@acedatacloud/nexior 3.277.3 → 3.277.4

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 (129) hide show
  1. package/dist/assets/{ApiCodeButton-C3NNEgIA.js → ApiCodeButton-DXN7iB8l.js} +1 -1
  2. package/dist/assets/{AskUserQuestionCard-BQrjaZfD.js → AskUserQuestionCard-CPQb26DU.js} +1 -1
  3. package/dist/assets/{Auth-B0pAJwBT.js → Auth-BkXFXHwC.js} +1 -1
  4. package/dist/assets/{Bare-Jr_u6Ip-.js → Bare-B5EPTD3k.js} +1 -1
  5. package/dist/assets/{BotPlaceholder-DFp0g5zS.js → BotPlaceholder-R_nAAbft.js} +1 -1
  6. package/dist/assets/{BottomFooter-J3fs48OL.js → BottomFooter-jepzQURF.js} +1 -1
  7. package/dist/assets/{Callback-DQu66NJR.js → Callback-DH3ldyqo.js} +1 -1
  8. package/dist/assets/{Console-BuT_Sy5O.js → Console-rsr21rbN.js} +1 -1
  9. package/dist/assets/{Consumption-Ci-3V7yB.js → Consumption-CjrpUNmV.js} +1 -1
  10. package/dist/assets/{Conversation-vmUlxDUt.js → Conversation-PmXYPnF1.js} +1 -1
  11. package/dist/assets/{CopyToClipboard-BvyK_FyK.js → CopyToClipboard-DXA4nHxo.js} +1 -1
  12. package/dist/assets/{Detail-DqdplcKY.js → Detail-BtKYzcA7.js} +2 -2
  13. package/dist/assets/{Extra-YxVzLWxN.js → Extra-B9rCcwWj.js} +1 -1
  14. package/dist/assets/{FilePreview-DyPtwSpl.js → FilePreview-Dqk4WVEr.js} +1 -1
  15. package/dist/assets/{Hailuo-CFky3Lrx.js → Hailuo-D_ir2qwk.js} +1 -1
  16. package/dist/assets/{History-BTlW60Z_.js → History-g_mPJBRP.js} +1 -1
  17. package/dist/assets/{ImagePreview-BOICGdPc.js → ImagePreview-Bkw_taCt.js} +1 -1
  18. package/dist/assets/{ImageWrapper-CjcxJKbz.js → ImageWrapper-BPvtDIMf.js} +1 -1
  19. package/dist/assets/{Index-CeOceb1r.js → Index-B6G7B2I0.js} +1 -1
  20. package/dist/assets/{Index-BleLHCzx.js → Index-BDGE5GsR.js} +1 -1
  21. package/dist/assets/{Index-nQFr7Mqq.js → Index-BHzERvOB.js} +1 -1
  22. package/dist/assets/{Index-C2xwzuPg.js → Index-BQWV4ACZ.js} +1 -1
  23. package/dist/assets/{Index-CoSl81hw.js → Index-C2M1W6HA.js} +1 -1
  24. package/dist/assets/{Index-CuspO5XN.js → Index-C2jzr33l.js} +1 -1
  25. package/dist/assets/{Index-DhKbeWPM.js → Index-C3yZt6r4.js} +1 -1
  26. package/dist/assets/{Index-9o2TcIhP.js → Index-C8zclc3l.js} +1 -1
  27. package/dist/assets/{Index-CL7PBeHi.js → Index-C9vdHrH1.js} +1 -1
  28. package/dist/assets/{Index-wxVuBy_P.js → Index-CEMmW0Xt.js} +1 -1
  29. package/dist/assets/{Index-BQhjdBiU.js → Index-CGQPNGH6.js} +1 -1
  30. package/dist/assets/{Index-mFG2r6T9.js → Index-CJ_B5PUw.js} +1 -1
  31. package/dist/assets/{Index-C6CTXHLR.js → Index-CTuEMRMq.js} +1 -1
  32. package/dist/assets/Index-CaYlG9QS.js +1 -0
  33. package/dist/assets/{Index-Bvt-5639.js → Index-ComARfRw.js} +1 -1
  34. package/dist/assets/{Index-Dd0is5a9.js → Index-CqgNerQP.js} +1 -1
  35. package/dist/assets/{Index-CuYlvz4a.js → Index-CycuKObu.js} +1 -1
  36. package/dist/assets/{Index-BNSvVx0-.js → Index-D3Do9QG2.js} +1 -1
  37. package/dist/assets/{Index-GojRL2Q0.js → Index-D9e-AGnZ.js} +1 -1
  38. package/dist/assets/{Index-BJAwNvvA.js → Index-DQ6WJNd4.js} +1 -1
  39. package/dist/assets/{Index-n0F8cB1P.js → Index-DSIgRXEN.js} +1 -1
  40. package/dist/assets/{Index-LsMI_8w6.js → Index-Dsbx7mYp.js} +1 -1
  41. package/dist/assets/{Index-peHUkz4M.js → Index-JB4pTHsw.js} +1 -1
  42. package/dist/assets/{Index-C2JSQHAI.css → Index-M4C0FZly.css} +1 -1
  43. package/dist/assets/{Index-BGsjWAH_.js → Index-Wn4WhxSA.js} +1 -1
  44. package/dist/assets/{Index-BcpcEBAL.js → Index-ZXaIaAWW.js} +1 -1
  45. package/dist/assets/{Index-C_I0V4J4.js → Index-ke_plb_v.js} +1 -1
  46. package/dist/assets/{Invitees-ZMTR5Mw5.js → Invitees-CtOjf0iy.js} +1 -1
  47. package/dist/assets/{List-CLixtUIF.js → List-CpB562Ry.js} +1 -1
  48. package/dist/assets/{List-OqkS3Z-y.js → List-DjAb-cmd.js} +1 -1
  49. package/dist/assets/{List-DANE1rC8.js → List-HnIA1E2e.js} +1 -1
  50. package/dist/assets/{Main-gX15SCD5.js → Main-BI0k19m6.js} +1 -1
  51. package/dist/assets/{Model-f_tXlzlC.js → Model-wnwwcJwj.js} +1 -1
  52. package/dist/assets/{Navigator-Bf2BQePt.js → Navigator-BknUSx4Z.js} +1 -1
  53. package/dist/assets/{NoTasks-C9x-H4Pc.js → NoTasks-568fhAGt.js} +1 -1
  54. package/dist/assets/{NotFound-5NCCtTs5.js → NotFound-Co5GcLDE.js} +1 -1
  55. package/dist/assets/{Pagination-ApvtnnDe.js → Pagination-C9VVozAy.js} +1 -1
  56. package/dist/assets/{Pay-D38fD_Tf.js → Pay-D0MlHd8L.js} +1 -1
  57. package/dist/assets/{Player-BjdmSEmF.js → Player--ctmekZs.js} +1 -1
  58. package/dist/assets/{Seedance-j5rWDeIn.js → Seedance-vljqSpVs.js} +1 -1
  59. package/dist/assets/{Status-CXBAckSE.js → Status-CvH_CBCZ.js} +1 -1
  60. package/dist/assets/{Subscribe-B9Ab7kYI.js → Subscribe-DCU6AfQa.js} +1 -1
  61. package/dist/assets/{TabSwitcher-BmrPOpEA.js → TabSwitcher-CHZ_ECnY.js} +1 -1
  62. package/dist/assets/{Tts-DBUqXpm5.js → Tts-DGZwUosH.js} +1 -1
  63. package/dist/assets/{VideoPlayer-BSYfg9U5.js → VideoPlayer-BjsbkQZc.js} +1 -1
  64. package/dist/assets/{avatar-D3Nl8Z28.js → avatar-CHgySyav.js} +1 -1
  65. package/dist/assets/{basic-BTtHOvX9.js → basic-CjTT_oRU.js} +1 -1
  66. package/dist/assets/{chat-DKrLfQP_.js → chat-BOAbBwQI.js} +1 -1
  67. package/dist/assets/{codingBridge-DOHIPtSS.js → codingBridge-Dxupvrte.js} +1 -1
  68. package/dist/assets/{codingBridgeNotify-B7il-Bzj.js → codingBridgeNotify-nSBbOsRW.js} +2 -2
  69. package/dist/assets/{collapse-_9L7y8Kn.js → collapse-B99-bYjk.js} +1 -1
  70. package/dist/assets/{constants-BVtW3DRs.js → constants-B6_fTlam.js} +1 -1
  71. package/dist/assets/{createTaskActions-BMPQj3BV.js → createTaskActions-CClbGT-n.js} +1 -1
  72. package/dist/assets/{date-picker-DeDPk0XD.js → date-picker-BtukkZrG.js} +1 -1
  73. package/dist/assets/{dropdown-BMnGWAZv.js → dropdown-BzFwppmF.js} +1 -1
  74. package/dist/assets/{esm-DosWasv4.js → esm-BOBX4dhx.js} +1 -1
  75. package/dist/assets/{esm-DACSoJup.js → esm-CWZTkeBt.js} +3 -3
  76. package/dist/assets/{esm-JIjkyeBW.js → esm-CyghH0i3.js} +2 -2
  77. package/dist/assets/{esm-EbY2HqLq.js → esm-DFfWKlEX.js} +1 -1
  78. package/dist/assets/esm-LoPWTfn9.js +1 -0
  79. package/dist/assets/{esm-COGYrEvv.js → esm-kL8Pp6jZ.js} +2 -2
  80. package/dist/assets/{esm-Dq5zq6dj.js → esm-l5ji9H4b.js} +1 -1
  81. package/dist/assets/{fish-nnTLWe7Q.js → fish-BWtzHFqO.js} +1 -1
  82. package/dist/assets/{flux-B6-tLWO8.js → flux-C-FqnDs4.js} +1 -1
  83. package/dist/assets/{grokvideo-CLpRWxm7.js → grokvideo-C9fmjCwH.js} +1 -1
  84. package/dist/assets/{hailuo-CJF4b-71.js → hailuo-BrfV-8h8.js} +1 -1
  85. package/dist/assets/{headshots-BO3pktL-.js → headshots-Mjvj0YDr.js} +1 -1
  86. package/dist/assets/{image-tzz5bG4l.js → image-tItcr5tZ.js} +1 -1
  87. package/dist/assets/{index-DGgsHGQJ.js → index-DpREqzJQ.js} +5 -5
  88. package/dist/assets/{index.browser.esm-C_K_MRCj.js → index.browser.esm-BVybW0ME.js} +1 -1
  89. package/dist/assets/{index.es-CX_i3qgT.js → index.es-DkXuZNXE.js} +1 -1
  90. package/dist/assets/{input-number-C6xd-oPl.js → input-number-BZClQnf5.js} +1 -1
  91. package/dist/assets/kling-DnnRrHSY.js +1 -0
  92. package/dist/assets/{kling-Bx6IczHr.js → kling-Rhjbl3yb.js} +1 -1
  93. package/dist/assets/{kling-aUagiKYM.js → kling-bCcngi_D.js} +1 -1
  94. package/dist/assets/{luma-BpBVPq9l.js → luma-BfJ45Nrp.js} +1 -1
  95. package/dist/assets/{midjourney-CtWadOHD.js → midjourney-BhBFIcGa.js} +1 -1
  96. package/dist/assets/{nanobanana-teIZjPc_.js → nanobanana-9yIPx-7N.js} +1 -1
  97. package/dist/assets/{openaiimage-DnsNbdBg.js → openaiimage-yBE3S9GR.js} +1 -1
  98. package/dist/assets/{pagination-CpCpCjbW.js → pagination-BQOE0Lce.js} +1 -1
  99. package/dist/assets/{pika-l6Hjyhl_.js → pika-BwDH6RXc.js} +1 -1
  100. package/dist/assets/{pixverse-BPE-YyOj.js → pixverse-V1u83-NJ.js} +1 -1
  101. package/dist/assets/{popover-D6hrrn0d.js → popover-BOyleW7G.js} +1 -1
  102. package/dist/assets/{producer-BwYjyAl1.js → producer-D5j29zwT.js} +1 -1
  103. package/dist/assets/{qrart-BaTJErnJ.js → qrart-BOGIYlCy.js} +1 -1
  104. package/dist/assets/{row-B3j6500Z.js → row-D8loqAPL.js} +1 -1
  105. package/dist/assets/{seedance-DPupGdGX.js → seedance-BFWs3OMD.js} +1 -1
  106. package/dist/assets/{seedream-CUfAjPXi.js → seedream-PMGj_GEr.js} +1 -1
  107. package/dist/assets/{select-CqM5oalI.js → select-CYdISXBV.js} +1 -1
  108. package/dist/assets/{serp-C6wH_snl.js → serp-BXsV4ruQ.js} +1 -1
  109. package/dist/assets/{slider-Dr2SA5cy.js → slider-heMG04zo.js} +1 -1
  110. package/dist/assets/{solana-wallets-Dd_x7gzO.js → solana-wallets-DpEYEH8X.js} +2 -2
  111. package/dist/assets/{solana-wallets-vue-C896qtEf.js → solana-wallets-vue-DwDUK9GJ.js} +1 -1
  112. package/dist/assets/{sora-2YLk-g1l.js → sora-BPluLKCF.js} +1 -1
  113. package/dist/assets/{suno-OuJ5-ifF.js → suno-B3FfSfsu.js} +1 -1
  114. package/dist/assets/{switch-DzVsc9s3.js → switch-DT8swXGq.js} +1 -1
  115. package/dist/assets/{tabs-DCtQDb8I.js → tabs-DbqhD0Ri.js} +1 -1
  116. package/dist/assets/{upload-C7rPv2P3.js → upload-CHAO8dYa.js} +1 -1
  117. package/dist/assets/{veo-CiywFUme.js → veo--ebyIQZO.js} +1 -1
  118. package/dist/assets/{wan-Dpdolh0u.js → wan-QNzJ6Wsl.js} +1 -1
  119. package/dist/assets/{web-DFYDb5Ka.js → web-B3c_92-W.js} +1 -1
  120. package/dist/assets/{web-2EV-7FEo.js → web-BhPhz6gK.js} +1 -1
  121. package/dist/assets/{web-CPsOCiaz.js → web-CggzH-kj.js} +1 -1
  122. package/dist/assets/{web-DCVaZkxt.js → web-DaBpN21i.js} +1 -1
  123. package/dist/assets/{web-CSHQzItc.js → web-Dslc1DMt.js} +1 -1
  124. package/dist/assets/{webextrator-yjRn1FFS.js → webextrator-BVPmDKBS.js} +1 -1
  125. package/dist/index.html +2 -2
  126. package/package.json +1 -1
  127. package/dist/assets/Index-CvqxRHFv.js +0 -1
  128. package/dist/assets/esm-DDA6R-b4.js +0 -1
  129. package/dist/assets/kling-dnFKynlT.js +0 -1
