@acedatacloud/nexior 3.239.0 → 3.240.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (234) hide show
  1. package/dist/assets/{ApiCodeButton-9XDDLdNe.js → ApiCodeButton-Bu2nLY5J.js} +1 -1
  2. package/dist/assets/{Auth-E-skiK5V.js → Auth-MVXwbx0J.js} +1 -1
  3. package/dist/assets/{BotPlaceholder-Bm3iFf5b.js → BotPlaceholder-B5Bw1tlj.js} +1 -1
  4. package/dist/assets/{Callback-D_hR-iD4.js → Callback-CltrhgQA.js} +1 -1
  5. package/dist/assets/{Console-BM0YTLRm.js → Console-CgysLeM3.js} +1 -1
  6. package/dist/assets/{Consumption-Dvylkuyr.js → Consumption-BAwCyKhW.js} +1 -1
  7. package/dist/assets/{Conversation-BijKY7y4.js → Conversation-zDAXEQqo.js} +1 -1
  8. package/dist/assets/{CopyToClipboard-3JBcjf6f.js → CopyToClipboard-B1L4gFQs.js} +1 -1
  9. package/dist/assets/{Detail-lOm9PZvx.js → Detail-5n82dmr-.js} +2 -2
  10. package/dist/assets/{Extra-DPbHG9qK.js → Extra-BgGNwscr.js} +1 -1
  11. package/dist/assets/{FilePreview-DoguENGr.js → FilePreview-Hbma88Qo.js} +1 -1
  12. package/dist/assets/{Hailuo-DohJzCSN.js → Hailuo-CnUcHX2i.js} +1 -1
  13. package/dist/assets/{History-kX-OZwNZ.js → History-DGmfJiN5.js} +1 -1
  14. package/dist/assets/{ImagePreview-Deaq21aE.js → ImagePreview-BjgklCqN.js} +1 -1
  15. package/dist/assets/{ImageWrapper-DImeHzsC.js → ImageWrapper-Gdemv0z3.js} +1 -1
  16. package/dist/assets/{Index-DVis1sP7.js → Index-BBEtdH9l.js} +1 -1
  17. package/dist/assets/{Index-BgFaQOoo.js → Index-BOlGOuA5.js} +1 -1
  18. package/dist/assets/{Index-BhpyCXhO.js → Index-Beq58ww2.js} +1 -1
  19. package/dist/assets/{Index-BJ3_okcm.js → Index-BfKwv0eb.js} +1 -1
  20. package/dist/assets/{Index-DyAuRyZg.js → Index-Bk0gOn4W.js} +1 -1
  21. package/dist/assets/{Index-CVe_7DP8.js → Index-C71z7s6j.js} +1 -1
  22. package/dist/assets/{Index-DZ5j-DTs.js → Index-CDwIsBFd.js} +1 -1
  23. package/dist/assets/{Index-BFsNP2B_.js → Index-CJaf5_XG.js} +1 -1
  24. package/dist/assets/{Index-CyquPdM-.js → Index-Cbcjj-AY.js} +1 -1
  25. package/dist/assets/{Index-B0X6_nJH.js → Index-CiY_Y0jY.js} +1 -1
  26. package/dist/assets/{Index-DB8QWEcm.js → Index-Cl8Xxyup.js} +1 -1
  27. package/dist/assets/{Index-DNpl_Z74.js → Index-CspjrBOF.js} +1 -1
  28. package/dist/assets/{Index-CFroiTM4.js → Index-D12Yc04H.js} +1 -1
  29. package/dist/assets/{Index-DzFtGWLo.js → Index-D3YJWopQ.js} +1 -1
  30. package/dist/assets/{Index-Dwff1_YM.js → Index-D8LIm110.js} +1 -1
  31. package/dist/assets/{Index-wIEETVeb.js → Index-DD4INS9g.js} +1 -1
  32. package/dist/assets/{Index-C98LPYHA.js → Index-DUCq5f56.js} +1 -1
  33. package/dist/assets/{Index-D43f89Xf.js → Index-DVlwl58S.js} +1 -1
  34. package/dist/assets/{Index-CaeG-Ijb.js → Index-DenNaMxa.js} +1 -1
  35. package/dist/assets/{Index-B_XtH1-K.js → Index-DjJcHPVV.js} +1 -1
  36. package/dist/assets/{Index-Cj9nyhEQ.js → Index-DnC39l_Q.js} +1 -1
  37. package/dist/assets/{Index-DUbD0frI.js → Index-Drv2EbJI.js} +1 -1
  38. package/dist/assets/{Index-DnPgKumX.js → Index-MWSwaNZf.js} +1 -1
  39. package/dist/assets/{Index-BKYmZwGJ.js → Index-osgVGw2t.js} +1 -1
  40. package/dist/assets/{Index-BE7-MjC3.js → Index-tSbYt2id.js} +1 -1
  41. package/dist/assets/{Invitees-i5VbbrcY.js → Invitees-CQcBWZIM.js} +1 -1
  42. package/dist/assets/{List-CEZWNjFR.js → List-BLKUfRUt.js} +1 -1
  43. package/dist/assets/{List-Dbu3Ztki.js → List-BoO6cP4z.js} +1 -1
  44. package/dist/assets/{List-B4Dxou83.js → List-Cw4CkHUs.js} +1 -1
  45. package/dist/assets/{Main-fFwoQBAi.js → Main-DXsWIIt1.js} +1 -1
  46. package/dist/assets/{Model-C-KyaS22.js → Model-BLGUDfZz.js} +1 -1
  47. package/dist/assets/{Navigator-BaaMmQ4U.js → Navigator-D67RKX6g.js} +3 -3
  48. package/dist/assets/Navigator-Diw71MjW.css +1 -0
  49. package/dist/assets/{NoTasks-DYAWTz-D.js → NoTasks-DLn86jTC.js} +1 -1
  50. package/dist/assets/{NotFound-CDJbN_1S.js → NotFound-C5dv6Kjb.js} +1 -1
  51. package/dist/assets/{Pagination-DufV0sEu.js → Pagination-0_XLUd-n.js} +1 -1
  52. package/dist/assets/{Player.vue_vue_type_script_setup_true_lang-D3T5quDE.js → Player.vue_vue_type_script_setup_true_lang-CyZbXnZx.js} +1 -1
  53. package/dist/assets/{Status-C4IHxHJ1.js → Status-DjSNonyM.js} +1 -1
  54. package/dist/assets/{Subscribe-BGKhTstR.js → Subscribe-DYMDeoww.js} +1 -1
  55. package/dist/assets/{TabSwitcher-DW6ihcmN.js → TabSwitcher-BwEKX6yw.js} +1 -1
  56. package/dist/assets/{Tts-KOlK790E.js → Tts-DYyb20bL.js} +1 -1
  57. package/dist/assets/{VideoPlayer-Br2yW1lu.js → VideoPlayer-lNCFIvjW.js} +1 -1
  58. package/dist/assets/{_Uint8Array-CRC1hUw5.js → _Uint8Array-pGzioutB.js} +1 -1
  59. package/dist/assets/{_baseClone-BR0qWb-t.js → _baseClone-D8eUdaQd.js} +1 -1
  60. package/dist/assets/{_baseIteratee-BQgCC_-_.js → _baseIteratee-BCY-1IYO.js} +1 -1
  61. package/dist/assets/{_initCloneObject-EbmJQUEy.js → _initCloneObject-CAH0nDM3.js} +1 -1
  62. package/dist/assets/{add-CRpDp35U.js → add-4pP0Wiem.js} +1 -1
  63. package/dist/assets/{all-wallets-DwbobbEs.js → all-wallets-DQ1EnmWI.js} +1 -1
  64. package/dist/assets/{app-store-ips1Ck1n.js → app-store-CSbgMxFH.js} +1 -1
  65. package/dist/assets/{apple-DHC4UjwD.js → apple-ZwnWcRrl.js} +1 -1
  66. package/dist/assets/{arrow-bottom-BZFYAi_-.js → arrow-bottom-BVOOOKi7.js} +1 -1
  67. package/dist/assets/{arrow-bottom-circle-CQHF78JI.js → arrow-bottom-circle-BdURFSFJ.js} +1 -1
  68. package/dist/assets/{arrow-left-DxFsbLoi.js → arrow-left-qggBrx-R.js} +1 -1
  69. package/dist/assets/{arrow-right-Bvacre0J.js → arrow-right-BaxSKZcj.js} +1 -1
  70. package/dist/assets/{arrow-top-CGIfeznS.js → arrow-top-DNnWLjaS.js} +1 -1
  71. package/dist/assets/{avatar-DSBIeYLM.js → avatar-B0gMZK2R.js} +1 -1
  72. package/dist/assets/{bank-BhhhHBlx.js → bank-sp9vGgEp.js} +1 -1
  73. package/dist/assets/{basic-DqTjgomq.js → basic-D3qRqU9j.js} +1 -1
  74. package/dist/assets/{browser-Cq11PuHx.js → browser-BCMEImu1.js} +1 -1
  75. package/dist/assets/{byokCredential-CR_scd-V.js → byokCredential-CISXgUhK.js} +1 -1
  76. package/dist/assets/{card-CWT4zM8c.js → card-CE2GYV7m.js} +1 -1
  77. package/dist/assets/{castArray-D90oh5Za.js → castArray-CJ8hzGGj.js} +1 -1
  78. package/dist/assets/{chat-DovQA6qr.js → chat-B1OUDJRg.js} +1 -1
  79. package/dist/assets/{checkmark-G7hCMAuv.js → checkmark-_Fg66XcU.js} +1 -1
  80. package/dist/assets/{checkmark-bold-DRTmcfqk.js → checkmark-bold-CgYeIl0T.js} +1 -1
  81. package/dist/assets/{chevron-bottom-ZbJ3daPB.js → chevron-bottom-C_QL5-Bz.js} +1 -1
  82. package/dist/assets/{chevron-left-BffvOzR9.js → chevron-left-DilaVL0B.js} +1 -1
  83. package/dist/assets/{chevron-right-mhZNm2FM.js → chevron-right-BGrX1ToW.js} +1 -1
  84. package/dist/assets/{chevron-top-DaZAYyiN.js → chevron-top-wGqTBsfo.js} +1 -1
  85. package/dist/assets/{chrome-store-G4JXejzb.js → chrome-store-BQVIpUxR.js} +1 -1
  86. package/dist/assets/{clock-DWiCagKC.js → clock-B7zChjNC.js} +1 -1
  87. package/dist/assets/{close-iqkiQ-Hh.js → close-GEY-WIPu.js} +1 -1
  88. package/dist/assets/{coinPlaceholder-yVGymBZU.js → coinPlaceholder-tscoun_E.js} +1 -1
  89. package/dist/assets/{compass-DYe-Gp8w.js → compass-CZuq8FEk.js} +1 -1
  90. package/dist/assets/{copy-Crx05MoJ.js → copy-D6ICjkKl.js} +1 -1
  91. package/dist/assets/{createTaskActions-Q6UtPA9W.js → createTaskActions-BEjXSCHm.js} +1 -1
  92. package/dist/assets/{cursor-CtXPztuR.js → cursor-oFFjVoXL.js} +1 -1
  93. package/dist/assets/{cursor-transparent-CqD8yUua.js → cursor-transparent-zwVrQsY1.js} +1 -1
  94. package/dist/assets/{debounce-B16-iZx6.js → debounce-G93CFNE1.js} +1 -1
  95. package/dist/assets/{desktop-DjCmfA67.js → desktop-B4oyPaU_.js} +1 -1
  96. package/dist/assets/{disconnect-2kt93r5t.js → disconnect-KiTBpX_6.js} +1 -1
  97. package/dist/assets/{discord-BXh9KuOQ.js → discord-BLxijDdw.js} +1 -1
  98. package/dist/assets/{distribution-BqdaQ6Cl.js → distribution-ClawWswB.js} +1 -1
  99. package/dist/assets/{dropdown-D9V39-fe.js → dropdown-wn8wa-_S.js} +1 -1
  100. package/dist/assets/{etherscan-6mn_a0iV.js → etherscan-CE2F8Xw6.js} +1 -1
  101. package/dist/assets/{exclamation-triangle-BNZ7Y0y8.js → exclamation-triangle-BzziKWnK.js} +1 -1
  102. package/dist/assets/{extension-Ctbyh_V5.js → extension-lB-sxIFk.js} +1 -1
  103. package/dist/assets/{external-link-CNs_rVuZ.js → external-link-DeSW97tD.js} +1 -1
  104. package/dist/assets/{facebook-CEapcw-R.js → facebook-ClFpcvFA.js} +1 -1
  105. package/dist/assets/{farcaster-Dh8WXaVA.js → farcaster-C4s006nq.js} +1 -1
  106. package/dist/assets/{filters-BA2TDn92.js → filters-2lTgPbw7.js} +1 -1
  107. package/dist/assets/{github-PKGGE05y.js → github-DPor1lTC.js} +1 -1
  108. package/dist/assets/{google-DraeeoL7.js → google-Cbtzzd6i.js} +1 -1
  109. package/dist/assets/{help-circle-BuYisFM2.js → help-circle-Bplzn7yC.js} +1 -1
  110. package/dist/assets/{highlight-DEv6Uzjh.js → highlight-DsFwBu4N.js} +1 -1
  111. package/dist/assets/{id-BCZIyTBk.js → id-DUTTATgR.js} +1 -1
  112. package/dist/assets/{image-DxhDw2vp.js → image-CABCG5CT.js} +1 -1
  113. package/dist/assets/{index-DYQToXUU.js → index-1WxaVCeu.js} +1 -1
  114. package/dist/assets/{index-B8P1W9Dy.js → index-4sXDQxR4.js} +1 -1
  115. package/dist/assets/{index-DI25owPX.js → index-5d8gk-Z2.js} +1 -1
  116. package/dist/assets/{index-CBCFXmR4.js → index-B1wXO9Vt.js} +1 -1
  117. package/dist/assets/{index-D7zJSPd1.js → index-B2RWgAXh.js} +1 -1
  118. package/dist/assets/{index-BBhODJQx.js → index-B3_om4ZB.js} +1 -1
  119. package/dist/assets/{index-D7f1sAJb.js → index-B7qOoyCR.js} +1 -1
  120. package/dist/assets/{index-C0zx3uvU.js → index-BCum0A0B.js} +1 -1
  121. package/dist/assets/{index-Cy8wLIr0.js → index-BDNA2DMu.js} +1 -1
  122. package/dist/assets/{index-CuQoKX2f.js → index-BEpptA5S.js} +1 -1
  123. package/dist/assets/{index-Bi53K4Mi.js → index-BFKyqrk3.js} +1 -1
  124. package/dist/assets/{index-Bo7zkVzy.js → index-BI3c17YF.js} +1 -1
  125. package/dist/assets/{index-BHVQW8Q2.js → index-BJr3r4qN.js} +1 -1
  126. package/dist/assets/{index-C9-0VnKI.js → index-BKPqbe4l.js} +1 -1
  127. package/dist/assets/{index-BFUf5YVt.js → index-BYnYd0I7.js} +1 -1
  128. package/dist/assets/{index-BiKbOqit.js → index-BZ650ta7.js} +5 -5
  129. package/dist/assets/{index-CAnSJQ4u.js → index-BfmYQvxy.js} +1 -1
  130. package/dist/assets/{index-C_zWcuAN.js → index-BgYoXjG3.js} +1 -1
  131. package/dist/assets/{index-PLhHdafx.js → index-Bn4CF14q.js} +1 -1
  132. package/dist/assets/{index-CRROw2v3.js → index-BnUjW8_R.js} +1 -1
  133. package/dist/assets/{index-BVwAPJvQ.js → index-BoAkyNNY.js} +1 -1
  134. package/dist/assets/{index-_-FKmUiC.js → index-Bq9eVEdU.js} +1 -1
  135. package/dist/assets/{index-8HF8bAn8.js → index-Br5-UL2X.js} +1 -1
  136. package/dist/assets/{index-DY9n5RWp.js → index-Buukpn8o.js} +1 -1
  137. package/dist/assets/{index-BV4fHzx-.js → index-BvlOxujk.js} +1 -1
  138. package/dist/assets/{index-D95HBrhl.js → index-C9krDm9Y.js} +1 -1
  139. package/dist/assets/{index-XLYMNUFJ.js → index-CLIkNw25.js} +1 -1
  140. package/dist/assets/{index-CCeJfLsu.js → index-CNnBDoa1.js} +1 -1
  141. package/dist/assets/{index-D21QqIXk.js → index-CQsdLZkK.js} +1 -1
  142. package/dist/assets/{index-BkchfnNA.js → index-CXgPGdvu.js} +1 -1
  143. package/dist/assets/{index-osOxmKEr.js → index-CdgbI3Pp.js} +1 -1
  144. package/dist/assets/{index-DldYJWMF.js → index-CfjhTpXV.js} +1 -1
  145. package/dist/assets/{index-DqD-0Cn7.js → index-CgqZ4RXB.js} +1 -1
  146. package/dist/assets/{index-DcCp2-Ex.js → index-CkucVuT-.js} +1 -1
  147. package/dist/assets/{index-DQ7HmFtn.js → index-Co8QBZNt.js} +1 -1
  148. package/dist/assets/{index-Ccy80B9i.js → index-Cp55c10D.js} +1 -1
  149. package/dist/assets/{index-D_TaRFAX.js → index-Cso_L9kT.js} +1 -1
  150. package/dist/assets/{index-BLH93c1h.js → index-Cvc-YkZx.js} +1 -1
  151. package/dist/assets/{index-DJQOztFq.js → index-CxBaRfj2.js} +1 -1
  152. package/dist/assets/{index-C41gSxyw.js → index-D2fLbQOU.js} +1 -1
  153. package/dist/assets/{index-CXGm2ibp.js → index-D7cRCqFS.js} +1 -1
  154. package/dist/assets/{index-D0beq2Y9.js → index-D8fRcnkf.js} +3 -3
  155. package/dist/assets/{index-BtRIGKkx.js → index-DGIx57wo.js} +1 -1
  156. package/dist/assets/{index-CFtFSkRX.js → index-DHPT8S22.js} +1 -1
  157. package/dist/assets/{index-CgwDba1C.js → index-DPxpocQo.js} +1 -1
  158. package/dist/assets/{index-DMuir5Ca.js → index-DSFt02oT.js} +1 -1
  159. package/dist/assets/{index-IEnCZwtg.js → index-DWWSYHUH.js} +1 -1
  160. package/dist/assets/{index-BtCpCAYM.js → index-DcO0RpyY.js} +1 -1
  161. package/dist/assets/{index-CbNmLSFW.js → index-DgjpEM3x.js} +1 -1
  162. package/dist/assets/{index-CVCfk6pt.js → index-DkLXeCmb.js} +1 -1
  163. package/dist/assets/{index-BAWUkbI3.js → index-Dp_Mn_DN.js} +1 -1
  164. package/dist/assets/{index-CfpZLGo7.js → index-Dy4hgCya.js} +1 -1
  165. package/dist/assets/{index-DDg_ne2W.js → index-IIu99qEL.js} +1 -1
  166. package/dist/assets/{index-BKgRYY8E.js → index-KTS__Qmb.js} +1 -1
  167. package/dist/assets/{index-Bz9B1sA_.js → index-OunnXcRy.js} +1 -1
  168. package/dist/assets/{index-CrqbAkrw.js → index-RM1Yx2Zt.js} +1 -1
  169. package/dist/assets/{index-cn5_DmaE.js → index-WPH6eO9g.js} +1 -1
  170. package/dist/assets/{index-DayNhmqV.js → index-_0hbL4Kz.js} +1 -1
  171. package/dist/assets/{index-TqGfcTRI.js → index-f5KBtxLP.js} +1 -1
  172. package/dist/assets/{index-BitdtvW1.js → index-kok2V6cj.js} +3 -3
  173. package/dist/assets/{index-BjbmY8Qg.js → index-qnMPi-5D.js} +1 -1
  174. package/dist/assets/{index-Cco9hRL2.js → index-sRDCM6JU.js} +2 -2
  175. package/dist/assets/{index-B5zfRlKe.js → index-yNToY-SP.js} +1 -1
  176. package/dist/assets/{index.browser.esm-BpmaOdhL.js → index.browser.esm-7IocQhpc.js} +1 -1
  177. package/dist/assets/{index.es-fM0biscR.js → index.es-UMFIHXWc.js} +1 -1
  178. package/dist/assets/{info-DrWk6vRi.js → info-CKDUbxoF.js} +1 -1
  179. package/dist/assets/{info-circle-02zOJVKW.js → info-circle-B_kyIlbw.js} +1 -1
  180. package/dist/assets/{isEqual-CMrgrIDS.js → isEqual-DBGyFRF0.js} +1 -1
  181. package/dist/assets/{isPlainObject-C8UsK3_R.js → isPlainObject-BffmECLj.js} +1 -1
  182. package/dist/assets/{lightbulb-Dcnqg3zI.js → lightbulb-r-LyxXzT.js} +1 -1
  183. package/dist/assets/{mail-C8sqp_v6.js → mail-Cmi_B5ib.js} +1 -1
  184. package/dist/assets/{midjourney-BHGRMonG.js → midjourney-CpAIejbT.js} +1 -1
  185. package/dist/assets/{mobile-cH01pbv1.js → mobile-CtV2VqE7.js} +1 -1
  186. package/dist/assets/{more-BYMndHQe.js → more-D6K0huEn.js} +1 -1
  187. package/dist/assets/{network-placeholder-QWwr0dl-.js → network-placeholder-CZilKAko.js} +1 -1
  188. package/dist/assets/{nftPlaceholder-DoAK6JHj.js → nftPlaceholder-BQzwKTsV.js} +1 -1
  189. package/dist/assets/{off-DU4onOnU.js → off-B6pZ8DjL.js} +1 -1
  190. package/dist/assets/{order-DmJO74Fs.js → order-D5tnFLUF.js} +1 -1
  191. package/dist/assets/{pagination-CDMeT271.js → pagination-EsDrj3yC.js} +1 -1
  192. package/dist/assets/{play-store-DFZUhS6Y.js → play-store-BCTckm04.js} +1 -1
  193. package/dist/assets/{plus-C2zrXi7v.js → plus-mdaUsXl5.js} +1 -1
  194. package/dist/assets/{price-UzqaC8kS.js → price-Beya5kld.js} +1 -1
  195. package/dist/assets/{producer-CwYheP8p.js → producer-rWlmBf6r.js} +1 -1
  196. package/dist/assets/{qr-code-dngEl-ZK.js → qr-code-D8Sjqh8L.js} +1 -1
  197. package/dist/assets/{recycle-horizontal-B4wowDGK.js → recycle-horizontal-CPLHRf4o.js} +1 -1
  198. package/dist/assets/{refresh-C6LEL-5a.js → refresh-jKwy0GpU.js} +1 -1
  199. package/dist/assets/{reown-logo-DtQhfal2.js → reown-logo-CPPULql9.js} +1 -1
  200. package/dist/assets/{search-Sm0vDUH5.js → search-1eSZhp20.js} +1 -1
  201. package/dist/assets/{secp256k1-BelJbK0s.js → secp256k1-B_FLw2WH.js} +1 -1
  202. package/dist/assets/{secp256k1-mIpi5NB9.js → secp256k1-BsXGtyEK.js} +1 -1
  203. package/dist/assets/{seedream-CmLyPhZ0.js → seedream-jD5w8Wkn.js} +1 -1
  204. package/dist/assets/{send-DQbdEfeX.js → send-B3yYwiO-.js} +1 -1
  205. package/dist/assets/{service-Cth1lVB8.js → service-6pzgrgNR.js} +1 -1
  206. package/dist/assets/{solana-wallets-BAy2-eoa.js → solana-wallets-B8mQpYIR.js} +2 -2
  207. package/dist/assets/{solana-wallets-vue-FjQ7t8jk.js → solana-wallets-vue-OMit6gDf.js} +1 -1
  208. package/dist/assets/{suno-VCUQZZa7.js → suno-DSUwKnh3.js} +1 -1
  209. package/dist/assets/{swapHorizontal-Cs5ExypK.js → swapHorizontal-Br-5wqY-.js} +1 -1
  210. package/dist/assets/{swapHorizontalBold-BYj0sSJS.js → swapHorizontalBold-DuCN4UcO.js} +1 -1
  211. package/dist/assets/{swapHorizontalMedium-BkkxkNRJ.js → swapHorizontalMedium-zV1oXq_b.js} +1 -1
  212. package/dist/assets/{swapHorizontalRoundedBold-CzBCoABO.js → swapHorizontalRoundedBold-DDrEgAhO.js} +1 -1
  213. package/dist/assets/{swapVertical-CWFkNqay.js → swapVertical-y0KV1QQR.js} +1 -1
  214. package/dist/assets/{telegram-CP9ruRz3.js → telegram-mND4CsPI.js} +1 -1
  215. package/dist/assets/{three-dots-DPEF_pkB.js → three-dots-HzdB6sGq.js} +1 -1
  216. package/dist/assets/{twitch-Dom0AiOG.js → twitch-0478BEgU.js} +1 -1
  217. package/dist/assets/{twitterIcon-BADqc1Z8.js → twitterIcon-D0Pr83ih.js} +1 -1
  218. package/dist/assets/{typescript-CdFsS8fD.js → typescript-CfmcPqGh.js} +1 -1
  219. package/dist/assets/{use-form-item-CaXGkw6S.js → use-form-item-CYiJWVVo.js} +1 -1
  220. package/dist/assets/validator-7URr4p3I.js +1 -0
  221. package/dist/assets/{verify-Dwwr_ytZ.js → verify-QazBPVGr.js} +1 -1
  222. package/dist/assets/{verify-filled-JqqsjM4k.js → verify-filled-DFzSdAuk.js} +1 -1
  223. package/dist/assets/{w3m-modal-CDncFu_i.js → w3m-modal-BQ0hIRJA.js} +1 -1
  224. package/dist/assets/{wallet-BbYj1sn_.js → wallet-DMP1k3cH.js} +1 -1
  225. package/dist/assets/{wallet-placeholder-C2ScyMjR.js → wallet-placeholder-B3gN0g8z.js} +1 -1
  226. package/dist/assets/{walletconnect-B2A33q08.js → walletconnect-Dl5PB53v.js} +1 -1
  227. package/dist/assets/{warning-circle-Dvs9YTFd.js → warning-circle-DwJzRCqK.js} +1 -1
  228. package/dist/assets/{web-DTuJ35Tx.js → web-CTaJ2ntq.js} +1 -1
  229. package/dist/assets/{web-DnbaFvS2.js → web-Cw04riuO.js} +1 -1
  230. package/dist/assets/{x-DH3hIXRZ.js → x-BejnjBsB.js} +1 -1
  231. package/dist/index.html +1 -1
  232. package/package.json +1 -1
  233. package/dist/assets/Navigator-DyXS7zmI.css +0 -1
  234. package/dist/assets/validator-BIWRmSMB.js +0 -1