@@ -1 +1 @@
1
- import"./rolldown-runtime--c01j_DQ.js";import{$ as e,Bt as t,D as n,E as r,M as i,N as a,O as o,P as s,Q as c,Ut as l,X as u,_ as d,et as f,k as p,lt as m,ut as h,x as g}from"./vendor-chart-mdwpew_o.js";import{t as _}from"./button-DWzbdjZV.js";import{r as v,t as y}from"./select-CqM5oalI.js";import{t as b}from"./upload-C7rPv2P3.js";import{t as x}from"./tooltip-C3PYfh8V.js";import{t as S}from"./image-tzz5bG4l.js";import{t as C}from"./alert-BJj7gY4q.js";import{n as w,r as T}from"./radio-IJQsW93X.js";import{t as ee}from"./drawer-BvYPSxXh.js";import{t as E}from"./switch-DzVsc9s3.js";import{Cr as D,hi as O}from"./constants-BVtW3DRs.js";import{An as k,At as te,E as A,Fn as j,Nt as M,Ot as N,Sr as P,jt as F,kr as I,kt as L,mn as R,yr as z}from"./index-DGgsHGQJ.js";import{t as B}from"./index.es-CX_i3qgT.js";import{t as V}from"./CopyToClipboard-BvyK_FyK.js";import{t as H}from"./ImagePreview-BOICGdPc.js";import{n as U}from"./taskDrawerMixin-Cr17Yxqk.js";import{t as W}from"./BotPlaceholder-DFp0g5zS.js";import{i as G,n as K,t as q}from"./pagination-CpCpCjbW.js";import{n as J,t as Y}from"./NoTasks-C9x-H4Pc.js";import{t as X}from"./Consumption-Ci-3V7yB.js";import{t as Z}from"./ApiCodeButton-C3NNEgIA.js";import{t as Q}from"./vue-plyr-wiIKa-zl.js";var ne=s({name:`LayoutPika`,components:{ElDrawer:ee,ElButton:_,FontAwesomeIcon:B},mixins:[U]}),re={class:`main flex flex-row flex-1`},ie={class:`config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]`},ae={class:`result h-full p-6 flex-1 flex flex-col min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]`};function oe(t,n,i,o,s,c){let l=f(`font-awesome-icon`),g=f(`el-button`),_=f(`el-drawer`);return u(),p(`div`,re,[r(`div`,ie,[e(t.$slots,`config`,{},void 0,!0)]),r(`div`,ae,[e(t.$slots,`result`,{},void 0,!0)]),h(a(g,{circle:``,class:`menu`,onClick:n[0]||=e=>t.drawer=!0},{default:m(()=>[a(l,{icon:`fa-solid fa-magic`})]),_:1},512),[[d,!t.tasksEmpty]]),a(_,{modelValue:t.drawer,"onUpdate:modelValue":n[1]||=e=>t.drawer=e,direction:`ltr`,"with-header":!1,size:`350px`},{default:m(()=>[e(t.$slots,`config`,{},void 0,!0)]),_:3},8,[`modelValue`])])}var se=A(ne,[[`render`,oe],[`__scopeId`,`data-v-cbfdbeb3`]]),ce=s({name:`IngredientsSelector`,components:{ElSwitch:E,InfoIcon:G},computed:{value:{get(){return this.$store.state.pika?.config?.ingredients},set(e){console.debug(`set ingredients`,e),e||this.$store.commit(`pika/setConfig`,{...this.$store.state.pika?.config,ingredients:e,ingredients_mode:void 0,image_url:void 0}),this.$store.commit(`pika/setConfig`,{...this.$store.state.pika?.config,ingredients:e,model:`2.0`})}}},mounted(){this.value===void 0&&(this.value=!1)}}),le={class:`field`},ue={class:`title font-bold`};function de(e,t,n,i,o,s){let c=f(`el-switch`),d=f(`info-icon`);return u(),p(`div`,le,[r(`h2`,ue,l(e.$t(`pika.name.ingredients`)),1),a(c,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,class:`value`},null,8,[`modelValue`]),a(d,{content:e.$t(`pika.description.ingredients`),class:`info`},null,8,[`content`])])}var fe=A(ce,[[`render`,de],[`__scopeId`,`data-v-17c0af5c`]]),pe=s({name:`EffectSelector`,components:{ElSelect:v,ElOption:y},data(){return{}},computed:{options(){return[{value:`Levitate`,label:this.$t(`pika.style.effect1`)},{value:`Decapitate`,label:this.$t(`pika.style.effect2`)},{value:`Eye-pop`,label:this.$t(`pika.style.effect3`)},{value:`Ta-da`,label:this.$t(`pika.style.effect4`)},{value:`Deflate`,label:this.$t(`pika.style.effect5`)},{value:`Crumble`,label:this.$t(`pika.style.effect6`)},{value:`Dissolve`,label:this.$t(`pika.style.effect7`)},{value:`Squish`,label:this.$t(`pika.style.effect8`)},{value:`Inflate`,label:this.$t(`pika.style.effect9`)},{value:`Melt`,label:this.$t(`pika.style.effect10`)},{value:`Cake-ify`,label:this.$t(`pika.style.effect11`)},{value:`Crush`,label:this.$t(`pika.style.effect12`)},{value:`Explode`,label:this.$t(`pika.style.effect13`)}]},value:{get(){return this.$store.state.pika?.config?.effect},set(e){this.$store.commit(`pika/setConfig`,{...this.$store.state.pika?.config,effect:e})}}}}),me={class:`field`},he={class:`title font-bold`},ge={class:`float-left`};function _e(e,t,i,o,s,d){let h=f(`el-option`),_=f(`el-select`);return u(),p(`div`,me,[r(`h2`,he,l(e.$t(`pika.name.effect`)),1),a(_,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,class:`value`,placeholder:e.$t(`pika.placeholder.select`),clearable:``},{default:m(()=>[(u(!0),p(g,null,c(e.options,e=>(u(),n(h,{key:e.value,label:e.label,value:e.value},{default:m(()=>[r(`span`,ge,l(e.label),1)]),_:2},1032,[`label`,`value`]))),128))]),_:1},8,[`modelValue`,`placeholder`])])}var ve=A(pe,[[`render`,_e],[`__scopeId`,`data-v-d1c54475`]]),ye=s({name:`IngredientsModelSelector`,components:{ElRadioButton:w,ElRadioGroup:T},data(){return{options:[{label:this.$t(`pika.button.precise`),value:`precise`},{label:this.$t(`pika.button.creative`),value:`creative`}]}},computed:{value:{get(){return this.$store.state.pika?.config?.ingredients_mode},set(e){this.$store.commit(`pika/setConfig`,{...this.$store.state.pika?.config,ingredients_mode:e})}}},mounted(){this.value||=D}}),be={class:`field`},xe={class:`title font-bold`};function Se(e,t,o,s,d,h){let _=f(`el-radio-button`),v=f(`el-radio-group`);return u(),p(`div`,be,[r(`h2`,xe,l(e.$t(`pika.name.ingredientsModel`)),1),a(v,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,class:`quality`},{default:m(()=>[(u(!0),p(g,null,c(e.options,e=>(u(),n(_,{key:e.value,label:e.value},{default:m(()=>[i(l(e.label),1)]),_:2},1032,[`label`]))),128))]),_:1},8,[`modelValue`])])}var Ce=A(ye,[[`render`,Se],[`__scopeId`,`data-v-b72865fa`]]),we=s({name:`ModelSelector`,components:{ElSelect:v,ElOption:y},props:{modelValue:{type:String,default:void 0}},emits:[`update:modelValue`],data(){return{options:[{value:`2.0`,label:`2.0`},{value:`1.5`,label:`1.5`}]}},computed:{value:{get(){return this.$store.state.pika?.config?.model},set(e){this.$store.commit(`pika/setConfig`,{...this.$store.state.pika.config,model:e})}}},mounted(){this.value||=`2.0`}}),Te={class:`field`},Ee={class:`title font-bold`};function De(e,t,i,o,s,d){let h=f(`el-option`),_=f(`el-select`);return u(),p(`div`,Te,[r(`h2`,Ee,l(e.$t(`pika.name.model`)),1),a(_,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,class:`value`,placeholder:e.$t(`pika.placeholder.select`)},{default:m(()=>[(u(!0),p(g,null,c(e.options,e=>(u(),n(h,{key:e.value,label:e.label,value:e.value},null,8,[`label`,`value`]))),128))]),_:1},8,[`modelValue`,`placeholder`])])}var Oe=A(we,[[`render`,De],[`__scopeId`,`data-v-7b2e870a`]]),ke=s({name:`ImageUrlInput`,components:{ElUpload:b,ElButton:_,InfoIcon:G,ImagePreview:H,FontAwesomeIcon:B},mixins:[F,L],data(){return{fileList:[],uploadUrl:P()+`/api/v1/files/`}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e?.response?.file_url)},value:{get(){return this.$store.state.pika?.config?.image_url},set(){let e=this.urls?.[0];this.$store.commit(`pika/setConfig`,{...this.$store.state.pika?.config,image_url:e})}}},mounted(){this.value||=void 0,this.onSetStartImageUrl()},methods:{onExceed(){I.warning(this.$t(`pika.message.uploadStartImageExceed`))},onError(){I.error(this.$t(`pika.message.uploadStartImageError`))},async onRemove(){I.error(this.$t(`pika.message.uploadStartImageError`))},onSetStartImageUrl(){this.$store.commit(`pika/setConfig`,{...this.$store.state.pika?.config,image_url:this.urls})},async onSuccess(){this.onSetStartImageUrl()}}}),Ae={class:`field`},je={class:`title font-bold`},Me={class:`upload-wrapper`};function Ne(e,t,n,o,s,c){let d=f(`image-preview`),h=f(`font-awesome-icon`),g=f(`el-button`),_=f(`el-upload`),v=f(`info-icon`);return u(),p(`div`,Ae,[r(`h2`,je,l(e.$t(`pika.name.imageUrl`)),1),r(`div`,Me,[a(_,{ref:`uploader`,"file-list":e.fileList,"onUpdate:fileList":t[0]||=t=>e.fileList=t,accept:`.png,.jpg,.jpeg,.gif,.bmp,.webp`,name:`file`,class:`value upload-wrapper`,limit:3,multiple:!0,"list-type":`picture`,action:e.uploadUrl,"on-exceed":e.onExceed,"on-error":e.onError,"on-remove":e.onRemove,"on-success":e.onSuccess,headers:e.headers},{file:m(({file:t})=>[a(d,{url:t.url||t.response?.file_url,name:t.name,percentage:t.percentage,onRemove:n=>e.fileList.splice(e.fileList.indexOf(t),1)},null,8,[`url`,`name`,`percentage`,`onRemove`])]),default:m(()=>[a(g,{size:`small`,type:`primary`,round:``},{default:m(()=>[a(h,{icon:`fa-solid fa-upload`,class:`mr-1`}),i(` `+l(e.$t(`pika.button.uploadImageUrl`)),1)]),_:1})]),_:1},8,[`file-list`,`action`,`on-exceed`,`on-error`,`on-remove`,`on-success`,`headers`])]),a(v,{content:e.$t(`pika.description.imageUrl`),class:`info`},null,8,[`content`])])}var Pe=A(ke,[[`render`,Ne],[`__scopeId`,`data-v-25cefe78`]]),Fe=s({name:`PromptInput`,components:{PromptTextarea:J},computed:{prompt:{get(){return this.$store.state.pika?.config?.prompt},set(e){this.$store.commit(`pika/setConfig`,{...this.$store.state.pika?.config,prompt:e})}}},mounted(){this.prompt||=``}});function Ie(e,t,r,i,a,o){let s=f(`prompt-textarea`);return u(),n(s,{modelValue:e.prompt,"onUpdate:modelValue":t[0]||=t=>e.prompt=t,title:e.$t(`pika.name.prompt`),info:e.$t(`pika.description.prompt`),placeholder:e.$t(`pika.placeholder.prompt`)},null,8,[`modelValue`,`title`,`info`,`placeholder`])}var Le=s({name:`PresetPanel`,components:{ImageUrlInput:Pe,ElButton:_,FontAwesomeIcon:B,Consumption:X,PromptInput:A(Fe,[[`render`,Ie]]),IngredientsSelector:fe,IngredientsModelSelector:Ce,ModelSelector:Oe,EffectSelector:ve},emits:[`generate`],computed:{config(){return this.$store.state.pika?.config},consumption(){return M(this.config,this.service?.cost)},service(){return this.$store.state.pika?.service}},methods:{onGenerate(){this.$emit(`generate`)}}}),Re={class:`flex flex-col h-full`},ze={class:`flex-1 overflow-y-auto p-5`},Be={class:`flex flex-col items-center justify-center px-5 pb-5`};function Ve(e,t,s,c,d,h){let g=f(`prompt-input`),_=f(`model-selector`),v=f(`ingredients-selector`),y=f(`effect-selector`),b=f(`image-url-input`),x=f(`ingredients-model-selector`),S=f(`consumption`),C=f(`font-awesome-icon`),w=f(`el-button`);return u(),p(`div`,Re,[r(`div`,ze,[a(g,{class:`mb-4`}),a(_,{class:`mb-4`}),a(v,{class:`mb-4`}),a(y,{class:`mb-4`}),e.config?.ingredients?(u(),n(b,{key:0,class:`mb-4`})):o(``,!0),e.config?.ingredients?(u(),n(x,{key:1,class:`mb-4`})):o(``,!0)]),r(`div`,Be,[a(S,{value:e.consumption,service:e.service},null,8,[`value`,`service`]),a(w,{type:`primary`,class:`btn w-full`,round:``,onClick:e.onGenerate},{default:m(()=>[a(C,{icon:`fa-solid fa-magic`,class:`mr-2`}),i(` `+l(e.$t(`pika.button.generate`)),1)]),_:1},8,[`onClick`])])])}var He=A(Le,[[`render`,Ve]]),Ue=s({name:`VideoPlayer`,components:{VuePlyr:Q},props:{modelValue:{type:Object,required:!0}},data(){return{options:{quality:{default:1080,options:[1080]}}}}}),We=[`data-poster`],Ge=[`src`];function Ke(e,t,n,i,o,s){let c=f(`vue-plyr`);return u(),p(`div`,null,[a(c,{options:e.options,class:`video`},{default:m(()=>[r(`video`,{controls:``,playsinline:``,preload:`metadata`,"data-poster":e.modelValue?.image_url},[r(`source`,{size:`1080`,src:e.modelValue?.video_url,type:`video/mp4`},null,8,Ge)],8,We)]),_:1},8,[`options`])])}var qe=s({name:`TaskPreview`,components:{ElImage:S,CopyToClipboard:V,FontAwesomeIcon:B,ElAlert:C,VideoPlayer:A(Ue,[[`render`,Ke],[`__scopeId`,`data-v-897d9fe0`]]),ElTooltip:x,ElButton:_,ApiCodeButton:Z},props:{modelValue:{type:Object,required:!0}},data(){return{}},computed:{application(){return this.$store.state.pika?.application},config(){return this.$store.state.pika?.config},videos(){let e=[],t=this.modelValue?.request?.action;return Array.isArray(this.modelValue?.response?.data)&&this.modelValue?.response?.data?.forEach(n=>{let r=n;t&&(r.action=t),e.push(r)}),e}},methods:{onDownload(e){console.log(`on download`),window.open(e,`_blank`)},onReload(e){let t=e.target,n=new URL(t.src),r=n.searchParams.get(`retry`);if(!r)n.searchParams.set(`retry`,`1`);else if(parseInt(r)<2)n.searchParams.set(`retry`,(parseInt(r)+1).toString());else return;t.src=n.toString()},onOpenVideo(e){window.open(e,`_blank`)}}}),Je={class:`left`},Ye={class:`main`},Xe={class:`bot`},Ze={class:`datetime`},Qe={class:`info`},$e={key:0,class:`prompt mt-2`},et={key:0},tt={key:1},nt={key:0,class:t({content:!0,failed:!0})},rt={class:`image-wrapper`},it={key:0,class:t({operations:!0,"mt-2":!0})},at={key:0,class:`description`},ot={class:`description`},st={key:1,class:`description`},ct={key:1,class:t({content:!0})},lt={class:`description`},ut={class:`description`},dt={key:0,class:`description`},ft={class:`description`},$={key:2,class:t({content:!0})},pt={class:`description`};function mt(e,t,s,d,h,_){let v=f(`el-image`),y=f(`VideoPlayer`),b=f(`el-button`),x=f(`el-tooltip`),S=f(`api-code-button`),C=f(`font-awesome-icon`),w=f(`copy-to-clipboard`),T=f(`el-alert`);return u(!0),p(g,null,c(e.videos,(t,s)=>(u(),p(`div`,{key:s,class:`preview`},[r(`div`,Je,[a(v,{src:`https://cdn.acedata.cloud/i80tgn.png`,class:`avatar`})]),r(`div`,Ye,[r(`div`,Xe,[i(l(e.$t(`pika.name.pikaBot`))+` `,1),r(`span`,Ze,l(e.$dayjs.format(``+new Date(parseFloat((e.modelValue?.created_at||``).toString())*1e3))),1)]),r(`div`,Qe,[e.modelValue?.request?.prompt?(u(),p(`p`,$e,[i(l(e.modelValue?.request?.prompt)+` `,1),e.modelValue?.response?o(``,!0):(u(),p(`span`,et,` - (`+l(e.$t(`pika.status.pending`))+`) `,1)),t?.state===`processing`||t?.state===`pending`?(u(),p(`span`,tt,` - (`+l(e.$t(`pika.status.processing`))+`) `,1)):o(``,!0)])):o(``,!0)]),e.modelValue?.response?.success===!0?(u(),p(`div`,nt,[r(`div`,rt,[a(y,{"model-value":t},null,8,[`model-value`])]),t?(u(),p(`div`,it,[a(x,{class:`box-item`,effect:`dark`,content:e.$t(`pika.message.downloadVideo`),placement:`top-start`},{default:m(()=>[t?.video_url?(u(),n(b,{key:0,type:`info`,size:`small`,class:`btn-action`,onClick:n=>e.onDownload(t?.video_url)},{default:m(()=>[i(l(e.$t(`pika.button.download`)),1)]),_:1},8,[`onClick`])):o(``,!0)]),_:2},1032,[`content`]),a(S,{path:`/pika/videos`,body:e.modelValue?.request},null,8,[`body`])])):o(``,!0),a(T,{closable:!1,class:`mt-2 success`},{default:m(()=>[e.modelValue?.request?.model?(u(),p(`p`,at,[a(C,{icon:`fa-solid fa-hashtag`,class:`mr-1`}),i(` `+l(e.$t(`pika.name.model`))+`: `+l(e.modelValue?.request?.model),1)])):o(``,!0),r(`p`,ot,[a(C,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+l(e.$t(`pika.name.taskId`))+`: `+l(e.modelValue?.id)+` `,1),a(w,{content:e.modelValue?.id,class:`btn-copy`},null,8,[`content`])]),e.modelValue?.elapsed?(u(),p(`p`,st,[a(C,{icon:`fa-solid fa-clock`,class:`mr-1`}),i(` `+l(e.$t(`pika.name.elapsed`))+`: `+l(e.modelValue?.elapsed?.toFixed(2))+`s `,1)])):o(``,!0)]),_:1})])):o(``,!0),e.modelValue?.response?.success===!1?(u(),p(`div`,ct,[a(T,{closable:!1,class:`failure`},{template:m(()=>[a(C,{icon:`fa-solid fa-exclamation-triangle`,class:`mr-1`}),i(` `+l(e.$t(`pika.name.failure`)),1)]),default:m(()=>[r(`p`,lt,[a(C,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+l(e.$t(`pika.name.taskId`))+`: `+l(e.modelValue?.id)+` `,1),a(w,{content:e.modelValue?.id,class:`btn-copy`},null,8,[`content`])]),r(`p`,ut,[a(C,{icon:`fa-solid fa-circle-info`,class:`mr-1`}),i(` `+l(e.$t(`pika.name.failureReason`))+`: `+l(e.modelValue?.response?.error?.message)+` `,1),a(w,{content:e.modelValue?.response?.error?.message,class:`btn-copy`},null,8,[`content`])]),e.modelValue?.elapsed?(u(),p(`p`,dt,[a(C,{icon:`fa-solid fa-clock`,class:`mr-1`}),i(` `+l(e.$t(`pika.name.elapsed`))+`: `+l(e.modelValue?.elapsed?.toFixed(2))+`s `,1)])):o(``,!0),r(`p`,ft,[a(C,{icon:`fa-solid fa-hashtag`,class:`mr-1`}),i(` `+l(e.$t(`pika.name.traceId`))+`: `+l(e.modelValue?.response?.trace_id)+` `,1),a(w,{content:e.modelValue?.response?.trace_id,class:`btn-copy`},null,8,[`content`])])]),_:1})])):o(``,!0),!e.modelValue?.response||t?.state===`processing`||t?.state===`pending`?(u(),p(`div`,$,[a(T,{closable:!1,class:`info`},{template:m(()=>[a(C,{icon:`fa-solid fa-exclamation-triangle`,class:`mr-1`}),i(` `+l(e.$t(`pika.name.failure`)),1)]),default:m(()=>[r(`p`,pt,[a(C,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+l(e.$t(`pika.name.taskId`))+`: `+l(e.modelValue?.id)+` `,1),a(w,{content:e.modelValue?.id,class:`btn-copy`},null,8,[`content`])])]),_:1})])):o(``,!0)])]))),128)}var ht=s({name:`RecentPanel`,components:{TaskPreview:A(qe,[[`render`,mt],[`__scopeId`,`data-v-52856c99`]]),BotPlaceholder:W,NoTasks:Y,ScrollList:K},props:{loading:{type:Boolean,default:!1}},emits:[`reach-top`],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.pika?.tasks,items:this.$store.state.pika?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),gt={key:0},_t={key:2,class:`w-full h-full flex items-center justify-center`};function vt(e,t,r,i,s,l){let d=f(`bot-placeholder`),h=f(`task-preview`),_=f(`scroll-list`),v=f(`no-tasks`);return u(),p(g,null,[e.tasks?.items===void 0?(u(),p(`div`,gt,[a(d)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(u(),n(_,{key:1,ref:`scrollList`,class:`tasks h-full w-full overflow-y-auto`,loading:e.loading,onReachTop:t[0]||=t=>e.$emit(`reach-top`)},{default:m(()=>[(u(!0),p(g,null,c(e.tasks?.items,(e,t)=>(u(),n(h,{key:t,"model-value":e},null,8,[`model-value`]))),128))]),_:1},8,[`loading`])):o(``,!0),e.tasks?.items?.length===0?(u(),p(`div`,_t,[a(v)])):o(``,!0)],64)}var yt=A(ht,[[`render`,vt]]),bt=O(`pika`),xt=s({name:`PikaIndex`,components:{ConfigPanel:He,Layout:se,RecentPanel:yt},mixins:[te],inject:[`initialized`],data(){return{task:void 0,job:0,loadingMore:!1,fetchingTasks:!1}},computed:{applicationsLoading(){return this.$store.state.pika?.status?.getApplications===z.Request},tasksLoading(){return this.$store.state.pika?.status?.getTasks===z.Request||this.fetchingTasks},service(){return this.$store.state.pika.service},credential(){return this.$store.state.pika.credential},config(){return this.$store.state.pika.config},initializing(){return this.$store.state.pika.status.getApplications===z.Request},needApply(){return this.$store.state.pika.status.getApplications===z.Success&&!this.application},application(){return this.$store.state.pika.application},applications(){return this.$store.state.pika.applications},tasks(){return this.$store.state.pika.tasks}},watch:{tasks:{handler(e,t){e?.items?.length>t?.items?.length&&console.debug(`new tasks detected`)},deep:!0},initialized:{async handler(e){e&&(console.debug(`layout initialized`),await this.onGetTasks(),await this.onScrollDown(),this.job=window.setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){window.clearInterval(this.job)},methods:{async onReachTop(){await q({tasks:this.tasks,getTasks:()=>this.tasks,loading:this.loadingMore,setLoading:e=>this.loadingMore=e,isBlocked:()=>this.tasksLoading||this.applicationsLoading,fetch:e=>this.onGetTasks({createdAtMax:e}),getScrollElement:()=>this.getTasksScrollElement()})},async onGetService(){console.debug(`start onGetService`),await this.$store.dispatch(`pika/getService`),console.debug(`end onGetService`)},async onGetApplication(){console.debug(`start onGetApplication`),await this.$store.dispatch(`pika/getApplications`),console.debug(`end onGetApplication`),await this.onGetTasks()},onApply(){k.create({application:this.application}).then(({data:e})=>{this.application=e,I.success(this.$t(`application.message.applySuccessfully`))}).catch(e=>{e?.response?.data?.code===`duplication`&&I.error(this.$t(`application.message.alreadyApplied`))})},async onScrollDown(){await this.$nextTick();let e=this.getTasksScrollElement();e&&(e.scrollTop=e.scrollHeight)},async onGetTasks(e){if(this.applicationsLoading||this.fetchingTasks){console.debug(`loading`);return}console.debug(`start onGetTasks`,e);let{limit:t=5,createdAtMin:n,createdAtMax:r}=e||{};console.debug(`limit`,t,`createdAtMin`,n,`createdAtMax`,r),this.fetchingTasks=!0;try{await this.$store.dispatch(`pika/getTasks`,{limit:t,createdAtMin:n,createdAtMax:r})}finally{this.fetchingTasks=!1}},async onGenerate(){if(!N(this.uploadTracker,e=>this.$t(e),e=>I.warning(e)))return;let e={...this.config,callback_url:bt},t=this.credential?.token;if(!t){console.error(`no token specified`);return}I.info(this.$t(`pika.message.startingTask`)),j(`pika`,R.generate(e,{token:t})).then(()=>{I.success(this.$t(`pika.message.startTaskSuccess`)),this.$store.commit(`pika/setConfig`,{config:void 0})}).catch(e=>{(e?.response?.data)?.error?.code===`used_up`?I.error(this.$t(`pika.message.usedUp`)):I.error(this.$t(`pika.message.startTaskFailed`))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function St(e,t,r,i,o,s){let c=f(`config-panel`),l=f(`recent-panel`),d=f(`layout`);return u(),n(d,null,{config:m(()=>[a(c,{onGenerate:e.onGenerate},null,8,[`onGenerate`])]),result:m(()=>[a(l,{ref:`recentPanel`,class:`panel recent`,loading:e.loadingMore,onReachTop:e.onReachTop},null,8,[`loading`,`onReachTop`])]),_:1})}var Ct=A(xt,[[`render`,St],[`__scopeId`,`data-v-eae39ce1`]]);export{Ct as default};
1
+ import"./rolldown-runtime--c01j_DQ.js";import{$ as e,Bt as t,D as n,E as r,M as i,N as a,O as o,P as s,Q as c,Ut as l,X as u,_ as d,et as f,k as p,lt as m,ut as h,x as g}from"./vendor-chart-mdwpew_o.js";import{t as _}from"./button-DWzbdjZV.js";import{r as v,t as y}from"./select-CYdISXBV.js";import{t as b}from"./upload-CHAO8dYa.js";import{t as x}from"./tooltip-C3PYfh8V.js";import{t as S}from"./image-tItcr5tZ.js";import{t as C}from"./alert-BJj7gY4q.js";import{n as w,r as T}from"./radio-IJQsW93X.js";import{t as ee}from"./drawer-BvYPSxXh.js";import{t as E}from"./switch-DT8swXGq.js";import{Cr as D,hi as O}from"./constants-B6_fTlam.js";import{An as k,At as te,E as A,Fn as j,Nt as M,Ot as N,Sr as P,jt as F,kr as I,kt as L,mn as R,yr as z}from"./index-DpREqzJQ.js";import{t as B}from"./index.es-DkXuZNXE.js";import{t as V}from"./CopyToClipboard-DXA4nHxo.js";import{t as H}from"./ImagePreview-Bkw_taCt.js";import{n as U}from"./taskDrawerMixin-Cr17Yxqk.js";import{t as W}from"./BotPlaceholder-R_nAAbft.js";import{i as G,n as K,t as q}from"./pagination-BQOE0Lce.js";import{n as J,t as Y}from"./NoTasks-568fhAGt.js";import{t as X}from"./Consumption-CjrpUNmV.js";import{t as Z}from"./ApiCodeButton-DXN7iB8l.js";import{t as Q}from"./vue-plyr-wiIKa-zl.js";var ne=s({name:`LayoutPika`,components:{ElDrawer:ee,ElButton:_,FontAwesomeIcon:B},mixins:[U]}),re={class:`main flex flex-row flex-1`},ie={class:`config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]`},ae={class:`result h-full p-6 flex-1 flex flex-col min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]`};function oe(t,n,i,o,s,c){let l=f(`font-awesome-icon`),g=f(`el-button`),_=f(`el-drawer`);return u(),p(`div`,re,[r(`div`,ie,[e(t.$slots,`config`,{},void 0,!0)]),r(`div`,ae,[e(t.$slots,`result`,{},void 0,!0)]),h(a(g,{circle:``,class:`menu`,onClick:n[0]||=e=>t.drawer=!0},{default:m(()=>[a(l,{icon:`fa-solid fa-magic`})]),_:1},512),[[d,!t.tasksEmpty]]),a(_,{modelValue:t.drawer,"onUpdate:modelValue":n[1]||=e=>t.drawer=e,direction:`ltr`,"with-header":!1,size:`350px`},{default:m(()=>[e(t.$slots,`config`,{},void 0,!0)]),_:3},8,[`modelValue`])])}var se=A(ne,[[`render`,oe],[`__scopeId`,`data-v-cbfdbeb3`]]),ce=s({name:`IngredientsSelector`,components:{ElSwitch:E,InfoIcon:G},computed:{value:{get(){return this.$store.state.pika?.config?.ingredients},set(e){console.debug(`set ingredients`,e),e||this.$store.commit(`pika/setConfig`,{...this.$store.state.pika?.config,ingredients:e,ingredients_mode:void 0,image_url:void 0}),this.$store.commit(`pika/setConfig`,{...this.$store.state.pika?.config,ingredients:e,model:`2.0`})}}},mounted(){this.value===void 0&&(this.value=!1)}}),le={class:`field`},ue={class:`title font-bold`};function de(e,t,n,i,o,s){let c=f(`el-switch`),d=f(`info-icon`);return u(),p(`div`,le,[r(`h2`,ue,l(e.$t(`pika.name.ingredients`)),1),a(c,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,class:`value`},null,8,[`modelValue`]),a(d,{content:e.$t(`pika.description.ingredients`),class:`info`},null,8,[`content`])])}var fe=A(ce,[[`render`,de],[`__scopeId`,`data-v-17c0af5c`]]),pe=s({name:`EffectSelector`,components:{ElSelect:v,ElOption:y},data(){return{}},computed:{options(){return[{value:`Levitate`,label:this.$t(`pika.style.effect1`)},{value:`Decapitate`,label:this.$t(`pika.style.effect2`)},{value:`Eye-pop`,label:this.$t(`pika.style.effect3`)},{value:`Ta-da`,label:this.$t(`pika.style.effect4`)},{value:`Deflate`,label:this.$t(`pika.style.effect5`)},{value:`Crumble`,label:this.$t(`pika.style.effect6`)},{value:`Dissolve`,label:this.$t(`pika.style.effect7`)},{value:`Squish`,label:this.$t(`pika.style.effect8`)},{value:`Inflate`,label:this.$t(`pika.style.effect9`)},{value:`Melt`,label:this.$t(`pika.style.effect10`)},{value:`Cake-ify`,label:this.$t(`pika.style.effect11`)},{value:`Crush`,label:this.$t(`pika.style.effect12`)},{value:`Explode`,label:this.$t(`pika.style.effect13`)}]},value:{get(){return this.$store.state.pika?.config?.effect},set(e){this.$store.commit(`pika/setConfig`,{...this.$store.state.pika?.config,effect:e})}}}}),me={class:`field`},he={class:`title font-bold`},ge={class:`float-left`};function _e(e,t,i,o,s,d){let h=f(`el-option`),_=f(`el-select`);return u(),p(`div`,me,[r(`h2`,he,l(e.$t(`pika.name.effect`)),1),a(_,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,class:`value`,placeholder:e.$t(`pika.placeholder.select`),clearable:``},{default:m(()=>[(u(!0),p(g,null,c(e.options,e=>(u(),n(h,{key:e.value,label:e.label,value:e.value},{default:m(()=>[r(`span`,ge,l(e.label),1)]),_:2},1032,[`label`,`value`]))),128))]),_:1},8,[`modelValue`,`placeholder`])])}var ve=A(pe,[[`render`,_e],[`__scopeId`,`data-v-d1c54475`]]),ye=s({name:`IngredientsModelSelector`,components:{ElRadioButton:w,ElRadioGroup:T},data(){return{options:[{label:this.$t(`pika.button.precise`),value:`precise`},{label:this.$t(`pika.button.creative`),value:`creative`}]}},computed:{value:{get(){return this.$store.state.pika?.config?.ingredients_mode},set(e){this.$store.commit(`pika/setConfig`,{...this.$store.state.pika?.config,ingredients_mode:e})}}},mounted(){this.value||=D}}),be={class:`field`},xe={class:`title font-bold`};function Se(e,t,o,s,d,h){let _=f(`el-radio-button`),v=f(`el-radio-group`);return u(),p(`div`,be,[r(`h2`,xe,l(e.$t(`pika.name.ingredientsModel`)),1),a(v,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,class:`quality`},{default:m(()=>[(u(!0),p(g,null,c(e.options,e=>(u(),n(_,{key:e.value,label:e.value},{default:m(()=>[i(l(e.label),1)]),_:2},1032,[`label`]))),128))]),_:1},8,[`modelValue`])])}var Ce=A(ye,[[`render`,Se],[`__scopeId`,`data-v-b72865fa`]]),we=s({name:`ModelSelector`,components:{ElSelect:v,ElOption:y},props:{modelValue:{type:String,default:void 0}},emits:[`update:modelValue`],data(){return{options:[{value:`2.0`,label:`2.0`},{value:`1.5`,label:`1.5`}]}},computed:{value:{get(){return this.$store.state.pika?.config?.model},set(e){this.$store.commit(`pika/setConfig`,{...this.$store.state.pika.config,model:e})}}},mounted(){this.value||=`2.0`}}),Te={class:`field`},Ee={class:`title font-bold`};function De(e,t,i,o,s,d){let h=f(`el-option`),_=f(`el-select`);return u(),p(`div`,Te,[r(`h2`,Ee,l(e.$t(`pika.name.model`)),1),a(_,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,class:`value`,placeholder:e.$t(`pika.placeholder.select`)},{default:m(()=>[(u(!0),p(g,null,c(e.options,e=>(u(),n(h,{key:e.value,label:e.label,value:e.value},null,8,[`label`,`value`]))),128))]),_:1},8,[`modelValue`,`placeholder`])])}var Oe=A(we,[[`render`,De],[`__scopeId`,`data-v-7b2e870a`]]),ke=s({name:`ImageUrlInput`,components:{ElUpload:b,ElButton:_,InfoIcon:G,ImagePreview:H,FontAwesomeIcon:B},mixins:[F,L],data(){return{fileList:[],uploadUrl:P()+`/api/v1/files/`}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e?.response?.file_url)},value:{get(){return this.$store.state.pika?.config?.image_url},set(){let e=this.urls?.[0];this.$store.commit(`pika/setConfig`,{...this.$store.state.pika?.config,image_url:e})}}},mounted(){this.value||=void 0,this.onSetStartImageUrl()},methods:{onExceed(){I.warning(this.$t(`pika.message.uploadStartImageExceed`))},onError(){I.error(this.$t(`pika.message.uploadStartImageError`))},async onRemove(){I.error(this.$t(`pika.message.uploadStartImageError`))},onSetStartImageUrl(){this.$store.commit(`pika/setConfig`,{...this.$store.state.pika?.config,image_url:this.urls})},async onSuccess(){this.onSetStartImageUrl()}}}),Ae={class:`field`},je={class:`title font-bold`},Me={class:`upload-wrapper`};function Ne(e,t,n,o,s,c){let d=f(`image-preview`),h=f(`font-awesome-icon`),g=f(`el-button`),_=f(`el-upload`),v=f(`info-icon`);return u(),p(`div`,Ae,[r(`h2`,je,l(e.$t(`pika.name.imageUrl`)),1),r(`div`,Me,[a(_,{ref:`uploader`,"file-list":e.fileList,"onUpdate:fileList":t[0]||=t=>e.fileList=t,accept:`.png,.jpg,.jpeg,.gif,.bmp,.webp`,name:`file`,class:`value upload-wrapper`,limit:3,multiple:!0,"list-type":`picture`,action:e.uploadUrl,"on-exceed":e.onExceed,"on-error":e.onError,"on-remove":e.onRemove,"on-success":e.onSuccess,headers:e.headers},{file:m(({file:t})=>[a(d,{url:t.url||t.response?.file_url,name:t.name,percentage:t.percentage,onRemove:n=>e.fileList.splice(e.fileList.indexOf(t),1)},null,8,[`url`,`name`,`percentage`,`onRemove`])]),default:m(()=>[a(g,{size:`small`,type:`primary`,round:``},{default:m(()=>[a(h,{icon:`fa-solid fa-upload`,class:`mr-1`}),i(` `+l(e.$t(`pika.button.uploadImageUrl`)),1)]),_:1})]),_:1},8,[`file-list`,`action`,`on-exceed`,`on-error`,`on-remove`,`on-success`,`headers`])]),a(v,{content:e.$t(`pika.description.imageUrl`),class:`info`},null,8,[`content`])])}var Pe=A(ke,[[`render`,Ne],[`__scopeId`,`data-v-25cefe78`]]),Fe=s({name:`PromptInput`,components:{PromptTextarea:J},computed:{prompt:{get(){return this.$store.state.pika?.config?.prompt},set(e){this.$store.commit(`pika/setConfig`,{...this.$store.state.pika?.config,prompt:e})}}},mounted(){this.prompt||=``}});function Ie(e,t,r,i,a,o){let s=f(`prompt-textarea`);return u(),n(s,{modelValue:e.prompt,"onUpdate:modelValue":t[0]||=t=>e.prompt=t,title:e.$t(`pika.name.prompt`),info:e.$t(`pika.description.prompt`),placeholder:e.$t(`pika.placeholder.prompt`)},null,8,[`modelValue`,`title`,`info`,`placeholder`])}var Le=s({name:`PresetPanel`,components:{ImageUrlInput:Pe,ElButton:_,FontAwesomeIcon:B,Consumption:X,PromptInput:A(Fe,[[`render`,Ie]]),IngredientsSelector:fe,IngredientsModelSelector:Ce,ModelSelector:Oe,EffectSelector:ve},emits:[`generate`],computed:{config(){return this.$store.state.pika?.config},consumption(){return M(this.config,this.service?.cost)},service(){return this.$store.state.pika?.service}},methods:{onGenerate(){this.$emit(`generate`)}}}),Re={class:`flex flex-col h-full`},ze={class:`flex-1 overflow-y-auto p-5`},Be={class:`flex flex-col items-center justify-center px-5 pb-5`};function Ve(e,t,s,c,d,h){let g=f(`prompt-input`),_=f(`model-selector`),v=f(`ingredients-selector`),y=f(`effect-selector`),b=f(`image-url-input`),x=f(`ingredients-model-selector`),S=f(`consumption`),C=f(`font-awesome-icon`),w=f(`el-button`);return u(),p(`div`,Re,[r(`div`,ze,[a(g,{class:`mb-4`}),a(_,{class:`mb-4`}),a(v,{class:`mb-4`}),a(y,{class:`mb-4`}),e.config?.ingredients?(u(),n(b,{key:0,class:`mb-4`})):o(``,!0),e.config?.ingredients?(u(),n(x,{key:1,class:`mb-4`})):o(``,!0)]),r(`div`,Be,[a(S,{value:e.consumption,service:e.service},null,8,[`value`,`service`]),a(w,{type:`primary`,class:`btn w-full`,round:``,onClick:e.onGenerate},{default:m(()=>[a(C,{icon:`fa-solid fa-magic`,class:`mr-2`}),i(` `+l(e.$t(`pika.button.generate`)),1)]),_:1},8,[`onClick`])])])}var He=A(Le,[[`render`,Ve]]),Ue=s({name:`VideoPlayer`,components:{VuePlyr:Q},props:{modelValue:{type:Object,required:!0}},data(){return{options:{quality:{default:1080,options:[1080]}}}}}),We=[`data-poster`],Ge=[`src`];function Ke(e,t,n,i,o,s){let c=f(`vue-plyr`);return u(),p(`div`,null,[a(c,{options:e.options,class:`video`},{default:m(()=>[r(`video`,{controls:``,playsinline:``,preload:`metadata`,"data-poster":e.modelValue?.image_url},[r(`source`,{size:`1080`,src:e.modelValue?.video_url,type:`video/mp4`},null,8,Ge)],8,We)]),_:1},8,[`options`])])}var qe=s({name:`TaskPreview`,components:{ElImage:S,CopyToClipboard:V,FontAwesomeIcon:B,ElAlert:C,VideoPlayer:A(Ue,[[`render`,Ke],[`__scopeId`,`data-v-897d9fe0`]]),ElTooltip:x,ElButton:_,ApiCodeButton:Z},props:{modelValue:{type:Object,required:!0}},data(){return{}},computed:{application(){return this.$store.state.pika?.application},config(){return this.$store.state.pika?.config},videos(){let e=[],t=this.modelValue?.request?.action;return Array.isArray(this.modelValue?.response?.data)&&this.modelValue?.response?.data?.forEach(n=>{let r=n;t&&(r.action=t),e.push(r)}),e}},methods:{onDownload(e){console.log(`on download`),window.open(e,`_blank`)},onReload(e){let t=e.target,n=new URL(t.src),r=n.searchParams.get(`retry`);if(!r)n.searchParams.set(`retry`,`1`);else if(parseInt(r)<2)n.searchParams.set(`retry`,(parseInt(r)+1).toString());else return;t.src=n.toString()},onOpenVideo(e){window.open(e,`_blank`)}}}),Je={class:`left`},Ye={class:`main`},Xe={class:`bot`},Ze={class:`datetime`},Qe={class:`info`},$e={key:0,class:`prompt mt-2`},et={key:0},tt={key:1},nt={key:0,class:t({content:!0,failed:!0})},rt={class:`image-wrapper`},it={key:0,class:t({operations:!0,"mt-2":!0})},at={key:0,class:`description`},ot={class:`description`},st={key:1,class:`description`},ct={key:1,class:t({content:!0})},lt={class:`description`},ut={class:`description`},dt={key:0,class:`description`},ft={class:`description`},$={key:2,class:t({content:!0})},pt={class:`description`};function mt(e,t,s,d,h,_){let v=f(`el-image`),y=f(`VideoPlayer`),b=f(`el-button`),x=f(`el-tooltip`),S=f(`api-code-button`),C=f(`font-awesome-icon`),w=f(`copy-to-clipboard`),T=f(`el-alert`);return u(!0),p(g,null,c(e.videos,(t,s)=>(u(),p(`div`,{key:s,class:`preview`},[r(`div`,Je,[a(v,{src:`https://cdn.acedata.cloud/i80tgn.png`,class:`avatar`})]),r(`div`,Ye,[r(`div`,Xe,[i(l(e.$t(`pika.name.pikaBot`))+` `,1),r(`span`,Ze,l(e.$dayjs.format(``+new Date(parseFloat((e.modelValue?.created_at||``).toString())*1e3))),1)]),r(`div`,Qe,[e.modelValue?.request?.prompt?(u(),p(`p`,$e,[i(l(e.modelValue?.request?.prompt)+` `,1),e.modelValue?.response?o(``,!0):(u(),p(`span`,et,` - (`+l(e.$t(`pika.status.pending`))+`) `,1)),t?.state===`processing`||t?.state===`pending`?(u(),p(`span`,tt,` - (`+l(e.$t(`pika.status.processing`))+`) `,1)):o(``,!0)])):o(``,!0)]),e.modelValue?.response?.success===!0?(u(),p(`div`,nt,[r(`div`,rt,[a(y,{"model-value":t},null,8,[`model-value`])]),t?(u(),p(`div`,it,[a(x,{class:`box-item`,effect:`dark`,content:e.$t(`pika.message.downloadVideo`),placement:`top-start`},{default:m(()=>[t?.video_url?(u(),n(b,{key:0,type:`info`,size:`small`,class:`btn-action`,onClick:n=>e.onDownload(t?.video_url)},{default:m(()=>[i(l(e.$t(`pika.button.download`)),1)]),_:1},8,[`onClick`])):o(``,!0)]),_:2},1032,[`content`]),a(S,{path:`/pika/videos`,body:e.modelValue?.request},null,8,[`body`])])):o(``,!0),a(T,{closable:!1,class:`mt-2 success`},{default:m(()=>[e.modelValue?.request?.model?(u(),p(`p`,at,[a(C,{icon:`fa-solid fa-hashtag`,class:`mr-1`}),i(` `+l(e.$t(`pika.name.model`))+`: `+l(e.modelValue?.request?.model),1)])):o(``,!0),r(`p`,ot,[a(C,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+l(e.$t(`pika.name.taskId`))+`: `+l(e.modelValue?.id)+` `,1),a(w,{content:e.modelValue?.id,class:`btn-copy`},null,8,[`content`])]),e.modelValue?.elapsed?(u(),p(`p`,st,[a(C,{icon:`fa-solid fa-clock`,class:`mr-1`}),i(` `+l(e.$t(`pika.name.elapsed`))+`: `+l(e.modelValue?.elapsed?.toFixed(2))+`s `,1)])):o(``,!0)]),_:1})])):o(``,!0),e.modelValue?.response?.success===!1?(u(),p(`div`,ct,[a(T,{closable:!1,class:`failure`},{template:m(()=>[a(C,{icon:`fa-solid fa-exclamation-triangle`,class:`mr-1`}),i(` `+l(e.$t(`pika.name.failure`)),1)]),default:m(()=>[r(`p`,lt,[a(C,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+l(e.$t(`pika.name.taskId`))+`: `+l(e.modelValue?.id)+` `,1),a(w,{content:e.modelValue?.id,class:`btn-copy`},null,8,[`content`])]),r(`p`,ut,[a(C,{icon:`fa-solid fa-circle-info`,class:`mr-1`}),i(` `+l(e.$t(`pika.name.failureReason`))+`: `+l(e.modelValue?.response?.error?.message)+` `,1),a(w,{content:e.modelValue?.response?.error?.message,class:`btn-copy`},null,8,[`content`])]),e.modelValue?.elapsed?(u(),p(`p`,dt,[a(C,{icon:`fa-solid fa-clock`,class:`mr-1`}),i(` `+l(e.$t(`pika.name.elapsed`))+`: `+l(e.modelValue?.elapsed?.toFixed(2))+`s `,1)])):o(``,!0),r(`p`,ft,[a(C,{icon:`fa-solid fa-hashtag`,class:`mr-1`}),i(` `+l(e.$t(`pika.name.traceId`))+`: `+l(e.modelValue?.response?.trace_id)+` `,1),a(w,{content:e.modelValue?.response?.trace_id,class:`btn-copy`},null,8,[`content`])])]),_:1})])):o(``,!0),!e.modelValue?.response||t?.state===`processing`||t?.state===`pending`?(u(),p(`div`,$,[a(T,{closable:!1,class:`info`},{template:m(()=>[a(C,{icon:`fa-solid fa-exclamation-triangle`,class:`mr-1`}),i(` `+l(e.$t(`pika.name.failure`)),1)]),default:m(()=>[r(`p`,pt,[a(C,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+l(e.$t(`pika.name.taskId`))+`: `+l(e.modelValue?.id)+` `,1),a(w,{content:e.modelValue?.id,class:`btn-copy`},null,8,[`content`])])]),_:1})])):o(``,!0)])]))),128)}var ht=s({name:`RecentPanel`,components:{TaskPreview:A(qe,[[`render`,mt],[`__scopeId`,`data-v-52856c99`]]),BotPlaceholder:W,NoTasks:Y,ScrollList:K},props:{loading:{type:Boolean,default:!1}},emits:[`reach-top`],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.pika?.tasks,items:this.$store.state.pika?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),gt={key:0},_t={key:2,class:`w-full h-full flex items-center justify-center`};function vt(e,t,r,i,s,l){let d=f(`bot-placeholder`),h=f(`task-preview`),_=f(`scroll-list`),v=f(`no-tasks`);return u(),p(g,null,[e.tasks?.items===void 0?(u(),p(`div`,gt,[a(d)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(u(),n(_,{key:1,ref:`scrollList`,class:`tasks h-full w-full overflow-y-auto`,loading:e.loading,onReachTop:t[0]||=t=>e.$emit(`reach-top`)},{default:m(()=>[(u(!0),p(g,null,c(e.tasks?.items,(e,t)=>(u(),n(h,{key:t,"model-value":e},null,8,[`model-value`]))),128))]),_:1},8,[`loading`])):o(``,!0),e.tasks?.items?.length===0?(u(),p(`div`,_t,[a(v)])):o(``,!0)],64)}var yt=A(ht,[[`render`,vt]]),bt=O(`pika`),xt=s({name:`PikaIndex`,components:{ConfigPanel:He,Layout:se,RecentPanel:yt},mixins:[te],inject:[`initialized`],data(){return{task:void 0,job:0,loadingMore:!1,fetchingTasks:!1}},computed:{applicationsLoading(){return this.$store.state.pika?.status?.getApplications===z.Request},tasksLoading(){return this.$store.state.pika?.status?.getTasks===z.Request||this.fetchingTasks},service(){return this.$store.state.pika.service},credential(){return this.$store.state.pika.credential},config(){return this.$store.state.pika.config},initializing(){return this.$store.state.pika.status.getApplications===z.Request},needApply(){return this.$store.state.pika.status.getApplications===z.Success&&!this.application},application(){return this.$store.state.pika.application},applications(){return this.$store.state.pika.applications},tasks(){return this.$store.state.pika.tasks}},watch:{tasks:{handler(e,t){e?.items?.length>t?.items?.length&&console.debug(`new tasks detected`)},deep:!0},initialized:{async handler(e){e&&(console.debug(`layout initialized`),await this.onGetTasks(),await this.onScrollDown(),this.job=window.setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){window.clearInterval(this.job)},methods:{async onReachTop(){await q({tasks:this.tasks,getTasks:()=>this.tasks,loading:this.loadingMore,setLoading:e=>this.loadingMore=e,isBlocked:()=>this.tasksLoading||this.applicationsLoading,fetch:e=>this.onGetTasks({createdAtMax:e}),getScrollElement:()=>this.getTasksScrollElement()})},async onGetService(){console.debug(`start onGetService`),await this.$store.dispatch(`pika/getService`),console.debug(`end onGetService`)},async onGetApplication(){console.debug(`start onGetApplication`),await this.$store.dispatch(`pika/getApplications`),console.debug(`end onGetApplication`),await this.onGetTasks()},onApply(){k.create({application:this.application}).then(({data:e})=>{this.application=e,I.success(this.$t(`application.message.applySuccessfully`))}).catch(e=>{e?.response?.data?.code===`duplication`&&I.error(this.$t(`application.message.alreadyApplied`))})},async onScrollDown(){await this.$nextTick();let e=this.getTasksScrollElement();e&&(e.scrollTop=e.scrollHeight)},async onGetTasks(e){if(this.applicationsLoading||this.fetchingTasks){console.debug(`loading`);return}console.debug(`start onGetTasks`,e);let{limit:t=5,createdAtMin:n,createdAtMax:r}=e||{};console.debug(`limit`,t,`createdAtMin`,n,`createdAtMax`,r),this.fetchingTasks=!0;try{await this.$store.dispatch(`pika/getTasks`,{limit:t,createdAtMin:n,createdAtMax:r})}finally{this.fetchingTasks=!1}},async onGenerate(){if(!N(this.uploadTracker,e=>this.$t(e),e=>I.warning(e)))return;let e={...this.config,callback_url:bt},t=this.credential?.token;if(!t){console.error(`no token specified`);return}I.info(this.$t(`pika.message.startingTask`)),j(`pika`,R.generate(e,{token:t})).then(()=>{I.success(this.$t(`pika.message.startTaskSuccess`)),this.$store.commit(`pika/setConfig`,{config:void 0})}).catch(e=>{(e?.response?.data)?.error?.code===`used_up`?I.error(this.$t(`pika.message.usedUp`)):I.error(this.$t(`pika.message.startTaskFailed`))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function St(e,t,r,i,o,s){let c=f(`config-panel`),l=f(`recent-panel`),d=f(`layout`);return u(),n(d,null,{config:m(()=>[a(c,{onGenerate:e.onGenerate},null,8,[`onGenerate`])]),result:m(()=>[a(l,{ref:`recentPanel`,class:`panel recent`,loading:e.loadingMore,onReachTop:e.onReachTop},null,8,[`loading`,`onReachTop`])]),_:1})}var Ct=A(xt,[[`render`,St],[`__scopeId`,`data-v-eae39ce1`]]);export{Ct as default};
@@ -1 +1 @@
1
- import"./rolldown-runtime--c01j_DQ.js";import{$ as e,Bt as t,D as n,E as r,M as i,N as a,O as o,P as s,Q as c,Ut as l,X as u,_ as d,et as f,k as p,lt as m,ut as h,x as g}from"./vendor-chart-mdwpew_o.js";import{t as _}from"./button-DWzbdjZV.js";import{r as v,t as y}from"./select-CqM5oalI.js";import{t as b}from"./upload-C7rPv2P3.js";import{t as x}from"./image-tzz5bG4l.js";import{t as S}from"./alert-BJj7gY4q.js";import{t as C}from"./drawer-BvYPSxXh.js";import{t as ee}from"./input-number-C6xd-oPl.js";import{t as w}from"./slider-Dr2SA5cy.js";import{Hn as T,Un as E,hi as D}from"./constants-BVtW3DRs.js";import{At as te,E as O,Fn as k,Nt as A,Ot as j,Sr as M,jt as N,kr as P,kt as F,ln as I,yr as L}from"./index-DGgsHGQJ.js";import{t as R}from"./index.es-CX_i3qgT.js";import{t as z}from"./CopyToClipboard-BvyK_FyK.js";import{t as B}from"./ImagePreview-BOICGdPc.js";import{n as V}from"./taskDrawerMixin-Cr17Yxqk.js";import{t as H}from"./BotPlaceholder-DFp0g5zS.js";import{i as U,n as W,t as G}from"./pagination-CpCpCjbW.js";import{n as K,t as q}from"./NoTasks-C9x-H4Pc.js";import{t as J}from"./Consumption-Ci-3V7yB.js";import{t as Y}from"./ApiCodeButton-C3NNEgIA.js";import{t as X}from"./ImageWrapper-CjcxJKbz.js";var Z=s({name:`LayoutFlux`,components:{ElDrawer:C,ElButton:_,FontAwesomeIcon:R},mixins:[V]}),Q={class:`main flex flex-row flex-1`},ne={class:`config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]`},re={class:`result h-full p-6 flex-1 flex flex-col min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]`};function ie(t,n,i,o,s,c){let l=f(`font-awesome-icon`),g=f(`el-button`),_=f(`el-drawer`);return u(),p(`div`,Q,[r(`div`,ne,[e(t.$slots,`config`,{},void 0,!0)]),r(`div`,re,[e(t.$slots,`result`,{},void 0,!0)]),h(a(g,{circle:``,class:`menu`,onClick:n[0]||=e=>t.drawer=!0},{default:m(()=>[a(l,{icon:`fa-solid fa-magic`})]),_:1},512),[[d,!t.tasksEmpty]]),a(_,{modelValue:t.drawer,"onUpdate:modelValue":n[1]||=e=>t.drawer=e,direction:`ltr`,"with-header":!1,size:`340px`,class:`drawer`},{default:m(()=>[e(t.$slots,`config`,{},void 0,!0)]),_:3},8,[`modelValue`])])}var ae=O(Z,[[`render`,ie],[`__scopeId`,`data-v-8ae8c974`]]),oe=s({name:`ModelSelector`,components:{ElSelect:v,ElOption:y},props:{modelValue:{type:String,default:void 0}},emits:[`update:modelValue`],data(){return{options:[{value:`flux-dev`,label:`flux-dev`},{value:`flux-pro`,label:`flux-pro`},{value:`flux-kontext-pro`,label:`flux-kontext-pro`},{value:`flux-kontext-max`,label:`flux-kontext-max`},{value:`flux-2-flex`,label:`flux-2-flex`},{value:`flux-2-pro`,label:`flux-2-pro`},{value:`flux-2-max`,label:`flux-2-max`}]}},computed:{value:{get(){return this.$store.state.flux?.config?.model},set(e){this.$store.commit(`flux/setConfig`,{...this.$store.state.flux.config,model:e})}}},mounted(){this.value||=E}}),se={class:`field`},ce={class:`title font-bold`};function le(e,t,i,o,s,d){let h=f(`el-option`),_=f(`el-select`);return u(),p(`div`,se,[r(`h2`,ce,l(e.$t(`flux.name.model`)),1),a(_,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,class:`value`,placeholder:e.$t(`flux.placeholder.select`)},{default:m(()=>[(u(!0),p(g,null,c(e.options,e=>(u(),n(h,{key:e.value,label:e.label,value:e.value},null,8,[`label`,`value`]))),128))]),_:1},8,[`modelValue`,`placeholder`])])}var ue=O(oe,[[`render`,le],[`__scopeId`,`data-v-e9b17945`]]),de=s({name:`CountSelector`,components:{ElSlider:w,InfoIcon:U,ElInputNumber:ee},computed:{value:{get(){return this.$store.state.flux?.config?.count},set(e){console.debug(`set count`,e),this.$store.commit(`flux/setConfig`,{...this.$store.state.flux?.config,count:e})}}},mounted(){this.value||=1}}),fe={class:`flex justify-between`},pe={class:`flex justify-start items-center`},me={class:`text-sm font-bold`},he={class:`flex justify-end items-center`},ge={class:`w-full`};function _e(e,t,n,i,o,s){let c=f(`info-icon`),d=f(`el-input-number`),m=f(`el-slider`);return u(),p(`div`,null,[r(`div`,fe,[r(`div`,pe,[r(`span`,me,l(e.$t(`flux.name.numbers`)),1),a(c,{content:e.$t(`flux.description.numbers`)},null,8,[`content`])]),r(`div`,he,[a(d,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,"controls-position":`right`},null,8,[`modelValue`])])]),r(`div`,ge,[a(m,{modelValue:e.value,"onUpdate:modelValue":t[1]||=t=>e.value=t,min:1,max:4,step:1},null,8,[`modelValue`])])])}var ve=O(de,[[`render`,_e]]),ye=s({name:`ActionSelector`,components:{ElSelect:v,ElOption:y},props:{modelValue:{type:String,default:void 0}},emits:[`update:modelValue`],data(){return{options:[{value:`generate`,label:this.$t(`flux.name.generate`)},{value:`edits`,label:this.$t(`flux.name.edits`)}]}},computed:{value:{get(){return this.$store.state.flux?.config?.action},set(e){this.$store.commit(`flux/setConfig`,{...this.$store.state.flux.config,action:e})}}},mounted(){this.value||=T}}),be={class:`field`},xe={class:`title font-bold`};function Se(e,t,i,o,s,d){let h=f(`el-option`),_=f(`el-select`);return u(),p(`div`,be,[r(`h2`,xe,l(e.$t(`flux.name.task`)),1),a(_,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,class:`value`,placeholder:e.$t(`flux.placeholder.select`)},{default:m(()=>[(u(!0),p(g,null,c(e.options,e=>(u(),n(h,{key:e.value,label:e.label,value:e.value},null,8,[`label`,`value`]))),128))]),_:1},8,[`modelValue`,`placeholder`])])}var Ce=O(ye,[[`render`,Se],[`__scopeId`,`data-v-81fd05e5`]]),we=s({name:`ImageUrlInput`,components:{ElUpload:b,ElButton:_,InfoIcon:U,FontAwesomeIcon:R,ImagePreview:B},mixins:[N,F],emits:[`change`],data(){return{fileList:[],uploadUrl:M()+`/api/v1/files/`}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e?.response?.file_url)}},watch:{urls:{handler(e){console.debug(`URLs changed:`,e),this.$store.commit(`flux/setConfig`,{...this.$store.state.flux.config,image_url:e[0]})}}},methods:{onExceed(){P.warning(this.$t(`flux.message.uploadStartImageExceed`))},onError(){P.error(this.$t(`flux.message.uploadStartImageError`))}}}),Te={class:`relative`},Ee={class:`flex justify-between`},De={class:`flex justify-start items-center`},Oe={class:`text-sm font-bold`};function ke(e,t,n,o,s,c){let d=f(`info-icon`),h=f(`image-preview`),g=f(`font-awesome-icon`),_=f(`el-button`),v=f(`el-upload`);return u(),p(`div`,Te,[r(`div`,Ee,[r(`div`,De,[r(`span`,Oe,l(e.$t(`flux.name.imageUrl`)),1),a(d,{content:e.$t(`flux.description.imageUrl`)},null,8,[`content`])])]),a(v,{ref:`uploader`,"file-list":e.fileList,"onUpdate:fileList":t[0]||=t=>e.fileList=t,name:`file`,limit:5,class:`upload-wrapper`,accept:`.png,.jpg,.jpeg,.gif,.bmp,.webp`,multiple:!0,"list-type":`picture`,action:e.uploadUrl,"on-exceed":e.onExceed,"on-error":e.onError,headers:e.headers},{file:m(({file:t})=>[a(h,{url:t.url||t.response?.file_url,name:t.name,percentage:t.percentage,onRemove:n=>e.fileList.splice(e.fileList.indexOf(t),1)},null,8,[`url`,`name`,`percentage`,`onRemove`])]),default:m(()=>[a(_,{round:``,type:`primary`,size:`small`,class:`btn btn-upload`},{default:m(()=>[a(g,{icon:`fa-solid fa-upload`,class:`icon mr-1`}),i(` `+l(e.$t(`flux.button.uploadImageUrl`)),1)]),_:1})]),_:1},8,[`file-list`,`action`,`on-exceed`,`on-error`,`headers`])])}var Ae=O(we,[[`render`,ke],[`__scopeId`,`data-v-7482072d`]]),je=s({name:`PromptInput`,components:{PromptTextarea:K},computed:{prompt:{get(){return this.$store.state.flux?.config?.prompt},set(e){this.$store.commit(`flux/setConfig`,{...this.$store.state.flux?.config,prompt:e})}}},mounted(){this.prompt||=``}});function Me(e,t,r,i,a,o){let s=f(`prompt-textarea`);return u(),n(s,{modelValue:e.prompt,"onUpdate:modelValue":t[0]||=t=>e.prompt=t,title:e.$t(`flux.name.prompt`),info:e.$t(`flux.description.prompt`),placeholder:e.$t(`flux.placeholder.prompt`)},null,8,[`modelValue`,`title`,`info`,`placeholder`])}var Ne=s({name:`PresetPanel`,components:{ElButton:_,FontAwesomeIcon:R,PromptInput:O(je,[[`render`,Me]]),ModelSelector:ue,CountSelector:ve,Consumption:J,ActionSelector:Ce,ImageUrlInput:Ae},emits:[`generate`],computed:{config(){return this.$store.state.flux?.config},consumption(){return A(this.config,this.service?.cost)},service(){return this.$store.state.flux?.service}},methods:{onGenerate(){this.$emit(`generate`)}}}),Pe={class:`flex flex-col h-full`},Fe={class:`flex-1 overflow-y-auto p-5`},Ie={class:`flex flex-col items-center justify-center px-5 pb-5`};function Le(e,t,s,c,d,h){let g=f(`action-selector`),_=f(`prompt-input`),v=f(`image-url-input`),y=f(`model-selector`),b=f(`count-selector`),x=f(`consumption`),S=f(`font-awesome-icon`),C=f(`el-button`);return u(),p(`div`,Pe,[r(`div`,Fe,[a(g,{class:`mb-4`}),a(_,{class:`mb-4`}),e.config?.action===`edits`?(u(),n(v,{key:0,class:`mb-4`})):o(``,!0),a(y,{class:`mb-4`}),a(b,{class:`mb-4`})]),r(`div`,Ie,[a(x,{value:e.consumption,service:e.service},null,8,[`value`,`service`]),a(C,{type:`primary`,class:`btn w-full`,round:``,onClick:e.onGenerate},{default:m(()=>[a(S,{icon:`fa-solid fa-magic`,class:`mr-2`}),i(` `+l(e.$t(`flux.button.generate`)),1)]),_:1},8,[`onClick`])])])}var Re=O(Ne,[[`render`,Le]]),ze=s({name:`TaskPreview`,components:{ElImage:x,CopyToClipboard:z,FontAwesomeIcon:R,ElAlert:S,ImageWrapper:X,ApiCodeButton:Y},props:{modelValue:{type:Object,required:!0}},data(){return{}},computed:{application(){return this.$store.state.flux?.application},config(){return this.$store.state.flux?.config},images(){let e=[],t=this.modelValue?.request?.action;return Array.isArray(this.modelValue?.response?.data)&&this.modelValue?.response?.data?.forEach(n=>{let r=n;t&&(r.action=t),e.push(r)}),e}},methods:{onDownload(e,t){e?.stopPropagation(),console.log(`on download`),window.open(t,`_blank`)},onOpenImage(e){window.open(e,`_blank`)}}}),Be={class:`preview`},Ve={class:`left`},He={class:`main`},Ue={class:`bot`},We={class:`datetime`},Ge={class:`info`},Ke={key:0,class:`prompt mt-2`},qe={key:0},Je={key:0,class:t({content:!0,failed:!0})},Ye={class:`flex justify-start items-center gap-4 w-full overflow-x-auto`},Xe={class:t({operations:!0,"mt-2":!0,"mb-2":!0})},Ze={class:`text-[var(--el-text-color-regular)] text-xs mb-2`},Qe={class:`text-[var(--el-text-color-regular)] text-xs mb-2`},$e={key:0,class:`text-[var(--el-text-color-regular)] text-xs mb-0`},et={key:1,class:t({content:!0})},tt={class:`text-[var(--el-text-color-regular)] text-xs mb-2`},$={class:`text-[var(--el-text-color-regular)] text-xs mb-2`},nt={key:0,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},rt={class:`text-[var(--el-text-color-regular)] text-xs mb-0`},it={key:2,class:t({content:!0})},at={class:`text-[var(--el-text-color-regular)] text-xs mb-0`};function ot(e,t,s,d,h,_){let v=f(`el-image`),y=f(`image-wrapper`),b=f(`api-code-button`),x=f(`font-awesome-icon`),S=f(`copy-to-clipboard`),C=f(`el-alert`);return u(),p(`div`,Be,[r(`div`,Ve,[a(v,{src:`https://cdn.acedata.cloud/ogm2oa.png`,class:`avatar`})]),r(`div`,He,[r(`div`,Ue,[i(l(e.$t(`flux.name.fluxBot`))+` `,1),r(`span`,We,l(e.$dayjs.format(``+new Date(parseFloat((e.modelValue?.created_at||``).toString())*1e3))),1)]),r(`div`,Ge,[e.modelValue?.request?.prompt?(u(),p(`p`,Ke,[i(l(e.modelValue?.request?.prompt)+` `,1),e.modelValue?.response?o(``,!0):(u(),p(`span`,qe,` - (`+l(e.$t(`flux.status.pending`))+`) `,1))])):o(``,!0)]),e.modelValue?.response?.success===!0?(u(),p(`div`,Je,[r(`div`,Ye,[(u(!0),p(g,null,c(e.images,(e,t)=>(u(),n(y,{key:t,src:e?.image_url,"raw-src":e?.image_url,"model-value":e},null,8,[`src`,`raw-src`,`model-value`]))),128))]),r(`div`,Xe,[a(b,{path:`/flux/images`,body:e.modelValue?.request},null,8,[`body`])]),a(C,{closable:!1,class:`mt-2 success`},{default:m(()=>[r(`p`,Ze,[a(x,{icon:`fa-solid fa-hashtag`,class:`mr-1`}),i(` `+l(e.$t(`flux.name.model`))+`: `+l(e.modelValue?.request?.model),1)]),r(`p`,Qe,[a(x,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+l(e.$t(`flux.name.taskId`))+`: `+l(e.modelValue?.id)+` `,1),a(S,{content:e.modelValue?.id,class:`btn-copy inline-block`},null,8,[`content`])]),e.modelValue?.elapsed?(u(),p(`p`,$e,[a(x,{icon:`fa-solid fa-clock`,class:`mr-1`}),i(` `+l(e.$t(`flux.name.elapsed`))+`: `+l(e.modelValue?.elapsed?.toFixed(2))+`s `,1)])):o(``,!0)]),_:1})])):o(``,!0),e.modelValue?.response?.success===!1?(u(),p(`div`,et,[a(C,{closable:!1,class:`failure`},{template:m(()=>[a(x,{icon:`fa-solid fa-exclamation-triangle`,class:`mr-1`}),i(` `+l(e.$t(`flux.name.failure`)),1)]),default:m(()=>[r(`p`,tt,[a(x,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+l(e.$t(`flux.name.taskId`))+`: `+l(e.modelValue?.id)+` `,1),a(S,{content:e.modelValue?.id,class:`btn-copy`},null,8,[`content`])]),r(`p`,$,[a(x,{icon:`fa-solid fa-circle-info`,class:`mr-1`}),i(` `+l(e.$t(`flux.name.failureReason`))+`: `+l(e.modelValue?.response?.error?.message)+` `,1),a(S,{content:e.modelValue?.response?.error?.message,class:`btn-copy`},null,8,[`content`])]),e.modelValue?.elapsed?(u(),p(`p`,nt,[a(x,{icon:`fa-solid fa-clock`,class:`mr-1`}),i(` `+l(e.$t(`flux.name.elapsed`))+`: `+l(e.modelValue?.elapsed?.toFixed(2))+`s `,1)])):o(``,!0),r(`p`,rt,[a(x,{icon:`fa-solid fa-hashtag`,class:`mr-1`}),i(` `+l(e.$t(`flux.name.traceId`))+`: `+l(e.modelValue?.response?.trace_id)+` `,1),a(S,{content:e.modelValue?.response?.trace_id,class:`btn-copy`},null,8,[`content`])])]),_:1})])):o(``,!0),e.modelValue?.response?o(``,!0):(u(),p(`div`,it,[a(C,{closable:!1,class:`info`},{template:m(()=>[a(x,{icon:`fa-solid fa-exclamation-triangle`,class:`mr-1`}),i(` `+l(e.$t(`flux.name.failure`)),1)]),default:m(()=>[r(`p`,at,[a(x,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+l(e.$t(`flux.name.taskId`))+`: `+l(e.modelValue?.id)+` `,1),a(S,{content:e.modelValue?.id,class:`btn-copy`},null,8,[`content`])])]),_:1})]))])])}var st=s({name:`RecentPanel`,components:{TaskPreview:O(ze,[[`render`,ot],[`__scopeId`,`data-v-bf1b183c`]]),BotPlaceholder:H,NoTasks:q,ScrollList:W},props:{loading:{type:Boolean,default:!1}},emits:[`reach-top`],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.flux?.tasks,items:this.$store.state.flux?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),ct={key:0},lt={key:2,class:`w-full h-full flex items-center justify-center`};function ut(e,t,r,i,s,l){let d=f(`bot-placeholder`),h=f(`task-preview`),_=f(`scroll-list`),v=f(`no-tasks`);return u(),p(g,null,[e.tasks?.items===void 0?(u(),p(`div`,ct,[a(d)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(u(),n(_,{key:1,ref:`scrollList`,class:`tasks h-full w-full overflow-y-auto`,loading:e.loading,onReachTop:t[0]||=t=>e.$emit(`reach-top`)},{default:m(()=>[(u(!0),p(g,null,c(e.tasks?.items,e=>(u(),n(h,{key:e.id,"model-value":e},null,8,[`model-value`]))),128))]),_:1},8,[`loading`])):o(``,!0),e.tasks?.items?.length===0?(u(),p(`div`,lt,[a(v)])):o(``,!0)],64)}var dt=O(st,[[`render`,ut]]),ft=D(`flux`),pt=s({name:`FluxIndex`,components:{ConfigPanel:Re,Layout:ae,RecentPanel:dt},mixins:[te],inject:[`initialized`],data(){return{task:void 0,job:0,loadingMore:!1,fetchingTasks:!1}},computed:{applicationsLoading(){return this.$store.state.flux?.status?.getApplications===L.Request},tasksLoading(){return this.$store.state.flux?.status?.getTasks===L.Request||this.fetchingTasks},credential(){return this.$store.state.flux?.credential},config(){return this.$store.state.flux?.config},application(){return this.$store.state.flux?.application},tasks(){return this.$store.state.flux?.tasks}},watch:{tasks:{handler(e,t){e?.items?.length>t?.items?.length&&console.debug(`new tasks detected`)},deep:!0},initialized:{async handler(e){e&&(console.debug(`layout initialized`),await this.onGetTasks(),await this.onScrollDown(),this.job=window.setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){window.clearInterval(this.job)},methods:{async onReachTop(){await G({tasks:this.tasks,getTasks:()=>this.tasks,loading:this.loadingMore,setLoading:e=>this.loadingMore=e,isBlocked:()=>this.tasksLoading||this.applicationsLoading,fetch:e=>this.onGetTasks({createdAtMax:e}),getScrollElement:()=>this.getTasksScrollElement()})},async onGetService(){console.debug(`start onGetService`),await this.$store.dispatch(`flux/getService`),console.debug(`end onGetService`)},async onGetApplication(){console.debug(`start onGetApplication`),await this.$store.dispatch(`flux/getApplications`),console.debug(`end onGetApplication`),await this.onGetTasks()},async onScrollDown(){await this.$nextTick();let e=this.getTasksScrollElement();e&&(e.scrollTop=e.scrollHeight)},async onGetTasks(e){if(this.applicationsLoading||this.fetchingTasks){console.debug(`loading`);return}console.debug(`start onGetTasks`,e);let{limit:t=5,createdAtMin:n,createdAtMax:r}=e||{};console.debug(`limit`,t,`createdAtMin`,n,`createdAtMax`,r),this.fetchingTasks=!0;try{await this.$store.dispatch(`flux/getTasks`,{limit:t,createdAtMin:n,createdAtMax:r})}finally{this.fetchingTasks=!1}},async onGenerate(){if(!j(this.uploadTracker,e=>this.$t(e),e=>P.warning(e)))return;let e={...this.config,callback_url:ft},t=this.credential?.token;if(!t){console.error(`no token specified`);return}P.info(this.$t(`flux.message.startingTask`)),k(`flux`,I.generate(e,{token:t})).then(()=>{P.success(this.$t(`flux.message.startTaskSuccess`))}).catch(e=>{let t=e?.response?.data;t?.error?.code===`used_up`?P.error(this.$t(`flux.message.usedUp`)):P.error(this.$t(`flux.message.startTaskFailed`)+t?.error?.message)}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function mt(e,t,r,i,o,s){let c=f(`config-panel`),l=f(`recent-panel`),d=f(`layout`);return u(),n(d,null,{config:m(()=>[a(c,{onGenerate:e.onGenerate},null,8,[`onGenerate`])]),result:m(()=>[a(l,{ref:`recentPanel`,loading:e.loadingMore,onReachTop:e.onReachTop},null,8,[`loading`,`onReachTop`])]),_:1})}var ht=O(pt,[[`render`,mt]]);export{ht as default};
1
+ import"./rolldown-runtime--c01j_DQ.js";import{$ as e,Bt as t,D as n,E as r,M as i,N as a,O as o,P as s,Q as c,Ut as l,X as u,_ as d,et as f,k as p,lt as m,ut as h,x as g}from"./vendor-chart-mdwpew_o.js";import{t as _}from"./button-DWzbdjZV.js";import{r as v,t as y}from"./select-CYdISXBV.js";import{t as b}from"./upload-CHAO8dYa.js";import{t as x}from"./image-tItcr5tZ.js";import{t as S}from"./alert-BJj7gY4q.js";import{t as C}from"./drawer-BvYPSxXh.js";import{t as ee}from"./input-number-BZClQnf5.js";import{t as w}from"./slider-heMG04zo.js";import{Hn as T,Un as E,hi as D}from"./constants-B6_fTlam.js";import{At as te,E as O,Fn as k,Nt as A,Ot as j,Sr as M,jt as N,kr as P,kt as F,ln as I,yr as L}from"./index-DpREqzJQ.js";import{t as R}from"./index.es-DkXuZNXE.js";import{t as z}from"./CopyToClipboard-DXA4nHxo.js";import{t as B}from"./ImagePreview-Bkw_taCt.js";import{n as V}from"./taskDrawerMixin-Cr17Yxqk.js";import{t as H}from"./BotPlaceholder-R_nAAbft.js";import{i as U,n as W,t as G}from"./pagination-BQOE0Lce.js";import{n as K,t as q}from"./NoTasks-568fhAGt.js";import{t as J}from"./Consumption-CjrpUNmV.js";import{t as Y}from"./ApiCodeButton-DXN7iB8l.js";import{t as X}from"./ImageWrapper-BPvtDIMf.js";var Z=s({name:`LayoutFlux`,components:{ElDrawer:C,ElButton:_,FontAwesomeIcon:R},mixins:[V]}),Q={class:`main flex flex-row flex-1`},ne={class:`config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]`},re={class:`result h-full p-6 flex-1 flex flex-col min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]`};function ie(t,n,i,o,s,c){let l=f(`font-awesome-icon`),g=f(`el-button`),_=f(`el-drawer`);return u(),p(`div`,Q,[r(`div`,ne,[e(t.$slots,`config`,{},void 0,!0)]),r(`div`,re,[e(t.$slots,`result`,{},void 0,!0)]),h(a(g,{circle:``,class:`menu`,onClick:n[0]||=e=>t.drawer=!0},{default:m(()=>[a(l,{icon:`fa-solid fa-magic`})]),_:1},512),[[d,!t.tasksEmpty]]),a(_,{modelValue:t.drawer,"onUpdate:modelValue":n[1]||=e=>t.drawer=e,direction:`ltr`,"with-header":!1,size:`340px`,class:`drawer`},{default:m(()=>[e(t.$slots,`config`,{},void 0,!0)]),_:3},8,[`modelValue`])])}var ae=O(Z,[[`render`,ie],[`__scopeId`,`data-v-8ae8c974`]]),oe=s({name:`ModelSelector`,components:{ElSelect:v,ElOption:y},props:{modelValue:{type:String,default:void 0}},emits:[`update:modelValue`],data(){return{options:[{value:`flux-dev`,label:`flux-dev`},{value:`flux-pro`,label:`flux-pro`},{value:`flux-kontext-pro`,label:`flux-kontext-pro`},{value:`flux-kontext-max`,label:`flux-kontext-max`},{value:`flux-2-flex`,label:`flux-2-flex`},{value:`flux-2-pro`,label:`flux-2-pro`},{value:`flux-2-max`,label:`flux-2-max`}]}},computed:{value:{get(){return this.$store.state.flux?.config?.model},set(e){this.$store.commit(`flux/setConfig`,{...this.$store.state.flux.config,model:e})}}},mounted(){this.value||=E}}),se={class:`field`},ce={class:`title font-bold`};function le(e,t,i,o,s,d){let h=f(`el-option`),_=f(`el-select`);return u(),p(`div`,se,[r(`h2`,ce,l(e.$t(`flux.name.model`)),1),a(_,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,class:`value`,placeholder:e.$t(`flux.placeholder.select`)},{default:m(()=>[(u(!0),p(g,null,c(e.options,e=>(u(),n(h,{key:e.value,label:e.label,value:e.value},null,8,[`label`,`value`]))),128))]),_:1},8,[`modelValue`,`placeholder`])])}var ue=O(oe,[[`render`,le],[`__scopeId`,`data-v-e9b17945`]]),de=s({name:`CountSelector`,components:{ElSlider:w,InfoIcon:U,ElInputNumber:ee},computed:{value:{get(){return this.$store.state.flux?.config?.count},set(e){console.debug(`set count`,e),this.$store.commit(`flux/setConfig`,{...this.$store.state.flux?.config,count:e})}}},mounted(){this.value||=1}}),fe={class:`flex justify-between`},pe={class:`flex justify-start items-center`},me={class:`text-sm font-bold`},he={class:`flex justify-end items-center`},ge={class:`w-full`};function _e(e,t,n,i,o,s){let c=f(`info-icon`),d=f(`el-input-number`),m=f(`el-slider`);return u(),p(`div`,null,[r(`div`,fe,[r(`div`,pe,[r(`span`,me,l(e.$t(`flux.name.numbers`)),1),a(c,{content:e.$t(`flux.description.numbers`)},null,8,[`content`])]),r(`div`,he,[a(d,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,"controls-position":`right`},null,8,[`modelValue`])])]),r(`div`,ge,[a(m,{modelValue:e.value,"onUpdate:modelValue":t[1]||=t=>e.value=t,min:1,max:4,step:1},null,8,[`modelValue`])])])}var ve=O(de,[[`render`,_e]]),ye=s({name:`ActionSelector`,components:{ElSelect:v,ElOption:y},props:{modelValue:{type:String,default:void 0}},emits:[`update:modelValue`],data(){return{options:[{value:`generate`,label:this.$t(`flux.name.generate`)},{value:`edits`,label:this.$t(`flux.name.edits`)}]}},computed:{value:{get(){return this.$store.state.flux?.config?.action},set(e){this.$store.commit(`flux/setConfig`,{...this.$store.state.flux.config,action:e})}}},mounted(){this.value||=T}}),be={class:`field`},xe={class:`title font-bold`};function Se(e,t,i,o,s,d){let h=f(`el-option`),_=f(`el-select`);return u(),p(`div`,be,[r(`h2`,xe,l(e.$t(`flux.name.task`)),1),a(_,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,class:`value`,placeholder:e.$t(`flux.placeholder.select`)},{default:m(()=>[(u(!0),p(g,null,c(e.options,e=>(u(),n(h,{key:e.value,label:e.label,value:e.value},null,8,[`label`,`value`]))),128))]),_:1},8,[`modelValue`,`placeholder`])])}var Ce=O(ye,[[`render`,Se],[`__scopeId`,`data-v-81fd05e5`]]),we=s({name:`ImageUrlInput`,components:{ElUpload:b,ElButton:_,InfoIcon:U,FontAwesomeIcon:R,ImagePreview:B},mixins:[N,F],emits:[`change`],data(){return{fileList:[],uploadUrl:M()+`/api/v1/files/`}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e?.response?.file_url)}},watch:{urls:{handler(e){console.debug(`URLs changed:`,e),this.$store.commit(`flux/setConfig`,{...this.$store.state.flux.config,image_url:e[0]})}}},methods:{onExceed(){P.warning(this.$t(`flux.message.uploadStartImageExceed`))},onError(){P.error(this.$t(`flux.message.uploadStartImageError`))}}}),Te={class:`relative`},Ee={class:`flex justify-between`},De={class:`flex justify-start items-center`},Oe={class:`text-sm font-bold`};function ke(e,t,n,o,s,c){let d=f(`info-icon`),h=f(`image-preview`),g=f(`font-awesome-icon`),_=f(`el-button`),v=f(`el-upload`);return u(),p(`div`,Te,[r(`div`,Ee,[r(`div`,De,[r(`span`,Oe,l(e.$t(`flux.name.imageUrl`)),1),a(d,{content:e.$t(`flux.description.imageUrl`)},null,8,[`content`])])]),a(v,{ref:`uploader`,"file-list":e.fileList,"onUpdate:fileList":t[0]||=t=>e.fileList=t,name:`file`,limit:5,class:`upload-wrapper`,accept:`.png,.jpg,.jpeg,.gif,.bmp,.webp`,multiple:!0,"list-type":`picture`,action:e.uploadUrl,"on-exceed":e.onExceed,"on-error":e.onError,headers:e.headers},{file:m(({file:t})=>[a(h,{url:t.url||t.response?.file_url,name:t.name,percentage:t.percentage,onRemove:n=>e.fileList.splice(e.fileList.indexOf(t),1)},null,8,[`url`,`name`,`percentage`,`onRemove`])]),default:m(()=>[a(_,{round:``,type:`primary`,size:`small`,class:`btn btn-upload`},{default:m(()=>[a(g,{icon:`fa-solid fa-upload`,class:`icon mr-1`}),i(` `+l(e.$t(`flux.button.uploadImageUrl`)),1)]),_:1})]),_:1},8,[`file-list`,`action`,`on-exceed`,`on-error`,`headers`])])}var Ae=O(we,[[`render`,ke],[`__scopeId`,`data-v-7482072d`]]),je=s({name:`PromptInput`,components:{PromptTextarea:K},computed:{prompt:{get(){return this.$store.state.flux?.config?.prompt},set(e){this.$store.commit(`flux/setConfig`,{...this.$store.state.flux?.config,prompt:e})}}},mounted(){this.prompt||=``}});function Me(e,t,r,i,a,o){let s=f(`prompt-textarea`);return u(),n(s,{modelValue:e.prompt,"onUpdate:modelValue":t[0]||=t=>e.prompt=t,title:e.$t(`flux.name.prompt`),info:e.$t(`flux.description.prompt`),placeholder:e.$t(`flux.placeholder.prompt`)},null,8,[`modelValue`,`title`,`info`,`placeholder`])}var Ne=s({name:`PresetPanel`,components:{ElButton:_,FontAwesomeIcon:R,PromptInput:O(je,[[`render`,Me]]),ModelSelector:ue,CountSelector:ve,Consumption:J,ActionSelector:Ce,ImageUrlInput:Ae},emits:[`generate`],computed:{config(){return this.$store.state.flux?.config},consumption(){return A(this.config,this.service?.cost)},service(){return this.$store.state.flux?.service}},methods:{onGenerate(){this.$emit(`generate`)}}}),Pe={class:`flex flex-col h-full`},Fe={class:`flex-1 overflow-y-auto p-5`},Ie={class:`flex flex-col items-center justify-center px-5 pb-5`};function Le(e,t,s,c,d,h){let g=f(`action-selector`),_=f(`prompt-input`),v=f(`image-url-input`),y=f(`model-selector`),b=f(`count-selector`),x=f(`consumption`),S=f(`font-awesome-icon`),C=f(`el-button`);return u(),p(`div`,Pe,[r(`div`,Fe,[a(g,{class:`mb-4`}),a(_,{class:`mb-4`}),e.config?.action===`edits`?(u(),n(v,{key:0,class:`mb-4`})):o(``,!0),a(y,{class:`mb-4`}),a(b,{class:`mb-4`})]),r(`div`,Ie,[a(x,{value:e.consumption,service:e.service},null,8,[`value`,`service`]),a(C,{type:`primary`,class:`btn w-full`,round:``,onClick:e.onGenerate},{default:m(()=>[a(S,{icon:`fa-solid fa-magic`,class:`mr-2`}),i(` `+l(e.$t(`flux.button.generate`)),1)]),_:1},8,[`onClick`])])])}var Re=O(Ne,[[`render`,Le]]),ze=s({name:`TaskPreview`,components:{ElImage:x,CopyToClipboard:z,FontAwesomeIcon:R,ElAlert:S,ImageWrapper:X,ApiCodeButton:Y},props:{modelValue:{type:Object,required:!0}},data(){return{}},computed:{application(){return this.$store.state.flux?.application},config(){return this.$store.state.flux?.config},images(){let e=[],t=this.modelValue?.request?.action;return Array.isArray(this.modelValue?.response?.data)&&this.modelValue?.response?.data?.forEach(n=>{let r=n;t&&(r.action=t),e.push(r)}),e}},methods:{onDownload(e,t){e?.stopPropagation(),console.log(`on download`),window.open(t,`_blank`)},onOpenImage(e){window.open(e,`_blank`)}}}),Be={class:`preview`},Ve={class:`left`},He={class:`main`},Ue={class:`bot`},We={class:`datetime`},Ge={class:`info`},Ke={key:0,class:`prompt mt-2`},qe={key:0},Je={key:0,class:t({content:!0,failed:!0})},Ye={class:`flex justify-start items-center gap-4 w-full overflow-x-auto`},Xe={class:t({operations:!0,"mt-2":!0,"mb-2":!0})},Ze={class:`text-[var(--el-text-color-regular)] text-xs mb-2`},Qe={class:`text-[var(--el-text-color-regular)] text-xs mb-2`},$e={key:0,class:`text-[var(--el-text-color-regular)] text-xs mb-0`},et={key:1,class:t({content:!0})},tt={class:`text-[var(--el-text-color-regular)] text-xs mb-2`},$={class:`text-[var(--el-text-color-regular)] text-xs mb-2`},nt={key:0,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},rt={class:`text-[var(--el-text-color-regular)] text-xs mb-0`},it={key:2,class:t({content:!0})},at={class:`text-[var(--el-text-color-regular)] text-xs mb-0`};function ot(e,t,s,d,h,_){let v=f(`el-image`),y=f(`image-wrapper`),b=f(`api-code-button`),x=f(`font-awesome-icon`),S=f(`copy-to-clipboard`),C=f(`el-alert`);return u(),p(`div`,Be,[r(`div`,Ve,[a(v,{src:`https://cdn.acedata.cloud/ogm2oa.png`,class:`avatar`})]),r(`div`,He,[r(`div`,Ue,[i(l(e.$t(`flux.name.fluxBot`))+` `,1),r(`span`,We,l(e.$dayjs.format(``+new Date(parseFloat((e.modelValue?.created_at||``).toString())*1e3))),1)]),r(`div`,Ge,[e.modelValue?.request?.prompt?(u(),p(`p`,Ke,[i(l(e.modelValue?.request?.prompt)+` `,1),e.modelValue?.response?o(``,!0):(u(),p(`span`,qe,` - (`+l(e.$t(`flux.status.pending`))+`) `,1))])):o(``,!0)]),e.modelValue?.response?.success===!0?(u(),p(`div`,Je,[r(`div`,Ye,[(u(!0),p(g,null,c(e.images,(e,t)=>(u(),n(y,{key:t,src:e?.image_url,"raw-src":e?.image_url,"model-value":e},null,8,[`src`,`raw-src`,`model-value`]))),128))]),r(`div`,Xe,[a(b,{path:`/flux/images`,body:e.modelValue?.request},null,8,[`body`])]),a(C,{closable:!1,class:`mt-2 success`},{default:m(()=>[r(`p`,Ze,[a(x,{icon:`fa-solid fa-hashtag`,class:`mr-1`}),i(` `+l(e.$t(`flux.name.model`))+`: `+l(e.modelValue?.request?.model),1)]),r(`p`,Qe,[a(x,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+l(e.$t(`flux.name.taskId`))+`: `+l(e.modelValue?.id)+` `,1),a(S,{content:e.modelValue?.id,class:`btn-copy inline-block`},null,8,[`content`])]),e.modelValue?.elapsed?(u(),p(`p`,$e,[a(x,{icon:`fa-solid fa-clock`,class:`mr-1`}),i(` `+l(e.$t(`flux.name.elapsed`))+`: `+l(e.modelValue?.elapsed?.toFixed(2))+`s `,1)])):o(``,!0)]),_:1})])):o(``,!0),e.modelValue?.response?.success===!1?(u(),p(`div`,et,[a(C,{closable:!1,class:`failure`},{template:m(()=>[a(x,{icon:`fa-solid fa-exclamation-triangle`,class:`mr-1`}),i(` `+l(e.$t(`flux.name.failure`)),1)]),default:m(()=>[r(`p`,tt,[a(x,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+l(e.$t(`flux.name.taskId`))+`: `+l(e.modelValue?.id)+` `,1),a(S,{content:e.modelValue?.id,class:`btn-copy`},null,8,[`content`])]),r(`p`,$,[a(x,{icon:`fa-solid fa-circle-info`,class:`mr-1`}),i(` `+l(e.$t(`flux.name.failureReason`))+`: `+l(e.modelValue?.response?.error?.message)+` `,1),a(S,{content:e.modelValue?.response?.error?.message,class:`btn-copy`},null,8,[`content`])]),e.modelValue?.elapsed?(u(),p(`p`,nt,[a(x,{icon:`fa-solid fa-clock`,class:`mr-1`}),i(` `+l(e.$t(`flux.name.elapsed`))+`: `+l(e.modelValue?.elapsed?.toFixed(2))+`s `,1)])):o(``,!0),r(`p`,rt,[a(x,{icon:`fa-solid fa-hashtag`,class:`mr-1`}),i(` `+l(e.$t(`flux.name.traceId`))+`: `+l(e.modelValue?.response?.trace_id)+` `,1),a(S,{content:e.modelValue?.response?.trace_id,class:`btn-copy`},null,8,[`content`])])]),_:1})])):o(``,!0),e.modelValue?.response?o(``,!0):(u(),p(`div`,it,[a(C,{closable:!1,class:`info`},{template:m(()=>[a(x,{icon:`fa-solid fa-exclamation-triangle`,class:`mr-1`}),i(` `+l(e.$t(`flux.name.failure`)),1)]),default:m(()=>[r(`p`,at,[a(x,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+l(e.$t(`flux.name.taskId`))+`: `+l(e.modelValue?.id)+` `,1),a(S,{content:e.modelValue?.id,class:`btn-copy`},null,8,[`content`])])]),_:1})]))])])}var st=s({name:`RecentPanel`,components:{TaskPreview:O(ze,[[`render`,ot],[`__scopeId`,`data-v-bf1b183c`]]),BotPlaceholder:H,NoTasks:q,ScrollList:W},props:{loading:{type:Boolean,default:!1}},emits:[`reach-top`],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.flux?.tasks,items:this.$store.state.flux?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),ct={key:0},lt={key:2,class:`w-full h-full flex items-center justify-center`};function ut(e,t,r,i,s,l){let d=f(`bot-placeholder`),h=f(`task-preview`),_=f(`scroll-list`),v=f(`no-tasks`);return u(),p(g,null,[e.tasks?.items===void 0?(u(),p(`div`,ct,[a(d)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(u(),n(_,{key:1,ref:`scrollList`,class:`tasks h-full w-full overflow-y-auto`,loading:e.loading,onReachTop:t[0]||=t=>e.$emit(`reach-top`)},{default:m(()=>[(u(!0),p(g,null,c(e.tasks?.items,e=>(u(),n(h,{key:e.id,"model-value":e},null,8,[`model-value`]))),128))]),_:1},8,[`loading`])):o(``,!0),e.tasks?.items?.length===0?(u(),p(`div`,lt,[a(v)])):o(``,!0)],64)}var dt=O(st,[[`render`,ut]]),ft=D(`flux`),pt=s({name:`FluxIndex`,components:{ConfigPanel:Re,Layout:ae,RecentPanel:dt},mixins:[te],inject:[`initialized`],data(){return{task:void 0,job:0,loadingMore:!1,fetchingTasks:!1}},computed:{applicationsLoading(){return this.$store.state.flux?.status?.getApplications===L.Request},tasksLoading(){return this.$store.state.flux?.status?.getTasks===L.Request||this.fetchingTasks},credential(){return this.$store.state.flux?.credential},config(){return this.$store.state.flux?.config},application(){return this.$store.state.flux?.application},tasks(){return this.$store.state.flux?.tasks}},watch:{tasks:{handler(e,t){e?.items?.length>t?.items?.length&&console.debug(`new tasks detected`)},deep:!0},initialized:{async handler(e){e&&(console.debug(`layout initialized`),await this.onGetTasks(),await this.onScrollDown(),this.job=window.setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){window.clearInterval(this.job)},methods:{async onReachTop(){await G({tasks:this.tasks,getTasks:()=>this.tasks,loading:this.loadingMore,setLoading:e=>this.loadingMore=e,isBlocked:()=>this.tasksLoading||this.applicationsLoading,fetch:e=>this.onGetTasks({createdAtMax:e}),getScrollElement:()=>this.getTasksScrollElement()})},async onGetService(){console.debug(`start onGetService`),await this.$store.dispatch(`flux/getService`),console.debug(`end onGetService`)},async onGetApplication(){console.debug(`start onGetApplication`),await this.$store.dispatch(`flux/getApplications`),console.debug(`end onGetApplication`),await this.onGetTasks()},async onScrollDown(){await this.$nextTick();let e=this.getTasksScrollElement();e&&(e.scrollTop=e.scrollHeight)},async onGetTasks(e){if(this.applicationsLoading||this.fetchingTasks){console.debug(`loading`);return}console.debug(`start onGetTasks`,e);let{limit:t=5,createdAtMin:n,createdAtMax:r}=e||{};console.debug(`limit`,t,`createdAtMin`,n,`createdAtMax`,r),this.fetchingTasks=!0;try{await this.$store.dispatch(`flux/getTasks`,{limit:t,createdAtMin:n,createdAtMax:r})}finally{this.fetchingTasks=!1}},async onGenerate(){if(!j(this.uploadTracker,e=>this.$t(e),e=>P.warning(e)))return;let e={...this.config,callback_url:ft},t=this.credential?.token;if(!t){console.error(`no token specified`);return}P.info(this.$t(`flux.message.startingTask`)),k(`flux`,I.generate(e,{token:t})).then(()=>{P.success(this.$t(`flux.message.startTaskSuccess`))}).catch(e=>{let t=e?.response?.data;t?.error?.code===`used_up`?P.error(this.$t(`flux.message.usedUp`)):P.error(this.$t(`flux.message.startTaskFailed`)+t?.error?.message)}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function mt(e,t,r,i,o,s){let c=f(`config-panel`),l=f(`recent-panel`),d=f(`layout`);return u(),n(d,null,{config:m(()=>[a(c,{onGenerate:e.onGenerate},null,8,[`onGenerate`])]),result:m(()=>[a(l,{ref:`recentPanel`,loading:e.loadingMore,onReachTop:e.onReachTop},null,8,[`loading`,`onReachTop`])]),_:1})}var ht=O(pt,[[`render`,mt]]);export{ht as default};
@@ -1 +1 @@
1
- import"./rolldown-runtime--c01j_DQ.js";import{$ as e,D as t,E as n,M as r,N as i,O as a,P as o,Q as s,Ut as c,X as l,et as u,j as d,k as f,lt as p,x as m}from"./vendor-chart-mdwpew_o.js";import{t as h}from"./button-DWzbdjZV.js";import{r as g,t as _}from"./select-CqM5oalI.js";import{n as v,t as y}from"./collapse-_9L7y8Kn.js";import{t as b}from"./drawer-BvYPSxXh.js";import"./constants-BVtW3DRs.js";import{E as x,Ir as S,Nt as C,kr as w,yr as T}from"./index-DGgsHGQJ.js";import{t as E}from"./index.es-CX_i3qgT.js";import{t as ee}from"./Consumption-Ci-3V7yB.js";var te=o({name:`LayoutSerp`,components:{ElDrawer:b,ElButton:h,FontAwesomeIcon:E},data(){return{drawer:!1}}}),D={class:`main flex flex-row flex-1`},O={class:`config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]`},k={class:`result h-full flex-1 flex flex-col min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]`};function A(t,r,a,o,s,c){let d=u(`font-awesome-icon`),m=u(`el-button`),h=u(`el-drawer`);return l(),f(`div`,D,[n(`div`,O,[e(t.$slots,`config`,{},void 0,!0)]),n(`div`,k,[e(t.$slots,`result`,{},void 0,!0)]),i(m,{circle:``,class:`menu`,onClick:r[0]||=e=>t.drawer=!0},{default:p(()=>[i(d,{icon:`fa-solid fa-search`})]),_:1}),i(h,{modelValue:t.drawer,"onUpdate:modelValue":r[1]||=e=>t.drawer=e,direction:`ltr`,"with-header":!1,size:`340px`,class:`drawer`},{default:p(()=>[e(t.$slots,`config`,{},void 0,!0)]),_:3},8,[`modelValue`])])}var j=x(te,[[`render`,A],[`__scopeId`,`data-v-72398911`]]),M=o({name:`QueryInput`,components:{ElInput:S},computed:{query:{get(){return this.$store.state.serp?.config?.query},set(e){this.$store.commit(`serp/setConfig`,{...this.$store.state.serp?.config,query:e})}}}}),N={class:`field`},P={class:`box`},F={class:`title font-bold`};function I(e,t,r,a,o,s){let d=u(`el-input`);return l(),f(`div`,N,[n(`div`,P,[n(`h2`,F,c(e.$t(`serp.name.query`)),1)]),i(d,{modelValue:e.query,"onUpdate:modelValue":t[0]||=t=>e.query=t,rows:3,type:`textarea`,class:`prompt`,placeholder:e.$t(`serp.placeholder.query`)},null,8,[`modelValue`,`placeholder`])])}var L=x(M,[[`render`,I],[`__scopeId`,`data-v-3582b195`]]),R=o({name:`TypeSelector`,components:{ElSelect:g,ElOption:_},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||=`search`}}),z={class:`field`},B={class:`title font-bold`};function V(e,t,r,a,o,s){let d=u(`el-option`),m=u(`el-select`);return l(),f(`div`,z,[n(`h2`,B,c(e.$t(`serp.name.type`)),1),i(m,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,class:`value`},{default:p(()=>[i(d,{value:`search`,label:e.$t(`serp.type.search`)},null,8,[`label`]),i(d,{value:`images`,label:e.$t(`serp.type.images`)},null,8,[`label`]),i(d,{value:`news`,label:e.$t(`serp.type.news`)},null,8,[`label`]),i(d,{value:`videos`,label:e.$t(`serp.type.videos`)},null,8,[`label`])]),_:1},8,[`modelValue`])])}var H=x(R,[[`render`,V],[`__scopeId`,`data-v-2913fb62`]]),U=o({name:`CountryInput`,components:{ElInput:S},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||=`US`}}),W={class:`field`},G={class:`title font-bold`};function K(e,t,r,a,o,s){let d=u(`el-input`);return l(),f(`div`,W,[n(`h2`,G,c(e.$t(`serp.name.country`)),1),i(d,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,class:`value`,placeholder:e.$t(`serp.placeholder.country`)},null,8,[`modelValue`,`placeholder`])])}var q=x(U,[[`render`,K],[`__scopeId`,`data-v-f0672cc6`]]),J=o({name:`LanguageInput`,components:{ElInput:S},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||=`en`}}),Y={class:`field`},X={class:`title font-bold`};function Z(e,t,r,a,o,s){let d=u(`el-input`);return l(),f(`div`,Y,[n(`h2`,X,c(e.$t(`serp.name.language`)),1),i(d,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,class:`value`,placeholder:e.$t(`serp.placeholder.language`)},null,8,[`modelValue`,`placeholder`])])}var Q=o({name:`SearchPanel`,components:{ElButton:h,FontAwesomeIcon:E,QueryInput:L,TypeSelector:H,CountryInput:q,LanguageInput:x(J,[[`render`,Z],[`__scopeId`,`data-v-dc1c94b7`]]),Consumption:ee},emits:[`search`],computed:{config(){return this.$store.state.serp?.config},consumption(){return C(this.config,this.service?.cost)},service(){return this.$store.state.serp?.service},searching(){return this.$store.state.serp?.status?.search===T.Request}},methods:{onSearch(){this.$emit(`search`)}}}),ne={class:`flex flex-col h-full`},re={class:`flex-1 overflow-y-auto p-5`},ie={class:`flex flex-col items-center justify-center px-5 pb-5`};function ae(e,t,a,o,s,d){let m=u(`query-input`),h=u(`type-selector`),g=u(`country-input`),_=u(`language-input`),v=u(`consumption`),y=u(`font-awesome-icon`),b=u(`el-button`);return l(),f(`div`,ne,[n(`div`,re,[i(m,{class:`mb-4`}),i(h,{class:`mb-4`}),i(g,{class:`mb-4`}),i(_,{class:`mb-4`})]),n(`div`,ie,[i(v,{value:e.consumption,service:e.service},null,8,[`value`,`service`]),i(b,{type:`primary`,class:`btn w-full`,round:``,loading:e.searching,onClick:e.onSearch},{default:p(()=>[i(y,{icon:`fa-solid fa-search`,class:`mr-2`}),r(` `+c(e.$t(`serp.button.search`)),1)]),_:1},8,[`loading`,`onClick`])])])}var oe=x(Q,[[`render`,ae]]),se=o({name:`KnowledgeGraph`,props:{data:{type:Object,required:!0}}}),ce={class:`knowledge-graph rounded-xl border border-[var(--el-border-color-lighter)] p-5 bg-[var(--el-fill-color-blank)]`},le={class:`flex flex-row gap-4`},ue=[`src`,`alt`],de={class:`flex-1 min-w-0`},fe={key:0,class:`text-xs text-[var(--el-text-color-disabled)] mb-1 uppercase tracking-wide`},pe={class:`text-xl font-bold mb-1.5`},me={key:1,class:`text-sm text-[var(--el-text-color-regular)] mb-3 leading-relaxed`},he=[`href`],ge={key:2,class:`text-sm`},_e={class:`text-[var(--el-text-color-disabled)] flex-none font-medium`},ve={class:`text-[var(--el-text-color-regular)]`};function ye(e,t,i,o,u,d){return l(),f(`div`,ce,[n(`div`,le,[e.data.image_url?(l(),f(`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,ue)):a(``,!0),n(`div`,de,[e.data.type?(l(),f(`div`,fe,c(e.data.type),1)):a(``,!0),n(`h3`,pe,c(e.data.title),1),e.data.description?(l(),f(`p`,me,[r(c(e.data.description)+` `,1),e.data.description_link?(l(),f(`a`,{key:0,href:e.data.description_link,target:`_blank`,rel:`noopener noreferrer`,class:`text-[var(--el-color-primary)] hover:underline ml-1`},c(e.data.description_source||`Source`),9,he)):a(``,!0)])):a(``,!0),e.data.attributes&&Object.keys(e.data.attributes).length?(l(),f(`div`,ge,[(l(!0),f(m,null,s(e.data.attributes,(e,t)=>(l(),f(`div`,{key:t,class:`flex gap-2 mb-1 py-0.5`},[n(`span`,_e,c(t)+`:`,1),n(`span`,ve,c(e),1)]))),128))])):a(``,!0)])])])}var be=x(se,[[`render`,ye]]),xe=o({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{let 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`}}}),Se={class:`organic-result rounded-lg p-4 transition-all duration-200 hover:bg-[var(--el-fill-color-lighter)]`},Ce={key:0,class:`flex items-center gap-2 mb-1.5`},we=[`src`,`alt`],Te={class:`text-xs text-[var(--el-text-color-secondary)] truncate`},Ee={class:`text-xs text-[var(--el-text-color-disabled)]`},De=[`href`],Oe={key:1,class:`text-xs text-[var(--el-text-color-disabled)] mt-1`},ke={key:2,class:`text-sm text-[var(--el-text-color-regular)] mt-1.5 leading-relaxed line-clamp-3`},Ae={key:3,class:`mt-3 flex flex-wrap gap-x-4 gap-y-1`},je=[`href`];function Me(e,t,r,i,o,u){return l(),f(`div`,Se,[e.displayUrl?(l(),f(`div`,Ce,[n(`img`,{src:e.faviconUrl,alt:e.hostname,class:`w-4 h-4 rounded-sm flex-none`,loading:`lazy`,onError:t[0]||=(...t)=>e.onFaviconError&&e.onFaviconError(...t)},null,40,we),n(`span`,Te,c(e.hostname),1),n(`span`,Ee,c(e.pathname),1)])):a(``,!0),n(`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`},c(e.data.title),9,De),e.data.date?(l(),f(`div`,Oe,c(e.data.date),1)):a(``,!0),e.data.snippet?(l(),f(`p`,ke,c(e.data.snippet),1)):a(``,!0),e.data.sitelinks?.length?(l(),f(`div`,Ae,[(l(!0),f(m,null,s(e.data.sitelinks,(e,t)=>(l(),f(`a`,{key:t,href:e.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`},c(e.title),9,je))),128))])):a(``,!0)])}var Ne=x(xe,[[`render`,Me]]),Pe=o({name:`ImageResults`,props:{data:{type:Array,required:!0}}}),Fe={class:`rounded-xl border border-[var(--el-border-color-lighter)] p-5 bg-[var(--el-fill-color-blank)]`},Ie={class:`text-base font-bold mb-3`},Le={class:`grid grid-cols-2 sm:grid-cols-3 md:grid-cols-4 gap-3`},Re=[`href`],ze=[`src`,`alt`],Be={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`},Ve={class:`text-xs text-white line-clamp-2`};function He(e,t,r,i,o,u){return l(),f(`div`,Fe,[n(`h3`,Ie,c(e.$t(`serp.name.imageResults`)),1),n(`div`,Le,[(l(!0),f(m,null,s(e.data,(e,t)=>(l(),f(`a`,{key:t,href:e.link,target:`_blank`,rel:`noopener noreferrer`,class:`group relative rounded-lg overflow-hidden bg-[var(--el-fill-color-light)] aspect-square`},[e.image_url?(l(),f(`img`,{key:0,src:e.image_url,alt:e.title,class:`w-full h-full object-cover transition-transform duration-300 group-hover:scale-105`,loading:`lazy`},null,8,ze)):a(``,!0),n(`div`,Be,[n(`span`,Ve,c(e.title),1)])],8,Re))),128))])])}var Ue=x(Pe,[[`render`,He]]),We=o({name:`VideoResults`,props:{data:{type:Array,required:!0}}}),Ge={class:`text-base font-bold mb-3`},Ke={class:`space-y-4`},qe=[`href`],Je={class:`relative flex-shrink-0 w-40 h-24 rounded overflow-hidden bg-gray-100 dark:bg-gray-800`},Ye=[`src`,`alt`],Xe={key:1,class:`absolute bottom-1 right-1 bg-black/80 text-white text-xs px-1 rounded`},Ze={class:`flex-1 min-w-0`},Qe={class:`text-blue-600 group-hover:underline font-medium line-clamp-2`},$e={class:`text-xs text-gray-400 mt-1`},et={key:0},tt={key:1},nt={key:2},rt={key:0,class:`text-sm text-gray-600 dark:text-gray-300 mt-1 line-clamp-2`};function it(e,t,r,i,o,u){return l(),f(`div`,null,[n(`h3`,Ge,c(e.$t(`serp.name.videoResults`)),1),n(`div`,Ke,[(l(!0),f(m,null,s(e.data,(e,t)=>(l(),f(`a`,{key:t,href:e.link,target:`_blank`,rel:`noopener noreferrer`,class:`flex gap-4 group`},[n(`div`,Je,[e.image_url?(l(),f(`img`,{key:0,src:e.image_url,alt:e.title,class:`w-full h-full object-cover`,loading:`lazy`},null,8,Ye)):a(``,!0),e.duration?(l(),f(`div`,Xe,c(e.duration),1)):a(``,!0)]),n(`div`,Ze,[n(`div`,Qe,c(e.title),1),n(`div`,$e,[e.source?(l(),f(`span`,et,c(e.source),1)):a(``,!0),e.channel?(l(),f(`span`,tt,` · `+c(e.channel),1)):a(``,!0),e.date?(l(),f(`span`,nt,` · `+c(e.date),1)):a(``,!0)]),e.snippet?(l(),f(`p`,rt,c(e.snippet),1)):a(``,!0)])],8,qe))),128))])])}var at=x(We,[[`render`,it]]),ot=o({name:`NewsResults`,props:{data:{type:Array,required:!0}}}),st={class:`text-base font-bold mb-3`},ct={class:`space-y-4`},lt=[`href`],ut={class:`flex-1 min-w-0`},dt={class:`text-blue-600 group-hover:underline font-medium line-clamp-2`},ft={class:`text-xs text-gray-400 mt-1`},pt={key:0},mt={key:1},ht={key:0,class:`text-sm text-gray-600 dark:text-gray-300 mt-1 line-clamp-2`},gt={key:0,class:`flex-shrink-0 w-24 h-24 rounded overflow-hidden bg-gray-100 dark:bg-gray-800`},_t=[`src`,`alt`];function vt(e,t,r,i,o,u){return l(),f(`div`,null,[n(`h3`,st,c(e.$t(`serp.name.newsResults`)),1),n(`div`,ct,[(l(!0),f(m,null,s(e.data,(e,t)=>(l(),f(`a`,{key:t,href:e.link,target:`_blank`,rel:`noopener noreferrer`,class:`flex gap-4 group`},[n(`div`,ut,[n(`div`,dt,c(e.title),1),n(`div`,ft,[e.source?(l(),f(`span`,pt,c(e.source),1)):a(``,!0),e.date?(l(),f(`span`,mt,` · `+c(e.date),1)):a(``,!0)]),e.snippet?(l(),f(`p`,ht,c(e.snippet),1)):a(``,!0)]),e.image_url?(l(),f(`div`,gt,[n(`img`,{src:e.image_url,alt:e.title,class:`w-full h-full object-cover`,loading:`lazy`},null,8,_t)])):a(``,!0)],8,lt))),128))])])}var yt=x(ot,[[`render`,vt]]),bt=o({name:`PeopleAlsoAsk`,components:{ElCollapse:y,ElCollapseItem:v},props:{data:{type:Array,required:!0}}}),xt={class:`rounded-xl border border-[var(--el-border-color-lighter)] p-5 bg-[var(--el-fill-color-blank)]`},St={class:`text-base font-bold mb-3`},Ct={key:0,class:`text-sm text-[var(--el-text-color-regular)] mb-2 leading-relaxed`},wt=[`href`];function Tt(e,r,o,d,h,g){let _=u(`el-collapse-item`),v=u(`el-collapse`);return l(),f(`div`,xt,[n(`h3`,St,c(e.$t(`serp.name.peopleAlsoAsk`)),1),i(v,null,{default:p(()=>[(l(!0),f(m,null,s(e.data,(e,n)=>(l(),t(_,{key:n,title:e.question||e.title||``},{default:p(()=>[e.snippet?(l(),f(`p`,Ct,c(e.snippet),1)):a(``,!0),e.link?(l(),f(`a`,{key:1,href:e.link,target:`_blank`,rel:`noopener noreferrer`,class:`text-xs text-[var(--el-color-primary)] hover:underline`},c(e.title||e.link),9,wt)):a(``,!0)]),_:2},1032,[`title`]))),128))]),_:1})])}var Et=x(bt,[[`render`,Tt]]),Dt=o({name:`RelatedSearches`,components:{FontAwesomeIcon:E},props:{data:{type:Array,required:!0}},emits:[`search`],methods:{onSearch(e){e&&this.$emit(`search`,e)}}}),Ot={class:`rounded-xl border border-[var(--el-border-color-lighter)] p-5 bg-[var(--el-fill-color-blank)]`},kt={class:`text-base font-bold mb-3`},At={class:`flex flex-wrap gap-2`},jt=[`onClick`];function Mt(e,t,a,o,d,p){let h=u(`font-awesome-icon`);return l(),f(`div`,Ot,[n(`h3`,kt,c(e.$t(`serp.name.relatedSearches`)),1),n(`div`,At,[(l(!0),f(m,null,s(e.data,(t,n)=>(l(),f(`button`,{key:n,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:n=>e.onSearch(t.query)},[i(h,{icon:`fa-solid fa-magnifying-glass`,class:`text-xs opacity-50`}),r(` `+c(t.query),1)],8,jt))),128))])])}var Nt=o({name:`ResultPanel`,components:{FontAwesomeIcon:E,KnowledgeGraph:be,OrganicResult:Ne,ImageResults:Ue,VideoResults:at,NewsResults:yt,PeopleAlsoAsk:Et,RelatedSearches:x(Dt,[[`render`,Mt]])},emits:[`related-search`],computed:{results(){return this.$store.state.serp?.results},searching(){return this.$store.state.serp?.status?.search===T.Request},noResults(){return this.$store.state.serp?.status?.search===T.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)}}}),$={class:`h-full overflow-y-auto p-6`},Pt={key:0,class:`max-w-3xl mx-auto py-8`},Ft={key:1,class:`flex flex-col items-center justify-center py-24 text-[var(--el-text-color-disabled)]`},It={class:`text-base`},Lt={key:2,class:`max-w-3xl mx-auto`},Rt={key:1,class:`mb-6`},zt={key:3,class:`flex flex-col items-center justify-center py-24 text-[var(--el-text-color-disabled)]`},Bt={class:`text-base`};function Vt(e,r,o,p,h,g){let _=u(`font-awesome-icon`),v=u(`knowledge-graph`),y=u(`organic-result`),b=u(`image-results`),x=u(`video-results`),S=u(`news-results`),C=u(`people-also-ask`),w=u(`related-searches`);return l(),f(`div`,$,[e.searching?(l(),f(`div`,Pt,[(l(),f(m,null,s(4,e=>n(`div`,{key:e,class:`mb-6 animate-pulse`},[...r[0]||=[d(`<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?(l(),f(`div`,Ft,[i(_,{icon:`fa-solid fa-face-meh`,class:`text-5xl mb-4 opacity-40`}),n(`p`,It,c(e.$t(`serp.message.noResults`)),1)])):e.results?(l(),f(`div`,Lt,[e.results.knowledge_graph?.title?(l(),t(v,{key:0,data:e.results.knowledge_graph,class:`mb-6`},null,8,[`data`])):a(``,!0),e.results.organic?.length?(l(),f(`div`,Rt,[(l(!0),f(m,null,s(e.results.organic,(e,n)=>(l(),t(y,{key:n,data:e,class:`mb-1`},null,8,[`data`]))),128))])):a(``,!0),e.results.images?.length?(l(),t(b,{key:2,data:e.results.images,class:`mb-6`},null,8,[`data`])):a(``,!0),e.results.videos?.length?(l(),t(x,{key:3,data:e.results.videos,class:`mb-6`},null,8,[`data`])):a(``,!0),e.results.news?.length?(l(),t(S,{key:4,data:e.results.news,class:`mb-6`},null,8,[`data`])):a(``,!0),e.results.people_also_ask?.length?(l(),t(C,{key:5,data:e.results.people_also_ask,class:`mb-6`},null,8,[`data`])):a(``,!0),e.results.related_searches?.length?(l(),t(w,{key:6,data:e.results.related_searches,class:`mb-6`,onSearch:e.onRelatedSearch},null,8,[`data`,`onSearch`])):a(``,!0)])):(l(),f(`div`,zt,[i(_,{icon:`fa-solid fa-globe`,class:`text-5xl mb-4 opacity-30`}),n(`p`,Bt,c(e.$t(`serp.description.query`)),1)]))])}var Ht=o({name:`SerpIndex`,components:{Layout:j,SearchPanel:oe,ResultPanel:x(Nt,[[`render`,Vt]])},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(e){(e?.response?.data)?.error?.code===`used_up`?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 Ut(e,n,r,a,o,s){let c=u(`search-panel`),d=u(`result-panel`),f=u(`layout`);return l(),t(f,null,{config:p(()=>[i(c,{onSearch:e.onSearch},null,8,[`onSearch`])]),result:p(()=>[i(d,{onRelatedSearch:e.onRelatedSearch},null,8,[`onRelatedSearch`])]),_:1})}var Wt=x(Ht,[[`render`,Ut]]);export{Wt as default};
1
+ import"./rolldown-runtime--c01j_DQ.js";import{$ as e,D as t,E as n,M as r,N as i,O as a,P as o,Q as s,Ut as c,X as l,et as u,j as d,k as f,lt as p,x as m}from"./vendor-chart-mdwpew_o.js";import{t as h}from"./button-DWzbdjZV.js";import{r as g,t as _}from"./select-CYdISXBV.js";import{n as v,t as y}from"./collapse-B99-bYjk.js";import{t as b}from"./drawer-BvYPSxXh.js";import"./constants-B6_fTlam.js";import{E as x,Ir as S,Nt as C,kr as w,yr as T}from"./index-DpREqzJQ.js";import{t as E}from"./index.es-DkXuZNXE.js";import{t as ee}from"./Consumption-CjrpUNmV.js";var te=o({name:`LayoutSerp`,components:{ElDrawer:b,ElButton:h,FontAwesomeIcon:E},data(){return{drawer:!1}}}),D={class:`main flex flex-row flex-1`},O={class:`config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]`},k={class:`result h-full flex-1 flex flex-col min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]`};function A(t,r,a,o,s,c){let d=u(`font-awesome-icon`),m=u(`el-button`),h=u(`el-drawer`);return l(),f(`div`,D,[n(`div`,O,[e(t.$slots,`config`,{},void 0,!0)]),n(`div`,k,[e(t.$slots,`result`,{},void 0,!0)]),i(m,{circle:``,class:`menu`,onClick:r[0]||=e=>t.drawer=!0},{default:p(()=>[i(d,{icon:`fa-solid fa-search`})]),_:1}),i(h,{modelValue:t.drawer,"onUpdate:modelValue":r[1]||=e=>t.drawer=e,direction:`ltr`,"with-header":!1,size:`340px`,class:`drawer`},{default:p(()=>[e(t.$slots,`config`,{},void 0,!0)]),_:3},8,[`modelValue`])])}var j=x(te,[[`render`,A],[`__scopeId`,`data-v-72398911`]]),M=o({name:`QueryInput`,components:{ElInput:S},computed:{query:{get(){return this.$store.state.serp?.config?.query},set(e){this.$store.commit(`serp/setConfig`,{...this.$store.state.serp?.config,query:e})}}}}),N={class:`field`},P={class:`box`},F={class:`title font-bold`};function I(e,t,r,a,o,s){let d=u(`el-input`);return l(),f(`div`,N,[n(`div`,P,[n(`h2`,F,c(e.$t(`serp.name.query`)),1)]),i(d,{modelValue:e.query,"onUpdate:modelValue":t[0]||=t=>e.query=t,rows:3,type:`textarea`,class:`prompt`,placeholder:e.$t(`serp.placeholder.query`)},null,8,[`modelValue`,`placeholder`])])}var L=x(M,[[`render`,I],[`__scopeId`,`data-v-3582b195`]]),R=o({name:`TypeSelector`,components:{ElSelect:g,ElOption:_},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||=`search`}}),z={class:`field`},B={class:`title font-bold`};function V(e,t,r,a,o,s){let d=u(`el-option`),m=u(`el-select`);return l(),f(`div`,z,[n(`h2`,B,c(e.$t(`serp.name.type`)),1),i(m,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,class:`value`},{default:p(()=>[i(d,{value:`search`,label:e.$t(`serp.type.search`)},null,8,[`label`]),i(d,{value:`images`,label:e.$t(`serp.type.images`)},null,8,[`label`]),i(d,{value:`news`,label:e.$t(`serp.type.news`)},null,8,[`label`]),i(d,{value:`videos`,label:e.$t(`serp.type.videos`)},null,8,[`label`])]),_:1},8,[`modelValue`])])}var H=x(R,[[`render`,V],[`__scopeId`,`data-v-2913fb62`]]),U=o({name:`CountryInput`,components:{ElInput:S},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||=`US`}}),W={class:`field`},G={class:`title font-bold`};function K(e,t,r,a,o,s){let d=u(`el-input`);return l(),f(`div`,W,[n(`h2`,G,c(e.$t(`serp.name.country`)),1),i(d,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,class:`value`,placeholder:e.$t(`serp.placeholder.country`)},null,8,[`modelValue`,`placeholder`])])}var q=x(U,[[`render`,K],[`__scopeId`,`data-v-f0672cc6`]]),J=o({name:`LanguageInput`,components:{ElInput:S},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||=`en`}}),Y={class:`field`},X={class:`title font-bold`};function Z(e,t,r,a,o,s){let d=u(`el-input`);return l(),f(`div`,Y,[n(`h2`,X,c(e.$t(`serp.name.language`)),1),i(d,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,class:`value`,placeholder:e.$t(`serp.placeholder.language`)},null,8,[`modelValue`,`placeholder`])])}var Q=o({name:`SearchPanel`,components:{ElButton:h,FontAwesomeIcon:E,QueryInput:L,TypeSelector:H,CountryInput:q,LanguageInput:x(J,[[`render`,Z],[`__scopeId`,`data-v-dc1c94b7`]]),Consumption:ee},emits:[`search`],computed:{config(){return this.$store.state.serp?.config},consumption(){return C(this.config,this.service?.cost)},service(){return this.$store.state.serp?.service},searching(){return this.$store.state.serp?.status?.search===T.Request}},methods:{onSearch(){this.$emit(`search`)}}}),ne={class:`flex flex-col h-full`},re={class:`flex-1 overflow-y-auto p-5`},ie={class:`flex flex-col items-center justify-center px-5 pb-5`};function ae(e,t,a,o,s,d){let m=u(`query-input`),h=u(`type-selector`),g=u(`country-input`),_=u(`language-input`),v=u(`consumption`),y=u(`font-awesome-icon`),b=u(`el-button`);return l(),f(`div`,ne,[n(`div`,re,[i(m,{class:`mb-4`}),i(h,{class:`mb-4`}),i(g,{class:`mb-4`}),i(_,{class:`mb-4`})]),n(`div`,ie,[i(v,{value:e.consumption,service:e.service},null,8,[`value`,`service`]),i(b,{type:`primary`,class:`btn w-full`,round:``,loading:e.searching,onClick:e.onSearch},{default:p(()=>[i(y,{icon:`fa-solid fa-search`,class:`mr-2`}),r(` `+c(e.$t(`serp.button.search`)),1)]),_:1},8,[`loading`,`onClick`])])])}var oe=x(Q,[[`render`,ae]]),se=o({name:`KnowledgeGraph`,props:{data:{type:Object,required:!0}}}),ce={class:`knowledge-graph rounded-xl border border-[var(--el-border-color-lighter)] p-5 bg-[var(--el-fill-color-blank)]`},le={class:`flex flex-row gap-4`},ue=[`src`,`alt`],de={class:`flex-1 min-w-0`},fe={key:0,class:`text-xs text-[var(--el-text-color-disabled)] mb-1 uppercase tracking-wide`},pe={class:`text-xl font-bold mb-1.5`},me={key:1,class:`text-sm text-[var(--el-text-color-regular)] mb-3 leading-relaxed`},he=[`href`],ge={key:2,class:`text-sm`},_e={class:`text-[var(--el-text-color-disabled)] flex-none font-medium`},ve={class:`text-[var(--el-text-color-regular)]`};function ye(e,t,i,o,u,d){return l(),f(`div`,ce,[n(`div`,le,[e.data.image_url?(l(),f(`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,ue)):a(``,!0),n(`div`,de,[e.data.type?(l(),f(`div`,fe,c(e.data.type),1)):a(``,!0),n(`h3`,pe,c(e.data.title),1),e.data.description?(l(),f(`p`,me,[r(c(e.data.description)+` `,1),e.data.description_link?(l(),f(`a`,{key:0,href:e.data.description_link,target:`_blank`,rel:`noopener noreferrer`,class:`text-[var(--el-color-primary)] hover:underline ml-1`},c(e.data.description_source||`Source`),9,he)):a(``,!0)])):a(``,!0),e.data.attributes&&Object.keys(e.data.attributes).length?(l(),f(`div`,ge,[(l(!0),f(m,null,s(e.data.attributes,(e,t)=>(l(),f(`div`,{key:t,class:`flex gap-2 mb-1 py-0.5`},[n(`span`,_e,c(t)+`:`,1),n(`span`,ve,c(e),1)]))),128))])):a(``,!0)])])])}var be=x(se,[[`render`,ye]]),xe=o({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{let 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`}}}),Se={class:`organic-result rounded-lg p-4 transition-all duration-200 hover:bg-[var(--el-fill-color-lighter)]`},Ce={key:0,class:`flex items-center gap-2 mb-1.5`},we=[`src`,`alt`],Te={class:`text-xs text-[var(--el-text-color-secondary)] truncate`},Ee={class:`text-xs text-[var(--el-text-color-disabled)]`},De=[`href`],Oe={key:1,class:`text-xs text-[var(--el-text-color-disabled)] mt-1`},ke={key:2,class:`text-sm text-[var(--el-text-color-regular)] mt-1.5 leading-relaxed line-clamp-3`},Ae={key:3,class:`mt-3 flex flex-wrap gap-x-4 gap-y-1`},je=[`href`];function Me(e,t,r,i,o,u){return l(),f(`div`,Se,[e.displayUrl?(l(),f(`div`,Ce,[n(`img`,{src:e.faviconUrl,alt:e.hostname,class:`w-4 h-4 rounded-sm flex-none`,loading:`lazy`,onError:t[0]||=(...t)=>e.onFaviconError&&e.onFaviconError(...t)},null,40,we),n(`span`,Te,c(e.hostname),1),n(`span`,Ee,c(e.pathname),1)])):a(``,!0),n(`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`},c(e.data.title),9,De),e.data.date?(l(),f(`div`,Oe,c(e.data.date),1)):a(``,!0),e.data.snippet?(l(),f(`p`,ke,c(e.data.snippet),1)):a(``,!0),e.data.sitelinks?.length?(l(),f(`div`,Ae,[(l(!0),f(m,null,s(e.data.sitelinks,(e,t)=>(l(),f(`a`,{key:t,href:e.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`},c(e.title),9,je))),128))])):a(``,!0)])}var Ne=x(xe,[[`render`,Me]]),Pe=o({name:`ImageResults`,props:{data:{type:Array,required:!0}}}),Fe={class:`rounded-xl border border-[var(--el-border-color-lighter)] p-5 bg-[var(--el-fill-color-blank)]`},Ie={class:`text-base font-bold mb-3`},Le={class:`grid grid-cols-2 sm:grid-cols-3 md:grid-cols-4 gap-3`},Re=[`href`],ze=[`src`,`alt`],Be={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`},Ve={class:`text-xs text-white line-clamp-2`};function He(e,t,r,i,o,u){return l(),f(`div`,Fe,[n(`h3`,Ie,c(e.$t(`serp.name.imageResults`)),1),n(`div`,Le,[(l(!0),f(m,null,s(e.data,(e,t)=>(l(),f(`a`,{key:t,href:e.link,target:`_blank`,rel:`noopener noreferrer`,class:`group relative rounded-lg overflow-hidden bg-[var(--el-fill-color-light)] aspect-square`},[e.image_url?(l(),f(`img`,{key:0,src:e.image_url,alt:e.title,class:`w-full h-full object-cover transition-transform duration-300 group-hover:scale-105`,loading:`lazy`},null,8,ze)):a(``,!0),n(`div`,Be,[n(`span`,Ve,c(e.title),1)])],8,Re))),128))])])}var Ue=x(Pe,[[`render`,He]]),We=o({name:`VideoResults`,props:{data:{type:Array,required:!0}}}),Ge={class:`text-base font-bold mb-3`},Ke={class:`space-y-4`},qe=[`href`],Je={class:`relative flex-shrink-0 w-40 h-24 rounded overflow-hidden bg-gray-100 dark:bg-gray-800`},Ye=[`src`,`alt`],Xe={key:1,class:`absolute bottom-1 right-1 bg-black/80 text-white text-xs px-1 rounded`},Ze={class:`flex-1 min-w-0`},Qe={class:`text-blue-600 group-hover:underline font-medium line-clamp-2`},$e={class:`text-xs text-gray-400 mt-1`},et={key:0},tt={key:1},nt={key:2},rt={key:0,class:`text-sm text-gray-600 dark:text-gray-300 mt-1 line-clamp-2`};function it(e,t,r,i,o,u){return l(),f(`div`,null,[n(`h3`,Ge,c(e.$t(`serp.name.videoResults`)),1),n(`div`,Ke,[(l(!0),f(m,null,s(e.data,(e,t)=>(l(),f(`a`,{key:t,href:e.link,target:`_blank`,rel:`noopener noreferrer`,class:`flex gap-4 group`},[n(`div`,Je,[e.image_url?(l(),f(`img`,{key:0,src:e.image_url,alt:e.title,class:`w-full h-full object-cover`,loading:`lazy`},null,8,Ye)):a(``,!0),e.duration?(l(),f(`div`,Xe,c(e.duration),1)):a(``,!0)]),n(`div`,Ze,[n(`div`,Qe,c(e.title),1),n(`div`,$e,[e.source?(l(),f(`span`,et,c(e.source),1)):a(``,!0),e.channel?(l(),f(`span`,tt,` · `+c(e.channel),1)):a(``,!0),e.date?(l(),f(`span`,nt,` · `+c(e.date),1)):a(``,!0)]),e.snippet?(l(),f(`p`,rt,c(e.snippet),1)):a(``,!0)])],8,qe))),128))])])}var at=x(We,[[`render`,it]]),ot=o({name:`NewsResults`,props:{data:{type:Array,required:!0}}}),st={class:`text-base font-bold mb-3`},ct={class:`space-y-4`},lt=[`href`],ut={class:`flex-1 min-w-0`},dt={class:`text-blue-600 group-hover:underline font-medium line-clamp-2`},ft={class:`text-xs text-gray-400 mt-1`},pt={key:0},mt={key:1},ht={key:0,class:`text-sm text-gray-600 dark:text-gray-300 mt-1 line-clamp-2`},gt={key:0,class:`flex-shrink-0 w-24 h-24 rounded overflow-hidden bg-gray-100 dark:bg-gray-800`},_t=[`src`,`alt`];function vt(e,t,r,i,o,u){return l(),f(`div`,null,[n(`h3`,st,c(e.$t(`serp.name.newsResults`)),1),n(`div`,ct,[(l(!0),f(m,null,s(e.data,(e,t)=>(l(),f(`a`,{key:t,href:e.link,target:`_blank`,rel:`noopener noreferrer`,class:`flex gap-4 group`},[n(`div`,ut,[n(`div`,dt,c(e.title),1),n(`div`,ft,[e.source?(l(),f(`span`,pt,c(e.source),1)):a(``,!0),e.date?(l(),f(`span`,mt,` · `+c(e.date),1)):a(``,!0)]),e.snippet?(l(),f(`p`,ht,c(e.snippet),1)):a(``,!0)]),e.image_url?(l(),f(`div`,gt,[n(`img`,{src:e.image_url,alt:e.title,class:`w-full h-full object-cover`,loading:`lazy`},null,8,_t)])):a(``,!0)],8,lt))),128))])])}var yt=x(ot,[[`render`,vt]]),bt=o({name:`PeopleAlsoAsk`,components:{ElCollapse:y,ElCollapseItem:v},props:{data:{type:Array,required:!0}}}),xt={class:`rounded-xl border border-[var(--el-border-color-lighter)] p-5 bg-[var(--el-fill-color-blank)]`},St={class:`text-base font-bold mb-3`},Ct={key:0,class:`text-sm text-[var(--el-text-color-regular)] mb-2 leading-relaxed`},wt=[`href`];function Tt(e,r,o,d,h,g){let _=u(`el-collapse-item`),v=u(`el-collapse`);return l(),f(`div`,xt,[n(`h3`,St,c(e.$t(`serp.name.peopleAlsoAsk`)),1),i(v,null,{default:p(()=>[(l(!0),f(m,null,s(e.data,(e,n)=>(l(),t(_,{key:n,title:e.question||e.title||``},{default:p(()=>[e.snippet?(l(),f(`p`,Ct,c(e.snippet),1)):a(``,!0),e.link?(l(),f(`a`,{key:1,href:e.link,target:`_blank`,rel:`noopener noreferrer`,class:`text-xs text-[var(--el-color-primary)] hover:underline`},c(e.title||e.link),9,wt)):a(``,!0)]),_:2},1032,[`title`]))),128))]),_:1})])}var Et=x(bt,[[`render`,Tt]]),Dt=o({name:`RelatedSearches`,components:{FontAwesomeIcon:E},props:{data:{type:Array,required:!0}},emits:[`search`],methods:{onSearch(e){e&&this.$emit(`search`,e)}}}),Ot={class:`rounded-xl border border-[var(--el-border-color-lighter)] p-5 bg-[var(--el-fill-color-blank)]`},kt={class:`text-base font-bold mb-3`},At={class:`flex flex-wrap gap-2`},jt=[`onClick`];function Mt(e,t,a,o,d,p){let h=u(`font-awesome-icon`);return l(),f(`div`,Ot,[n(`h3`,kt,c(e.$t(`serp.name.relatedSearches`)),1),n(`div`,At,[(l(!0),f(m,null,s(e.data,(t,n)=>(l(),f(`button`,{key:n,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:n=>e.onSearch(t.query)},[i(h,{icon:`fa-solid fa-magnifying-glass`,class:`text-xs opacity-50`}),r(` `+c(t.query),1)],8,jt))),128))])])}var Nt=o({name:`ResultPanel`,components:{FontAwesomeIcon:E,KnowledgeGraph:be,OrganicResult:Ne,ImageResults:Ue,VideoResults:at,NewsResults:yt,PeopleAlsoAsk:Et,RelatedSearches:x(Dt,[[`render`,Mt]])},emits:[`related-search`],computed:{results(){return this.$store.state.serp?.results},searching(){return this.$store.state.serp?.status?.search===T.Request},noResults(){return this.$store.state.serp?.status?.search===T.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)}}}),$={class:`h-full overflow-y-auto p-6`},Pt={key:0,class:`max-w-3xl mx-auto py-8`},Ft={key:1,class:`flex flex-col items-center justify-center py-24 text-[var(--el-text-color-disabled)]`},It={class:`text-base`},Lt={key:2,class:`max-w-3xl mx-auto`},Rt={key:1,class:`mb-6`},zt={key:3,class:`flex flex-col items-center justify-center py-24 text-[var(--el-text-color-disabled)]`},Bt={class:`text-base`};function Vt(e,r,o,p,h,g){let _=u(`font-awesome-icon`),v=u(`knowledge-graph`),y=u(`organic-result`),b=u(`image-results`),x=u(`video-results`),S=u(`news-results`),C=u(`people-also-ask`),w=u(`related-searches`);return l(),f(`div`,$,[e.searching?(l(),f(`div`,Pt,[(l(),f(m,null,s(4,e=>n(`div`,{key:e,class:`mb-6 animate-pulse`},[...r[0]||=[d(`<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?(l(),f(`div`,Ft,[i(_,{icon:`fa-solid fa-face-meh`,class:`text-5xl mb-4 opacity-40`}),n(`p`,It,c(e.$t(`serp.message.noResults`)),1)])):e.results?(l(),f(`div`,Lt,[e.results.knowledge_graph?.title?(l(),t(v,{key:0,data:e.results.knowledge_graph,class:`mb-6`},null,8,[`data`])):a(``,!0),e.results.organic?.length?(l(),f(`div`,Rt,[(l(!0),f(m,null,s(e.results.organic,(e,n)=>(l(),t(y,{key:n,data:e,class:`mb-1`},null,8,[`data`]))),128))])):a(``,!0),e.results.images?.length?(l(),t(b,{key:2,data:e.results.images,class:`mb-6`},null,8,[`data`])):a(``,!0),e.results.videos?.length?(l(),t(x,{key:3,data:e.results.videos,class:`mb-6`},null,8,[`data`])):a(``,!0),e.results.news?.length?(l(),t(S,{key:4,data:e.results.news,class:`mb-6`},null,8,[`data`])):a(``,!0),e.results.people_also_ask?.length?(l(),t(C,{key:5,data:e.results.people_also_ask,class:`mb-6`},null,8,[`data`])):a(``,!0),e.results.related_searches?.length?(l(),t(w,{key:6,data:e.results.related_searches,class:`mb-6`,onSearch:e.onRelatedSearch},null,8,[`data`,`onSearch`])):a(``,!0)])):(l(),f(`div`,zt,[i(_,{icon:`fa-solid fa-globe`,class:`text-5xl mb-4 opacity-30`}),n(`p`,Bt,c(e.$t(`serp.description.query`)),1)]))])}var Ht=o({name:`SerpIndex`,components:{Layout:j,SearchPanel:oe,ResultPanel:x(Nt,[[`render`,Vt]])},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(e){(e?.response?.data)?.error?.code===`used_up`?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 Ut(e,n,r,a,o,s){let c=u(`search-panel`),d=u(`result-panel`),f=u(`layout`);return l(),t(f,null,{config:p(()=>[i(c,{onSearch:e.onSearch},null,8,[`onSearch`])]),result:p(()=>[i(d,{onRelatedSearch:e.onRelatedSearch},null,8,[`onRelatedSearch`])]),_:1})}var Wt=x(Ht,[[`render`,Ut]]);export{Wt as default};
@@ -1 +1 @@
1
- import"./rolldown-runtime--c01j_DQ.js";import{$ as e,Bt as t,D as n,E as r,M as i,N as a,O as o,P as s,Q as c,Ut as l,X as u,_ as d,et as f,k as p,lt as m,ut as h,x as g,y as _}from"./vendor-chart-mdwpew_o.js";import{t as v}from"./button-DWzbdjZV.js";import{n as y,r as b,t as x}from"./select-CqM5oalI.js";import{t as S}from"./upload-C7rPv2P3.js";import{t as C}from"./tooltip-C3PYfh8V.js";import{t as w}from"./image-tzz5bG4l.js";import{t as T}from"./alert-BJj7gY4q.js";import{t as E}from"./drawer-BvYPSxXh.js";import{t as D}from"./input-number-C6xd-oPl.js";import{t as O}from"./switch-DzVsc9s3.js";import{Cn as k,Tn as A,_n as j,bn as M,gn as N,hi as P,hn as ee,mn as te,pn as ne,vn as re,wn as ie,xn as F,yn as I}from"./constants-BVtW3DRs.js";import{At as L,E as R,Fn as z,Nt as B,Ot as V,Sr as H,en as U,kr as W,kt as G,yr as K}from"./index-DGgsHGQJ.js";import{t as q}from"./index.es-CX_i3qgT.js";import{t as J}from"./CopyToClipboard-BvyK_FyK.js";import{t as Y}from"./ImagePreview-BOICGdPc.js";import{n as ae}from"./taskDrawerMixin-Cr17Yxqk.js";import{t as oe}from"./BotPlaceholder-DFp0g5zS.js";import{i as X,n as se,t as ce}from"./pagination-CpCpCjbW.js";import{n as le,t as ue}from"./NoTasks-C9x-H4Pc.js";import{t as de}from"./Consumption-Ci-3V7yB.js";import{t as fe}from"./ApiCodeButton-C3NNEgIA.js";import{t as pe}from"./ImageWrapper-CjcxJKbz.js";var me=s({name:`LayoutNanobanana`,components:{ElDrawer:E,ElButton:v,FontAwesomeIcon:q},mixins:[ae]}),he={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)]`},_e={class:`result h-full p-6 flex-1 flex flex-col min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]`};function ve(t,n,i,o,s,c){let l=f(`font-awesome-icon`),g=f(`el-button`),_=f(`el-drawer`);return u(),p(`div`,he,[r(`div`,ge,[e(t.$slots,`config`,{},void 0,!0)]),r(`div`,_e,[e(t.$slots,`result`,{},void 0,!0)]),h(a(g,{circle:``,class:`menu`,onClick:n[0]||=e=>t.drawer=!0},{default:m(()=>[a(l,{icon:`fa-solid fa-magic`})]),_:1},512),[[d,!t.tasksEmpty]]),a(_,{modelValue:t.drawer,"onUpdate:modelValue":n[1]||=e=>t.drawer=e,direction:`ltr`,"with-header":!1,size:`340px`,class:`drawer`},{default:m(()=>[e(t.$slots,`config`,{},void 0,!0)]),_:3},8,[`modelValue`])])}var ye=R(me,[[`render`,ve],[`__scopeId`,`data-v-cca80bbd`]]),be=s({name:`PromptInput`,components:{PromptTextarea:le},computed:{prompt:{get(){return this.$store.state.openaiimage?.config?.prompt},set(e){this.$store.commit(`openaiimage/setConfig`,{...this.$store.state.openaiimage?.config,prompt:e})}}},mounted(){this.prompt||=``}});function xe(e,t,r,i,a,o){let s=f(`prompt-textarea`);return u(),n(s,{modelValue:e.prompt,"onUpdate:modelValue":t[0]||=t=>e.prompt=t,title:e.$t(`openaiimage.name.prompt`),info:e.$t(`openaiimage.description.prompt`),placeholder:e.$t(`openaiimage.placeholder.prompt`)},null,8,[`modelValue`,`title`,`info`,`placeholder`])}var Se=R(be,[[`render`,xe]]),Ce=s({name:`ImageUrlsInput`,components:{ElUpload:S,ElButton:v,InfoIcon:X,ImagePreview:Y,FontAwesomeIcon:q},mixins:[G],data(){return{fileList:[],uploadUrl:H()+`/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){let e=(this.fileList||[]).filter(e=>!e?.response?.file_url);this.fileList=e.length?e:[];return}let t=[];e.forEach(e=>{let n=this.fileList.find(t=>t?.response?.file_url===e||t?.url===e);n?t.push(n):t.push({name:e.split(`/`).pop()||e,url:e,status:`success`,percentage:100,response:{file_url:e}})}),(this.fileList||[]).filter(e=>!e?.response?.file_url).forEach(e=>{t.some(t=>t===e||t?.url===e?.url||t?.response?.file_url===e?.response?.file_url)||t.push(e)}),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(){W.warning(this.$t(`openaiimage.message.uploadImageExceed`))},onError(){W.error(this.$t(`openaiimage.message.uploadImageError`))},onSetImageUrls(){let 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()}}}),we={class:`field flex items-center justify-between`},Te={class:`title font-bold text-[14px] mb-[10px]`},Ee={class:`upload-wrapper flex flex-col items-start gap-[8px]`},De={class:`controls flex items-center`},Oe={class:`file-list flex flex-wrap gap-[10px]`};function ke(e,t,o,s,d,h){let _=f(`font-awesome-icon`),v=f(`el-button`),y=f(`el-upload`),b=f(`info-icon`),x=f(`image-preview`);return u(),p(g,null,[r(`div`,we,[r(`h2`,Te,l(e.$t(`openaiimage.name.imageUrls`)),1),r(`div`,Ee,[r(`div`,De,[a(y,{"file-list":e.fileList,"onUpdate:fileList":t[0]||=t=>e.fileList=t,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:m(()=>[a(v,{size:`small`,type:`primary`,round:``},{default:m(()=>[a(_,{icon:`fa-solid fa-upload`,class:`mr-1`}),i(` `+l(e.$t(`openaiimage.button.uploadImageUrls`)),1)]),_:1})]),_:1},8,[`file-list`,`action`,`on-exceed`,`on-error`,`on-success`,`on-change`,`on-remove`,`headers`]),a(b,{content:e.$t(`openaiimage.description.imageUrls`),class:`ml-2`},null,8,[`content`])])])]),r(`div`,Oe,[(u(!0),p(g,null,c(e.fileList,(t,r)=>(u(),n(x,{key:t.uid||t?.response?.file_url||t.url||r,url:t.url||t?.response?.file_url,name:t.name,percentage:t.percentage,onRemove:n=>e.onRemovePreview(r,t)},null,8,[`url`,`name`,`percentage`,`onRemove`]))),128))])],64)}var Ae=R(Ce,[[`render`,ke]]),je=s({name:`OpenAIImageModelSelector`,components:{ElSelect:b,ElOption:x,InfoIcon:X},data(){return{options:[{value:re,label:this.$t(`openaiimage.model.gptImage1`)},{value:I,label:this.$t(`openaiimage.model.gptImage15`)},{value:M,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||=N}}),Me={class:`field`},Ne={class:`label`},Pe={class:`box`},Fe={class:`title font-bold`};function Ie(e,t,i,o,s,d){let h=f(`info-icon`),_=f(`el-option`),v=f(`el-select`);return u(),p(`div`,Me,[r(`div`,Ne,[r(`div`,Pe,[r(`h2`,Fe,l(e.$t(`openaiimage.name.model`)),1),a(h,{content:e.modelDescription,class:`info`},null,8,[`content`])])]),a(v,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,class:`value`,placeholder:e.$t(`openaiimage.placeholder.select`)},{default:m(()=>[(u(!0),p(g,null,c(e.options,e=>(u(),n(_,{key:e.value,label:e.label,value:e.value},null,8,[`label`,`value`]))),128))]),_:1},8,[`modelValue`,`placeholder`])])}var Le=R(je,[[`render`,Ie],[`__scopeId`,`data-v-cec771bd`]]);function Z(e){if(!e)return;let t=/^(\d+)x(\d+)$/.exec(e);if(t)return{w:Number(t[1]),h:Number(t[2])}}var Re=s({name:`OpenAIImageSizeSelector`,components:{ElSelect:b,ElOption:x,ElOptionGroup:y,ElSwitch:O,ElInputNumber:D,InfoIcon:X},data(){return{customMode:!1,customWidth:1024,customHeight:1024}},computed:{model(){return this.$store.state.openaiimage?.config?.model||`gpt-image-2`},storedSize(){return this.$store.state.openaiimage?.config?.size},emptySizeValue(){return``},customSupported(){return ee.includes(this.model)},presets(){return F[this.model]??F[`gpt-image-2`]??[]},presetGroups(){return this.model===`gpt-image-2`?[{label:this.$t(`openaiimage.sizeGroup.standard1k`),options:k},{label:this.$t(`openaiimage.sizeGroup.preset2k`),options:ie},{label:this.$t(`openaiimage.sizeGroup.preset4k`),options:A}]:[{label:this.$t(`openaiimage.sizeGroup.standard1k`),options:this.presets}]},useCustom:{get(){return this.customSupported&&this.customMode},set(e){if(!(e&&!this.customSupported))if(this.customMode=e,e){if(this.customError)return;this.commitSize(`${this.customWidth}x${this.customHeight}`)}else this.commitSize()}},presetValue:{get(){let e=this.storedSize;return e&&this.presets.includes(e)?e:this.emptySizeValue},set(e){this.customMode=!1,this.commitSize(e||void 0)}},multiple(){return 16},minSide(){return 256},maxSide(){return ne},customError(){let e=this.customWidth,t=this.customHeight;return!Number.isFinite(e)||!Number.isFinite(t)||e<=0||t<=0?this.$t(`openaiimage.error.customSizePositive`):e%this.multiple!==0||t%this.multiple!==0?this.$t(`openaiimage.error.customSizeMultiple`,{multiple:this.multiple}):e<this.minSide||t<this.minSide?this.$t(`openaiimage.error.customSizeMin`,{min:this.minSide}):Math.max(e,t)>this.maxSide?this.$t(`openaiimage.error.customSizeMax`,{max:this.maxSide}):e*t>8294400?this.$t(`openaiimage.error.customSizePixels`,{pixels:te.toLocaleString()}):``}},watch:{model:{immediate:!1,handler(){this.customSupported||(this.customMode=!1);let e=this.storedSize;if(!e||this.presets.includes(e))return;let t=Z(e);t&&this.customSupported&&(this.customMode=!0,this.customWidth=t.w,this.customHeight=t.h,!this.customError)||this.commitSize()}},storedSize(e){if(!e){this.customMode=!1;return}if(this.presets.includes(e)){this.customMode=!1;return}let t=Z(e);t&&this.customSupported&&(this.customMode=!0,this.customWidth!==t.w&&(this.customWidth=t.w),this.customHeight!==t.h&&(this.customHeight=t.h))},customWidth(){this.syncCustomToStore()},customHeight(){this.syncCustomToStore()}},mounted(){let e=this.storedSize,t=Z(e);e&&t&&this.customSupported&&!this.presets.includes(e)&&(this.customMode=!0,this.customWidth=t.w,this.customHeight=t.h)},methods:{commitSize(e){let t={...this.$store.state.openaiimage?.config};e?t.size=e:delete t.size,this.$store.commit(`openaiimage/setConfig`,t)},syncCustomToStore(){this.useCustom&&(this.customError||this.commitSize(`${this.customWidth}x${this.customHeight}`))}}}),ze={class:`resolution`},Be={class:`field`},Ve={class:`label`},He={class:`box`},Ue={class:`title font-bold`},We={class:`field custom-toggle`},Ge={class:`label`},Ke={class:`box`},qe={class:`title font-bold`},Je={key:0,class:`custom-inputs`},Ye={class:`row`},Xe={class:`row-label`},Ze={class:`row`},Qe={class:`row-label`},$e={key:0,class:`error`};function et(e,t,i,s,d,h){let _=f(`info-icon`),v=f(`el-option`),y=f(`el-option-group`),b=f(`el-select`),x=f(`el-switch`),S=f(`el-input-number`);return u(),p(`div`,ze,[r(`div`,Be,[r(`div`,Ve,[r(`div`,He,[r(`h2`,Ue,l(e.$t(`openaiimage.name.size`)),1),a(_,{content:e.$t(`openaiimage.description.size`),class:`info`},null,8,[`content`])])]),a(b,{modelValue:e.presetValue,"onUpdate:modelValue":t[0]||=t=>e.presetValue=t,class:`value`,placeholder:e.$t(`openaiimage.placeholder.select`),disabled:e.useCustom},{default:m(()=>[a(v,{label:e.$t(`suno.gender.auto`),value:e.emptySizeValue},null,8,[`label`,`value`]),(u(!0),p(g,null,c(e.presetGroups,e=>(u(),n(y,{key:e.label,label:e.label},{default:m(()=>[(u(!0),p(g,null,c(e.options,e=>(u(),n(v,{key:e,label:e,value:e},null,8,[`label`,`value`]))),128))]),_:2},1032,[`label`]))),128))]),_:1},8,[`modelValue`,`placeholder`,`disabled`])]),e.customSupported?(u(),p(g,{key:0},[r(`div`,We,[r(`div`,Ge,[r(`div`,Ke,[r(`h2`,qe,l(e.$t(`openaiimage.name.customSize`)),1),a(_,{content:e.$t(`openaiimage.description.customSize`),class:`info`},null,8,[`content`])])]),a(x,{modelValue:e.useCustom,"onUpdate:modelValue":t[1]||=t=>e.useCustom=t,class:`value-switch`},null,8,[`modelValue`])]),e.useCustom?(u(),p(`div`,Je,[r(`div`,Ye,[r(`span`,Xe,l(e.$t(`openaiimage.name.width`)),1),a(S,{modelValue:e.customWidth,"onUpdate:modelValue":t[2]||=t=>e.customWidth=t,class:`row-input`,min:e.minSide,max:e.maxSide,step:e.multiple,"step-strictly":!0,"controls-position":`right`},null,8,[`modelValue`,`min`,`max`,`step`])]),r(`div`,Ze,[r(`span`,Qe,l(e.$t(`openaiimage.name.height`)),1),a(S,{modelValue:e.customHeight,"onUpdate:modelValue":t[3]||=t=>e.customHeight=t,class:`row-input`,min:e.minSide,max:e.maxSide,step:e.multiple,"step-strictly":!0,"controls-position":`right`},null,8,[`modelValue`,`min`,`max`,`step`])]),e.customError?(u(),p(`div`,$e,l(e.customError),1)):o(``,!0)])):o(``,!0)],64)):o(``,!0)])}var tt=s({name:`ConfigPanel`,components:{ElButton:v,FontAwesomeIcon:q,PromptInput:Se,Consumption:de,ImageUrlsInput:Ae,ModelSelector:Le,ResolutionSelector:R(Re,[[`render`,et],[`__scopeId`,`data-v-d5544d69`]])},emits:[`generate`],computed:{config(){return this.$store.state.openaiimage?.config},consumption(){return B({...this.config||{}},this.service?.cost)},service(){return this.$store.state.openaiimage?.service}},methods:{onGenerate(){this.$emit(`generate`)}}}),nt={class:`flex flex-col h-full`},rt={class:`flex-1 overflow-y-auto p-5`},it={class:`flex flex-col items-center justify-center px-5 pb-5`};function at(e,t,n,o,s,c){let d=f(`model-selector`),h=f(`resolution-selector`),g=f(`prompt-input`),_=f(`image-urls-input`),v=f(`consumption`),y=f(`font-awesome-icon`),b=f(`el-button`);return u(),p(`div`,nt,[r(`div`,rt,[a(d,{class:`mb-4`}),a(h,{class:`mb-4`}),a(g,{class:`mb-4`}),a(_,{class:`mb-4`})]),r(`div`,it,[a(v,{value:e.consumption,service:e.service},null,8,[`value`,`service`]),a(b,{type:`primary`,class:`btn w-full`,round:``,onClick:e.onGenerate},{default:m(()=>[a(y,{icon:`fa-solid fa-magic`,class:`mr-2`}),i(` `+l(e.$t(`openaiimage.button.generate`)),1)]),_:1},8,[`onClick`])])])}var ot=R(tt,[[`render`,at]]),st=s({name:`TaskPreview`,components:{ElImage:w,CopyToClipboard:J,FontAwesomeIcon:q,ElAlert:T,ImageWrapper:pe,ElButton:v,ElTooltip:C,ImagePreview:Y,ApiCodeButton:fe},props:{modelValue:{type:Object,required:!0}},setup(){return{OPENAIIMAGE_LOGO:j}},computed:{isEditRequest(){let e=this.modelValue?.request;return this.modelValue?.type===`images_edits`||e?.action===`edit`||this.referenceImages.length>0},showTaskType(){return!!(this.modelValue?.request?.action||this.modelValue?.type||this.referenceImages.length>0)},taskTypeLabel(){return this.isEditRequest?this.$t(`openaiimage.name.edits`):this.$t(`openaiimage.name.generate`)},openaiimagePath(){return this.isEditRequest?`/openai/images/edits`:`/openai/images/generations`},openaiimageCodeBody(){let e=this.modelValue?.request;if(!e)return;let t={...e};if(delete t.action,delete t.callback_url,this.isEditRequest){delete t.image_urls,delete t.image;let e=this.referenceImages;e.length===1?t.image=e[0]:e.length>1&&(t.image=e)}else delete t.image_urls,delete t.image;return t},images(){let e=[];return Array.isArray(this.modelValue?.response?.data)&&this.modelValue?.response?.data?.forEach(t=>{let n=t;if(n?.image_url||n?.url){e.push(n);return}n?.b64_json&&e.push({...n,url:`data:image/png;base64,${n.b64_json}`})}),e},referenceImages(){let e=this.modelValue?.request;if(!e)return[];let t=Array.isArray(e.image_urls)?e.image_urls:[];if(t.length>0)return t.filter(e=>typeof e==`string`&&e.length>0);let n=e.image;return Array.isArray(n)?n.filter(e=>typeof e==`string`&&e.length>0):typeof n==`string`&&n.length>0?[n]:Array.isArray(e.images)?e.images.map(e=>{if(typeof e==`string`)return e;if(e&&typeof e==`object`)return e.image_url}).filter(e=>typeof e==`string`&&e.length>0):[]}},methods:{onEdit(e){if(!e)return;console.debug(`Edit image:`,e);let t={...this.$store.state.openaiimage?.config||{}};t.image_urls=[e],this.$store.commit(`openaiimage/setConfig`,t)}}}),ct={class:`preview`},lt={class:`left`},ut={class:`main`},dt={class:`bot`},ft={class:`datetime`},pt={class:`info`},mt={key:0,class:`flex justify-start items-center gap-2 mt-2 w-full overflow-x-auto`},ht={key:1,class:`prompt mt-2`},gt={key:0},_t={key:0,class:t({content:!0,failed:!0})},vt={class:`flex justify-start items-center gap-4 w-full overflow-x-auto`},yt={class:t({operations:!0,"mt-2":!0,"mb-2":!0})},bt={key:0,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},xt={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`},Ct={class:`text-[var(--el-text-color-regular)] text-xs mb-2`},wt={key:3,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},Tt={key:4,class:`text-[var(--el-text-color-regular)] text-xs mb-0`},Et={key:1,class:t({content:!0})},Dt={key:0,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},Ot={key:1,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},kt={key:2,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},At={class:`text-[var(--el-text-color-regular)] text-xs mb-2`},jt={class:`text-[var(--el-text-color-regular)] text-xs mb-2`},Mt={key:3,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},Nt={key:4,class:`text-[var(--el-text-color-regular)] text-xs mb-0`},Pt={key:2,class:t({content:!0})},Q={key:0,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},Ft={key:1,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},It={key:2,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},Lt={class:`text-[var(--el-text-color-regular)] text-xs mb-2`};function Rt(e,t,s,d,h,v){let y=f(`el-image`),b=f(`image-preview`),x=f(`image-wrapper`),S=f(`el-button`),C=f(`el-tooltip`),w=f(`api-code-button`),T=f(`font-awesome-icon`),E=f(`copy-to-clipboard`),D=f(`el-alert`);return u(),p(`div`,ct,[r(`div`,lt,[a(y,{src:e.OPENAIIMAGE_LOGO,class:`avatar`},null,8,[`src`])]),r(`div`,ut,[r(`div`,dt,[i(l(e.$t(`openaiimage.name.openaiimageBot`))+` `,1),r(`span`,ft,l(e.$dayjs.format(``+new Date(parseFloat((e.modelValue?.created_at||``).toString())*1e3))),1)]),r(`div`,pt,[e.referenceImages.length>0?(u(),p(`div`,mt,[(u(!0),p(g,null,c(e.referenceImages,(e,t)=>(u(),n(b,{key:t,url:e,name:`image-${t+1}`,closable:!1},null,8,[`url`,`name`]))),128))])):o(``,!0),e.modelValue?.request?.prompt?(u(),p(`p`,ht,[i(l(e.modelValue?.request?.prompt)+` `,1),e.modelValue?.response?o(``,!0):(u(),p(`span`,gt,` - (`+l(e.$t(`openaiimage.status.pending`))+`) `,1))])):o(``,!0)]),e.modelValue?.response?.success===!0?(u(),p(`div`,_t,[r(`div`,vt,[(u(!0),p(g,null,c(e.images,(e,t)=>(u(),n(x,{key:t,src:e?.image_url||e?.url||``,"raw-src":e?.image_url||e?.url||``},null,8,[`src`,`raw-src`]))),128))]),r(`div`,yt,[a(C,{class:`box-item`,effect:`dark`,content:e.$t(`common.button.edit`),placement:`top-start`},{default:m(()=>[a(S,{type:`info`,size:`small`,class:`btn-action`,onClick:t[0]||=_(t=>e.onEdit(e.images?.[0]?.image_url||e.images?.[0]?.url),[`stop`])},{default:m(()=>[i(l(e.$t(`common.button.edit`)),1)]),_:1})]),_:1},8,[`content`]),a(w,{path:e.openaiimagePath,body:e.openaiimageCodeBody},null,8,[`path`,`body`])]),a(D,{closable:!1,class:`mt-2 success`},{default:m(()=>[e.modelValue?.request?.model?(u(),p(`p`,bt,[a(T,{icon:`fa-solid fa-cube`,class:`mr-1`}),i(` `+l(e.$t(`openaiimage.name.model`))+`: `+l(e.modelValue?.request?.model),1)])):o(``,!0),e.modelValue?.request?.size?(u(),p(`p`,xt,[a(T,{icon:`fa-solid fa-image`,class:`mr-1`}),i(` `+l(e.$t(`openaiimage.name.size`))+`: `+l(e.modelValue?.request?.size),1)])):o(``,!0),e.showTaskType?(u(),p(`p`,St,[a(T,{icon:`fa-solid fa-bolt`,class:`mr-1`}),i(` `+l(e.$t(`openaiimage.name.task`))+`: `+l(e.taskTypeLabel),1)])):o(``,!0),r(`p`,Ct,[a(T,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+l(e.$t(`openaiimage.name.taskId`))+`: `+l(e.modelValue?.id)+` `,1),a(E,{content:e.modelValue?.id,class:`btn-copy inline-block`},null,8,[`content`])]),e.modelValue?.elapsed?(u(),p(`p`,wt,[a(T,{icon:`fa-solid fa-clock`,class:`mr-1`}),i(` `+l(e.$t(`openaiimage.name.elapsed`))+`: `+l(e.modelValue?.elapsed?.toFixed(2))+`s `,1)])):o(``,!0),e.modelValue?.response?.trace_id?(u(),p(`p`,Tt,[a(T,{icon:`fa-solid fa-hashtag`,class:`mr-1`}),i(` `+l(e.$t(`openaiimage.name.traceId`))+`: `+l(e.modelValue?.response?.trace_id)+` `,1),a(E,{content:e.modelValue?.response?.trace_id,class:`btn-copy inline-block`},null,8,[`content`])])):o(``,!0)]),_:1})])):e.modelValue?.response?.success===!1?(u(),p(`div`,Et,[a(D,{closable:!1,class:`failure`},{template:m(()=>[a(T,{icon:`fa-solid fa-exclamation-triangle`,class:`mr-1`}),i(` `+l(e.$t(`openaiimage.name.failure`)),1)]),default:m(()=>[e.modelValue?.request?.model?(u(),p(`p`,Dt,[a(T,{icon:`fa-solid fa-cube`,class:`mr-1`}),i(` `+l(e.$t(`openaiimage.name.model`))+`: `+l(e.modelValue?.request?.model),1)])):o(``,!0),e.modelValue?.request?.size?(u(),p(`p`,Ot,[a(T,{icon:`fa-solid fa-image`,class:`mr-1`}),i(` `+l(e.$t(`openaiimage.name.size`))+`: `+l(e.modelValue?.request?.size),1)])):o(``,!0),e.showTaskType?(u(),p(`p`,kt,[a(T,{icon:`fa-solid fa-bolt`,class:`mr-1`}),i(` `+l(e.$t(`openaiimage.name.task`))+`: `+l(e.taskTypeLabel),1)])):o(``,!0),r(`p`,At,[a(T,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+l(e.$t(`openaiimage.name.taskId`))+`: `+l(e.modelValue?.id)+` `,1),a(E,{content:e.modelValue?.id,class:`btn-copy`},null,8,[`content`])]),r(`p`,jt,[a(T,{icon:`fa-solid fa-circle-info`,class:`mr-1`}),i(` `+l(e.$t(`openaiimage.name.failureReason`))+`: `+l(e.modelValue?.response?.error?.message)+` `,1),a(E,{content:e.modelValue?.response?.error?.message,class:`btn-copy`},null,8,[`content`])]),e.modelValue?.elapsed?(u(),p(`p`,Mt,[a(T,{icon:`fa-solid fa-clock`,class:`mr-1`}),i(` `+l(e.$t(`openaiimage.name.elapsed`))+`: `+l(e.modelValue?.elapsed?.toFixed(2))+`s `,1)])):o(``,!0),e.modelValue?.response?.trace_id?(u(),p(`p`,Nt,[a(T,{icon:`fa-solid fa-hashtag`,class:`mr-1`}),i(` `+l(e.$t(`openaiimage.name.traceId`))+`: `+l(e.modelValue?.response?.trace_id)+` `,1),a(E,{content:e.modelValue?.response?.trace_id,class:`btn-copy`},null,8,[`content`])])):o(``,!0)]),_:1})])):(u(),p(`div`,Pt,[a(D,{closable:!1,class:`info`},{template:m(()=>[a(T,{icon:`fa-solid fa-exclamation-triangle`,class:`mr-1`}),i(` `+l(e.$t(`openaiimage.name.failure`)),1)]),default:m(()=>[e.modelValue?.request?.model?(u(),p(`p`,Q,[a(T,{icon:`fa-solid fa-cube`,class:`mr-1`}),i(` `+l(e.$t(`openaiimage.name.model`))+`: `+l(e.modelValue?.request?.model),1)])):o(``,!0),e.modelValue?.request?.size?(u(),p(`p`,Ft,[a(T,{icon:`fa-solid fa-image`,class:`mr-1`}),i(` `+l(e.$t(`openaiimage.name.size`))+`: `+l(e.modelValue?.request?.size),1)])):o(``,!0),e.showTaskType?(u(),p(`p`,It,[a(T,{icon:`fa-solid fa-bolt`,class:`mr-1`}),i(` `+l(e.$t(`openaiimage.name.task`))+`: `+l(e.taskTypeLabel),1)])):o(``,!0),r(`p`,Lt,[a(T,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+l(e.$t(`openaiimage.name.taskId`))+`: `+l(e.modelValue?.id)+` `,1),a(E,{content:e.modelValue?.id,class:`btn-copy`},null,8,[`content`])])]),_:1})]))])])}var zt=s({name:`RecentPanel`,components:{TaskPreview:R(st,[[`render`,Rt],[`__scopeId`,`data-v-8ee5fb87`]]),BotPlaceholder:oe,NoTasks:ue,ScrollList:se},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?.()}}}),Bt={key:0},Vt={key:2,class:`w-full h-full flex items-center justify-center`};function Ht(e,t,r,i,s,l){let d=f(`bot-placeholder`),h=f(`task-preview`),_=f(`scroll-list`),v=f(`no-tasks`);return u(),p(g,null,[e.tasks?.items===void 0?(u(),p(`div`,Bt,[a(d)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(u(),n(_,{key:1,ref:`scrollList`,class:`tasks h-full w-full overflow-y-auto`,loading:e.loading,onReachTop:t[0]||=t=>e.$emit(`reach-top`)},{default:m(()=>[(u(!0),p(g,null,c(e.tasks?.items,e=>(u(),n(h,{key:e.id,"model-value":e},null,8,[`model-value`]))),128))]),_:1},8,[`loading`])):o(``,!0),e.tasks?.items?.length===0?(u(),p(`div`,Vt,[a(v)])):o(``,!0)],64)}var Ut=R(zt,[[`render`,Ht]]),$=P(`openaiimage`),Wt=s({name:`OpenAIImageIndex`,components:{ConfigPanel:ot,Layout:ye,RecentPanel:Ut},mixins:[L],inject:[`initialized`],data(){return{task:void 0,job:0,loading:!1}},computed:{applicationsLoading(){return this.$store.state.openaiimage?.status?.getApplications===K.Request},tasksLoading(){return this.$store.state.openaiimage?.status?.getTasks===K.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(){await ce({tasks:this.tasks,getTasks:()=>this.tasks,loading:this.loading,setLoading:e=>this.loading=e,isBlocked:()=>this.tasksLoading,fetch:e=>this.onGetTasks({createdAtMax:e}),getScrollElement:()=>this.getTasksScrollElement()})},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();let 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);let{limit:t=20,createdAtMin:n,createdAtMax:r}=e||{};console.debug(`limit`,t,`createdAtMin`,n,`createdAtMax`,r),await this.$store.dispatch(`openaiimage/getTasks`,{limit:t,createdAtMin:n,createdAtMax:r})},async onGenerate(){if(!V(this.uploadTracker,e=>this.$t(e),e=>W.warning(e)))return;let e={...this.config||{}},t=Array.isArray(e?.image_urls)&&e.image_urls.length>0;if(!this.hasText(e.prompt)){W.error(this.$t(`openaiimage.message.promptRequired`));return}e.prompt=e.prompt.trim(),!t&&`image_urls`in e&&delete e.image_urls,e.size||delete e.size;let n={...e,action:`generate`,callback_url:$},r={action:`edit`,model:e?.model,prompt:e?.prompt,size:e?.size,image_urls:e?.image_urls||[],callback_url:$},i=this.credential?.token;if(!i){console.error(`no token specified`);return}W.info(this.$t(`openaiimage.message.startingTask`)),z(`openaiimage`,t?U.edit(r,{token:i}):U.generate(n,{token:i})).then(e=>{console.debug(`task accepted`,e.data?.task_id),W.success(this.$t(`openaiimage.message.startTaskSuccess`))}).catch(e=>{let t=e?.response?.data;t?.error?.code===`used_up`?W.error(this.$t(`openaiimage.message.usedUp`)):W.error(this.$t(`openaiimage.message.startTaskFailed`)+(t?.error?.message||``))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()},hasText(e){return typeof e==`string`&&e.trim().length>0}}});function Gt(e,t,r,i,o,s){let c=f(`config-panel`),l=f(`recent-panel`),d=f(`layout`);return u(),n(d,null,{config:m(()=>[a(c,{onGenerate:e.onGenerate},null,8,[`onGenerate`])]),result:m(()=>[a(l,{ref:`recentPanel`,loading:e.loading,onReachTop:e.onReachTop},null,8,[`loading`,`onReachTop`])]),_:1})}var Kt=R(Wt,[[`render`,Gt]]);export{Kt as default};
1
+ import"./rolldown-runtime--c01j_DQ.js";import{$ as e,Bt as t,D as n,E as r,M as i,N as a,O as o,P as s,Q as c,Ut as l,X as u,_ as d,et as f,k as p,lt as m,ut as h,x as g,y as _}from"./vendor-chart-mdwpew_o.js";import{t as v}from"./button-DWzbdjZV.js";import{n as y,r as b,t as x}from"./select-CYdISXBV.js";import{t as S}from"./upload-CHAO8dYa.js";import{t as C}from"./tooltip-C3PYfh8V.js";import{t as w}from"./image-tItcr5tZ.js";import{t as T}from"./alert-BJj7gY4q.js";import{t as E}from"./drawer-BvYPSxXh.js";import{t as D}from"./input-number-BZClQnf5.js";import{t as O}from"./switch-DT8swXGq.js";import{Cn as k,Tn as A,_n as j,bn as M,gn as N,hi as P,hn as ee,mn as te,pn as ne,vn as re,wn as ie,xn as F,yn as I}from"./constants-B6_fTlam.js";import{At as L,E as R,Fn as z,Nt as B,Ot as V,Sr as H,en as U,kr as W,kt as G,yr as K}from"./index-DpREqzJQ.js";import{t as q}from"./index.es-DkXuZNXE.js";import{t as J}from"./CopyToClipboard-DXA4nHxo.js";import{t as Y}from"./ImagePreview-Bkw_taCt.js";import{n as ae}from"./taskDrawerMixin-Cr17Yxqk.js";import{t as oe}from"./BotPlaceholder-R_nAAbft.js";import{i as X,n as se,t as ce}from"./pagination-BQOE0Lce.js";import{n as le,t as ue}from"./NoTasks-568fhAGt.js";import{t as de}from"./Consumption-CjrpUNmV.js";import{t as fe}from"./ApiCodeButton-DXN7iB8l.js";import{t as pe}from"./ImageWrapper-BPvtDIMf.js";var me=s({name:`LayoutNanobanana`,components:{ElDrawer:E,ElButton:v,FontAwesomeIcon:q},mixins:[ae]}),he={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)]`},_e={class:`result h-full p-6 flex-1 flex flex-col min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]`};function ve(t,n,i,o,s,c){let l=f(`font-awesome-icon`),g=f(`el-button`),_=f(`el-drawer`);return u(),p(`div`,he,[r(`div`,ge,[e(t.$slots,`config`,{},void 0,!0)]),r(`div`,_e,[e(t.$slots,`result`,{},void 0,!0)]),h(a(g,{circle:``,class:`menu`,onClick:n[0]||=e=>t.drawer=!0},{default:m(()=>[a(l,{icon:`fa-solid fa-magic`})]),_:1},512),[[d,!t.tasksEmpty]]),a(_,{modelValue:t.drawer,"onUpdate:modelValue":n[1]||=e=>t.drawer=e,direction:`ltr`,"with-header":!1,size:`340px`,class:`drawer`},{default:m(()=>[e(t.$slots,`config`,{},void 0,!0)]),_:3},8,[`modelValue`])])}var ye=R(me,[[`render`,ve],[`__scopeId`,`data-v-cca80bbd`]]),be=s({name:`PromptInput`,components:{PromptTextarea:le},computed:{prompt:{get(){return this.$store.state.openaiimage?.config?.prompt},set(e){this.$store.commit(`openaiimage/setConfig`,{...this.$store.state.openaiimage?.config,prompt:e})}}},mounted(){this.prompt||=``}});function xe(e,t,r,i,a,o){let s=f(`prompt-textarea`);return u(),n(s,{modelValue:e.prompt,"onUpdate:modelValue":t[0]||=t=>e.prompt=t,title:e.$t(`openaiimage.name.prompt`),info:e.$t(`openaiimage.description.prompt`),placeholder:e.$t(`openaiimage.placeholder.prompt`)},null,8,[`modelValue`,`title`,`info`,`placeholder`])}var Se=R(be,[[`render`,xe]]),Ce=s({name:`ImageUrlsInput`,components:{ElUpload:S,ElButton:v,InfoIcon:X,ImagePreview:Y,FontAwesomeIcon:q},mixins:[G],data(){return{fileList:[],uploadUrl:H()+`/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){let e=(this.fileList||[]).filter(e=>!e?.response?.file_url);this.fileList=e.length?e:[];return}let t=[];e.forEach(e=>{let n=this.fileList.find(t=>t?.response?.file_url===e||t?.url===e);n?t.push(n):t.push({name:e.split(`/`).pop()||e,url:e,status:`success`,percentage:100,response:{file_url:e}})}),(this.fileList||[]).filter(e=>!e?.response?.file_url).forEach(e=>{t.some(t=>t===e||t?.url===e?.url||t?.response?.file_url===e?.response?.file_url)||t.push(e)}),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(){W.warning(this.$t(`openaiimage.message.uploadImageExceed`))},onError(){W.error(this.$t(`openaiimage.message.uploadImageError`))},onSetImageUrls(){let 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()}}}),we={class:`field flex items-center justify-between`},Te={class:`title font-bold text-[14px] mb-[10px]`},Ee={class:`upload-wrapper flex flex-col items-start gap-[8px]`},De={class:`controls flex items-center`},Oe={class:`file-list flex flex-wrap gap-[10px]`};function ke(e,t,o,s,d,h){let _=f(`font-awesome-icon`),v=f(`el-button`),y=f(`el-upload`),b=f(`info-icon`),x=f(`image-preview`);return u(),p(g,null,[r(`div`,we,[r(`h2`,Te,l(e.$t(`openaiimage.name.imageUrls`)),1),r(`div`,Ee,[r(`div`,De,[a(y,{"file-list":e.fileList,"onUpdate:fileList":t[0]||=t=>e.fileList=t,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:m(()=>[a(v,{size:`small`,type:`primary`,round:``},{default:m(()=>[a(_,{icon:`fa-solid fa-upload`,class:`mr-1`}),i(` `+l(e.$t(`openaiimage.button.uploadImageUrls`)),1)]),_:1})]),_:1},8,[`file-list`,`action`,`on-exceed`,`on-error`,`on-success`,`on-change`,`on-remove`,`headers`]),a(b,{content:e.$t(`openaiimage.description.imageUrls`),class:`ml-2`},null,8,[`content`])])])]),r(`div`,Oe,[(u(!0),p(g,null,c(e.fileList,(t,r)=>(u(),n(x,{key:t.uid||t?.response?.file_url||t.url||r,url:t.url||t?.response?.file_url,name:t.name,percentage:t.percentage,onRemove:n=>e.onRemovePreview(r,t)},null,8,[`url`,`name`,`percentage`,`onRemove`]))),128))])],64)}var Ae=R(Ce,[[`render`,ke]]),je=s({name:`OpenAIImageModelSelector`,components:{ElSelect:b,ElOption:x,InfoIcon:X},data(){return{options:[{value:re,label:this.$t(`openaiimage.model.gptImage1`)},{value:I,label:this.$t(`openaiimage.model.gptImage15`)},{value:M,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||=N}}),Me={class:`field`},Ne={class:`label`},Pe={class:`box`},Fe={class:`title font-bold`};function Ie(e,t,i,o,s,d){let h=f(`info-icon`),_=f(`el-option`),v=f(`el-select`);return u(),p(`div`,Me,[r(`div`,Ne,[r(`div`,Pe,[r(`h2`,Fe,l(e.$t(`openaiimage.name.model`)),1),a(h,{content:e.modelDescription,class:`info`},null,8,[`content`])])]),a(v,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,class:`value`,placeholder:e.$t(`openaiimage.placeholder.select`)},{default:m(()=>[(u(!0),p(g,null,c(e.options,e=>(u(),n(_,{key:e.value,label:e.label,value:e.value},null,8,[`label`,`value`]))),128))]),_:1},8,[`modelValue`,`placeholder`])])}var Le=R(je,[[`render`,Ie],[`__scopeId`,`data-v-cec771bd`]]);function Z(e){if(!e)return;let t=/^(\d+)x(\d+)$/.exec(e);if(t)return{w:Number(t[1]),h:Number(t[2])}}var Re=s({name:`OpenAIImageSizeSelector`,components:{ElSelect:b,ElOption:x,ElOptionGroup:y,ElSwitch:O,ElInputNumber:D,InfoIcon:X},data(){return{customMode:!1,customWidth:1024,customHeight:1024}},computed:{model(){return this.$store.state.openaiimage?.config?.model||`gpt-image-2`},storedSize(){return this.$store.state.openaiimage?.config?.size},emptySizeValue(){return``},customSupported(){return ee.includes(this.model)},presets(){return F[this.model]??F[`gpt-image-2`]??[]},presetGroups(){return this.model===`gpt-image-2`?[{label:this.$t(`openaiimage.sizeGroup.standard1k`),options:k},{label:this.$t(`openaiimage.sizeGroup.preset2k`),options:ie},{label:this.$t(`openaiimage.sizeGroup.preset4k`),options:A}]:[{label:this.$t(`openaiimage.sizeGroup.standard1k`),options:this.presets}]},useCustom:{get(){return this.customSupported&&this.customMode},set(e){if(!(e&&!this.customSupported))if(this.customMode=e,e){if(this.customError)return;this.commitSize(`${this.customWidth}x${this.customHeight}`)}else this.commitSize()}},presetValue:{get(){let e=this.storedSize;return e&&this.presets.includes(e)?e:this.emptySizeValue},set(e){this.customMode=!1,this.commitSize(e||void 0)}},multiple(){return 16},minSide(){return 256},maxSide(){return ne},customError(){let e=this.customWidth,t=this.customHeight;return!Number.isFinite(e)||!Number.isFinite(t)||e<=0||t<=0?this.$t(`openaiimage.error.customSizePositive`):e%this.multiple!==0||t%this.multiple!==0?this.$t(`openaiimage.error.customSizeMultiple`,{multiple:this.multiple}):e<this.minSide||t<this.minSide?this.$t(`openaiimage.error.customSizeMin`,{min:this.minSide}):Math.max(e,t)>this.maxSide?this.$t(`openaiimage.error.customSizeMax`,{max:this.maxSide}):e*t>8294400?this.$t(`openaiimage.error.customSizePixels`,{pixels:te.toLocaleString()}):``}},watch:{model:{immediate:!1,handler(){this.customSupported||(this.customMode=!1);let e=this.storedSize;if(!e||this.presets.includes(e))return;let t=Z(e);t&&this.customSupported&&(this.customMode=!0,this.customWidth=t.w,this.customHeight=t.h,!this.customError)||this.commitSize()}},storedSize(e){if(!e){this.customMode=!1;return}if(this.presets.includes(e)){this.customMode=!1;return}let t=Z(e);t&&this.customSupported&&(this.customMode=!0,this.customWidth!==t.w&&(this.customWidth=t.w),this.customHeight!==t.h&&(this.customHeight=t.h))},customWidth(){this.syncCustomToStore()},customHeight(){this.syncCustomToStore()}},mounted(){let e=this.storedSize,t=Z(e);e&&t&&this.customSupported&&!this.presets.includes(e)&&(this.customMode=!0,this.customWidth=t.w,this.customHeight=t.h)},methods:{commitSize(e){let t={...this.$store.state.openaiimage?.config};e?t.size=e:delete t.size,this.$store.commit(`openaiimage/setConfig`,t)},syncCustomToStore(){this.useCustom&&(this.customError||this.commitSize(`${this.customWidth}x${this.customHeight}`))}}}),ze={class:`resolution`},Be={class:`field`},Ve={class:`label`},He={class:`box`},Ue={class:`title font-bold`},We={class:`field custom-toggle`},Ge={class:`label`},Ke={class:`box`},qe={class:`title font-bold`},Je={key:0,class:`custom-inputs`},Ye={class:`row`},Xe={class:`row-label`},Ze={class:`row`},Qe={class:`row-label`},$e={key:0,class:`error`};function et(e,t,i,s,d,h){let _=f(`info-icon`),v=f(`el-option`),y=f(`el-option-group`),b=f(`el-select`),x=f(`el-switch`),S=f(`el-input-number`);return u(),p(`div`,ze,[r(`div`,Be,[r(`div`,Ve,[r(`div`,He,[r(`h2`,Ue,l(e.$t(`openaiimage.name.size`)),1),a(_,{content:e.$t(`openaiimage.description.size`),class:`info`},null,8,[`content`])])]),a(b,{modelValue:e.presetValue,"onUpdate:modelValue":t[0]||=t=>e.presetValue=t,class:`value`,placeholder:e.$t(`openaiimage.placeholder.select`),disabled:e.useCustom},{default:m(()=>[a(v,{label:e.$t(`suno.gender.auto`),value:e.emptySizeValue},null,8,[`label`,`value`]),(u(!0),p(g,null,c(e.presetGroups,e=>(u(),n(y,{key:e.label,label:e.label},{default:m(()=>[(u(!0),p(g,null,c(e.options,e=>(u(),n(v,{key:e,label:e,value:e},null,8,[`label`,`value`]))),128))]),_:2},1032,[`label`]))),128))]),_:1},8,[`modelValue`,`placeholder`,`disabled`])]),e.customSupported?(u(),p(g,{key:0},[r(`div`,We,[r(`div`,Ge,[r(`div`,Ke,[r(`h2`,qe,l(e.$t(`openaiimage.name.customSize`)),1),a(_,{content:e.$t(`openaiimage.description.customSize`),class:`info`},null,8,[`content`])])]),a(x,{modelValue:e.useCustom,"onUpdate:modelValue":t[1]||=t=>e.useCustom=t,class:`value-switch`},null,8,[`modelValue`])]),e.useCustom?(u(),p(`div`,Je,[r(`div`,Ye,[r(`span`,Xe,l(e.$t(`openaiimage.name.width`)),1),a(S,{modelValue:e.customWidth,"onUpdate:modelValue":t[2]||=t=>e.customWidth=t,class:`row-input`,min:e.minSide,max:e.maxSide,step:e.multiple,"step-strictly":!0,"controls-position":`right`},null,8,[`modelValue`,`min`,`max`,`step`])]),r(`div`,Ze,[r(`span`,Qe,l(e.$t(`openaiimage.name.height`)),1),a(S,{modelValue:e.customHeight,"onUpdate:modelValue":t[3]||=t=>e.customHeight=t,class:`row-input`,min:e.minSide,max:e.maxSide,step:e.multiple,"step-strictly":!0,"controls-position":`right`},null,8,[`modelValue`,`min`,`max`,`step`])]),e.customError?(u(),p(`div`,$e,l(e.customError),1)):o(``,!0)])):o(``,!0)],64)):o(``,!0)])}var tt=s({name:`ConfigPanel`,components:{ElButton:v,FontAwesomeIcon:q,PromptInput:Se,Consumption:de,ImageUrlsInput:Ae,ModelSelector:Le,ResolutionSelector:R(Re,[[`render`,et],[`__scopeId`,`data-v-d5544d69`]])},emits:[`generate`],computed:{config(){return this.$store.state.openaiimage?.config},consumption(){return B({...this.config||{}},this.service?.cost)},service(){return this.$store.state.openaiimage?.service}},methods:{onGenerate(){this.$emit(`generate`)}}}),nt={class:`flex flex-col h-full`},rt={class:`flex-1 overflow-y-auto p-5`},it={class:`flex flex-col items-center justify-center px-5 pb-5`};function at(e,t,n,o,s,c){let d=f(`model-selector`),h=f(`resolution-selector`),g=f(`prompt-input`),_=f(`image-urls-input`),v=f(`consumption`),y=f(`font-awesome-icon`),b=f(`el-button`);return u(),p(`div`,nt,[r(`div`,rt,[a(d,{class:`mb-4`}),a(h,{class:`mb-4`}),a(g,{class:`mb-4`}),a(_,{class:`mb-4`})]),r(`div`,it,[a(v,{value:e.consumption,service:e.service},null,8,[`value`,`service`]),a(b,{type:`primary`,class:`btn w-full`,round:``,onClick:e.onGenerate},{default:m(()=>[a(y,{icon:`fa-solid fa-magic`,class:`mr-2`}),i(` `+l(e.$t(`openaiimage.button.generate`)),1)]),_:1},8,[`onClick`])])])}var ot=R(tt,[[`render`,at]]),st=s({name:`TaskPreview`,components:{ElImage:w,CopyToClipboard:J,FontAwesomeIcon:q,ElAlert:T,ImageWrapper:pe,ElButton:v,ElTooltip:C,ImagePreview:Y,ApiCodeButton:fe},props:{modelValue:{type:Object,required:!0}},setup(){return{OPENAIIMAGE_LOGO:j}},computed:{isEditRequest(){let e=this.modelValue?.request;return this.modelValue?.type===`images_edits`||e?.action===`edit`||this.referenceImages.length>0},showTaskType(){return!!(this.modelValue?.request?.action||this.modelValue?.type||this.referenceImages.length>0)},taskTypeLabel(){return this.isEditRequest?this.$t(`openaiimage.name.edits`):this.$t(`openaiimage.name.generate`)},openaiimagePath(){return this.isEditRequest?`/openai/images/edits`:`/openai/images/generations`},openaiimageCodeBody(){let e=this.modelValue?.request;if(!e)return;let t={...e};if(delete t.action,delete t.callback_url,this.isEditRequest){delete t.image_urls,delete t.image;let e=this.referenceImages;e.length===1?t.image=e[0]:e.length>1&&(t.image=e)}else delete t.image_urls,delete t.image;return t},images(){let e=[];return Array.isArray(this.modelValue?.response?.data)&&this.modelValue?.response?.data?.forEach(t=>{let n=t;if(n?.image_url||n?.url){e.push(n);return}n?.b64_json&&e.push({...n,url:`data:image/png;base64,${n.b64_json}`})}),e},referenceImages(){let e=this.modelValue?.request;if(!e)return[];let t=Array.isArray(e.image_urls)?e.image_urls:[];if(t.length>0)return t.filter(e=>typeof e==`string`&&e.length>0);let n=e.image;return Array.isArray(n)?n.filter(e=>typeof e==`string`&&e.length>0):typeof n==`string`&&n.length>0?[n]:Array.isArray(e.images)?e.images.map(e=>{if(typeof e==`string`)return e;if(e&&typeof e==`object`)return e.image_url}).filter(e=>typeof e==`string`&&e.length>0):[]}},methods:{onEdit(e){if(!e)return;console.debug(`Edit image:`,e);let t={...this.$store.state.openaiimage?.config||{}};t.image_urls=[e],this.$store.commit(`openaiimage/setConfig`,t)}}}),ct={class:`preview`},lt={class:`left`},ut={class:`main`},dt={class:`bot`},ft={class:`datetime`},pt={class:`info`},mt={key:0,class:`flex justify-start items-center gap-2 mt-2 w-full overflow-x-auto`},ht={key:1,class:`prompt mt-2`},gt={key:0},_t={key:0,class:t({content:!0,failed:!0})},vt={class:`flex justify-start items-center gap-4 w-full overflow-x-auto`},yt={class:t({operations:!0,"mt-2":!0,"mb-2":!0})},bt={key:0,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},xt={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`},Ct={class:`text-[var(--el-text-color-regular)] text-xs mb-2`},wt={key:3,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},Tt={key:4,class:`text-[var(--el-text-color-regular)] text-xs mb-0`},Et={key:1,class:t({content:!0})},Dt={key:0,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},Ot={key:1,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},kt={key:2,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},At={class:`text-[var(--el-text-color-regular)] text-xs mb-2`},jt={class:`text-[var(--el-text-color-regular)] text-xs mb-2`},Mt={key:3,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},Nt={key:4,class:`text-[var(--el-text-color-regular)] text-xs mb-0`},Pt={key:2,class:t({content:!0})},Q={key:0,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},Ft={key:1,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},It={key:2,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},Lt={class:`text-[var(--el-text-color-regular)] text-xs mb-2`};function Rt(e,t,s,d,h,v){let y=f(`el-image`),b=f(`image-preview`),x=f(`image-wrapper`),S=f(`el-button`),C=f(`el-tooltip`),w=f(`api-code-button`),T=f(`font-awesome-icon`),E=f(`copy-to-clipboard`),D=f(`el-alert`);return u(),p(`div`,ct,[r(`div`,lt,[a(y,{src:e.OPENAIIMAGE_LOGO,class:`avatar`},null,8,[`src`])]),r(`div`,ut,[r(`div`,dt,[i(l(e.$t(`openaiimage.name.openaiimageBot`))+` `,1),r(`span`,ft,l(e.$dayjs.format(``+new Date(parseFloat((e.modelValue?.created_at||``).toString())*1e3))),1)]),r(`div`,pt,[e.referenceImages.length>0?(u(),p(`div`,mt,[(u(!0),p(g,null,c(e.referenceImages,(e,t)=>(u(),n(b,{key:t,url:e,name:`image-${t+1}`,closable:!1},null,8,[`url`,`name`]))),128))])):o(``,!0),e.modelValue?.request?.prompt?(u(),p(`p`,ht,[i(l(e.modelValue?.request?.prompt)+` `,1),e.modelValue?.response?o(``,!0):(u(),p(`span`,gt,` - (`+l(e.$t(`openaiimage.status.pending`))+`) `,1))])):o(``,!0)]),e.modelValue?.response?.success===!0?(u(),p(`div`,_t,[r(`div`,vt,[(u(!0),p(g,null,c(e.images,(e,t)=>(u(),n(x,{key:t,src:e?.image_url||e?.url||``,"raw-src":e?.image_url||e?.url||``},null,8,[`src`,`raw-src`]))),128))]),r(`div`,yt,[a(C,{class:`box-item`,effect:`dark`,content:e.$t(`common.button.edit`),placement:`top-start`},{default:m(()=>[a(S,{type:`info`,size:`small`,class:`btn-action`,onClick:t[0]||=_(t=>e.onEdit(e.images?.[0]?.image_url||e.images?.[0]?.url),[`stop`])},{default:m(()=>[i(l(e.$t(`common.button.edit`)),1)]),_:1})]),_:1},8,[`content`]),a(w,{path:e.openaiimagePath,body:e.openaiimageCodeBody},null,8,[`path`,`body`])]),a(D,{closable:!1,class:`mt-2 success`},{default:m(()=>[e.modelValue?.request?.model?(u(),p(`p`,bt,[a(T,{icon:`fa-solid fa-cube`,class:`mr-1`}),i(` `+l(e.$t(`openaiimage.name.model`))+`: `+l(e.modelValue?.request?.model),1)])):o(``,!0),e.modelValue?.request?.size?(u(),p(`p`,xt,[a(T,{icon:`fa-solid fa-image`,class:`mr-1`}),i(` `+l(e.$t(`openaiimage.name.size`))+`: `+l(e.modelValue?.request?.size),1)])):o(``,!0),e.showTaskType?(u(),p(`p`,St,[a(T,{icon:`fa-solid fa-bolt`,class:`mr-1`}),i(` `+l(e.$t(`openaiimage.name.task`))+`: `+l(e.taskTypeLabel),1)])):o(``,!0),r(`p`,Ct,[a(T,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+l(e.$t(`openaiimage.name.taskId`))+`: `+l(e.modelValue?.id)+` `,1),a(E,{content:e.modelValue?.id,class:`btn-copy inline-block`},null,8,[`content`])]),e.modelValue?.elapsed?(u(),p(`p`,wt,[a(T,{icon:`fa-solid fa-clock`,class:`mr-1`}),i(` `+l(e.$t(`openaiimage.name.elapsed`))+`: `+l(e.modelValue?.elapsed?.toFixed(2))+`s `,1)])):o(``,!0),e.modelValue?.response?.trace_id?(u(),p(`p`,Tt,[a(T,{icon:`fa-solid fa-hashtag`,class:`mr-1`}),i(` `+l(e.$t(`openaiimage.name.traceId`))+`: `+l(e.modelValue?.response?.trace_id)+` `,1),a(E,{content:e.modelValue?.response?.trace_id,class:`btn-copy inline-block`},null,8,[`content`])])):o(``,!0)]),_:1})])):e.modelValue?.response?.success===!1?(u(),p(`div`,Et,[a(D,{closable:!1,class:`failure`},{template:m(()=>[a(T,{icon:`fa-solid fa-exclamation-triangle`,class:`mr-1`}),i(` `+l(e.$t(`openaiimage.name.failure`)),1)]),default:m(()=>[e.modelValue?.request?.model?(u(),p(`p`,Dt,[a(T,{icon:`fa-solid fa-cube`,class:`mr-1`}),i(` `+l(e.$t(`openaiimage.name.model`))+`: `+l(e.modelValue?.request?.model),1)])):o(``,!0),e.modelValue?.request?.size?(u(),p(`p`,Ot,[a(T,{icon:`fa-solid fa-image`,class:`mr-1`}),i(` `+l(e.$t(`openaiimage.name.size`))+`: `+l(e.modelValue?.request?.size),1)])):o(``,!0),e.showTaskType?(u(),p(`p`,kt,[a(T,{icon:`fa-solid fa-bolt`,class:`mr-1`}),i(` `+l(e.$t(`openaiimage.name.task`))+`: `+l(e.taskTypeLabel),1)])):o(``,!0),r(`p`,At,[a(T,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+l(e.$t(`openaiimage.name.taskId`))+`: `+l(e.modelValue?.id)+` `,1),a(E,{content:e.modelValue?.id,class:`btn-copy`},null,8,[`content`])]),r(`p`,jt,[a(T,{icon:`fa-solid fa-circle-info`,class:`mr-1`}),i(` `+l(e.$t(`openaiimage.name.failureReason`))+`: `+l(e.modelValue?.response?.error?.message)+` `,1),a(E,{content:e.modelValue?.response?.error?.message,class:`btn-copy`},null,8,[`content`])]),e.modelValue?.elapsed?(u(),p(`p`,Mt,[a(T,{icon:`fa-solid fa-clock`,class:`mr-1`}),i(` `+l(e.$t(`openaiimage.name.elapsed`))+`: `+l(e.modelValue?.elapsed?.toFixed(2))+`s `,1)])):o(``,!0),e.modelValue?.response?.trace_id?(u(),p(`p`,Nt,[a(T,{icon:`fa-solid fa-hashtag`,class:`mr-1`}),i(` `+l(e.$t(`openaiimage.name.traceId`))+`: `+l(e.modelValue?.response?.trace_id)+` `,1),a(E,{content:e.modelValue?.response?.trace_id,class:`btn-copy`},null,8,[`content`])])):o(``,!0)]),_:1})])):(u(),p(`div`,Pt,[a(D,{closable:!1,class:`info`},{template:m(()=>[a(T,{icon:`fa-solid fa-exclamation-triangle`,class:`mr-1`}),i(` `+l(e.$t(`openaiimage.name.failure`)),1)]),default:m(()=>[e.modelValue?.request?.model?(u(),p(`p`,Q,[a(T,{icon:`fa-solid fa-cube`,class:`mr-1`}),i(` `+l(e.$t(`openaiimage.name.model`))+`: `+l(e.modelValue?.request?.model),1)])):o(``,!0),e.modelValue?.request?.size?(u(),p(`p`,Ft,[a(T,{icon:`fa-solid fa-image`,class:`mr-1`}),i(` `+l(e.$t(`openaiimage.name.size`))+`: `+l(e.modelValue?.request?.size),1)])):o(``,!0),e.showTaskType?(u(),p(`p`,It,[a(T,{icon:`fa-solid fa-bolt`,class:`mr-1`}),i(` `+l(e.$t(`openaiimage.name.task`))+`: `+l(e.taskTypeLabel),1)])):o(``,!0),r(`p`,Lt,[a(T,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+l(e.$t(`openaiimage.name.taskId`))+`: `+l(e.modelValue?.id)+` `,1),a(E,{content:e.modelValue?.id,class:`btn-copy`},null,8,[`content`])])]),_:1})]))])])}var zt=s({name:`RecentPanel`,components:{TaskPreview:R(st,[[`render`,Rt],[`__scopeId`,`data-v-8ee5fb87`]]),BotPlaceholder:oe,NoTasks:ue,ScrollList:se},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?.()}}}),Bt={key:0},Vt={key:2,class:`w-full h-full flex items-center justify-center`};function Ht(e,t,r,i,s,l){let d=f(`bot-placeholder`),h=f(`task-preview`),_=f(`scroll-list`),v=f(`no-tasks`);return u(),p(g,null,[e.tasks?.items===void 0?(u(),p(`div`,Bt,[a(d)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(u(),n(_,{key:1,ref:`scrollList`,class:`tasks h-full w-full overflow-y-auto`,loading:e.loading,onReachTop:t[0]||=t=>e.$emit(`reach-top`)},{default:m(()=>[(u(!0),p(g,null,c(e.tasks?.items,e=>(u(),n(h,{key:e.id,"model-value":e},null,8,[`model-value`]))),128))]),_:1},8,[`loading`])):o(``,!0),e.tasks?.items?.length===0?(u(),p(`div`,Vt,[a(v)])):o(``,!0)],64)}var Ut=R(zt,[[`render`,Ht]]),$=P(`openaiimage`),Wt=s({name:`OpenAIImageIndex`,components:{ConfigPanel:ot,Layout:ye,RecentPanel:Ut},mixins:[L],inject:[`initialized`],data(){return{task:void 0,job:0,loading:!1}},computed:{applicationsLoading(){return this.$store.state.openaiimage?.status?.getApplications===K.Request},tasksLoading(){return this.$store.state.openaiimage?.status?.getTasks===K.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(){await ce({tasks:this.tasks,getTasks:()=>this.tasks,loading:this.loading,setLoading:e=>this.loading=e,isBlocked:()=>this.tasksLoading,fetch:e=>this.onGetTasks({createdAtMax:e}),getScrollElement:()=>this.getTasksScrollElement()})},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();let 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);let{limit:t=20,createdAtMin:n,createdAtMax:r}=e||{};console.debug(`limit`,t,`createdAtMin`,n,`createdAtMax`,r),await this.$store.dispatch(`openaiimage/getTasks`,{limit:t,createdAtMin:n,createdAtMax:r})},async onGenerate(){if(!V(this.uploadTracker,e=>this.$t(e),e=>W.warning(e)))return;let e={...this.config||{}},t=Array.isArray(e?.image_urls)&&e.image_urls.length>0;if(!this.hasText(e.prompt)){W.error(this.$t(`openaiimage.message.promptRequired`));return}e.prompt=e.prompt.trim(),!t&&`image_urls`in e&&delete e.image_urls,e.size||delete e.size;let n={...e,action:`generate`,callback_url:$},r={action:`edit`,model:e?.model,prompt:e?.prompt,size:e?.size,image_urls:e?.image_urls||[],callback_url:$},i=this.credential?.token;if(!i){console.error(`no token specified`);return}W.info(this.$t(`openaiimage.message.startingTask`)),z(`openaiimage`,t?U.edit(r,{token:i}):U.generate(n,{token:i})).then(e=>{console.debug(`task accepted`,e.data?.task_id),W.success(this.$t(`openaiimage.message.startTaskSuccess`))}).catch(e=>{let t=e?.response?.data;t?.error?.code===`used_up`?W.error(this.$t(`openaiimage.message.usedUp`)):W.error(this.$t(`openaiimage.message.startTaskFailed`)+(t?.error?.message||``))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()},hasText(e){return typeof e==`string`&&e.trim().length>0}}});function Gt(e,t,r,i,o,s){let c=f(`config-panel`),l=f(`recent-panel`),d=f(`layout`);return u(),n(d,null,{config:m(()=>[a(c,{onGenerate:e.onGenerate},null,8,[`onGenerate`])]),result:m(()=>[a(l,{ref:`recentPanel`,loading:e.loading,onReachTop:e.onReachTop},null,8,[`loading`,`onReachTop`])]),_:1})}var Kt=R(Wt,[[`render`,Gt]]);export{Kt as default};
@@ -1 +1 @@
1
- .menu[data-v-b87958dc]{display:none}@media (width<=767px){.config[data-v-b87958dc]{display:none}.result[data-v-b87958dc]{width:100%}.menu[data-v-b87958dc]{right:8px;top:calc(45px + var(--app-safe-area-top));z-index:1000;display:block;position:absolute}}.field[data-v-04059875]{flex-direction:row;justify-content:space-between;align-items:center;display:flex}.field .title[data-v-04059875]{width:30%;margin:0;font-size:14px}.field .value[data-v-04059875]{width:120px}.field[data-v-9a8fa3c5]{flex-direction:row;justify-content:space-between;align-items:center;display:flex}.field .header[data-v-9a8fa3c5]{flex-direction:row;align-items:center;width:50%;display:flex}.field .header .title[data-v-9a8fa3c5]{margin:0;font-size:14px}.field .value[data-v-9a8fa3c5]{width:120px}.opt-disabled[data-v-9a8fa3c5]{color:var(--el-text-color-disabled)}.opt-tip[data-v-9a8fa3c5]{color:var(--el-text-color-placeholder);margin-left:8px;font-size:11px}.field[data-v-5ae55e28]{flex-direction:column;display:flex}.control[data-v-5ae55e28]{flex-direction:row;justify-content:space-between;align-items:center;display:flex}.label[data-v-5ae55e28]{flex-direction:row;align-items:center;display:flex}.title[data-v-5ae55e28]{margin:0;font-size:14px}.value[data-v-5ae55e28]{width:120px}.title[data-v-cdb14b2f]{margin-bottom:10px;font-size:14px}.items[data-v-cdb14b2f]{flex-direction:row;justify-content:flex-start;align-items:center;gap:10px;display:flex}.items .item[data-v-cdb14b2f]{border:1px solid var(--el-border-color);background-color:var(--el-fill-color-lighter);cursor:pointer;border-radius:10px;flex-direction:column;align-items:center;width:48px;height:70px;transition:background-color .2s,border-color .2s;display:flex}.items .item .preview[data-v-cdb14b2f]{flex-direction:row;justify-content:center;align-items:center;width:30px;height:30px;margin-top:8px;margin-bottom:4px;display:flex}.items .item .preview .rect[data-v-cdb14b2f]{border:1px solid var(--el-border-color-lighter);border-radius:2px;width:20px;height:20px}.items .item .name[data-v-cdb14b2f]{color:var(--el-text-color-primary);font-size:12px;display:block}.items .item[data-v-cdb14b2f]:hover{background-color:var(--el-fill-color)}.items .item.active[data-v-cdb14b2f]{border-color:var(--el-color-primary);background-color:var(--el-color-primary-light-9)}.items .item.active .rect[data-v-cdb14b2f]{border-color:var(--el-color-primary)}.title[data-v-756dc269]{width:30%;margin-bottom:0;font-size:14px}.btn.btn-upload[data-v-756dc269]{position:absolute;top:5px;right:0}.upload-wrapper .el-upload-list--picture .el-upload-list__item{background-color:#0000;border:none;height:auto;margin:8px 0 0;padding:0;overflow:visible}.title[data-v-c1b257e5]{width:30%;margin-bottom:0;font-size:14px}.btn.btn-upload[data-v-c1b257e5]{position:absolute;top:5px;right:0}.field[data-v-cd896060]{flex-direction:column;gap:8px;display:flex}.field .header[data-v-cd896060]{flex-direction:row;align-items:center;display:flex}.field .value[data-v-cd896060]{width:100%}.config-grid[data-v-cd896060]{background-color:var(--el-fill-color-lighter);border-radius:8px;flex-direction:column;gap:4px;padding:8px;display:flex}.config-grid .cfg-row[data-v-cd896060]{flex-direction:column;gap:0;display:flex}.config-grid .cfg-row .cfg-row-head[data-v-cd896060]{flex-direction:row;justify-content:space-between;align-items:center;display:flex}.config-grid .cfg-row .cfg-row-head .cfg-name[data-v-cd896060]{color:var(--el-text-color-regular);font-size:12px}.config-grid .cfg-row .cfg-row-head .cfg-num[data-v-cd896060]{width:100px}.pills[data-v-5fc4fa65]{flex-wrap:wrap;gap:6px;margin-bottom:8px;display:flex}.pill[data-v-5fc4fa65]{background-color:var(--el-color-primary-light-9);border:1px solid var(--el-color-primary-light-7);color:var(--el-color-primary);border-radius:999px;align-items:center;max-width:100%;padding:3px 4px 3px 10px;font-size:12px;line-height:1;display:inline-flex}.pill .pill-text[data-v-5fc4fa65]{text-overflow:ellipsis;white-space:nowrap;max-width:220px;overflow:hidden}.pill .pill-remove[data-v-5fc4fa65]{width:18px;height:18px;color:var(--el-color-primary);cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;margin-left:4px;padding:0;font-size:10px;display:inline-flex}.pill .pill-remove[data-v-5fc4fa65]:hover{background-color:var(--el-color-primary-light-7)}.inspiration-btn[data-v-c01fc1a6]{color:var(--el-color-primary);height:24px;padding:0 6px;font-size:12px}.field .box[data-v-de98cf01]{flex-direction:row;justify-content:space-between;align-items:center;display:flex;position:relative}.field .box .title[data-v-de98cf01]{margin-bottom:10px;font-size:14px}.field .info[data-v-de98cf01]{margin-left:auto}.drawer-content[data-v-7d457a69]{flex-direction:column;height:100%;padding:16px 18px 24px;display:flex;overflow-y:auto}.drawer-header[data-v-7d457a69]{flex-direction:row;justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.drawer-header .title-row[data-v-7d457a69]{color:var(--el-text-color-primary);align-items:center;font-size:16px;font-weight:600;display:inline-flex}.drawer-header .close-btn[data-v-7d457a69]{width:32px;height:32px;padding:6px}.hint[data-v-7d457a69]{color:var(--el-text-color-secondary);margin-bottom:12px;font-size:12px;line-height:1.5}.selected-bar[data-v-7d457a69]{background-color:var(--el-color-primary-light-9);border-radius:8px;justify-content:space-between;align-items:center;margin-bottom:12px;padding:8px 12px;font-size:12px;display:flex}.selected-bar .selected-text[data-v-7d457a69]{color:var(--el-color-primary);font-weight:500}.groups[data-v-7d457a69]{flex-direction:column;gap:18px;display:flex}.group .group-title[data-v-7d457a69]{color:var(--el-text-color-regular);margin-bottom:8px;font-size:13px;font-weight:600}.group .chip-grid[data-v-7d457a69]{flex-wrap:wrap;gap:8px;display:flex}.chip[data-v-7d457a69]{border:1px solid var(--el-border-color);background-color:var(--el-fill-color-lighter);color:var(--el-text-color-regular);cursor:pointer;border-radius:999px;align-items:center;padding:6px 12px;font-size:13px;transition:background-color .15s,border-color .15s,color .15s;display:inline-flex}.chip[data-v-7d457a69]:hover{border-color:var(--el-color-primary-light-5);background-color:var(--el-color-primary-light-9)}.chip.active[data-v-7d457a69]{border-color:var(--el-color-primary);background-color:var(--el-color-primary-light-9);color:var(--el-color-primary);font-weight:500}.kling-inspiration-drawer .el-drawer__body{padding:0}.summary-chip[data-v-418a6733]{background-color:var(--el-fill-color-light);color:var(--el-text-color-regular);-webkit-user-select:none;user-select:none;border-radius:999px;align-items:center;gap:6px;margin-bottom:10px;padding:4px 12px;font-size:12px;display:inline-flex}.summary-chip .part[data-v-418a6733]{white-space:nowrap}.summary-chip .dot[data-v-418a6733]{color:var(--el-text-color-disabled)}.summary-chip .audio[data-v-418a6733]{color:var(--el-color-primary);margin-left:4px;font-size:11px}.btn.btn-upload[data-v-e52eaf2f]{position:absolute;top:5px;right:0}.upload-wrapper{height:auto;display:flex}.upload-wrapper .el-upload-list{width:100%;margin:0}.btn.btn-upload[data-v-7019a8d2]{position:absolute;top:5px;right:0}.field .box[data-v-ca9fdbe5]{flex-direction:row;align-items:center;display:flex;position:relative}.field .box .title[data-v-ca9fdbe5]{margin-bottom:10px;font-size:14px}.field .info[data-v-ca9fdbe5]{margin-left:auto}.field[data-v-7a91195b]{flex-direction:column;gap:6px;display:flex}.field .header[data-v-7a91195b]{flex-direction:row;align-items:center;display:flex}.field[data-v-1295688c]{flex-direction:row;justify-content:space-between;align-items:center;display:flex}.field .header[data-v-1295688c]{flex-direction:row;align-items:center;width:50%;display:flex}.field .header .title[data-v-1295688c]{margin:0;font-size:14px}.field .value[data-v-1295688c]{width:120px}.kling-tabs[data-v-bf00c27e]{background-color:var(--app-sidebar-bg);flex:none;padding:0 8px}.kling-tabs[data-v-bf00c27e] .el-tabs__header{margin:0}.kling-tabs[data-v-bf00c27e] .el-tabs__nav-wrap:after{height:1px}.kling-tabs[data-v-bf00c27e] .el-tabs__item{height:38px;padding:0 6px;font-size:13px;line-height:38px}.kling-tabs .tab-label[data-v-bf00c27e]{white-space:nowrap;align-items:center;display:inline-flex}.kling-tabs .tab-label .text[data-v-bf00c27e]{text-overflow:ellipsis;max-width:100%;overflow:hidden}.kling-tabs .tab-label .badge[data-v-bf00c27e]{height:16px;margin-left:4px;padding:0 4px;font-size:9px;line-height:14px}.preview[data-v-c36bfd7f]{text-align:left;flex-direction:row;width:100%;height:fit-content;margin-bottom:15px;display:flex}.preview .left[data-v-c36bfd7f]{width:70px}.preview .left .avatar[data-v-c36bfd7f]{border-radius:50%;width:50px;height:50px;margin:10px}.preview .main[data-v-c36bfd7f]{flex:1;width:calc(100% - 70px);min-width:0;padding:10px 10px 0}.preview .main .bot[data-v-c36bfd7f]{color:var(--el-color-primary);text-overflow:ellipsis;white-space:nowrap;margin-top:0;margin-bottom:0;font-size:16px;font-weight:700;overflow:hidden}.preview .main .bot .datetime[data-v-c36bfd7f]{color:var(--el-text-color-secondary);margin-left:10px;font-size:12px;font-weight:400}.preview .main .info[data-v-c36bfd7f]{overflow:hidden}.preview .main .info .prompt[data-v-c36bfd7f]{color:var(--el-text-color-regular);white-space:normal;word-break:break-word;overflow-wrap:anywhere;margin-bottom:10px;font-size:16px;font-weight:700}.preview .main .content[data-v-c36bfd7f]{word-break:break-word;overflow-wrap:anywhere}.preview .main .content .el-alert[data-v-c36bfd7f]{border-left-style:solid;border-left-width:2px}.preview .main .content .el-alert.failure[data-v-c36bfd7f]{border-color:var(--el-color-danger)}.preview .main .content .el-alert.success[data-v-c36bfd7f]{border-color:var(--el-color-success)}.preview .main .content .el-alert.info[data-v-c36bfd7f]{border-color:var(--el-color-info)}.preview .main .content .el-alert[data-v-c36bfd7f] p:last-child{margin-bottom:0}.preview .main .operations[data-v-c36bfd7f]{text-align:center;width:100%;color:var(--el-text-color-regular);flex-flow:wrap;justify-content:left;align-items:baseline;font-size:14px;display:flex;overflow:hidden scroll}.preview .main .operations.full[data-v-c36bfd7f]{height:70px}.preview .main .operations .btn-action[data-v-c36bfd7f]{margin-bottom:10px}
1
+ .menu[data-v-b87958dc]{display:none}@media (width<=767px){.config[data-v-b87958dc]{display:none}.result[data-v-b87958dc]{width:100%}.menu[data-v-b87958dc]{right:8px;top:calc(45px + var(--app-safe-area-top));z-index:1000;display:block;position:absolute}}.field[data-v-04059875]{flex-direction:row;justify-content:space-between;align-items:center;display:flex}.field .title[data-v-04059875]{width:30%;margin:0;font-size:14px}.field .value[data-v-04059875]{width:120px}.field[data-v-9a8fa3c5]{flex-direction:row;justify-content:space-between;align-items:center;display:flex}.field .header[data-v-9a8fa3c5]{flex-direction:row;align-items:center;width:50%;display:flex}.field .header .title[data-v-9a8fa3c5]{margin:0;font-size:14px}.field .value[data-v-9a8fa3c5]{width:120px}.opt-disabled[data-v-9a8fa3c5]{color:var(--el-text-color-disabled)}.opt-tip[data-v-9a8fa3c5]{color:var(--el-text-color-placeholder);margin-left:8px;font-size:11px}.field[data-v-5ae55e28]{flex-direction:column;display:flex}.control[data-v-5ae55e28]{flex-direction:row;justify-content:space-between;align-items:center;display:flex}.label[data-v-5ae55e28]{flex-direction:row;align-items:center;display:flex}.title[data-v-5ae55e28]{margin:0;font-size:14px}.value[data-v-5ae55e28]{width:120px}.title[data-v-cdb14b2f]{margin-bottom:10px;font-size:14px}.items[data-v-cdb14b2f]{flex-direction:row;justify-content:flex-start;align-items:center;gap:10px;display:flex}.items .item[data-v-cdb14b2f]{border:1px solid var(--el-border-color);background-color:var(--el-fill-color-lighter);cursor:pointer;border-radius:10px;flex-direction:column;align-items:center;width:48px;height:70px;transition:background-color .2s,border-color .2s;display:flex}.items .item .preview[data-v-cdb14b2f]{flex-direction:row;justify-content:center;align-items:center;width:30px;height:30px;margin-top:8px;margin-bottom:4px;display:flex}.items .item .preview .rect[data-v-cdb14b2f]{border:1px solid var(--el-border-color-lighter);border-radius:2px;width:20px;height:20px}.items .item .name[data-v-cdb14b2f]{color:var(--el-text-color-primary);font-size:12px;display:block}.items .item[data-v-cdb14b2f]:hover{background-color:var(--el-fill-color)}.items .item.active[data-v-cdb14b2f]{border-color:var(--el-color-primary);background-color:var(--el-color-primary-light-9)}.items .item.active .rect[data-v-cdb14b2f]{border-color:var(--el-color-primary)}.title[data-v-756dc269]{width:30%;margin-bottom:0;font-size:14px}.btn.btn-upload[data-v-756dc269]{position:absolute;top:5px;right:0}.upload-wrapper .el-upload-list--picture .el-upload-list__item{background-color:#0000;border:none;height:auto;margin:8px 0 0;padding:0;overflow:visible}.title[data-v-c1b257e5]{width:30%;margin-bottom:0;font-size:14px}.btn.btn-upload[data-v-c1b257e5]{position:absolute;top:5px;right:0}.field[data-v-cd896060]{flex-direction:column;gap:8px;display:flex}.field .header[data-v-cd896060]{flex-direction:row;align-items:center;display:flex}.field .value[data-v-cd896060]{width:100%}.config-grid[data-v-cd896060]{background-color:var(--el-fill-color-lighter);border-radius:8px;flex-direction:column;gap:4px;padding:8px;display:flex}.config-grid .cfg-row[data-v-cd896060]{flex-direction:column;gap:0;display:flex}.config-grid .cfg-row .cfg-row-head[data-v-cd896060]{flex-direction:row;justify-content:space-between;align-items:center;display:flex}.config-grid .cfg-row .cfg-row-head .cfg-name[data-v-cd896060]{color:var(--el-text-color-regular);font-size:12px}.config-grid .cfg-row .cfg-row-head .cfg-num[data-v-cd896060]{width:100px}.pills[data-v-5fc4fa65]{flex-wrap:wrap;gap:6px;margin-bottom:8px;display:flex}.pill[data-v-5fc4fa65]{background-color:var(--el-color-primary-light-9);border:1px solid var(--el-color-primary-light-7);color:var(--el-color-primary);border-radius:999px;align-items:center;max-width:100%;padding:3px 4px 3px 10px;font-size:12px;line-height:1;display:inline-flex}.pill .pill-text[data-v-5fc4fa65]{text-overflow:ellipsis;white-space:nowrap;max-width:220px;overflow:hidden}.pill .pill-remove[data-v-5fc4fa65]{width:18px;height:18px;color:var(--el-color-primary);cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;margin-left:4px;padding:0;font-size:10px;display:inline-flex}.pill .pill-remove[data-v-5fc4fa65]:hover{background-color:var(--el-color-primary-light-7)}.inspiration-btn[data-v-c01fc1a6]{color:var(--el-color-primary);height:24px;padding:0 6px;font-size:12px}.field .box[data-v-de98cf01]{flex-direction:row;justify-content:space-between;align-items:center;display:flex;position:relative}.field .box .title[data-v-de98cf01]{margin-bottom:10px;font-size:14px}.field .info[data-v-de98cf01]{margin-left:auto}.drawer-content[data-v-7d457a69]{flex-direction:column;height:100%;padding:16px 18px 24px;display:flex;overflow-y:auto}.drawer-header[data-v-7d457a69]{flex-direction:row;justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.drawer-header .title-row[data-v-7d457a69]{color:var(--el-text-color-primary);align-items:center;font-size:16px;font-weight:600;display:inline-flex}.drawer-header .close-btn[data-v-7d457a69]{width:32px;height:32px;padding:6px}.hint[data-v-7d457a69]{color:var(--el-text-color-secondary);margin-bottom:12px;font-size:12px;line-height:1.5}.selected-bar[data-v-7d457a69]{background-color:var(--el-color-primary-light-9);border-radius:8px;justify-content:space-between;align-items:center;margin-bottom:12px;padding:8px 12px;font-size:12px;display:flex}.selected-bar .selected-text[data-v-7d457a69]{color:var(--el-color-primary);font-weight:500}.groups[data-v-7d457a69]{flex-direction:column;gap:18px;display:flex}.group .group-title[data-v-7d457a69]{color:var(--el-text-color-regular);margin-bottom:8px;font-size:13px;font-weight:600}.group .chip-grid[data-v-7d457a69]{flex-wrap:wrap;gap:8px;display:flex}.chip[data-v-7d457a69]{border:1px solid var(--el-border-color);background-color:var(--el-fill-color-lighter);color:var(--el-text-color-regular);cursor:pointer;border-radius:999px;align-items:center;padding:6px 12px;font-size:13px;transition:background-color .15s,border-color .15s,color .15s;display:inline-flex}.chip[data-v-7d457a69]:hover{border-color:var(--el-color-primary-light-5);background-color:var(--el-color-primary-light-9)}.chip.active[data-v-7d457a69]{border-color:var(--el-color-primary);background-color:var(--el-color-primary-light-9);color:var(--el-color-primary);font-weight:500}.kling-inspiration-drawer .el-drawer__body{padding:0}.summary-chip[data-v-418a6733]{background-color:var(--el-fill-color-light);color:var(--el-text-color-regular);-webkit-user-select:none;user-select:none;border-radius:999px;align-items:center;gap:6px;margin-bottom:10px;padding:4px 12px;font-size:12px;display:inline-flex}.summary-chip .part[data-v-418a6733]{white-space:nowrap}.summary-chip .dot[data-v-418a6733]{color:var(--el-text-color-disabled)}.summary-chip .audio[data-v-418a6733]{color:var(--el-color-primary);margin-left:4px;font-size:11px}.btn.btn-upload[data-v-e52eaf2f]{position:absolute;top:5px;right:0}.upload-wrapper{height:auto;display:flex}.btn.btn-upload[data-v-7019a8d2]{position:absolute;top:5px;right:0}.field .box[data-v-ca9fdbe5]{flex-direction:row;align-items:center;display:flex;position:relative}.field .box .title[data-v-ca9fdbe5]{margin-bottom:10px;font-size:14px}.field .info[data-v-ca9fdbe5]{margin-left:auto}.field[data-v-7a91195b]{flex-direction:column;gap:6px;display:flex}.field .header[data-v-7a91195b]{flex-direction:row;align-items:center;display:flex}.field[data-v-1295688c]{flex-direction:row;justify-content:space-between;align-items:center;display:flex}.field .header[data-v-1295688c]{flex-direction:row;align-items:center;width:50%;display:flex}.field .header .title[data-v-1295688c]{margin:0;font-size:14px}.field .value[data-v-1295688c]{width:120px}.kling-tabs[data-v-fda33e4c]{background-color:var(--app-sidebar-bg);flex:none;padding:0 8px}.kling-tabs[data-v-fda33e4c] .el-tabs__header{margin:0}.kling-tabs[data-v-fda33e4c] .el-tabs__nav-wrap:after{height:1px}.kling-tabs[data-v-fda33e4c] .el-tabs__item{height:38px;padding:0 6px;font-size:13px;line-height:38px}.kling-tabs .tab-label[data-v-fda33e4c]{white-space:nowrap;align-items:center;display:inline-flex}.kling-tabs .tab-label .text[data-v-fda33e4c]{text-overflow:ellipsis;max-width:100%;overflow:hidden}.kling-tabs .tab-label .badge[data-v-fda33e4c]{height:16px;margin-left:4px;padding:0 4px;font-size:9px;line-height:14px}.btn.btn-upload[data-v-a3aa5a3a]{position:absolute;top:5px;right:0}.upload-wrapper{flex-direction:column;height:auto;display:flex}.upload-wrapper .el-upload-list{width:100%;margin:0}.preview[data-v-c36bfd7f]{text-align:left;flex-direction:row;width:100%;height:fit-content;margin-bottom:15px;display:flex}.preview .left[data-v-c36bfd7f]{width:70px}.preview .left .avatar[data-v-c36bfd7f]{border-radius:50%;width:50px;height:50px;margin:10px}.preview .main[data-v-c36bfd7f]{flex:1;width:calc(100% - 70px);min-width:0;padding:10px 10px 0}.preview .main .bot[data-v-c36bfd7f]{color:var(--el-color-primary);text-overflow:ellipsis;white-space:nowrap;margin-top:0;margin-bottom:0;font-size:16px;font-weight:700;overflow:hidden}.preview .main .bot .datetime[data-v-c36bfd7f]{color:var(--el-text-color-secondary);margin-left:10px;font-size:12px;font-weight:400}.preview .main .info[data-v-c36bfd7f]{overflow:hidden}.preview .main .info .prompt[data-v-c36bfd7f]{color:var(--el-text-color-regular);white-space:normal;word-break:break-word;overflow-wrap:anywhere;margin-bottom:10px;font-size:16px;font-weight:700}.preview .main .content[data-v-c36bfd7f]{word-break:break-word;overflow-wrap:anywhere}.preview .main .content .el-alert[data-v-c36bfd7f]{border-left-style:solid;border-left-width:2px}.preview .main .content .el-alert.failure[data-v-c36bfd7f]{border-color:var(--el-color-danger)}.preview .main .content .el-alert.success[data-v-c36bfd7f]{border-color:var(--el-color-success)}.preview .main .content .el-alert.info[data-v-c36bfd7f]{border-color:var(--el-color-info)}.preview .main .content .el-alert[data-v-c36bfd7f] p:last-child{margin-bottom:0}.preview .main .operations[data-v-c36bfd7f]{text-align:center;width:100%;color:var(--el-text-color-regular);flex-flow:wrap;justify-content:left;align-items:baseline;font-size:14px;display:flex;overflow:hidden scroll}.preview .main .operations.full[data-v-c36bfd7f]{height:70px}.preview .main .operations .btn-action[data-v-c36bfd7f]{margin-bottom:10px}
@@ -1 +1 @@
1
- import"./rolldown-runtime--c01j_DQ.js";import{D as e,E as t,M as n,N as r,O as i,P as a,Ut as o,X as s,et as c,k as l,lt as u,x as d}from"./vendor-chart-mdwpew_o.js";import{t as f}from"./button-DWzbdjZV.js";import{$ as p,et as m,tt as h}from"./constants-BVtW3DRs.js";import{E as ee,Et as g,r as _,s as v,v as y,x as b,y as x}from"./index-DGgsHGQJ.js";import{t as S}from"./index.es-CX_i3qgT.js";var C=a({name:`DownloadIndex`,components:{ElButton:f,QrCode:g,FontAwesomeIcon:S},data(){return{faAndroid:y,faApple:x,faGooglePlay:b,faDownload:v,faCircleInfo:_}},computed:{version(){return h},brandTitle(){return this.$store.state.site?.title||`AceData`},brandLogo(){return this.$store.state.site?.logo||`/assets/logo-CDy94G52.png`},androidDownloadUrl(){return p},hasAndroidDownload(){return!!p},playStoreUrl(){return m},hasPlayStore(){return!!m},iosDownloadUrl(){return``},iosFallbackUrl(){return``},hasIosDownload(){return!1}},methods:{openSupport(){window.open(`https://platform.acedata.cloud/support`,`_blank`)}}}),w={class:`download-page`},T={class:`download-page__inner`},E={class:`hero`},D={class:`hero__brand`},O=[`src`,`alt`],k={class:`hero__eyebrow`},A={class:`hero__title`},j={class:`hero__subtitle`},M={class:`hero__badges`},N={class:`badge badge--live`},P={class:`badge`},F={class:`badge`},I={class:`hero__actions`},L={class:`platforms`},R={class:`platform platform--android`},z={class:`platform__head`},B={class:`platform__os`},V={class:`chip chip--live`},H={class:`platform__title`},U={class:`platform__text`},W={key:0,class:`qr`},G={class:`qr__hint`},te={class:`platform__foot platform__foot--stack`},K={key:0,class:`platform__fallback`},q={class:`platform__meta`},J={class:`platform__meta`},Y={class:`platform platform--ios`},X={class:`platform__head`},Z={class:`platform__os`},Q={class:`chip chip--pending`},ne={class:`platform__title`},re={class:`platform__text`},ie={key:0,class:`platform__foot platform__foot--stack`},ae={class:`btn-row`},oe={class:`platform__meta`},se={class:`ios-soon`},ce={class:`ios-soon__text`},le={class:`platform__foot platform__foot--stack`},ue={class:`advantages`},de={class:`advantage`},fe={class:`advantage__title`},pe={class:`advantage__text`},$={class:`advantage`},me={class:`advantage__title`},he={class:`advantage__text`},ge={class:`advantage`},_e={class:`advantage__title`},ve={class:`advantage__text`},ye={class:`note`},be={class:`note__text`};function xe(a,f,p,m,h,ee){let g=c(`font-awesome-icon`),_=c(`el-button`),v=c(`qr-code`);return s(),l(`div`,w,[f[8]||=t(`div`,{class:`download-page__glow`,"aria-hidden":`true`},null,-1),t(`div`,T,[t(`header`,E,[t(`span`,D,[t(`img`,{src:a.brandLogo,alt:a.brandTitle,class:`hero__logo`},null,8,O)]),t(`p`,k,o(a.brandTitle)+` · `+o(a.$t(`common.nav.mobileApp`)),1),t(`h1`,A,o(a.$t(`common.title.mobileApp`)),1),t(`p`,j,o(a.$t(`common.message.mobileAppDescription`)),1),t(`div`,M,[t(`span`,N,[f[0]||=t(`span`,{class:`badge__dot`},null,-1),n(o(a.$t(`common.message.mobileAvailableNow`)),1)]),t(`span`,P,`v`+o(a.version),1),t(`span`,F,o(a.$t(`common.message.mobileSharedAccount`)),1)]),t(`div`,I,[a.hasPlayStore?(s(),e(_,{key:0,type:`primary`,round:``,size:`large`,tag:`a`,href:a.playStoreUrl,target:`_blank`},{default:u(()=>[r(g,{icon:a.faGooglePlay,class:`btn-icon`},null,8,[`icon`]),n(` `+o(a.$t(`common.button.getOnGooglePlay`)),1)]),_:1},8,[`href`])):a.hasAndroidDownload?(s(),e(_,{key:1,type:`primary`,round:``,size:`large`,tag:`a`,href:a.androidDownloadUrl,target:`_blank`},{default:u(()=>[r(g,{icon:a.faAndroid,class:`btn-icon`},null,8,[`icon`]),n(` `+o(a.$t(`common.button.downloadAndroid`)),1)]),_:1},8,[`href`])):i(``,!0),r(_,{round:``,size:`large`,class:`btn-ghost`,onClick:a.openSupport},{default:u(()=>[n(o(a.$t(`common.nav.support`)),1)]),_:1},8,[`onClick`])])]),t(`section`,L,[t(`article`,R,[t(`div`,z,[t(`span`,B,[r(g,{icon:a.faAndroid,class:`platform__os-icon`},null,8,[`icon`]),f[1]||=n(` Android `,-1)]),t(`span`,V,[f[2]||=t(`span`,{class:`chip__dot`},null,-1),n(o(a.$t(`common.message.mobileAvailableNow`)),1)])]),t(`h2`,H,o(a.$t(`common.button.downloadAndroid`)),1),t(`p`,U,o(a.$t(`common.message.mobileAndroidHint`)),1),a.hasPlayStore||a.hasAndroidDownload?(s(),l(`div`,W,[r(v,{value:a.hasPlayStore?a.playStoreUrl:a.androidDownloadUrl,width:184,height:184,class:`qr__img`,type:`image/png`,color:{dark:`#0e2a33ff`,light:`#ffffffff`}},null,8,[`value`]),t(`p`,G,o(a.hasPlayStore?a.$t(`common.message.mobilePlayStoreHint`):a.$t(`common.message.mobileSecureDelivery`)),1)])):i(``,!0),t(`div`,te,[a.hasPlayStore?(s(),e(_,{key:0,type:`primary`,round:``,size:`large`,tag:`a`,href:a.playStoreUrl,target:`_blank`},{default:u(()=>[r(g,{icon:a.faGooglePlay,class:`btn-icon`},null,8,[`icon`]),n(` `+o(a.$t(`common.button.getOnGooglePlay`)),1)]),_:1},8,[`href`])):i(``,!0),a.hasAndroidDownload?(s(),l(d,{key:1},[a.hasPlayStore?(s(),l(`div`,K,[r(_,{round:``,tag:`a`,href:a.androidDownloadUrl,target:`_blank`,class:`btn-ghost`},{default:u(()=>[r(g,{icon:a.faDownload,class:`btn-icon`},null,8,[`icon`]),n(` `+o(a.$t(`common.button.downloadAndroid`)),1)]),_:1},8,[`href`]),t(`span`,q,o(a.$t(`common.message.mobileApkFallback`))+` · v`+o(a.version),1)])):(s(),l(d,{key:1},[r(_,{type:`primary`,round:``,size:`large`,tag:`a`,href:a.androidDownloadUrl,target:`_blank`},{default:u(()=>[r(g,{icon:a.faDownload,class:`btn-icon`},null,8,[`icon`]),n(` `+o(a.$t(`common.button.downloadAndroid`)),1)]),_:1},8,[`href`]),t(`span`,J,o(a.$t(`common.message.mobileDirectInstall`))+` · v`+o(a.version),1)],64))],64)):i(``,!0)])]),t(`article`,Y,[t(`div`,X,[t(`span`,Z,[r(g,{icon:a.faApple,class:`platform__os-icon`},null,8,[`icon`]),f[3]||=n(` iOS `,-1)]),t(`span`,Q,[f[4]||=t(`span`,{class:`chip__dot`},null,-1),n(o(a.$t(`common.message.mobileComingSoon`)),1)])]),t(`h2`,ne,o(a.$t(`common.button.downloadIos`)),1),t(`p`,re,o(a.hasIosDownload?a.$t(`common.message.mobileIosHint`):a.$t(`common.message.mobileIosPending`)),1),a.hasIosDownload?(s(),l(`div`,ie,[t(`div`,ae,[r(_,{type:`primary`,round:``,size:`large`,tag:`a`,href:a.iosDownloadUrl,target:`_blank`},{default:u(()=>[r(g,{icon:a.faApple,class:`btn-icon`},null,8,[`icon`]),n(` `+o(a.$t(`common.button.installIos`)),1)]),_:1},8,[`href`]),r(_,{round:``,size:`large`,class:`btn-ghost`,tag:`a`,href:a.iosFallbackUrl,target:`_blank`},{default:u(()=>[n(o(a.$t(`common.button.downloadIos`)),1)]),_:1},8,[`href`])]),t(`span`,oe,o(a.$t(`common.message.mobileInstallNote`)),1)])):(s(),l(d,{key:1},[t(`div`,se,[r(g,{icon:a.faApple,class:`ios-soon__icon`},null,8,[`icon`]),t(`p`,ce,o(a.$t(`common.message.mobileComingSoon`)),1)]),t(`div`,le,[r(_,{round:``,size:`large`,class:`btn-ghost`,onClick:a.openSupport},{default:u(()=>[n(o(a.$t(`common.nav.support`)),1)]),_:1},8,[`onClick`])])],64))])]),t(`section`,ue,[t(`article`,de,[f[5]||=t(`span`,{class:`advantage__num`},`01`,-1),t(`h3`,fe,o(a.$t(`common.title.mobileFastAccess`)),1),t(`p`,pe,o(a.$t(`common.message.mobileFastAccess`)),1)]),t(`article`,$,[f[6]||=t(`span`,{class:`advantage__num`},`02`,-1),t(`h3`,me,o(a.$t(`common.title.mobileTrustedRelease`)),1),t(`p`,he,o(a.$t(`common.message.mobileTrustedRelease`)),1)]),t(`article`,ge,[f[7]||=t(`span`,{class:`advantage__num`},`03`,-1),t(`h3`,_e,o(a.$t(`common.title.mobileUnifiedExperience`)),1),t(`p`,ve,o(a.$t(`common.message.mobileUnifiedExperience`)),1)])]),t(`aside`,ye,[r(g,{icon:a.faCircleInfo,class:`note__icon`},null,8,[`icon`]),t(`p`,be,o(a.$t(`common.message.mobileInstallNote`)),1)])])])}var Se=ee(C,[[`render`,xe],[`__scopeId`,`data-v-46efd51c`]]);export{Se as default};
1
+ import"./rolldown-runtime--c01j_DQ.js";import{D as e,E as t,M as n,N as r,O as i,P as a,Ut as o,X as s,et as c,k as l,lt as u,x as d}from"./vendor-chart-mdwpew_o.js";import{t as f}from"./button-DWzbdjZV.js";import{$ as p,et as m,tt as h}from"./constants-B6_fTlam.js";import{E as ee,Et as g,r as _,s as v,v as y,x as b,y as x}from"./index-DpREqzJQ.js";import{t as S}from"./index.es-DkXuZNXE.js";var C=a({name:`DownloadIndex`,components:{ElButton:f,QrCode:g,FontAwesomeIcon:S},data(){return{faAndroid:y,faApple:x,faGooglePlay:b,faDownload:v,faCircleInfo:_}},computed:{version(){return h},brandTitle(){return this.$store.state.site?.title||`AceData`},brandLogo(){return this.$store.state.site?.logo||`/assets/logo-CDy94G52.png`},androidDownloadUrl(){return p},hasAndroidDownload(){return!!p},playStoreUrl(){return m},hasPlayStore(){return!!m},iosDownloadUrl(){return``},iosFallbackUrl(){return``},hasIosDownload(){return!1}},methods:{openSupport(){window.open(`https://platform.acedata.cloud/support`,`_blank`)}}}),w={class:`download-page`},T={class:`download-page__inner`},E={class:`hero`},D={class:`hero__brand`},O=[`src`,`alt`],k={class:`hero__eyebrow`},A={class:`hero__title`},j={class:`hero__subtitle`},M={class:`hero__badges`},N={class:`badge badge--live`},P={class:`badge`},F={class:`badge`},I={class:`hero__actions`},L={class:`platforms`},R={class:`platform platform--android`},z={class:`platform__head`},B={class:`platform__os`},V={class:`chip chip--live`},H={class:`platform__title`},U={class:`platform__text`},W={key:0,class:`qr`},G={class:`qr__hint`},te={class:`platform__foot platform__foot--stack`},K={key:0,class:`platform__fallback`},q={class:`platform__meta`},J={class:`platform__meta`},Y={class:`platform platform--ios`},X={class:`platform__head`},Z={class:`platform__os`},Q={class:`chip chip--pending`},ne={class:`platform__title`},re={class:`platform__text`},ie={key:0,class:`platform__foot platform__foot--stack`},ae={class:`btn-row`},oe={class:`platform__meta`},se={class:`ios-soon`},ce={class:`ios-soon__text`},le={class:`platform__foot platform__foot--stack`},ue={class:`advantages`},de={class:`advantage`},fe={class:`advantage__title`},pe={class:`advantage__text`},$={class:`advantage`},me={class:`advantage__title`},he={class:`advantage__text`},ge={class:`advantage`},_e={class:`advantage__title`},ve={class:`advantage__text`},ye={class:`note`},be={class:`note__text`};function xe(a,f,p,m,h,ee){let g=c(`font-awesome-icon`),_=c(`el-button`),v=c(`qr-code`);return s(),l(`div`,w,[f[8]||=t(`div`,{class:`download-page__glow`,"aria-hidden":`true`},null,-1),t(`div`,T,[t(`header`,E,[t(`span`,D,[t(`img`,{src:a.brandLogo,alt:a.brandTitle,class:`hero__logo`},null,8,O)]),t(`p`,k,o(a.brandTitle)+` · `+o(a.$t(`common.nav.mobileApp`)),1),t(`h1`,A,o(a.$t(`common.title.mobileApp`)),1),t(`p`,j,o(a.$t(`common.message.mobileAppDescription`)),1),t(`div`,M,[t(`span`,N,[f[0]||=t(`span`,{class:`badge__dot`},null,-1),n(o(a.$t(`common.message.mobileAvailableNow`)),1)]),t(`span`,P,`v`+o(a.version),1),t(`span`,F,o(a.$t(`common.message.mobileSharedAccount`)),1)]),t(`div`,I,[a.hasPlayStore?(s(),e(_,{key:0,type:`primary`,round:``,size:`large`,tag:`a`,href:a.playStoreUrl,target:`_blank`},{default:u(()=>[r(g,{icon:a.faGooglePlay,class:`btn-icon`},null,8,[`icon`]),n(` `+o(a.$t(`common.button.getOnGooglePlay`)),1)]),_:1},8,[`href`])):a.hasAndroidDownload?(s(),e(_,{key:1,type:`primary`,round:``,size:`large`,tag:`a`,href:a.androidDownloadUrl,target:`_blank`},{default:u(()=>[r(g,{icon:a.faAndroid,class:`btn-icon`},null,8,[`icon`]),n(` `+o(a.$t(`common.button.downloadAndroid`)),1)]),_:1},8,[`href`])):i(``,!0),r(_,{round:``,size:`large`,class:`btn-ghost`,onClick:a.openSupport},{default:u(()=>[n(o(a.$t(`common.nav.support`)),1)]),_:1},8,[`onClick`])])]),t(`section`,L,[t(`article`,R,[t(`div`,z,[t(`span`,B,[r(g,{icon:a.faAndroid,class:`platform__os-icon`},null,8,[`icon`]),f[1]||=n(` Android `,-1)]),t(`span`,V,[f[2]||=t(`span`,{class:`chip__dot`},null,-1),n(o(a.$t(`common.message.mobileAvailableNow`)),1)])]),t(`h2`,H,o(a.$t(`common.button.downloadAndroid`)),1),t(`p`,U,o(a.$t(`common.message.mobileAndroidHint`)),1),a.hasPlayStore||a.hasAndroidDownload?(s(),l(`div`,W,[r(v,{value:a.hasPlayStore?a.playStoreUrl:a.androidDownloadUrl,width:184,height:184,class:`qr__img`,type:`image/png`,color:{dark:`#0e2a33ff`,light:`#ffffffff`}},null,8,[`value`]),t(`p`,G,o(a.hasPlayStore?a.$t(`common.message.mobilePlayStoreHint`):a.$t(`common.message.mobileSecureDelivery`)),1)])):i(``,!0),t(`div`,te,[a.hasPlayStore?(s(),e(_,{key:0,type:`primary`,round:``,size:`large`,tag:`a`,href:a.playStoreUrl,target:`_blank`},{default:u(()=>[r(g,{icon:a.faGooglePlay,class:`btn-icon`},null,8,[`icon`]),n(` `+o(a.$t(`common.button.getOnGooglePlay`)),1)]),_:1},8,[`href`])):i(``,!0),a.hasAndroidDownload?(s(),l(d,{key:1},[a.hasPlayStore?(s(),l(`div`,K,[r(_,{round:``,tag:`a`,href:a.androidDownloadUrl,target:`_blank`,class:`btn-ghost`},{default:u(()=>[r(g,{icon:a.faDownload,class:`btn-icon`},null,8,[`icon`]),n(` `+o(a.$t(`common.button.downloadAndroid`)),1)]),_:1},8,[`href`]),t(`span`,q,o(a.$t(`common.message.mobileApkFallback`))+` · v`+o(a.version),1)])):(s(),l(d,{key:1},[r(_,{type:`primary`,round:``,size:`large`,tag:`a`,href:a.androidDownloadUrl,target:`_blank`},{default:u(()=>[r(g,{icon:a.faDownload,class:`btn-icon`},null,8,[`icon`]),n(` `+o(a.$t(`common.button.downloadAndroid`)),1)]),_:1},8,[`href`]),t(`span`,J,o(a.$t(`common.message.mobileDirectInstall`))+` · v`+o(a.version),1)],64))],64)):i(``,!0)])]),t(`article`,Y,[t(`div`,X,[t(`span`,Z,[r(g,{icon:a.faApple,class:`platform__os-icon`},null,8,[`icon`]),f[3]||=n(` iOS `,-1)]),t(`span`,Q,[f[4]||=t(`span`,{class:`chip__dot`},null,-1),n(o(a.$t(`common.message.mobileComingSoon`)),1)])]),t(`h2`,ne,o(a.$t(`common.button.downloadIos`)),1),t(`p`,re,o(a.hasIosDownload?a.$t(`common.message.mobileIosHint`):a.$t(`common.message.mobileIosPending`)),1),a.hasIosDownload?(s(),l(`div`,ie,[t(`div`,ae,[r(_,{type:`primary`,round:``,size:`large`,tag:`a`,href:a.iosDownloadUrl,target:`_blank`},{default:u(()=>[r(g,{icon:a.faApple,class:`btn-icon`},null,8,[`icon`]),n(` `+o(a.$t(`common.button.installIos`)),1)]),_:1},8,[`href`]),r(_,{round:``,size:`large`,class:`btn-ghost`,tag:`a`,href:a.iosFallbackUrl,target:`_blank`},{default:u(()=>[n(o(a.$t(`common.button.downloadIos`)),1)]),_:1},8,[`href`])]),t(`span`,oe,o(a.$t(`common.message.mobileInstallNote`)),1)])):(s(),l(d,{key:1},[t(`div`,se,[r(g,{icon:a.faApple,class:`ios-soon__icon`},null,8,[`icon`]),t(`p`,ce,o(a.$t(`common.message.mobileComingSoon`)),1)]),t(`div`,le,[r(_,{round:``,size:`large`,class:`btn-ghost`,onClick:a.openSupport},{default:u(()=>[n(o(a.$t(`common.nav.support`)),1)]),_:1},8,[`onClick`])])],64))])]),t(`section`,ue,[t(`article`,de,[f[5]||=t(`span`,{class:`advantage__num`},`01`,-1),t(`h3`,fe,o(a.$t(`common.title.mobileFastAccess`)),1),t(`p`,pe,o(a.$t(`common.message.mobileFastAccess`)),1)]),t(`article`,$,[f[6]||=t(`span`,{class:`advantage__num`},`02`,-1),t(`h3`,me,o(a.$t(`common.title.mobileTrustedRelease`)),1),t(`p`,he,o(a.$t(`common.message.mobileTrustedRelease`)),1)]),t(`article`,ge,[f[7]||=t(`span`,{class:`advantage__num`},`03`,-1),t(`h3`,_e,o(a.$t(`common.title.mobileUnifiedExperience`)),1),t(`p`,ve,o(a.$t(`common.message.mobileUnifiedExperience`)),1)])]),t(`aside`,ye,[r(g,{icon:a.faCircleInfo,class:`note__icon`},null,8,[`icon`]),t(`p`,be,o(a.$t(`common.message.mobileInstallNote`)),1)])])])}var Se=ee(C,[[`render`,xe],[`__scopeId`,`data-v-46efd51c`]]);export{Se as default};
@@ -1 +1 @@
1
- import"./rolldown-runtime--c01j_DQ.js";import{Bt as e,D as t,E as n,M as r,N as i,O as a,P as o,Q as s,Ut as c,X as l,et as u,k as d,lt as f,x as p,y as m}from"./vendor-chart-mdwpew_o.js";import{t as h}from"./button-DWzbdjZV.js";import{r as g,t as _}from"./select-CqM5oalI.js";import{t as v}from"./upload-C7rPv2P3.js";import{t as y}from"./tooltip-C3PYfh8V.js";import{t as b}from"./image-tzz5bG4l.js";import{t as x}from"./alert-BJj7gY4q.js";import{hi as S,zn as C}from"./constants-BVtW3DRs.js";import{At as w,E as T,Fn as E,Nt as D,Ot as ee,Sr as te,cn as O,jt as k,kr as A,kt as j,yr as M}from"./index-DGgsHGQJ.js";import{t as N}from"./index.es-CX_i3qgT.js";import{t as P}from"./CopyToClipboard-BvyK_FyK.js";import{t as F}from"./ImagePreview-BOICGdPc.js";import{t as I}from"./Hailuo-CFky3Lrx.js";import{t as L}from"./BotPlaceholder-DFp0g5zS.js";import{i as R,n as z,t as B}from"./pagination-CpCpCjbW.js";import{n as V,t as H}from"./NoTasks-C9x-H4Pc.js";import{t as U}from"./Consumption-Ci-3V7yB.js";import{t as W}from"./ApiCodeButton-C3NNEgIA.js";import{t as G}from"./VideoPlayer-BSYfg9U5.js";var K=o({name:`ModelSelector`,components:{ElSelect:g,ElOption:_},data(){return{}},computed:{options(){return[{value:`minimax-t2v`,label:this.$t(`hailuo.button.model1`)},{value:`minimax-i2v`,label:this.$t(`hailuo.button.model2`)},{value:`minimax-i2v-director`,label:this.$t(`hailuo.button.model3`)}]},value:{get(){return this.$store.state.hailuo?.config?.model},set(e){this.$store.commit(`hailuo/setConfig`,{...this.$store.state.hailuo?.config,model:e})}}},mounted(){this.value||=C}}),q={class:`field`},J={class:`title font-bold`},Y={class:`float-left`};function X(e,r,a,o,m,h){let g=u(`el-option`),_=u(`el-select`);return l(),d(`div`,q,[n(`h2`,J,c(e.$t(`hailuo.name.model`)),1),i(_,{modelValue:e.value,"onUpdate:modelValue":r[0]||=t=>e.value=t,class:`value`,placeholder:e.$t(`hailuo.placeholder.select`),clearable:``},{default:f(()=>[(l(!0),d(p,null,s(e.options,e=>(l(),t(g,{key:e.value,label:e.label,value:e.value},{default:f(()=>[n(`span`,Y,c(e.label),1)]),_:2},1032,[`label`,`value`]))),128))]),_:1},8,[`modelValue`,`placeholder`])])}var Z=T(K,[[`render`,X],[`__scopeId`,`data-v-a768fbd9`]]),Q=o({name:`StartImageUrlInput`,components:{ElUpload:v,ElButton:h,InfoIcon:R,ImagePreview:F},mixins:[k,j],data(){return{fileList:[],uploadUrl:te()+`/api/v1/files/`}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e.url).filter(e=>e!==void 0)},value:{get(){return this.$store.state.hailuo?.config?.first_image_url},set(){let e=this.urls?.[0];this.$store.commit(`hailuo/setConfig`,{...this.$store.state.hailuo?.config,first_image_url:e})}}},mounted(){this.value||=void 0,this.onSetStartImageUrl()},methods:{onExceed(){A.warning(this.$t(`hailuo.message.uploadStartImageExceed`))},onError(){A.error(this.$t(`hailuo.message.uploadStartImageError`))},async onRemove(){A.error(this.$t(`hailuo.message.uploadStartImageError`))},onSetStartImageUrl(){let e=this.urls?.[0];this.$store.commit(`hailuo/setConfig`,{...this.$store.state.hailuo?.config,first_image_url:e})},async onSuccess(){this.onSetStartImageUrl()}}}),ne={class:`relative`},re={class:`flex justify-between`},ie={class:`flex justify-start items-center`},ae={class:`text-sm font-bold`};function oe(e,o,s,p,m,h){let g=u(`info-icon`),_=u(`image-preview`),v=u(`el-button`),y=u(`el-upload`);return l(),d(`div`,ne,[n(`div`,re,[n(`div`,ie,[n(`span`,ae,c(e.$t(`hailuo.name.startImageUrl`)),1),i(g,{content:e.$t(`hailuo.description.startImageUrl`),class:`info`},null,8,[`content`])])]),i(y,{ref:`uploader`,"file-list":e.fileList,"onUpdate:fileList":o[0]||=t=>e.fileList=t,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:f(({file:n})=>[n.url&&n.percentage!==void 0?(l(),t(_,{key:0,url:n.url,name:n.name,percentage:n.percentage,onRemove:t=>e.fileList.splice(e.fileList.indexOf(n),1)},null,8,[`url`,`name`,`percentage`,`onRemove`])):a(``,!0)]),default:f(()=>[i(v,{size:`small`,type:`primary`,class:`btn btn-upload`,round:``},{default:f(()=>[r(c(e.$t(`hailuo.button.uploadStartImageUrl`)),1)]),_:1})]),_:1},8,[`file-list`,`action`,`on-exceed`,`on-error`,`on-remove`,`on-success`,`headers`])])}var se=T(Q,[[`render`,oe],[`__scopeId`,`data-v-fbf49b06`]]),ce=o({name:`PromptInput`,components:{PromptTextarea:V},computed:{prompt:{get(){return this.$store.state.hailuo?.config?.prompt},set(e){this.$store.commit(`hailuo/setConfig`,{...this.$store.state.hailuo?.config,prompt:e})}}},mounted(){this.prompt||=``}});function le(e,n,r,i,a,o){let s=u(`prompt-textarea`);return l(),t(s,{modelValue:e.prompt,"onUpdate:modelValue":n[0]||=t=>e.prompt=t,title:e.$t(`hailuo.name.prompt`),info:e.$t(`hailuo.description.prompt`),placeholder:e.$t(`hailuo.placeholder.prompt`)},null,8,[`modelValue`,`title`,`info`,`placeholder`])}var ue=o({name:`PresetPanel`,components:{ElButton:h,FontAwesomeIcon:N,PromptInput:T(ce,[[`render`,le]]),StartImageUrlInput:se,ModelSelector:Z,Consumption:U},emits:[`generate`],computed:{config(){return this.$store.state.hailuo?.config},consumption(){return D(this.config,this.service?.cost)},service(){return this.$store.state.hailuo?.service}},methods:{onGenerate(){this.$emit(`generate`)}}}),de={class:`flex flex-col h-full`},fe={class:`flex-1 overflow-y-auto p-5`},pe={class:`flex flex-col items-center justify-center px-5 pb-5`};function me(e,o,s,p,m,h){let g=u(`prompt-input`),_=u(`model-selector`),v=u(`start-image-url-input`),y=u(`consumption`),b=u(`font-awesome-icon`),x=u(`el-button`);return l(),d(`div`,de,[n(`div`,fe,[i(g,{class:`mb-4`}),i(_,{class:`mb-4`}),e.config?.model===`minimax-i2v`?(l(),t(v,{key:0,class:`mb-2`})):a(``,!0)]),n(`div`,pe,[i(y,{value:e.consumption,service:e.service},null,8,[`value`,`service`]),e.config?.video_url!==void 0||e.config?.custom?(l(),t(x,{key:0,type:`primary`,class:`btn w-full`,round:``,onClick:e.onGenerate},{default:f(()=>[i(b,{icon:`fa-solid fa-magic`,class:`mr-2`}),r(` `+c(e.$t(`hailuo.button.extend`)),1)]),_:1},8,[`onClick`])):(l(),t(x,{key:1,type:`primary`,class:`btn w-full`,round:``,onClick:e.onGenerate},{default:f(()=>[i(b,{icon:`fa-solid fa-magic`,class:`mr-2`}),r(` `+c(e.$t(`hailuo.button.generate`)),1)]),_:1},8,[`onClick`]))])])}var he=T(ue,[[`render`,me]]),ge=o({name:`TaskPreview`,components:{ElImage:b,CopyToClipboard:P,FontAwesomeIcon:N,ElAlert:x,VideoPlayer:G,ElTooltip:y,ElButton:h,ApiCodeButton:W},props:{modelValue:{type:Object,required:!0}},computed:{application(){return this.$store.state.hailuo?.application},config(){return this.$store.state.hailuo?.config},video(){return this.modelValue?.response?.data?.[0]}},methods:{onDownload(e){console.debug(`on download hailuo video`,e),window.open(e,`_blank`)}}}),_e={class:`preview`},ve={class:`left`},ye={class:`main`},be={class:`bot`},xe={class:`datetime`},Se={class:`info`},Ce={key:0,class:`prompt mt-2`},we={key:0},Te={key:1},Ee={key:0,class:e({content:!0,failed:!0})},De={key:0,class:`mb-4`},Oe={key:1,class:e({operations:!0,"mt-2":!0})},ke={key:0,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},Ae={class:`text-[var(--el-text-color-regular)] text-xs mb-2`},je={key:1,class:`text-[var(--el-text-color-regular)] text-xs mb-0`},Me={key:1,class:e({content:!0})},Ne={class:`text-[var(--el-text-color-regular)] text-xs mb-2`},Pe={class:`text-[var(--el-text-color-regular)] text-xs mb-2`},$={key:0,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},Fe={class:`text-[var(--el-text-color-regular)] text-xs mb-0`},Ie={key:2,class:e({content:!0})},Le={class:`text-[var(--el-text-color-regular)] text-xs mb-0`};function Re(e,o,s,p,h,g){let _=u(`el-image`),v=u(`video-player`),y=u(`el-button`),b=u(`el-tooltip`),x=u(`api-code-button`),S=u(`font-awesome-icon`),C=u(`copy-to-clipboard`),w=u(`el-alert`);return l(),d(`div`,_e,[n(`div`,ve,[i(_,{src:`https://cdn.acedata.cloud/0qg4gp.png`,class:`avatar`})]),n(`div`,ye,[n(`div`,be,[r(c(e.$t(`hailuo.name.hailuoBot`))+` `,1),n(`span`,xe,c(e.$dayjs.format(``+new Date(parseFloat((e.modelValue?.created_at||``).toString())*1e3))),1)]),n(`div`,Se,[e.modelValue?.request?.prompt?(l(),d(`p`,Ce,[r(c(e.modelValue?.request?.prompt)+` `,1),e.modelValue?.response?a(``,!0):(l(),d(`span`,we,` - (`+c(e.$t(`hailuo.status.pending`))+`) `,1)),e.video?.state===`processing`||e.video?.state===`pending`||e.video?.state===`running`?(l(),d(`span`,Te,` - (`+c(e.$t(`hailuo.status.processing`))+`) `,1)):a(``,!0)])):a(``,!0)]),e.modelValue?.response?.success===!0?(l(),d(`div`,Ee,[e.video?.video_url?(l(),d(`div`,De,[i(v,{src:e.video?.video_url},null,8,[`src`])])):a(``,!0),e.video?(l(),d(`div`,Oe,[i(b,{class:`box-item`,effect:`dark`,content:e.$t(`hailuo.message.downloadVideo`),placement:`top-start`},{default:f(()=>[e.video?.video_url?(l(),t(y,{key:0,type:`info`,size:`small`,class:`mb-2`,onClick:o[0]||=m(t=>e.onDownload(e.video?.video_url),[`stop`])},{default:f(()=>[r(c(e.$t(`hailuo.button.download`)),1)]),_:1})):a(``,!0)]),_:1},8,[`content`]),i(x,{path:`/hailuo/videos`,body:e.modelValue?.request},null,8,[`body`])])):a(``,!0),i(w,{closable:!1,class:`mt-2 success`},{default:f(()=>[e.modelValue?.request?.model?(l(),d(`p`,ke,[i(S,{icon:`fa-solid fa-hashtag`,class:`mr-1`}),r(` `+c(e.$t(`hailuo.name.model`))+`: `+c(e.modelValue?.request?.model)+` `,1),i(C,{content:e.modelValue?.id},null,8,[`content`])])):a(``,!0),n(`p`,Ae,[i(S,{icon:`fa-solid fa-magic`,class:`mr-1`}),r(` `+c(e.$t(`hailuo.name.taskId`))+`: `+c(e.modelValue?.id)+` `,1),i(C,{content:e.modelValue?.id},null,8,[`content`])]),e.modelValue?.elapsed?(l(),d(`p`,je,[i(S,{icon:`fa-solid fa-clock`,class:`mr-1`}),r(` `+c(e.$t(`hailuo.name.elapsed`))+`: `+c(e.modelValue?.elapsed?.toFixed(2))+`s `,1)])):a(``,!0)]),_:1})])):a(``,!0),e.modelValue?.response?.success===!1?(l(),d(`div`,Me,[i(w,{closable:!1,class:`failure`},{template:f(()=>[i(S,{icon:`fa-solid fa-exclamation-triangle`,class:`mr-1`}),r(` `+c(e.$t(`hailuo.name.failure`)),1)]),default:f(()=>[n(`p`,Ne,[i(S,{icon:`fa-solid fa-magic`,class:`mr-1`}),r(` `+c(e.$t(`hailuo.name.taskId`))+`: `+c(e.modelValue?.id)+` `,1),i(C,{content:e.modelValue?.id},null,8,[`content`])]),n(`p`,Pe,[i(S,{icon:`fa-solid fa-circle-info`,class:`mr-1`}),r(` `+c(e.$t(`hailuo.name.failureReason`))+`: `+c(e.modelValue?.response?.error?.message)+` `,1),i(C,{content:e.modelValue?.response?.error?.message},null,8,[`content`])]),e.modelValue?.elapsed?(l(),d(`p`,$,[i(S,{icon:`fa-solid fa-clock`,class:`mr-1`}),r(` `+c(e.$t(`hailuo.name.elapsed`))+`: `+c(e.modelValue?.elapsed?.toFixed(2))+`s `,1)])):a(``,!0),n(`p`,Fe,[i(S,{icon:`fa-solid fa-hashtag`,class:`mr-1`}),r(` `+c(e.$t(`hailuo.name.traceId`))+`: `+c(e.modelValue?.response?.trace_id)+` `,1),i(C,{content:e.modelValue?.response?.trace_id},null,8,[`content`])])]),_:1})])):a(``,!0),e.modelValue?.response?.success===void 0?(l(),d(`div`,Ie,[i(w,{closable:!1,class:`info`},{template:f(()=>[i(S,{icon:`fa-solid fa-exclamation-triangle`,class:`mr-1`}),r(` `+c(e.$t(`hailuo.name.failure`)),1)]),default:f(()=>[n(`p`,Le,[i(S,{icon:`fa-solid fa-magic`,class:`mr-1`}),r(` `+c(e.$t(`hailuo.name.taskId`))+`: `+c(e.modelValue?.id)+` `,1),i(C,{content:e.modelValue?.id},null,8,[`content`])])]),_:1})])):a(``,!0)])])}var ze=o({name:`RecentPanel`,components:{TaskPreview:T(ge,[[`render`,Re],[`__scopeId`,`data-v-53d13da4`]]),BotPlaceholder:L,NoTasks:H,ScrollList:z},props:{loading:{type:Boolean,default:!1}},emits:[`reach-top`],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.hailuo?.tasks,items:this.$store.state.hailuo?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),Be={key:0},Ve={key:2,class:`w-full h-full flex items-center justify-center`};function He(e,n,r,o,c,m){let h=u(`bot-placeholder`),g=u(`task-preview`),_=u(`scroll-list`),v=u(`no-tasks`);return l(),d(p,null,[e.tasks?.items===void 0?(l(),d(`div`,Be,[i(h)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(l(),t(_,{key:1,ref:`scrollList`,class:`tasks w-full h-full overflow-y-auto`,loading:e.loading,onReachTop:n[0]||=t=>e.$emit(`reach-top`)},{default:f(()=>[(l(!0),d(p,null,s(e.tasks?.items,e=>(l(),t(g,{key:e.id,"model-value":e},null,8,[`model-value`]))),128))]),_:1},8,[`loading`])):a(``,!0),e.tasks?.items?.length===0?(l(),d(`div`,Ve,[i(v)])):a(``,!0)],64)}var Ue=T(ze,[[`render`,He]]),We=S(`hailuo`),Ge=o({name:`HailuoIndex`,components:{ConfigPanel:he,Layout:I,RecentPanel:Ue},mixins:[w],inject:[`initialized`],data(){return{task:void 0,job:0,timer:void 0,loadingMore:!1,fetchingTasks:!1}},computed:{applicationsLoading(){return this.$store.state.hailuo?.status?.getApplications===M.Request},tasksLoading(){return this.$store.state.hailuo?.status?.getTasks===M.Request||this.fetchingTasks},credential(){return this.$store.state.hailuo.credential},config(){return this.$store.state.hailuo.config},application(){return this.$store.state.hailuo.application},tasks(){return this.$store.state.hailuo.tasks}},watch:{tasks:{handler(e,t){e?.items?.length>t?.items?.length&&console.debug(`new tasks detected`)},deep:!0},initialized:{async handler(e){e&&(console.debug(`layout initialized`),await this.onGetTasks(),await this.onScrollDown(),this.job=window.setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){window.clearInterval(this.job)},methods:{async onReachTop(){await B({tasks:this.tasks,getTasks:()=>this.tasks,loading:this.loadingMore,setLoading:e=>this.loadingMore=e,isBlocked:()=>this.tasksLoading||this.applicationsLoading,fetch:e=>this.onGetTasks({createdAtMax:e}),getScrollElement:()=>this.getTasksScrollElement()})},async onGetService(){console.debug(`start onGetService`),await this.$store.dispatch(`hailuo/getService`),console.debug(`end onGetService`)},async onGetApplication(){console.debug(`start onGetApplication`),await this.$store.dispatch(`hailuo/getApplications`),console.debug(`end onGetApplication`),await this.onGetTasks()},async onScrollDown(){await this.$nextTick();let e=this.getTasksScrollElement();e&&(e.scrollTop=e.scrollHeight)},async onGetTasks(e){if(this.applicationsLoading||this.fetchingTasks){console.debug(`loading`);return}console.debug(`start onGetTasks`,e);let{limit:t=5,createdAtMin:n,createdAtMax:r}=e||{};console.debug(`limit`,t,`createdAtMin`,n,`createdAtMax`,r),this.fetchingTasks=!0;try{await this.$store.dispatch(`hailuo/getTasks`,{limit:t,createdAtMin:n,createdAtMax:r})}finally{this.fetchingTasks=!1}},async onGenerate(){if(!ee(this.uploadTracker,e=>this.$t(e),e=>A.warning(e)))return;let e={...this.config,callback_url:We},t=this.credential?.token;if(!t){console.error(`no token specified`);return}A.info(this.$t(`hailuo.message.startingTask`)),E(`hailuo`,O.generate(e,{token:t})).then(()=>{A.success(this.$t(`hailuo.message.startTaskSuccess`))}).catch(e=>{(e?.response?.data)?.error?.code===`used_up`?A.error(this.$t(`hailuo.message.usedUp`)):A.error(this.$t(`hailuo.message.startTaskFailed`))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function Ke(e,n,r,a,o,s){let c=u(`config-panel`),d=u(`recent-panel`),p=u(`layout`);return l(),t(p,null,{config:f(()=>[i(c,{onGenerate:e.onGenerate},null,8,[`onGenerate`])]),result:f(()=>[i(d,{ref:`recentPanel`,loading:e.loadingMore,onReachTop:e.onReachTop},null,8,[`loading`,`onReachTop`])]),_:1})}var qe=T(Ge,[[`render`,Ke]]);export{qe as default};
1
+ import"./rolldown-runtime--c01j_DQ.js";import{Bt as e,D as t,E as n,M as r,N as i,O as a,P as o,Q as s,Ut as c,X as l,et as u,k as d,lt as f,x as p,y as m}from"./vendor-chart-mdwpew_o.js";import{t as h}from"./button-DWzbdjZV.js";import{r as g,t as _}from"./select-CYdISXBV.js";import{t as v}from"./upload-CHAO8dYa.js";import{t as y}from"./tooltip-C3PYfh8V.js";import{t as b}from"./image-tItcr5tZ.js";import{t as x}from"./alert-BJj7gY4q.js";import{hi as S,zn as C}from"./constants-B6_fTlam.js";import{At as w,E as T,Fn as E,Nt as D,Ot as ee,Sr as te,cn as O,jt as k,kr as A,kt as j,yr as M}from"./index-DpREqzJQ.js";import{t as N}from"./index.es-DkXuZNXE.js";import{t as P}from"./CopyToClipboard-DXA4nHxo.js";import{t as F}from"./ImagePreview-Bkw_taCt.js";import{t as I}from"./Hailuo-D_ir2qwk.js";import{t as L}from"./BotPlaceholder-R_nAAbft.js";import{i as R,n as z,t as B}from"./pagination-BQOE0Lce.js";import{n as V,t as H}from"./NoTasks-568fhAGt.js";import{t as U}from"./Consumption-CjrpUNmV.js";import{t as W}from"./ApiCodeButton-DXN7iB8l.js";import{t as G}from"./VideoPlayer-BjsbkQZc.js";var K=o({name:`ModelSelector`,components:{ElSelect:g,ElOption:_},data(){return{}},computed:{options(){return[{value:`minimax-t2v`,label:this.$t(`hailuo.button.model1`)},{value:`minimax-i2v`,label:this.$t(`hailuo.button.model2`)},{value:`minimax-i2v-director`,label:this.$t(`hailuo.button.model3`)}]},value:{get(){return this.$store.state.hailuo?.config?.model},set(e){this.$store.commit(`hailuo/setConfig`,{...this.$store.state.hailuo?.config,model:e})}}},mounted(){this.value||=C}}),q={class:`field`},J={class:`title font-bold`},Y={class:`float-left`};function X(e,r,a,o,m,h){let g=u(`el-option`),_=u(`el-select`);return l(),d(`div`,q,[n(`h2`,J,c(e.$t(`hailuo.name.model`)),1),i(_,{modelValue:e.value,"onUpdate:modelValue":r[0]||=t=>e.value=t,class:`value`,placeholder:e.$t(`hailuo.placeholder.select`),clearable:``},{default:f(()=>[(l(!0),d(p,null,s(e.options,e=>(l(),t(g,{key:e.value,label:e.label,value:e.value},{default:f(()=>[n(`span`,Y,c(e.label),1)]),_:2},1032,[`label`,`value`]))),128))]),_:1},8,[`modelValue`,`placeholder`])])}var Z=T(K,[[`render`,X],[`__scopeId`,`data-v-a768fbd9`]]),Q=o({name:`StartImageUrlInput`,components:{ElUpload:v,ElButton:h,InfoIcon:R,ImagePreview:F},mixins:[k,j],data(){return{fileList:[],uploadUrl:te()+`/api/v1/files/`}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e.url).filter(e=>e!==void 0)},value:{get(){return this.$store.state.hailuo?.config?.first_image_url},set(){let e=this.urls?.[0];this.$store.commit(`hailuo/setConfig`,{...this.$store.state.hailuo?.config,first_image_url:e})}}},mounted(){this.value||=void 0,this.onSetStartImageUrl()},methods:{onExceed(){A.warning(this.$t(`hailuo.message.uploadStartImageExceed`))},onError(){A.error(this.$t(`hailuo.message.uploadStartImageError`))},async onRemove(){A.error(this.$t(`hailuo.message.uploadStartImageError`))},onSetStartImageUrl(){let e=this.urls?.[0];this.$store.commit(`hailuo/setConfig`,{...this.$store.state.hailuo?.config,first_image_url:e})},async onSuccess(){this.onSetStartImageUrl()}}}),ne={class:`relative`},re={class:`flex justify-between`},ie={class:`flex justify-start items-center`},ae={class:`text-sm font-bold`};function oe(e,o,s,p,m,h){let g=u(`info-icon`),_=u(`image-preview`),v=u(`el-button`),y=u(`el-upload`);return l(),d(`div`,ne,[n(`div`,re,[n(`div`,ie,[n(`span`,ae,c(e.$t(`hailuo.name.startImageUrl`)),1),i(g,{content:e.$t(`hailuo.description.startImageUrl`),class:`info`},null,8,[`content`])])]),i(y,{ref:`uploader`,"file-list":e.fileList,"onUpdate:fileList":o[0]||=t=>e.fileList=t,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:f(({file:n})=>[n.url&&n.percentage!==void 0?(l(),t(_,{key:0,url:n.url,name:n.name,percentage:n.percentage,onRemove:t=>e.fileList.splice(e.fileList.indexOf(n),1)},null,8,[`url`,`name`,`percentage`,`onRemove`])):a(``,!0)]),default:f(()=>[i(v,{size:`small`,type:`primary`,class:`btn btn-upload`,round:``},{default:f(()=>[r(c(e.$t(`hailuo.button.uploadStartImageUrl`)),1)]),_:1})]),_:1},8,[`file-list`,`action`,`on-exceed`,`on-error`,`on-remove`,`on-success`,`headers`])])}var se=T(Q,[[`render`,oe],[`__scopeId`,`data-v-fbf49b06`]]),ce=o({name:`PromptInput`,components:{PromptTextarea:V},computed:{prompt:{get(){return this.$store.state.hailuo?.config?.prompt},set(e){this.$store.commit(`hailuo/setConfig`,{...this.$store.state.hailuo?.config,prompt:e})}}},mounted(){this.prompt||=``}});function le(e,n,r,i,a,o){let s=u(`prompt-textarea`);return l(),t(s,{modelValue:e.prompt,"onUpdate:modelValue":n[0]||=t=>e.prompt=t,title:e.$t(`hailuo.name.prompt`),info:e.$t(`hailuo.description.prompt`),placeholder:e.$t(`hailuo.placeholder.prompt`)},null,8,[`modelValue`,`title`,`info`,`placeholder`])}var ue=o({name:`PresetPanel`,components:{ElButton:h,FontAwesomeIcon:N,PromptInput:T(ce,[[`render`,le]]),StartImageUrlInput:se,ModelSelector:Z,Consumption:U},emits:[`generate`],computed:{config(){return this.$store.state.hailuo?.config},consumption(){return D(this.config,this.service?.cost)},service(){return this.$store.state.hailuo?.service}},methods:{onGenerate(){this.$emit(`generate`)}}}),de={class:`flex flex-col h-full`},fe={class:`flex-1 overflow-y-auto p-5`},pe={class:`flex flex-col items-center justify-center px-5 pb-5`};function me(e,o,s,p,m,h){let g=u(`prompt-input`),_=u(`model-selector`),v=u(`start-image-url-input`),y=u(`consumption`),b=u(`font-awesome-icon`),x=u(`el-button`);return l(),d(`div`,de,[n(`div`,fe,[i(g,{class:`mb-4`}),i(_,{class:`mb-4`}),e.config?.model===`minimax-i2v`?(l(),t(v,{key:0,class:`mb-2`})):a(``,!0)]),n(`div`,pe,[i(y,{value:e.consumption,service:e.service},null,8,[`value`,`service`]),e.config?.video_url!==void 0||e.config?.custom?(l(),t(x,{key:0,type:`primary`,class:`btn w-full`,round:``,onClick:e.onGenerate},{default:f(()=>[i(b,{icon:`fa-solid fa-magic`,class:`mr-2`}),r(` `+c(e.$t(`hailuo.button.extend`)),1)]),_:1},8,[`onClick`])):(l(),t(x,{key:1,type:`primary`,class:`btn w-full`,round:``,onClick:e.onGenerate},{default:f(()=>[i(b,{icon:`fa-solid fa-magic`,class:`mr-2`}),r(` `+c(e.$t(`hailuo.button.generate`)),1)]),_:1},8,[`onClick`]))])])}var he=T(ue,[[`render`,me]]),ge=o({name:`TaskPreview`,components:{ElImage:b,CopyToClipboard:P,FontAwesomeIcon:N,ElAlert:x,VideoPlayer:G,ElTooltip:y,ElButton:h,ApiCodeButton:W},props:{modelValue:{type:Object,required:!0}},computed:{application(){return this.$store.state.hailuo?.application},config(){return this.$store.state.hailuo?.config},video(){return this.modelValue?.response?.data?.[0]}},methods:{onDownload(e){console.debug(`on download hailuo video`,e),window.open(e,`_blank`)}}}),_e={class:`preview`},ve={class:`left`},ye={class:`main`},be={class:`bot`},xe={class:`datetime`},Se={class:`info`},Ce={key:0,class:`prompt mt-2`},we={key:0},Te={key:1},Ee={key:0,class:e({content:!0,failed:!0})},De={key:0,class:`mb-4`},Oe={key:1,class:e({operations:!0,"mt-2":!0})},ke={key:0,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},Ae={class:`text-[var(--el-text-color-regular)] text-xs mb-2`},je={key:1,class:`text-[var(--el-text-color-regular)] text-xs mb-0`},Me={key:1,class:e({content:!0})},Ne={class:`text-[var(--el-text-color-regular)] text-xs mb-2`},Pe={class:`text-[var(--el-text-color-regular)] text-xs mb-2`},$={key:0,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},Fe={class:`text-[var(--el-text-color-regular)] text-xs mb-0`},Ie={key:2,class:e({content:!0})},Le={class:`text-[var(--el-text-color-regular)] text-xs mb-0`};function Re(e,o,s,p,h,g){let _=u(`el-image`),v=u(`video-player`),y=u(`el-button`),b=u(`el-tooltip`),x=u(`api-code-button`),S=u(`font-awesome-icon`),C=u(`copy-to-clipboard`),w=u(`el-alert`);return l(),d(`div`,_e,[n(`div`,ve,[i(_,{src:`https://cdn.acedata.cloud/0qg4gp.png`,class:`avatar`})]),n(`div`,ye,[n(`div`,be,[r(c(e.$t(`hailuo.name.hailuoBot`))+` `,1),n(`span`,xe,c(e.$dayjs.format(``+new Date(parseFloat((e.modelValue?.created_at||``).toString())*1e3))),1)]),n(`div`,Se,[e.modelValue?.request?.prompt?(l(),d(`p`,Ce,[r(c(e.modelValue?.request?.prompt)+` `,1),e.modelValue?.response?a(``,!0):(l(),d(`span`,we,` - (`+c(e.$t(`hailuo.status.pending`))+`) `,1)),e.video?.state===`processing`||e.video?.state===`pending`||e.video?.state===`running`?(l(),d(`span`,Te,` - (`+c(e.$t(`hailuo.status.processing`))+`) `,1)):a(``,!0)])):a(``,!0)]),e.modelValue?.response?.success===!0?(l(),d(`div`,Ee,[e.video?.video_url?(l(),d(`div`,De,[i(v,{src:e.video?.video_url},null,8,[`src`])])):a(``,!0),e.video?(l(),d(`div`,Oe,[i(b,{class:`box-item`,effect:`dark`,content:e.$t(`hailuo.message.downloadVideo`),placement:`top-start`},{default:f(()=>[e.video?.video_url?(l(),t(y,{key:0,type:`info`,size:`small`,class:`mb-2`,onClick:o[0]||=m(t=>e.onDownload(e.video?.video_url),[`stop`])},{default:f(()=>[r(c(e.$t(`hailuo.button.download`)),1)]),_:1})):a(``,!0)]),_:1},8,[`content`]),i(x,{path:`/hailuo/videos`,body:e.modelValue?.request},null,8,[`body`])])):a(``,!0),i(w,{closable:!1,class:`mt-2 success`},{default:f(()=>[e.modelValue?.request?.model?(l(),d(`p`,ke,[i(S,{icon:`fa-solid fa-hashtag`,class:`mr-1`}),r(` `+c(e.$t(`hailuo.name.model`))+`: `+c(e.modelValue?.request?.model)+` `,1),i(C,{content:e.modelValue?.id},null,8,[`content`])])):a(``,!0),n(`p`,Ae,[i(S,{icon:`fa-solid fa-magic`,class:`mr-1`}),r(` `+c(e.$t(`hailuo.name.taskId`))+`: `+c(e.modelValue?.id)+` `,1),i(C,{content:e.modelValue?.id},null,8,[`content`])]),e.modelValue?.elapsed?(l(),d(`p`,je,[i(S,{icon:`fa-solid fa-clock`,class:`mr-1`}),r(` `+c(e.$t(`hailuo.name.elapsed`))+`: `+c(e.modelValue?.elapsed?.toFixed(2))+`s `,1)])):a(``,!0)]),_:1})])):a(``,!0),e.modelValue?.response?.success===!1?(l(),d(`div`,Me,[i(w,{closable:!1,class:`failure`},{template:f(()=>[i(S,{icon:`fa-solid fa-exclamation-triangle`,class:`mr-1`}),r(` `+c(e.$t(`hailuo.name.failure`)),1)]),default:f(()=>[n(`p`,Ne,[i(S,{icon:`fa-solid fa-magic`,class:`mr-1`}),r(` `+c(e.$t(`hailuo.name.taskId`))+`: `+c(e.modelValue?.id)+` `,1),i(C,{content:e.modelValue?.id},null,8,[`content`])]),n(`p`,Pe,[i(S,{icon:`fa-solid fa-circle-info`,class:`mr-1`}),r(` `+c(e.$t(`hailuo.name.failureReason`))+`: `+c(e.modelValue?.response?.error?.message)+` `,1),i(C,{content:e.modelValue?.response?.error?.message},null,8,[`content`])]),e.modelValue?.elapsed?(l(),d(`p`,$,[i(S,{icon:`fa-solid fa-clock`,class:`mr-1`}),r(` `+c(e.$t(`hailuo.name.elapsed`))+`: `+c(e.modelValue?.elapsed?.toFixed(2))+`s `,1)])):a(``,!0),n(`p`,Fe,[i(S,{icon:`fa-solid fa-hashtag`,class:`mr-1`}),r(` `+c(e.$t(`hailuo.name.traceId`))+`: `+c(e.modelValue?.response?.trace_id)+` `,1),i(C,{content:e.modelValue?.response?.trace_id},null,8,[`content`])])]),_:1})])):a(``,!0),e.modelValue?.response?.success===void 0?(l(),d(`div`,Ie,[i(w,{closable:!1,class:`info`},{template:f(()=>[i(S,{icon:`fa-solid fa-exclamation-triangle`,class:`mr-1`}),r(` `+c(e.$t(`hailuo.name.failure`)),1)]),default:f(()=>[n(`p`,Le,[i(S,{icon:`fa-solid fa-magic`,class:`mr-1`}),r(` `+c(e.$t(`hailuo.name.taskId`))+`: `+c(e.modelValue?.id)+` `,1),i(C,{content:e.modelValue?.id},null,8,[`content`])])]),_:1})])):a(``,!0)])])}var ze=o({name:`RecentPanel`,components:{TaskPreview:T(ge,[[`render`,Re],[`__scopeId`,`data-v-53d13da4`]]),BotPlaceholder:L,NoTasks:H,ScrollList:z},props:{loading:{type:Boolean,default:!1}},emits:[`reach-top`],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.hailuo?.tasks,items:this.$store.state.hailuo?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),Be={key:0},Ve={key:2,class:`w-full h-full flex items-center justify-center`};function He(e,n,r,o,c,m){let h=u(`bot-placeholder`),g=u(`task-preview`),_=u(`scroll-list`),v=u(`no-tasks`);return l(),d(p,null,[e.tasks?.items===void 0?(l(),d(`div`,Be,[i(h)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(l(),t(_,{key:1,ref:`scrollList`,class:`tasks w-full h-full overflow-y-auto`,loading:e.loading,onReachTop:n[0]||=t=>e.$emit(`reach-top`)},{default:f(()=>[(l(!0),d(p,null,s(e.tasks?.items,e=>(l(),t(g,{key:e.id,"model-value":e},null,8,[`model-value`]))),128))]),_:1},8,[`loading`])):a(``,!0),e.tasks?.items?.length===0?(l(),d(`div`,Ve,[i(v)])):a(``,!0)],64)}var Ue=T(ze,[[`render`,He]]),We=S(`hailuo`),Ge=o({name:`HailuoIndex`,components:{ConfigPanel:he,Layout:I,RecentPanel:Ue},mixins:[w],inject:[`initialized`],data(){return{task:void 0,job:0,timer:void 0,loadingMore:!1,fetchingTasks:!1}},computed:{applicationsLoading(){return this.$store.state.hailuo?.status?.getApplications===M.Request},tasksLoading(){return this.$store.state.hailuo?.status?.getTasks===M.Request||this.fetchingTasks},credential(){return this.$store.state.hailuo.credential},config(){return this.$store.state.hailuo.config},application(){return this.$store.state.hailuo.application},tasks(){return this.$store.state.hailuo.tasks}},watch:{tasks:{handler(e,t){e?.items?.length>t?.items?.length&&console.debug(`new tasks detected`)},deep:!0},initialized:{async handler(e){e&&(console.debug(`layout initialized`),await this.onGetTasks(),await this.onScrollDown(),this.job=window.setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){window.clearInterval(this.job)},methods:{async onReachTop(){await B({tasks:this.tasks,getTasks:()=>this.tasks,loading:this.loadingMore,setLoading:e=>this.loadingMore=e,isBlocked:()=>this.tasksLoading||this.applicationsLoading,fetch:e=>this.onGetTasks({createdAtMax:e}),getScrollElement:()=>this.getTasksScrollElement()})},async onGetService(){console.debug(`start onGetService`),await this.$store.dispatch(`hailuo/getService`),console.debug(`end onGetService`)},async onGetApplication(){console.debug(`start onGetApplication`),await this.$store.dispatch(`hailuo/getApplications`),console.debug(`end onGetApplication`),await this.onGetTasks()},async onScrollDown(){await this.$nextTick();let e=this.getTasksScrollElement();e&&(e.scrollTop=e.scrollHeight)},async onGetTasks(e){if(this.applicationsLoading||this.fetchingTasks){console.debug(`loading`);return}console.debug(`start onGetTasks`,e);let{limit:t=5,createdAtMin:n,createdAtMax:r}=e||{};console.debug(`limit`,t,`createdAtMin`,n,`createdAtMax`,r),this.fetchingTasks=!0;try{await this.$store.dispatch(`hailuo/getTasks`,{limit:t,createdAtMin:n,createdAtMax:r})}finally{this.fetchingTasks=!1}},async onGenerate(){if(!ee(this.uploadTracker,e=>this.$t(e),e=>A.warning(e)))return;let e={...this.config,callback_url:We},t=this.credential?.token;if(!t){console.error(`no token specified`);return}A.info(this.$t(`hailuo.message.startingTask`)),E(`hailuo`,O.generate(e,{token:t})).then(()=>{A.success(this.$t(`hailuo.message.startTaskSuccess`))}).catch(e=>{(e?.response?.data)?.error?.code===`used_up`?A.error(this.$t(`hailuo.message.usedUp`)):A.error(this.$t(`hailuo.message.startTaskFailed`))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function Ke(e,n,r,a,o,s){let c=u(`config-panel`),d=u(`recent-panel`),p=u(`layout`);return l(),t(p,null,{config:f(()=>[i(c,{onGenerate:e.onGenerate},null,8,[`onGenerate`])]),result:f(()=>[i(d,{ref:`recentPanel`,loading:e.loadingMore,onReachTop:e.onReachTop},null,8,[`loading`,`onReachTop`])]),_:1})}var qe=T(Ge,[[`render`,Ke]]);export{qe as default};