@@ -1 +1 @@
1
- import{F as S}from"./index.es-fM0biscR.js";import{E as q}from"./index-CXGm2ibp.js";import{E as K}from"./index-DYQToXUU.js";import{d as y,H as l,E as u,z as O,C as a,y as b,D as s,q as n,x as k,F as o,I as c,O as N,N as R,J as f,M as H,Q as U}from"./vendor-vue-NSDaktjZ.js";import{H as w,bp as J,cR as Q,cS as W,cT as P,cU as X,cV as I,cW as j,cX as D,cY as F,cs as Y,aW as Z,S as x,ct as ee}from"./index-BitdtvW1.js";import{P as te,N as ae}from"./NoTasks-DYAWTz-D.js";import{p as oe}from"./pasteUploadMixin-BurWbGNQ.js";import{u as ne,a as se,e as le}from"./uploadTrackerMixin--N-yU8Tl.js";import{I as B,S as re,l as ie}from"./pagination-CDMeT271.js";import{I as z}from"./ImagePreview-Deaq21aE.js";import{E as ce}from"./index-B5zfRlKe.js";import{E}from"./index-DY9n5RWp.js";import{E as M,a as G}from"./index-CVCfk6pt.js";import{C as ue}from"./Consumption-Dvylkuyr.js";import{a as me}from"./price-UzqaC8kS.js";import{b as de}from"./errorCode-Cqj9Td_Z.js";import{C as pe}from"./CopyToClipboard-3JBcjf6f.js";import{I as fe}from"./ImageWrapper-DImeHzsC.js";import{A as he}from"./ApiCodeButton-9XDDLdNe.js";import{E as _e}from"./index-CRROw2v3.js";import{E as ge}from"./index-XLYMNUFJ.js";import{E as be}from"./index-BkchfnNA.js";import{B as $e}from"./BotPlaceholder-Bm3iFf5b.js";import"./use-form-item-CaXGkw6S.js";import"./index-BuyEbX8F.js";import"./vendor-axios-B8_nURbH.js";import"./vendor-dayjs-v0j1UNZp.js";import"./vendor-vue-router-Df5ITouH.js";import"./index-cn5_DmaE.js";import"./typescript-CdFsS8fD.js";import"./index-BKgRYY8E.js";import"./index-IEnCZwtg.js";import"./highlight-DEv6Uzjh.js";import"./index-BLjywj98.js";import"./vendor-highlight-lEWW1Jxd.js";import"./index-CCeJfLsu.js";import"./_baseClone-BR0qWb-t.js";import"./_Uint8Array-CRC1hUw5.js";import"./_initCloneObject-EbmJQUEy.js";import"./isEqual-CMrgrIDS.js";import"./index-BFUf5YVt.js";import"./strings-beZM2Y-f.js";import"./castArray-D90oh5Za.js";import"./debounce-B16-iZx6.js";import"./_baseIteratee-BQgCC_-_.js";import"./index-Bo7zkVzy.js";import"./index-BHVQW8Q2.js";const ve=y({name:"LayoutNanobanana",components:{ElDrawer:K,ElButton:q,FontAwesomeIcon:S},data(){return{drawer:!1}}}),ke={class:"main flex flex-row flex-1"},ye={class:"config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]"},we={class:"result h-full p-6 flex-1 flex flex-col min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]"};function Ve(e,t,$,r,d,h){const _=s("font-awesome-icon"),g=s("el-button"),p=s("el-drawer");return n(),l("div",ke,[u("div",ye,[O(e.$slots,"config",{},void 0,!0)]),u("div",we,[O(e.$slots,"result",{},void 0,!0)]),a(g,{circle:"",class:"menu",onClick:t[0]||(t[0]=m=>e.drawer=!0)},{default:b(()=>[a(_,{icon:"fa-solid fa-magic"})]),_:1}),a(p,{modelValue:e.drawer,"onUpdate:modelValue":t[1]||(t[1]=m=>e.drawer=m),direction:"ltr","with-header":!1,size:"340px",class:"drawer"},{default:b(()=>[O(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const Ae=w(ve,[["render",Ve],["__scopeId","data-v-8ca1c212"]]),Ne="",Ee=y({name:"PromptInput",components:{PromptTextarea:te},computed:{prompt:{get(){return this.$store.state.nanobanana?.config?.prompt},set(e){this.$store.commit("nanobanana/setConfig",{...this.$store.state.nanobanana?.config,prompt:e})}}},mounted(){this.prompt||(this.prompt=Ne)}});function Re(e,t,$,r,d,h){const _=s("prompt-textarea");return n(),k(_,{modelValue:e.prompt,"onUpdate:modelValue":t[0]||(t[0]=g=>e.prompt=g),title:e.$t("nanobanana.name.prompt"),info:e.$t("nanobanana.description.prompt"),placeholder:e.$t("nanobanana.placeholder.prompt")},null,8,["modelValue","title","info","placeholder"])}const Le=w(Ee,[["render",Re]]),Te=y({name:"ImageUrlsInput",components:{ElUpload:ce,ElButton:q,InfoIcon:B,ImagePreview:z,FontAwesomeIcon:S},mixins:[oe,ne],data(){return{fileList:[],uploadUrl:J()+"/api/v1/files/",suppressWatch:!1}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e?.response?.file_url).filter(e=>!!e)},value(){return this.$store.state.nanobanana?.config?.image_urls}},watch:{value:{immediate:!0,handler(e){if(this.suppressWatch)return;if(!e||e.length===0){const r=(this.fileList||[]).filter(d=>!d?.response?.file_url);this.fileList=r.length?r:[];return}const t=[];e.forEach(r=>{const d=this.fileList.find(h=>h?.response?.file_url===r||h?.url===r);d?t.push(d):t.push({name:r.split("/").pop()||r,url:r,status:"success",percentage:100,response:{file_url:r}})}),(this.fileList||[]).filter(r=>!r?.response?.file_url).forEach(r=>{t.some(h=>h===r||h?.url===r?.url||h?.response?.file_url===r?.response?.file_url)||t.push(r)}),this.fileList=t}}},mounted(){},methods:{onChange(e){if(!e?.url&&e?.raw)try{e.url=URL.createObjectURL(e.raw)}catch{}},onRemove(e){if(e?.url&&typeof e.url=="string"&&e.url.startsWith("blob:"))try{URL.revokeObjectURL(e.url)}catch{}this.onSetImageUrls()},onExceed(){E.warning(this.$t("nanobanana.message.uploadImageExceed"))},onError(){E.error(this.$t("nanobanana.message.uploadImageError"))},onSetImageUrls(){const e=this.urls;this.suppressWatch=!0,this.$store.commit("nanobanana/setConfig",{...this.$store.state.nanobanana?.config,image_urls:e}),this.$nextTick(()=>{this.suppressWatch=!1})},async onSuccess(e,t){e?.file_url&&(t.url=e.file_url,t.response=e),this.onSetImageUrls()},onRemovePreview(e,t){if(this.fileList.splice(e,1),t?.url&&typeof t.url=="string"&&t.url.startsWith("blob:"))try{URL.revokeObjectURL(t.url)}catch{}this.onSetImageUrls()}}}),Ie={class:"field flex items-center justify-between"},Se={class:"title font-bold text-[14px] mb-[10px]"},qe={class:"upload-wrapper flex flex-col items-start gap-[8px]"},Ue={class:"controls flex items-center"},Ce={class:"file-list flex flex-wrap gap-[10px]"};function Oe(e,t,$,r,d,h){const _=s("font-awesome-icon"),g=s("el-button"),p=s("el-upload"),m=s("info-icon"),V=s("image-preview");return n(),l(N,null,[u("div",Ie,[u("h2",Se,o(e.$t("nanobanana.name.imageUrls")),1),u("div",qe,[u("div",Ue,[a(p,{ref:"uploader","file-list":e.fileList,"onUpdate:fileList":t[0]||(t[0]=v=>e.fileList=v),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:b(()=>[a(g,{size:"small",type:"primary",round:""},{default:b(()=>[a(_,{icon:"fa-solid fa-upload",class:"mr-1"}),c(" "+o(e.$t("nanobanana.button.uploadImageUrls")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-success","on-change","on-remove","headers"]),a(m,{content:e.$t("nanobanana.description.imageUrls"),class:"ml-2"},null,8,["content"])])])]),u("div",Ce,[(n(!0),l(N,null,R(e.fileList,(v,i)=>(n(),k(V,{key:v.uid||v?.response?.file_url||v.url||i,url:v.url||v?.response?.file_url,name:v.name,percentage:v.percentage,onRemove:A=>e.onRemovePreview(i,v)},null,8,["url","name","percentage","onRemove"]))),128))])],64)}const Pe=w(Te,[["render",Oe]]),Be=y({name:"AspectRatioSelector",components:{ElSelect:G,ElOption:M},data(){return{options:["1:1","3:2","2:3","16:9","9:16","4:3","3:4"]}},computed:{value:{get(){return this.$store.state.nanobanana?.config?.aspect_ratio},set(e){console.debug("set aspect_ratio",e);const t={...this.$store.state.nanobanana?.config||{}};e?t.aspect_ratio=e:delete t.aspect_ratio,this.$store.commit("nanobanana/setConfig",t)}}}}),Me={class:"field"},Ge={class:"title font-bold"};function je(e,t,$,r,d,h){const _=s("el-option"),g=s("el-select");return n(),l("div",Me,[u("h2",Ge,o(e.$t("nanobanana.name.aspectRatio")),1),a(g,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=p=>e.value=p),class:"value",clearable:"",placeholder:e.$t("nanobanana.placeholder.select")},{default:b(()=>[(n(!0),l(N,null,R(e.options,p=>(n(),k(_,{key:p,label:p,value:p},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const De=w(Be,[["render",je],["__scopeId","data-v-67f08a08"]]),Fe=y({name:"NanobananaModelSelector",components:{ElSelect:G,ElOption:M,InfoIcon:B},data(){return{options:[{value:W,label:this.$t("nanobanana.model.nanoBanana")},{value:P,label:this.$t("nanobanana.model.nanoBananaPro")},{value:X,label:this.$t("nanobanana.model.nanoBanana2")}]}},computed:{value:{get(){return this.$store.state.nanobanana?.config?.model},set(e){this.$store.commit("nanobanana/setConfig",{...this.$store.state.nanobanana?.config,model:e})}},modelDescription(){return this.$t("nanobanana.description.model")}},mounted(){this.value||(this.value=Q)}}),xe={class:"field"},We={class:"label"},ze={class:"box"},Ke={class:"title font-bold"};function He(e,t,$,r,d,h){const _=s("info-icon"),g=s("el-option"),p=s("el-select");return n(),l("div",xe,[u("div",We,[u("div",ze,[u("h2",Ke,o(e.$t("nanobanana.name.model")),1),a(_,{content:e.modelDescription,class:"info"},null,8,["content"])])]),a(p,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=m=>e.value=m),class:"value",placeholder:e.$t("nanobanana.placeholder.select")},{default:b(()=>[(n(!0),l(N,null,R(e.options,m=>(n(),k(g,{key:m.value,label:m.label,value:m.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Je=w(Fe,[["render",He],["__scopeId","data-v-94304d73"]]),Qe=y({name:"NanobananaResolutionSelector",components:{ElSelect:G,ElOption:M,InfoIcon:B},data(){return{cachedResolution:I,options:[{value:j,label:j},{value:D,label:D},{value:F,label:F}]}},computed:{value:{get(){return this.$store.state.nanobanana?.config?.resolution},set(e){this.$store.commit("nanobanana/setConfig",{...this.$store.state.nanobanana?.config,resolution:e})}},isProModel(){return this.$store.state.nanobanana?.config?.model!==W}},watch:{value(e){this.isProModel&&e&&(this.cachedResolution=e)},isProModel(e){e?this.value||(this.value=this.cachedResolution||I):(this.value&&(this.cachedResolution=this.value),this.$store.commit("nanobanana/setConfig",{...this.$store.state.nanobanana?.config,resolution:void 0}))}},mounted(){this.isProModel&&!this.value&&(this.value=I),!this.isProModel&&this.value&&(this.cachedResolution=this.value,this.$store.commit("nanobanana/setConfig",{...this.$store.state.nanobanana?.config,resolution:void 0}))}}),Xe={class:"field"},Ye={class:"label"},Ze={class:"box"},et={class:"title font-bold"};function tt(e,t,$,r,d,h){const _=s("info-icon"),g=s("el-option"),p=s("el-select");return n(),l("div",Xe,[u("div",Ye,[u("div",Ze,[u("h2",et,o(e.$t("nanobanana.name.resolution")),1),a(_,{content:e.$t("nanobanana.description.resolutionProOnly"),class:"info"},null,8,["content"])])]),a(p,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=m=>e.value=m),class:"value",placeholder:e.$t("nanobanana.placeholder.select"),disabled:!e.isProModel},{default:b(()=>[(n(!0),l(N,null,R(e.options,m=>(n(),k(g,{key:m.value,label:m.label,value:m.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder","disabled"])])}const at=w(Qe,[["render",tt],["__scopeId","data-v-fd5ab393"]]),ot=y({name:"ConfigPanel",components:{ElButton:q,FontAwesomeIcon:S,PromptInput:Le,Consumption:ue,ImageUrlsInput:Pe,AspectRatioSelector:De,ModelSelector:Je,ResolutionSelector:at},emits:["generate"],computed:{config(){return this.$store.state.nanobanana?.config},consumption(){const e={...this.config||{}},t=Array.isArray(e?.image_urls)&&e.image_urls.length>0;return me({...e,action:t?"edit":"generate"},this.service?.cost)},service(){return this.$store.state.nanobanana?.service}},methods:{onGenerate(){this.$emit("generate")}}}),nt={class:"flex flex-col h-full"},st={class:"flex-1 overflow-y-auto p-5"},lt={class:"flex flex-col items-center justify-center px-5 pb-5"};function rt(e,t,$,r,d,h){const _=s("model-selector"),g=s("resolution-selector"),p=s("prompt-input"),m=s("aspect-ratio-selector"),V=s("image-urls-input"),v=s("consumption"),i=s("font-awesome-icon"),A=s("el-button");return n(),l("div",nt,[u("div",st,[a(_,{class:"mb-4"}),a(g,{class:"mb-4"}),a(p,{class:"mb-4"}),a(m,{class:"mb-4"}),a(V,{class:"mb-4"})]),u("div",lt,[a(v,{value:e.consumption,service:e.service},null,8,["value","service"]),a(A,{type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:b(()=>[a(i,{icon:"fa-solid fa-magic",class:"mr-2"}),c(" "+o(e.$t("nanobanana.button.generate")),1)]),_:1},8,["onClick"])])])}const it=w(ot,[["render",rt]]),ct=y({name:"TaskPreview",components:{ElImage:be,CopyToClipboard:pe,FontAwesomeIcon:S,ElAlert:ge,ImageWrapper:fe,ElButton:q,ElTooltip:_e,ImagePreview:z,ApiCodeButton:he},props:{modelValue:{type:Object,required:!0}},computed:{images(){const e=[];return Array.isArray(this.modelValue?.response?.data)&&this.modelValue?.response?.data?.forEach(t=>{e.push(t)}),e}},methods:{onEdit(e){if(!e)return;console.debug("Edit image:",e);const t={...this.$store.state.nanobanana?.config||{}};delete t.action,t.image_urls=[e],this.$store.commit("nanobanana/setConfig",t)}}}),ut={class:"preview"},mt={class:"left"},dt={class:"main"},pt={class:"bot"},ft={class:"datetime"},ht={class:"info"},_t={key:0,class:"flex justify-start items-center gap-2 mt-2 w-full overflow-x-auto"},gt={key:1,class:"prompt mt-2"},bt={key:0},$t={key:0,class:U({content:!0,failed:!0})},vt={class:"flex justify-start items-center gap-4 w-full overflow-x-auto"},kt={class:U({operations:!0,"mt-2":!0,"mb-2":!0})},yt={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},wt={key:1,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Vt={key:2,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},At={key:3,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Nt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Et={key:4,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Rt={key:5,class:"text-[var(--el-text-color-regular)] text-xs mb-0"},Lt={key:1,class:U({content:!0})},Tt={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},It={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"},qt={key:3,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Ut={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Ct={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Ot={key:4,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Pt={key:5,class:"text-[var(--el-text-color-regular)] text-xs mb-0"},Bt={key:2,class:U({content:!0})},Mt={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Gt={key:1,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},jt={key:2,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Dt={key:3,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Ft={class:"text-[var(--el-text-color-regular)] text-xs mb-2"};function xt(e,t,$,r,d,h){const _=s("el-image"),g=s("image-preview"),p=s("image-wrapper"),m=s("el-button"),V=s("el-tooltip"),v=s("api-code-button"),i=s("font-awesome-icon"),A=s("copy-to-clipboard"),C=s("el-alert");return n(),l("div",ut,[u("div",mt,[a(_,{src:"https://cdn.acedata.cloud/859plc.jpg",class:"avatar"})]),u("div",dt,[u("div",pt,[c(o(e.$t("nanobanana.name.nanobananaBot"))+" ",1),u("span",ft,o(e.$dayjs.format(""+new Date(parseFloat((e.modelValue?.created_at||"").toString())*1e3))),1)]),u("div",ht,[e.modelValue?.request?.image_urls&&e.modelValue?.request?.image_urls.length>0?(n(),l("div",_t,[(n(!0),l(N,null,R(e.modelValue?.request?.image_urls,(L,T)=>(n(),k(g,{key:T,url:L,name:`image-${T+1}`,closable:!1},null,8,["url","name"]))),128))])):f("",!0),e.modelValue?.request?.prompt?(n(),l("p",gt,[c(o(e.modelValue?.request?.prompt)+" ",1),e.modelValue?.response?f("",!0):(n(),l("span",bt," - ("+o(e.$t("nanobanana.status.pending"))+") ",1))])):f("",!0)]),e.modelValue?.response?.success===!0?(n(),l("div",$t,[u("div",vt,[(n(!0),l(N,null,R(e.images,(L,T)=>(n(),k(p,{key:T,src:L?.image_url,"raw-src":L?.image_url},null,8,["src","raw-src"]))),128))]),u("div",kt,[a(V,{class:"box-item",effect:"dark",content:e.$t("common.button.edit"),placement:"top-start"},{default:b(()=>[a(m,{type:"info",size:"small",class:"btn-action",onClick:t[0]||(t[0]=H(L=>e.onEdit(e.images?.[0]?.image_url),["stop"]))},{default:b(()=>[c(o(e.$t("common.button.edit")),1)]),_:1})]),_:1},8,["content"]),a(v,{path:"/nano-banana/images",body:e.modelValue?.request},null,8,["body"])]),a(C,{closable:!1,class:"mt-2 success"},{default:b(()=>[e.modelValue?.request?.model?(n(),l("p",yt,[a(i,{icon:"fa-solid fa-cube",class:"mr-1"}),c(" "+o(e.$t("nanobanana.name.model"))+": "+o(e.modelValue?.request?.model),1)])):f("",!0),e.modelValue?.request?.resolution?(n(),l("p",wt,[a(i,{icon:"fa-solid fa-image",class:"mr-1"}),c(" "+o(e.$t("nanobanana.name.resolution"))+": "+o(e.modelValue?.request?.resolution),1)])):f("",!0),e.modelValue?.request?.aspect_ratio?(n(),l("p",Vt,[a(i,{icon:"fa-solid fa-up-right-from-square",class:"mr-1"}),c(" "+o(e.$t("nanobanana.name.aspectRatio"))+": "+o(e.modelValue?.request?.aspect_ratio),1)])):f("",!0),e.modelValue?.request?.action?(n(),l("p",At,[a(i,{icon:"fa-solid fa-bolt",class:"mr-1"}),c(" "+o(e.$t("nanobanana.name.task"))+": "+o(e.modelValue?.request?.action==="generate"?e.$t("nanobanana.name.generate"):e.$t("nanobanana.name.edits")),1)])):f("",!0),u("p",Nt,[a(i,{icon:"fa-solid fa-magic",class:"mr-1"}),c(" "+o(e.$t("nanobanana.name.taskId"))+": "+o(e.modelValue?.id)+" ",1),a(A,{content:e.modelValue?.id,class:"btn-copy inline-block"},null,8,["content"])]),e.modelValue?.elapsed?(n(),l("p",Et,[a(i,{icon:"fa-solid fa-clock",class:"mr-1"}),c(" "+o(e.$t("nanobanana.name.elapsed"))+": "+o(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):f("",!0),e.modelValue?.response?.trace_id?(n(),l("p",Rt,[a(i,{icon:"fa-solid fa-hashtag",class:"mr-1"}),c(" "+o(e.$t("nanobanana.name.traceId"))+": "+o(e.modelValue?.response?.trace_id)+" ",1),a(A,{content:e.modelValue?.response?.trace_id,class:"btn-copy inline-block"},null,8,["content"])])):f("",!0)]),_:1})])):e.modelValue?.response?.success===!1?(n(),l("div",Lt,[a(C,{closable:!1,class:"failure"},{template:b(()=>[a(i,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),c(" "+o(e.$t("nanobanana.name.failure")),1)]),default:b(()=>[e.modelValue?.request?.model?(n(),l("p",Tt,[a(i,{icon:"fa-solid fa-cube",class:"mr-1"}),c(" "+o(e.$t("nanobanana.name.model"))+": "+o(e.modelValue?.request?.model),1)])):f("",!0),e.modelValue?.request?.resolution?(n(),l("p",It,[a(i,{icon:"fa-solid fa-image",class:"mr-1"}),c(" "+o(e.$t("nanobanana.name.resolution"))+": "+o(e.modelValue?.request?.resolution),1)])):f("",!0),e.modelValue?.request?.aspect_ratio?(n(),l("p",St,[a(i,{icon:"fa-solid fa-up-right-from-square",class:"mr-1"}),c(" "+o(e.$t("nanobanana.name.aspectRatio"))+": "+o(e.modelValue?.request?.aspect_ratio),1)])):f("",!0),e.modelValue?.request?.action?(n(),l("p",qt,[a(i,{icon:"fa-solid fa-bolt",class:"mr-1"}),c(" "+o(e.$t("nanobanana.name.task"))+": "+o(e.modelValue?.request?.action==="generate"?e.$t("nanobanana.name.generate"):e.$t("nanobanana.name.edits")),1)])):f("",!0),u("p",Ut,[a(i,{icon:"fa-solid fa-magic",class:"mr-1"}),c(" "+o(e.$t("nanobanana.name.taskId"))+": "+o(e.modelValue?.id)+" ",1),a(A,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])]),u("p",Ct,[a(i,{icon:"fa-solid fa-circle-info",class:"mr-1"}),c(" "+o(e.$t("nanobanana.name.failureReason"))+": "+o(e.modelValue?.response?.error?.message)+" ",1),a(A,{content:e.modelValue?.response?.error?.message,class:"btn-copy"},null,8,["content"])]),e.modelValue?.elapsed?(n(),l("p",Ot,[a(i,{icon:"fa-solid fa-clock",class:"mr-1"}),c(" "+o(e.$t("nanobanana.name.elapsed"))+": "+o(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):f("",!0),e.modelValue?.response?.trace_id?(n(),l("p",Pt,[a(i,{icon:"fa-solid fa-hashtag",class:"mr-1"}),c(" "+o(e.$t("nanobanana.name.traceId"))+": "+o(e.modelValue?.response?.trace_id)+" ",1),a(A,{content:e.modelValue?.response?.trace_id,class:"btn-copy"},null,8,["content"])])):f("",!0)]),_:1})])):(n(),l("div",Bt,[a(C,{closable:!1,class:"info"},{template:b(()=>[a(i,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),c(" "+o(e.$t("nanobanana.name.failure")),1)]),default:b(()=>[e.modelValue?.request?.model?(n(),l("p",Mt,[a(i,{icon:"fa-solid fa-cube",class:"mr-1"}),c(" "+o(e.$t("nanobanana.name.model"))+": "+o(e.modelValue?.request?.model),1)])):f("",!0),e.modelValue?.request?.resolution?(n(),l("p",Gt,[a(i,{icon:"fa-solid fa-image",class:"mr-1"}),c(" "+o(e.$t("nanobanana.name.resolution"))+": "+o(e.modelValue?.request?.resolution),1)])):f("",!0),e.modelValue?.request?.aspect_ratio?(n(),l("p",jt,[a(i,{icon:"fa-solid fa-up-right-from-square",class:"mr-1"}),c(" "+o(e.$t("nanobanana.name.aspectRatio"))+": "+o(e.modelValue?.request?.aspect_ratio),1)])):f("",!0),e.modelValue?.request?.action?(n(),l("p",Dt,[a(i,{icon:"fa-solid fa-bolt",class:"mr-1"}),c(" "+o(e.$t("nanobanana.name.task"))+": "+o(e.modelValue?.request?.action==="generate"?e.$t("nanobanana.name.generate"):e.$t("nanobanana.name.edits")),1)])):f("",!0),u("p",Ft,[a(i,{icon:"fa-solid fa-magic",class:"mr-1"}),c(" "+o(e.$t("nanobanana.name.taskId"))+": "+o(e.modelValue?.id)+" ",1),a(A,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])])]),_:1})]))])])}const Wt=w(ct,[["render",xt],["__scopeId","data-v-63f58569"]]),zt=y({name:"RecentPanel",components:{TaskPreview:Wt,BotPlaceholder:$e,NoTasks:ae,ScrollList:re},props:{loading:{type:Boolean,default:!1}},emits:["reach-top"],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.nanobanana?.tasks,items:this.$store.state.nanobanana?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),Kt={key:0},Ht={key:2,class:"w-full h-full flex items-center justify-center"};function Jt(e,t,$,r,d,h){const _=s("bot-placeholder"),g=s("task-preview"),p=s("scroll-list"),m=s("no-tasks");return n(),l(N,null,[e.tasks?.items===void 0?(n(),l("div",Kt,[a(_)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(n(),k(p,{key:1,ref:"scrollList",class:"tasks h-full w-full overflow-y-auto",loading:e.loading,onReachTop:t[0]||(t[0]=V=>e.$emit("reach-top"))},{default:b(()=>[(n(!0),l(N,null,R(e.tasks?.items,V=>(n(),k(g,{key:V.id,"model-value":V},null,8,["model-value"]))),128))]),_:1},8,["loading"])):f("",!0),e.tasks?.items?.length===0?(n(),l("div",Ht,[a(m)])):f("",!0)],64)}const Qt=w(zt,[["render",Jt]]),Xt=ee("nanobanana"),Yt=y({name:"NanobananaIndex",components:{ConfigPanel:it,Layout:Ae,RecentPanel:Qt},mixins:[se],inject:["initialized"],data(){return{task:void 0,job:0,loading:!1}},computed:{applicationsLoading(){return this.$store.state.nanobanana?.status?.getApplications===x.Request},tasksLoading(){return this.$store.state.nanobanana?.status?.getTasks===x.Request},credential(){return this.$store.state.nanobanana?.credential},config(){return this.$store.state.nanobanana?.config},application(){return this.$store.state.nanobanana?.application},tasks(){return this.$store.state.nanobanana?.tasks}},watch:{tasks:{handler(e,t){e?.items?.length>t?.items?.length&&console.debug("new tasks detected")},deep:!0},initialized:{async handler(e){e&&(console.debug("layout initialized"),await this.onGetTasks(),await this.onScrollDown(),this.job=window.setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){window.clearInterval(this.job)},methods:{async onReachTop(){await ie({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("nanobanana/getService"),console.debug("end onGetService")},async onGetApplication(){console.debug("start onGetApplication"),await this.$store.dispatch("nanobanana/getApplications"),console.debug("end onGetApplication"),await this.onGetTasks()},async onScrollDown(){await this.$nextTick();const e=this.getTasksScrollElement();e&&(e.scrollTop=e.scrollHeight)},async onGetTasks(e){if(this.applicationsLoading||this.tasksLoading){console.debug("loading");return}console.debug("start onGetTasks",e);const{limit:t=20,createdAtMin:$,createdAtMax:r}=e||{};console.debug("limit",t,"createdAtMin",$,"createdAtMax",r),await this.$store.dispatch("nanobanana/getTasks",{limit:t,createdAtMin:$,createdAtMax:r})},async onGenerate(){if(!le(this.uploadTracker,d=>this.$t(d),d=>E.warning(d)))return;const e={...this.config||{}},t=Array.isArray(e?.image_urls)&&e.image_urls.length>0;delete e.action,!t&&"image_urls"in e&&delete e.image_urls,e?.aspect_ratio||delete e.aspect_ratio,e?.model!==P&&"resolution"in e&&delete e.resolution,e?.model===P&&!e?.resolution&&(e.resolution=I);const $={...e,action:t?"edit":"generate",callback_url:Xt},r=this.credential?.token;if(!r){console.error("no token specified");return}E.info(this.$t("nanobanana.message.startingTask")),Y("nanobanana",Z.generate($,{token:r})).then(()=>{E.success(this.$t("nanobanana.message.startTaskSuccess"))}).catch(d=>{const h=d?.response?.data;h?.error?.code===de?E.error(this.$t("nanobanana.message.usedUp")):E.error(this.$t("nanobanana.message.startTaskFailed")+(h?.error?.message||""))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function Zt(e,t,$,r,d,h){const _=s("config-panel"),g=s("recent-panel"),p=s("layout");return n(),k(p,null,{config:b(()=>[a(_,{onGenerate:e.onGenerate},null,8,["onGenerate"])]),result:b(()=>[a(g,{ref:"recentPanel",loading:e.loading,onReachTop:e.onReachTop},null,8,["loading","onReachTop"])]),_:1})}const Ka=w(Yt,[["render",Zt]]);export{Ka as default};
1
+ import{F as S}from"./index.es-UMFIHXWc.js";import{E as q}from"./index-D7cRCqFS.js";import{E as K}from"./index-1WxaVCeu.js";import{d as y,H as l,E as u,z as O,C as a,y as b,D as s,q as n,x as k,F as o,I as c,O as N,N as R,J as f,M as H,Q as U}from"./vendor-vue-NSDaktjZ.js";import{H as w,bp as J,cR as Q,cS as W,cT as P,cU as X,cV as I,cW as j,cX as D,cY as F,cs as Y,aW as Z,S as x,ct as ee}from"./index-kok2V6cj.js";import{P as te,N as ae}from"./NoTasks-DLn86jTC.js";import{p as oe}from"./pasteUploadMixin-BurWbGNQ.js";import{u as ne,a as se,e as le}from"./uploadTrackerMixin--N-yU8Tl.js";import{I as B,S as re,l as ie}from"./pagination-EsDrj3yC.js";import{I as z}from"./ImagePreview-BjgklCqN.js";import{E as ce}from"./index-yNToY-SP.js";import{E}from"./index-Buukpn8o.js";import{E as M,a as G}from"./index-DkLXeCmb.js";import{C as ue}from"./Consumption-BAwCyKhW.js";import{a as me}from"./price-Beya5kld.js";import{b as de}from"./errorCode-Cqj9Td_Z.js";import{C as pe}from"./CopyToClipboard-B1L4gFQs.js";import{I as fe}from"./ImageWrapper-Gdemv0z3.js";import{A as he}from"./ApiCodeButton-Bu2nLY5J.js";import{E as _e}from"./index-BnUjW8_R.js";import{E as ge}from"./index-CLIkNw25.js";import{E as be}from"./index-CXgPGdvu.js";import{B as $e}from"./BotPlaceholder-B5Bw1tlj.js";import"./use-form-item-CYiJWVVo.js";import"./index-BuyEbX8F.js";import"./vendor-axios-B8_nURbH.js";import"./vendor-dayjs-v0j1UNZp.js";import"./vendor-vue-router-Df5ITouH.js";import"./index-WPH6eO9g.js";import"./typescript-CfmcPqGh.js";import"./index-KTS__Qmb.js";import"./index-DWWSYHUH.js";import"./highlight-DsFwBu4N.js";import"./index-BLjywj98.js";import"./vendor-highlight-lEWW1Jxd.js";import"./index-CNnBDoa1.js";import"./_baseClone-D8eUdaQd.js";import"./_Uint8Array-pGzioutB.js";import"./_initCloneObject-CAH0nDM3.js";import"./isEqual-DBGyFRF0.js";import"./index-BYnYd0I7.js";import"./strings-beZM2Y-f.js";import"./castArray-CJ8hzGGj.js";import"./debounce-G93CFNE1.js";import"./_baseIteratee-BCY-1IYO.js";import"./index-BI3c17YF.js";import"./index-BJr3r4qN.js";const ve=y({name:"LayoutNanobanana",components:{ElDrawer:K,ElButton:q,FontAwesomeIcon:S},data(){return{drawer:!1}}}),ke={class:"main flex flex-row flex-1"},ye={class:"config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]"},we={class:"result h-full p-6 flex-1 flex flex-col min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]"};function Ve(e,t,$,r,d,h){const _=s("font-awesome-icon"),g=s("el-button"),p=s("el-drawer");return n(),l("div",ke,[u("div",ye,[O(e.$slots,"config",{},void 0,!0)]),u("div",we,[O(e.$slots,"result",{},void 0,!0)]),a(g,{circle:"",class:"menu",onClick:t[0]||(t[0]=m=>e.drawer=!0)},{default:b(()=>[a(_,{icon:"fa-solid fa-magic"})]),_:1}),a(p,{modelValue:e.drawer,"onUpdate:modelValue":t[1]||(t[1]=m=>e.drawer=m),direction:"ltr","with-header":!1,size:"340px",class:"drawer"},{default:b(()=>[O(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const Ae=w(ve,[["render",Ve],["__scopeId","data-v-8ca1c212"]]),Ne="",Ee=y({name:"PromptInput",components:{PromptTextarea:te},computed:{prompt:{get(){return this.$store.state.nanobanana?.config?.prompt},set(e){this.$store.commit("nanobanana/setConfig",{...this.$store.state.nanobanana?.config,prompt:e})}}},mounted(){this.prompt||(this.prompt=Ne)}});function Re(e,t,$,r,d,h){const _=s("prompt-textarea");return n(),k(_,{modelValue:e.prompt,"onUpdate:modelValue":t[0]||(t[0]=g=>e.prompt=g),title:e.$t("nanobanana.name.prompt"),info:e.$t("nanobanana.description.prompt"),placeholder:e.$t("nanobanana.placeholder.prompt")},null,8,["modelValue","title","info","placeholder"])}const Le=w(Ee,[["render",Re]]),Te=y({name:"ImageUrlsInput",components:{ElUpload:ce,ElButton:q,InfoIcon:B,ImagePreview:z,FontAwesomeIcon:S},mixins:[oe,ne],data(){return{fileList:[],uploadUrl:J()+"/api/v1/files/",suppressWatch:!1}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e?.response?.file_url).filter(e=>!!e)},value(){return this.$store.state.nanobanana?.config?.image_urls}},watch:{value:{immediate:!0,handler(e){if(this.suppressWatch)return;if(!e||e.length===0){const r=(this.fileList||[]).filter(d=>!d?.response?.file_url);this.fileList=r.length?r:[];return}const t=[];e.forEach(r=>{const d=this.fileList.find(h=>h?.response?.file_url===r||h?.url===r);d?t.push(d):t.push({name:r.split("/").pop()||r,url:r,status:"success",percentage:100,response:{file_url:r}})}),(this.fileList||[]).filter(r=>!r?.response?.file_url).forEach(r=>{t.some(h=>h===r||h?.url===r?.url||h?.response?.file_url===r?.response?.file_url)||t.push(r)}),this.fileList=t}}},mounted(){},methods:{onChange(e){if(!e?.url&&e?.raw)try{e.url=URL.createObjectURL(e.raw)}catch{}},onRemove(e){if(e?.url&&typeof e.url=="string"&&e.url.startsWith("blob:"))try{URL.revokeObjectURL(e.url)}catch{}this.onSetImageUrls()},onExceed(){E.warning(this.$t("nanobanana.message.uploadImageExceed"))},onError(){E.error(this.$t("nanobanana.message.uploadImageError"))},onSetImageUrls(){const e=this.urls;this.suppressWatch=!0,this.$store.commit("nanobanana/setConfig",{...this.$store.state.nanobanana?.config,image_urls:e}),this.$nextTick(()=>{this.suppressWatch=!1})},async onSuccess(e,t){e?.file_url&&(t.url=e.file_url,t.response=e),this.onSetImageUrls()},onRemovePreview(e,t){if(this.fileList.splice(e,1),t?.url&&typeof t.url=="string"&&t.url.startsWith("blob:"))try{URL.revokeObjectURL(t.url)}catch{}this.onSetImageUrls()}}}),Ie={class:"field flex items-center justify-between"},Se={class:"title font-bold text-[14px] mb-[10px]"},qe={class:"upload-wrapper flex flex-col items-start gap-[8px]"},Ue={class:"controls flex items-center"},Ce={class:"file-list flex flex-wrap gap-[10px]"};function Oe(e,t,$,r,d,h){const _=s("font-awesome-icon"),g=s("el-button"),p=s("el-upload"),m=s("info-icon"),V=s("image-preview");return n(),l(N,null,[u("div",Ie,[u("h2",Se,o(e.$t("nanobanana.name.imageUrls")),1),u("div",qe,[u("div",Ue,[a(p,{ref:"uploader","file-list":e.fileList,"onUpdate:fileList":t[0]||(t[0]=v=>e.fileList=v),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:b(()=>[a(g,{size:"small",type:"primary",round:""},{default:b(()=>[a(_,{icon:"fa-solid fa-upload",class:"mr-1"}),c(" "+o(e.$t("nanobanana.button.uploadImageUrls")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-success","on-change","on-remove","headers"]),a(m,{content:e.$t("nanobanana.description.imageUrls"),class:"ml-2"},null,8,["content"])])])]),u("div",Ce,[(n(!0),l(N,null,R(e.fileList,(v,i)=>(n(),k(V,{key:v.uid||v?.response?.file_url||v.url||i,url:v.url||v?.response?.file_url,name:v.name,percentage:v.percentage,onRemove:A=>e.onRemovePreview(i,v)},null,8,["url","name","percentage","onRemove"]))),128))])],64)}const Pe=w(Te,[["render",Oe]]),Be=y({name:"AspectRatioSelector",components:{ElSelect:G,ElOption:M},data(){return{options:["1:1","3:2","2:3","16:9","9:16","4:3","3:4"]}},computed:{value:{get(){return this.$store.state.nanobanana?.config?.aspect_ratio},set(e){console.debug("set aspect_ratio",e);const t={...this.$store.state.nanobanana?.config||{}};e?t.aspect_ratio=e:delete t.aspect_ratio,this.$store.commit("nanobanana/setConfig",t)}}}}),Me={class:"field"},Ge={class:"title font-bold"};function je(e,t,$,r,d,h){const _=s("el-option"),g=s("el-select");return n(),l("div",Me,[u("h2",Ge,o(e.$t("nanobanana.name.aspectRatio")),1),a(g,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=p=>e.value=p),class:"value",clearable:"",placeholder:e.$t("nanobanana.placeholder.select")},{default:b(()=>[(n(!0),l(N,null,R(e.options,p=>(n(),k(_,{key:p,label:p,value:p},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const De=w(Be,[["render",je],["__scopeId","data-v-67f08a08"]]),Fe=y({name:"NanobananaModelSelector",components:{ElSelect:G,ElOption:M,InfoIcon:B},data(){return{options:[{value:W,label:this.$t("nanobanana.model.nanoBanana")},{value:P,label:this.$t("nanobanana.model.nanoBananaPro")},{value:X,label:this.$t("nanobanana.model.nanoBanana2")}]}},computed:{value:{get(){return this.$store.state.nanobanana?.config?.model},set(e){this.$store.commit("nanobanana/setConfig",{...this.$store.state.nanobanana?.config,model:e})}},modelDescription(){return this.$t("nanobanana.description.model")}},mounted(){this.value||(this.value=Q)}}),xe={class:"field"},We={class:"label"},ze={class:"box"},Ke={class:"title font-bold"};function He(e,t,$,r,d,h){const _=s("info-icon"),g=s("el-option"),p=s("el-select");return n(),l("div",xe,[u("div",We,[u("div",ze,[u("h2",Ke,o(e.$t("nanobanana.name.model")),1),a(_,{content:e.modelDescription,class:"info"},null,8,["content"])])]),a(p,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=m=>e.value=m),class:"value",placeholder:e.$t("nanobanana.placeholder.select")},{default:b(()=>[(n(!0),l(N,null,R(e.options,m=>(n(),k(g,{key:m.value,label:m.label,value:m.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Je=w(Fe,[["render",He],["__scopeId","data-v-94304d73"]]),Qe=y({name:"NanobananaResolutionSelector",components:{ElSelect:G,ElOption:M,InfoIcon:B},data(){return{cachedResolution:I,options:[{value:j,label:j},{value:D,label:D},{value:F,label:F}]}},computed:{value:{get(){return this.$store.state.nanobanana?.config?.resolution},set(e){this.$store.commit("nanobanana/setConfig",{...this.$store.state.nanobanana?.config,resolution:e})}},isProModel(){return this.$store.state.nanobanana?.config?.model!==W}},watch:{value(e){this.isProModel&&e&&(this.cachedResolution=e)},isProModel(e){e?this.value||(this.value=this.cachedResolution||I):(this.value&&(this.cachedResolution=this.value),this.$store.commit("nanobanana/setConfig",{...this.$store.state.nanobanana?.config,resolution:void 0}))}},mounted(){this.isProModel&&!this.value&&(this.value=I),!this.isProModel&&this.value&&(this.cachedResolution=this.value,this.$store.commit("nanobanana/setConfig",{...this.$store.state.nanobanana?.config,resolution:void 0}))}}),Xe={class:"field"},Ye={class:"label"},Ze={class:"box"},et={class:"title font-bold"};function tt(e,t,$,r,d,h){const _=s("info-icon"),g=s("el-option"),p=s("el-select");return n(),l("div",Xe,[u("div",Ye,[u("div",Ze,[u("h2",et,o(e.$t("nanobanana.name.resolution")),1),a(_,{content:e.$t("nanobanana.description.resolutionProOnly"),class:"info"},null,8,["content"])])]),a(p,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=m=>e.value=m),class:"value",placeholder:e.$t("nanobanana.placeholder.select"),disabled:!e.isProModel},{default:b(()=>[(n(!0),l(N,null,R(e.options,m=>(n(),k(g,{key:m.value,label:m.label,value:m.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder","disabled"])])}const at=w(Qe,[["render",tt],["__scopeId","data-v-fd5ab393"]]),ot=y({name:"ConfigPanel",components:{ElButton:q,FontAwesomeIcon:S,PromptInput:Le,Consumption:ue,ImageUrlsInput:Pe,AspectRatioSelector:De,ModelSelector:Je,ResolutionSelector:at},emits:["generate"],computed:{config(){return this.$store.state.nanobanana?.config},consumption(){const e={...this.config||{}},t=Array.isArray(e?.image_urls)&&e.image_urls.length>0;return me({...e,action:t?"edit":"generate"},this.service?.cost)},service(){return this.$store.state.nanobanana?.service}},methods:{onGenerate(){this.$emit("generate")}}}),nt={class:"flex flex-col h-full"},st={class:"flex-1 overflow-y-auto p-5"},lt={class:"flex flex-col items-center justify-center px-5 pb-5"};function rt(e,t,$,r,d,h){const _=s("model-selector"),g=s("resolution-selector"),p=s("prompt-input"),m=s("aspect-ratio-selector"),V=s("image-urls-input"),v=s("consumption"),i=s("font-awesome-icon"),A=s("el-button");return n(),l("div",nt,[u("div",st,[a(_,{class:"mb-4"}),a(g,{class:"mb-4"}),a(p,{class:"mb-4"}),a(m,{class:"mb-4"}),a(V,{class:"mb-4"})]),u("div",lt,[a(v,{value:e.consumption,service:e.service},null,8,["value","service"]),a(A,{type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:b(()=>[a(i,{icon:"fa-solid fa-magic",class:"mr-2"}),c(" "+o(e.$t("nanobanana.button.generate")),1)]),_:1},8,["onClick"])])])}const it=w(ot,[["render",rt]]),ct=y({name:"TaskPreview",components:{ElImage:be,CopyToClipboard:pe,FontAwesomeIcon:S,ElAlert:ge,ImageWrapper:fe,ElButton:q,ElTooltip:_e,ImagePreview:z,ApiCodeButton:he},props:{modelValue:{type:Object,required:!0}},computed:{images(){const e=[];return Array.isArray(this.modelValue?.response?.data)&&this.modelValue?.response?.data?.forEach(t=>{e.push(t)}),e}},methods:{onEdit(e){if(!e)return;console.debug("Edit image:",e);const t={...this.$store.state.nanobanana?.config||{}};delete t.action,t.image_urls=[e],this.$store.commit("nanobanana/setConfig",t)}}}),ut={class:"preview"},mt={class:"left"},dt={class:"main"},pt={class:"bot"},ft={class:"datetime"},ht={class:"info"},_t={key:0,class:"flex justify-start items-center gap-2 mt-2 w-full overflow-x-auto"},gt={key:1,class:"prompt mt-2"},bt={key:0},$t={key:0,class:U({content:!0,failed:!0})},vt={class:"flex justify-start items-center gap-4 w-full overflow-x-auto"},kt={class:U({operations:!0,"mt-2":!0,"mb-2":!0})},yt={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},wt={key:1,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Vt={key:2,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},At={key:3,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Nt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Et={key:4,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Rt={key:5,class:"text-[var(--el-text-color-regular)] text-xs mb-0"},Lt={key:1,class:U({content:!0})},Tt={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},It={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"},qt={key:3,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Ut={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Ct={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Ot={key:4,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Pt={key:5,class:"text-[var(--el-text-color-regular)] text-xs mb-0"},Bt={key:2,class:U({content:!0})},Mt={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Gt={key:1,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},jt={key:2,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Dt={key:3,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Ft={class:"text-[var(--el-text-color-regular)] text-xs mb-2"};function xt(e,t,$,r,d,h){const _=s("el-image"),g=s("image-preview"),p=s("image-wrapper"),m=s("el-button"),V=s("el-tooltip"),v=s("api-code-button"),i=s("font-awesome-icon"),A=s("copy-to-clipboard"),C=s("el-alert");return n(),l("div",ut,[u("div",mt,[a(_,{src:"https://cdn.acedata.cloud/859plc.jpg",class:"avatar"})]),u("div",dt,[u("div",pt,[c(o(e.$t("nanobanana.name.nanobananaBot"))+" ",1),u("span",ft,o(e.$dayjs.format(""+new Date(parseFloat((e.modelValue?.created_at||"").toString())*1e3))),1)]),u("div",ht,[e.modelValue?.request?.image_urls&&e.modelValue?.request?.image_urls.length>0?(n(),l("div",_t,[(n(!0),l(N,null,R(e.modelValue?.request?.image_urls,(L,T)=>(n(),k(g,{key:T,url:L,name:`image-${T+1}`,closable:!1},null,8,["url","name"]))),128))])):f("",!0),e.modelValue?.request?.prompt?(n(),l("p",gt,[c(o(e.modelValue?.request?.prompt)+" ",1),e.modelValue?.response?f("",!0):(n(),l("span",bt," - ("+o(e.$t("nanobanana.status.pending"))+") ",1))])):f("",!0)]),e.modelValue?.response?.success===!0?(n(),l("div",$t,[u("div",vt,[(n(!0),l(N,null,R(e.images,(L,T)=>(n(),k(p,{key:T,src:L?.image_url,"raw-src":L?.image_url},null,8,["src","raw-src"]))),128))]),u("div",kt,[a(V,{class:"box-item",effect:"dark",content:e.$t("common.button.edit"),placement:"top-start"},{default:b(()=>[a(m,{type:"info",size:"small",class:"btn-action",onClick:t[0]||(t[0]=H(L=>e.onEdit(e.images?.[0]?.image_url),["stop"]))},{default:b(()=>[c(o(e.$t("common.button.edit")),1)]),_:1})]),_:1},8,["content"]),a(v,{path:"/nano-banana/images",body:e.modelValue?.request},null,8,["body"])]),a(C,{closable:!1,class:"mt-2 success"},{default:b(()=>[e.modelValue?.request?.model?(n(),l("p",yt,[a(i,{icon:"fa-solid fa-cube",class:"mr-1"}),c(" "+o(e.$t("nanobanana.name.model"))+": "+o(e.modelValue?.request?.model),1)])):f("",!0),e.modelValue?.request?.resolution?(n(),l("p",wt,[a(i,{icon:"fa-solid fa-image",class:"mr-1"}),c(" "+o(e.$t("nanobanana.name.resolution"))+": "+o(e.modelValue?.request?.resolution),1)])):f("",!0),e.modelValue?.request?.aspect_ratio?(n(),l("p",Vt,[a(i,{icon:"fa-solid fa-up-right-from-square",class:"mr-1"}),c(" "+o(e.$t("nanobanana.name.aspectRatio"))+": "+o(e.modelValue?.request?.aspect_ratio),1)])):f("",!0),e.modelValue?.request?.action?(n(),l("p",At,[a(i,{icon:"fa-solid fa-bolt",class:"mr-1"}),c(" "+o(e.$t("nanobanana.name.task"))+": "+o(e.modelValue?.request?.action==="generate"?e.$t("nanobanana.name.generate"):e.$t("nanobanana.name.edits")),1)])):f("",!0),u("p",Nt,[a(i,{icon:"fa-solid fa-magic",class:"mr-1"}),c(" "+o(e.$t("nanobanana.name.taskId"))+": "+o(e.modelValue?.id)+" ",1),a(A,{content:e.modelValue?.id,class:"btn-copy inline-block"},null,8,["content"])]),e.modelValue?.elapsed?(n(),l("p",Et,[a(i,{icon:"fa-solid fa-clock",class:"mr-1"}),c(" "+o(e.$t("nanobanana.name.elapsed"))+": "+o(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):f("",!0),e.modelValue?.response?.trace_id?(n(),l("p",Rt,[a(i,{icon:"fa-solid fa-hashtag",class:"mr-1"}),c(" "+o(e.$t("nanobanana.name.traceId"))+": "+o(e.modelValue?.response?.trace_id)+" ",1),a(A,{content:e.modelValue?.response?.trace_id,class:"btn-copy inline-block"},null,8,["content"])])):f("",!0)]),_:1})])):e.modelValue?.response?.success===!1?(n(),l("div",Lt,[a(C,{closable:!1,class:"failure"},{template:b(()=>[a(i,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),c(" "+o(e.$t("nanobanana.name.failure")),1)]),default:b(()=>[e.modelValue?.request?.model?(n(),l("p",Tt,[a(i,{icon:"fa-solid fa-cube",class:"mr-1"}),c(" "+o(e.$t("nanobanana.name.model"))+": "+o(e.modelValue?.request?.model),1)])):f("",!0),e.modelValue?.request?.resolution?(n(),l("p",It,[a(i,{icon:"fa-solid fa-image",class:"mr-1"}),c(" "+o(e.$t("nanobanana.name.resolution"))+": "+o(e.modelValue?.request?.resolution),1)])):f("",!0),e.modelValue?.request?.aspect_ratio?(n(),l("p",St,[a(i,{icon:"fa-solid fa-up-right-from-square",class:"mr-1"}),c(" "+o(e.$t("nanobanana.name.aspectRatio"))+": "+o(e.modelValue?.request?.aspect_ratio),1)])):f("",!0),e.modelValue?.request?.action?(n(),l("p",qt,[a(i,{icon:"fa-solid fa-bolt",class:"mr-1"}),c(" "+o(e.$t("nanobanana.name.task"))+": "+o(e.modelValue?.request?.action==="generate"?e.$t("nanobanana.name.generate"):e.$t("nanobanana.name.edits")),1)])):f("",!0),u("p",Ut,[a(i,{icon:"fa-solid fa-magic",class:"mr-1"}),c(" "+o(e.$t("nanobanana.name.taskId"))+": "+o(e.modelValue?.id)+" ",1),a(A,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])]),u("p",Ct,[a(i,{icon:"fa-solid fa-circle-info",class:"mr-1"}),c(" "+o(e.$t("nanobanana.name.failureReason"))+": "+o(e.modelValue?.response?.error?.message)+" ",1),a(A,{content:e.modelValue?.response?.error?.message,class:"btn-copy"},null,8,["content"])]),e.modelValue?.elapsed?(n(),l("p",Ot,[a(i,{icon:"fa-solid fa-clock",class:"mr-1"}),c(" "+o(e.$t("nanobanana.name.elapsed"))+": "+o(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):f("",!0),e.modelValue?.response?.trace_id?(n(),l("p",Pt,[a(i,{icon:"fa-solid fa-hashtag",class:"mr-1"}),c(" "+o(e.$t("nanobanana.name.traceId"))+": "+o(e.modelValue?.response?.trace_id)+" ",1),a(A,{content:e.modelValue?.response?.trace_id,class:"btn-copy"},null,8,["content"])])):f("",!0)]),_:1})])):(n(),l("div",Bt,[a(C,{closable:!1,class:"info"},{template:b(()=>[a(i,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),c(" "+o(e.$t("nanobanana.name.failure")),1)]),default:b(()=>[e.modelValue?.request?.model?(n(),l("p",Mt,[a(i,{icon:"fa-solid fa-cube",class:"mr-1"}),c(" "+o(e.$t("nanobanana.name.model"))+": "+o(e.modelValue?.request?.model),1)])):f("",!0),e.modelValue?.request?.resolution?(n(),l("p",Gt,[a(i,{icon:"fa-solid fa-image",class:"mr-1"}),c(" "+o(e.$t("nanobanana.name.resolution"))+": "+o(e.modelValue?.request?.resolution),1)])):f("",!0),e.modelValue?.request?.aspect_ratio?(n(),l("p",jt,[a(i,{icon:"fa-solid fa-up-right-from-square",class:"mr-1"}),c(" "+o(e.$t("nanobanana.name.aspectRatio"))+": "+o(e.modelValue?.request?.aspect_ratio),1)])):f("",!0),e.modelValue?.request?.action?(n(),l("p",Dt,[a(i,{icon:"fa-solid fa-bolt",class:"mr-1"}),c(" "+o(e.$t("nanobanana.name.task"))+": "+o(e.modelValue?.request?.action==="generate"?e.$t("nanobanana.name.generate"):e.$t("nanobanana.name.edits")),1)])):f("",!0),u("p",Ft,[a(i,{icon:"fa-solid fa-magic",class:"mr-1"}),c(" "+o(e.$t("nanobanana.name.taskId"))+": "+o(e.modelValue?.id)+" ",1),a(A,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])])]),_:1})]))])])}const Wt=w(ct,[["render",xt],["__scopeId","data-v-63f58569"]]),zt=y({name:"RecentPanel",components:{TaskPreview:Wt,BotPlaceholder:$e,NoTasks:ae,ScrollList:re},props:{loading:{type:Boolean,default:!1}},emits:["reach-top"],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.nanobanana?.tasks,items:this.$store.state.nanobanana?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),Kt={key:0},Ht={key:2,class:"w-full h-full flex items-center justify-center"};function Jt(e,t,$,r,d,h){const _=s("bot-placeholder"),g=s("task-preview"),p=s("scroll-list"),m=s("no-tasks");return n(),l(N,null,[e.tasks?.items===void 0?(n(),l("div",Kt,[a(_)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(n(),k(p,{key:1,ref:"scrollList",class:"tasks h-full w-full overflow-y-auto",loading:e.loading,onReachTop:t[0]||(t[0]=V=>e.$emit("reach-top"))},{default:b(()=>[(n(!0),l(N,null,R(e.tasks?.items,V=>(n(),k(g,{key:V.id,"model-value":V},null,8,["model-value"]))),128))]),_:1},8,["loading"])):f("",!0),e.tasks?.items?.length===0?(n(),l("div",Ht,[a(m)])):f("",!0)],64)}const Qt=w(zt,[["render",Jt]]),Xt=ee("nanobanana"),Yt=y({name:"NanobananaIndex",components:{ConfigPanel:it,Layout:Ae,RecentPanel:Qt},mixins:[se],inject:["initialized"],data(){return{task:void 0,job:0,loading:!1}},computed:{applicationsLoading(){return this.$store.state.nanobanana?.status?.getApplications===x.Request},tasksLoading(){return this.$store.state.nanobanana?.status?.getTasks===x.Request},credential(){return this.$store.state.nanobanana?.credential},config(){return this.$store.state.nanobanana?.config},application(){return this.$store.state.nanobanana?.application},tasks(){return this.$store.state.nanobanana?.tasks}},watch:{tasks:{handler(e,t){e?.items?.length>t?.items?.length&&console.debug("new tasks detected")},deep:!0},initialized:{async handler(e){e&&(console.debug("layout initialized"),await this.onGetTasks(),await this.onScrollDown(),this.job=window.setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){window.clearInterval(this.job)},methods:{async onReachTop(){await ie({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("nanobanana/getService"),console.debug("end onGetService")},async onGetApplication(){console.debug("start onGetApplication"),await this.$store.dispatch("nanobanana/getApplications"),console.debug("end onGetApplication"),await this.onGetTasks()},async onScrollDown(){await this.$nextTick();const e=this.getTasksScrollElement();e&&(e.scrollTop=e.scrollHeight)},async onGetTasks(e){if(this.applicationsLoading||this.tasksLoading){console.debug("loading");return}console.debug("start onGetTasks",e);const{limit:t=20,createdAtMin:$,createdAtMax:r}=e||{};console.debug("limit",t,"createdAtMin",$,"createdAtMax",r),await this.$store.dispatch("nanobanana/getTasks",{limit:t,createdAtMin:$,createdAtMax:r})},async onGenerate(){if(!le(this.uploadTracker,d=>this.$t(d),d=>E.warning(d)))return;const e={...this.config||{}},t=Array.isArray(e?.image_urls)&&e.image_urls.length>0;delete e.action,!t&&"image_urls"in e&&delete e.image_urls,e?.aspect_ratio||delete e.aspect_ratio,e?.model!==P&&"resolution"in e&&delete e.resolution,e?.model===P&&!e?.resolution&&(e.resolution=I);const $={...e,action:t?"edit":"generate",callback_url:Xt},r=this.credential?.token;if(!r){console.error("no token specified");return}E.info(this.$t("nanobanana.message.startingTask")),Y("nanobanana",Z.generate($,{token:r})).then(()=>{E.success(this.$t("nanobanana.message.startTaskSuccess"))}).catch(d=>{const h=d?.response?.data;h?.error?.code===de?E.error(this.$t("nanobanana.message.usedUp")):E.error(this.$t("nanobanana.message.startTaskFailed")+(h?.error?.message||""))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function Zt(e,t,$,r,d,h){const _=s("config-panel"),g=s("recent-panel"),p=s("layout");return n(),k(p,null,{config:b(()=>[a(_,{onGenerate:e.onGenerate},null,8,["onGenerate"])]),result:b(()=>[a(g,{ref:"recentPanel",loading:e.loading,onReachTop:e.onReachTop},null,8,["loading","onReachTop"])]),_:1})}const Ka=w(Yt,[["render",Zt]]);export{Ka as default};
@@ -1 +1 @@
1
- import{L as G}from"./Hailuo-DohJzCSN.js";import{F as P}from"./index.es-fM0biscR.js";import{H as b,bp as A,cs as R,aS as M,S as L,ct as B}from"./index-BitdtvW1.js";import{a as j}from"./hailuo-C8Dw-0xR.js";import{E as D,a as q}from"./index-CVCfk6pt.js";import{d as y,H as l,E as r,F as o,C as t,y as c,O as I,N as U,D as a,q as s,x as $,I as m,J as d,M as F,Q as V}from"./vendor-vue-NSDaktjZ.js";import{p as O}from"./pasteUploadMixin-BurWbGNQ.js";import{u as N,a as z,e as H}from"./uploadTrackerMixin--N-yU8Tl.js";import{I as J,S as K,l as Q}from"./pagination-CDMeT271.js";import{I as W}from"./ImagePreview-Deaq21aE.js";import{E as C}from"./index-CXGm2ibp.js";import{E as X}from"./index-B5zfRlKe.js";import{E as v}from"./index-DY9n5RWp.js";import{P as Y,N as Z}from"./NoTasks-DYAWTz-D.js";import{C as x}from"./Consumption-Dvylkuyr.js";import{a as ee}from"./price-UzqaC8kS.js";import{b as te}from"./errorCode-Cqj9Td_Z.js";import{C as oe}from"./CopyToClipboard-3JBcjf6f.js";import{V as se}from"./VideoPlayer-Br2yW1lu.js";import{A as ae}from"./ApiCodeButton-9XDDLdNe.js";import{E as ne}from"./index-CRROw2v3.js";import{E as le}from"./index-XLYMNUFJ.js";import{E as ie}from"./index-BkchfnNA.js";import{B as re}from"./BotPlaceholder-Bm3iFf5b.js";import"./index-DYQToXUU.js";import"./vendor-axios-B8_nURbH.js";import"./vendor-dayjs-v0j1UNZp.js";import"./vendor-vue-router-Df5ITouH.js";import"./index-BFUf5YVt.js";import"./typescript-CdFsS8fD.js";import"./index-BKgRYY8E.js";import"./strings-beZM2Y-f.js";import"./isEqual-CMrgrIDS.js";import"./_Uint8Array-CRC1hUw5.js";import"./castArray-D90oh5Za.js";import"./use-form-item-CaXGkw6S.js";import"./index-cn5_DmaE.js";import"./index-IEnCZwtg.js";import"./debounce-B16-iZx6.js";import"./_baseIteratee-BQgCC_-_.js";import"./index-Bo7zkVzy.js";import"./highlight-DEv6Uzjh.js";import"./index-BLjywj98.js";import"./vendor-highlight-lEWW1Jxd.js";import"./index-CCeJfLsu.js";import"./index-BuyEbX8F.js";import"./_baseClone-BR0qWb-t.js";import"./_initCloneObject-EbmJQUEy.js";import"./vue-plyr-BO2nlN4c.js";import"./index-BHVQW8Q2.js";const ce=y({name:"ModelSelector",components:{ElSelect:q,ElOption:D},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||(this.value=j)}}),ue={class:"field"},me={class:"title font-bold"},de={class:"float-left"};function pe(e,n,p,_,w,T){const f=a("el-option"),g=a("el-select");return s(),l("div",ue,[r("h2",me,o(e.$t("hailuo.name.model")),1),t(g,{modelValue:e.value,"onUpdate:modelValue":n[0]||(n[0]=u=>e.value=u),class:"value",placeholder:e.$t("hailuo.placeholder.select"),clearable:""},{default:c(()=>[(s(!0),l(I,null,U(e.options,u=>(s(),$(f,{key:u.value,label:u.label,value:u.value},{default:c(()=>[r("span",de,o(u.label),1)]),_:2},1032,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const he=b(ce,[["render",pe],["__scopeId","data-v-a768fbd9"]]),fe=y({name:"StartImageUrlInput",components:{ElUpload:X,ElButton:C,InfoIcon:J,ImagePreview:W},mixins:[O,N],data(){return{fileList:[],uploadUrl:A()+"/api/v1/files/"}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e.url).filter(e=>e!==void 0)},value:{get(){return this.$store.state.hailuo?.config?.first_image_url},set(){const e=this.urls?.[0];this.$store.commit("hailuo/setConfig",{...this.$store.state.hailuo?.config,first_image_url:e})}}},mounted(){this.value||(this.value=void 0),this.onSetStartImageUrl()},methods:{onExceed(){v.warning(this.$t("hailuo.message.uploadStartImageExceed"))},onError(){v.error(this.$t("hailuo.message.uploadStartImageError"))},async onRemove(){v.error(this.$t("hailuo.message.uploadStartImageError"))},onSetStartImageUrl(){const e=this.urls?.[0];this.$store.commit("hailuo/setConfig",{...this.$store.state.hailuo?.config,first_image_url:e})},async onSuccess(){this.onSetStartImageUrl()}}}),ge={class:"relative"},_e={class:"flex justify-between"},$e={class:"flex justify-start items-center"},ve={class:"text-sm font-bold"};function ke(e,n,p,_,w,T){const f=a("info-icon"),g=a("image-preview"),u=a("el-button"),k=a("el-upload");return s(),l("div",ge,[r("div",_e,[r("div",$e,[r("span",ve,o(e.$t("hailuo.name.startImageUrl")),1),t(f,{content:e.$t("hailuo.description.startImageUrl"),class:"info"},null,8,["content"])])]),t(k,{ref:"uploader","file-list":e.fileList,"onUpdate:fileList":n[0]||(n[0]=i=>e.fileList=i),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:c(({file:i})=>[i.url&&i.percentage!==void 0?(s(),$(g,{key:0,url:i.url,name:i.name,percentage:i.percentage,onRemove:h=>e.fileList.splice(e.fileList.indexOf(i),1)},null,8,["url","name","percentage","onRemove"])):d("",!0)]),default:c(()=>[t(u,{size:"small",type:"primary",class:"btn btn-upload",round:""},{default:c(()=>[m(o(e.$t("hailuo.button.uploadStartImageUrl")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-remove","on-success","headers"])])}const be=b(fe,[["render",ke],["__scopeId","data-v-fbf49b06"]]),ye="",we=y({name:"PromptInput",components:{PromptTextarea:Y},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||(this.prompt=ye)}});function Te(e,n,p,_,w,T){const f=a("prompt-textarea");return s(),$(f,{modelValue:e.prompt,"onUpdate:modelValue":n[0]||(n[0]=g=>e.prompt=g),title:e.$t("hailuo.name.prompt"),info:e.$t("hailuo.description.prompt"),placeholder:e.$t("hailuo.placeholder.prompt")},null,8,["modelValue","title","info","placeholder"])}const Se=b(we,[["render",Te]]),Ve=y({name:"PresetPanel",components:{ElButton:C,FontAwesomeIcon:P,PromptInput:Se,StartImageUrlInput:be,ModelSelector:he,Consumption:x},emits:["generate"],computed:{config(){return this.$store.state.hailuo?.config},consumption(){return ee(this.config,this.service?.cost)},service(){return this.$store.state.hailuo?.service}},methods:{onGenerate(){this.$emit("generate")}}}),Ee={class:"flex flex-col h-full"},Ie={class:"flex-1 overflow-y-auto p-5"},Ce={class:"flex flex-col items-center justify-center px-5 pb-5"};function Le(e,n,p,_,w,T){const f=a("prompt-input"),g=a("model-selector"),u=a("start-image-url-input"),k=a("consumption"),i=a("font-awesome-icon"),h=a("el-button");return s(),l("div",Ee,[r("div",Ie,[t(f,{class:"mb-4"}),t(g,{class:"mb-4"}),e.config?.model==="minimax-i2v"?(s(),$(u,{key:0,class:"mb-2"})):d("",!0)]),r("div",Ce,[t(k,{value:e.consumption,service:e.service},null,8,["value","service"]),e.config?.video_url!==void 0||e.config?.custom?(s(),$(h,{key:0,type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:c(()=>[t(i,{icon:"fa-solid fa-magic",class:"mr-2"}),m(" "+o(e.$t("hailuo.button.extend")),1)]),_:1},8,["onClick"])):(s(),$(h,{key:1,type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:c(()=>[t(i,{icon:"fa-solid fa-magic",class:"mr-2"}),m(" "+o(e.$t("hailuo.button.generate")),1)]),_:1},8,["onClick"]))])])}const Pe=b(Ve,[["render",Le]]),Ue=y({name:"TaskPreview",components:{ElImage:ie,CopyToClipboard:oe,FontAwesomeIcon:P,ElAlert:le,VideoPlayer:se,ElTooltip:ne,ElButton:C,ApiCodeButton:ae},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")}}}),Ge={class:"preview"},Ae={class:"left"},Re={class:"main"},Me={class:"bot"},Be={class:"datetime"},je={class:"info"},De={key:0,class:"prompt mt-2"},qe={key:0},Fe={key:1},Oe={key:0,class:V({content:!0,failed:!0})},Ne={key:0,class:"mb-4"},ze={key:1,class:V({operations:!0,"mt-2":!0})},He={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Je={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Ke={key:1,class:"text-[var(--el-text-color-regular)] text-xs mb-0"},Qe={key:1,class:V({content:!0})},We={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Xe={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Ye={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Ze={class:"text-[var(--el-text-color-regular)] text-xs mb-0"},xe={key:2,class:V({content:!0})},et={class:"text-[var(--el-text-color-regular)] text-xs mb-0"};function tt(e,n,p,_,w,T){const f=a("el-image"),g=a("video-player"),u=a("el-button"),k=a("el-tooltip"),i=a("api-code-button"),h=a("font-awesome-icon"),S=a("copy-to-clipboard"),E=a("el-alert");return s(),l("div",Ge,[r("div",Ae,[t(f,{src:"https://cdn.acedata.cloud/0qg4gp.png",class:"avatar"})]),r("div",Re,[r("div",Me,[m(o(e.$t("hailuo.name.hailuoBot"))+" ",1),r("span",Be,o(e.$dayjs.format(""+new Date(parseFloat((e.modelValue?.created_at||"").toString())*1e3))),1)]),r("div",je,[e.modelValue?.request?.prompt?(s(),l("p",De,[m(o(e.modelValue?.request?.prompt)+" ",1),e.modelValue?.response?d("",!0):(s(),l("span",qe," - ("+o(e.$t("hailuo.status.pending"))+") ",1)),e.video?.state==="processing"||e.video?.state==="pending"||e.video?.state==="running"?(s(),l("span",Fe," - ("+o(e.$t("hailuo.status.processing"))+") ",1)):d("",!0)])):d("",!0)]),e.modelValue?.response?.success===!0?(s(),l("div",Oe,[e.video?.video_url?(s(),l("div",Ne,[t(g,{src:e.video?.video_url},null,8,["src"])])):d("",!0),e.video?(s(),l("div",ze,[t(k,{class:"box-item",effect:"dark",content:e.$t("hailuo.message.downloadVideo"),placement:"top-start"},{default:c(()=>[e.video?.video_url?(s(),$(u,{key:0,type:"info",size:"small",class:"mb-2",onClick:n[0]||(n[0]=F(mt=>e.onDownload(e.video?.video_url),["stop"]))},{default:c(()=>[m(o(e.$t("hailuo.button.download")),1)]),_:1})):d("",!0)]),_:1},8,["content"]),t(i,{path:"/hailuo/videos",body:e.modelValue?.request},null,8,["body"])])):d("",!0),t(E,{closable:!1,class:"mt-2 success"},{default:c(()=>[e.modelValue?.request?.model?(s(),l("p",He,[t(h,{icon:"fa-solid fa-hashtag",class:"mr-1"}),m(" "+o(e.$t("hailuo.name.model"))+": "+o(e.modelValue?.request?.model)+" ",1),t(S,{content:e.modelValue?.id},null,8,["content"])])):d("",!0),r("p",Je,[t(h,{icon:"fa-solid fa-magic",class:"mr-1"}),m(" "+o(e.$t("hailuo.name.taskId"))+": "+o(e.modelValue?.id)+" ",1),t(S,{content:e.modelValue?.id},null,8,["content"])]),e.modelValue?.elapsed?(s(),l("p",Ke,[t(h,{icon:"fa-solid fa-clock",class:"mr-1"}),m(" "+o(e.$t("hailuo.name.elapsed"))+": "+o(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):d("",!0)]),_:1})])):d("",!0),e.modelValue?.response?.success===!1?(s(),l("div",Qe,[t(E,{closable:!1,class:"failure"},{template:c(()=>[t(h,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),m(" "+o(e.$t("hailuo.name.failure")),1)]),default:c(()=>[r("p",We,[t(h,{icon:"fa-solid fa-magic",class:"mr-1"}),m(" "+o(e.$t("hailuo.name.taskId"))+": "+o(e.modelValue?.id)+" ",1),t(S,{content:e.modelValue?.id},null,8,["content"])]),r("p",Xe,[t(h,{icon:"fa-solid fa-circle-info",class:"mr-1"}),m(" "+o(e.$t("hailuo.name.failureReason"))+": "+o(e.modelValue?.response?.error?.message)+" ",1),t(S,{content:e.modelValue?.response?.error?.message},null,8,["content"])]),e.modelValue?.elapsed?(s(),l("p",Ye,[t(h,{icon:"fa-solid fa-clock",class:"mr-1"}),m(" "+o(e.$t("hailuo.name.elapsed"))+": "+o(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):d("",!0),r("p",Ze,[t(h,{icon:"fa-solid fa-hashtag",class:"mr-1"}),m(" "+o(e.$t("hailuo.name.traceId"))+": "+o(e.modelValue?.response?.trace_id)+" ",1),t(S,{content:e.modelValue?.response?.trace_id},null,8,["content"])])]),_:1})])):d("",!0),e.modelValue?.response?.success===void 0?(s(),l("div",xe,[t(E,{closable:!1,class:"info"},{template:c(()=>[t(h,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),m(" "+o(e.$t("hailuo.name.failure")),1)]),default:c(()=>[r("p",et,[t(h,{icon:"fa-solid fa-magic",class:"mr-1"}),m(" "+o(e.$t("hailuo.name.taskId"))+": "+o(e.modelValue?.id)+" ",1),t(S,{content:e.modelValue?.id},null,8,["content"])])]),_:1})])):d("",!0)])])}const ot=b(Ue,[["render",tt],["__scopeId","data-v-53d13da4"]]),st=y({name:"RecentPanel",components:{TaskPreview:ot,BotPlaceholder:re,NoTasks:Z,ScrollList:K},props:{loading:{type:Boolean,default:!1}},emits:["reach-top"],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.hailuo?.tasks,items:this.$store.state.hailuo?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),at={key:0},nt={key:2,class:"w-full h-full flex items-center justify-center"};function lt(e,n,p,_,w,T){const f=a("bot-placeholder"),g=a("task-preview"),u=a("scroll-list"),k=a("no-tasks");return s(),l(I,null,[e.tasks?.items===void 0?(s(),l("div",at,[t(f)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(s(),$(u,{key:1,ref:"scrollList",class:"tasks w-full h-full overflow-y-auto",loading:e.loading,onReachTop:n[0]||(n[0]=i=>e.$emit("reach-top"))},{default:c(()=>[(s(!0),l(I,null,U(e.tasks?.items,i=>(s(),$(g,{key:i.id,"model-value":i},null,8,["model-value"]))),128))]),_:1},8,["loading"])):d("",!0),e.tasks?.items?.length===0?(s(),l("div",nt,[t(k)])):d("",!0)],64)}const it=b(st,[["render",lt]]),rt=B("hailuo"),ct=y({name:"HailuoIndex",components:{ConfigPanel:Pe,Layout:G,RecentPanel:it},mixins:[z],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===L.Request},tasksLoading(){return this.$store.state.hailuo?.status?.getTasks===L.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,n){e?.items?.length>n?.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("hailuo/getService"),console.debug("end onGetService")},async onGetApplication(){console.debug("start onGetApplication"),await this.$store.dispatch("hailuo/getApplications"),console.debug("end onGetApplication"),await this.onGetTasks()},async onScrollDown(){await this.$nextTick();const e=this.getTasksScrollElement();e&&(e.scrollTop=e.scrollHeight)},async onGetTasks(e){if(this.applicationsLoading||this.fetchingTasks){console.debug("loading");return}console.debug("start onGetTasks",e);const{limit:n=5,createdAtMin:p,createdAtMax:_}=e||{};console.debug("limit",n,"createdAtMin",p,"createdAtMax",_),this.fetchingTasks=!0;try{await this.$store.dispatch("hailuo/getTasks",{limit:n,createdAtMin:p,createdAtMax:_})}finally{this.fetchingTasks=!1}},async onGenerate(){if(!H(this.uploadTracker,p=>this.$t(p),p=>v.warning(p)))return;const e={...this.config,callback_url:rt},n=this.credential?.token;if(!n){console.error("no token specified");return}v.info(this.$t("hailuo.message.startingTask")),R("hailuo",M.generate(e,{token:n})).then(()=>{v.success(this.$t("hailuo.message.startTaskSuccess"))}).catch(p=>{p?.response?.data?.error?.code===te?v.error(this.$t("hailuo.message.usedUp")):v.error(this.$t("hailuo.message.startTaskFailed"))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function ut(e,n,p,_,w,T){const f=a("config-panel"),g=a("recent-panel"),u=a("layout");return s(),$(u,null,{config:c(()=>[t(f,{onGenerate:e.onGenerate},null,8,["onGenerate"])]),result:c(()=>[t(g,{ref:"recentPanel",loading:e.loadingMore,onReachTop:e.onReachTop},null,8,["loading","onReachTop"])]),_:1})}const ro=b(ct,[["render",ut]]);export{ro as default};
1
+ import{L as G}from"./Hailuo-CnUcHX2i.js";import{F as P}from"./index.es-UMFIHXWc.js";import{H as b,bp as A,cs as R,aS as M,S as L,ct as B}from"./index-kok2V6cj.js";import{a as j}from"./hailuo-C8Dw-0xR.js";import{E as D,a as q}from"./index-DkLXeCmb.js";import{d as y,H as l,E as r,F as o,C as t,y as c,O as I,N as U,D as a,q as s,x as $,I as m,J as d,M as F,Q as V}from"./vendor-vue-NSDaktjZ.js";import{p as O}from"./pasteUploadMixin-BurWbGNQ.js";import{u as N,a as z,e as H}from"./uploadTrackerMixin--N-yU8Tl.js";import{I as J,S as K,l as Q}from"./pagination-EsDrj3yC.js";import{I as W}from"./ImagePreview-BjgklCqN.js";import{E as C}from"./index-D7cRCqFS.js";import{E as X}from"./index-yNToY-SP.js";import{E as v}from"./index-Buukpn8o.js";import{P as Y,N as Z}from"./NoTasks-DLn86jTC.js";import{C as x}from"./Consumption-BAwCyKhW.js";import{a as ee}from"./price-Beya5kld.js";import{b as te}from"./errorCode-Cqj9Td_Z.js";import{C as oe}from"./CopyToClipboard-B1L4gFQs.js";import{V as se}from"./VideoPlayer-lNCFIvjW.js";import{A as ae}from"./ApiCodeButton-Bu2nLY5J.js";import{E as ne}from"./index-BnUjW8_R.js";import{E as le}from"./index-CLIkNw25.js";import{E as ie}from"./index-CXgPGdvu.js";import{B as re}from"./BotPlaceholder-B5Bw1tlj.js";import"./index-1WxaVCeu.js";import"./vendor-axios-B8_nURbH.js";import"./vendor-dayjs-v0j1UNZp.js";import"./vendor-vue-router-Df5ITouH.js";import"./index-BYnYd0I7.js";import"./typescript-CfmcPqGh.js";import"./index-KTS__Qmb.js";import"./strings-beZM2Y-f.js";import"./isEqual-DBGyFRF0.js";import"./_Uint8Array-pGzioutB.js";import"./castArray-CJ8hzGGj.js";import"./use-form-item-CYiJWVVo.js";import"./index-WPH6eO9g.js";import"./index-DWWSYHUH.js";import"./debounce-G93CFNE1.js";import"./_baseIteratee-BCY-1IYO.js";import"./index-BI3c17YF.js";import"./highlight-DsFwBu4N.js";import"./index-BLjywj98.js";import"./vendor-highlight-lEWW1Jxd.js";import"./index-CNnBDoa1.js";import"./index-BuyEbX8F.js";import"./_baseClone-D8eUdaQd.js";import"./_initCloneObject-CAH0nDM3.js";import"./vue-plyr-BO2nlN4c.js";import"./index-BJr3r4qN.js";const ce=y({name:"ModelSelector",components:{ElSelect:q,ElOption:D},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||(this.value=j)}}),ue={class:"field"},me={class:"title font-bold"},de={class:"float-left"};function pe(e,n,p,_,w,T){const f=a("el-option"),g=a("el-select");return s(),l("div",ue,[r("h2",me,o(e.$t("hailuo.name.model")),1),t(g,{modelValue:e.value,"onUpdate:modelValue":n[0]||(n[0]=u=>e.value=u),class:"value",placeholder:e.$t("hailuo.placeholder.select"),clearable:""},{default:c(()=>[(s(!0),l(I,null,U(e.options,u=>(s(),$(f,{key:u.value,label:u.label,value:u.value},{default:c(()=>[r("span",de,o(u.label),1)]),_:2},1032,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const he=b(ce,[["render",pe],["__scopeId","data-v-a768fbd9"]]),fe=y({name:"StartImageUrlInput",components:{ElUpload:X,ElButton:C,InfoIcon:J,ImagePreview:W},mixins:[O,N],data(){return{fileList:[],uploadUrl:A()+"/api/v1/files/"}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e.url).filter(e=>e!==void 0)},value:{get(){return this.$store.state.hailuo?.config?.first_image_url},set(){const e=this.urls?.[0];this.$store.commit("hailuo/setConfig",{...this.$store.state.hailuo?.config,first_image_url:e})}}},mounted(){this.value||(this.value=void 0),this.onSetStartImageUrl()},methods:{onExceed(){v.warning(this.$t("hailuo.message.uploadStartImageExceed"))},onError(){v.error(this.$t("hailuo.message.uploadStartImageError"))},async onRemove(){v.error(this.$t("hailuo.message.uploadStartImageError"))},onSetStartImageUrl(){const e=this.urls?.[0];this.$store.commit("hailuo/setConfig",{...this.$store.state.hailuo?.config,first_image_url:e})},async onSuccess(){this.onSetStartImageUrl()}}}),ge={class:"relative"},_e={class:"flex justify-between"},$e={class:"flex justify-start items-center"},ve={class:"text-sm font-bold"};function ke(e,n,p,_,w,T){const f=a("info-icon"),g=a("image-preview"),u=a("el-button"),k=a("el-upload");return s(),l("div",ge,[r("div",_e,[r("div",$e,[r("span",ve,o(e.$t("hailuo.name.startImageUrl")),1),t(f,{content:e.$t("hailuo.description.startImageUrl"),class:"info"},null,8,["content"])])]),t(k,{ref:"uploader","file-list":e.fileList,"onUpdate:fileList":n[0]||(n[0]=i=>e.fileList=i),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:c(({file:i})=>[i.url&&i.percentage!==void 0?(s(),$(g,{key:0,url:i.url,name:i.name,percentage:i.percentage,onRemove:h=>e.fileList.splice(e.fileList.indexOf(i),1)},null,8,["url","name","percentage","onRemove"])):d("",!0)]),default:c(()=>[t(u,{size:"small",type:"primary",class:"btn btn-upload",round:""},{default:c(()=>[m(o(e.$t("hailuo.button.uploadStartImageUrl")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-remove","on-success","headers"])])}const be=b(fe,[["render",ke],["__scopeId","data-v-fbf49b06"]]),ye="",we=y({name:"PromptInput",components:{PromptTextarea:Y},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||(this.prompt=ye)}});function Te(e,n,p,_,w,T){const f=a("prompt-textarea");return s(),$(f,{modelValue:e.prompt,"onUpdate:modelValue":n[0]||(n[0]=g=>e.prompt=g),title:e.$t("hailuo.name.prompt"),info:e.$t("hailuo.description.prompt"),placeholder:e.$t("hailuo.placeholder.prompt")},null,8,["modelValue","title","info","placeholder"])}const Se=b(we,[["render",Te]]),Ve=y({name:"PresetPanel",components:{ElButton:C,FontAwesomeIcon:P,PromptInput:Se,StartImageUrlInput:be,ModelSelector:he,Consumption:x},emits:["generate"],computed:{config(){return this.$store.state.hailuo?.config},consumption(){return ee(this.config,this.service?.cost)},service(){return this.$store.state.hailuo?.service}},methods:{onGenerate(){this.$emit("generate")}}}),Ee={class:"flex flex-col h-full"},Ie={class:"flex-1 overflow-y-auto p-5"},Ce={class:"flex flex-col items-center justify-center px-5 pb-5"};function Le(e,n,p,_,w,T){const f=a("prompt-input"),g=a("model-selector"),u=a("start-image-url-input"),k=a("consumption"),i=a("font-awesome-icon"),h=a("el-button");return s(),l("div",Ee,[r("div",Ie,[t(f,{class:"mb-4"}),t(g,{class:"mb-4"}),e.config?.model==="minimax-i2v"?(s(),$(u,{key:0,class:"mb-2"})):d("",!0)]),r("div",Ce,[t(k,{value:e.consumption,service:e.service},null,8,["value","service"]),e.config?.video_url!==void 0||e.config?.custom?(s(),$(h,{key:0,type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:c(()=>[t(i,{icon:"fa-solid fa-magic",class:"mr-2"}),m(" "+o(e.$t("hailuo.button.extend")),1)]),_:1},8,["onClick"])):(s(),$(h,{key:1,type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:c(()=>[t(i,{icon:"fa-solid fa-magic",class:"mr-2"}),m(" "+o(e.$t("hailuo.button.generate")),1)]),_:1},8,["onClick"]))])])}const Pe=b(Ve,[["render",Le]]),Ue=y({name:"TaskPreview",components:{ElImage:ie,CopyToClipboard:oe,FontAwesomeIcon:P,ElAlert:le,VideoPlayer:se,ElTooltip:ne,ElButton:C,ApiCodeButton:ae},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")}}}),Ge={class:"preview"},Ae={class:"left"},Re={class:"main"},Me={class:"bot"},Be={class:"datetime"},je={class:"info"},De={key:0,class:"prompt mt-2"},qe={key:0},Fe={key:1},Oe={key:0,class:V({content:!0,failed:!0})},Ne={key:0,class:"mb-4"},ze={key:1,class:V({operations:!0,"mt-2":!0})},He={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Je={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Ke={key:1,class:"text-[var(--el-text-color-regular)] text-xs mb-0"},Qe={key:1,class:V({content:!0})},We={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Xe={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Ye={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Ze={class:"text-[var(--el-text-color-regular)] text-xs mb-0"},xe={key:2,class:V({content:!0})},et={class:"text-[var(--el-text-color-regular)] text-xs mb-0"};function tt(e,n,p,_,w,T){const f=a("el-image"),g=a("video-player"),u=a("el-button"),k=a("el-tooltip"),i=a("api-code-button"),h=a("font-awesome-icon"),S=a("copy-to-clipboard"),E=a("el-alert");return s(),l("div",Ge,[r("div",Ae,[t(f,{src:"https://cdn.acedata.cloud/0qg4gp.png",class:"avatar"})]),r("div",Re,[r("div",Me,[m(o(e.$t("hailuo.name.hailuoBot"))+" ",1),r("span",Be,o(e.$dayjs.format(""+new Date(parseFloat((e.modelValue?.created_at||"").toString())*1e3))),1)]),r("div",je,[e.modelValue?.request?.prompt?(s(),l("p",De,[m(o(e.modelValue?.request?.prompt)+" ",1),e.modelValue?.response?d("",!0):(s(),l("span",qe," - ("+o(e.$t("hailuo.status.pending"))+") ",1)),e.video?.state==="processing"||e.video?.state==="pending"||e.video?.state==="running"?(s(),l("span",Fe," - ("+o(e.$t("hailuo.status.processing"))+") ",1)):d("",!0)])):d("",!0)]),e.modelValue?.response?.success===!0?(s(),l("div",Oe,[e.video?.video_url?(s(),l("div",Ne,[t(g,{src:e.video?.video_url},null,8,["src"])])):d("",!0),e.video?(s(),l("div",ze,[t(k,{class:"box-item",effect:"dark",content:e.$t("hailuo.message.downloadVideo"),placement:"top-start"},{default:c(()=>[e.video?.video_url?(s(),$(u,{key:0,type:"info",size:"small",class:"mb-2",onClick:n[0]||(n[0]=F(mt=>e.onDownload(e.video?.video_url),["stop"]))},{default:c(()=>[m(o(e.$t("hailuo.button.download")),1)]),_:1})):d("",!0)]),_:1},8,["content"]),t(i,{path:"/hailuo/videos",body:e.modelValue?.request},null,8,["body"])])):d("",!0),t(E,{closable:!1,class:"mt-2 success"},{default:c(()=>[e.modelValue?.request?.model?(s(),l("p",He,[t(h,{icon:"fa-solid fa-hashtag",class:"mr-1"}),m(" "+o(e.$t("hailuo.name.model"))+": "+o(e.modelValue?.request?.model)+" ",1),t(S,{content:e.modelValue?.id},null,8,["content"])])):d("",!0),r("p",Je,[t(h,{icon:"fa-solid fa-magic",class:"mr-1"}),m(" "+o(e.$t("hailuo.name.taskId"))+": "+o(e.modelValue?.id)+" ",1),t(S,{content:e.modelValue?.id},null,8,["content"])]),e.modelValue?.elapsed?(s(),l("p",Ke,[t(h,{icon:"fa-solid fa-clock",class:"mr-1"}),m(" "+o(e.$t("hailuo.name.elapsed"))+": "+o(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):d("",!0)]),_:1})])):d("",!0),e.modelValue?.response?.success===!1?(s(),l("div",Qe,[t(E,{closable:!1,class:"failure"},{template:c(()=>[t(h,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),m(" "+o(e.$t("hailuo.name.failure")),1)]),default:c(()=>[r("p",We,[t(h,{icon:"fa-solid fa-magic",class:"mr-1"}),m(" "+o(e.$t("hailuo.name.taskId"))+": "+o(e.modelValue?.id)+" ",1),t(S,{content:e.modelValue?.id},null,8,["content"])]),r("p",Xe,[t(h,{icon:"fa-solid fa-circle-info",class:"mr-1"}),m(" "+o(e.$t("hailuo.name.failureReason"))+": "+o(e.modelValue?.response?.error?.message)+" ",1),t(S,{content:e.modelValue?.response?.error?.message},null,8,["content"])]),e.modelValue?.elapsed?(s(),l("p",Ye,[t(h,{icon:"fa-solid fa-clock",class:"mr-1"}),m(" "+o(e.$t("hailuo.name.elapsed"))+": "+o(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):d("",!0),r("p",Ze,[t(h,{icon:"fa-solid fa-hashtag",class:"mr-1"}),m(" "+o(e.$t("hailuo.name.traceId"))+": "+o(e.modelValue?.response?.trace_id)+" ",1),t(S,{content:e.modelValue?.response?.trace_id},null,8,["content"])])]),_:1})])):d("",!0),e.modelValue?.response?.success===void 0?(s(),l("div",xe,[t(E,{closable:!1,class:"info"},{template:c(()=>[t(h,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),m(" "+o(e.$t("hailuo.name.failure")),1)]),default:c(()=>[r("p",et,[t(h,{icon:"fa-solid fa-magic",class:"mr-1"}),m(" "+o(e.$t("hailuo.name.taskId"))+": "+o(e.modelValue?.id)+" ",1),t(S,{content:e.modelValue?.id},null,8,["content"])])]),_:1})])):d("",!0)])])}const ot=b(Ue,[["render",tt],["__scopeId","data-v-53d13da4"]]),st=y({name:"RecentPanel",components:{TaskPreview:ot,BotPlaceholder:re,NoTasks:Z,ScrollList:K},props:{loading:{type:Boolean,default:!1}},emits:["reach-top"],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.hailuo?.tasks,items:this.$store.state.hailuo?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),at={key:0},nt={key:2,class:"w-full h-full flex items-center justify-center"};function lt(e,n,p,_,w,T){const f=a("bot-placeholder"),g=a("task-preview"),u=a("scroll-list"),k=a("no-tasks");return s(),l(I,null,[e.tasks?.items===void 0?(s(),l("div",at,[t(f)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(s(),$(u,{key:1,ref:"scrollList",class:"tasks w-full h-full overflow-y-auto",loading:e.loading,onReachTop:n[0]||(n[0]=i=>e.$emit("reach-top"))},{default:c(()=>[(s(!0),l(I,null,U(e.tasks?.items,i=>(s(),$(g,{key:i.id,"model-value":i},null,8,["model-value"]))),128))]),_:1},8,["loading"])):d("",!0),e.tasks?.items?.length===0?(s(),l("div",nt,[t(k)])):d("",!0)],64)}const it=b(st,[["render",lt]]),rt=B("hailuo"),ct=y({name:"HailuoIndex",components:{ConfigPanel:Pe,Layout:G,RecentPanel:it},mixins:[z],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===L.Request},tasksLoading(){return this.$store.state.hailuo?.status?.getTasks===L.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,n){e?.items?.length>n?.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("hailuo/getService"),console.debug("end onGetService")},async onGetApplication(){console.debug("start onGetApplication"),await this.$store.dispatch("hailuo/getApplications"),console.debug("end onGetApplication"),await this.onGetTasks()},async onScrollDown(){await this.$nextTick();const e=this.getTasksScrollElement();e&&(e.scrollTop=e.scrollHeight)},async onGetTasks(e){if(this.applicationsLoading||this.fetchingTasks){console.debug("loading");return}console.debug("start onGetTasks",e);const{limit:n=5,createdAtMin:p,createdAtMax:_}=e||{};console.debug("limit",n,"createdAtMin",p,"createdAtMax",_),this.fetchingTasks=!0;try{await this.$store.dispatch("hailuo/getTasks",{limit:n,createdAtMin:p,createdAtMax:_})}finally{this.fetchingTasks=!1}},async onGenerate(){if(!H(this.uploadTracker,p=>this.$t(p),p=>v.warning(p)))return;const e={...this.config,callback_url:rt},n=this.credential?.token;if(!n){console.error("no token specified");return}v.info(this.$t("hailuo.message.startingTask")),R("hailuo",M.generate(e,{token:n})).then(()=>{v.success(this.$t("hailuo.message.startTaskSuccess"))}).catch(p=>{p?.response?.data?.error?.code===te?v.error(this.$t("hailuo.message.usedUp")):v.error(this.$t("hailuo.message.startTaskFailed"))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function ut(e,n,p,_,w,T){const f=a("config-panel"),g=a("recent-panel"),u=a("layout");return s(),$(u,null,{config:c(()=>[t(f,{onGenerate:e.onGenerate},null,8,["onGenerate"])]),result:c(()=>[t(g,{ref:"recentPanel",loading:e.loadingMore,onReachTop:e.onReachTop},null,8,["loading","onReachTop"])]),_:1})}const ro=b(ct,[["render",ut]]);export{ro as default};
@@ -1 +1 @@
1
- import{F as z}from"./index.es-fM0biscR.js";import{E as P}from"./index-CXGm2ibp.js";import{E as x}from"./index-DYQToXUU.js";import{d as y,H as n,E as m,z as O,C as s,y as _,D as i,q as a,x as I,F as o,I as u,O as S,N as M,J as d,M as K,Q as L}from"./vendor-vue-NSDaktjZ.js";import{H as w,bp as X,cC as U,cD as J,cE as Q,cF as B,cG as G,cH as N,cI as Y,cJ as ee,cK as te,cL as se,cM as oe,cN as ae,cO as R,cP as ie,cQ as ne,cs as re,aZ as D,S as j,ct as le}from"./index-BitdtvW1.js";import{P as me,N as ce}from"./NoTasks-DYAWTz-D.js";import{u as pe,a as ue,e as de}from"./uploadTrackerMixin--N-yU8Tl.js";import{I as q,S as ge,l as he}from"./pagination-CDMeT271.js";import{I as F}from"./ImagePreview-Deaq21aE.js";import{E as fe}from"./index-B5zfRlKe.js";import{E as V}from"./index-DY9n5RWp.js";import{C as _e}from"./Consumption-Dvylkuyr.js";import{a as $e}from"./price-UzqaC8kS.js";import{E as H,a as Z,b as be}from"./index-CVCfk6pt.js";import{E as ve}from"./index-CAnSJQ4u.js";import{E as ke}from"./index-Cy8wLIr0.js";import{b as Ee}from"./errorCode-Cqj9Td_Z.js";import{C as Se}from"./CopyToClipboard-3JBcjf6f.js";import{I as Ie}from"./ImageWrapper-DImeHzsC.js";import{A as ye}from"./ApiCodeButton-9XDDLdNe.js";import{E as we}from"./index-CRROw2v3.js";import{E as Ve}from"./index-XLYMNUFJ.js";import{E as Ae}from"./index-BkchfnNA.js";import{B as Me}from"./BotPlaceholder-Bm3iFf5b.js";import"./use-form-item-CaXGkw6S.js";import"./index-BuyEbX8F.js";import"./vendor-axios-B8_nURbH.js";import"./vendor-dayjs-v0j1UNZp.js";import"./vendor-vue-router-Df5ITouH.js";import"./index-cn5_DmaE.js";import"./typescript-CdFsS8fD.js";import"./index-BKgRYY8E.js";import"./index-IEnCZwtg.js";import"./highlight-DEv6Uzjh.js";import"./index-BLjywj98.js";import"./vendor-highlight-lEWW1Jxd.js";import"./index-CCeJfLsu.js";import"./_baseClone-BR0qWb-t.js";import"./_Uint8Array-CRC1hUw5.js";import"./_initCloneObject-EbmJQUEy.js";import"./isEqual-CMrgrIDS.js";import"./index-BFUf5YVt.js";import"./strings-beZM2Y-f.js";import"./castArray-D90oh5Za.js";import"./debounce-B16-iZx6.js";import"./_baseIteratee-BQgCC_-_.js";import"./index-Bo7zkVzy.js";import"./index-Cu41y2Fl.js";import"./validator-BIWRmSMB.js";import"./index-BHVQW8Q2.js";const Ge=y({name:"LayoutNanobanana",components:{ElDrawer:x,ElButton:P,FontAwesomeIcon:z},data(){return{drawer:!1}}}),Te={class:"main flex flex-row flex-1"},ze={class:"config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]"},Pe={class:"result h-full p-6 flex-1 flex flex-col min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]"};function Le(e,t,c,r,h,b){const p=i("font-awesome-icon"),g=i("el-button"),v=i("el-drawer");return a(),n("div",Te,[m("div",ze,[O(e.$slots,"config",{},void 0,!0)]),m("div",Pe,[O(e.$slots,"result",{},void 0,!0)]),s(g,{circle:"",class:"menu",onClick:t[0]||(t[0]=f=>e.drawer=!0)},{default:_(()=>[s(p,{icon:"fa-solid fa-magic"})]),_:1}),s(v,{modelValue:e.drawer,"onUpdate:modelValue":t[1]||(t[1]=f=>e.drawer=f),direction:"ltr","with-header":!1,size:"340px",class:"drawer"},{default:_(()=>[O(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const Ce=w(Ge,[["render",Le],["__scopeId","data-v-e480ada6"]]),Oe="",Ue=y({name:"PromptInput",components:{PromptTextarea:me},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||(this.prompt=Oe)}});function qe(e,t,c,r,h,b){const p=i("prompt-textarea");return a(),I(p,{modelValue:e.prompt,"onUpdate:modelValue":t[0]||(t[0]=g=>e.prompt=g),title:e.$t("openaiimage.name.prompt"),info:e.$t("openaiimage.description.prompt"),placeholder:e.$t("openaiimage.placeholder.prompt")},null,8,["modelValue","title","info","placeholder"])}const Ne=w(Ue,[["render",qe]]),Re=y({name:"ImageUrlsInput",components:{ElUpload:fe,ElButton:P,InfoIcon:q,ImagePreview:F,FontAwesomeIcon:z},mixins:[pe],data(){return{fileList:[],uploadUrl:X()+"/api/v1/files/",suppressWatch:!1}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e?.response?.file_url).filter(e=>!!e)},value(){return this.$store.state.openaiimage?.config?.image_urls}},watch:{value:{immediate:!0,handler(e){if(this.suppressWatch)return;if(!e||e.length===0){const r=(this.fileList||[]).filter(h=>!h?.response?.file_url);this.fileList=r.length?r:[];return}const t=[];e.forEach(r=>{const h=this.fileList.find(b=>b?.response?.file_url===r||b?.url===r);h?t.push(h):t.push({name:r.split("/").pop()||r,url:r,status:"success",percentage:100,response:{file_url:r}})}),(this.fileList||[]).filter(r=>!r?.response?.file_url).forEach(r=>{t.some(b=>b===r||b?.url===r?.url||b?.response?.file_url===r?.response?.file_url)||t.push(r)}),this.fileList=t}}},mounted(){},methods:{onChange(e){if(!e?.url&&e?.raw)try{e.url=URL.createObjectURL(e.raw)}catch{}},onRemove(e){if(e?.url&&typeof e.url=="string"&&e.url.startsWith("blob:"))try{URL.revokeObjectURL(e.url)}catch{}this.onSetImageUrls()},onExceed(){V.warning(this.$t("openaiimage.message.uploadImageExceed"))},onError(){V.error(this.$t("openaiimage.message.uploadImageError"))},onSetImageUrls(){const e=this.urls;this.suppressWatch=!0,this.$store.commit("openaiimage/setConfig",{...this.$store.state.openaiimage?.config,image_urls:e}),this.$nextTick(()=>{this.suppressWatch=!1})},async onSuccess(e,t){e?.file_url&&(t.url=e.file_url,t.response=e),this.onSetImageUrls()},onRemovePreview(e,t){if(this.fileList.splice(e,1),t?.url&&typeof t.url=="string"&&t.url.startsWith("blob:"))try{URL.revokeObjectURL(t.url)}catch{}this.onSetImageUrls()}}}),De={class:"field flex items-center justify-between"},je={class:"title font-bold text-[14px] mb-[10px]"},We={class:"upload-wrapper flex flex-col items-start gap-[8px]"},Be={class:"controls flex items-center"},Fe={class:"file-list flex flex-wrap gap-[10px]"};function He(e,t,c,r,h,b){const p=i("font-awesome-icon"),g=i("el-button"),v=i("el-upload"),f=i("info-icon"),k=i("image-preview");return a(),n(S,null,[m("div",De,[m("h2",je,o(e.$t("openaiimage.name.imageUrls")),1),m("div",We,[m("div",Be,[s(v,{"file-list":e.fileList,"onUpdate:fileList":t[0]||(t[0]=$=>e.fileList=$),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:_(()=>[s(g,{size:"small",type:"primary",round:""},{default:_(()=>[s(p,{icon:"fa-solid fa-upload",class:"mr-1"}),u(" "+o(e.$t("openaiimage.button.uploadImageUrls")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-success","on-change","on-remove","headers"]),s(f,{content:e.$t("openaiimage.description.imageUrls"),class:"ml-2"},null,8,["content"])])])]),m("div",Fe,[(a(!0),n(S,null,M(e.fileList,($,l)=>(a(),I(k,{key:$.uid||$?.response?.file_url||$.url||l,url:$.url||$?.response?.file_url,name:$.name,percentage:$.percentage,onRemove:E=>e.onRemovePreview(l,$)},null,8,["url","name","percentage","onRemove"]))),128))])],64)}const Ze=w(Re,[["render",He]]),xe=y({name:"OpenAIImageModelSelector",components:{ElSelect:Z,ElOption:H,InfoIcon:q},data(){return{options:[{value:J,label:this.$t("openaiimage.model.gptImage1")},{value:Q,label:this.$t("openaiimage.model.gptImage15")},{value:B,label:this.$t("openaiimage.model.gptImage2")}]}},computed:{value:{get(){return this.$store.state.openaiimage?.config?.model},set(e){this.$store.commit("openaiimage/setConfig",{...this.$store.state.openaiimage?.config,model:e})}},modelDescription(){return this.$t("openaiimage.description.model")}},mounted(){this.value||(this.value=U)}}),Ke={class:"field"},Xe={class:"label"},Je={class:"box"},Qe={class:"title font-bold"};function Ye(e,t,c,r,h,b){const p=i("info-icon"),g=i("el-option"),v=i("el-select");return a(),n("div",Ke,[m("div",Xe,[m("div",Je,[m("h2",Qe,o(e.$t("openaiimage.name.model")),1),s(p,{content:e.modelDescription,class:"info"},null,8,["content"])])]),s(v,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=f=>e.value=f),class:"value",placeholder:e.$t("openaiimage.placeholder.select")},{default:_(()=>[(a(!0),n(S,null,M(e.options,f=>(a(),I(g,{key:f.value,label:f.label,value:f.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const et=w(xe,[["render",Ye],["__scopeId","data-v-cec771bd"]]);function tt(e){if(!e)return;const t=/^(\d+)x(\d+)$/.exec(e);if(t)return{w:Number(t[1]),h:Number(t[2])}}const st=y({name:"OpenAIImageSizeSelector",components:{ElSelect:Z,ElOption:H,ElOptionGroup:be,ElSwitch:ke,ElInputNumber:ve,InfoIcon:q},data(){return{customMode:!1,customWidth:1024,customHeight:1024}},computed:{model(){return this.$store.state.openaiimage?.config?.model||U},storedSize(){return this.$store.state.openaiimage?.config?.size},customSupported(){return ie.includes(this.model)},presets(){return R[this.model]??R[U]??[]},presetGroups(){return this.model===B?[{label:this.$t("openaiimage.sizeGroup.standard1k"),options:se},{label:this.$t("openaiimage.sizeGroup.preset2k"),options:oe},{label:this.$t("openaiimage.sizeGroup.preset4k"),options:ae}]:[{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{const t=this.presets[0]??G;this.commitSize(t)}}},presetValue:{get(){const e=this.storedSize;return e&&this.presets.includes(e)?e:this.presets[0]??G},set(e){this.customMode=!1,this.commitSize(e)}},multiple(){return te},minSide(){return ee},maxSide(){return Y},customError(){const 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>N?this.$t("openaiimage.error.customSizePixels",{pixels:N.toLocaleString()}):""}},watch:{model:{immediate:!1,handler(){if(!this.customSupported){this.customMode=!1;const t=this.storedSize;(!t||!this.presets.includes(t))&&this.commitSize(this.presets[0]??G);return}const e=this.storedSize;if(this.customMode&&!this.customError){this.commitSize(`${this.customWidth}x${this.customHeight}`);return}(!e||!this.presets.includes(e))&&this.commitSize(this.presets[0]??G)}},customWidth(){this.syncCustomToStore()},customHeight(){this.syncCustomToStore()}},mounted(){if(!this.storedSize){this.commitSize(this.presets[0]??G);return}const e=tt(this.storedSize);e&&this.customSupported&&!this.presets.includes(this.storedSize)&&(this.customMode=!0,this.customWidth=e.w,this.customHeight=e.h)},methods:{commitSize(e){this.$store.commit("openaiimage/setConfig",{...this.$store.state.openaiimage?.config,size:e})},syncCustomToStore(){this.useCustom&&(this.customError||this.commitSize(`${this.customWidth}x${this.customHeight}`))}}}),ot={class:"resolution"},at={class:"field"},it={class:"label"},nt={class:"box"},rt={class:"title font-bold"},lt={class:"field custom-toggle"},mt={class:"label"},ct={class:"box"},pt={class:"title font-bold"},ut={key:0,class:"custom-inputs"},dt={class:"row"},gt={class:"row-label"},ht={class:"row"},ft={class:"row-label"},_t={key:0,class:"error"};function $t(e,t,c,r,h,b){const p=i("info-icon"),g=i("el-option"),v=i("el-option-group"),f=i("el-select"),k=i("el-switch"),$=i("el-input-number");return a(),n("div",ot,[m("div",at,[m("div",it,[m("div",nt,[m("h2",rt,o(e.$t("openaiimage.name.size")),1),s(p,{content:e.$t("openaiimage.description.size"),class:"info"},null,8,["content"])])]),s(f,{modelValue:e.presetValue,"onUpdate:modelValue":t[0]||(t[0]=l=>e.presetValue=l),class:"value",placeholder:e.$t("openaiimage.placeholder.select"),disabled:e.useCustom},{default:_(()=>[(a(!0),n(S,null,M(e.presetGroups,l=>(a(),I(v,{key:l.label,label:l.label},{default:_(()=>[(a(!0),n(S,null,M(l.options,E=>(a(),I(g,{key:E,label:E,value:E},null,8,["label","value"]))),128))]),_:2},1032,["label"]))),128))]),_:1},8,["modelValue","placeholder","disabled"])]),e.customSupported?(a(),n(S,{key:0},[m("div",lt,[m("div",mt,[m("div",ct,[m("h2",pt,o(e.$t("openaiimage.name.customSize")),1),s(p,{content:e.$t("openaiimage.description.customSize"),class:"info"},null,8,["content"])])]),s(k,{modelValue:e.useCustom,"onUpdate:modelValue":t[1]||(t[1]=l=>e.useCustom=l),class:"value-switch"},null,8,["modelValue"])]),e.useCustom?(a(),n("div",ut,[m("div",dt,[m("span",gt,o(e.$t("openaiimage.name.width")),1),s($,{modelValue:e.customWidth,"onUpdate:modelValue":t[2]||(t[2]=l=>e.customWidth=l),class:"row-input",min:e.minSide,max:e.maxSide,step:e.multiple,"step-strictly":!0,"controls-position":"right"},null,8,["modelValue","min","max","step"])]),m("div",ht,[m("span",ft,o(e.$t("openaiimage.name.height")),1),s($,{modelValue:e.customHeight,"onUpdate:modelValue":t[3]||(t[3]=l=>e.customHeight=l),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?(a(),n("div",_t,o(e.customError),1)):d("",!0)])):d("",!0)],64)):d("",!0)])}const bt=w(st,[["render",$t],["__scopeId","data-v-218b58cb"]]),vt=y({name:"ConfigPanel",components:{ElButton:P,FontAwesomeIcon:z,PromptInput:Ne,Consumption:_e,ImageUrlsInput:Ze,ModelSelector:et,ResolutionSelector:bt},emits:["generate"],computed:{config(){return this.$store.state.openaiimage?.config},consumption(){const e={...this.config||{}};return $e({...e},this.service?.cost)},service(){return this.$store.state.openaiimage?.service}},methods:{onGenerate(){this.$emit("generate")}}}),kt={class:"flex flex-col h-full"},Et={class:"flex-1 overflow-y-auto p-5"},St={class:"flex flex-col items-center justify-center px-5 pb-5"};function It(e,t,c,r,h,b){const p=i("model-selector"),g=i("resolution-selector"),v=i("prompt-input"),f=i("image-urls-input"),k=i("consumption"),$=i("font-awesome-icon"),l=i("el-button");return a(),n("div",kt,[m("div",Et,[s(p,{class:"mb-4"}),s(g,{class:"mb-4"}),s(v,{class:"mb-4"}),s(f,{class:"mb-4"})]),m("div",St,[s(k,{value:e.consumption,service:e.service},null,8,["value","service"]),s(l,{type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:_(()=>[s($,{icon:"fa-solid fa-magic",class:"mr-2"}),u(" "+o(e.$t("openaiimage.button.generate")),1)]),_:1},8,["onClick"])])])}const yt=w(vt,[["render",It]]),wt=y({name:"TaskPreview",components:{ElImage:Ae,CopyToClipboard:Se,FontAwesomeIcon:z,ElAlert:Ve,ImageWrapper:Ie,ElButton:P,ElTooltip:we,ImagePreview:F,ApiCodeButton:ye},props:{modelValue:{type:Object,required:!0}},setup(){return{OPENAIIMAGE_LOGO:ne}},computed:{openaiimagePath(){return this.modelValue?.request?.action==="edit"?"/openai/images/edits":"/openai/images/generations"},images(){const e=[];return Array.isArray(this.modelValue?.response?.data)&&this.modelValue?.response?.data?.forEach(t=>{const c=t;if(c?.image_url||c?.url){e.push(c);return}c?.b64_json&&e.push({...c,url:`data:image/png;base64,${c.b64_json}`})}),e},referenceImages(){const e=this.modelValue?.request;if(!e)return[];const t=Array.isArray(e.image_urls)?e.image_urls:[];if(t.length>0)return t.filter(r=>typeof r=="string"&&r.length>0);const c=e.image;return Array.isArray(c)?c.filter(r=>typeof r=="string"&&r.length>0):typeof c=="string"&&c.length>0?[c]:[]}},methods:{onEdit(e){if(!e)return;console.debug("Edit image:",e);const t={...this.$store.state.openaiimage?.config||{}};t.image_urls=[e],this.$store.commit("openaiimage/setConfig",t)}}}),Vt={class:"preview"},At={class:"left"},Mt={class:"main"},Gt={class:"bot"},Tt={class:"datetime"},zt={class:"info"},Pt={key:0,class:"flex justify-start items-center gap-2 mt-2 w-full overflow-x-auto"},Lt={key:1,class:"prompt mt-2"},Ct={key:0},Ot={key:0,class:L({content:!0,failed:!0})},Ut={class:"flex justify-start items-center gap-4 w-full overflow-x-auto"},qt={class:L({operations:!0,"mt-2":!0,"mb-2":!0})},Nt={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Rt={key:1,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Dt={key:2,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},jt={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"},Bt={key:4,class:"text-[var(--el-text-color-regular)] text-xs mb-0"},Ft={key:1,class:L({content:!0})},Ht={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Zt={key:1,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},xt={key:2,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Kt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Xt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Jt={key:3,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Qt={key:4,class:"text-[var(--el-text-color-regular)] text-xs mb-0"},Yt={key:2,class:L({content:!0})},es={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},ts={key:1,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},ss={key:2,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},os={class:"text-[var(--el-text-color-regular)] text-xs mb-2"};function as(e,t,c,r,h,b){const p=i("el-image"),g=i("image-preview"),v=i("image-wrapper"),f=i("el-button"),k=i("el-tooltip"),$=i("api-code-button"),l=i("font-awesome-icon"),E=i("copy-to-clipboard"),C=i("el-alert");return a(),n("div",Vt,[m("div",At,[s(p,{src:e.OPENAIIMAGE_LOGO,class:"avatar"},null,8,["src"])]),m("div",Mt,[m("div",Gt,[u(o(e.$t("openaiimage.name.openaiimageBot"))+" ",1),m("span",Tt,o(e.$dayjs.format(""+new Date(parseFloat((e.modelValue?.created_at||"").toString())*1e3))),1)]),m("div",zt,[e.referenceImages.length>0?(a(),n("div",Pt,[(a(!0),n(S,null,M(e.referenceImages,(A,T)=>(a(),I(g,{key:T,url:A,name:`image-${T+1}`,closable:!1},null,8,["url","name"]))),128))])):d("",!0),e.modelValue?.request?.prompt?(a(),n("p",Lt,[u(o(e.modelValue?.request?.prompt)+" ",1),e.modelValue?.response?d("",!0):(a(),n("span",Ct," - ("+o(e.$t("openaiimage.status.pending"))+") ",1))])):d("",!0)]),e.modelValue?.response?.success===!0?(a(),n("div",Ot,[m("div",Ut,[(a(!0),n(S,null,M(e.images,(A,T)=>(a(),I(v,{key:T,src:A?.image_url||A?.url||"","raw-src":A?.image_url||A?.url||""},null,8,["src","raw-src"]))),128))]),m("div",qt,[s(k,{class:"box-item",effect:"dark",content:e.$t("common.button.edit"),placement:"top-start"},{default:_(()=>[s(f,{type:"info",size:"small",class:"btn-action",onClick:t[0]||(t[0]=K(A=>e.onEdit(e.images?.[0]?.image_url||e.images?.[0]?.url),["stop"]))},{default:_(()=>[u(o(e.$t("common.button.edit")),1)]),_:1})]),_:1},8,["content"]),s($,{path:e.openaiimagePath,body:e.modelValue?.request},null,8,["path","body"])]),s(C,{closable:!1,class:"mt-2 success"},{default:_(()=>[e.modelValue?.request?.model?(a(),n("p",Nt,[s(l,{icon:"fa-solid fa-cube",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.model"))+": "+o(e.modelValue?.request?.model),1)])):d("",!0),e.modelValue?.request?.size?(a(),n("p",Rt,[s(l,{icon:"fa-solid fa-image",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.size"))+": "+o(e.modelValue?.request?.size),1)])):d("",!0),e.modelValue?.request?.action?(a(),n("p",Dt,[s(l,{icon:"fa-solid fa-bolt",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.task"))+": "+o(e.modelValue?.request?.action==="generate"?e.$t("openaiimage.name.generate"):e.$t("openaiimage.name.edits")),1)])):d("",!0),m("p",jt,[s(l,{icon:"fa-solid fa-magic",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.taskId"))+": "+o(e.modelValue?.id)+" ",1),s(E,{content:e.modelValue?.id,class:"btn-copy inline-block"},null,8,["content"])]),e.modelValue?.elapsed?(a(),n("p",Wt,[s(l,{icon:"fa-solid fa-clock",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.elapsed"))+": "+o(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):d("",!0),e.modelValue?.response?.trace_id?(a(),n("p",Bt,[s(l,{icon:"fa-solid fa-hashtag",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.traceId"))+": "+o(e.modelValue?.response?.trace_id)+" ",1),s(E,{content:e.modelValue?.response?.trace_id,class:"btn-copy inline-block"},null,8,["content"])])):d("",!0)]),_:1})])):e.modelValue?.response?.success===!1?(a(),n("div",Ft,[s(C,{closable:!1,class:"failure"},{template:_(()=>[s(l,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.failure")),1)]),default:_(()=>[e.modelValue?.request?.model?(a(),n("p",Ht,[s(l,{icon:"fa-solid fa-cube",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.model"))+": "+o(e.modelValue?.request?.model),1)])):d("",!0),e.modelValue?.request?.size?(a(),n("p",Zt,[s(l,{icon:"fa-solid fa-image",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.size"))+": "+o(e.modelValue?.request?.size),1)])):d("",!0),e.modelValue?.request?.action?(a(),n("p",xt,[s(l,{icon:"fa-solid fa-bolt",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.task"))+": "+o(e.modelValue?.request?.action==="generate"?e.$t("openaiimage.name.generate"):e.$t("openaiimage.name.edits")),1)])):d("",!0),m("p",Kt,[s(l,{icon:"fa-solid fa-magic",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.taskId"))+": "+o(e.modelValue?.id)+" ",1),s(E,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])]),m("p",Xt,[s(l,{icon:"fa-solid fa-circle-info",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.failureReason"))+": "+o(e.modelValue?.response?.error?.message)+" ",1),s(E,{content:e.modelValue?.response?.error?.message,class:"btn-copy"},null,8,["content"])]),e.modelValue?.elapsed?(a(),n("p",Jt,[s(l,{icon:"fa-solid fa-clock",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.elapsed"))+": "+o(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):d("",!0),e.modelValue?.response?.trace_id?(a(),n("p",Qt,[s(l,{icon:"fa-solid fa-hashtag",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.traceId"))+": "+o(e.modelValue?.response?.trace_id)+" ",1),s(E,{content:e.modelValue?.response?.trace_id,class:"btn-copy"},null,8,["content"])])):d("",!0)]),_:1})])):(a(),n("div",Yt,[s(C,{closable:!1,class:"info"},{template:_(()=>[s(l,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.failure")),1)]),default:_(()=>[e.modelValue?.request?.model?(a(),n("p",es,[s(l,{icon:"fa-solid fa-cube",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.model"))+": "+o(e.modelValue?.request?.model),1)])):d("",!0),e.modelValue?.request?.size?(a(),n("p",ts,[s(l,{icon:"fa-solid fa-image",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.size"))+": "+o(e.modelValue?.request?.size),1)])):d("",!0),e.modelValue?.request?.action?(a(),n("p",ss,[s(l,{icon:"fa-solid fa-bolt",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.task"))+": "+o(e.modelValue?.request?.action==="generate"?e.$t("openaiimage.name.generate"):e.$t("openaiimage.name.edits")),1)])):d("",!0),m("p",os,[s(l,{icon:"fa-solid fa-magic",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.taskId"))+": "+o(e.modelValue?.id)+" ",1),s(E,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])])]),_:1})]))])])}const is=w(wt,[["render",as],["__scopeId","data-v-8057d8e2"]]),ns=y({name:"RecentPanel",components:{TaskPreview:is,BotPlaceholder:Me,NoTasks:ce,ScrollList:ge},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?.()}}}),rs={key:0},ls={key:2,class:"w-full h-full flex items-center justify-center"};function ms(e,t,c,r,h,b){const p=i("bot-placeholder"),g=i("task-preview"),v=i("scroll-list"),f=i("no-tasks");return a(),n(S,null,[e.tasks?.items===void 0?(a(),n("div",rs,[s(p)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(a(),I(v,{key:1,ref:"scrollList",class:"tasks h-full w-full overflow-y-auto",loading:e.loading,onReachTop:t[0]||(t[0]=k=>e.$emit("reach-top"))},{default:_(()=>[(a(!0),n(S,null,M(e.tasks?.items,k=>(a(),I(g,{key:k.id,"model-value":k},null,8,["model-value"]))),128))]),_:1},8,["loading"])):d("",!0),e.tasks?.items?.length===0?(a(),n("div",ls,[s(f)])):d("",!0)],64)}const cs=w(ns,[["render",ms]]),W=le("openaiimage"),ps=y({name:"OpenAIImageIndex",components:{ConfigPanel:yt,Layout:Ce,RecentPanel:cs},mixins:[ue],inject:["initialized"],data(){return{task:void 0,job:0,loading:!1}},computed:{applicationsLoading(){return this.$store.state.openaiimage?.status?.getApplications===j.Request},tasksLoading(){return this.$store.state.openaiimage?.status?.getTasks===j.Request},credential(){return this.$store.state.openaiimage?.credential},config(){return this.$store.state.openaiimage?.config},application(){return this.$store.state.openaiimage?.application},tasks(){return this.$store.state.openaiimage?.tasks}},watch:{tasks:{handler(e,t){e?.items?.length>t?.items?.length&&console.debug("new tasks detected")},deep:!0},initialized:{async handler(e){e&&(console.debug("layout initialized"),await this.onGetTasks(),await this.onScrollDown(),this.job=window.setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){window.clearInterval(this.job)},methods:{async onReachTop(){await he({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();const e=this.getTasksScrollElement();e&&(e.scrollTop=e.scrollHeight)},async onGetTasks(e){if(this.applicationsLoading||this.tasksLoading){console.debug("loading");return}console.debug("start onGetTasks",e);const{limit:t=20,createdAtMin:c,createdAtMax:r}=e||{};console.debug("limit",t,"createdAtMin",c,"createdAtMax",r),await this.$store.dispatch("openaiimage/getTasks",{limit:t,createdAtMin:c,createdAtMax:r})},async onGenerate(){if(!de(this.uploadTracker,p=>this.$t(p),p=>V.warning(p)))return;const e={...this.config||{}},t=Array.isArray(e?.image_urls)&&e.image_urls.length>0;if(!this.hasText(e.prompt)){V.error(this.$t("openaiimage.message.promptRequired"));return}e.prompt=e.prompt.trim(),!t&&"image_urls"in e&&delete e.image_urls;const c={...e,action:"generate",callback_url:W},r={action:"edit",model:e?.model,prompt:e?.prompt,size:e?.size,image_urls:e?.image_urls||[],callback_url:W},h=this.credential?.token;if(!h){console.error("no token specified");return}V.info(this.$t("openaiimage.message.startingTask")),re("openaiimage",t?D.edit(r,{token:h}):D.generate(c,{token:h})).then(p=>{console.debug("task accepted",p.data?.task_id),V.success(this.$t("openaiimage.message.startTaskSuccess"))}).catch(p=>{const g=p?.response?.data;g?.error?.code===Ee?V.error(this.$t("openaiimage.message.usedUp")):V.error(this.$t("openaiimage.message.startTaskFailed")+(g?.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 us(e,t,c,r,h,b){const p=i("config-panel"),g=i("recent-panel"),v=i("layout");return a(),I(v,null,{config:_(()=>[s(p,{onGenerate:e.onGenerate},null,8,["onGenerate"])]),result:_(()=>[s(g,{ref:"recentPanel",loading:e.loading,onReachTop:e.onReachTop},null,8,["loading","onReachTop"])]),_:1})}const mo=w(ps,[["render",us]]);export{mo as default};
1
+ import{F as z}from"./index.es-UMFIHXWc.js";import{E as P}from"./index-D7cRCqFS.js";import{E as x}from"./index-1WxaVCeu.js";import{d as y,H as n,E as m,z as O,C as s,y as _,D as i,q as a,x as I,F as o,I as u,O as S,N as M,J as d,M as K,Q as L}from"./vendor-vue-NSDaktjZ.js";import{H as w,bp as X,cC as U,cD as J,cE as Q,cF as B,cG as G,cH as N,cI as Y,cJ as ee,cK as te,cL as se,cM as oe,cN as ae,cO as R,cP as ie,cQ as ne,cs as re,aZ as D,S as j,ct as le}from"./index-kok2V6cj.js";import{P as me,N as ce}from"./NoTasks-DLn86jTC.js";import{u as pe,a as ue,e as de}from"./uploadTrackerMixin--N-yU8Tl.js";import{I as q,S as ge,l as he}from"./pagination-EsDrj3yC.js";import{I as F}from"./ImagePreview-BjgklCqN.js";import{E as fe}from"./index-yNToY-SP.js";import{E as V}from"./index-Buukpn8o.js";import{C as _e}from"./Consumption-BAwCyKhW.js";import{a as $e}from"./price-Beya5kld.js";import{E as H,a as Z,b as be}from"./index-DkLXeCmb.js";import{E as ve}from"./index-BfmYQvxy.js";import{E as ke}from"./index-BDNA2DMu.js";import{b as Ee}from"./errorCode-Cqj9Td_Z.js";import{C as Se}from"./CopyToClipboard-B1L4gFQs.js";import{I as Ie}from"./ImageWrapper-Gdemv0z3.js";import{A as ye}from"./ApiCodeButton-Bu2nLY5J.js";import{E as we}from"./index-BnUjW8_R.js";import{E as Ve}from"./index-CLIkNw25.js";import{E as Ae}from"./index-CXgPGdvu.js";import{B as Me}from"./BotPlaceholder-B5Bw1tlj.js";import"./use-form-item-CYiJWVVo.js";import"./index-BuyEbX8F.js";import"./vendor-axios-B8_nURbH.js";import"./vendor-dayjs-v0j1UNZp.js";import"./vendor-vue-router-Df5ITouH.js";import"./index-WPH6eO9g.js";import"./typescript-CfmcPqGh.js";import"./index-KTS__Qmb.js";import"./index-DWWSYHUH.js";import"./highlight-DsFwBu4N.js";import"./index-BLjywj98.js";import"./vendor-highlight-lEWW1Jxd.js";import"./index-CNnBDoa1.js";import"./_baseClone-D8eUdaQd.js";import"./_Uint8Array-pGzioutB.js";import"./_initCloneObject-CAH0nDM3.js";import"./isEqual-DBGyFRF0.js";import"./index-BYnYd0I7.js";import"./strings-beZM2Y-f.js";import"./castArray-CJ8hzGGj.js";import"./debounce-G93CFNE1.js";import"./_baseIteratee-BCY-1IYO.js";import"./index-BI3c17YF.js";import"./index-Cu41y2Fl.js";import"./validator-7URr4p3I.js";import"./index-BJr3r4qN.js";const Ge=y({name:"LayoutNanobanana",components:{ElDrawer:x,ElButton:P,FontAwesomeIcon:z},data(){return{drawer:!1}}}),Te={class:"main flex flex-row flex-1"},ze={class:"config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]"},Pe={class:"result h-full p-6 flex-1 flex flex-col min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]"};function Le(e,t,c,r,h,b){const p=i("font-awesome-icon"),g=i("el-button"),v=i("el-drawer");return a(),n("div",Te,[m("div",ze,[O(e.$slots,"config",{},void 0,!0)]),m("div",Pe,[O(e.$slots,"result",{},void 0,!0)]),s(g,{circle:"",class:"menu",onClick:t[0]||(t[0]=f=>e.drawer=!0)},{default:_(()=>[s(p,{icon:"fa-solid fa-magic"})]),_:1}),s(v,{modelValue:e.drawer,"onUpdate:modelValue":t[1]||(t[1]=f=>e.drawer=f),direction:"ltr","with-header":!1,size:"340px",class:"drawer"},{default:_(()=>[O(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const Ce=w(Ge,[["render",Le],["__scopeId","data-v-e480ada6"]]),Oe="",Ue=y({name:"PromptInput",components:{PromptTextarea:me},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||(this.prompt=Oe)}});function qe(e,t,c,r,h,b){const p=i("prompt-textarea");return a(),I(p,{modelValue:e.prompt,"onUpdate:modelValue":t[0]||(t[0]=g=>e.prompt=g),title:e.$t("openaiimage.name.prompt"),info:e.$t("openaiimage.description.prompt"),placeholder:e.$t("openaiimage.placeholder.prompt")},null,8,["modelValue","title","info","placeholder"])}const Ne=w(Ue,[["render",qe]]),Re=y({name:"ImageUrlsInput",components:{ElUpload:fe,ElButton:P,InfoIcon:q,ImagePreview:F,FontAwesomeIcon:z},mixins:[pe],data(){return{fileList:[],uploadUrl:X()+"/api/v1/files/",suppressWatch:!1}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e?.response?.file_url).filter(e=>!!e)},value(){return this.$store.state.openaiimage?.config?.image_urls}},watch:{value:{immediate:!0,handler(e){if(this.suppressWatch)return;if(!e||e.length===0){const r=(this.fileList||[]).filter(h=>!h?.response?.file_url);this.fileList=r.length?r:[];return}const t=[];e.forEach(r=>{const h=this.fileList.find(b=>b?.response?.file_url===r||b?.url===r);h?t.push(h):t.push({name:r.split("/").pop()||r,url:r,status:"success",percentage:100,response:{file_url:r}})}),(this.fileList||[]).filter(r=>!r?.response?.file_url).forEach(r=>{t.some(b=>b===r||b?.url===r?.url||b?.response?.file_url===r?.response?.file_url)||t.push(r)}),this.fileList=t}}},mounted(){},methods:{onChange(e){if(!e?.url&&e?.raw)try{e.url=URL.createObjectURL(e.raw)}catch{}},onRemove(e){if(e?.url&&typeof e.url=="string"&&e.url.startsWith("blob:"))try{URL.revokeObjectURL(e.url)}catch{}this.onSetImageUrls()},onExceed(){V.warning(this.$t("openaiimage.message.uploadImageExceed"))},onError(){V.error(this.$t("openaiimage.message.uploadImageError"))},onSetImageUrls(){const e=this.urls;this.suppressWatch=!0,this.$store.commit("openaiimage/setConfig",{...this.$store.state.openaiimage?.config,image_urls:e}),this.$nextTick(()=>{this.suppressWatch=!1})},async onSuccess(e,t){e?.file_url&&(t.url=e.file_url,t.response=e),this.onSetImageUrls()},onRemovePreview(e,t){if(this.fileList.splice(e,1),t?.url&&typeof t.url=="string"&&t.url.startsWith("blob:"))try{URL.revokeObjectURL(t.url)}catch{}this.onSetImageUrls()}}}),De={class:"field flex items-center justify-between"},je={class:"title font-bold text-[14px] mb-[10px]"},We={class:"upload-wrapper flex flex-col items-start gap-[8px]"},Be={class:"controls flex items-center"},Fe={class:"file-list flex flex-wrap gap-[10px]"};function He(e,t,c,r,h,b){const p=i("font-awesome-icon"),g=i("el-button"),v=i("el-upload"),f=i("info-icon"),k=i("image-preview");return a(),n(S,null,[m("div",De,[m("h2",je,o(e.$t("openaiimage.name.imageUrls")),1),m("div",We,[m("div",Be,[s(v,{"file-list":e.fileList,"onUpdate:fileList":t[0]||(t[0]=$=>e.fileList=$),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:_(()=>[s(g,{size:"small",type:"primary",round:""},{default:_(()=>[s(p,{icon:"fa-solid fa-upload",class:"mr-1"}),u(" "+o(e.$t("openaiimage.button.uploadImageUrls")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-success","on-change","on-remove","headers"]),s(f,{content:e.$t("openaiimage.description.imageUrls"),class:"ml-2"},null,8,["content"])])])]),m("div",Fe,[(a(!0),n(S,null,M(e.fileList,($,l)=>(a(),I(k,{key:$.uid||$?.response?.file_url||$.url||l,url:$.url||$?.response?.file_url,name:$.name,percentage:$.percentage,onRemove:E=>e.onRemovePreview(l,$)},null,8,["url","name","percentage","onRemove"]))),128))])],64)}const Ze=w(Re,[["render",He]]),xe=y({name:"OpenAIImageModelSelector",components:{ElSelect:Z,ElOption:H,InfoIcon:q},data(){return{options:[{value:J,label:this.$t("openaiimage.model.gptImage1")},{value:Q,label:this.$t("openaiimage.model.gptImage15")},{value:B,label:this.$t("openaiimage.model.gptImage2")}]}},computed:{value:{get(){return this.$store.state.openaiimage?.config?.model},set(e){this.$store.commit("openaiimage/setConfig",{...this.$store.state.openaiimage?.config,model:e})}},modelDescription(){return this.$t("openaiimage.description.model")}},mounted(){this.value||(this.value=U)}}),Ke={class:"field"},Xe={class:"label"},Je={class:"box"},Qe={class:"title font-bold"};function Ye(e,t,c,r,h,b){const p=i("info-icon"),g=i("el-option"),v=i("el-select");return a(),n("div",Ke,[m("div",Xe,[m("div",Je,[m("h2",Qe,o(e.$t("openaiimage.name.model")),1),s(p,{content:e.modelDescription,class:"info"},null,8,["content"])])]),s(v,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=f=>e.value=f),class:"value",placeholder:e.$t("openaiimage.placeholder.select")},{default:_(()=>[(a(!0),n(S,null,M(e.options,f=>(a(),I(g,{key:f.value,label:f.label,value:f.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const et=w(xe,[["render",Ye],["__scopeId","data-v-cec771bd"]]);function tt(e){if(!e)return;const t=/^(\d+)x(\d+)$/.exec(e);if(t)return{w:Number(t[1]),h:Number(t[2])}}const st=y({name:"OpenAIImageSizeSelector",components:{ElSelect:Z,ElOption:H,ElOptionGroup:be,ElSwitch:ke,ElInputNumber:ve,InfoIcon:q},data(){return{customMode:!1,customWidth:1024,customHeight:1024}},computed:{model(){return this.$store.state.openaiimage?.config?.model||U},storedSize(){return this.$store.state.openaiimage?.config?.size},customSupported(){return ie.includes(this.model)},presets(){return R[this.model]??R[U]??[]},presetGroups(){return this.model===B?[{label:this.$t("openaiimage.sizeGroup.standard1k"),options:se},{label:this.$t("openaiimage.sizeGroup.preset2k"),options:oe},{label:this.$t("openaiimage.sizeGroup.preset4k"),options:ae}]:[{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{const t=this.presets[0]??G;this.commitSize(t)}}},presetValue:{get(){const e=this.storedSize;return e&&this.presets.includes(e)?e:this.presets[0]??G},set(e){this.customMode=!1,this.commitSize(e)}},multiple(){return te},minSide(){return ee},maxSide(){return Y},customError(){const 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>N?this.$t("openaiimage.error.customSizePixels",{pixels:N.toLocaleString()}):""}},watch:{model:{immediate:!1,handler(){if(!this.customSupported){this.customMode=!1;const t=this.storedSize;(!t||!this.presets.includes(t))&&this.commitSize(this.presets[0]??G);return}const e=this.storedSize;if(this.customMode&&!this.customError){this.commitSize(`${this.customWidth}x${this.customHeight}`);return}(!e||!this.presets.includes(e))&&this.commitSize(this.presets[0]??G)}},customWidth(){this.syncCustomToStore()},customHeight(){this.syncCustomToStore()}},mounted(){if(!this.storedSize){this.commitSize(this.presets[0]??G);return}const e=tt(this.storedSize);e&&this.customSupported&&!this.presets.includes(this.storedSize)&&(this.customMode=!0,this.customWidth=e.w,this.customHeight=e.h)},methods:{commitSize(e){this.$store.commit("openaiimage/setConfig",{...this.$store.state.openaiimage?.config,size:e})},syncCustomToStore(){this.useCustom&&(this.customError||this.commitSize(`${this.customWidth}x${this.customHeight}`))}}}),ot={class:"resolution"},at={class:"field"},it={class:"label"},nt={class:"box"},rt={class:"title font-bold"},lt={class:"field custom-toggle"},mt={class:"label"},ct={class:"box"},pt={class:"title font-bold"},ut={key:0,class:"custom-inputs"},dt={class:"row"},gt={class:"row-label"},ht={class:"row"},ft={class:"row-label"},_t={key:0,class:"error"};function $t(e,t,c,r,h,b){const p=i("info-icon"),g=i("el-option"),v=i("el-option-group"),f=i("el-select"),k=i("el-switch"),$=i("el-input-number");return a(),n("div",ot,[m("div",at,[m("div",it,[m("div",nt,[m("h2",rt,o(e.$t("openaiimage.name.size")),1),s(p,{content:e.$t("openaiimage.description.size"),class:"info"},null,8,["content"])])]),s(f,{modelValue:e.presetValue,"onUpdate:modelValue":t[0]||(t[0]=l=>e.presetValue=l),class:"value",placeholder:e.$t("openaiimage.placeholder.select"),disabled:e.useCustom},{default:_(()=>[(a(!0),n(S,null,M(e.presetGroups,l=>(a(),I(v,{key:l.label,label:l.label},{default:_(()=>[(a(!0),n(S,null,M(l.options,E=>(a(),I(g,{key:E,label:E,value:E},null,8,["label","value"]))),128))]),_:2},1032,["label"]))),128))]),_:1},8,["modelValue","placeholder","disabled"])]),e.customSupported?(a(),n(S,{key:0},[m("div",lt,[m("div",mt,[m("div",ct,[m("h2",pt,o(e.$t("openaiimage.name.customSize")),1),s(p,{content:e.$t("openaiimage.description.customSize"),class:"info"},null,8,["content"])])]),s(k,{modelValue:e.useCustom,"onUpdate:modelValue":t[1]||(t[1]=l=>e.useCustom=l),class:"value-switch"},null,8,["modelValue"])]),e.useCustom?(a(),n("div",ut,[m("div",dt,[m("span",gt,o(e.$t("openaiimage.name.width")),1),s($,{modelValue:e.customWidth,"onUpdate:modelValue":t[2]||(t[2]=l=>e.customWidth=l),class:"row-input",min:e.minSide,max:e.maxSide,step:e.multiple,"step-strictly":!0,"controls-position":"right"},null,8,["modelValue","min","max","step"])]),m("div",ht,[m("span",ft,o(e.$t("openaiimage.name.height")),1),s($,{modelValue:e.customHeight,"onUpdate:modelValue":t[3]||(t[3]=l=>e.customHeight=l),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?(a(),n("div",_t,o(e.customError),1)):d("",!0)])):d("",!0)],64)):d("",!0)])}const bt=w(st,[["render",$t],["__scopeId","data-v-218b58cb"]]),vt=y({name:"ConfigPanel",components:{ElButton:P,FontAwesomeIcon:z,PromptInput:Ne,Consumption:_e,ImageUrlsInput:Ze,ModelSelector:et,ResolutionSelector:bt},emits:["generate"],computed:{config(){return this.$store.state.openaiimage?.config},consumption(){const e={...this.config||{}};return $e({...e},this.service?.cost)},service(){return this.$store.state.openaiimage?.service}},methods:{onGenerate(){this.$emit("generate")}}}),kt={class:"flex flex-col h-full"},Et={class:"flex-1 overflow-y-auto p-5"},St={class:"flex flex-col items-center justify-center px-5 pb-5"};function It(e,t,c,r,h,b){const p=i("model-selector"),g=i("resolution-selector"),v=i("prompt-input"),f=i("image-urls-input"),k=i("consumption"),$=i("font-awesome-icon"),l=i("el-button");return a(),n("div",kt,[m("div",Et,[s(p,{class:"mb-4"}),s(g,{class:"mb-4"}),s(v,{class:"mb-4"}),s(f,{class:"mb-4"})]),m("div",St,[s(k,{value:e.consumption,service:e.service},null,8,["value","service"]),s(l,{type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:_(()=>[s($,{icon:"fa-solid fa-magic",class:"mr-2"}),u(" "+o(e.$t("openaiimage.button.generate")),1)]),_:1},8,["onClick"])])])}const yt=w(vt,[["render",It]]),wt=y({name:"TaskPreview",components:{ElImage:Ae,CopyToClipboard:Se,FontAwesomeIcon:z,ElAlert:Ve,ImageWrapper:Ie,ElButton:P,ElTooltip:we,ImagePreview:F,ApiCodeButton:ye},props:{modelValue:{type:Object,required:!0}},setup(){return{OPENAIIMAGE_LOGO:ne}},computed:{openaiimagePath(){return this.modelValue?.request?.action==="edit"?"/openai/images/edits":"/openai/images/generations"},images(){const e=[];return Array.isArray(this.modelValue?.response?.data)&&this.modelValue?.response?.data?.forEach(t=>{const c=t;if(c?.image_url||c?.url){e.push(c);return}c?.b64_json&&e.push({...c,url:`data:image/png;base64,${c.b64_json}`})}),e},referenceImages(){const e=this.modelValue?.request;if(!e)return[];const t=Array.isArray(e.image_urls)?e.image_urls:[];if(t.length>0)return t.filter(r=>typeof r=="string"&&r.length>0);const c=e.image;return Array.isArray(c)?c.filter(r=>typeof r=="string"&&r.length>0):typeof c=="string"&&c.length>0?[c]:[]}},methods:{onEdit(e){if(!e)return;console.debug("Edit image:",e);const t={...this.$store.state.openaiimage?.config||{}};t.image_urls=[e],this.$store.commit("openaiimage/setConfig",t)}}}),Vt={class:"preview"},At={class:"left"},Mt={class:"main"},Gt={class:"bot"},Tt={class:"datetime"},zt={class:"info"},Pt={key:0,class:"flex justify-start items-center gap-2 mt-2 w-full overflow-x-auto"},Lt={key:1,class:"prompt mt-2"},Ct={key:0},Ot={key:0,class:L({content:!0,failed:!0})},Ut={class:"flex justify-start items-center gap-4 w-full overflow-x-auto"},qt={class:L({operations:!0,"mt-2":!0,"mb-2":!0})},Nt={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Rt={key:1,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Dt={key:2,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},jt={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"},Bt={key:4,class:"text-[var(--el-text-color-regular)] text-xs mb-0"},Ft={key:1,class:L({content:!0})},Ht={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Zt={key:1,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},xt={key:2,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Kt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Xt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Jt={key:3,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Qt={key:4,class:"text-[var(--el-text-color-regular)] text-xs mb-0"},Yt={key:2,class:L({content:!0})},es={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},ts={key:1,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},ss={key:2,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},os={class:"text-[var(--el-text-color-regular)] text-xs mb-2"};function as(e,t,c,r,h,b){const p=i("el-image"),g=i("image-preview"),v=i("image-wrapper"),f=i("el-button"),k=i("el-tooltip"),$=i("api-code-button"),l=i("font-awesome-icon"),E=i("copy-to-clipboard"),C=i("el-alert");return a(),n("div",Vt,[m("div",At,[s(p,{src:e.OPENAIIMAGE_LOGO,class:"avatar"},null,8,["src"])]),m("div",Mt,[m("div",Gt,[u(o(e.$t("openaiimage.name.openaiimageBot"))+" ",1),m("span",Tt,o(e.$dayjs.format(""+new Date(parseFloat((e.modelValue?.created_at||"").toString())*1e3))),1)]),m("div",zt,[e.referenceImages.length>0?(a(),n("div",Pt,[(a(!0),n(S,null,M(e.referenceImages,(A,T)=>(a(),I(g,{key:T,url:A,name:`image-${T+1}`,closable:!1},null,8,["url","name"]))),128))])):d("",!0),e.modelValue?.request?.prompt?(a(),n("p",Lt,[u(o(e.modelValue?.request?.prompt)+" ",1),e.modelValue?.response?d("",!0):(a(),n("span",Ct," - ("+o(e.$t("openaiimage.status.pending"))+") ",1))])):d("",!0)]),e.modelValue?.response?.success===!0?(a(),n("div",Ot,[m("div",Ut,[(a(!0),n(S,null,M(e.images,(A,T)=>(a(),I(v,{key:T,src:A?.image_url||A?.url||"","raw-src":A?.image_url||A?.url||""},null,8,["src","raw-src"]))),128))]),m("div",qt,[s(k,{class:"box-item",effect:"dark",content:e.$t("common.button.edit"),placement:"top-start"},{default:_(()=>[s(f,{type:"info",size:"small",class:"btn-action",onClick:t[0]||(t[0]=K(A=>e.onEdit(e.images?.[0]?.image_url||e.images?.[0]?.url),["stop"]))},{default:_(()=>[u(o(e.$t("common.button.edit")),1)]),_:1})]),_:1},8,["content"]),s($,{path:e.openaiimagePath,body:e.modelValue?.request},null,8,["path","body"])]),s(C,{closable:!1,class:"mt-2 success"},{default:_(()=>[e.modelValue?.request?.model?(a(),n("p",Nt,[s(l,{icon:"fa-solid fa-cube",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.model"))+": "+o(e.modelValue?.request?.model),1)])):d("",!0),e.modelValue?.request?.size?(a(),n("p",Rt,[s(l,{icon:"fa-solid fa-image",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.size"))+": "+o(e.modelValue?.request?.size),1)])):d("",!0),e.modelValue?.request?.action?(a(),n("p",Dt,[s(l,{icon:"fa-solid fa-bolt",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.task"))+": "+o(e.modelValue?.request?.action==="generate"?e.$t("openaiimage.name.generate"):e.$t("openaiimage.name.edits")),1)])):d("",!0),m("p",jt,[s(l,{icon:"fa-solid fa-magic",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.taskId"))+": "+o(e.modelValue?.id)+" ",1),s(E,{content:e.modelValue?.id,class:"btn-copy inline-block"},null,8,["content"])]),e.modelValue?.elapsed?(a(),n("p",Wt,[s(l,{icon:"fa-solid fa-clock",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.elapsed"))+": "+o(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):d("",!0),e.modelValue?.response?.trace_id?(a(),n("p",Bt,[s(l,{icon:"fa-solid fa-hashtag",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.traceId"))+": "+o(e.modelValue?.response?.trace_id)+" ",1),s(E,{content:e.modelValue?.response?.trace_id,class:"btn-copy inline-block"},null,8,["content"])])):d("",!0)]),_:1})])):e.modelValue?.response?.success===!1?(a(),n("div",Ft,[s(C,{closable:!1,class:"failure"},{template:_(()=>[s(l,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.failure")),1)]),default:_(()=>[e.modelValue?.request?.model?(a(),n("p",Ht,[s(l,{icon:"fa-solid fa-cube",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.model"))+": "+o(e.modelValue?.request?.model),1)])):d("",!0),e.modelValue?.request?.size?(a(),n("p",Zt,[s(l,{icon:"fa-solid fa-image",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.size"))+": "+o(e.modelValue?.request?.size),1)])):d("",!0),e.modelValue?.request?.action?(a(),n("p",xt,[s(l,{icon:"fa-solid fa-bolt",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.task"))+": "+o(e.modelValue?.request?.action==="generate"?e.$t("openaiimage.name.generate"):e.$t("openaiimage.name.edits")),1)])):d("",!0),m("p",Kt,[s(l,{icon:"fa-solid fa-magic",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.taskId"))+": "+o(e.modelValue?.id)+" ",1),s(E,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])]),m("p",Xt,[s(l,{icon:"fa-solid fa-circle-info",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.failureReason"))+": "+o(e.modelValue?.response?.error?.message)+" ",1),s(E,{content:e.modelValue?.response?.error?.message,class:"btn-copy"},null,8,["content"])]),e.modelValue?.elapsed?(a(),n("p",Jt,[s(l,{icon:"fa-solid fa-clock",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.elapsed"))+": "+o(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):d("",!0),e.modelValue?.response?.trace_id?(a(),n("p",Qt,[s(l,{icon:"fa-solid fa-hashtag",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.traceId"))+": "+o(e.modelValue?.response?.trace_id)+" ",1),s(E,{content:e.modelValue?.response?.trace_id,class:"btn-copy"},null,8,["content"])])):d("",!0)]),_:1})])):(a(),n("div",Yt,[s(C,{closable:!1,class:"info"},{template:_(()=>[s(l,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.failure")),1)]),default:_(()=>[e.modelValue?.request?.model?(a(),n("p",es,[s(l,{icon:"fa-solid fa-cube",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.model"))+": "+o(e.modelValue?.request?.model),1)])):d("",!0),e.modelValue?.request?.size?(a(),n("p",ts,[s(l,{icon:"fa-solid fa-image",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.size"))+": "+o(e.modelValue?.request?.size),1)])):d("",!0),e.modelValue?.request?.action?(a(),n("p",ss,[s(l,{icon:"fa-solid fa-bolt",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.task"))+": "+o(e.modelValue?.request?.action==="generate"?e.$t("openaiimage.name.generate"):e.$t("openaiimage.name.edits")),1)])):d("",!0),m("p",os,[s(l,{icon:"fa-solid fa-magic",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.taskId"))+": "+o(e.modelValue?.id)+" ",1),s(E,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])])]),_:1})]))])])}const is=w(wt,[["render",as],["__scopeId","data-v-8057d8e2"]]),ns=y({name:"RecentPanel",components:{TaskPreview:is,BotPlaceholder:Me,NoTasks:ce,ScrollList:ge},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?.()}}}),rs={key:0},ls={key:2,class:"w-full h-full flex items-center justify-center"};function ms(e,t,c,r,h,b){const p=i("bot-placeholder"),g=i("task-preview"),v=i("scroll-list"),f=i("no-tasks");return a(),n(S,null,[e.tasks?.items===void 0?(a(),n("div",rs,[s(p)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(a(),I(v,{key:1,ref:"scrollList",class:"tasks h-full w-full overflow-y-auto",loading:e.loading,onReachTop:t[0]||(t[0]=k=>e.$emit("reach-top"))},{default:_(()=>[(a(!0),n(S,null,M(e.tasks?.items,k=>(a(),I(g,{key:k.id,"model-value":k},null,8,["model-value"]))),128))]),_:1},8,["loading"])):d("",!0),e.tasks?.items?.length===0?(a(),n("div",ls,[s(f)])):d("",!0)],64)}const cs=w(ns,[["render",ms]]),W=le("openaiimage"),ps=y({name:"OpenAIImageIndex",components:{ConfigPanel:yt,Layout:Ce,RecentPanel:cs},mixins:[ue],inject:["initialized"],data(){return{task:void 0,job:0,loading:!1}},computed:{applicationsLoading(){return this.$store.state.openaiimage?.status?.getApplications===j.Request},tasksLoading(){return this.$store.state.openaiimage?.status?.getTasks===j.Request},credential(){return this.$store.state.openaiimage?.credential},config(){return this.$store.state.openaiimage?.config},application(){return this.$store.state.openaiimage?.application},tasks(){return this.$store.state.openaiimage?.tasks}},watch:{tasks:{handler(e,t){e?.items?.length>t?.items?.length&&console.debug("new tasks detected")},deep:!0},initialized:{async handler(e){e&&(console.debug("layout initialized"),await this.onGetTasks(),await this.onScrollDown(),this.job=window.setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){window.clearInterval(this.job)},methods:{async onReachTop(){await he({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();const e=this.getTasksScrollElement();e&&(e.scrollTop=e.scrollHeight)},async onGetTasks(e){if(this.applicationsLoading||this.tasksLoading){console.debug("loading");return}console.debug("start onGetTasks",e);const{limit:t=20,createdAtMin:c,createdAtMax:r}=e||{};console.debug("limit",t,"createdAtMin",c,"createdAtMax",r),await this.$store.dispatch("openaiimage/getTasks",{limit:t,createdAtMin:c,createdAtMax:r})},async onGenerate(){if(!de(this.uploadTracker,p=>this.$t(p),p=>V.warning(p)))return;const e={...this.config||{}},t=Array.isArray(e?.image_urls)&&e.image_urls.length>0;if(!this.hasText(e.prompt)){V.error(this.$t("openaiimage.message.promptRequired"));return}e.prompt=e.prompt.trim(),!t&&"image_urls"in e&&delete e.image_urls;const c={...e,action:"generate",callback_url:W},r={action:"edit",model:e?.model,prompt:e?.prompt,size:e?.size,image_urls:e?.image_urls||[],callback_url:W},h=this.credential?.token;if(!h){console.error("no token specified");return}V.info(this.$t("openaiimage.message.startingTask")),re("openaiimage",t?D.edit(r,{token:h}):D.generate(c,{token:h})).then(p=>{console.debug("task accepted",p.data?.task_id),V.success(this.$t("openaiimage.message.startTaskSuccess"))}).catch(p=>{const g=p?.response?.data;g?.error?.code===Ee?V.error(this.$t("openaiimage.message.usedUp")):V.error(this.$t("openaiimage.message.startTaskFailed")+(g?.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 us(e,t,c,r,h,b){const p=i("config-panel"),g=i("recent-panel"),v=i("layout");return a(),I(v,null,{config:_(()=>[s(p,{onGenerate:e.onGenerate},null,8,["onGenerate"])]),result:_(()=>[s(g,{ref:"recentPanel",loading:e.loading,onReachTop:e.onReachTop},null,8,["loading","onReachTop"])]),_:1})}const mo=w(ps,[["render",us]]);export{mo as default};
@@ -1 +1 @@
1
- import{F as R}from"./index.es-fM0biscR.js";import{E as S}from"./index-CXGm2ibp.js";import{E as D}from"./index-DYQToXUU.js";import{d as v,H as r,E as i,z as C,C as t,y as c,D as o,q as s,F as a,O as I,N as U,x as $,I as h,J as m,M,Q as L}from"./vendor-vue-NSDaktjZ.js";import{H as b,bp as O,cs as B,b5 as j,S as G,ct as F}from"./index-BitdtvW1.js";import{a as N,b as q}from"./wan-DKq-jYOo.js";import{E as A,a as P}from"./index-CVCfk6pt.js";import{p as z}from"./pasteUploadMixin-BurWbGNQ.js";import{u as W,a as H,e as J}from"./uploadTrackerMixin--N-yU8Tl.js";import{I as K,S as Q,l as X}from"./pagination-CDMeT271.js";import{I as Y}from"./ImagePreview-Deaq21aE.js";import{E as Z}from"./index-B5zfRlKe.js";import{E as T}from"./index-DY9n5RWp.js";import{P as x,N as ee}from"./NoTasks-DYAWTz-D.js";import{C as te}from"./Consumption-Dvylkuyr.js";import{a as oe}from"./price-UzqaC8kS.js";import{b as se}from"./errorCode-Cqj9Td_Z.js";import{C as ne}from"./CopyToClipboard-3JBcjf6f.js";import{V as ae}from"./VideoPlayer-Br2yW1lu.js";import{A as le}from"./ApiCodeButton-9XDDLdNe.js";import{E as re}from"./index-CRROw2v3.js";import{E as ie}from"./index-XLYMNUFJ.js";import{E as ce}from"./index-BkchfnNA.js";import{B as de}from"./BotPlaceholder-Bm3iFf5b.js";import"./use-form-item-CaXGkw6S.js";import"./index-BuyEbX8F.js";import"./vendor-axios-B8_nURbH.js";import"./vendor-dayjs-v0j1UNZp.js";import"./vendor-vue-router-Df5ITouH.js";import"./index-BFUf5YVt.js";import"./typescript-CdFsS8fD.js";import"./index-BKgRYY8E.js";import"./strings-beZM2Y-f.js";import"./isEqual-CMrgrIDS.js";import"./_Uint8Array-CRC1hUw5.js";import"./castArray-D90oh5Za.js";import"./index-cn5_DmaE.js";import"./index-IEnCZwtg.js";import"./debounce-B16-iZx6.js";import"./_baseIteratee-BQgCC_-_.js";import"./index-Bo7zkVzy.js";import"./highlight-DEv6Uzjh.js";import"./index-BLjywj98.js";import"./vendor-highlight-lEWW1Jxd.js";import"./index-CCeJfLsu.js";import"./_baseClone-BR0qWb-t.js";import"./_initCloneObject-EbmJQUEy.js";import"./vue-plyr-BO2nlN4c.js";import"./index-BHVQW8Q2.js";const ue=v({name:"LayoutWan",components:{ElDrawer:D,ElButton:S,FontAwesomeIcon:R},data(){return{drawer:!1}}}),pe={class:"main flex flex-row flex-1"},me={class:"config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]"},fe={class:"result h-full p-6 flex-1 flex flex-col min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]"};function he(e,n,p,_,k,y){const d=o("font-awesome-icon"),u=o("el-button"),l=o("el-drawer");return s(),r("div",pe,[i("div",me,[C(e.$slots,"config",{},void 0,!0)]),i("div",fe,[C(e.$slots,"result",{},void 0,!0)]),t(u,{circle:"",class:"menu",onClick:n[0]||(n[0]=w=>e.drawer=!0)},{default:c(()=>[t(d,{icon:"fa-solid fa-magic"})]),_:1}),t(l,{modelValue:e.drawer,"onUpdate:modelValue":n[1]||(n[1]=w=>e.drawer=w),direction:"ltr","with-header":!1,size:"340px"},{default:c(()=>[C(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const _e=b(ue,[["render",he],["__scopeId","data-v-3b0702a7"]]),ge=v({name:"ModelSelector",components:{ElSelect:P,ElOption:A},data(){return{}},computed:{options(){return[{value:"wan2.6-t2v",label:this.$t("wan.button.modelT2v")},{value:"wan2.6-i2v",label:this.$t("wan.button.modelI2v")},{value:"wan2.6-i2v-flash",label:this.$t("wan.button.modelI2vFlash")},{value:"wan2.6-r2v",label:this.$t("wan.button.modelR2v")}]},value:{get(){return this.$store.state.wan?.config?.model},set(e){this.$store.commit("wan/setConfig",{...this.$store.state.wan?.config,model:e})}}},mounted(){this.value||(this.value=N)}}),$e={class:"field"},we={class:"title font-bold"},ve={class:"float-left"};function be(e,n,p,_,k,y){const d=o("el-option"),u=o("el-select");return s(),r("div",$e,[i("h2",we,a(e.$t("wan.name.model")),1),t(u,{modelValue:e.value,"onUpdate:modelValue":n[0]||(n[0]=l=>e.value=l),class:"value",placeholder:e.$t("wan.placeholder.select"),clearable:""},{default:c(()=>[(s(!0),r(I,null,U(e.options,l=>(s(),$(d,{key:l.value,label:l.label,value:l.value},{default:c(()=>[i("span",ve,a(l.label),1)]),_:2},1032,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const ke=b(ge,[["render",be],["__scopeId","data-v-eb090beb"]]),ye="720p",Ve=v({name:"ResolutionSelector",components:{ElSelect:P,ElOption:A},computed:{options(){return[{value:"480p",label:this.$t("wan.name.resolution480p")},{value:"720p",label:this.$t("wan.name.resolution720p")},{value:"1080p",label:this.$t("wan.name.resolution1080p")}]},value:{get(){return this.$store.state.wan?.config?.resolution},set(e){this.$store.commit("wan/setConfig",{...this.$store.state.wan?.config,resolution:e})}}},mounted(){this.value||(this.value=ye)}}),Te={class:"field"},Ee={class:"title font-bold"},Ie={class:"float-left"};function Se(e,n,p,_,k,y){const d=o("el-option"),u=o("el-select");return s(),r("div",Te,[i("h2",Ee,a(e.$t("wan.name.resolution")),1),t(u,{modelValue:e.value,"onUpdate:modelValue":n[0]||(n[0]=l=>e.value=l),class:"value",placeholder:e.$t("wan.placeholder.select"),clearable:""},{default:c(()=>[(s(!0),r(I,null,U(e.options,l=>(s(),$(d,{key:l.value,label:l.label,value:l.value},{default:c(()=>[i("span",Ie,a(l.label),1)]),_:2},1032,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Ue=b(Ve,[["render",Se],["__scopeId","data-v-3e39f44e"]]),Le=5,Ce=v({name:"DurationSelector",components:{ElSelect:P,ElOption:A},computed:{options(){return[{value:5,label:this.$t("wan.name.duration5s")},{value:10,label:this.$t("wan.name.duration10s")},{value:15,label:this.$t("wan.name.duration15s")}]},value:{get(){return this.$store.state.wan?.config?.duration},set(e){this.$store.commit("wan/setConfig",{...this.$store.state.wan?.config,duration:e})}}},mounted(){this.value||(this.value=Le)}}),Re={class:"field"},Ae={class:"title font-bold"},Pe={class:"float-left"};function Ge(e,n,p,_,k,y){const d=o("el-option"),u=o("el-select");return s(),r("div",Re,[i("h2",Ae,a(e.$t("wan.name.duration")),1),t(u,{modelValue:e.value,"onUpdate:modelValue":n[0]||(n[0]=l=>e.value=l),class:"value",placeholder:e.$t("wan.placeholder.select"),clearable:""},{default:c(()=>[(s(!0),r(I,null,U(e.options,l=>(s(),$(d,{key:l.value,label:l.label,value:l.value},{default:c(()=>[i("span",Pe,a(l.label),1)]),_:2},1032,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const De=b(Ce,[["render",Ge],["__scopeId","data-v-5f35a2cf"]]),Me=v({name:"ImageUrlInput",components:{ElUpload:Z,ElButton:S,InfoIcon:K,ImagePreview:Y},mixins:[z,W],data(){return{fileList:[],uploadUrl:O()+"/api/v1/files/"}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e.url).filter(e=>e!==void 0)},value:{get(){return this.$store.state.wan?.config?.image_url},set(){const e=this.urls?.[0];this.$store.commit("wan/setConfig",{...this.$store.state.wan?.config,image_url:e})}}},mounted(){this.value||(this.value=void 0),this.onSetImageUrl()},methods:{onExceed(){T.warning(this.$t("wan.message.uploadImageExceed"))},onError(){T.error(this.$t("wan.message.uploadImageError"))},async onRemove(){T.error(this.$t("wan.message.uploadImageError"))},onSetImageUrl(){const e=this.urls?.[0];this.$store.commit("wan/setConfig",{...this.$store.state.wan?.config,image_url:e})},async onSuccess(){this.onSetImageUrl()}}}),Oe={class:"relative"},Be={class:"flex justify-between"},je={class:"flex justify-start items-center"},Fe={class:"text-sm font-bold"};function Ne(e,n,p,_,k,y){const d=o("info-icon"),u=o("image-preview"),l=o("el-button"),w=o("el-upload");return s(),r("div",Oe,[i("div",Be,[i("div",je,[i("span",Fe,a(e.$t("wan.name.imageUrl")),1),t(d,{content:e.$t("wan.description.imageUrl"),class:"info"},null,8,["content"])])]),t(w,{"file-list":e.fileList,"onUpdate:fileList":n[0]||(n[0]=f=>e.fileList=f),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:c(({file:f})=>[f.url&&f.percentage!==void 0?(s(),$(u,{key:0,url:f.url,name:f.name,percentage:f.percentage,onRemove:g=>e.fileList.splice(e.fileList.indexOf(f),1)},null,8,["url","name","percentage","onRemove"])):m("",!0)]),default:c(()=>[t(l,{size:"small",type:"primary",class:"btn btn-upload",round:""},{default:c(()=>[h(a(e.$t("wan.button.uploadImageUrl")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-remove","on-success","headers"])])}const qe=b(Me,[["render",Ne],["__scopeId","data-v-41a69004"]]),ze="",We=v({name:"PromptInput",components:{PromptTextarea:x},computed:{prompt:{get(){return this.$store.state.wan?.config?.prompt},set(e){this.$store.commit("wan/setConfig",{...this.$store.state.wan?.config,prompt:e})}}},mounted(){this.prompt||(this.prompt=ze)}});function He(e,n,p,_,k,y){const d=o("prompt-textarea");return s(),$(d,{modelValue:e.prompt,"onUpdate:modelValue":n[0]||(n[0]=u=>e.prompt=u),title:e.$t("wan.name.prompt"),info:e.$t("wan.description.prompt"),placeholder:e.$t("wan.placeholder.prompt")},null,8,["modelValue","title","info","placeholder"])}const Je=b(We,[["render",He]]),Ke=v({name:"PresetPanel",components:{ElButton:S,FontAwesomeIcon:R,PromptInput:Je,ImageUrlInput:qe,ModelSelector:ke,ResolutionSelector:Ue,DurationSelector:De,Consumption:te},emits:["generate"],computed:{config(){return this.$store.state.wan?.config},consumption(){return oe(this.config,this.service?.cost)},service(){return this.$store.state.wan?.service},supportsResolution(){const e=this.config?.model;return e==="wan2.6-t2v"||e==="wan2.6-i2v"||e==="wan2.6-i2v-flash"},supportsDuration(){return this.config?.model==="wan2.6-t2v"},supportsImageUrl(){const e=this.config?.model;return e==="wan2.6-i2v"||e==="wan2.6-i2v-flash"}},methods:{onGenerate(){this.$emit("generate")}}}),Qe={class:"flex flex-col h-full"},Xe={class:"flex-1 overflow-y-auto p-5"},Ye={class:"flex flex-col items-center justify-center px-5 pb-5"};function Ze(e,n,p,_,k,y){const d=o("prompt-input"),u=o("model-selector"),l=o("resolution-selector"),w=o("duration-selector"),f=o("image-url-input"),g=o("consumption"),V=o("font-awesome-icon"),E=o("el-button");return s(),r("div",Qe,[i("div",Xe,[t(d,{class:"mb-4"}),t(u,{class:"mb-4"}),e.supportsResolution?(s(),$(l,{key:0,class:"mb-4"})):m("",!0),e.supportsDuration?(s(),$(w,{key:1,class:"mb-4"})):m("",!0),e.supportsImageUrl?(s(),$(f,{key:2,class:"mb-2"})):m("",!0)]),i("div",Ye,[t(g,{value:e.consumption,service:e.service},null,8,["value","service"]),t(E,{type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:c(()=>[t(V,{icon:"fa-solid fa-magic",class:"mr-2"}),h(" "+a(e.$t("wan.button.generate")),1)]),_:1},8,["onClick"])])])}const xe=b(Ke,[["render",Ze]]),et=v({name:"TaskPreview",components:{ElImage:ce,CopyToClipboard:ne,FontAwesomeIcon:R,ElAlert:ie,VideoPlayer:ae,ElTooltip:re,ElButton:S,ApiCodeButton:le},props:{modelValue:{type:Object,required:!0}},setup(){return{WAN_LOGO:q}},computed:{application(){return this.$store.state.wan?.application},config(){return this.$store.state.wan?.config}},methods:{onDownload(e){console.debug("on download wan video",e),window.open(e,"_blank")}}}),tt={class:"preview"},ot={class:"left"},st={class:"main"},nt={class:"bot"},at={class:"datetime"},lt={class:"info"},rt={key:0,class:"prompt mt-2"},it={key:0},ct={key:1},dt={key:0,class:L({content:!0,failed:!0})},ut={key:0,class:"mb-4"},pt={key:1,class:L({operations:!0,"mt-2":!0})},mt={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},ft={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},ht={key:1,class:"text-[var(--el-text-color-regular)] text-xs mb-0"},_t={key:1,class:L({content:!0})},gt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},$t={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},wt={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},vt={class:"text-[var(--el-text-color-regular)] text-xs mb-0"},bt={key:2,class:L({content:!0})},kt={class:"text-[var(--el-text-color-regular)] text-xs mb-0"};function yt(e,n,p,_,k,y){const d=o("el-image"),u=o("video-player"),l=o("el-button"),w=o("el-tooltip"),f=o("api-code-button"),g=o("font-awesome-icon"),V=o("copy-to-clipboard"),E=o("el-alert");return s(),r("div",tt,[i("div",ot,[t(d,{src:e.WAN_LOGO,class:"avatar"},null,8,["src"])]),i("div",st,[i("div",nt,[h(a(e.$t("wan.name.wanBot"))+" ",1),i("span",at,a(e.$dayjs.format(""+new Date(parseFloat((e.modelValue?.created_at||"").toString())*1e3))),1)]),i("div",lt,[e.modelValue?.request?.prompt?(s(),r("p",rt,[h(a(e.modelValue?.request?.prompt)+" ",1),e.modelValue?.response?m("",!0):(s(),r("span",it," - ("+a(e.$t("wan.status.pending"))+") ",1)),e.modelValue?.response?.state==="processing"||e.modelValue?.response?.state==="pending"||e.modelValue?.response?.state==="running"?(s(),r("span",ct," - ("+a(e.$t("wan.status.processing"))+") ",1)):m("",!0)])):m("",!0)]),e.modelValue?.response?.success===!0?(s(),r("div",dt,[e.modelValue?.response?.video_url?(s(),r("div",ut,[t(u,{src:e.modelValue?.response?.video_url},null,8,["src"])])):m("",!0),e.modelValue?.response?.video_url?(s(),r("div",pt,[t(w,{class:"box-item",effect:"dark",content:e.$t("wan.message.downloadVideo"),placement:"top-start"},{default:c(()=>[t(l,{type:"info",size:"small",class:"mb-2",onClick:n[0]||(n[0]=M(At=>e.onDownload(e.modelValue?.response?.video_url),["stop"]))},{default:c(()=>[h(a(e.$t("wan.button.download")),1)]),_:1})]),_:1},8,["content"]),t(f,{path:"/wan/videos",body:e.modelValue?.request},null,8,["body"])])):m("",!0),t(E,{closable:!1,class:"mt-2 success"},{default:c(()=>[e.modelValue?.request?.model?(s(),r("p",mt,[t(g,{icon:"fa-solid fa-hashtag",class:"mr-1"}),h(" "+a(e.$t("wan.name.model"))+": "+a(e.modelValue?.request?.model)+" ",1),t(V,{content:e.modelValue?.id},null,8,["content"])])):m("",!0),i("p",ft,[t(g,{icon:"fa-solid fa-magic",class:"mr-1"}),h(" "+a(e.$t("wan.name.taskId"))+": "+a(e.modelValue?.id)+" ",1),t(V,{content:e.modelValue?.id},null,8,["content"])]),e.modelValue?.elapsed?(s(),r("p",ht,[t(g,{icon:"fa-solid fa-clock",class:"mr-1"}),h(" "+a(e.$t("wan.name.elapsed"))+": "+a(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):m("",!0)]),_:1})])):m("",!0),e.modelValue?.response?.success===!1?(s(),r("div",_t,[t(E,{closable:!1,class:"failure"},{template:c(()=>[t(g,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),h(" "+a(e.$t("wan.name.failure")),1)]),default:c(()=>[i("p",gt,[t(g,{icon:"fa-solid fa-magic",class:"mr-1"}),h(" "+a(e.$t("wan.name.taskId"))+": "+a(e.modelValue?.id)+" ",1),t(V,{content:e.modelValue?.id},null,8,["content"])]),i("p",$t,[t(g,{icon:"fa-solid fa-circle-info",class:"mr-1"}),h(" "+a(e.$t("wan.name.failureReason"))+": "+a(e.modelValue?.response?.error?.message)+" ",1),t(V,{content:e.modelValue?.response?.error?.message},null,8,["content"])]),e.modelValue?.elapsed?(s(),r("p",wt,[t(g,{icon:"fa-solid fa-clock",class:"mr-1"}),h(" "+a(e.$t("wan.name.elapsed"))+": "+a(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):m("",!0),i("p",vt,[t(g,{icon:"fa-solid fa-hashtag",class:"mr-1"}),h(" "+a(e.$t("wan.name.traceId"))+": "+a(e.modelValue?.response?.trace_id)+" ",1),t(V,{content:e.modelValue?.response?.trace_id},null,8,["content"])])]),_:1})])):m("",!0),e.modelValue?.response?.success===void 0?(s(),r("div",bt,[t(E,{closable:!1,class:"info"},{template:c(()=>[t(g,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),h(" "+a(e.$t("wan.name.failure")),1)]),default:c(()=>[i("p",kt,[t(g,{icon:"fa-solid fa-magic",class:"mr-1"}),h(" "+a(e.$t("wan.name.taskId"))+": "+a(e.modelValue?.id)+" ",1),t(V,{content:e.modelValue?.id},null,8,["content"])])]),_:1})])):m("",!0)])])}const Vt=b(et,[["render",yt],["__scopeId","data-v-916b8970"]]),Tt=v({name:"RecentPanel",components:{TaskPreview:Vt,BotPlaceholder:de,NoTasks:ee,ScrollList:Q},props:{loading:{type:Boolean,default:!1}},emits:["reach-top"],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.wan?.tasks,items:this.$store.state.wan?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),Et={key:0},It={key:2,class:"w-full h-full flex items-center justify-center"};function St(e,n,p,_,k,y){const d=o("bot-placeholder"),u=o("task-preview"),l=o("scroll-list"),w=o("no-tasks");return s(),r(I,null,[e.tasks?.items===void 0?(s(),r("div",Et,[t(d)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(s(),$(l,{key:1,ref:"scrollList",class:"tasks w-full h-full overflow-y-auto",loading:e.loading,onReachTop:n[0]||(n[0]=f=>e.$emit("reach-top"))},{default:c(()=>[(s(!0),r(I,null,U(e.tasks?.items,f=>(s(),$(u,{key:f.id,"model-value":f},null,8,["model-value"]))),128))]),_:1},8,["loading"])):m("",!0),e.tasks?.items?.length===0?(s(),r("div",It,[t(w)])):m("",!0)],64)}const Ut=b(Tt,[["render",St]]),Lt=F("wan"),Ct=v({name:"WanIndex",components:{ConfigPanel:xe,Layout:_e,RecentPanel:Ut},mixins:[H],inject:["initialized"],data(){return{task:void 0,job:0,timer:void 0,loadingMore:!1,fetchingTasks:!1}},computed:{applicationsLoading(){return this.$store.state.wan?.status?.getApplications===G.Request},tasksLoading(){return this.$store.state.wan?.status?.getTasks===G.Request||this.fetchingTasks},credential(){return this.$store.state.wan.credential},config(){return this.$store.state.wan.config},application(){return this.$store.state.wan.application},tasks(){return this.$store.state.wan.tasks}},watch:{tasks:{handler(e,n){e?.items?.length>n?.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 X({tasks:this.tasks,getTasks:()=>this.tasks,loading:this.loadingMore,setLoading:e=>this.loadingMore=e,isBlocked:()=>this.tasksLoading||this.applicationsLoading,fetch:e=>this.onGetTasks({createdAtMax:e}),getScrollElement:()=>this.getTasksScrollElement()})},async onGetService(){console.debug("start onGetService"),await this.$store.dispatch("wan/getService"),console.debug("end onGetService")},async onGetApplication(){console.debug("start onGetApplication"),await this.$store.dispatch("wan/getApplications"),console.debug("end onGetApplication"),await this.onGetTasks()},async onScrollDown(){await this.$nextTick();const e=this.getTasksScrollElement();e&&(e.scrollTop=e.scrollHeight)},async onGetTasks(e){if(this.applicationsLoading||this.fetchingTasks){console.debug("loading");return}console.debug("start onGetTasks",e);const{limit:n=5,createdAtMin:p,createdAtMax:_}=e||{};console.debug("limit",n,"createdAtMin",p,"createdAtMax",_),this.fetchingTasks=!0;try{await this.$store.dispatch("wan/getTasks",{limit:n,createdAtMin:p,createdAtMax:_})}finally{this.fetchingTasks=!1}},async onGenerate(){if(!J(this.uploadTracker,p=>this.$t(p),p=>T.warning(p)))return;const e={...this.config,callback_url:Lt},n=this.credential?.token;if(!n){console.error("no token specified");return}T.info(this.$t("wan.message.startingTask")),B("wan",j.generate(e,{token:n})).then(()=>{T.success(this.$t("wan.message.startTaskSuccess"))}).catch(p=>{p?.response?.data?.error?.code===se?T.error(this.$t("wan.message.usedUp")):T.error(this.$t("wan.message.startTaskFailed"))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function Rt(e,n,p,_,k,y){const d=o("config-panel"),u=o("recent-panel"),l=o("layout");return s(),$(l,null,{config:c(()=>[t(d,{onGenerate:e.onGenerate},null,8,["onGenerate"])]),result:c(()=>[t(u,{ref:"recentPanel",loading:e.loadingMore,onReachTop:e.onReachTop},null,8,["loading","onReachTop"])]),_:1})}const Lo=b(Ct,[["render",Rt]]);export{Lo as default};
1
+ import{F as R}from"./index.es-UMFIHXWc.js";import{E as S}from"./index-D7cRCqFS.js";import{E as D}from"./index-1WxaVCeu.js";import{d as v,H as r,E as i,z as C,C as t,y as c,D as o,q as s,F as a,O as I,N as U,x as $,I as h,J as m,M,Q as L}from"./vendor-vue-NSDaktjZ.js";import{H as b,bp as O,cs as B,b5 as j,S as G,ct as F}from"./index-kok2V6cj.js";import{a as N,b as q}from"./wan-DKq-jYOo.js";import{E as A,a as P}from"./index-DkLXeCmb.js";import{p as z}from"./pasteUploadMixin-BurWbGNQ.js";import{u as W,a as H,e as J}from"./uploadTrackerMixin--N-yU8Tl.js";import{I as K,S as Q,l as X}from"./pagination-EsDrj3yC.js";import{I as Y}from"./ImagePreview-BjgklCqN.js";import{E as Z}from"./index-yNToY-SP.js";import{E as T}from"./index-Buukpn8o.js";import{P as x,N as ee}from"./NoTasks-DLn86jTC.js";import{C as te}from"./Consumption-BAwCyKhW.js";import{a as oe}from"./price-Beya5kld.js";import{b as se}from"./errorCode-Cqj9Td_Z.js";import{C as ne}from"./CopyToClipboard-B1L4gFQs.js";import{V as ae}from"./VideoPlayer-lNCFIvjW.js";import{A as le}from"./ApiCodeButton-Bu2nLY5J.js";import{E as re}from"./index-BnUjW8_R.js";import{E as ie}from"./index-CLIkNw25.js";import{E as ce}from"./index-CXgPGdvu.js";import{B as de}from"./BotPlaceholder-B5Bw1tlj.js";import"./use-form-item-CYiJWVVo.js";import"./index-BuyEbX8F.js";import"./vendor-axios-B8_nURbH.js";import"./vendor-dayjs-v0j1UNZp.js";import"./vendor-vue-router-Df5ITouH.js";import"./index-BYnYd0I7.js";import"./typescript-CfmcPqGh.js";import"./index-KTS__Qmb.js";import"./strings-beZM2Y-f.js";import"./isEqual-DBGyFRF0.js";import"./_Uint8Array-pGzioutB.js";import"./castArray-CJ8hzGGj.js";import"./index-WPH6eO9g.js";import"./index-DWWSYHUH.js";import"./debounce-G93CFNE1.js";import"./_baseIteratee-BCY-1IYO.js";import"./index-BI3c17YF.js";import"./highlight-DsFwBu4N.js";import"./index-BLjywj98.js";import"./vendor-highlight-lEWW1Jxd.js";import"./index-CNnBDoa1.js";import"./_baseClone-D8eUdaQd.js";import"./_initCloneObject-CAH0nDM3.js";import"./vue-plyr-BO2nlN4c.js";import"./index-BJr3r4qN.js";const ue=v({name:"LayoutWan",components:{ElDrawer:D,ElButton:S,FontAwesomeIcon:R},data(){return{drawer:!1}}}),pe={class:"main flex flex-row flex-1"},me={class:"config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]"},fe={class:"result h-full p-6 flex-1 flex flex-col min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]"};function he(e,n,p,_,k,y){const d=o("font-awesome-icon"),u=o("el-button"),l=o("el-drawer");return s(),r("div",pe,[i("div",me,[C(e.$slots,"config",{},void 0,!0)]),i("div",fe,[C(e.$slots,"result",{},void 0,!0)]),t(u,{circle:"",class:"menu",onClick:n[0]||(n[0]=w=>e.drawer=!0)},{default:c(()=>[t(d,{icon:"fa-solid fa-magic"})]),_:1}),t(l,{modelValue:e.drawer,"onUpdate:modelValue":n[1]||(n[1]=w=>e.drawer=w),direction:"ltr","with-header":!1,size:"340px"},{default:c(()=>[C(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const _e=b(ue,[["render",he],["__scopeId","data-v-3b0702a7"]]),ge=v({name:"ModelSelector",components:{ElSelect:P,ElOption:A},data(){return{}},computed:{options(){return[{value:"wan2.6-t2v",label:this.$t("wan.button.modelT2v")},{value:"wan2.6-i2v",label:this.$t("wan.button.modelI2v")},{value:"wan2.6-i2v-flash",label:this.$t("wan.button.modelI2vFlash")},{value:"wan2.6-r2v",label:this.$t("wan.button.modelR2v")}]},value:{get(){return this.$store.state.wan?.config?.model},set(e){this.$store.commit("wan/setConfig",{...this.$store.state.wan?.config,model:e})}}},mounted(){this.value||(this.value=N)}}),$e={class:"field"},we={class:"title font-bold"},ve={class:"float-left"};function be(e,n,p,_,k,y){const d=o("el-option"),u=o("el-select");return s(),r("div",$e,[i("h2",we,a(e.$t("wan.name.model")),1),t(u,{modelValue:e.value,"onUpdate:modelValue":n[0]||(n[0]=l=>e.value=l),class:"value",placeholder:e.$t("wan.placeholder.select"),clearable:""},{default:c(()=>[(s(!0),r(I,null,U(e.options,l=>(s(),$(d,{key:l.value,label:l.label,value:l.value},{default:c(()=>[i("span",ve,a(l.label),1)]),_:2},1032,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const ke=b(ge,[["render",be],["__scopeId","data-v-eb090beb"]]),ye="720p",Ve=v({name:"ResolutionSelector",components:{ElSelect:P,ElOption:A},computed:{options(){return[{value:"480p",label:this.$t("wan.name.resolution480p")},{value:"720p",label:this.$t("wan.name.resolution720p")},{value:"1080p",label:this.$t("wan.name.resolution1080p")}]},value:{get(){return this.$store.state.wan?.config?.resolution},set(e){this.$store.commit("wan/setConfig",{...this.$store.state.wan?.config,resolution:e})}}},mounted(){this.value||(this.value=ye)}}),Te={class:"field"},Ee={class:"title font-bold"},Ie={class:"float-left"};function Se(e,n,p,_,k,y){const d=o("el-option"),u=o("el-select");return s(),r("div",Te,[i("h2",Ee,a(e.$t("wan.name.resolution")),1),t(u,{modelValue:e.value,"onUpdate:modelValue":n[0]||(n[0]=l=>e.value=l),class:"value",placeholder:e.$t("wan.placeholder.select"),clearable:""},{default:c(()=>[(s(!0),r(I,null,U(e.options,l=>(s(),$(d,{key:l.value,label:l.label,value:l.value},{default:c(()=>[i("span",Ie,a(l.label),1)]),_:2},1032,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Ue=b(Ve,[["render",Se],["__scopeId","data-v-3e39f44e"]]),Le=5,Ce=v({name:"DurationSelector",components:{ElSelect:P,ElOption:A},computed:{options(){return[{value:5,label:this.$t("wan.name.duration5s")},{value:10,label:this.$t("wan.name.duration10s")},{value:15,label:this.$t("wan.name.duration15s")}]},value:{get(){return this.$store.state.wan?.config?.duration},set(e){this.$store.commit("wan/setConfig",{...this.$store.state.wan?.config,duration:e})}}},mounted(){this.value||(this.value=Le)}}),Re={class:"field"},Ae={class:"title font-bold"},Pe={class:"float-left"};function Ge(e,n,p,_,k,y){const d=o("el-option"),u=o("el-select");return s(),r("div",Re,[i("h2",Ae,a(e.$t("wan.name.duration")),1),t(u,{modelValue:e.value,"onUpdate:modelValue":n[0]||(n[0]=l=>e.value=l),class:"value",placeholder:e.$t("wan.placeholder.select"),clearable:""},{default:c(()=>[(s(!0),r(I,null,U(e.options,l=>(s(),$(d,{key:l.value,label:l.label,value:l.value},{default:c(()=>[i("span",Pe,a(l.label),1)]),_:2},1032,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const De=b(Ce,[["render",Ge],["__scopeId","data-v-5f35a2cf"]]),Me=v({name:"ImageUrlInput",components:{ElUpload:Z,ElButton:S,InfoIcon:K,ImagePreview:Y},mixins:[z,W],data(){return{fileList:[],uploadUrl:O()+"/api/v1/files/"}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e.url).filter(e=>e!==void 0)},value:{get(){return this.$store.state.wan?.config?.image_url},set(){const e=this.urls?.[0];this.$store.commit("wan/setConfig",{...this.$store.state.wan?.config,image_url:e})}}},mounted(){this.value||(this.value=void 0),this.onSetImageUrl()},methods:{onExceed(){T.warning(this.$t("wan.message.uploadImageExceed"))},onError(){T.error(this.$t("wan.message.uploadImageError"))},async onRemove(){T.error(this.$t("wan.message.uploadImageError"))},onSetImageUrl(){const e=this.urls?.[0];this.$store.commit("wan/setConfig",{...this.$store.state.wan?.config,image_url:e})},async onSuccess(){this.onSetImageUrl()}}}),Oe={class:"relative"},Be={class:"flex justify-between"},je={class:"flex justify-start items-center"},Fe={class:"text-sm font-bold"};function Ne(e,n,p,_,k,y){const d=o("info-icon"),u=o("image-preview"),l=o("el-button"),w=o("el-upload");return s(),r("div",Oe,[i("div",Be,[i("div",je,[i("span",Fe,a(e.$t("wan.name.imageUrl")),1),t(d,{content:e.$t("wan.description.imageUrl"),class:"info"},null,8,["content"])])]),t(w,{"file-list":e.fileList,"onUpdate:fileList":n[0]||(n[0]=f=>e.fileList=f),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:c(({file:f})=>[f.url&&f.percentage!==void 0?(s(),$(u,{key:0,url:f.url,name:f.name,percentage:f.percentage,onRemove:g=>e.fileList.splice(e.fileList.indexOf(f),1)},null,8,["url","name","percentage","onRemove"])):m("",!0)]),default:c(()=>[t(l,{size:"small",type:"primary",class:"btn btn-upload",round:""},{default:c(()=>[h(a(e.$t("wan.button.uploadImageUrl")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-remove","on-success","headers"])])}const qe=b(Me,[["render",Ne],["__scopeId","data-v-41a69004"]]),ze="",We=v({name:"PromptInput",components:{PromptTextarea:x},computed:{prompt:{get(){return this.$store.state.wan?.config?.prompt},set(e){this.$store.commit("wan/setConfig",{...this.$store.state.wan?.config,prompt:e})}}},mounted(){this.prompt||(this.prompt=ze)}});function He(e,n,p,_,k,y){const d=o("prompt-textarea");return s(),$(d,{modelValue:e.prompt,"onUpdate:modelValue":n[0]||(n[0]=u=>e.prompt=u),title:e.$t("wan.name.prompt"),info:e.$t("wan.description.prompt"),placeholder:e.$t("wan.placeholder.prompt")},null,8,["modelValue","title","info","placeholder"])}const Je=b(We,[["render",He]]),Ke=v({name:"PresetPanel",components:{ElButton:S,FontAwesomeIcon:R,PromptInput:Je,ImageUrlInput:qe,ModelSelector:ke,ResolutionSelector:Ue,DurationSelector:De,Consumption:te},emits:["generate"],computed:{config(){return this.$store.state.wan?.config},consumption(){return oe(this.config,this.service?.cost)},service(){return this.$store.state.wan?.service},supportsResolution(){const e=this.config?.model;return e==="wan2.6-t2v"||e==="wan2.6-i2v"||e==="wan2.6-i2v-flash"},supportsDuration(){return this.config?.model==="wan2.6-t2v"},supportsImageUrl(){const e=this.config?.model;return e==="wan2.6-i2v"||e==="wan2.6-i2v-flash"}},methods:{onGenerate(){this.$emit("generate")}}}),Qe={class:"flex flex-col h-full"},Xe={class:"flex-1 overflow-y-auto p-5"},Ye={class:"flex flex-col items-center justify-center px-5 pb-5"};function Ze(e,n,p,_,k,y){const d=o("prompt-input"),u=o("model-selector"),l=o("resolution-selector"),w=o("duration-selector"),f=o("image-url-input"),g=o("consumption"),V=o("font-awesome-icon"),E=o("el-button");return s(),r("div",Qe,[i("div",Xe,[t(d,{class:"mb-4"}),t(u,{class:"mb-4"}),e.supportsResolution?(s(),$(l,{key:0,class:"mb-4"})):m("",!0),e.supportsDuration?(s(),$(w,{key:1,class:"mb-4"})):m("",!0),e.supportsImageUrl?(s(),$(f,{key:2,class:"mb-2"})):m("",!0)]),i("div",Ye,[t(g,{value:e.consumption,service:e.service},null,8,["value","service"]),t(E,{type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:c(()=>[t(V,{icon:"fa-solid fa-magic",class:"mr-2"}),h(" "+a(e.$t("wan.button.generate")),1)]),_:1},8,["onClick"])])])}const xe=b(Ke,[["render",Ze]]),et=v({name:"TaskPreview",components:{ElImage:ce,CopyToClipboard:ne,FontAwesomeIcon:R,ElAlert:ie,VideoPlayer:ae,ElTooltip:re,ElButton:S,ApiCodeButton:le},props:{modelValue:{type:Object,required:!0}},setup(){return{WAN_LOGO:q}},computed:{application(){return this.$store.state.wan?.application},config(){return this.$store.state.wan?.config}},methods:{onDownload(e){console.debug("on download wan video",e),window.open(e,"_blank")}}}),tt={class:"preview"},ot={class:"left"},st={class:"main"},nt={class:"bot"},at={class:"datetime"},lt={class:"info"},rt={key:0,class:"prompt mt-2"},it={key:0},ct={key:1},dt={key:0,class:L({content:!0,failed:!0})},ut={key:0,class:"mb-4"},pt={key:1,class:L({operations:!0,"mt-2":!0})},mt={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},ft={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},ht={key:1,class:"text-[var(--el-text-color-regular)] text-xs mb-0"},_t={key:1,class:L({content:!0})},gt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},$t={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},wt={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},vt={class:"text-[var(--el-text-color-regular)] text-xs mb-0"},bt={key:2,class:L({content:!0})},kt={class:"text-[var(--el-text-color-regular)] text-xs mb-0"};function yt(e,n,p,_,k,y){const d=o("el-image"),u=o("video-player"),l=o("el-button"),w=o("el-tooltip"),f=o("api-code-button"),g=o("font-awesome-icon"),V=o("copy-to-clipboard"),E=o("el-alert");return s(),r("div",tt,[i("div",ot,[t(d,{src:e.WAN_LOGO,class:"avatar"},null,8,["src"])]),i("div",st,[i("div",nt,[h(a(e.$t("wan.name.wanBot"))+" ",1),i("span",at,a(e.$dayjs.format(""+new Date(parseFloat((e.modelValue?.created_at||"").toString())*1e3))),1)]),i("div",lt,[e.modelValue?.request?.prompt?(s(),r("p",rt,[h(a(e.modelValue?.request?.prompt)+" ",1),e.modelValue?.response?m("",!0):(s(),r("span",it," - ("+a(e.$t("wan.status.pending"))+") ",1)),e.modelValue?.response?.state==="processing"||e.modelValue?.response?.state==="pending"||e.modelValue?.response?.state==="running"?(s(),r("span",ct," - ("+a(e.$t("wan.status.processing"))+") ",1)):m("",!0)])):m("",!0)]),e.modelValue?.response?.success===!0?(s(),r("div",dt,[e.modelValue?.response?.video_url?(s(),r("div",ut,[t(u,{src:e.modelValue?.response?.video_url},null,8,["src"])])):m("",!0),e.modelValue?.response?.video_url?(s(),r("div",pt,[t(w,{class:"box-item",effect:"dark",content:e.$t("wan.message.downloadVideo"),placement:"top-start"},{default:c(()=>[t(l,{type:"info",size:"small",class:"mb-2",onClick:n[0]||(n[0]=M(At=>e.onDownload(e.modelValue?.response?.video_url),["stop"]))},{default:c(()=>[h(a(e.$t("wan.button.download")),1)]),_:1})]),_:1},8,["content"]),t(f,{path:"/wan/videos",body:e.modelValue?.request},null,8,["body"])])):m("",!0),t(E,{closable:!1,class:"mt-2 success"},{default:c(()=>[e.modelValue?.request?.model?(s(),r("p",mt,[t(g,{icon:"fa-solid fa-hashtag",class:"mr-1"}),h(" "+a(e.$t("wan.name.model"))+": "+a(e.modelValue?.request?.model)+" ",1),t(V,{content:e.modelValue?.id},null,8,["content"])])):m("",!0),i("p",ft,[t(g,{icon:"fa-solid fa-magic",class:"mr-1"}),h(" "+a(e.$t("wan.name.taskId"))+": "+a(e.modelValue?.id)+" ",1),t(V,{content:e.modelValue?.id},null,8,["content"])]),e.modelValue?.elapsed?(s(),r("p",ht,[t(g,{icon:"fa-solid fa-clock",class:"mr-1"}),h(" "+a(e.$t("wan.name.elapsed"))+": "+a(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):m("",!0)]),_:1})])):m("",!0),e.modelValue?.response?.success===!1?(s(),r("div",_t,[t(E,{closable:!1,class:"failure"},{template:c(()=>[t(g,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),h(" "+a(e.$t("wan.name.failure")),1)]),default:c(()=>[i("p",gt,[t(g,{icon:"fa-solid fa-magic",class:"mr-1"}),h(" "+a(e.$t("wan.name.taskId"))+": "+a(e.modelValue?.id)+" ",1),t(V,{content:e.modelValue?.id},null,8,["content"])]),i("p",$t,[t(g,{icon:"fa-solid fa-circle-info",class:"mr-1"}),h(" "+a(e.$t("wan.name.failureReason"))+": "+a(e.modelValue?.response?.error?.message)+" ",1),t(V,{content:e.modelValue?.response?.error?.message},null,8,["content"])]),e.modelValue?.elapsed?(s(),r("p",wt,[t(g,{icon:"fa-solid fa-clock",class:"mr-1"}),h(" "+a(e.$t("wan.name.elapsed"))+": "+a(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):m("",!0),i("p",vt,[t(g,{icon:"fa-solid fa-hashtag",class:"mr-1"}),h(" "+a(e.$t("wan.name.traceId"))+": "+a(e.modelValue?.response?.trace_id)+" ",1),t(V,{content:e.modelValue?.response?.trace_id},null,8,["content"])])]),_:1})])):m("",!0),e.modelValue?.response?.success===void 0?(s(),r("div",bt,[t(E,{closable:!1,class:"info"},{template:c(()=>[t(g,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),h(" "+a(e.$t("wan.name.failure")),1)]),default:c(()=>[i("p",kt,[t(g,{icon:"fa-solid fa-magic",class:"mr-1"}),h(" "+a(e.$t("wan.name.taskId"))+": "+a(e.modelValue?.id)+" ",1),t(V,{content:e.modelValue?.id},null,8,["content"])])]),_:1})])):m("",!0)])])}const Vt=b(et,[["render",yt],["__scopeId","data-v-916b8970"]]),Tt=v({name:"RecentPanel",components:{TaskPreview:Vt,BotPlaceholder:de,NoTasks:ee,ScrollList:Q},props:{loading:{type:Boolean,default:!1}},emits:["reach-top"],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.wan?.tasks,items:this.$store.state.wan?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),Et={key:0},It={key:2,class:"w-full h-full flex items-center justify-center"};function St(e,n,p,_,k,y){const d=o("bot-placeholder"),u=o("task-preview"),l=o("scroll-list"),w=o("no-tasks");return s(),r(I,null,[e.tasks?.items===void 0?(s(),r("div",Et,[t(d)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(s(),$(l,{key:1,ref:"scrollList",class:"tasks w-full h-full overflow-y-auto",loading:e.loading,onReachTop:n[0]||(n[0]=f=>e.$emit("reach-top"))},{default:c(()=>[(s(!0),r(I,null,U(e.tasks?.items,f=>(s(),$(u,{key:f.id,"model-value":f},null,8,["model-value"]))),128))]),_:1},8,["loading"])):m("",!0),e.tasks?.items?.length===0?(s(),r("div",It,[t(w)])):m("",!0)],64)}const Ut=b(Tt,[["render",St]]),Lt=F("wan"),Ct=v({name:"WanIndex",components:{ConfigPanel:xe,Layout:_e,RecentPanel:Ut},mixins:[H],inject:["initialized"],data(){return{task:void 0,job:0,timer:void 0,loadingMore:!1,fetchingTasks:!1}},computed:{applicationsLoading(){return this.$store.state.wan?.status?.getApplications===G.Request},tasksLoading(){return this.$store.state.wan?.status?.getTasks===G.Request||this.fetchingTasks},credential(){return this.$store.state.wan.credential},config(){return this.$store.state.wan.config},application(){return this.$store.state.wan.application},tasks(){return this.$store.state.wan.tasks}},watch:{tasks:{handler(e,n){e?.items?.length>n?.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 X({tasks:this.tasks,getTasks:()=>this.tasks,loading:this.loadingMore,setLoading:e=>this.loadingMore=e,isBlocked:()=>this.tasksLoading||this.applicationsLoading,fetch:e=>this.onGetTasks({createdAtMax:e}),getScrollElement:()=>this.getTasksScrollElement()})},async onGetService(){console.debug("start onGetService"),await this.$store.dispatch("wan/getService"),console.debug("end onGetService")},async onGetApplication(){console.debug("start onGetApplication"),await this.$store.dispatch("wan/getApplications"),console.debug("end onGetApplication"),await this.onGetTasks()},async onScrollDown(){await this.$nextTick();const e=this.getTasksScrollElement();e&&(e.scrollTop=e.scrollHeight)},async onGetTasks(e){if(this.applicationsLoading||this.fetchingTasks){console.debug("loading");return}console.debug("start onGetTasks",e);const{limit:n=5,createdAtMin:p,createdAtMax:_}=e||{};console.debug("limit",n,"createdAtMin",p,"createdAtMax",_),this.fetchingTasks=!0;try{await this.$store.dispatch("wan/getTasks",{limit:n,createdAtMin:p,createdAtMax:_})}finally{this.fetchingTasks=!1}},async onGenerate(){if(!J(this.uploadTracker,p=>this.$t(p),p=>T.warning(p)))return;const e={...this.config,callback_url:Lt},n=this.credential?.token;if(!n){console.error("no token specified");return}T.info(this.$t("wan.message.startingTask")),B("wan",j.generate(e,{token:n})).then(()=>{T.success(this.$t("wan.message.startTaskSuccess"))}).catch(p=>{p?.response?.data?.error?.code===se?T.error(this.$t("wan.message.usedUp")):T.error(this.$t("wan.message.startTaskFailed"))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function Rt(e,n,p,_,k,y){const d=o("config-panel"),u=o("recent-panel"),l=o("layout");return s(),$(l,null,{config:c(()=>[t(d,{onGenerate:e.onGenerate},null,8,["onGenerate"])]),result:c(()=>[t(u,{ref:"recentPanel",loading:e.loadingMore,onReachTop:e.onReachTop},null,8,["loading","onReachTop"])]),_:1})}const Lo=b(Ct,[["render",Rt]]);export{Lo as default};