@acedatacloud/nexior 3.128.0 → 3.129.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 (242) hide show
  1. package/dist/assets/{Auth-BMzo33RR.js → Auth-C6wr891o.js} +1 -1
  2. package/dist/assets/{BotPlaceholder-5oNK0Ith.js → BotPlaceholder-Bxg1WSeO.js} +1 -1
  3. package/dist/assets/{Callback-BC3tTOVf.js → Callback-BwoKrpxP.js} +1 -1
  4. package/dist/assets/{Console-BNMxI5up.js → Console-CWmm0dyp.js} +1 -1
  5. package/dist/assets/{Consumption-DEJXi9Yk.js → Consumption-DhMtSnnQ.js} +1 -1
  6. package/dist/assets/{Conversation-DNsT5Ae7.js → Conversation-DPk_uXLn.js} +1 -1
  7. package/dist/assets/{CopyToClipboard-DB2Z-HRU.js → CopyToClipboard-DrzpK9ow.js} +1 -1
  8. package/dist/assets/{Detail-BmO6q1-G.js → Detail-C9F8qPBS.js} +2 -2
  9. package/dist/assets/{EditArray-B3wGTZaR.js → EditArray-KHBbE9zY.js} +1 -1
  10. package/dist/assets/{Extra-D_AhvmOn.js → Extra-CK8Cz5kT.js} +1 -1
  11. package/dist/assets/{FilePreview-BJg4x3AQ.js → FilePreview-DAghvicx.js} +1 -1
  12. package/dist/assets/{History-BYiQh6_S.js → History-BIBlU1lS.js} +1 -1
  13. package/dist/assets/{IconPark.vue_vue_type_script_setup_true_lang-EQKHPSAQ.js → IconPark.vue_vue_type_script_setup_true_lang-BzHyU7fq.js} +1 -1
  14. package/dist/assets/{ImagePreview-BuuE19Gy.js → ImagePreview-DGgsF-1W.js} +1 -1
  15. package/dist/assets/{ImageWrapper-B87viqTL.js → ImageWrapper-D3SmhRJ2.js} +1 -1
  16. package/dist/assets/{Index-kbM7rrvI.js → Index-98pSKakk.js} +1 -1
  17. package/dist/assets/{Index-CuuMu3n2.js → Index-B9DdTfO_.js} +1 -1
  18. package/dist/assets/{Index-ByQZPDSs.js → Index-BDyuR4Yn.js} +1 -1
  19. package/dist/assets/{Index-C9baZsOc.js → Index-Bb9OC1vx.js} +1 -1
  20. package/dist/assets/{Index-BilmOncm.js → Index-BzsYSUWi.js} +1 -1
  21. package/dist/assets/{Index-DU9__5sQ.js → Index-C0Fhwvdl.js} +1 -1
  22. package/dist/assets/{Index-BZ4CRgdi.js → Index-CJcWQf6n.js} +1 -1
  23. package/dist/assets/{Index-iohZz7y_.js → Index-CUOw5gGW.js} +1 -1
  24. package/dist/assets/{Index-sD4xC_4s.js → Index-CWm9n2YF.js} +1 -1
  25. package/dist/assets/{Index-C4CWnW3t.js → Index-CZXMmH0p.js} +1 -1
  26. package/dist/assets/{Index-CvxcxmnK.js → Index-D115uFa4.js} +1 -1
  27. package/dist/assets/{Index-Czx0T0dE.js → Index-D4N_EcHx.js} +1 -1
  28. package/dist/assets/{Index-CZ2Mk99K.js → Index-DMeXUxJq.js} +1 -1
  29. package/dist/assets/{Index-CaqP8Yuf.js → Index-DNxu1Tme.js} +1 -1
  30. package/dist/assets/{Index-DLbbmdH5.js → Index-DO8x_-kO.js} +1 -1
  31. package/dist/assets/{Index-CRbqucZB.js → Index-DXKlzMzm.js} +1 -1
  32. package/dist/assets/{Index-CEm5mQt9.js → Index-Dsg6kUwi.js} +1 -1
  33. package/dist/assets/{Index-DOBsNAIR.js → Index-DuspubCQ.js} +1 -1
  34. package/dist/assets/{Index-Cb97gM-B.js → Index-Dz0-Akfd.js} +1 -1
  35. package/dist/assets/{Index-C8Nu7xsC.js → Index-KezgLWzj.js} +1 -1
  36. package/dist/assets/{Index-BZ-U_CDb.js → Index-Pmwam5Y5.js} +1 -1
  37. package/dist/assets/{Index-B5_jv8pV.js → Index-_MauVsrS.js} +1 -1
  38. package/dist/assets/{Index-O0C6DD-b.js → Index-lIlzXU6m.js} +1 -1
  39. package/dist/assets/{Index-C8aZkwob.js → Index-lhUC1ujT.js} +1 -1
  40. package/dist/assets/{Invitees-CpwkMcrL.js → Invitees-BsSs-EAK.js} +1 -1
  41. package/dist/assets/{List-B3kyG9X_.js → List-Dx1BdOBE.js} +1 -1
  42. package/dist/assets/{List-DUd5spYA.js → List-HNKAKFbq.js} +1 -1
  43. package/dist/assets/{List-qZl2FZ2J.js → List-opMrjM1A.js} +1 -1
  44. package/dist/assets/{Main-DRzryMUS.js → Main-5JqRXBq_.js} +1 -1
  45. package/dist/assets/{Navigator-DH2CsZgN.js → Navigator-kqKQIHAX.js} +1 -1
  46. package/dist/assets/{NoTasks-ZpQi0TyE.js → NoTasks-M-MqsF2Q.js} +1 -1
  47. package/dist/assets/{NotFound-Bmg82IiX.js → NotFound-QwMecwb5.js} +1 -1
  48. package/dist/assets/{OAuthCallback-CKC04WA3.js → OAuthCallback-zw6v-flP.js} +1 -1
  49. package/dist/assets/{Pagination-BGlPlWIy.js → Pagination-D3wwQpIW.js} +1 -1
  50. package/dist/assets/{ScrollList-DKlPMNZT.js → ScrollList-DMu-o4cw.js} +1 -1
  51. package/dist/assets/{Status-Cs6beKU6.js → Status-Dur0uyXT.js} +1 -1
  52. package/dist/assets/{Subscribe-FR1fBm-n.js → Subscribe-BM78IM0M.js} +1 -1
  53. package/dist/assets/{TransportWebHID-CGHLGUa4.js → TransportWebHID-B9bCMW4g.js} +1 -1
  54. package/dist/assets/{VideoPlayer-Dd86J0Gg.js → VideoPlayer-CHTi5hkY.js} +1 -1
  55. package/dist/assets/{_Uint8Array-ByIiAerw.js → _Uint8Array-C3Lbt_45.js} +1 -1
  56. package/dist/assets/{_baseClone-DZS2KndZ.js → _baseClone-vd8PLpyA.js} +1 -1
  57. package/dist/assets/{_baseIteratee-DWXq1g8X.js → _baseIteratee-BEktInjh.js} +1 -1
  58. package/dist/assets/{_initCloneObject-CuynXAWC.js → _initCloneObject-D5Z-CcL7.js} +1 -1
  59. package/dist/assets/{add-Dlnk29GG.js → add-Rhr3tPKw.js} +1 -1
  60. package/dist/assets/{all-wallets-CQElnySF.js → all-wallets-CCjRz3O9.js} +1 -1
  61. package/dist/assets/{app-store-PdJQ-IN4.js → app-store-lc068hsQ.js} +1 -1
  62. package/dist/assets/{apple-DYTTljit.js → apple-B7Ol_uH3.js} +1 -1
  63. package/dist/assets/{arrow-bottom-B4iC7k_x.js → arrow-bottom-CItJJlyT.js} +1 -1
  64. package/dist/assets/{arrow-bottom-circle-DHAoj62t.js → arrow-bottom-circle-B-D0ltWE.js} +1 -1
  65. package/dist/assets/{arrow-left-BJIElBiB.js → arrow-left-C95ErQIg.js} +1 -1
  66. package/dist/assets/{arrow-right-oTeCiqXH.js → arrow-right-DVxN-a3P.js} +1 -1
  67. package/dist/assets/{arrow-top-h7HEs_ua.js → arrow-top-Cp2ChGar.js} +1 -1
  68. package/dist/assets/{avatar-CcNXPTqK.js → avatar-CzOVqXLD.js} +1 -1
  69. package/dist/assets/{bank-CFwg2DY1.js → bank-xjecoC1A.js} +1 -1
  70. package/dist/assets/{basic-B-L0hrHz.js → basic-Bzuf2xSF.js} +1 -1
  71. package/dist/assets/{browser-DeTVbWhl.js → browser-BpqHtbmM.js} +1 -1
  72. package/dist/assets/{byokCredential-yEsNpz0J.js → byokCredential-D6aUoPSm.js} +1 -1
  73. package/dist/assets/{card-CB_EJqZO.js → card-D8gw3i8F.js} +1 -1
  74. package/dist/assets/{castArray-Dy2e0JbB.js → castArray-BgN0ywwP.js} +1 -1
  75. package/dist/assets/{chat-BM9B5rm-.js → chat-CsIdwksH.js} +1 -1
  76. package/dist/assets/{checkmark-BTW78uHG.js → checkmark-Zv0yogw9.js} +1 -1
  77. package/dist/assets/{checkmark-bold-CoLnJYOy.js → checkmark-bold-BZEGI2-2.js} +1 -1
  78. package/dist/assets/{chevron-bottom-s8SnVs06.js → chevron-bottom-DZrw0_8N.js} +1 -1
  79. package/dist/assets/{chevron-left-CIi44YLE.js → chevron-left-do53nOJf.js} +1 -1
  80. package/dist/assets/{chevron-right-BCGXKj96.js → chevron-right-TuH_zhQN.js} +1 -1
  81. package/dist/assets/{chevron-top-BqV8ade_.js → chevron-top-DBG6w7XR.js} +1 -1
  82. package/dist/assets/{chrome-store-DDHTIy24.js → chrome-store-DNON-ERX.js} +1 -1
  83. package/dist/assets/{clock-BwlCy5Iu.js → clock-_GvZ1cK4.js} +1 -1
  84. package/dist/assets/{close-WgguUBLs.js → close-5vy-RJs0.js} +1 -1
  85. package/dist/assets/{coinPlaceholder-8cut9Fa-.js → coinPlaceholder-B-b0AZM6.js} +1 -1
  86. package/dist/assets/{compass-Dn7n8jop.js → compass-Bd4r_sA_.js} +1 -1
  87. package/dist/assets/{copy-BHa6Ptil.js → copy-BFgv8THt.js} +1 -1
  88. package/dist/assets/{cursor-C8Ux6Rzo.js → cursor-CVMC812V.js} +1 -1
  89. package/dist/assets/{cursor-transparent-Bn7Xrx49.js → cursor-transparent-BTn1ZeoW.js} +1 -1
  90. package/dist/assets/{debounce-Cu_Jtjpm.js → debounce-CfLqwhiY.js} +1 -1
  91. package/dist/assets/{desktop-EpjTjuon.js → desktop-C5K6G_aZ.js} +1 -1
  92. package/dist/assets/{disconnect-FnOrJghM.js → disconnect-RBsPwfU6.js} +1 -1
  93. package/dist/assets/{discord-5SARw18s.js → discord-DynP7LWn.js} +1 -1
  94. package/dist/assets/{distribution-BkXq6sX-.js → distribution-CosZlALm.js} +1 -1
  95. package/dist/assets/{dropdown-BP_ej-SX.js → dropdown-D3hMk_5d.js} +1 -1
  96. package/dist/assets/{etherscan-cux-dhcl.js → etherscan-BrOlLE0m.js} +1 -1
  97. package/dist/assets/{exclamation-triangle-XrbX3TYD.js → exclamation-triangle-Cihq_Ywd.js} +1 -1
  98. package/dist/assets/{extension-Cj40EbIY.js → extension-mkEqD_BJ.js} +1 -1
  99. package/dist/assets/{external-link-DNtVmuRC.js → external-link-DYVDX0z5.js} +1 -1
  100. package/dist/assets/{facebook-CMe_Zte3.js → facebook-QMnr-1js.js} +1 -1
  101. package/dist/assets/{farcaster-BoKGgj82.js → farcaster-CPWveC__.js} +1 -1
  102. package/dist/assets/{filters-Be4tOW_G.js → filters-CYUcoLkD.js} +1 -1
  103. package/dist/assets/{flux-MJJJeGdQ.js → flux-Bp51qI1Q.js} +1 -1
  104. package/dist/assets/{github-DMFcTvOd.js → github-uyLzo_z8.js} +1 -1
  105. package/dist/assets/{google-7jxGmkGd.js → google-fPSfCR9C.js} +1 -1
  106. package/dist/assets/{hailuo-C2DAgWRq.js → hailuo-DZqfvXW2.js} +1 -1
  107. package/dist/assets/{headshots-BbqgI9h9.js → headshots-mfi_0kms.js} +1 -1
  108. package/dist/assets/{help-circle-D5HNn9tu.js → help-circle-CiHKb6Il.js} +1 -1
  109. package/dist/assets/{id-DD-6Aoqo.js → id-B8fRq-M4.js} +1 -1
  110. package/dist/assets/{image-DOLvzBT4.js → image-CBVy9et1.js} +1 -1
  111. package/dist/assets/{index-BjR1xkY6.js → index-1e6zn-my.js} +1 -1
  112. package/dist/assets/{index-FQXQEEy6.js → index-5aZRl_F2.js} +1 -1
  113. package/dist/assets/{index-CtySKs9Q.js → index-8KP8o-wR.js} +1 -1
  114. package/dist/assets/{index-BtBl6GQu.js → index-B5iae9JX.js} +1 -1
  115. package/dist/assets/{index-DqLO_LT6.js → index-BBtY3fhg.js} +1 -1
  116. package/dist/assets/{index-B4u9m5KW.js → index-BE5mvr9Z.js} +1 -1
  117. package/dist/assets/{index-DA-DwjoG.js → index-BMB0tPaL.js} +1 -1
  118. package/dist/assets/{index-CcnMKyw7.js → index-BYgw8Ne9.js} +1 -1
  119. package/dist/assets/{index-BEbgH5il.js → index-Bf-VYX2K.js} +1 -1
  120. package/dist/assets/{index-C3HcWVsL.js → index-BfYt3lpS.js} +1 -1
  121. package/dist/assets/{index-C2sZXfFW.js → index-BkJcEPcB.js} +1 -1
  122. package/dist/assets/{index-bQIOVtse.js → index-BkRv-z3G.js} +1 -1
  123. package/dist/assets/{index-BAlXF3lp.js → index-BmskuvzR.js} +4 -4
  124. package/dist/assets/{index-D-krlzAy.js → index-Br8Me_3x.js} +1 -1
  125. package/dist/assets/{index-BIIkgwju.js → index-Bt0qEKcm.js} +6 -6
  126. package/dist/assets/{index-DWiPtPwc.js → index-BvsGeWBq.js} +1 -1
  127. package/dist/assets/{index-DHE-zvMr.js → index-BxG3gwu6.js} +1 -1
  128. package/dist/assets/{index-B4Tz7YfZ.js → index-BySOUfaP.js} +1 -1
  129. package/dist/assets/{index-D2uEfxFl.js → index-C2eH1iHa.js} +1 -1
  130. package/dist/assets/{index-C9y6Qn-P.js → index-C2rR58Ot.js} +1 -1
  131. package/dist/assets/{index-z3iphkru.js → index-C38keIAt.js} +1 -1
  132. package/dist/assets/{index-DOZj5eEY.js → index-C4Lwn9IE.js} +1 -1
  133. package/dist/assets/{index-DhStH-hF.js → index-C4cFnn6h.js} +1 -1
  134. package/dist/assets/{index-Dt0y3LtV.js → index-C9PM4M05.js} +1 -1
  135. package/dist/assets/{index-CDkwLyG4.js → index-C9lzUGs5.js} +1 -1
  136. package/dist/assets/{index-C9pbuvyJ.js → index-CEOn0L_0.js} +1 -1
  137. package/dist/assets/{index-BVj6npzc.js → index-CKM7surl.js} +1 -1
  138. package/dist/assets/{index-pm_F56KR.js → index-CMgORxMe.js} +1 -1
  139. package/dist/assets/{index-Dz6jYLFM.js → index-CO8_QyaE.js} +1 -1
  140. package/dist/assets/{index-DFMs40N-.js → index-C_CFcyfA.js} +1 -1
  141. package/dist/assets/{index-BJwefJmT.js → index-CfOE8c8A.js} +1 -1
  142. package/dist/assets/{index-C1HKY4Q8.js → index-Cq1B7Sqv.js} +1 -1
  143. package/dist/assets/{index-D2zmio0m.js → index-CwLbS1A8.js} +1 -1
  144. package/dist/assets/{index-fxyUeDwr.js → index-CwoK3VdT.js} +1 -1
  145. package/dist/assets/{index-bJyGALvw.js → index-CzpXDEHV.js} +1 -1
  146. package/dist/assets/{index-B90YNXz4.js → index-D-VeTnRp.js} +3 -3
  147. package/dist/assets/{index-BPFaQ_s8.js → index-D1h0lpk4.js} +1 -1
  148. package/dist/assets/{index-B8Wsd2do.js → index-D7J-d7kY.js} +1 -1
  149. package/dist/assets/{index-B3UfVG_d.js → index-D7TXnRb-.js} +1 -1
  150. package/dist/assets/{index-1ks7CUYl.js → index-DKiuKeDx.js} +1 -1
  151. package/dist/assets/{index-Cy0v6DrL.js → index-DLJaPPEs.js} +1 -1
  152. package/dist/assets/{index-9SbBDGPs.js → index-DOUTCEtG.js} +1 -1
  153. package/dist/assets/{index-BNrf8OA9.js → index-DOxWI9dz.js} +1 -1
  154. package/dist/assets/{index-BWtgvNsd.js → index-DZ1tqrhb.js} +1 -1
  155. package/dist/assets/{index-DSub3p13.js → index-DZxx2mSr.js} +1 -1
  156. package/dist/assets/{index-n5Z6KNBS.js → index-D_y8kja2.js} +1 -1
  157. package/dist/assets/{index-BsAWh0kj.js → index-DfNRxa4s.js} +1 -1
  158. package/dist/assets/{index-D-YgqEsL.js → index-Dirtp-2U.js} +1 -1
  159. package/dist/assets/{index-B5UvkoVZ.js → index-Dlb1ce1V.js} +1 -1
  160. package/dist/assets/{index-DlKK7xr9.js → index-DnoD1Giz.js} +1 -1
  161. package/dist/assets/{index-D5lu46ap.js → index-DrYucvvt.js} +1 -1
  162. package/dist/assets/{index-CDkjWK7c.js → index-FPk3fSOu.js} +1 -1
  163. package/dist/assets/{index-Hxc7n4HD.js → index-JlXUmriI.js} +1 -1
  164. package/dist/assets/{index-5GxMphke.js → index-X4RPhZd6.js} +1 -1
  165. package/dist/assets/{index-czzMfzSq.js → index-Z6qAnijd.js} +1 -1
  166. package/dist/assets/{index-CWF_Pcdb.js → index-chdjSg4m.js} +1 -1
  167. package/dist/assets/{index-D53OHe6n.js → index-dsEGFRI5.js} +1 -1
  168. package/dist/assets/{index-wAnOYUjA.js → index-fpoSH8bT.js} +1 -1
  169. package/dist/assets/{index-BlT4xa9T.js → index-jvX6Scau.js} +1 -1
  170. package/dist/assets/{index-DnRWA3xQ.js → index-xC8HW9HC.js} +1 -1
  171. package/dist/assets/{index-Bb59aSYy.js → index-yeaw2_Qj.js} +1 -1
  172. package/dist/assets/{index-Bd83o_xd.js → index-ys73P36s.js} +1 -1
  173. package/dist/assets/{index.browser.esm-Dfr8LG5m.js → index.browser.esm-qLCiA7oD.js} +1 -1
  174. package/dist/assets/{index.es-CqUFafZ-.js → index.es-DgRqc681.js} +1 -1
  175. package/dist/assets/{info-DdT0G4Ot.js → info-1pyBFDvz.js} +1 -1
  176. package/dist/assets/{info-circle-Db5UBjst.js → info-circle-CkCfVbaC.js} +1 -1
  177. package/dist/assets/{isEqual-CIKj9pK6.js → isEqual-BPX3ojYz.js} +1 -1
  178. package/dist/assets/{isPlainObject-DmlMwz4l.js → isPlainObject-COYsLQum.js} +1 -1
  179. package/dist/assets/{kling-SEl8x51b.js → kling-GPS_1w8O.js} +1 -1
  180. package/dist/assets/{lightbulb-B4xbVPvl.js → lightbulb-DQ75OCny.js} +1 -1
  181. package/dist/assets/{luma-DGn6nqV7.js → luma-aWecxKUd.js} +1 -1
  182. package/dist/assets/{mail-ByKxrMPw.js → mail-BLRceXUR.js} +1 -1
  183. package/dist/assets/{midjourney-BSWqUGQQ.js → midjourney-CeqX80Ag.js} +1 -1
  184. package/dist/assets/{mobile-rHRia3aj.js → mobile-u_lzxBw2.js} +1 -1
  185. package/dist/assets/{more-B4I-SO1Q.js → more-B5BCNDgH.js} +1 -1
  186. package/dist/assets/{nanobanana-DewrOPDP.js → nanobanana-C9Llm_-d.js} +1 -1
  187. package/dist/assets/{network-placeholder-CEYIzFQj.js → network-placeholder-D7PTW8r9.js} +1 -1
  188. package/dist/assets/{nftPlaceholder-Ctxw7Mli.js → nftPlaceholder-eW3UWdis.js} +1 -1
  189. package/dist/assets/{off-Dv478v24.js → off-CAlsnWwC.js} +1 -1
  190. package/dist/assets/{openaiimage-3xfIWOkR.js → openaiimage-AsNjvitU.js} +1 -1
  191. package/dist/assets/{order-enu14tu8.js → order-Bqp2j3Jf.js} +1 -1
  192. package/dist/assets/{pika-D3yfT-c8.js → pika-B23NLf6i.js} +1 -1
  193. package/dist/assets/{pixverse-vDZ8uqHW.js → pixverse-CymNtjaz.js} +1 -1
  194. package/dist/assets/{play-store-B-PP3MyR.js → play-store-lvlDQ5vJ.js} +1 -1
  195. package/dist/assets/{plus-CeeYvJhl.js → plus-D58DFJ1T.js} +1 -1
  196. package/dist/assets/{price-Bs-d-Bvz.js → price-BGnrujo6.js} +1 -1
  197. package/dist/assets/{producer-B49TcM9P.js → producer-DjoJHK-p.js} +1 -1
  198. package/dist/assets/{qr-code-qM1T9bcv.js → qr-code-C5bC5x0O.js} +1 -1
  199. package/dist/assets/{qrart-BE7gP9Sz.js → qrart-OgtVocdR.js} +1 -1
  200. package/dist/assets/{recycle-horizontal-BQgUj8lg.js → recycle-horizontal-CQY-N3Q_.js} +1 -1
  201. package/dist/assets/{refresh-DPBcR56r.js → refresh-drZsyGvi.js} +1 -1
  202. package/dist/assets/{reown-logo-DCs1vcN3.js → reown-logo-CcS9acqr.js} +1 -1
  203. package/dist/assets/{search-C-vCUCIZ.js → search-DfE8H2N-.js} +1 -1
  204. package/dist/assets/{secp256k1-DYa8itNv.js → secp256k1-DkPjZYcD.js} +1 -1
  205. package/dist/assets/{secp256k1-DPRwQ62w.js → secp256k1-DzB028xx.js} +1 -1
  206. package/dist/assets/{seedance-MDz_-hre.js → seedance-B0lpHKHp.js} +1 -1
  207. package/dist/assets/{seedream-BeTQj6-2.js → seedream-C4W4jOZg.js} +1 -1
  208. package/dist/assets/{send-CQd-5Anp.js → send-CdO-Stc1.js} +1 -1
  209. package/dist/assets/{service-DqR1SsrS.js → service-Ba0En9-N.js} +1 -1
  210. package/dist/assets/{solana-wallets-CvvurVgA.js → solana-wallets-ffNGp49h.js} +2 -2
  211. package/dist/assets/{solana-wallets-vue-B1CuH8rk.js → solana-wallets-vue-BwoUgU-D.js} +1 -1
  212. package/dist/assets/{solanaEmbed.esm-BAFw5Kew.js → solanaEmbed.esm-CbUJ1Emr.js} +1 -1
  213. package/dist/assets/{sora-DJzE9qk-.js → sora-D1tfRRAJ.js} +1 -1
  214. package/dist/assets/{string_decoder-Qt1yWfpl.js → string_decoder-UO8XV3w0.js} +1 -1
  215. package/dist/assets/{suno-RxwwPeb3.js → suno-CH5veNaK.js} +1 -1
  216. package/dist/assets/{swapHorizontal-qOYrsKcy.js → swapHorizontal-CDkqUedL.js} +1 -1
  217. package/dist/assets/{swapHorizontalBold-C23FJdW6.js → swapHorizontalBold-CKEmUjvW.js} +1 -1
  218. package/dist/assets/{swapHorizontalMedium-Dw33R_YX.js → swapHorizontalMedium-B1V9Px50.js} +1 -1
  219. package/dist/assets/{swapHorizontalRoundedBold-DXAIqBfA.js → swapHorizontalRoundedBold-BageN9lw.js} +1 -1
  220. package/dist/assets/{swapVertical-CLL_wH2T.js → swapVertical-CoUDmzSI.js} +1 -1
  221. package/dist/assets/{telegram-qaIYbaMw.js → telegram-CFFroUec.js} +1 -1
  222. package/dist/assets/{three-dots-CBqjBJxZ.js → three-dots-CK9mr39y.js} +1 -1
  223. package/dist/assets/{twitch-CKaRzziJ.js → twitch-Cr468Tua.js} +1 -1
  224. package/dist/assets/{twitterIcon-7nYx2boi.js → twitterIcon-Bls5nwE-.js} +1 -1
  225. package/dist/assets/{typescript-DGijeo9F.js → typescript-D5w3x56R.js} +1 -1
  226. package/dist/assets/{use-form-item-DooKcsta.js → use-form-item-7D-CUO4M.js} +1 -1
  227. package/dist/assets/validator-DC9gRNtc.js +1 -0
  228. package/dist/assets/{veo-BpjTBfa7.js → veo-CWhJ-UE3.js} +1 -1
  229. package/dist/assets/{verify-sxm-YcaK.js → verify-HKc4Iikd.js} +1 -1
  230. package/dist/assets/{verify-filled-CfVn0iGz.js → verify-filled-C2cJL44n.js} +1 -1
  231. package/dist/assets/{w3m-modal-BN39GbH4.js → w3m-modal-JlUKAPAZ.js} +1 -1
  232. package/dist/assets/{wallet-DqpHM8tl.js → wallet-i38ODjy6.js} +1 -1
  233. package/dist/assets/{wallet-placeholder-DbZVjWDe.js → wallet-placeholder-CA4dHP8h.js} +1 -1
  234. package/dist/assets/{walletconnect-DjpJOcfy.js → walletconnect-DkmKqSTr.js} +1 -1
  235. package/dist/assets/{wan-biTqax26.js → wan-B_XnEbZW.js} +1 -1
  236. package/dist/assets/{warning-circle-Dxz0DLuZ.js → warning-circle-BmlNgUmm.js} +1 -1
  237. package/dist/assets/{web-BxKPaBjY.js → web-C5BhI75D.js} +1 -1
  238. package/dist/assets/{web-sAw_tSKv.js → web-ChsJIVKh.js} +1 -1
  239. package/dist/assets/{x-CHlrndhE.js → x-CFu0d94i.js} +1 -1
  240. package/dist/index.html +1 -1
  241. package/package.json +1 -1
  242. package/dist/assets/validator-BbzUjG__.js +0 -1
@@ -1 +1 @@
1
- import{F as C}from"./index.es-CqUFafZ-.js";import{E as T}from"./index-C3HcWVsL.js";import{E as M}from"./index-B3UfVG_d.js";import{d as w,H as r,E as c,z as U,C as t,y as d,D as o,q as s,F as l,O as I,N as S,x as $,I as f,J as m,M as O,Q as L}from"./vendor-vue-NSDaktjZ.js";import{E as v,b8 as j,cd as B,aw as D}from"./index-BAlXF3lp.js";import{a as F,b as N}from"./wan-DKq-jYOo.js";import{E as R,a as G}from"./index-CcnMKyw7.js";import{p as q}from"./pasteUploadMixin-BurWbGNQ.js";import{I as P,S as z}from"./ScrollList-DKlPMNZT.js";import{I as W}from"./ImagePreview-BuuE19Gy.js";import{E as H}from"./index-BtBl6GQu.js";import{E as V}from"./index-czzMfzSq.js";import{E as J}from"./index-DhStH-hF.js";import{C as K}from"./Consumption-DEJXi9Yk.js";import{a as Q}from"./price-Bs-d-Bvz.js";import{b as X}from"./errorCode-Cqj9Td_Z.js";import{w as Y}from"./wan-biTqax26.js";import{C as Z}from"./CopyToClipboard-DB2Z-HRU.js";import{V as x}from"./VideoPlayer-Dd86J0Gg.js";import{E as ee}from"./index-5GxMphke.js";import{E as te}from"./index-Hxc7n4HD.js";import{E as oe}from"./index-C2sZXfFW.js";import{B as se}from"./BotPlaceholder-5oNK0Ith.js";import{N as ne}from"./NoTasks-ZpQi0TyE.js";import{l as ae}from"./pagination-Cnc6Oeyx.js";import"./use-form-item-DooKcsta.js";import"./index-BuyEbX8F.js";import"./vendor-axios-B8_nURbH.js";import"./vendor-dayjs-Cvgzdobq.js";import"./vendor-vue-router-Kg6s1a65.js";import"./index-Bd83o_xd.js";import"./typescript-DGijeo9F.js";import"./index-C9pbuvyJ.js";import"./strings-beZM2Y-f.js";import"./isEqual-CIKj9pK6.js";import"./_Uint8Array-ByIiAerw.js";import"./castArray-Dy2e0JbB.js";import"./debounce-Cu_Jtjpm.js";import"./_baseIteratee-DWXq1g8X.js";import"./index-bQIOVtse.js";import"./index-DHE-zvMr.js";import"./_baseClone-DZS2KndZ.js";import"./_initCloneObject-CuynXAWC.js";import"./index-DWiPtPwc.js";import"./vue-plyr-BO2nlN4c.js";import"./index-C1HKY4Q8.js";const le=w({name:"LayoutWan",components:{ElDrawer:M,ElButton:T,FontAwesomeIcon:C},data(){return{drawer:!1}}}),re={class:"main flex flex-row flex-1"},ie={class:"config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]"},ce={class:"result h-full p-6 flex-1 flex flex-col min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]"};function de(e,n,h,_,b,k){const u=o("font-awesome-icon"),p=o("el-button"),a=o("el-drawer");return s(),r("div",re,[c("div",ie,[U(e.$slots,"config",{},void 0,!0)]),c("div",ce,[U(e.$slots,"result",{},void 0,!0)]),t(p,{circle:"",class:"menu",onClick:n[0]||(n[0]=g=>e.drawer=!0)},{default:d(()=>[t(u,{icon:"fa-solid fa-magic"})]),_:1}),t(a,{modelValue:e.drawer,"onUpdate:modelValue":n[1]||(n[1]=g=>e.drawer=g),direction:"ltr","with-header":!1,size:"340px"},{default:d(()=>[U(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const ue=v(le,[["render",de],["__scopeId","data-v-98681d9b"]]),pe=w({name:"ModelSelector",components:{ElSelect:G,ElOption:R},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=F)}}),me={class:"field"},fe={class:"title font-bold"},he={class:"float-left"};function _e(e,n,h,_,b,k){const u=o("el-option"),p=o("el-select");return s(),r("div",me,[c("h2",fe,l(e.$t("wan.name.model")),1),t(p,{modelValue:e.value,"onUpdate:modelValue":n[0]||(n[0]=a=>e.value=a),class:"value",placeholder:e.$t("wan.placeholder.select"),clearable:""},{default:d(()=>[(s(!0),r(I,null,S(e.options,a=>(s(),$(u,{key:a.value,label:a.label,value:a.value},{default:d(()=>[c("span",he,l(a.label),1)]),_:2},1032,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const ge=v(pe,[["render",_e],["__scopeId","data-v-eb090beb"]]),$e="720p",we=w({name:"ResolutionSelector",components:{ElSelect:G,ElOption:R},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=$e)}}),ve={class:"field"},be={class:"title font-bold"},ke={class:"float-left"};function ye(e,n,h,_,b,k){const u=o("el-option"),p=o("el-select");return s(),r("div",ve,[c("h2",be,l(e.$t("wan.name.resolution")),1),t(p,{modelValue:e.value,"onUpdate:modelValue":n[0]||(n[0]=a=>e.value=a),class:"value",placeholder:e.$t("wan.placeholder.select"),clearable:""},{default:d(()=>[(s(!0),r(I,null,S(e.options,a=>(s(),$(u,{key:a.value,label:a.label,value:a.value},{default:d(()=>[c("span",ke,l(a.label),1)]),_:2},1032,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Ve=v(we,[["render",ye],["__scopeId","data-v-3e39f44e"]]),Ee=5,Ie=w({name:"DurationSelector",components:{ElSelect:G,ElOption:R},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=Ee)}}),Te={class:"field"},Se={class:"title font-bold"},Le={class:"float-left"};function Ue(e,n,h,_,b,k){const u=o("el-option"),p=o("el-select");return s(),r("div",Te,[c("h2",Se,l(e.$t("wan.name.duration")),1),t(p,{modelValue:e.value,"onUpdate:modelValue":n[0]||(n[0]=a=>e.value=a),class:"value",placeholder:e.$t("wan.placeholder.select"),clearable:""},{default:d(()=>[(s(!0),r(I,null,S(e.options,a=>(s(),$(u,{key:a.value,label:a.label,value:a.value},{default:d(()=>[c("span",Le,l(a.label),1)]),_:2},1032,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Ce=v(Ie,[["render",Ue],["__scopeId","data-v-5f35a2cf"]]),Re=w({name:"ImageUrlInput",components:{ElUpload:H,ElButton:T,InfoIcon:P,ImagePreview:W},mixins:[q],data(){return{fileList:[],uploadUrl:j()+"/api/v1/files/"}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e.url).filter(e=>e!==void 0)},value:{get(){return this.$store.state.wan?.config?.image_url},set(){const e=this.urls?.[0];this.$store.commit("wan/setConfig",{...this.$store.state.wan?.config,image_url:e})}}},mounted(){this.value||(this.value=void 0),this.onSetImageUrl()},methods:{onExceed(){V.warning(this.$t("wan.message.uploadImageExceed"))},onError(){V.error(this.$t("wan.message.uploadImageError"))},async onRemove(){V.error(this.$t("wan.message.uploadImageError"))},onSetImageUrl(){const e=this.urls?.[0];this.$store.commit("wan/setConfig",{...this.$store.state.wan?.config,image_url:e})},async onSuccess(){this.onSetImageUrl()}}}),Ge={class:"relative"},Ae={class:"flex justify-between"},De={class:"flex justify-start items-center"},Pe={class:"text-sm font-bold"};function Me(e,n,h,_,b,k){const u=o("info-icon"),p=o("image-preview"),a=o("el-button"),g=o("el-upload");return s(),r("div",Ge,[c("div",Ae,[c("div",De,[c("span",Pe,l(e.$t("wan.name.imageUrl")),1),t(u,{content:e.$t("wan.description.imageUrl"),class:"info"},null,8,["content"])])]),t(g,{"file-list":e.fileList,"onUpdate:fileList":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:d(({file:i})=>[i.url&&i.percentage!==void 0?(s(),$(p,{key:0,url:i.url,name:i.name,percentage:i.percentage,onRemove:y=>e.fileList.splice(e.fileList.indexOf(i),1)},null,8,["url","name","percentage","onRemove"])):m("",!0)]),default:d(()=>[t(a,{size:"small",type:"primary",class:"btn btn-upload",round:""},{default:d(()=>[f(l(e.$t("wan.button.uploadImageUrl")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-remove","on-success","headers"])])}const Oe=v(Re,[["render",Me],["__scopeId","data-v-c9ebe1b1"]]),je="",Be=w({name:"PromptInput",components:{ElInput:J,InfoIcon:P},computed:{prompt:{get(){return this.$store.state.wan?.config?.prompt},set(e){console.debug("set prompt",e),this.$store.commit("wan/setConfig",{...this.$store.state.wan?.config,prompt:e})}}},mounted(){this.prompt||(this.prompt=je)}}),Fe={class:"field"},Ne={class:"box"},qe={class:"title font-bold"};function ze(e,n,h,_,b,k){const u=o("info-icon"),p=o("el-input");return s(),r("div",Fe,[c("div",Ne,[c("h2",qe,l(e.$t("wan.name.prompt")),1),t(u,{content:e.$t("wan.description.prompt"),class:"info"},null,8,["content"])]),t(p,{modelValue:e.prompt,"onUpdate:modelValue":n[0]||(n[0]=a=>e.prompt=a),rows:3,type:"textarea",class:"prompt",placeholder:e.$t("wan.placeholder.prompt")},null,8,["modelValue","placeholder"])])}const We=v(Be,[["render",ze],["__scopeId","data-v-45557a2d"]]),He=w({name:"PresetPanel",components:{ElButton:T,FontAwesomeIcon:C,PromptInput:We,ImageUrlInput:Oe,ModelSelector:ge,ResolutionSelector:Ve,DurationSelector:Ce,Consumption:K},emits:["generate"],computed:{config(){return this.$store.state.wan?.config},consumption(){return Q(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")}}}),Je={class:"flex flex-col h-full"},Ke={class:"flex-1 overflow-y-auto p-5"},Qe={class:"flex flex-col items-center justify-center px-5 pb-5"};function Xe(e,n,h,_,b,k){const u=o("prompt-input"),p=o("model-selector"),a=o("resolution-selector"),g=o("duration-selector"),i=o("image-url-input"),y=o("consumption"),E=o("font-awesome-icon"),A=o("el-button");return s(),r("div",Je,[c("div",Ke,[t(u,{class:"mb-4"}),t(p,{class:"mb-4"}),e.supportsResolution?(s(),$(a,{key:0,class:"mb-4"})):m("",!0),e.supportsDuration?(s(),$(g,{key:1,class:"mb-4"})):m("",!0),e.supportsImageUrl?(s(),$(i,{key:2,class:"mb-2"})):m("",!0)]),c("div",Qe,[t(y,{value:e.consumption,service:e.service},null,8,["value","service"]),t(A,{type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:d(()=>[t(E,{icon:"fa-solid fa-magic",class:"mr-2"}),f(" "+l(e.$t("wan.button.generate")),1)]),_:1},8,["onClick"])])])}const Ye=v(He,[["render",Xe]]),Ze=w({name:"TaskPreview",components:{ElImage:oe,CopyToClipboard:Z,FontAwesomeIcon:C,ElAlert:te,VideoPlayer:x,ElTooltip:ee,ElButton:T},props:{modelValue:{type:Object,required:!0}},setup(){return{WAN_LOGO:N}},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")}}}),xe={class:"preview"},et={class:"left"},tt={class:"main"},ot={class:"bot"},st={class:"datetime"},nt={class:"info"},at={key:0,class:"prompt mt-2"},lt={key:0},rt={key:1},it={key:0,class:L({content:!0,failed:!0})},ct={key:0,class:"mb-4"},dt={key:1,class:L({operations:!0,"mt-2":!0})},ut={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},pt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},mt={key:1,class:"text-[var(--el-text-color-regular)] text-xs mb-0"},ft={key:1,class:L({content:!0})},ht={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},_t={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},gt={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},$t={class:"text-[var(--el-text-color-regular)] text-xs mb-0"},wt={key:2,class:L({content:!0})},vt={class:"text-[var(--el-text-color-regular)] text-xs mb-0"};function bt(e,n,h,_,b,k){const u=o("el-image"),p=o("video-player"),a=o("el-button"),g=o("el-tooltip"),i=o("font-awesome-icon"),y=o("copy-to-clipboard"),E=o("el-alert");return s(),r("div",xe,[c("div",et,[t(u,{src:e.WAN_LOGO,class:"avatar"},null,8,["src"])]),c("div",tt,[c("div",ot,[f(l(e.$t("wan.name.wanBot"))+" ",1),c("span",st,l(e.$dayjs.format(""+new Date(parseFloat((e.modelValue?.created_at||"").toString())*1e3))),1)]),c("div",nt,[e.modelValue?.request?.prompt?(s(),r("p",at,[f(l(e.modelValue?.request?.prompt)+" ",1),e.modelValue?.response?m("",!0):(s(),r("span",lt," - ("+l(e.$t("wan.status.pending"))+") ",1)),e.modelValue?.response?.state==="processing"||e.modelValue?.response?.state==="pending"||e.modelValue?.response?.state==="running"?(s(),r("span",rt," - ("+l(e.$t("wan.status.processing"))+") ",1)):m("",!0)])):m("",!0)]),e.modelValue?.response?.success===!0?(s(),r("div",it,[e.modelValue?.response?.video_url?(s(),r("div",ct,[t(p,{src:e.modelValue?.response?.video_url},null,8,["src"])])):m("",!0),e.modelValue?.response?.video_url?(s(),r("div",dt,[t(g,{class:"box-item",effect:"dark",content:e.$t("wan.message.downloadVideo"),placement:"top-start"},{default:d(()=>[t(a,{type:"info",size:"small",class:"mb-2",onClick:n[0]||(n[0]=O(A=>e.onDownload(e.modelValue?.response?.video_url),["stop"]))},{default:d(()=>[f(l(e.$t("wan.button.download")),1)]),_:1})]),_:1},8,["content"])])):m("",!0),t(E,{closable:!1,class:"mt-2 success"},{default:d(()=>[e.modelValue?.request?.model?(s(),r("p",ut,[t(i,{icon:"fa-solid fa-hashtag",class:"mr-1"}),f(" "+l(e.$t("wan.name.model"))+": "+l(e.modelValue?.request?.model)+" ",1),t(y,{content:e.modelValue?.id},null,8,["content"])])):m("",!0),c("p",pt,[t(i,{icon:"fa-solid fa-magic",class:"mr-1"}),f(" "+l(e.$t("wan.name.taskId"))+": "+l(e.modelValue?.id)+" ",1),t(y,{content:e.modelValue?.id},null,8,["content"])]),e.modelValue?.elapsed?(s(),r("p",mt,[t(i,{icon:"fa-solid fa-clock",class:"mr-1"}),f(" "+l(e.$t("wan.name.elapsed"))+": "+l(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):m("",!0)]),_:1})])):m("",!0),e.modelValue?.response?.success===!1?(s(),r("div",ft,[t(E,{closable:!1,class:"failure"},{template:d(()=>[t(i,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),f(" "+l(e.$t("wan.name.failure")),1)]),default:d(()=>[c("p",ht,[t(i,{icon:"fa-solid fa-magic",class:"mr-1"}),f(" "+l(e.$t("wan.name.taskId"))+": "+l(e.modelValue?.id)+" ",1),t(y,{content:e.modelValue?.id},null,8,["content"])]),c("p",_t,[t(i,{icon:"fa-solid fa-circle-info",class:"mr-1"}),f(" "+l(e.$t("wan.name.failureReason"))+": "+l(e.modelValue?.response?.error?.message)+" ",1),t(y,{content:e.modelValue?.response?.error?.message},null,8,["content"])]),e.modelValue?.elapsed?(s(),r("p",gt,[t(i,{icon:"fa-solid fa-clock",class:"mr-1"}),f(" "+l(e.$t("wan.name.elapsed"))+": "+l(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):m("",!0),c("p",$t,[t(i,{icon:"fa-solid fa-hashtag",class:"mr-1"}),f(" "+l(e.$t("wan.name.traceId"))+": "+l(e.modelValue?.response?.trace_id)+" ",1),t(y,{content:e.modelValue?.response?.trace_id},null,8,["content"])])]),_:1})])):m("",!0),e.modelValue?.response?.success===void 0?(s(),r("div",wt,[t(E,{closable:!1,class:"info"},{template:d(()=>[t(i,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),f(" "+l(e.$t("wan.name.failure")),1)]),default:d(()=>[c("p",vt,[t(i,{icon:"fa-solid fa-magic",class:"mr-1"}),f(" "+l(e.$t("wan.name.taskId"))+": "+l(e.modelValue?.id)+" ",1),t(y,{content:e.modelValue?.id},null,8,["content"])])]),_:1})])):m("",!0)])])}const kt=v(Ze,[["render",bt],["__scopeId","data-v-6d1d636e"]]),yt=w({name:"RecentPanel",components:{TaskPreview:kt,BotPlaceholder:se,NoTasks:ne,ScrollList:z},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?.()}}}),Vt={key:0},Et={key:2,class:"w-full h-full flex items-center justify-center"};function It(e,n,h,_,b,k){const u=o("bot-placeholder"),p=o("task-preview"),a=o("scroll-list"),g=o("no-tasks");return s(),r(I,null,[e.tasks?.items===void 0?(s(),r("div",Vt,[t(u)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(s(),$(a,{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:d(()=>[(s(!0),r(I,null,S(e.tasks?.items,i=>(s(),$(p,{key:i.id,"model-value":i},null,8,["model-value"]))),128))]),_:1},8,["loading"])):m("",!0),e.tasks?.items?.length===0?(s(),r("div",Et,[t(g)])):m("",!0)],64)}const Tt=v(yt,[["render",It]]),St="https://webhook.acedata.cloud/wan",Lt=w({name:"WanIndex",components:{ConfigPanel:Ye,Layout:ue,RecentPanel:Tt},inject:["initialized"],data(){return{task:void 0,job:0,timer:void 0,loadingMore:!1,fetchingTasks:!1}},computed:{applicationsLoading(){return this.$store.state.wan?.status?.getApplications===D.Request},tasksLoading(){return this.$store.state.wan?.status?.getTasks===D.Request||this.fetchingTasks},credential(){return this.$store.state.wan.credential},config(){return this.$store.state.wan.config},application(){return this.$store.state.wan.application},tasks(){return this.$store.state.wan.tasks}},watch:{tasks:{handler(e,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 ae({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:h,createdAtMax:_}=e||{};console.debug("limit",n,"createdAtMin",h,"createdAtMax",_),this.fetchingTasks=!0;try{await this.$store.dispatch("wan/getTasks",{limit:n,createdAtMin:h,createdAtMax:_})}finally{this.fetchingTasks=!1}},async onGenerate(){const e={...this.config,callback_url:St},n=this.credential?.token;if(!n){console.error("no token specified");return}V.info(this.$t("wan.message.startingTask")),B("wan",Y.generate(e,{token:n})).then(()=>{V.success(this.$t("wan.message.startTaskSuccess"))}).catch(h=>{h?.response?.data?.error?.code===X?V.error(this.$t("wan.message.usedUp")):V.error(this.$t("wan.message.startTaskFailed"))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function Ut(e,n,h,_,b,k){const u=o("config-panel"),p=o("recent-panel"),a=o("layout");return s(),$(a,null,{config:d(()=>[t(u,{onGenerate:e.onGenerate},null,8,["onGenerate"])]),result:d(()=>[t(p,{ref:"recentPanel",loading:e.loadingMore,onReachTop:e.onReachTop},null,8,["loading","onReachTop"])]),_:1})}const Vo=v(Lt,[["render",Ut]]);export{Vo as default};
1
+ import{F as C}from"./index.es-DgRqc681.js";import{E as T}from"./index-BfYt3lpS.js";import{E as M}from"./index-D7TXnRb-.js";import{d as w,H as r,E as c,z as U,C as t,y as d,D as o,q as s,F as l,O as I,N as S,x as $,I as f,J as m,M as O,Q as L}from"./vendor-vue-NSDaktjZ.js";import{E as v,b8 as j,cd as B,aw as D}from"./index-BmskuvzR.js";import{a as F,b as N}from"./wan-DKq-jYOo.js";import{E as R,a as G}from"./index-BYgw8Ne9.js";import{p as q}from"./pasteUploadMixin-BurWbGNQ.js";import{I as P,S as z}from"./ScrollList-DMu-o4cw.js";import{I as W}from"./ImagePreview-DGgsF-1W.js";import{E as H}from"./index-B5iae9JX.js";import{E as V}from"./index-Z6qAnijd.js";import{E as J}from"./index-C4cFnn6h.js";import{C as K}from"./Consumption-DhMtSnnQ.js";import{a as Q}from"./price-BGnrujo6.js";import{b as X}from"./errorCode-Cqj9Td_Z.js";import{w as Y}from"./wan-B_XnEbZW.js";import{C as Z}from"./CopyToClipboard-DrzpK9ow.js";import{V as x}from"./VideoPlayer-CHTi5hkY.js";import{E as ee}from"./index-X4RPhZd6.js";import{E as te}from"./index-JlXUmriI.js";import{E as oe}from"./index-BkJcEPcB.js";import{B as se}from"./BotPlaceholder-Bxg1WSeO.js";import{N as ne}from"./NoTasks-M-MqsF2Q.js";import{l as ae}from"./pagination-Cnc6Oeyx.js";import"./use-form-item-7D-CUO4M.js";import"./index-BuyEbX8F.js";import"./vendor-axios-B8_nURbH.js";import"./vendor-dayjs-Cvgzdobq.js";import"./vendor-vue-router-Kg6s1a65.js";import"./index-ys73P36s.js";import"./typescript-D5w3x56R.js";import"./index-CEOn0L_0.js";import"./strings-beZM2Y-f.js";import"./isEqual-BPX3ojYz.js";import"./_Uint8Array-C3Lbt_45.js";import"./castArray-BgN0ywwP.js";import"./debounce-CfLqwhiY.js";import"./_baseIteratee-BEktInjh.js";import"./index-BkRv-z3G.js";import"./index-BxG3gwu6.js";import"./_baseClone-vd8PLpyA.js";import"./_initCloneObject-D5Z-CcL7.js";import"./index-BvsGeWBq.js";import"./vue-plyr-BO2nlN4c.js";import"./index-Cq1B7Sqv.js";const le=w({name:"LayoutWan",components:{ElDrawer:M,ElButton:T,FontAwesomeIcon:C},data(){return{drawer:!1}}}),re={class:"main flex flex-row flex-1"},ie={class:"config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]"},ce={class:"result h-full p-6 flex-1 flex flex-col min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]"};function de(e,n,h,_,b,k){const u=o("font-awesome-icon"),p=o("el-button"),a=o("el-drawer");return s(),r("div",re,[c("div",ie,[U(e.$slots,"config",{},void 0,!0)]),c("div",ce,[U(e.$slots,"result",{},void 0,!0)]),t(p,{circle:"",class:"menu",onClick:n[0]||(n[0]=g=>e.drawer=!0)},{default:d(()=>[t(u,{icon:"fa-solid fa-magic"})]),_:1}),t(a,{modelValue:e.drawer,"onUpdate:modelValue":n[1]||(n[1]=g=>e.drawer=g),direction:"ltr","with-header":!1,size:"340px"},{default:d(()=>[U(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const ue=v(le,[["render",de],["__scopeId","data-v-98681d9b"]]),pe=w({name:"ModelSelector",components:{ElSelect:G,ElOption:R},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=F)}}),me={class:"field"},fe={class:"title font-bold"},he={class:"float-left"};function _e(e,n,h,_,b,k){const u=o("el-option"),p=o("el-select");return s(),r("div",me,[c("h2",fe,l(e.$t("wan.name.model")),1),t(p,{modelValue:e.value,"onUpdate:modelValue":n[0]||(n[0]=a=>e.value=a),class:"value",placeholder:e.$t("wan.placeholder.select"),clearable:""},{default:d(()=>[(s(!0),r(I,null,S(e.options,a=>(s(),$(u,{key:a.value,label:a.label,value:a.value},{default:d(()=>[c("span",he,l(a.label),1)]),_:2},1032,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const ge=v(pe,[["render",_e],["__scopeId","data-v-eb090beb"]]),$e="720p",we=w({name:"ResolutionSelector",components:{ElSelect:G,ElOption:R},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=$e)}}),ve={class:"field"},be={class:"title font-bold"},ke={class:"float-left"};function ye(e,n,h,_,b,k){const u=o("el-option"),p=o("el-select");return s(),r("div",ve,[c("h2",be,l(e.$t("wan.name.resolution")),1),t(p,{modelValue:e.value,"onUpdate:modelValue":n[0]||(n[0]=a=>e.value=a),class:"value",placeholder:e.$t("wan.placeholder.select"),clearable:""},{default:d(()=>[(s(!0),r(I,null,S(e.options,a=>(s(),$(u,{key:a.value,label:a.label,value:a.value},{default:d(()=>[c("span",ke,l(a.label),1)]),_:2},1032,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Ve=v(we,[["render",ye],["__scopeId","data-v-3e39f44e"]]),Ee=5,Ie=w({name:"DurationSelector",components:{ElSelect:G,ElOption:R},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=Ee)}}),Te={class:"field"},Se={class:"title font-bold"},Le={class:"float-left"};function Ue(e,n,h,_,b,k){const u=o("el-option"),p=o("el-select");return s(),r("div",Te,[c("h2",Se,l(e.$t("wan.name.duration")),1),t(p,{modelValue:e.value,"onUpdate:modelValue":n[0]||(n[0]=a=>e.value=a),class:"value",placeholder:e.$t("wan.placeholder.select"),clearable:""},{default:d(()=>[(s(!0),r(I,null,S(e.options,a=>(s(),$(u,{key:a.value,label:a.label,value:a.value},{default:d(()=>[c("span",Le,l(a.label),1)]),_:2},1032,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Ce=v(Ie,[["render",Ue],["__scopeId","data-v-5f35a2cf"]]),Re=w({name:"ImageUrlInput",components:{ElUpload:H,ElButton:T,InfoIcon:P,ImagePreview:W},mixins:[q],data(){return{fileList:[],uploadUrl:j()+"/api/v1/files/"}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e.url).filter(e=>e!==void 0)},value:{get(){return this.$store.state.wan?.config?.image_url},set(){const e=this.urls?.[0];this.$store.commit("wan/setConfig",{...this.$store.state.wan?.config,image_url:e})}}},mounted(){this.value||(this.value=void 0),this.onSetImageUrl()},methods:{onExceed(){V.warning(this.$t("wan.message.uploadImageExceed"))},onError(){V.error(this.$t("wan.message.uploadImageError"))},async onRemove(){V.error(this.$t("wan.message.uploadImageError"))},onSetImageUrl(){const e=this.urls?.[0];this.$store.commit("wan/setConfig",{...this.$store.state.wan?.config,image_url:e})},async onSuccess(){this.onSetImageUrl()}}}),Ge={class:"relative"},Ae={class:"flex justify-between"},De={class:"flex justify-start items-center"},Pe={class:"text-sm font-bold"};function Me(e,n,h,_,b,k){const u=o("info-icon"),p=o("image-preview"),a=o("el-button"),g=o("el-upload");return s(),r("div",Ge,[c("div",Ae,[c("div",De,[c("span",Pe,l(e.$t("wan.name.imageUrl")),1),t(u,{content:e.$t("wan.description.imageUrl"),class:"info"},null,8,["content"])])]),t(g,{"file-list":e.fileList,"onUpdate:fileList":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:d(({file:i})=>[i.url&&i.percentage!==void 0?(s(),$(p,{key:0,url:i.url,name:i.name,percentage:i.percentage,onRemove:y=>e.fileList.splice(e.fileList.indexOf(i),1)},null,8,["url","name","percentage","onRemove"])):m("",!0)]),default:d(()=>[t(a,{size:"small",type:"primary",class:"btn btn-upload",round:""},{default:d(()=>[f(l(e.$t("wan.button.uploadImageUrl")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-remove","on-success","headers"])])}const Oe=v(Re,[["render",Me],["__scopeId","data-v-c9ebe1b1"]]),je="",Be=w({name:"PromptInput",components:{ElInput:J,InfoIcon:P},computed:{prompt:{get(){return this.$store.state.wan?.config?.prompt},set(e){console.debug("set prompt",e),this.$store.commit("wan/setConfig",{...this.$store.state.wan?.config,prompt:e})}}},mounted(){this.prompt||(this.prompt=je)}}),Fe={class:"field"},Ne={class:"box"},qe={class:"title font-bold"};function ze(e,n,h,_,b,k){const u=o("info-icon"),p=o("el-input");return s(),r("div",Fe,[c("div",Ne,[c("h2",qe,l(e.$t("wan.name.prompt")),1),t(u,{content:e.$t("wan.description.prompt"),class:"info"},null,8,["content"])]),t(p,{modelValue:e.prompt,"onUpdate:modelValue":n[0]||(n[0]=a=>e.prompt=a),rows:3,type:"textarea",class:"prompt",placeholder:e.$t("wan.placeholder.prompt")},null,8,["modelValue","placeholder"])])}const We=v(Be,[["render",ze],["__scopeId","data-v-45557a2d"]]),He=w({name:"PresetPanel",components:{ElButton:T,FontAwesomeIcon:C,PromptInput:We,ImageUrlInput:Oe,ModelSelector:ge,ResolutionSelector:Ve,DurationSelector:Ce,Consumption:K},emits:["generate"],computed:{config(){return this.$store.state.wan?.config},consumption(){return Q(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")}}}),Je={class:"flex flex-col h-full"},Ke={class:"flex-1 overflow-y-auto p-5"},Qe={class:"flex flex-col items-center justify-center px-5 pb-5"};function Xe(e,n,h,_,b,k){const u=o("prompt-input"),p=o("model-selector"),a=o("resolution-selector"),g=o("duration-selector"),i=o("image-url-input"),y=o("consumption"),E=o("font-awesome-icon"),A=o("el-button");return s(),r("div",Je,[c("div",Ke,[t(u,{class:"mb-4"}),t(p,{class:"mb-4"}),e.supportsResolution?(s(),$(a,{key:0,class:"mb-4"})):m("",!0),e.supportsDuration?(s(),$(g,{key:1,class:"mb-4"})):m("",!0),e.supportsImageUrl?(s(),$(i,{key:2,class:"mb-2"})):m("",!0)]),c("div",Qe,[t(y,{value:e.consumption,service:e.service},null,8,["value","service"]),t(A,{type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:d(()=>[t(E,{icon:"fa-solid fa-magic",class:"mr-2"}),f(" "+l(e.$t("wan.button.generate")),1)]),_:1},8,["onClick"])])])}const Ye=v(He,[["render",Xe]]),Ze=w({name:"TaskPreview",components:{ElImage:oe,CopyToClipboard:Z,FontAwesomeIcon:C,ElAlert:te,VideoPlayer:x,ElTooltip:ee,ElButton:T},props:{modelValue:{type:Object,required:!0}},setup(){return{WAN_LOGO:N}},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")}}}),xe={class:"preview"},et={class:"left"},tt={class:"main"},ot={class:"bot"},st={class:"datetime"},nt={class:"info"},at={key:0,class:"prompt mt-2"},lt={key:0},rt={key:1},it={key:0,class:L({content:!0,failed:!0})},ct={key:0,class:"mb-4"},dt={key:1,class:L({operations:!0,"mt-2":!0})},ut={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},pt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},mt={key:1,class:"text-[var(--el-text-color-regular)] text-xs mb-0"},ft={key:1,class:L({content:!0})},ht={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},_t={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},gt={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},$t={class:"text-[var(--el-text-color-regular)] text-xs mb-0"},wt={key:2,class:L({content:!0})},vt={class:"text-[var(--el-text-color-regular)] text-xs mb-0"};function bt(e,n,h,_,b,k){const u=o("el-image"),p=o("video-player"),a=o("el-button"),g=o("el-tooltip"),i=o("font-awesome-icon"),y=o("copy-to-clipboard"),E=o("el-alert");return s(),r("div",xe,[c("div",et,[t(u,{src:e.WAN_LOGO,class:"avatar"},null,8,["src"])]),c("div",tt,[c("div",ot,[f(l(e.$t("wan.name.wanBot"))+" ",1),c("span",st,l(e.$dayjs.format(""+new Date(parseFloat((e.modelValue?.created_at||"").toString())*1e3))),1)]),c("div",nt,[e.modelValue?.request?.prompt?(s(),r("p",at,[f(l(e.modelValue?.request?.prompt)+" ",1),e.modelValue?.response?m("",!0):(s(),r("span",lt," - ("+l(e.$t("wan.status.pending"))+") ",1)),e.modelValue?.response?.state==="processing"||e.modelValue?.response?.state==="pending"||e.modelValue?.response?.state==="running"?(s(),r("span",rt," - ("+l(e.$t("wan.status.processing"))+") ",1)):m("",!0)])):m("",!0)]),e.modelValue?.response?.success===!0?(s(),r("div",it,[e.modelValue?.response?.video_url?(s(),r("div",ct,[t(p,{src:e.modelValue?.response?.video_url},null,8,["src"])])):m("",!0),e.modelValue?.response?.video_url?(s(),r("div",dt,[t(g,{class:"box-item",effect:"dark",content:e.$t("wan.message.downloadVideo"),placement:"top-start"},{default:d(()=>[t(a,{type:"info",size:"small",class:"mb-2",onClick:n[0]||(n[0]=O(A=>e.onDownload(e.modelValue?.response?.video_url),["stop"]))},{default:d(()=>[f(l(e.$t("wan.button.download")),1)]),_:1})]),_:1},8,["content"])])):m("",!0),t(E,{closable:!1,class:"mt-2 success"},{default:d(()=>[e.modelValue?.request?.model?(s(),r("p",ut,[t(i,{icon:"fa-solid fa-hashtag",class:"mr-1"}),f(" "+l(e.$t("wan.name.model"))+": "+l(e.modelValue?.request?.model)+" ",1),t(y,{content:e.modelValue?.id},null,8,["content"])])):m("",!0),c("p",pt,[t(i,{icon:"fa-solid fa-magic",class:"mr-1"}),f(" "+l(e.$t("wan.name.taskId"))+": "+l(e.modelValue?.id)+" ",1),t(y,{content:e.modelValue?.id},null,8,["content"])]),e.modelValue?.elapsed?(s(),r("p",mt,[t(i,{icon:"fa-solid fa-clock",class:"mr-1"}),f(" "+l(e.$t("wan.name.elapsed"))+": "+l(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):m("",!0)]),_:1})])):m("",!0),e.modelValue?.response?.success===!1?(s(),r("div",ft,[t(E,{closable:!1,class:"failure"},{template:d(()=>[t(i,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),f(" "+l(e.$t("wan.name.failure")),1)]),default:d(()=>[c("p",ht,[t(i,{icon:"fa-solid fa-magic",class:"mr-1"}),f(" "+l(e.$t("wan.name.taskId"))+": "+l(e.modelValue?.id)+" ",1),t(y,{content:e.modelValue?.id},null,8,["content"])]),c("p",_t,[t(i,{icon:"fa-solid fa-circle-info",class:"mr-1"}),f(" "+l(e.$t("wan.name.failureReason"))+": "+l(e.modelValue?.response?.error?.message)+" ",1),t(y,{content:e.modelValue?.response?.error?.message},null,8,["content"])]),e.modelValue?.elapsed?(s(),r("p",gt,[t(i,{icon:"fa-solid fa-clock",class:"mr-1"}),f(" "+l(e.$t("wan.name.elapsed"))+": "+l(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):m("",!0),c("p",$t,[t(i,{icon:"fa-solid fa-hashtag",class:"mr-1"}),f(" "+l(e.$t("wan.name.traceId"))+": "+l(e.modelValue?.response?.trace_id)+" ",1),t(y,{content:e.modelValue?.response?.trace_id},null,8,["content"])])]),_:1})])):m("",!0),e.modelValue?.response?.success===void 0?(s(),r("div",wt,[t(E,{closable:!1,class:"info"},{template:d(()=>[t(i,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),f(" "+l(e.$t("wan.name.failure")),1)]),default:d(()=>[c("p",vt,[t(i,{icon:"fa-solid fa-magic",class:"mr-1"}),f(" "+l(e.$t("wan.name.taskId"))+": "+l(e.modelValue?.id)+" ",1),t(y,{content:e.modelValue?.id},null,8,["content"])])]),_:1})])):m("",!0)])])}const kt=v(Ze,[["render",bt],["__scopeId","data-v-6d1d636e"]]),yt=w({name:"RecentPanel",components:{TaskPreview:kt,BotPlaceholder:se,NoTasks:ne,ScrollList:z},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?.()}}}),Vt={key:0},Et={key:2,class:"w-full h-full flex items-center justify-center"};function It(e,n,h,_,b,k){const u=o("bot-placeholder"),p=o("task-preview"),a=o("scroll-list"),g=o("no-tasks");return s(),r(I,null,[e.tasks?.items===void 0?(s(),r("div",Vt,[t(u)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(s(),$(a,{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:d(()=>[(s(!0),r(I,null,S(e.tasks?.items,i=>(s(),$(p,{key:i.id,"model-value":i},null,8,["model-value"]))),128))]),_:1},8,["loading"])):m("",!0),e.tasks?.items?.length===0?(s(),r("div",Et,[t(g)])):m("",!0)],64)}const Tt=v(yt,[["render",It]]),St="https://webhook.acedata.cloud/wan",Lt=w({name:"WanIndex",components:{ConfigPanel:Ye,Layout:ue,RecentPanel:Tt},inject:["initialized"],data(){return{task:void 0,job:0,timer:void 0,loadingMore:!1,fetchingTasks:!1}},computed:{applicationsLoading(){return this.$store.state.wan?.status?.getApplications===D.Request},tasksLoading(){return this.$store.state.wan?.status?.getTasks===D.Request||this.fetchingTasks},credential(){return this.$store.state.wan.credential},config(){return this.$store.state.wan.config},application(){return this.$store.state.wan.application},tasks(){return this.$store.state.wan.tasks}},watch:{tasks:{handler(e,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 ae({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:h,createdAtMax:_}=e||{};console.debug("limit",n,"createdAtMin",h,"createdAtMax",_),this.fetchingTasks=!0;try{await this.$store.dispatch("wan/getTasks",{limit:n,createdAtMin:h,createdAtMax:_})}finally{this.fetchingTasks=!1}},async onGenerate(){const e={...this.config,callback_url:St},n=this.credential?.token;if(!n){console.error("no token specified");return}V.info(this.$t("wan.message.startingTask")),B("wan",Y.generate(e,{token:n})).then(()=>{V.success(this.$t("wan.message.startTaskSuccess"))}).catch(h=>{h?.response?.data?.error?.code===X?V.error(this.$t("wan.message.usedUp")):V.error(this.$t("wan.message.startTaskFailed"))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function Ut(e,n,h,_,b,k){const u=o("config-panel"),p=o("recent-panel"),a=o("layout");return s(),$(a,null,{config:d(()=>[t(u,{onGenerate:e.onGenerate},null,8,["onGenerate"])]),result:d(()=>[t(p,{ref:"recentPanel",loading:e.loadingMore,onReachTop:e.onReachTop},null,8,["loading","onReachTop"])]),_:1})}const Vo=v(Lt,[["render",Ut]]);export{Vo as default};
@@ -1 +1 @@
1
- import{F as S}from"./index.es-CqUFafZ-.js";import{E as q}from"./index-C3HcWVsL.js";import{E as W}from"./index-B3UfVG_d.js";import{d as k,H as l,E as c,z as C,C as o,y as $,D as s,q as n,F as a,I as u,O as A,N,x as V,J as g,M as H,Q as O}from"./vendor-vue-NSDaktjZ.js";import{E as y,b8 as K,cq as J,cr as x,cs as P,ct as Q,cu as T,cv as G,cw as j,cx as D,cd as X,aw as F}from"./index-BAlXF3lp.js";import{I as U,S as Y}from"./ScrollList-DKlPMNZT.js";import{E as Z}from"./index-DhStH-hF.js";import{p as ee}from"./pasteUploadMixin-BurWbGNQ.js";import{I as z}from"./ImagePreview-BuuE19Gy.js";import{E as te}from"./index-BtBl6GQu.js";import{E as R}from"./index-czzMfzSq.js";import{E as B,a as M}from"./index-CcnMKyw7.js";import{C as oe}from"./Consumption-DEJXi9Yk.js";import{a as ae}from"./price-Bs-d-Bvz.js";import{b as ne}from"./errorCode-Cqj9Td_Z.js";import{n as se}from"./nanobanana-DewrOPDP.js";import{C as le}from"./CopyToClipboard-DB2Z-HRU.js";import{I as re}from"./ImageWrapper-B87viqTL.js";import{E as ie}from"./index-5GxMphke.js";import{E as ce}from"./index-Hxc7n4HD.js";import{E as ue}from"./index-C2sZXfFW.js";import{B as de}from"./BotPlaceholder-5oNK0Ith.js";import{N as me}from"./NoTasks-ZpQi0TyE.js";import"./use-form-item-DooKcsta.js";import"./index-BuyEbX8F.js";import"./vendor-axios-B8_nURbH.js";import"./vendor-dayjs-Cvgzdobq.js";import"./vendor-vue-router-Kg6s1a65.js";import"./typescript-DGijeo9F.js";import"./index-C9pbuvyJ.js";import"./index-DWiPtPwc.js";import"./index-DHE-zvMr.js";import"./_baseClone-DZS2KndZ.js";import"./_Uint8Array-ByIiAerw.js";import"./_initCloneObject-CuynXAWC.js";import"./isEqual-CIKj9pK6.js";import"./index-Bd83o_xd.js";import"./strings-beZM2Y-f.js";import"./castArray-Dy2e0JbB.js";import"./debounce-Cu_Jtjpm.js";import"./_baseIteratee-DWXq1g8X.js";import"./index-bQIOVtse.js";import"./index-C1HKY4Q8.js";const pe=k({name:"LayoutNanobanana",components:{ElDrawer:W,ElButton:q,FontAwesomeIcon:S},data(){return{drawer:!1}}}),fe={class:"main flex flex-row flex-1"},he={class:"config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]"},_e={class:"result h-full p-6 flex-1 flex flex-col min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]"};function ge(e,t,b,i,d,f){const h=s("font-awesome-icon"),_=s("el-button"),m=s("el-drawer");return n(),l("div",fe,[c("div",he,[C(e.$slots,"config",{},void 0,!0)]),c("div",_e,[C(e.$slots,"result",{},void 0,!0)]),o(_,{circle:"",class:"menu",onClick:t[0]||(t[0]=p=>e.drawer=!0)},{default:$(()=>[o(h,{icon:"fa-solid fa-magic"})]),_:1}),o(m,{modelValue:e.drawer,"onUpdate:modelValue":t[1]||(t[1]=p=>e.drawer=p),direction:"ltr","with-header":!1,size:"340px",class:"drawer"},{default:$(()=>[C(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const be=y(pe,[["render",ge],["__scopeId","data-v-9fbc8a5c"]]),$e="",ve=k({name:"PromptInput",components:{ElInput:Z,InfoIcon:U},computed:{prompt:{get(){return this.$store.state.nanobanana?.config?.prompt},set(e){console.debug("set prompt",e),this.$store.commit("nanobanana/setConfig",{...this.$store.state.nanobanana?.config,prompt:e})}}},mounted(){this.prompt||(this.prompt=$e)}}),ke={class:"field"},ye={class:"box"},we={class:"title font-bold"};function Ae(e,t,b,i,d,f){const h=s("info-icon"),_=s("el-input");return n(),l("div",ke,[c("div",ye,[c("h2",we,a(e.$t("nanobanana.name.prompt")),1),o(h,{content:e.$t("nanobanana.description.prompt"),class:"info"},null,8,["content"])]),o(_,{modelValue:e.prompt,"onUpdate:modelValue":t[0]||(t[0]=m=>e.prompt=m),rows:3,type:"textarea",class:"prompt",placeholder:e.$t("nanobanana.placeholder.prompt")},null,8,["modelValue","placeholder"])])}const Ve=y(ve,[["render",Ae],["__scopeId","data-v-2331e197"]]),Ne=k({name:"ImageUrlsInput",components:{ElUpload:te,ElButton:q,InfoIcon:U,ImagePreview:z,FontAwesomeIcon:S},mixins:[ee],data(){return{fileList:[],uploadUrl:K()+"/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 i=(this.fileList||[]).filter(d=>!d?.response?.file_url);this.fileList=i.length?i:[];return}const t=[];e.forEach(i=>{const d=this.fileList.find(f=>f?.response?.file_url===i||f?.url===i);d?t.push(d):t.push({name:i.split("/").pop()||i,url:i,status:"success",percentage:100,response:{file_url:i}})}),(this.fileList||[]).filter(i=>!i?.response?.file_url).forEach(i=>{t.some(f=>f===i||f?.url===i?.url||f?.response?.file_url===i?.response?.file_url)||t.push(i)}),this.fileList=t}}},mounted(){},methods:{onChange(e){if(!e?.url&&e?.raw)try{e.url=URL.createObjectURL(e.raw)}catch{}},onRemove(e){if(e?.url&&typeof e.url=="string"&&e.url.startsWith("blob:"))try{URL.revokeObjectURL(e.url)}catch{}this.onSetImageUrls()},onExceed(){R.warning(this.$t("nanobanana.message.uploadImageExceed"))},onError(){R.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()}}}),Ee={class:"field flex items-center justify-between"},Re={class:"title font-bold text-[14px] mb-[10px]"},Ie={class:"upload-wrapper flex flex-col items-start gap-[8px]"},Le={class:"controls flex items-center"},Te={class:"file-list flex flex-wrap gap-[10px]"};function Se(e,t,b,i,d,f){const h=s("font-awesome-icon"),_=s("el-button"),m=s("el-upload"),p=s("info-icon"),w=s("image-preview");return n(),l(A,null,[c("div",Ee,[c("h2",Re,a(e.$t("nanobanana.name.imageUrls")),1),c("div",Ie,[c("div",Le,[o(m,{ref:"uploader","file-list":e.fileList,"onUpdate:fileList":t[0]||(t[0]=r=>e.fileList=r),accept:".png,.jpg,.jpeg,.gif,.bmp,.webp",name:"file",class:"value",limit:5,multiple:!0,"show-file-list":!1,action:e.uploadUrl,"on-exceed":e.onExceed,"on-error":e.onError,"on-success":e.onSuccess,"on-change":e.onChange,"on-remove":e.onRemove,headers:e.headers},{default:$(()=>[o(_,{size:"small",type:"primary",round:""},{default:$(()=>[o(h,{icon:"fa-solid fa-upload",class:"mr-1"}),u(" "+a(e.$t("nanobanana.button.uploadImageUrls")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-success","on-change","on-remove","headers"]),o(p,{content:e.$t("nanobanana.description.imageUrls"),class:"ml-2"},null,8,["content"])])])]),c("div",Te,[(n(!0),l(A,null,N(e.fileList,(r,v)=>(n(),V(w,{key:r.uid||r?.response?.file_url||r.url||v,url:r.url||r?.response?.file_url,name:r.name,percentage:r.percentage,onRemove:E=>e.onRemovePreview(v,r)},null,8,["url","name","percentage","onRemove"]))),128))])],64)}const qe=y(Ne,[["render",Se]]),Oe=k({name:"AspectRatioSelector",components:{ElSelect:M,ElOption:B},data(){return{options:["1:1","3:2","2:3","16:9","9:16","4:3","3:4"]}},computed:{value:{get(){return this.$store.state.nanobanana?.config?.aspect_ratio},set(e){console.debug("set aspect_ratio",e);const t={...this.$store.state.nanobanana?.config||{}};e?t.aspect_ratio=e:delete t.aspect_ratio,this.$store.commit("nanobanana/setConfig",t)}}}}),Ue={class:"field"},Ce={class:"title font-bold"};function Pe(e,t,b,i,d,f){const h=s("el-option"),_=s("el-select");return n(),l("div",Ue,[c("h2",Ce,a(e.$t("nanobanana.name.aspectRatio")),1),o(_,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=m=>e.value=m),class:"value",clearable:"",placeholder:e.$t("nanobanana.placeholder.select")},{default:$(()=>[(n(!0),l(A,null,N(e.options,m=>(n(),V(h,{key:m,label:m,value:m},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Be=y(Oe,[["render",Pe],["__scopeId","data-v-67f08a08"]]),Me=k({name:"NanobananaModelSelector",components:{ElSelect:M,ElOption:B,InfoIcon:U},data(){return{options:[{value:x,label:this.$t("nanobanana.model.nanoBanana")},{value:P,label:this.$t("nanobanana.model.nanoBananaPro")},{value:Q,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=J)}}),Ge={class:"field"},je={class:"label"},De={class:"box"},Fe={class:"title font-bold"};function xe(e,t,b,i,d,f){const h=s("info-icon"),_=s("el-option"),m=s("el-select");return n(),l("div",Ge,[c("div",je,[c("div",De,[c("h2",Fe,a(e.$t("nanobanana.name.model")),1),o(h,{content:e.modelDescription,class:"info"},null,8,["content"])])]),o(m,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=p=>e.value=p),class:"value",placeholder:e.$t("nanobanana.placeholder.select")},{default:$(()=>[(n(!0),l(A,null,N(e.options,p=>(n(),V(_,{key:p.value,label:p.label,value:p.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const ze=y(Me,[["render",xe],["__scopeId","data-v-94304d73"]]),We=k({name:"NanobananaResolutionSelector",components:{ElSelect:M,ElOption:B,InfoIcon:U},data(){return{cachedResolution:T,options:[{value:G,label:G},{value:j,label:j},{value:D,label:D}]}},computed:{value:{get(){return this.$store.state.nanobanana?.config?.resolution},set(e){this.$store.commit("nanobanana/setConfig",{...this.$store.state.nanobanana?.config,resolution:e})}},isProModel(){return this.$store.state.nanobanana?.config?.model!==x}},watch:{value(e){this.isProModel&&e&&(this.cachedResolution=e)},isProModel(e){e?this.value||(this.value=this.cachedResolution||T):(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=T),!this.isProModel&&this.value&&(this.cachedResolution=this.value,this.$store.commit("nanobanana/setConfig",{...this.$store.state.nanobanana?.config,resolution:void 0}))}}),He={class:"field"},Ke={class:"label"},Je={class:"box"},Qe={class:"title font-bold"};function Xe(e,t,b,i,d,f){const h=s("info-icon"),_=s("el-option"),m=s("el-select");return n(),l("div",He,[c("div",Ke,[c("div",Je,[c("h2",Qe,a(e.$t("nanobanana.name.resolution")),1),o(h,{content:e.$t("nanobanana.description.resolutionProOnly"),class:"info"},null,8,["content"])])]),o(m,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=p=>e.value=p),class:"value",placeholder:e.$t("nanobanana.placeholder.select"),disabled:!e.isProModel},{default:$(()=>[(n(!0),l(A,null,N(e.options,p=>(n(),V(_,{key:p.value,label:p.label,value:p.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder","disabled"])])}const Ye=y(We,[["render",Xe],["__scopeId","data-v-fd5ab393"]]),Ze=k({name:"ConfigPanel",components:{ElButton:q,FontAwesomeIcon:S,PromptInput:Ve,Consumption:oe,ImageUrlsInput:qe,AspectRatioSelector:Be,ModelSelector:ze,ResolutionSelector:Ye},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 ae({...e,action:t?"edit":"generate"},this.service?.cost)},service(){return this.$store.state.nanobanana?.service}},methods:{onGenerate(){this.$emit("generate")}}}),et={class:"flex flex-col h-full"},tt={class:"flex-1 overflow-y-auto p-5"},ot={class:"flex flex-col items-center justify-center px-5 pb-5"};function at(e,t,b,i,d,f){const h=s("model-selector"),_=s("resolution-selector"),m=s("prompt-input"),p=s("aspect-ratio-selector"),w=s("image-urls-input"),r=s("consumption"),v=s("font-awesome-icon"),E=s("el-button");return n(),l("div",et,[c("div",tt,[o(h,{class:"mb-4"}),o(_,{class:"mb-4"}),o(m,{class:"mb-4"}),o(p,{class:"mb-4"}),o(w,{class:"mb-4"})]),c("div",ot,[o(r,{value:e.consumption,service:e.service},null,8,["value","service"]),o(E,{type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:$(()=>[o(v,{icon:"fa-solid fa-magic",class:"mr-2"}),u(" "+a(e.$t("nanobanana.button.generate")),1)]),_:1},8,["onClick"])])])}const nt=y(Ze,[["render",at]]),st=k({name:"TaskPreview",components:{ElImage:ue,CopyToClipboard:le,FontAwesomeIcon:S,ElAlert:ce,ImageWrapper:re,ElButton:q,ElTooltip:ie,ImagePreview:z},props:{modelValue:{type:Object,required:!0}},computed:{images(){const e=[];return Array.isArray(this.modelValue?.response?.data)&&this.modelValue?.response?.data?.forEach(t=>{e.push(t)}),e}},methods:{onEdit(e){if(!e)return;console.debug("Edit image:",e);const t={...this.$store.state.nanobanana?.config||{}};delete t.action,t.image_urls=[e],this.$store.commit("nanobanana/setConfig",t)}}}),lt={class:"preview"},rt={class:"left"},it={class:"main"},ct={class:"bot"},ut={class:"datetime"},dt={class:"info"},mt={key:0,class:"flex justify-start items-center gap-2 mt-2 w-full overflow-x-auto"},pt={key:1,class:"prompt mt-2"},ft={key:0},ht={key:0,class:O({content:!0,failed:!0})},_t={class:"flex justify-start items-center gap-4 w-full overflow-x-auto"},gt={class:O({operations:!0,"mt-2":!0,"mb-2":!0})},bt={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},$t={key:1,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},vt={key:2,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},kt={key:3,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},yt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},wt={key:4,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},At={key:5,class:"text-[var(--el-text-color-regular)] text-xs mb-0"},Vt={key:1,class:O({content:!0})},Nt={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Et={key:1,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Rt={key:2,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},It={key:3,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Lt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Tt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},St={key:4,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},qt={key:5,class:"text-[var(--el-text-color-regular)] text-xs mb-0"},Ot={key:2,class:O({content:!0})},Ut={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Ct={key:1,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Pt={key:2,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Bt={key:3,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Mt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"};function Gt(e,t,b,i,d,f){const h=s("el-image"),_=s("image-preview"),m=s("image-wrapper"),p=s("el-button"),w=s("el-tooltip"),r=s("font-awesome-icon"),v=s("copy-to-clipboard"),E=s("el-alert");return n(),l("div",lt,[c("div",rt,[o(h,{src:"https://cdn.acedata.cloud/859plc.jpg",class:"avatar"})]),c("div",it,[c("div",ct,[u(a(e.$t("nanobanana.name.nanobananaBot"))+" ",1),c("span",ut,a(e.$dayjs.format(""+new Date(parseFloat((e.modelValue?.created_at||"").toString())*1e3))),1)]),c("div",dt,[e.modelValue?.request?.image_urls&&e.modelValue?.request?.image_urls.length>0?(n(),l("div",mt,[(n(!0),l(A,null,N(e.modelValue?.request?.image_urls,(I,L)=>(n(),V(_,{key:L,url:I,name:`image-${L+1}`,closable:!1},null,8,["url","name"]))),128))])):g("",!0),e.modelValue?.request?.prompt?(n(),l("p",pt,[u(a(e.modelValue?.request?.prompt)+" ",1),e.modelValue?.response?g("",!0):(n(),l("span",ft," - ("+a(e.$t("nanobanana.status.pending"))+") ",1))])):g("",!0)]),e.modelValue?.response?.success===!0?(n(),l("div",ht,[c("div",_t,[(n(!0),l(A,null,N(e.images,(I,L)=>(n(),V(m,{key:L,src:I?.image_url,"raw-src":I?.image_url},null,8,["src","raw-src"]))),128))]),c("div",gt,[o(w,{class:"box-item",effect:"dark",content:e.$t("common.button.edit"),placement:"top-start"},{default:$(()=>[o(p,{type:"info",size:"small",class:"btn-action",onClick:t[0]||(t[0]=H(I=>e.onEdit(e.images?.[0]?.image_url),["stop"]))},{default:$(()=>[u(a(e.$t("common.button.edit")),1)]),_:1})]),_:1},8,["content"])]),o(E,{closable:!1,class:"mt-2 success"},{default:$(()=>[e.modelValue?.request?.model?(n(),l("p",bt,[o(r,{icon:"fa-solid fa-cube",class:"mr-1"}),u(" "+a(e.$t("nanobanana.name.model"))+": "+a(e.modelValue?.request?.model),1)])):g("",!0),e.modelValue?.request?.resolution?(n(),l("p",$t,[o(r,{icon:"fa-solid fa-image",class:"mr-1"}),u(" "+a(e.$t("nanobanana.name.resolution"))+": "+a(e.modelValue?.request?.resolution),1)])):g("",!0),e.modelValue?.request?.aspect_ratio?(n(),l("p",vt,[o(r,{icon:"fa-solid fa-up-right-from-square",class:"mr-1"}),u(" "+a(e.$t("nanobanana.name.aspectRatio"))+": "+a(e.modelValue?.request?.aspect_ratio),1)])):g("",!0),e.modelValue?.request?.action?(n(),l("p",kt,[o(r,{icon:"fa-solid fa-bolt",class:"mr-1"}),u(" "+a(e.$t("nanobanana.name.task"))+": "+a(e.modelValue?.request?.action==="generate"?e.$t("nanobanana.name.generate"):e.$t("nanobanana.name.edits")),1)])):g("",!0),c("p",yt,[o(r,{icon:"fa-solid fa-magic",class:"mr-1"}),u(" "+a(e.$t("nanobanana.name.taskId"))+": "+a(e.modelValue?.id)+" ",1),o(v,{content:e.modelValue?.id,class:"btn-copy inline-block"},null,8,["content"])]),e.modelValue?.elapsed?(n(),l("p",wt,[o(r,{icon:"fa-solid fa-clock",class:"mr-1"}),u(" "+a(e.$t("nanobanana.name.elapsed"))+": "+a(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):g("",!0),e.modelValue?.response?.trace_id?(n(),l("p",At,[o(r,{icon:"fa-solid fa-hashtag",class:"mr-1"}),u(" "+a(e.$t("nanobanana.name.traceId"))+": "+a(e.modelValue?.response?.trace_id)+" ",1),o(v,{content:e.modelValue?.response?.trace_id,class:"btn-copy inline-block"},null,8,["content"])])):g("",!0)]),_:1})])):e.modelValue?.response?.success===!1?(n(),l("div",Vt,[o(E,{closable:!1,class:"failure"},{template:$(()=>[o(r,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),u(" "+a(e.$t("nanobanana.name.failure")),1)]),default:$(()=>[e.modelValue?.request?.model?(n(),l("p",Nt,[o(r,{icon:"fa-solid fa-cube",class:"mr-1"}),u(" "+a(e.$t("nanobanana.name.model"))+": "+a(e.modelValue?.request?.model),1)])):g("",!0),e.modelValue?.request?.resolution?(n(),l("p",Et,[o(r,{icon:"fa-solid fa-image",class:"mr-1"}),u(" "+a(e.$t("nanobanana.name.resolution"))+": "+a(e.modelValue?.request?.resolution),1)])):g("",!0),e.modelValue?.request?.aspect_ratio?(n(),l("p",Rt,[o(r,{icon:"fa-solid fa-up-right-from-square",class:"mr-1"}),u(" "+a(e.$t("nanobanana.name.aspectRatio"))+": "+a(e.modelValue?.request?.aspect_ratio),1)])):g("",!0),e.modelValue?.request?.action?(n(),l("p",It,[o(r,{icon:"fa-solid fa-bolt",class:"mr-1"}),u(" "+a(e.$t("nanobanana.name.task"))+": "+a(e.modelValue?.request?.action==="generate"?e.$t("nanobanana.name.generate"):e.$t("nanobanana.name.edits")),1)])):g("",!0),c("p",Lt,[o(r,{icon:"fa-solid fa-magic",class:"mr-1"}),u(" "+a(e.$t("nanobanana.name.taskId"))+": "+a(e.modelValue?.id)+" ",1),o(v,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])]),c("p",Tt,[o(r,{icon:"fa-solid fa-circle-info",class:"mr-1"}),u(" "+a(e.$t("nanobanana.name.failureReason"))+": "+a(e.modelValue?.response?.error?.message)+" ",1),o(v,{content:e.modelValue?.response?.error?.message,class:"btn-copy"},null,8,["content"])]),e.modelValue?.elapsed?(n(),l("p",St,[o(r,{icon:"fa-solid fa-clock",class:"mr-1"}),u(" "+a(e.$t("nanobanana.name.elapsed"))+": "+a(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):g("",!0),e.modelValue?.response?.trace_id?(n(),l("p",qt,[o(r,{icon:"fa-solid fa-hashtag",class:"mr-1"}),u(" "+a(e.$t("nanobanana.name.traceId"))+": "+a(e.modelValue?.response?.trace_id)+" ",1),o(v,{content:e.modelValue?.response?.trace_id,class:"btn-copy"},null,8,["content"])])):g("",!0)]),_:1})])):(n(),l("div",Ot,[o(E,{closable:!1,class:"info"},{template:$(()=>[o(r,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),u(" "+a(e.$t("nanobanana.name.failure")),1)]),default:$(()=>[e.modelValue?.request?.model?(n(),l("p",Ut,[o(r,{icon:"fa-solid fa-cube",class:"mr-1"}),u(" "+a(e.$t("nanobanana.name.model"))+": "+a(e.modelValue?.request?.model),1)])):g("",!0),e.modelValue?.request?.resolution?(n(),l("p",Ct,[o(r,{icon:"fa-solid fa-image",class:"mr-1"}),u(" "+a(e.$t("nanobanana.name.resolution"))+": "+a(e.modelValue?.request?.resolution),1)])):g("",!0),e.modelValue?.request?.aspect_ratio?(n(),l("p",Pt,[o(r,{icon:"fa-solid fa-up-right-from-square",class:"mr-1"}),u(" "+a(e.$t("nanobanana.name.aspectRatio"))+": "+a(e.modelValue?.request?.aspect_ratio),1)])):g("",!0),e.modelValue?.request?.action?(n(),l("p",Bt,[o(r,{icon:"fa-solid fa-bolt",class:"mr-1"}),u(" "+a(e.$t("nanobanana.name.task"))+": "+a(e.modelValue?.request?.action==="generate"?e.$t("nanobanana.name.generate"):e.$t("nanobanana.name.edits")),1)])):g("",!0),c("p",Mt,[o(r,{icon:"fa-solid fa-magic",class:"mr-1"}),u(" "+a(e.$t("nanobanana.name.taskId"))+": "+a(e.modelValue?.id)+" ",1),o(v,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])])]),_:1})]))])])}const jt=y(st,[["render",Gt],["__scopeId","data-v-8d5f4fff"]]),Dt=k({name:"RecentPanel",components:{TaskPreview:jt,BotPlaceholder:de,NoTasks:me,ScrollList:Y},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?.()}}}),Ft={key:0},xt={key:2,class:"w-full h-full flex items-center justify-center"};function zt(e,t,b,i,d,f){const h=s("bot-placeholder"),_=s("task-preview"),m=s("scroll-list"),p=s("no-tasks");return n(),l(A,null,[e.tasks?.items===void 0?(n(),l("div",Ft,[o(h)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(n(),V(m,{key:1,ref:"scrollList",class:"tasks h-full w-full overflow-y-auto",loading:e.loading,onReachTop:t[0]||(t[0]=w=>e.$emit("reach-top"))},{default:$(()=>[(n(!0),l(A,null,N(e.tasks?.items,w=>(n(),V(_,{key:w.id,"model-value":w},null,8,["model-value"]))),128))]),_:1},8,["loading"])):g("",!0),e.tasks?.items?.length===0?(n(),l("div",xt,[o(p)])):g("",!0)],64)}const Wt=y(Dt,[["render",zt]]),Ht="https://webhook.acedata.cloud/nanobanana",Kt=k({name:"NanobananaIndex",components:{ConfigPanel:nt,Layout:be,RecentPanel:Wt},inject:["initialized"],data(){return{task:void 0,job:0,loading:!1}},computed:{applicationsLoading(){return this.$store.state.nanobanana?.status?.getApplications===F.Request},tasksLoading(){return this.$store.state.nanobanana?.status?.getTasks===F.Request},credential(){return this.$store.state.nanobanana?.credential},config(){return this.$store.state.nanobanana?.config},application(){return this.$store.state.nanobanana?.application},tasks(){return this.$store.state.nanobanana?.tasks}},watch:{tasks:{handler(e,t){e?.items?.length>t?.items?.length&&console.debug("new tasks detected")},deep:!0},initialized:{async handler(e){e&&(console.debug("layout initialized"),await this.onGetTasks(),await this.onScrollDown(),this.job=window.setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){window.clearInterval(this.job)},methods:{async onReachTop(){if(console.debug("reached top"),this.loading||this.tasksLoading)return;const e=this.tasks?.total,t=this.tasks?.items?.length||0;if(e!==void 0&&e<=t)return;const b=this.tasks?.items?.[0];if(!b?.created_at)return;const d=this.$refs.recentPanel?.getScrollElement?.(),f=d?.scrollHeight||0,h=d?.scrollTop||0;this.loading=!0;try{if(await this.onGetTasks({createdAtMax:b.created_at}),await this.$nextTick(),d){const _=d.scrollHeight;d.scrollTop=_-f+h}}finally{this.loading=!1}},async onGetService(){console.debug("start onGetService"),await this.$store.dispatch("nanobanana/getService"),console.debug("end onGetService")},async onGetApplication(){console.debug("start onGetApplication"),await this.$store.dispatch("nanobanana/getApplications"),console.debug("end onGetApplication"),await this.onGetTasks()},async onScrollDown(){await this.$nextTick();const e=this.getTasksScrollElement();e&&(e.scrollTop=e.scrollHeight)},async onGetTasks(e){if(this.applicationsLoading||this.tasksLoading){console.debug("loading");return}console.debug("start onGetTasks",e);const{limit:t=20,createdAtMin:b,createdAtMax:i}=e||{};console.debug("limit",t,"createdAtMin",b,"createdAtMax",i),await this.$store.dispatch("nanobanana/getTasks",{limit:t,createdAtMin:b,createdAtMax:i})},async onGenerate(){const e={...this.config||{}},t=Array.isArray(e?.image_urls)&&e.image_urls.length>0;delete e.action,!t&&"image_urls"in e&&delete e.image_urls,e?.aspect_ratio||delete e.aspect_ratio,e?.model!==P&&"resolution"in e&&delete e.resolution,e?.model===P&&!e?.resolution&&(e.resolution=T);const b={...e,action:t?"edit":"generate",callback_url:Ht},i=this.credential?.token;if(!i){console.error("no token specified");return}R.info(this.$t("nanobanana.message.startingTask")),X("nanobanana",se.generate(b,{token:i})).then(()=>{R.success(this.$t("nanobanana.message.startTaskSuccess"))}).catch(d=>{const f=d?.response?.data;f?.error?.code===ne?R.error(this.$t("nanobanana.message.usedUp")):R.error(this.$t("nanobanana.message.startTaskFailed")+(f?.error?.message||""))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function Jt(e,t,b,i,d,f){const h=s("config-panel"),_=s("recent-panel"),m=s("layout");return n(),V(m,null,{config:$(()=>[o(h,{onGenerate:e.onGenerate},null,8,["onGenerate"])]),result:$(()=>[o(_,{ref:"recentPanel",loading:e.loading,onReachTop:e.onReachTop},null,8,["loading","onReachTop"])]),_:1})}const Go=y(Kt,[["render",Jt]]);export{Go as default};
1
+ import{F as S}from"./index.es-DgRqc681.js";import{E as q}from"./index-BfYt3lpS.js";import{E as W}from"./index-D7TXnRb-.js";import{d as k,H as l,E as c,z as C,C as o,y as $,D as s,q as n,F as a,I as u,O as A,N,x as V,J as g,M as H,Q as O}from"./vendor-vue-NSDaktjZ.js";import{E as y,b8 as K,cq as J,cr as x,cs as P,ct as Q,cu as T,cv as G,cw as j,cx as D,cd as X,aw as F}from"./index-BmskuvzR.js";import{I as U,S as Y}from"./ScrollList-DMu-o4cw.js";import{E as Z}from"./index-C4cFnn6h.js";import{p as ee}from"./pasteUploadMixin-BurWbGNQ.js";import{I as z}from"./ImagePreview-DGgsF-1W.js";import{E as te}from"./index-B5iae9JX.js";import{E as R}from"./index-Z6qAnijd.js";import{E as B,a as M}from"./index-BYgw8Ne9.js";import{C as oe}from"./Consumption-DhMtSnnQ.js";import{a as ae}from"./price-BGnrujo6.js";import{b as ne}from"./errorCode-Cqj9Td_Z.js";import{n as se}from"./nanobanana-C9Llm_-d.js";import{C as le}from"./CopyToClipboard-DrzpK9ow.js";import{I as re}from"./ImageWrapper-D3SmhRJ2.js";import{E as ie}from"./index-X4RPhZd6.js";import{E as ce}from"./index-JlXUmriI.js";import{E as ue}from"./index-BkJcEPcB.js";import{B as de}from"./BotPlaceholder-Bxg1WSeO.js";import{N as me}from"./NoTasks-M-MqsF2Q.js";import"./use-form-item-7D-CUO4M.js";import"./index-BuyEbX8F.js";import"./vendor-axios-B8_nURbH.js";import"./vendor-dayjs-Cvgzdobq.js";import"./vendor-vue-router-Kg6s1a65.js";import"./typescript-D5w3x56R.js";import"./index-CEOn0L_0.js";import"./index-BvsGeWBq.js";import"./index-BxG3gwu6.js";import"./_baseClone-vd8PLpyA.js";import"./_Uint8Array-C3Lbt_45.js";import"./_initCloneObject-D5Z-CcL7.js";import"./isEqual-BPX3ojYz.js";import"./index-ys73P36s.js";import"./strings-beZM2Y-f.js";import"./castArray-BgN0ywwP.js";import"./debounce-CfLqwhiY.js";import"./_baseIteratee-BEktInjh.js";import"./index-BkRv-z3G.js";import"./index-Cq1B7Sqv.js";const pe=k({name:"LayoutNanobanana",components:{ElDrawer:W,ElButton:q,FontAwesomeIcon:S},data(){return{drawer:!1}}}),fe={class:"main flex flex-row flex-1"},he={class:"config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]"},_e={class:"result h-full p-6 flex-1 flex flex-col min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]"};function ge(e,t,b,i,d,f){const h=s("font-awesome-icon"),_=s("el-button"),m=s("el-drawer");return n(),l("div",fe,[c("div",he,[C(e.$slots,"config",{},void 0,!0)]),c("div",_e,[C(e.$slots,"result",{},void 0,!0)]),o(_,{circle:"",class:"menu",onClick:t[0]||(t[0]=p=>e.drawer=!0)},{default:$(()=>[o(h,{icon:"fa-solid fa-magic"})]),_:1}),o(m,{modelValue:e.drawer,"onUpdate:modelValue":t[1]||(t[1]=p=>e.drawer=p),direction:"ltr","with-header":!1,size:"340px",class:"drawer"},{default:$(()=>[C(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const be=y(pe,[["render",ge],["__scopeId","data-v-9fbc8a5c"]]),$e="",ve=k({name:"PromptInput",components:{ElInput:Z,InfoIcon:U},computed:{prompt:{get(){return this.$store.state.nanobanana?.config?.prompt},set(e){console.debug("set prompt",e),this.$store.commit("nanobanana/setConfig",{...this.$store.state.nanobanana?.config,prompt:e})}}},mounted(){this.prompt||(this.prompt=$e)}}),ke={class:"field"},ye={class:"box"},we={class:"title font-bold"};function Ae(e,t,b,i,d,f){const h=s("info-icon"),_=s("el-input");return n(),l("div",ke,[c("div",ye,[c("h2",we,a(e.$t("nanobanana.name.prompt")),1),o(h,{content:e.$t("nanobanana.description.prompt"),class:"info"},null,8,["content"])]),o(_,{modelValue:e.prompt,"onUpdate:modelValue":t[0]||(t[0]=m=>e.prompt=m),rows:3,type:"textarea",class:"prompt",placeholder:e.$t("nanobanana.placeholder.prompt")},null,8,["modelValue","placeholder"])])}const Ve=y(ve,[["render",Ae],["__scopeId","data-v-2331e197"]]),Ne=k({name:"ImageUrlsInput",components:{ElUpload:te,ElButton:q,InfoIcon:U,ImagePreview:z,FontAwesomeIcon:S},mixins:[ee],data(){return{fileList:[],uploadUrl:K()+"/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 i=(this.fileList||[]).filter(d=>!d?.response?.file_url);this.fileList=i.length?i:[];return}const t=[];e.forEach(i=>{const d=this.fileList.find(f=>f?.response?.file_url===i||f?.url===i);d?t.push(d):t.push({name:i.split("/").pop()||i,url:i,status:"success",percentage:100,response:{file_url:i}})}),(this.fileList||[]).filter(i=>!i?.response?.file_url).forEach(i=>{t.some(f=>f===i||f?.url===i?.url||f?.response?.file_url===i?.response?.file_url)||t.push(i)}),this.fileList=t}}},mounted(){},methods:{onChange(e){if(!e?.url&&e?.raw)try{e.url=URL.createObjectURL(e.raw)}catch{}},onRemove(e){if(e?.url&&typeof e.url=="string"&&e.url.startsWith("blob:"))try{URL.revokeObjectURL(e.url)}catch{}this.onSetImageUrls()},onExceed(){R.warning(this.$t("nanobanana.message.uploadImageExceed"))},onError(){R.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()}}}),Ee={class:"field flex items-center justify-between"},Re={class:"title font-bold text-[14px] mb-[10px]"},Ie={class:"upload-wrapper flex flex-col items-start gap-[8px]"},Le={class:"controls flex items-center"},Te={class:"file-list flex flex-wrap gap-[10px]"};function Se(e,t,b,i,d,f){const h=s("font-awesome-icon"),_=s("el-button"),m=s("el-upload"),p=s("info-icon"),w=s("image-preview");return n(),l(A,null,[c("div",Ee,[c("h2",Re,a(e.$t("nanobanana.name.imageUrls")),1),c("div",Ie,[c("div",Le,[o(m,{ref:"uploader","file-list":e.fileList,"onUpdate:fileList":t[0]||(t[0]=r=>e.fileList=r),accept:".png,.jpg,.jpeg,.gif,.bmp,.webp",name:"file",class:"value",limit:5,multiple:!0,"show-file-list":!1,action:e.uploadUrl,"on-exceed":e.onExceed,"on-error":e.onError,"on-success":e.onSuccess,"on-change":e.onChange,"on-remove":e.onRemove,headers:e.headers},{default:$(()=>[o(_,{size:"small",type:"primary",round:""},{default:$(()=>[o(h,{icon:"fa-solid fa-upload",class:"mr-1"}),u(" "+a(e.$t("nanobanana.button.uploadImageUrls")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-success","on-change","on-remove","headers"]),o(p,{content:e.$t("nanobanana.description.imageUrls"),class:"ml-2"},null,8,["content"])])])]),c("div",Te,[(n(!0),l(A,null,N(e.fileList,(r,v)=>(n(),V(w,{key:r.uid||r?.response?.file_url||r.url||v,url:r.url||r?.response?.file_url,name:r.name,percentage:r.percentage,onRemove:E=>e.onRemovePreview(v,r)},null,8,["url","name","percentage","onRemove"]))),128))])],64)}const qe=y(Ne,[["render",Se]]),Oe=k({name:"AspectRatioSelector",components:{ElSelect:M,ElOption:B},data(){return{options:["1:1","3:2","2:3","16:9","9:16","4:3","3:4"]}},computed:{value:{get(){return this.$store.state.nanobanana?.config?.aspect_ratio},set(e){console.debug("set aspect_ratio",e);const t={...this.$store.state.nanobanana?.config||{}};e?t.aspect_ratio=e:delete t.aspect_ratio,this.$store.commit("nanobanana/setConfig",t)}}}}),Ue={class:"field"},Ce={class:"title font-bold"};function Pe(e,t,b,i,d,f){const h=s("el-option"),_=s("el-select");return n(),l("div",Ue,[c("h2",Ce,a(e.$t("nanobanana.name.aspectRatio")),1),o(_,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=m=>e.value=m),class:"value",clearable:"",placeholder:e.$t("nanobanana.placeholder.select")},{default:$(()=>[(n(!0),l(A,null,N(e.options,m=>(n(),V(h,{key:m,label:m,value:m},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Be=y(Oe,[["render",Pe],["__scopeId","data-v-67f08a08"]]),Me=k({name:"NanobananaModelSelector",components:{ElSelect:M,ElOption:B,InfoIcon:U},data(){return{options:[{value:x,label:this.$t("nanobanana.model.nanoBanana")},{value:P,label:this.$t("nanobanana.model.nanoBananaPro")},{value:Q,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=J)}}),Ge={class:"field"},je={class:"label"},De={class:"box"},Fe={class:"title font-bold"};function xe(e,t,b,i,d,f){const h=s("info-icon"),_=s("el-option"),m=s("el-select");return n(),l("div",Ge,[c("div",je,[c("div",De,[c("h2",Fe,a(e.$t("nanobanana.name.model")),1),o(h,{content:e.modelDescription,class:"info"},null,8,["content"])])]),o(m,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=p=>e.value=p),class:"value",placeholder:e.$t("nanobanana.placeholder.select")},{default:$(()=>[(n(!0),l(A,null,N(e.options,p=>(n(),V(_,{key:p.value,label:p.label,value:p.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const ze=y(Me,[["render",xe],["__scopeId","data-v-94304d73"]]),We=k({name:"NanobananaResolutionSelector",components:{ElSelect:M,ElOption:B,InfoIcon:U},data(){return{cachedResolution:T,options:[{value:G,label:G},{value:j,label:j},{value:D,label:D}]}},computed:{value:{get(){return this.$store.state.nanobanana?.config?.resolution},set(e){this.$store.commit("nanobanana/setConfig",{...this.$store.state.nanobanana?.config,resolution:e})}},isProModel(){return this.$store.state.nanobanana?.config?.model!==x}},watch:{value(e){this.isProModel&&e&&(this.cachedResolution=e)},isProModel(e){e?this.value||(this.value=this.cachedResolution||T):(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=T),!this.isProModel&&this.value&&(this.cachedResolution=this.value,this.$store.commit("nanobanana/setConfig",{...this.$store.state.nanobanana?.config,resolution:void 0}))}}),He={class:"field"},Ke={class:"label"},Je={class:"box"},Qe={class:"title font-bold"};function Xe(e,t,b,i,d,f){const h=s("info-icon"),_=s("el-option"),m=s("el-select");return n(),l("div",He,[c("div",Ke,[c("div",Je,[c("h2",Qe,a(e.$t("nanobanana.name.resolution")),1),o(h,{content:e.$t("nanobanana.description.resolutionProOnly"),class:"info"},null,8,["content"])])]),o(m,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=p=>e.value=p),class:"value",placeholder:e.$t("nanobanana.placeholder.select"),disabled:!e.isProModel},{default:$(()=>[(n(!0),l(A,null,N(e.options,p=>(n(),V(_,{key:p.value,label:p.label,value:p.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder","disabled"])])}const Ye=y(We,[["render",Xe],["__scopeId","data-v-fd5ab393"]]),Ze=k({name:"ConfigPanel",components:{ElButton:q,FontAwesomeIcon:S,PromptInput:Ve,Consumption:oe,ImageUrlsInput:qe,AspectRatioSelector:Be,ModelSelector:ze,ResolutionSelector:Ye},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 ae({...e,action:t?"edit":"generate"},this.service?.cost)},service(){return this.$store.state.nanobanana?.service}},methods:{onGenerate(){this.$emit("generate")}}}),et={class:"flex flex-col h-full"},tt={class:"flex-1 overflow-y-auto p-5"},ot={class:"flex flex-col items-center justify-center px-5 pb-5"};function at(e,t,b,i,d,f){const h=s("model-selector"),_=s("resolution-selector"),m=s("prompt-input"),p=s("aspect-ratio-selector"),w=s("image-urls-input"),r=s("consumption"),v=s("font-awesome-icon"),E=s("el-button");return n(),l("div",et,[c("div",tt,[o(h,{class:"mb-4"}),o(_,{class:"mb-4"}),o(m,{class:"mb-4"}),o(p,{class:"mb-4"}),o(w,{class:"mb-4"})]),c("div",ot,[o(r,{value:e.consumption,service:e.service},null,8,["value","service"]),o(E,{type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:$(()=>[o(v,{icon:"fa-solid fa-magic",class:"mr-2"}),u(" "+a(e.$t("nanobanana.button.generate")),1)]),_:1},8,["onClick"])])])}const nt=y(Ze,[["render",at]]),st=k({name:"TaskPreview",components:{ElImage:ue,CopyToClipboard:le,FontAwesomeIcon:S,ElAlert:ce,ImageWrapper:re,ElButton:q,ElTooltip:ie,ImagePreview:z},props:{modelValue:{type:Object,required:!0}},computed:{images(){const e=[];return Array.isArray(this.modelValue?.response?.data)&&this.modelValue?.response?.data?.forEach(t=>{e.push(t)}),e}},methods:{onEdit(e){if(!e)return;console.debug("Edit image:",e);const t={...this.$store.state.nanobanana?.config||{}};delete t.action,t.image_urls=[e],this.$store.commit("nanobanana/setConfig",t)}}}),lt={class:"preview"},rt={class:"left"},it={class:"main"},ct={class:"bot"},ut={class:"datetime"},dt={class:"info"},mt={key:0,class:"flex justify-start items-center gap-2 mt-2 w-full overflow-x-auto"},pt={key:1,class:"prompt mt-2"},ft={key:0},ht={key:0,class:O({content:!0,failed:!0})},_t={class:"flex justify-start items-center gap-4 w-full overflow-x-auto"},gt={class:O({operations:!0,"mt-2":!0,"mb-2":!0})},bt={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},$t={key:1,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},vt={key:2,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},kt={key:3,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},yt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},wt={key:4,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},At={key:5,class:"text-[var(--el-text-color-regular)] text-xs mb-0"},Vt={key:1,class:O({content:!0})},Nt={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Et={key:1,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Rt={key:2,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},It={key:3,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Lt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Tt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},St={key:4,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},qt={key:5,class:"text-[var(--el-text-color-regular)] text-xs mb-0"},Ot={key:2,class:O({content:!0})},Ut={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Ct={key:1,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Pt={key:2,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Bt={key:3,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Mt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"};function Gt(e,t,b,i,d,f){const h=s("el-image"),_=s("image-preview"),m=s("image-wrapper"),p=s("el-button"),w=s("el-tooltip"),r=s("font-awesome-icon"),v=s("copy-to-clipboard"),E=s("el-alert");return n(),l("div",lt,[c("div",rt,[o(h,{src:"https://cdn.acedata.cloud/859plc.jpg",class:"avatar"})]),c("div",it,[c("div",ct,[u(a(e.$t("nanobanana.name.nanobananaBot"))+" ",1),c("span",ut,a(e.$dayjs.format(""+new Date(parseFloat((e.modelValue?.created_at||"").toString())*1e3))),1)]),c("div",dt,[e.modelValue?.request?.image_urls&&e.modelValue?.request?.image_urls.length>0?(n(),l("div",mt,[(n(!0),l(A,null,N(e.modelValue?.request?.image_urls,(I,L)=>(n(),V(_,{key:L,url:I,name:`image-${L+1}`,closable:!1},null,8,["url","name"]))),128))])):g("",!0),e.modelValue?.request?.prompt?(n(),l("p",pt,[u(a(e.modelValue?.request?.prompt)+" ",1),e.modelValue?.response?g("",!0):(n(),l("span",ft," - ("+a(e.$t("nanobanana.status.pending"))+") ",1))])):g("",!0)]),e.modelValue?.response?.success===!0?(n(),l("div",ht,[c("div",_t,[(n(!0),l(A,null,N(e.images,(I,L)=>(n(),V(m,{key:L,src:I?.image_url,"raw-src":I?.image_url},null,8,["src","raw-src"]))),128))]),c("div",gt,[o(w,{class:"box-item",effect:"dark",content:e.$t("common.button.edit"),placement:"top-start"},{default:$(()=>[o(p,{type:"info",size:"small",class:"btn-action",onClick:t[0]||(t[0]=H(I=>e.onEdit(e.images?.[0]?.image_url),["stop"]))},{default:$(()=>[u(a(e.$t("common.button.edit")),1)]),_:1})]),_:1},8,["content"])]),o(E,{closable:!1,class:"mt-2 success"},{default:$(()=>[e.modelValue?.request?.model?(n(),l("p",bt,[o(r,{icon:"fa-solid fa-cube",class:"mr-1"}),u(" "+a(e.$t("nanobanana.name.model"))+": "+a(e.modelValue?.request?.model),1)])):g("",!0),e.modelValue?.request?.resolution?(n(),l("p",$t,[o(r,{icon:"fa-solid fa-image",class:"mr-1"}),u(" "+a(e.$t("nanobanana.name.resolution"))+": "+a(e.modelValue?.request?.resolution),1)])):g("",!0),e.modelValue?.request?.aspect_ratio?(n(),l("p",vt,[o(r,{icon:"fa-solid fa-up-right-from-square",class:"mr-1"}),u(" "+a(e.$t("nanobanana.name.aspectRatio"))+": "+a(e.modelValue?.request?.aspect_ratio),1)])):g("",!0),e.modelValue?.request?.action?(n(),l("p",kt,[o(r,{icon:"fa-solid fa-bolt",class:"mr-1"}),u(" "+a(e.$t("nanobanana.name.task"))+": "+a(e.modelValue?.request?.action==="generate"?e.$t("nanobanana.name.generate"):e.$t("nanobanana.name.edits")),1)])):g("",!0),c("p",yt,[o(r,{icon:"fa-solid fa-magic",class:"mr-1"}),u(" "+a(e.$t("nanobanana.name.taskId"))+": "+a(e.modelValue?.id)+" ",1),o(v,{content:e.modelValue?.id,class:"btn-copy inline-block"},null,8,["content"])]),e.modelValue?.elapsed?(n(),l("p",wt,[o(r,{icon:"fa-solid fa-clock",class:"mr-1"}),u(" "+a(e.$t("nanobanana.name.elapsed"))+": "+a(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):g("",!0),e.modelValue?.response?.trace_id?(n(),l("p",At,[o(r,{icon:"fa-solid fa-hashtag",class:"mr-1"}),u(" "+a(e.$t("nanobanana.name.traceId"))+": "+a(e.modelValue?.response?.trace_id)+" ",1),o(v,{content:e.modelValue?.response?.trace_id,class:"btn-copy inline-block"},null,8,["content"])])):g("",!0)]),_:1})])):e.modelValue?.response?.success===!1?(n(),l("div",Vt,[o(E,{closable:!1,class:"failure"},{template:$(()=>[o(r,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),u(" "+a(e.$t("nanobanana.name.failure")),1)]),default:$(()=>[e.modelValue?.request?.model?(n(),l("p",Nt,[o(r,{icon:"fa-solid fa-cube",class:"mr-1"}),u(" "+a(e.$t("nanobanana.name.model"))+": "+a(e.modelValue?.request?.model),1)])):g("",!0),e.modelValue?.request?.resolution?(n(),l("p",Et,[o(r,{icon:"fa-solid fa-image",class:"mr-1"}),u(" "+a(e.$t("nanobanana.name.resolution"))+": "+a(e.modelValue?.request?.resolution),1)])):g("",!0),e.modelValue?.request?.aspect_ratio?(n(),l("p",Rt,[o(r,{icon:"fa-solid fa-up-right-from-square",class:"mr-1"}),u(" "+a(e.$t("nanobanana.name.aspectRatio"))+": "+a(e.modelValue?.request?.aspect_ratio),1)])):g("",!0),e.modelValue?.request?.action?(n(),l("p",It,[o(r,{icon:"fa-solid fa-bolt",class:"mr-1"}),u(" "+a(e.$t("nanobanana.name.task"))+": "+a(e.modelValue?.request?.action==="generate"?e.$t("nanobanana.name.generate"):e.$t("nanobanana.name.edits")),1)])):g("",!0),c("p",Lt,[o(r,{icon:"fa-solid fa-magic",class:"mr-1"}),u(" "+a(e.$t("nanobanana.name.taskId"))+": "+a(e.modelValue?.id)+" ",1),o(v,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])]),c("p",Tt,[o(r,{icon:"fa-solid fa-circle-info",class:"mr-1"}),u(" "+a(e.$t("nanobanana.name.failureReason"))+": "+a(e.modelValue?.response?.error?.message)+" ",1),o(v,{content:e.modelValue?.response?.error?.message,class:"btn-copy"},null,8,["content"])]),e.modelValue?.elapsed?(n(),l("p",St,[o(r,{icon:"fa-solid fa-clock",class:"mr-1"}),u(" "+a(e.$t("nanobanana.name.elapsed"))+": "+a(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):g("",!0),e.modelValue?.response?.trace_id?(n(),l("p",qt,[o(r,{icon:"fa-solid fa-hashtag",class:"mr-1"}),u(" "+a(e.$t("nanobanana.name.traceId"))+": "+a(e.modelValue?.response?.trace_id)+" ",1),o(v,{content:e.modelValue?.response?.trace_id,class:"btn-copy"},null,8,["content"])])):g("",!0)]),_:1})])):(n(),l("div",Ot,[o(E,{closable:!1,class:"info"},{template:$(()=>[o(r,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),u(" "+a(e.$t("nanobanana.name.failure")),1)]),default:$(()=>[e.modelValue?.request?.model?(n(),l("p",Ut,[o(r,{icon:"fa-solid fa-cube",class:"mr-1"}),u(" "+a(e.$t("nanobanana.name.model"))+": "+a(e.modelValue?.request?.model),1)])):g("",!0),e.modelValue?.request?.resolution?(n(),l("p",Ct,[o(r,{icon:"fa-solid fa-image",class:"mr-1"}),u(" "+a(e.$t("nanobanana.name.resolution"))+": "+a(e.modelValue?.request?.resolution),1)])):g("",!0),e.modelValue?.request?.aspect_ratio?(n(),l("p",Pt,[o(r,{icon:"fa-solid fa-up-right-from-square",class:"mr-1"}),u(" "+a(e.$t("nanobanana.name.aspectRatio"))+": "+a(e.modelValue?.request?.aspect_ratio),1)])):g("",!0),e.modelValue?.request?.action?(n(),l("p",Bt,[o(r,{icon:"fa-solid fa-bolt",class:"mr-1"}),u(" "+a(e.$t("nanobanana.name.task"))+": "+a(e.modelValue?.request?.action==="generate"?e.$t("nanobanana.name.generate"):e.$t("nanobanana.name.edits")),1)])):g("",!0),c("p",Mt,[o(r,{icon:"fa-solid fa-magic",class:"mr-1"}),u(" "+a(e.$t("nanobanana.name.taskId"))+": "+a(e.modelValue?.id)+" ",1),o(v,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])])]),_:1})]))])])}const jt=y(st,[["render",Gt],["__scopeId","data-v-8d5f4fff"]]),Dt=k({name:"RecentPanel",components:{TaskPreview:jt,BotPlaceholder:de,NoTasks:me,ScrollList:Y},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?.()}}}),Ft={key:0},xt={key:2,class:"w-full h-full flex items-center justify-center"};function zt(e,t,b,i,d,f){const h=s("bot-placeholder"),_=s("task-preview"),m=s("scroll-list"),p=s("no-tasks");return n(),l(A,null,[e.tasks?.items===void 0?(n(),l("div",Ft,[o(h)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(n(),V(m,{key:1,ref:"scrollList",class:"tasks h-full w-full overflow-y-auto",loading:e.loading,onReachTop:t[0]||(t[0]=w=>e.$emit("reach-top"))},{default:$(()=>[(n(!0),l(A,null,N(e.tasks?.items,w=>(n(),V(_,{key:w.id,"model-value":w},null,8,["model-value"]))),128))]),_:1},8,["loading"])):g("",!0),e.tasks?.items?.length===0?(n(),l("div",xt,[o(p)])):g("",!0)],64)}const Wt=y(Dt,[["render",zt]]),Ht="https://webhook.acedata.cloud/nanobanana",Kt=k({name:"NanobananaIndex",components:{ConfigPanel:nt,Layout:be,RecentPanel:Wt},inject:["initialized"],data(){return{task:void 0,job:0,loading:!1}},computed:{applicationsLoading(){return this.$store.state.nanobanana?.status?.getApplications===F.Request},tasksLoading(){return this.$store.state.nanobanana?.status?.getTasks===F.Request},credential(){return this.$store.state.nanobanana?.credential},config(){return this.$store.state.nanobanana?.config},application(){return this.$store.state.nanobanana?.application},tasks(){return this.$store.state.nanobanana?.tasks}},watch:{tasks:{handler(e,t){e?.items?.length>t?.items?.length&&console.debug("new tasks detected")},deep:!0},initialized:{async handler(e){e&&(console.debug("layout initialized"),await this.onGetTasks(),await this.onScrollDown(),this.job=window.setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){window.clearInterval(this.job)},methods:{async onReachTop(){if(console.debug("reached top"),this.loading||this.tasksLoading)return;const e=this.tasks?.total,t=this.tasks?.items?.length||0;if(e!==void 0&&e<=t)return;const b=this.tasks?.items?.[0];if(!b?.created_at)return;const d=this.$refs.recentPanel?.getScrollElement?.(),f=d?.scrollHeight||0,h=d?.scrollTop||0;this.loading=!0;try{if(await this.onGetTasks({createdAtMax:b.created_at}),await this.$nextTick(),d){const _=d.scrollHeight;d.scrollTop=_-f+h}}finally{this.loading=!1}},async onGetService(){console.debug("start onGetService"),await this.$store.dispatch("nanobanana/getService"),console.debug("end onGetService")},async onGetApplication(){console.debug("start onGetApplication"),await this.$store.dispatch("nanobanana/getApplications"),console.debug("end onGetApplication"),await this.onGetTasks()},async onScrollDown(){await this.$nextTick();const e=this.getTasksScrollElement();e&&(e.scrollTop=e.scrollHeight)},async onGetTasks(e){if(this.applicationsLoading||this.tasksLoading){console.debug("loading");return}console.debug("start onGetTasks",e);const{limit:t=20,createdAtMin:b,createdAtMax:i}=e||{};console.debug("limit",t,"createdAtMin",b,"createdAtMax",i),await this.$store.dispatch("nanobanana/getTasks",{limit:t,createdAtMin:b,createdAtMax:i})},async onGenerate(){const e={...this.config||{}},t=Array.isArray(e?.image_urls)&&e.image_urls.length>0;delete e.action,!t&&"image_urls"in e&&delete e.image_urls,e?.aspect_ratio||delete e.aspect_ratio,e?.model!==P&&"resolution"in e&&delete e.resolution,e?.model===P&&!e?.resolution&&(e.resolution=T);const b={...e,action:t?"edit":"generate",callback_url:Ht},i=this.credential?.token;if(!i){console.error("no token specified");return}R.info(this.$t("nanobanana.message.startingTask")),X("nanobanana",se.generate(b,{token:i})).then(()=>{R.success(this.$t("nanobanana.message.startTaskSuccess"))}).catch(d=>{const f=d?.response?.data;f?.error?.code===ne?R.error(this.$t("nanobanana.message.usedUp")):R.error(this.$t("nanobanana.message.startTaskFailed")+(f?.error?.message||""))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function Jt(e,t,b,i,d,f){const h=s("config-panel"),_=s("recent-panel"),m=s("layout");return n(),V(m,null,{config:$(()=>[o(h,{onGenerate:e.onGenerate},null,8,["onGenerate"])]),result:$(()=>[o(_,{ref:"recentPanel",loading:e.loading,onReachTop:e.onReachTop},null,8,["loading","onReachTop"])]),_:1})}const Go=y(Kt,[["render",Jt]]);export{Go as default};
@@ -1 +1 @@
1
- import{F as x}from"./index.es-CqUFafZ-.js";import{E as A}from"./index-C3HcWVsL.js";import{E as O}from"./index-B3UfVG_d.js";import{d as h,H as o,E as r,z as C,C as d,y as k,D as i,q as t,F as a,I,J as c,O as b,N as y,x as v,P as z}from"./vendor-vue-NSDaktjZ.js";import{E as m,aw as V}from"./index-BAlXF3lp.js";import{E as U}from"./index-DhStH-hF.js";import{E as N,a as P}from"./index-CcnMKyw7.js";import{C as L}from"./Consumption-DEJXi9Yk.js";import{a as G}from"./price-Bs-d-Bvz.js";import{E as B,a as D}from"./index-9SbBDGPs.js";import{b as T}from"./errorCode-Cqj9Td_Z.js";import{E as w}from"./index-czzMfzSq.js";import"./use-form-item-DooKcsta.js";import"./index-BuyEbX8F.js";import"./vendor-axios-B8_nURbH.js";import"./vendor-dayjs-Cvgzdobq.js";import"./vendor-vue-router-Kg6s1a65.js";import"./typescript-DGijeo9F.js";import"./index-C9pbuvyJ.js";import"./index-DWiPtPwc.js";import"./index-5GxMphke.js";import"./index-Bd83o_xd.js";import"./strings-beZM2Y-f.js";import"./isEqual-CIKj9pK6.js";import"./_Uint8Array-ByIiAerw.js";import"./castArray-Dy2e0JbB.js";import"./debounce-Cu_Jtjpm.js";import"./_baseIteratee-DWXq1g8X.js";import"./index-bQIOVtse.js";import"./index-BlT4xa9T.js";const K=h({name:"LayoutSerp",components:{ElDrawer:O,ElButton:A,FontAwesomeIcon:x},data(){return{drawer:!1}}}),Q={class:"main flex flex-row flex-1"},H={class:"config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]"},J={class:"result h-full flex-1 flex flex-col min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]"};function M(e,n,p,_,f,g){const s=i("font-awesome-icon"),l=i("el-button"),u=i("el-drawer");return t(),o("div",Q,[r("div",H,[C(e.$slots,"config",{},void 0,!0)]),r("div",J,[C(e.$slots,"result",{},void 0,!0)]),d(l,{circle:"",class:"menu",onClick:n[0]||(n[0]=$=>e.drawer=!0)},{default:k(()=>[d(s,{icon:"fa-solid fa-search"})]),_:1}),d(u,{modelValue:e.drawer,"onUpdate:modelValue":n[1]||(n[1]=$=>e.drawer=$),direction:"ltr","with-header":!1,size:"340px",class:"drawer"},{default:k(()=>[C(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const W=m(K,[["render",M],["__scopeId","data-v-99dba970"]]),X=h({name:"QueryInput",components:{ElInput:U},computed:{query:{get(){return this.$store.state.serp?.config?.query},set(e){this.$store.commit("serp/setConfig",{...this.$store.state.serp?.config,query:e})}}}}),Y={class:"field"},Z={class:"box"},ee={class:"title font-bold"};function te(e,n,p,_,f,g){const s=i("el-input");return t(),o("div",Y,[r("div",Z,[r("h2",ee,a(e.$t("serp.name.query")),1)]),d(s,{modelValue:e.query,"onUpdate:modelValue":n[0]||(n[0]=l=>e.query=l),rows:3,type:"textarea",class:"prompt",placeholder:e.$t("serp.placeholder.query")},null,8,["modelValue","placeholder"])])}const se=m(X,[["render",te],["__scopeId","data-v-3582b195"]]),oe=h({name:"TypeSelector",components:{ElSelect:P,ElOption:N},computed:{value:{get(){return this.$store.state.serp?.config?.type},set(e){this.$store.commit("serp/setConfig",{...this.$store.state.serp?.config,type:e})}}},mounted(){this.value||(this.value="search")}}),re={class:"field"},ae={class:"title font-bold"};function ne(e,n,p,_,f,g){const s=i("el-option"),l=i("el-select");return t(),o("div",re,[r("h2",ae,a(e.$t("serp.name.type")),1),d(l,{modelValue:e.value,"onUpdate:modelValue":n[0]||(n[0]=u=>e.value=u),class:"value"},{default:k(()=>[d(s,{value:"search",label:e.$t("serp.type.search")},null,8,["label"]),d(s,{value:"images",label:e.$t("serp.type.images")},null,8,["label"]),d(s,{value:"news",label:e.$t("serp.type.news")},null,8,["label"]),d(s,{value:"videos",label:e.$t("serp.type.videos")},null,8,["label"])]),_:1},8,["modelValue"])])}const le=m(oe,[["render",ne],["__scopeId","data-v-2913fb62"]]),ie=h({name:"CountryInput",components:{ElInput:U},computed:{value:{get(){return this.$store.state.serp?.config?.country},set(e){this.$store.commit("serp/setConfig",{...this.$store.state.serp?.config,country:e})}}},mounted(){this.value||(this.value="US")}}),ce={class:"field"},de={class:"title font-bold"};function ue(e,n,p,_,f,g){const s=i("el-input");return t(),o("div",ce,[r("h2",de,a(e.$t("serp.name.country")),1),d(s,{modelValue:e.value,"onUpdate:modelValue":n[0]||(n[0]=l=>e.value=l),class:"value",placeholder:e.$t("serp.placeholder.country")},null,8,["modelValue","placeholder"])])}const pe=m(ie,[["render",ue],["__scopeId","data-v-f0672cc6"]]),he=h({name:"LanguageInput",components:{ElInput:U},computed:{value:{get(){return this.$store.state.serp?.config?.language},set(e){this.$store.commit("serp/setConfig",{...this.$store.state.serp?.config,language:e})}}},mounted(){this.value||(this.value="en")}}),me={class:"field"},_e={class:"title font-bold"};function fe(e,n,p,_,f,g){const s=i("el-input");return t(),o("div",me,[r("h2",_e,a(e.$t("serp.name.language")),1),d(s,{modelValue:e.value,"onUpdate:modelValue":n[0]||(n[0]=l=>e.value=l),class:"value",placeholder:e.$t("serp.placeholder.language")},null,8,["modelValue","placeholder"])])}const ge=m(he,[["render",fe],["__scopeId","data-v-dc1c94b7"]]),$e=h({name:"SearchPanel",components:{ElButton:A,FontAwesomeIcon:x,QueryInput:se,TypeSelector:le,CountryInput:pe,LanguageInput:ge,Consumption:L},emits:["search"],computed:{config(){return this.$store.state.serp?.config},consumption(){return G(this.config,this.service?.cost)},service(){return this.$store.state.serp?.service},searching(){return this.$store.state.serp?.status?.search===V.Request}},methods:{onSearch(){this.$emit("search")}}}),ve={class:"flex flex-col h-full"},be={class:"flex-1 overflow-y-auto p-5"},ye={class:"flex flex-col items-center justify-center px-5 pb-5"};function ke(e,n,p,_,f,g){const s=i("query-input"),l=i("type-selector"),u=i("country-input"),$=i("language-input"),S=i("consumption"),R=i("font-awesome-icon"),q=i("el-button");return t(),o("div",ve,[r("div",be,[d(s,{class:"mb-4"}),d(l,{class:"mb-4"}),d(u,{class:"mb-4"}),d($,{class:"mb-4"})]),r("div",ye,[d(S,{value:e.consumption,service:e.service},null,8,["value","service"]),d(q,{type:"primary",class:"btn w-full",round:"",loading:e.searching,onClick:e.onSearch},{default:k(()=>[d(R,{icon:"fa-solid fa-search",class:"mr-2"}),I(" "+a(e.$t("serp.button.search")),1)]),_:1},8,["loading","onClick"])])])}const we=m($e,[["render",ke]]),xe=h({name:"KnowledgeGraph",props:{data:{type:Object,required:!0}}}),Se={class:"knowledge-graph rounded-xl border border-[var(--el-border-color-lighter)] p-5 bg-[var(--el-fill-color-blank)]"},Re={class:"flex flex-row gap-4"},qe=["src","alt"],Ee={class:"flex-1 min-w-0"},Ce={key:0,class:"text-xs text-[var(--el-text-color-disabled)] mb-1 uppercase tracking-wide"},Ve={class:"text-xl font-bold mb-1.5"},Ie={key:1,class:"text-sm text-[var(--el-text-color-regular)] mb-3 leading-relaxed"},Ue=["href"],Ae={key:2,class:"text-sm"},je={class:"text-[var(--el-text-color-disabled)] flex-none font-medium"},Fe={class:"text-[var(--el-text-color-regular)]"};function Oe(e,n,p,_,f,g){return t(),o("div",Se,[r("div",Re,[e.data.image_url?(t(),o("img",{key:0,src:e.data.image_url,alt:e.data.title,class:"w-28 h-28 rounded-lg object-cover flex-none shadow-sm"},null,8,qe)):c("",!0),r("div",Ee,[e.data.type?(t(),o("div",Ce,a(e.data.type),1)):c("",!0),r("h3",Ve,a(e.data.title),1),e.data.description?(t(),o("p",Ie,[I(a(e.data.description)+" ",1),e.data.description_link?(t(),o("a",{key:0,href:e.data.description_link,target:"_blank",rel:"noopener noreferrer",class:"text-[var(--el-color-primary)] hover:underline ml-1"},a(e.data.description_source||"Source"),9,Ue)):c("",!0)])):c("",!0),e.data.attributes&&Object.keys(e.data.attributes).length?(t(),o("div",Ae,[(t(!0),o(b,null,y(e.data.attributes,(s,l)=>(t(),o("div",{key:l,class:"flex gap-2 mb-1 py-0.5"},[r("span",je,a(l)+":",1),r("span",Fe,a(s),1)]))),128))])):c("",!0)])])])}const ze=m(xe,[["render",Oe]]),Ne=h({name:"OrganicResult",props:{data:{type:Object,required:!0}},data(){return{faviconFailed:!1}},computed:{hostname(){if(!this.data.link)return"";try{return new URL(this.data.link).hostname}catch{return""}},pathname(){if(!this.data.link)return"";try{const e=new URL(this.data.link).pathname;return e==="/"?"":e}catch{return""}},displayUrl(){return this.hostname},faviconUrl(){return this.faviconFailed||!this.hostname?"":`https://www.google.com/s2/favicons?domain=${this.hostname}&sz=32`}},methods:{onFaviconError(e){this.faviconFailed=!0,e.target.style.display="none"}}}),Pe={class:"organic-result rounded-lg p-4 transition-all duration-200 hover:bg-[var(--el-fill-color-lighter)]"},Le={key:0,class:"flex items-center gap-2 mb-1.5"},Ge=["src","alt"],Be={class:"text-xs text-[var(--el-text-color-secondary)] truncate"},De={class:"text-xs text-[var(--el-text-color-disabled)]"},Te=["href"],Ke={key:1,class:"text-xs text-[var(--el-text-color-disabled)] mt-1"},Qe={key:2,class:"text-sm text-[var(--el-text-color-regular)] mt-1.5 leading-relaxed line-clamp-3"},He={key:3,class:"mt-3 flex flex-wrap gap-x-4 gap-y-1"},Je=["href"];function Me(e,n,p,_,f,g){return t(),o("div",Pe,[e.displayUrl?(t(),o("div",Le,[r("img",{src:e.faviconUrl,alt:e.hostname,class:"w-4 h-4 rounded-sm flex-none",loading:"lazy",onError:n[0]||(n[0]=(...s)=>e.onFaviconError&&e.onFaviconError(...s))},null,40,Ge),r("span",Be,a(e.hostname),1),r("span",De,a(e.pathname),1)])):c("",!0),r("a",{href:e.data.link,target:"_blank",rel:"noopener noreferrer",class:"text-base font-semibold text-[var(--el-color-primary)] hover:underline leading-snug block"},a(e.data.title),9,Te),e.data.date?(t(),o("div",Ke,a(e.data.date),1)):c("",!0),e.data.snippet?(t(),o("p",Qe,a(e.data.snippet),1)):c("",!0),e.data.sitelinks?.length?(t(),o("div",He,[(t(!0),o(b,null,y(e.data.sitelinks,(s,l)=>(t(),o("a",{key:l,href:s.link,target:"_blank",rel:"noopener noreferrer",class:"text-xs text-[var(--el-color-primary-light-3)] hover:text-[var(--el-color-primary)] hover:underline transition-colors"},a(s.title),9,Je))),128))])):c("",!0)])}const We=m(Ne,[["render",Me]]),Xe=h({name:"ImageResults",props:{data:{type:Array,required:!0}}}),Ye={class:"rounded-xl border border-[var(--el-border-color-lighter)] p-5 bg-[var(--el-fill-color-blank)]"},Ze={class:"text-base font-bold mb-3"},et={class:"grid grid-cols-2 sm:grid-cols-3 md:grid-cols-4 gap-3"},tt=["href"],st=["src","alt"],ot={class:"absolute inset-x-0 bottom-0 bg-gradient-to-t from-black/70 to-transparent p-2.5 opacity-0 group-hover:opacity-100 transition-opacity duration-200"},rt={class:"text-xs text-white line-clamp-2"};function at(e,n,p,_,f,g){return t(),o("div",Ye,[r("h3",Ze,a(e.$t("serp.name.imageResults")),1),r("div",et,[(t(!0),o(b,null,y(e.data,(s,l)=>(t(),o("a",{key:l,href:s.link,target:"_blank",rel:"noopener noreferrer",class:"group relative rounded-lg overflow-hidden bg-[var(--el-fill-color-light)] aspect-square"},[s.image_url?(t(),o("img",{key:0,src:s.image_url,alt:s.title,class:"w-full h-full object-cover transition-transform duration-300 group-hover:scale-105",loading:"lazy"},null,8,st)):c("",!0),r("div",ot,[r("span",rt,a(s.title),1)])],8,tt))),128))])])}const nt=m(Xe,[["render",at]]),lt=h({name:"VideoResults",props:{data:{type:Array,required:!0}}}),it={class:"text-base font-bold mb-3"},ct={class:"space-y-4"},dt=["href"],ut={class:"relative flex-shrink-0 w-40 h-24 rounded overflow-hidden bg-gray-100 dark:bg-gray-800"},pt=["src","alt"],ht={key:1,class:"absolute bottom-1 right-1 bg-black/80 text-white text-xs px-1 rounded"},mt={class:"flex-1 min-w-0"},_t={class:"text-blue-600 group-hover:underline font-medium line-clamp-2"},ft={class:"text-xs text-gray-400 mt-1"},gt={key:0},$t={key:1},vt={key:2},bt={key:0,class:"text-sm text-gray-600 dark:text-gray-300 mt-1 line-clamp-2"};function yt(e,n,p,_,f,g){return t(),o("div",null,[r("h3",it,a(e.$t("serp.name.videoResults")),1),r("div",ct,[(t(!0),o(b,null,y(e.data,(s,l)=>(t(),o("a",{key:l,href:s.link,target:"_blank",rel:"noopener noreferrer",class:"flex gap-4 group"},[r("div",ut,[s.image_url?(t(),o("img",{key:0,src:s.image_url,alt:s.title,class:"w-full h-full object-cover",loading:"lazy"},null,8,pt)):c("",!0),s.duration?(t(),o("div",ht,a(s.duration),1)):c("",!0)]),r("div",mt,[r("div",_t,a(s.title),1),r("div",ft,[s.source?(t(),o("span",gt,a(s.source),1)):c("",!0),s.channel?(t(),o("span",$t," · "+a(s.channel),1)):c("",!0),s.date?(t(),o("span",vt," · "+a(s.date),1)):c("",!0)]),s.snippet?(t(),o("p",bt,a(s.snippet),1)):c("",!0)])],8,dt))),128))])])}const kt=m(lt,[["render",yt]]),wt=h({name:"NewsResults",props:{data:{type:Array,required:!0}}}),xt={class:"text-base font-bold mb-3"},St={class:"space-y-4"},Rt=["href"],qt={class:"flex-1 min-w-0"},Et={class:"text-blue-600 group-hover:underline font-medium line-clamp-2"},Ct={class:"text-xs text-gray-400 mt-1"},Vt={key:0},It={key:1},Ut={key:0,class:"text-sm text-gray-600 dark:text-gray-300 mt-1 line-clamp-2"},At={key:0,class:"flex-shrink-0 w-24 h-24 rounded overflow-hidden bg-gray-100 dark:bg-gray-800"},jt=["src","alt"];function Ft(e,n,p,_,f,g){return t(),o("div",null,[r("h3",xt,a(e.$t("serp.name.newsResults")),1),r("div",St,[(t(!0),o(b,null,y(e.data,(s,l)=>(t(),o("a",{key:l,href:s.link,target:"_blank",rel:"noopener noreferrer",class:"flex gap-4 group"},[r("div",qt,[r("div",Et,a(s.title),1),r("div",Ct,[s.source?(t(),o("span",Vt,a(s.source),1)):c("",!0),s.date?(t(),o("span",It," · "+a(s.date),1)):c("",!0)]),s.snippet?(t(),o("p",Ut,a(s.snippet),1)):c("",!0)]),s.image_url?(t(),o("div",At,[r("img",{src:s.image_url,alt:s.title,class:"w-full h-full object-cover",loading:"lazy"},null,8,jt)])):c("",!0)],8,Rt))),128))])])}const Ot=m(wt,[["render",Ft]]),zt=h({name:"PeopleAlsoAsk",components:{ElCollapse:D,ElCollapseItem:B},props:{data:{type:Array,required:!0}}}),Nt={class:"rounded-xl border border-[var(--el-border-color-lighter)] p-5 bg-[var(--el-fill-color-blank)]"},Pt={class:"text-base font-bold mb-3"},Lt={key:0,class:"text-sm text-[var(--el-text-color-regular)] mb-2 leading-relaxed"},Gt=["href"];function Bt(e,n,p,_,f,g){const s=i("el-collapse-item"),l=i("el-collapse");return t(),o("div",Nt,[r("h3",Pt,a(e.$t("serp.name.peopleAlsoAsk")),1),d(l,null,{default:k(()=>[(t(!0),o(b,null,y(e.data,(u,$)=>(t(),v(s,{key:$,title:u.question||u.title||""},{default:k(()=>[u.snippet?(t(),o("p",Lt,a(u.snippet),1)):c("",!0),u.link?(t(),o("a",{key:1,href:u.link,target:"_blank",rel:"noopener noreferrer",class:"text-xs text-[var(--el-color-primary)] hover:underline"},a(u.title||u.link),9,Gt)):c("",!0)]),_:2},1032,["title"]))),128))]),_:1})])}const Dt=m(zt,[["render",Bt]]),Tt=h({name:"RelatedSearches",components:{FontAwesomeIcon:x},props:{data:{type:Array,required:!0}},emits:["search"],methods:{onSearch(e){e&&this.$emit("search",e)}}}),Kt={class:"rounded-xl border border-[var(--el-border-color-lighter)] p-5 bg-[var(--el-fill-color-blank)]"},Qt={class:"text-base font-bold mb-3"},Ht={class:"flex flex-wrap gap-2"},Jt=["onClick"];function Mt(e,n,p,_,f,g){const s=i("font-awesome-icon");return t(),o("div",Kt,[r("h3",Qt,a(e.$t("serp.name.relatedSearches")),1),r("div",Ht,[(t(!0),o(b,null,y(e.data,(l,u)=>(t(),o("button",{key:u,class:"inline-flex items-center gap-1.5 px-3 py-1.5 rounded-full text-sm bg-[var(--el-fill-color-light)] text-[var(--el-text-color-regular)] hover:bg-[var(--el-color-primary-light-9)] hover:text-[var(--el-color-primary)] transition-colors cursor-pointer border-none",onClick:$=>e.onSearch(l.query)},[d(s,{icon:"fa-solid fa-magnifying-glass",class:"text-xs opacity-50"}),I(" "+a(l.query),1)],8,Jt))),128))])])}const Wt=m(Tt,[["render",Mt]]),Xt=h({name:"ResultPanel",components:{FontAwesomeIcon:x,KnowledgeGraph:ze,OrganicResult:We,ImageResults:nt,VideoResults:kt,NewsResults:Ot,PeopleAlsoAsk:Dt,RelatedSearches:Wt},emits:["related-search"],computed:{results(){return this.$store.state.serp?.results},searching(){return this.$store.state.serp?.status?.search===V.Request},noResults(){return this.$store.state.serp?.status?.search===V.Success&&this.results&&!this.results.organic?.length&&!this.results.images?.length&&!this.results.videos?.length&&!this.results.news?.length&&!this.results.knowledge_graph?.title}},methods:{onRelatedSearch(e){this.$emit("related-search",e)}}}),Yt={class:"h-full overflow-y-auto p-6"},Zt={key:0,class:"max-w-3xl mx-auto py-8"},es={key:1,class:"flex flex-col items-center justify-center py-24 text-[var(--el-text-color-disabled)]"},ts={class:"text-base"},ss={key:2,class:"max-w-3xl mx-auto"},os={key:1,class:"mb-6"},rs={key:3,class:"flex flex-col items-center justify-center py-24 text-[var(--el-text-color-disabled)]"},as={class:"text-base"};function ns(e,n,p,_,f,g){const s=i("font-awesome-icon"),l=i("knowledge-graph"),u=i("organic-result"),$=i("image-results"),S=i("video-results"),R=i("news-results"),q=i("people-also-ask"),j=i("related-searches");return t(),o("div",Yt,[e.searching?(t(),o("div",Zt,[(t(),o(b,null,y(4,E=>r("div",{key:E,class:"mb-6 animate-pulse"},[...n[0]||(n[0]=[z('<div class="flex items-center gap-2 mb-2"><div class="w-4 h-4 rounded-sm bg-[var(--el-fill-color-darker)]"></div><div class="h-3 w-32 rounded bg-[var(--el-fill-color-darker)]"></div></div><div class="h-4 w-3/4 rounded bg-[var(--el-fill-color-dark)] mb-2"></div><div class="h-3 w-full rounded bg-[var(--el-fill-color)] mb-1"></div><div class="h-3 w-5/6 rounded bg-[var(--el-fill-color)]"></div>',4)])])),64))])):e.noResults?(t(),o("div",es,[d(s,{icon:"fa-solid fa-face-meh",class:"text-5xl mb-4 opacity-40"}),r("p",ts,a(e.$t("serp.message.noResults")),1)])):e.results?(t(),o("div",ss,[e.results.knowledge_graph?.title?(t(),v(l,{key:0,data:e.results.knowledge_graph,class:"mb-6"},null,8,["data"])):c("",!0),e.results.organic?.length?(t(),o("div",os,[(t(!0),o(b,null,y(e.results.organic,(E,F)=>(t(),v(u,{key:F,data:E,class:"mb-1"},null,8,["data"]))),128))])):c("",!0),e.results.images?.length?(t(),v($,{key:2,data:e.results.images,class:"mb-6"},null,8,["data"])):c("",!0),e.results.videos?.length?(t(),v(S,{key:3,data:e.results.videos,class:"mb-6"},null,8,["data"])):c("",!0),e.results.news?.length?(t(),v(R,{key:4,data:e.results.news,class:"mb-6"},null,8,["data"])):c("",!0),e.results.people_also_ask?.length?(t(),v(q,{key:5,data:e.results.people_also_ask,class:"mb-6"},null,8,["data"])):c("",!0),e.results.related_searches?.length?(t(),v(j,{key:6,data:e.results.related_searches,class:"mb-6",onSearch:e.onRelatedSearch},null,8,["data","onSearch"])):c("",!0)])):(t(),o("div",rs,[d(s,{icon:"fa-solid fa-globe",class:"text-5xl mb-4 opacity-30"}),r("p",as,a(e.$t("serp.description.query")),1)]))])}const ls=m(Xt,[["render",ns]]),is=h({name:"SerpIndex",components:{Layout:W,SearchPanel:we,ResultPanel:ls},inject:["initialized"],async mounted(){await this.onGetService()},methods:{async onGetService(){console.debug("start onGetService"),await this.$store.dispatch("serp/getService"),console.debug("end onGetService")},async onSearch(){if(this.$store.state.serp?.config?.query){w.info(this.$t("serp.message.searching"));try{await this.$store.dispatch("serp/search"),w.success(this.$t("serp.message.searchSuccess"))}catch(n){n?.response?.data?.error?.code===T?w.error(this.$t("serp.message.usedUp")):w.error(this.$t("serp.message.searchFailed"))}}},async onRelatedSearch(e){this.$store.commit("serp/setConfig",{...this.$store.state.serp?.config,query:e}),await this.onSearch()}}});function cs(e,n,p,_,f,g){const s=i("search-panel"),l=i("result-panel"),u=i("layout");return t(),v(u,null,{config:k(()=>[d(s,{onSearch:e.onSearch},null,8,["onSearch"])]),result:k(()=>[d(l,{onRelatedSearch:e.onRelatedSearch},null,8,["onRelatedSearch"])]),_:1})}const Ls=m(is,[["render",cs]]);export{Ls as default};
1
+ import{F as x}from"./index.es-DgRqc681.js";import{E as A}from"./index-BfYt3lpS.js";import{E as O}from"./index-D7TXnRb-.js";import{d as h,H as o,E as r,z as C,C as d,y as k,D as i,q as t,F as a,I,J as c,O as b,N as y,x as v,P as z}from"./vendor-vue-NSDaktjZ.js";import{E as m,aw as V}from"./index-BmskuvzR.js";import{E as U}from"./index-C4cFnn6h.js";import{E as N,a as P}from"./index-BYgw8Ne9.js";import{C as L}from"./Consumption-DhMtSnnQ.js";import{a as G}from"./price-BGnrujo6.js";import{E as B,a as D}from"./index-DOUTCEtG.js";import{b as T}from"./errorCode-Cqj9Td_Z.js";import{E as w}from"./index-Z6qAnijd.js";import"./use-form-item-7D-CUO4M.js";import"./index-BuyEbX8F.js";import"./vendor-axios-B8_nURbH.js";import"./vendor-dayjs-Cvgzdobq.js";import"./vendor-vue-router-Kg6s1a65.js";import"./typescript-D5w3x56R.js";import"./index-CEOn0L_0.js";import"./index-BvsGeWBq.js";import"./index-X4RPhZd6.js";import"./index-ys73P36s.js";import"./strings-beZM2Y-f.js";import"./isEqual-BPX3ojYz.js";import"./_Uint8Array-C3Lbt_45.js";import"./castArray-BgN0ywwP.js";import"./debounce-CfLqwhiY.js";import"./_baseIteratee-BEktInjh.js";import"./index-BkRv-z3G.js";import"./index-jvX6Scau.js";const K=h({name:"LayoutSerp",components:{ElDrawer:O,ElButton:A,FontAwesomeIcon:x},data(){return{drawer:!1}}}),Q={class:"main flex flex-row flex-1"},H={class:"config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]"},J={class:"result h-full flex-1 flex flex-col min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]"};function M(e,n,p,_,f,g){const s=i("font-awesome-icon"),l=i("el-button"),u=i("el-drawer");return t(),o("div",Q,[r("div",H,[C(e.$slots,"config",{},void 0,!0)]),r("div",J,[C(e.$slots,"result",{},void 0,!0)]),d(l,{circle:"",class:"menu",onClick:n[0]||(n[0]=$=>e.drawer=!0)},{default:k(()=>[d(s,{icon:"fa-solid fa-search"})]),_:1}),d(u,{modelValue:e.drawer,"onUpdate:modelValue":n[1]||(n[1]=$=>e.drawer=$),direction:"ltr","with-header":!1,size:"340px",class:"drawer"},{default:k(()=>[C(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const W=m(K,[["render",M],["__scopeId","data-v-99dba970"]]),X=h({name:"QueryInput",components:{ElInput:U},computed:{query:{get(){return this.$store.state.serp?.config?.query},set(e){this.$store.commit("serp/setConfig",{...this.$store.state.serp?.config,query:e})}}}}),Y={class:"field"},Z={class:"box"},ee={class:"title font-bold"};function te(e,n,p,_,f,g){const s=i("el-input");return t(),o("div",Y,[r("div",Z,[r("h2",ee,a(e.$t("serp.name.query")),1)]),d(s,{modelValue:e.query,"onUpdate:modelValue":n[0]||(n[0]=l=>e.query=l),rows:3,type:"textarea",class:"prompt",placeholder:e.$t("serp.placeholder.query")},null,8,["modelValue","placeholder"])])}const se=m(X,[["render",te],["__scopeId","data-v-3582b195"]]),oe=h({name:"TypeSelector",components:{ElSelect:P,ElOption:N},computed:{value:{get(){return this.$store.state.serp?.config?.type},set(e){this.$store.commit("serp/setConfig",{...this.$store.state.serp?.config,type:e})}}},mounted(){this.value||(this.value="search")}}),re={class:"field"},ae={class:"title font-bold"};function ne(e,n,p,_,f,g){const s=i("el-option"),l=i("el-select");return t(),o("div",re,[r("h2",ae,a(e.$t("serp.name.type")),1),d(l,{modelValue:e.value,"onUpdate:modelValue":n[0]||(n[0]=u=>e.value=u),class:"value"},{default:k(()=>[d(s,{value:"search",label:e.$t("serp.type.search")},null,8,["label"]),d(s,{value:"images",label:e.$t("serp.type.images")},null,8,["label"]),d(s,{value:"news",label:e.$t("serp.type.news")},null,8,["label"]),d(s,{value:"videos",label:e.$t("serp.type.videos")},null,8,["label"])]),_:1},8,["modelValue"])])}const le=m(oe,[["render",ne],["__scopeId","data-v-2913fb62"]]),ie=h({name:"CountryInput",components:{ElInput:U},computed:{value:{get(){return this.$store.state.serp?.config?.country},set(e){this.$store.commit("serp/setConfig",{...this.$store.state.serp?.config,country:e})}}},mounted(){this.value||(this.value="US")}}),ce={class:"field"},de={class:"title font-bold"};function ue(e,n,p,_,f,g){const s=i("el-input");return t(),o("div",ce,[r("h2",de,a(e.$t("serp.name.country")),1),d(s,{modelValue:e.value,"onUpdate:modelValue":n[0]||(n[0]=l=>e.value=l),class:"value",placeholder:e.$t("serp.placeholder.country")},null,8,["modelValue","placeholder"])])}const pe=m(ie,[["render",ue],["__scopeId","data-v-f0672cc6"]]),he=h({name:"LanguageInput",components:{ElInput:U},computed:{value:{get(){return this.$store.state.serp?.config?.language},set(e){this.$store.commit("serp/setConfig",{...this.$store.state.serp?.config,language:e})}}},mounted(){this.value||(this.value="en")}}),me={class:"field"},_e={class:"title font-bold"};function fe(e,n,p,_,f,g){const s=i("el-input");return t(),o("div",me,[r("h2",_e,a(e.$t("serp.name.language")),1),d(s,{modelValue:e.value,"onUpdate:modelValue":n[0]||(n[0]=l=>e.value=l),class:"value",placeholder:e.$t("serp.placeholder.language")},null,8,["modelValue","placeholder"])])}const ge=m(he,[["render",fe],["__scopeId","data-v-dc1c94b7"]]),$e=h({name:"SearchPanel",components:{ElButton:A,FontAwesomeIcon:x,QueryInput:se,TypeSelector:le,CountryInput:pe,LanguageInput:ge,Consumption:L},emits:["search"],computed:{config(){return this.$store.state.serp?.config},consumption(){return G(this.config,this.service?.cost)},service(){return this.$store.state.serp?.service},searching(){return this.$store.state.serp?.status?.search===V.Request}},methods:{onSearch(){this.$emit("search")}}}),ve={class:"flex flex-col h-full"},be={class:"flex-1 overflow-y-auto p-5"},ye={class:"flex flex-col items-center justify-center px-5 pb-5"};function ke(e,n,p,_,f,g){const s=i("query-input"),l=i("type-selector"),u=i("country-input"),$=i("language-input"),S=i("consumption"),R=i("font-awesome-icon"),q=i("el-button");return t(),o("div",ve,[r("div",be,[d(s,{class:"mb-4"}),d(l,{class:"mb-4"}),d(u,{class:"mb-4"}),d($,{class:"mb-4"})]),r("div",ye,[d(S,{value:e.consumption,service:e.service},null,8,["value","service"]),d(q,{type:"primary",class:"btn w-full",round:"",loading:e.searching,onClick:e.onSearch},{default:k(()=>[d(R,{icon:"fa-solid fa-search",class:"mr-2"}),I(" "+a(e.$t("serp.button.search")),1)]),_:1},8,["loading","onClick"])])])}const we=m($e,[["render",ke]]),xe=h({name:"KnowledgeGraph",props:{data:{type:Object,required:!0}}}),Se={class:"knowledge-graph rounded-xl border border-[var(--el-border-color-lighter)] p-5 bg-[var(--el-fill-color-blank)]"},Re={class:"flex flex-row gap-4"},qe=["src","alt"],Ee={class:"flex-1 min-w-0"},Ce={key:0,class:"text-xs text-[var(--el-text-color-disabled)] mb-1 uppercase tracking-wide"},Ve={class:"text-xl font-bold mb-1.5"},Ie={key:1,class:"text-sm text-[var(--el-text-color-regular)] mb-3 leading-relaxed"},Ue=["href"],Ae={key:2,class:"text-sm"},je={class:"text-[var(--el-text-color-disabled)] flex-none font-medium"},Fe={class:"text-[var(--el-text-color-regular)]"};function Oe(e,n,p,_,f,g){return t(),o("div",Se,[r("div",Re,[e.data.image_url?(t(),o("img",{key:0,src:e.data.image_url,alt:e.data.title,class:"w-28 h-28 rounded-lg object-cover flex-none shadow-sm"},null,8,qe)):c("",!0),r("div",Ee,[e.data.type?(t(),o("div",Ce,a(e.data.type),1)):c("",!0),r("h3",Ve,a(e.data.title),1),e.data.description?(t(),o("p",Ie,[I(a(e.data.description)+" ",1),e.data.description_link?(t(),o("a",{key:0,href:e.data.description_link,target:"_blank",rel:"noopener noreferrer",class:"text-[var(--el-color-primary)] hover:underline ml-1"},a(e.data.description_source||"Source"),9,Ue)):c("",!0)])):c("",!0),e.data.attributes&&Object.keys(e.data.attributes).length?(t(),o("div",Ae,[(t(!0),o(b,null,y(e.data.attributes,(s,l)=>(t(),o("div",{key:l,class:"flex gap-2 mb-1 py-0.5"},[r("span",je,a(l)+":",1),r("span",Fe,a(s),1)]))),128))])):c("",!0)])])])}const ze=m(xe,[["render",Oe]]),Ne=h({name:"OrganicResult",props:{data:{type:Object,required:!0}},data(){return{faviconFailed:!1}},computed:{hostname(){if(!this.data.link)return"";try{return new URL(this.data.link).hostname}catch{return""}},pathname(){if(!this.data.link)return"";try{const e=new URL(this.data.link).pathname;return e==="/"?"":e}catch{return""}},displayUrl(){return this.hostname},faviconUrl(){return this.faviconFailed||!this.hostname?"":`https://www.google.com/s2/favicons?domain=${this.hostname}&sz=32`}},methods:{onFaviconError(e){this.faviconFailed=!0,e.target.style.display="none"}}}),Pe={class:"organic-result rounded-lg p-4 transition-all duration-200 hover:bg-[var(--el-fill-color-lighter)]"},Le={key:0,class:"flex items-center gap-2 mb-1.5"},Ge=["src","alt"],Be={class:"text-xs text-[var(--el-text-color-secondary)] truncate"},De={class:"text-xs text-[var(--el-text-color-disabled)]"},Te=["href"],Ke={key:1,class:"text-xs text-[var(--el-text-color-disabled)] mt-1"},Qe={key:2,class:"text-sm text-[var(--el-text-color-regular)] mt-1.5 leading-relaxed line-clamp-3"},He={key:3,class:"mt-3 flex flex-wrap gap-x-4 gap-y-1"},Je=["href"];function Me(e,n,p,_,f,g){return t(),o("div",Pe,[e.displayUrl?(t(),o("div",Le,[r("img",{src:e.faviconUrl,alt:e.hostname,class:"w-4 h-4 rounded-sm flex-none",loading:"lazy",onError:n[0]||(n[0]=(...s)=>e.onFaviconError&&e.onFaviconError(...s))},null,40,Ge),r("span",Be,a(e.hostname),1),r("span",De,a(e.pathname),1)])):c("",!0),r("a",{href:e.data.link,target:"_blank",rel:"noopener noreferrer",class:"text-base font-semibold text-[var(--el-color-primary)] hover:underline leading-snug block"},a(e.data.title),9,Te),e.data.date?(t(),o("div",Ke,a(e.data.date),1)):c("",!0),e.data.snippet?(t(),o("p",Qe,a(e.data.snippet),1)):c("",!0),e.data.sitelinks?.length?(t(),o("div",He,[(t(!0),o(b,null,y(e.data.sitelinks,(s,l)=>(t(),o("a",{key:l,href:s.link,target:"_blank",rel:"noopener noreferrer",class:"text-xs text-[var(--el-color-primary-light-3)] hover:text-[var(--el-color-primary)] hover:underline transition-colors"},a(s.title),9,Je))),128))])):c("",!0)])}const We=m(Ne,[["render",Me]]),Xe=h({name:"ImageResults",props:{data:{type:Array,required:!0}}}),Ye={class:"rounded-xl border border-[var(--el-border-color-lighter)] p-5 bg-[var(--el-fill-color-blank)]"},Ze={class:"text-base font-bold mb-3"},et={class:"grid grid-cols-2 sm:grid-cols-3 md:grid-cols-4 gap-3"},tt=["href"],st=["src","alt"],ot={class:"absolute inset-x-0 bottom-0 bg-gradient-to-t from-black/70 to-transparent p-2.5 opacity-0 group-hover:opacity-100 transition-opacity duration-200"},rt={class:"text-xs text-white line-clamp-2"};function at(e,n,p,_,f,g){return t(),o("div",Ye,[r("h3",Ze,a(e.$t("serp.name.imageResults")),1),r("div",et,[(t(!0),o(b,null,y(e.data,(s,l)=>(t(),o("a",{key:l,href:s.link,target:"_blank",rel:"noopener noreferrer",class:"group relative rounded-lg overflow-hidden bg-[var(--el-fill-color-light)] aspect-square"},[s.image_url?(t(),o("img",{key:0,src:s.image_url,alt:s.title,class:"w-full h-full object-cover transition-transform duration-300 group-hover:scale-105",loading:"lazy"},null,8,st)):c("",!0),r("div",ot,[r("span",rt,a(s.title),1)])],8,tt))),128))])])}const nt=m(Xe,[["render",at]]),lt=h({name:"VideoResults",props:{data:{type:Array,required:!0}}}),it={class:"text-base font-bold mb-3"},ct={class:"space-y-4"},dt=["href"],ut={class:"relative flex-shrink-0 w-40 h-24 rounded overflow-hidden bg-gray-100 dark:bg-gray-800"},pt=["src","alt"],ht={key:1,class:"absolute bottom-1 right-1 bg-black/80 text-white text-xs px-1 rounded"},mt={class:"flex-1 min-w-0"},_t={class:"text-blue-600 group-hover:underline font-medium line-clamp-2"},ft={class:"text-xs text-gray-400 mt-1"},gt={key:0},$t={key:1},vt={key:2},bt={key:0,class:"text-sm text-gray-600 dark:text-gray-300 mt-1 line-clamp-2"};function yt(e,n,p,_,f,g){return t(),o("div",null,[r("h3",it,a(e.$t("serp.name.videoResults")),1),r("div",ct,[(t(!0),o(b,null,y(e.data,(s,l)=>(t(),o("a",{key:l,href:s.link,target:"_blank",rel:"noopener noreferrer",class:"flex gap-4 group"},[r("div",ut,[s.image_url?(t(),o("img",{key:0,src:s.image_url,alt:s.title,class:"w-full h-full object-cover",loading:"lazy"},null,8,pt)):c("",!0),s.duration?(t(),o("div",ht,a(s.duration),1)):c("",!0)]),r("div",mt,[r("div",_t,a(s.title),1),r("div",ft,[s.source?(t(),o("span",gt,a(s.source),1)):c("",!0),s.channel?(t(),o("span",$t," · "+a(s.channel),1)):c("",!0),s.date?(t(),o("span",vt," · "+a(s.date),1)):c("",!0)]),s.snippet?(t(),o("p",bt,a(s.snippet),1)):c("",!0)])],8,dt))),128))])])}const kt=m(lt,[["render",yt]]),wt=h({name:"NewsResults",props:{data:{type:Array,required:!0}}}),xt={class:"text-base font-bold mb-3"},St={class:"space-y-4"},Rt=["href"],qt={class:"flex-1 min-w-0"},Et={class:"text-blue-600 group-hover:underline font-medium line-clamp-2"},Ct={class:"text-xs text-gray-400 mt-1"},Vt={key:0},It={key:1},Ut={key:0,class:"text-sm text-gray-600 dark:text-gray-300 mt-1 line-clamp-2"},At={key:0,class:"flex-shrink-0 w-24 h-24 rounded overflow-hidden bg-gray-100 dark:bg-gray-800"},jt=["src","alt"];function Ft(e,n,p,_,f,g){return t(),o("div",null,[r("h3",xt,a(e.$t("serp.name.newsResults")),1),r("div",St,[(t(!0),o(b,null,y(e.data,(s,l)=>(t(),o("a",{key:l,href:s.link,target:"_blank",rel:"noopener noreferrer",class:"flex gap-4 group"},[r("div",qt,[r("div",Et,a(s.title),1),r("div",Ct,[s.source?(t(),o("span",Vt,a(s.source),1)):c("",!0),s.date?(t(),o("span",It," · "+a(s.date),1)):c("",!0)]),s.snippet?(t(),o("p",Ut,a(s.snippet),1)):c("",!0)]),s.image_url?(t(),o("div",At,[r("img",{src:s.image_url,alt:s.title,class:"w-full h-full object-cover",loading:"lazy"},null,8,jt)])):c("",!0)],8,Rt))),128))])])}const Ot=m(wt,[["render",Ft]]),zt=h({name:"PeopleAlsoAsk",components:{ElCollapse:D,ElCollapseItem:B},props:{data:{type:Array,required:!0}}}),Nt={class:"rounded-xl border border-[var(--el-border-color-lighter)] p-5 bg-[var(--el-fill-color-blank)]"},Pt={class:"text-base font-bold mb-3"},Lt={key:0,class:"text-sm text-[var(--el-text-color-regular)] mb-2 leading-relaxed"},Gt=["href"];function Bt(e,n,p,_,f,g){const s=i("el-collapse-item"),l=i("el-collapse");return t(),o("div",Nt,[r("h3",Pt,a(e.$t("serp.name.peopleAlsoAsk")),1),d(l,null,{default:k(()=>[(t(!0),o(b,null,y(e.data,(u,$)=>(t(),v(s,{key:$,title:u.question||u.title||""},{default:k(()=>[u.snippet?(t(),o("p",Lt,a(u.snippet),1)):c("",!0),u.link?(t(),o("a",{key:1,href:u.link,target:"_blank",rel:"noopener noreferrer",class:"text-xs text-[var(--el-color-primary)] hover:underline"},a(u.title||u.link),9,Gt)):c("",!0)]),_:2},1032,["title"]))),128))]),_:1})])}const Dt=m(zt,[["render",Bt]]),Tt=h({name:"RelatedSearches",components:{FontAwesomeIcon:x},props:{data:{type:Array,required:!0}},emits:["search"],methods:{onSearch(e){e&&this.$emit("search",e)}}}),Kt={class:"rounded-xl border border-[var(--el-border-color-lighter)] p-5 bg-[var(--el-fill-color-blank)]"},Qt={class:"text-base font-bold mb-3"},Ht={class:"flex flex-wrap gap-2"},Jt=["onClick"];function Mt(e,n,p,_,f,g){const s=i("font-awesome-icon");return t(),o("div",Kt,[r("h3",Qt,a(e.$t("serp.name.relatedSearches")),1),r("div",Ht,[(t(!0),o(b,null,y(e.data,(l,u)=>(t(),o("button",{key:u,class:"inline-flex items-center gap-1.5 px-3 py-1.5 rounded-full text-sm bg-[var(--el-fill-color-light)] text-[var(--el-text-color-regular)] hover:bg-[var(--el-color-primary-light-9)] hover:text-[var(--el-color-primary)] transition-colors cursor-pointer border-none",onClick:$=>e.onSearch(l.query)},[d(s,{icon:"fa-solid fa-magnifying-glass",class:"text-xs opacity-50"}),I(" "+a(l.query),1)],8,Jt))),128))])])}const Wt=m(Tt,[["render",Mt]]),Xt=h({name:"ResultPanel",components:{FontAwesomeIcon:x,KnowledgeGraph:ze,OrganicResult:We,ImageResults:nt,VideoResults:kt,NewsResults:Ot,PeopleAlsoAsk:Dt,RelatedSearches:Wt},emits:["related-search"],computed:{results(){return this.$store.state.serp?.results},searching(){return this.$store.state.serp?.status?.search===V.Request},noResults(){return this.$store.state.serp?.status?.search===V.Success&&this.results&&!this.results.organic?.length&&!this.results.images?.length&&!this.results.videos?.length&&!this.results.news?.length&&!this.results.knowledge_graph?.title}},methods:{onRelatedSearch(e){this.$emit("related-search",e)}}}),Yt={class:"h-full overflow-y-auto p-6"},Zt={key:0,class:"max-w-3xl mx-auto py-8"},es={key:1,class:"flex flex-col items-center justify-center py-24 text-[var(--el-text-color-disabled)]"},ts={class:"text-base"},ss={key:2,class:"max-w-3xl mx-auto"},os={key:1,class:"mb-6"},rs={key:3,class:"flex flex-col items-center justify-center py-24 text-[var(--el-text-color-disabled)]"},as={class:"text-base"};function ns(e,n,p,_,f,g){const s=i("font-awesome-icon"),l=i("knowledge-graph"),u=i("organic-result"),$=i("image-results"),S=i("video-results"),R=i("news-results"),q=i("people-also-ask"),j=i("related-searches");return t(),o("div",Yt,[e.searching?(t(),o("div",Zt,[(t(),o(b,null,y(4,E=>r("div",{key:E,class:"mb-6 animate-pulse"},[...n[0]||(n[0]=[z('<div class="flex items-center gap-2 mb-2"><div class="w-4 h-4 rounded-sm bg-[var(--el-fill-color-darker)]"></div><div class="h-3 w-32 rounded bg-[var(--el-fill-color-darker)]"></div></div><div class="h-4 w-3/4 rounded bg-[var(--el-fill-color-dark)] mb-2"></div><div class="h-3 w-full rounded bg-[var(--el-fill-color)] mb-1"></div><div class="h-3 w-5/6 rounded bg-[var(--el-fill-color)]"></div>',4)])])),64))])):e.noResults?(t(),o("div",es,[d(s,{icon:"fa-solid fa-face-meh",class:"text-5xl mb-4 opacity-40"}),r("p",ts,a(e.$t("serp.message.noResults")),1)])):e.results?(t(),o("div",ss,[e.results.knowledge_graph?.title?(t(),v(l,{key:0,data:e.results.knowledge_graph,class:"mb-6"},null,8,["data"])):c("",!0),e.results.organic?.length?(t(),o("div",os,[(t(!0),o(b,null,y(e.results.organic,(E,F)=>(t(),v(u,{key:F,data:E,class:"mb-1"},null,8,["data"]))),128))])):c("",!0),e.results.images?.length?(t(),v($,{key:2,data:e.results.images,class:"mb-6"},null,8,["data"])):c("",!0),e.results.videos?.length?(t(),v(S,{key:3,data:e.results.videos,class:"mb-6"},null,8,["data"])):c("",!0),e.results.news?.length?(t(),v(R,{key:4,data:e.results.news,class:"mb-6"},null,8,["data"])):c("",!0),e.results.people_also_ask?.length?(t(),v(q,{key:5,data:e.results.people_also_ask,class:"mb-6"},null,8,["data"])):c("",!0),e.results.related_searches?.length?(t(),v(j,{key:6,data:e.results.related_searches,class:"mb-6",onSearch:e.onRelatedSearch},null,8,["data","onSearch"])):c("",!0)])):(t(),o("div",rs,[d(s,{icon:"fa-solid fa-globe",class:"text-5xl mb-4 opacity-30"}),r("p",as,a(e.$t("serp.description.query")),1)]))])}const ls=m(Xt,[["render",ns]]),is=h({name:"SerpIndex",components:{Layout:W,SearchPanel:we,ResultPanel:ls},inject:["initialized"],async mounted(){await this.onGetService()},methods:{async onGetService(){console.debug("start onGetService"),await this.$store.dispatch("serp/getService"),console.debug("end onGetService")},async onSearch(){if(this.$store.state.serp?.config?.query){w.info(this.$t("serp.message.searching"));try{await this.$store.dispatch("serp/search"),w.success(this.$t("serp.message.searchSuccess"))}catch(n){n?.response?.data?.error?.code===T?w.error(this.$t("serp.message.usedUp")):w.error(this.$t("serp.message.searchFailed"))}}},async onRelatedSearch(e){this.$store.commit("serp/setConfig",{...this.$store.state.serp?.config,query:e}),await this.onSearch()}}});function cs(e,n,p,_,f,g){const s=i("search-panel"),l=i("result-panel"),u=i("layout");return t(),v(u,null,{config:k(()=>[d(s,{onSearch:e.onSearch},null,8,["onSearch"])]),result:k(()=>[d(l,{onRelatedSearch:e.onRelatedSearch},null,8,["onRelatedSearch"])]),_:1})}const Ls=m(is,[["render",cs]]);export{Ls as default};
@@ -1 +1 @@
1
- import{F as S}from"./index.es-CqUFafZ-.js";import{E as P}from"./index-C3HcWVsL.js";import{E as x}from"./index-B3UfVG_d.js";import{d as y,H as l,E as m,z as q,C as o,y as v,D as n,q as a,F as s,I as u,O as I,N as L,x as E,J as _,M as W,Q as O}from"./vendor-vue-NSDaktjZ.js";import{E as w,b8 as H,ch as Z,ci as J,cj as K,ck as Q,cl as X,cm as U,cn as C,co as M,cp as Y,cd as ee,aw as z}from"./index-BAlXF3lp.js";import{I as R,S as te}from"./ScrollList-DKlPMNZT.js";import{E as oe}from"./index-DhStH-hF.js";import{I as N}from"./ImagePreview-BuuE19Gy.js";import{E as se}from"./index-BtBl6GQu.js";import{E as A}from"./index-czzMfzSq.js";import{C as ae}from"./Consumption-DEJXi9Yk.js";import{a as ne}from"./price-Bs-d-Bvz.js";import{E as B,a as F}from"./index-CcnMKyw7.js";import{b as ie}from"./errorCode-Cqj9Td_Z.js";import{o as j}from"./openaiimage-3xfIWOkR.js";import{C as le}from"./CopyToClipboard-DB2Z-HRU.js";import{I as re}from"./ImageWrapper-B87viqTL.js";import{E as ce}from"./index-5GxMphke.js";import{E as me}from"./index-Hxc7n4HD.js";import{E as pe}from"./index-C2sZXfFW.js";import{B as ue}from"./BotPlaceholder-5oNK0Ith.js";import{N as de}from"./NoTasks-ZpQi0TyE.js";import"./use-form-item-DooKcsta.js";import"./index-BuyEbX8F.js";import"./vendor-axios-B8_nURbH.js";import"./vendor-dayjs-Cvgzdobq.js";import"./vendor-vue-router-Kg6s1a65.js";import"./typescript-DGijeo9F.js";import"./index-C9pbuvyJ.js";import"./index-DWiPtPwc.js";import"./index-DHE-zvMr.js";import"./_baseClone-DZS2KndZ.js";import"./_Uint8Array-ByIiAerw.js";import"./_initCloneObject-CuynXAWC.js";import"./isEqual-CIKj9pK6.js";import"./index-Bd83o_xd.js";import"./strings-beZM2Y-f.js";import"./castArray-Dy2e0JbB.js";import"./debounce-Cu_Jtjpm.js";import"./_baseIteratee-DWXq1g8X.js";import"./index-bQIOVtse.js";import"./index-C1HKY4Q8.js";const ge=y({name:"LayoutNanobanana",components:{ElDrawer:x,ElButton:P,FontAwesomeIcon:S},data(){return{drawer:!1}}}),fe={class:"main flex flex-row flex-1"},he={class:"config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]"},_e={class:"result h-full p-6 flex-1 flex flex-col min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]"};function $e(e,t,c,i,p,h){const d=n("font-awesome-icon"),g=n("el-button"),$=n("el-drawer");return a(),l("div",fe,[m("div",he,[q(e.$slots,"config",{},void 0,!0)]),m("div",_e,[q(e.$slots,"result",{},void 0,!0)]),o(g,{circle:"",class:"menu",onClick:t[0]||(t[0]=f=>e.drawer=!0)},{default:v(()=>[o(d,{icon:"fa-solid fa-magic"})]),_:1}),o($,{modelValue:e.drawer,"onUpdate:modelValue":t[1]||(t[1]=f=>e.drawer=f),direction:"ltr","with-header":!1,size:"340px",class:"drawer"},{default:v(()=>[q(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const ve=w(ge,[["render",$e],["__scopeId","data-v-bfe5cd4b"]]),be="",ke=y({name:"PromptInput",components:{ElInput:oe,InfoIcon:R},computed:{prompt:{get(){return this.$store.state.openaiimage?.config?.prompt},set(e){console.debug("set prompt",e),this.$store.commit("openaiimage/setConfig",{...this.$store.state.openaiimage?.config,prompt:e})}}},mounted(){this.prompt||(this.prompt=be)}}),ye={class:"field"},we={class:"box"},Ie={class:"title font-bold"};function Ee(e,t,c,i,p,h){const d=n("info-icon"),g=n("el-input");return a(),l("div",ye,[m("div",we,[m("h2",Ie,s(e.$t("openaiimage.name.prompt")),1),o(d,{content:e.$t("openaiimage.description.prompt"),class:"info"},null,8,["content"])]),o(g,{modelValue:e.prompt,"onUpdate:modelValue":t[0]||(t[0]=$=>e.prompt=$),rows:3,type:"textarea",class:"prompt",placeholder:e.$t("openaiimage.placeholder.prompt")},null,8,["modelValue","placeholder"])])}const Ve=w(ke,[["render",Ee],["__scopeId","data-v-92f61e4a"]]),Ae=y({name:"ImageUrlsInput",components:{ElUpload:se,ElButton:P,InfoIcon:R,ImagePreview:N,FontAwesomeIcon:S},data(){return{fileList:[],uploadUrl:H()+"/api/v1/files/",suppressWatch:!1}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e?.response?.file_url).filter(e=>!!e)},value(){return this.$store.state.openaiimage?.config?.image_urls}},watch:{value:{immediate:!0,handler(e){if(this.suppressWatch)return;if(!e||e.length===0){const i=(this.fileList||[]).filter(p=>!p?.response?.file_url);this.fileList=i.length?i:[];return}const t=[];e.forEach(i=>{const p=this.fileList.find(h=>h?.response?.file_url===i||h?.url===i);p?t.push(p):t.push({name:i.split("/").pop()||i,url:i,status:"success",percentage:100,response:{file_url:i}})}),(this.fileList||[]).filter(i=>!i?.response?.file_url).forEach(i=>{t.some(h=>h===i||h?.url===i?.url||h?.response?.file_url===i?.response?.file_url)||t.push(i)}),this.fileList=t}}},mounted(){},methods:{onChange(e){if(!e?.url&&e?.raw)try{e.url=URL.createObjectURL(e.raw)}catch{}},onRemove(e){if(e?.url&&typeof e.url=="string"&&e.url.startsWith("blob:"))try{URL.revokeObjectURL(e.url)}catch{}this.onSetImageUrls()},onExceed(){A.warning(this.$t("openaiimage.message.uploadImageExceed"))},onError(){A.error(this.$t("openaiimage.message.uploadImageError"))},onSetImageUrls(){const e=this.urls;this.suppressWatch=!0,this.$store.commit("openaiimage/setConfig",{...this.$store.state.openaiimage?.config,image_urls:e}),this.$nextTick(()=>{this.suppressWatch=!1})},async onSuccess(e,t){e?.file_url&&(t.url=e.file_url,t.response=e),this.onSetImageUrls()},onRemovePreview(e,t){if(this.fileList.splice(e,1),t?.url&&typeof t.url=="string"&&t.url.startsWith("blob:"))try{URL.revokeObjectURL(t.url)}catch{}this.onSetImageUrls()}}}),Le={class:"field flex items-center justify-between"},Te={class:"title font-bold text-[14px] mb-[10px]"},Ge={class:"upload-wrapper flex flex-col items-start gap-[8px]"},Se={class:"controls flex items-center"},Pe={class:"file-list flex flex-wrap gap-[10px]"};function Oe(e,t,c,i,p,h){const d=n("font-awesome-icon"),g=n("el-button"),$=n("el-upload"),f=n("info-icon"),k=n("image-preview");return a(),l(I,null,[m("div",Le,[m("h2",Te,s(e.$t("openaiimage.name.imageUrls")),1),m("div",Ge,[m("div",Se,[o($,{"file-list":e.fileList,"onUpdate:fileList":t[0]||(t[0]=r=>e.fileList=r),accept:".png,.jpg,.jpeg,.gif,.bmp,.webp",name:"file",class:"value",limit:5,multiple:!0,"show-file-list":!1,action:e.uploadUrl,"on-exceed":e.onExceed,"on-error":e.onError,"on-success":e.onSuccess,"on-change":e.onChange,"on-remove":e.onRemove,headers:e.headers},{default:v(()=>[o(g,{size:"small",type:"primary",round:""},{default:v(()=>[o(d,{icon:"fa-solid fa-upload",class:"mr-1"}),u(" "+s(e.$t("openaiimage.button.uploadImageUrls")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-success","on-change","on-remove","headers"]),o(f,{content:e.$t("openaiimage.description.imageUrls"),class:"ml-2"},null,8,["content"])])])]),m("div",Pe,[(a(!0),l(I,null,L(e.fileList,(r,b)=>(a(),E(k,{key:r.uid||r?.response?.file_url||r.url||b,url:r.url||r?.response?.file_url,name:r.name,percentage:r.percentage,onRemove:T=>e.onRemovePreview(b,r)},null,8,["url","name","percentage","onRemove"]))),128))])],64)}const Re=w(Ae,[["render",Oe]]),qe=y({name:"OpenAIImageModelSelector",components:{ElSelect:F,ElOption:B,InfoIcon:R},data(){return{options:[{value:J,label:this.$t("openaiimage.model.gptImage1")},{value:K,label:this.$t("openaiimage.model.gptImage15")},{value:Q,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=Z)}}),Ue={class:"field"},Ce={class:"label"},Me={class:"box"},ze={class:"title font-bold"};function je(e,t,c,i,p,h){const d=n("info-icon"),g=n("el-option"),$=n("el-select");return a(),l("div",Ue,[m("div",Ce,[m("div",Me,[m("h2",ze,s(e.$t("openaiimage.name.model")),1),o(d,{content:e.modelDescription,class:"info"},null,8,["content"])])]),o($,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=f=>e.value=f),class:"value",placeholder:e.$t("openaiimage.placeholder.select")},{default:v(()=>[(a(!0),l(I,null,L(e.options,f=>(a(),E(g,{key:f.value,label:f.label,value:f.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const De=w(qe,[["render",je],["__scopeId","data-v-cec771bd"]]),Ne=y({name:"OpenAIImageSizeSelector",components:{ElSelect:F,ElOption:B,InfoIcon:R},data(){return{options:[{value:U,label:U},{value:C,label:C},{value:M,label:M}]}},computed:{value:{get(){return this.$store.state.openaiimage?.config?.size},set(e){this.$store.commit("openaiimage/setConfig",{...this.$store.state.openaiimage?.config,size:e})}}},mounted(){this.value||(this.value=X)}}),Be={class:"field"},Fe={class:"label"},xe={class:"box"},We={class:"title font-bold"};function He(e,t,c,i,p,h){const d=n("info-icon"),g=n("el-option"),$=n("el-select");return a(),l("div",Be,[m("div",Fe,[m("div",xe,[m("h2",We,s(e.$t("openaiimage.name.size")),1),o(d,{content:e.$t("openaiimage.description.size"),class:"info"},null,8,["content"])])]),o($,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=f=>e.value=f),class:"value",placeholder:e.$t("openaiimage.placeholder.select")},{default:v(()=>[(a(!0),l(I,null,L(e.options,f=>(a(),E(g,{key:f.value,label:f.label,value:f.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Ze=w(Ne,[["render",He],["__scopeId","data-v-11116785"]]),Je=y({name:"ConfigPanel",components:{ElButton:P,FontAwesomeIcon:S,PromptInput:Ve,Consumption:ae,ImageUrlsInput:Re,ModelSelector:De,ResolutionSelector:Ze},emits:["generate"],computed:{config(){return this.$store.state.openaiimage?.config},consumption(){const e={...this.config||{}};return ne({...e},this.service?.cost)},service(){return this.$store.state.openaiimage?.service}},methods:{onGenerate(){this.$emit("generate")}}}),Ke={class:"flex flex-col h-full"},Qe={class:"flex-1 overflow-y-auto p-5"},Xe={class:"flex flex-col items-center justify-center px-5 pb-5"};function Ye(e,t,c,i,p,h){const d=n("model-selector"),g=n("resolution-selector"),$=n("prompt-input"),f=n("image-urls-input"),k=n("consumption"),r=n("font-awesome-icon"),b=n("el-button");return a(),l("div",Ke,[m("div",Qe,[o(d,{class:"mb-4"}),o(g,{class:"mb-4"}),o($,{class:"mb-4"}),o(f,{class:"mb-4"})]),m("div",Xe,[o(k,{value:e.consumption,service:e.service},null,8,["value","service"]),o(b,{type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:v(()=>[o(r,{icon:"fa-solid fa-magic",class:"mr-2"}),u(" "+s(e.$t("openaiimage.button.generate")),1)]),_:1},8,["onClick"])])])}const et=w(Je,[["render",Ye]]),tt=y({name:"TaskPreview",components:{ElImage:pe,CopyToClipboard:le,FontAwesomeIcon:S,ElAlert:me,ImageWrapper:re,ElButton:P,ElTooltip:ce,ImagePreview:N},props:{modelValue:{type:Object,required:!0}},setup(){return{OPENAIIMAGE_LOGO:Y}},computed:{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(i=>typeof i=="string"&&i.length>0);const c=e.image;return Array.isArray(c)?c.filter(i=>typeof i=="string"&&i.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)}}}),ot={class:"preview"},st={class:"left"},at={class:"main"},nt={class:"bot"},it={class:"datetime"},lt={class:"info"},rt={key:0,class:"flex justify-start items-center gap-2 mt-2 w-full overflow-x-auto"},ct={key:1,class:"prompt mt-2"},mt={key:0},pt={key:0,class:O({content:!0,failed:!0})},ut={class:"flex justify-start items-center gap-4 w-full overflow-x-auto"},dt={class:O({operations:!0,"mt-2":!0,"mb-2":!0})},gt={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},ft={key:1,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},ht={key:2,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},_t={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},$t={key:3,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},vt={key:4,class:"text-[var(--el-text-color-regular)] text-xs mb-0"},bt={key:1,class:O({content:!0})},kt={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},yt={key:1,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},wt={key:2,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},It={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Et={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Vt={key:3,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},At={key:4,class:"text-[var(--el-text-color-regular)] text-xs mb-0"},Lt={key:2,class:O({content:!0})},Tt={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"},St={key:2,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Pt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"};function Ot(e,t,c,i,p,h){const d=n("el-image"),g=n("image-preview"),$=n("image-wrapper"),f=n("el-button"),k=n("el-tooltip"),r=n("font-awesome-icon"),b=n("copy-to-clipboard"),T=n("el-alert");return a(),l("div",ot,[m("div",st,[o(d,{src:e.OPENAIIMAGE_LOGO,class:"avatar"},null,8,["src"])]),m("div",at,[m("div",nt,[u(s(e.$t("openaiimage.name.openaiimageBot"))+" ",1),m("span",it,s(e.$dayjs.format(""+new Date(parseFloat((e.modelValue?.created_at||"").toString())*1e3))),1)]),m("div",lt,[e.referenceImages.length>0?(a(),l("div",rt,[(a(!0),l(I,null,L(e.referenceImages,(V,G)=>(a(),E(g,{key:G,url:V,name:`image-${G+1}`,closable:!1},null,8,["url","name"]))),128))])):_("",!0),e.modelValue?.request?.prompt?(a(),l("p",ct,[u(s(e.modelValue?.request?.prompt)+" ",1),e.modelValue?.response?_("",!0):(a(),l("span",mt," - ("+s(e.$t("openaiimage.status.pending"))+") ",1))])):_("",!0)]),e.modelValue?.response?.success===!0?(a(),l("div",pt,[m("div",ut,[(a(!0),l(I,null,L(e.images,(V,G)=>(a(),E($,{key:G,src:V?.image_url||V?.url||"","raw-src":V?.image_url||V?.url||""},null,8,["src","raw-src"]))),128))]),m("div",dt,[o(k,{class:"box-item",effect:"dark",content:e.$t("common.button.edit"),placement:"top-start"},{default:v(()=>[o(f,{type:"info",size:"small",class:"btn-action",onClick:t[0]||(t[0]=W(V=>e.onEdit(e.images?.[0]?.image_url||e.images?.[0]?.url),["stop"]))},{default:v(()=>[u(s(e.$t("common.button.edit")),1)]),_:1})]),_:1},8,["content"])]),o(T,{closable:!1,class:"mt-2 success"},{default:v(()=>[e.modelValue?.request?.model?(a(),l("p",gt,[o(r,{icon:"fa-solid fa-cube",class:"mr-1"}),u(" "+s(e.$t("openaiimage.name.model"))+": "+s(e.modelValue?.request?.model),1)])):_("",!0),e.modelValue?.request?.size?(a(),l("p",ft,[o(r,{icon:"fa-solid fa-image",class:"mr-1"}),u(" "+s(e.$t("openaiimage.name.size"))+": "+s(e.modelValue?.request?.size),1)])):_("",!0),e.modelValue?.request?.action?(a(),l("p",ht,[o(r,{icon:"fa-solid fa-bolt",class:"mr-1"}),u(" "+s(e.$t("openaiimage.name.task"))+": "+s(e.modelValue?.request?.action==="generate"?e.$t("openaiimage.name.generate"):e.$t("openaiimage.name.edits")),1)])):_("",!0),m("p",_t,[o(r,{icon:"fa-solid fa-magic",class:"mr-1"}),u(" "+s(e.$t("openaiimage.name.taskId"))+": "+s(e.modelValue?.id)+" ",1),o(b,{content:e.modelValue?.id,class:"btn-copy inline-block"},null,8,["content"])]),e.modelValue?.elapsed?(a(),l("p",$t,[o(r,{icon:"fa-solid fa-clock",class:"mr-1"}),u(" "+s(e.$t("openaiimage.name.elapsed"))+": "+s(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):_("",!0),e.modelValue?.response?.trace_id?(a(),l("p",vt,[o(r,{icon:"fa-solid fa-hashtag",class:"mr-1"}),u(" "+s(e.$t("openaiimage.name.traceId"))+": "+s(e.modelValue?.response?.trace_id)+" ",1),o(b,{content:e.modelValue?.response?.trace_id,class:"btn-copy inline-block"},null,8,["content"])])):_("",!0)]),_:1})])):e.modelValue?.response?.success===!1?(a(),l("div",bt,[o(T,{closable:!1,class:"failure"},{template:v(()=>[o(r,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),u(" "+s(e.$t("openaiimage.name.failure")),1)]),default:v(()=>[e.modelValue?.request?.model?(a(),l("p",kt,[o(r,{icon:"fa-solid fa-cube",class:"mr-1"}),u(" "+s(e.$t("openaiimage.name.model"))+": "+s(e.modelValue?.request?.model),1)])):_("",!0),e.modelValue?.request?.size?(a(),l("p",yt,[o(r,{icon:"fa-solid fa-image",class:"mr-1"}),u(" "+s(e.$t("openaiimage.name.size"))+": "+s(e.modelValue?.request?.size),1)])):_("",!0),e.modelValue?.request?.action?(a(),l("p",wt,[o(r,{icon:"fa-solid fa-bolt",class:"mr-1"}),u(" "+s(e.$t("openaiimage.name.task"))+": "+s(e.modelValue?.request?.action==="generate"?e.$t("openaiimage.name.generate"):e.$t("openaiimage.name.edits")),1)])):_("",!0),m("p",It,[o(r,{icon:"fa-solid fa-magic",class:"mr-1"}),u(" "+s(e.$t("openaiimage.name.taskId"))+": "+s(e.modelValue?.id)+" ",1),o(b,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])]),m("p",Et,[o(r,{icon:"fa-solid fa-circle-info",class:"mr-1"}),u(" "+s(e.$t("openaiimage.name.failureReason"))+": "+s(e.modelValue?.response?.error?.message)+" ",1),o(b,{content:e.modelValue?.response?.error?.message,class:"btn-copy"},null,8,["content"])]),e.modelValue?.elapsed?(a(),l("p",Vt,[o(r,{icon:"fa-solid fa-clock",class:"mr-1"}),u(" "+s(e.$t("openaiimage.name.elapsed"))+": "+s(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):_("",!0),e.modelValue?.response?.trace_id?(a(),l("p",At,[o(r,{icon:"fa-solid fa-hashtag",class:"mr-1"}),u(" "+s(e.$t("openaiimage.name.traceId"))+": "+s(e.modelValue?.response?.trace_id)+" ",1),o(b,{content:e.modelValue?.response?.trace_id,class:"btn-copy"},null,8,["content"])])):_("",!0)]),_:1})])):(a(),l("div",Lt,[o(T,{closable:!1,class:"info"},{template:v(()=>[o(r,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),u(" "+s(e.$t("openaiimage.name.failure")),1)]),default:v(()=>[e.modelValue?.request?.model?(a(),l("p",Tt,[o(r,{icon:"fa-solid fa-cube",class:"mr-1"}),u(" "+s(e.$t("openaiimage.name.model"))+": "+s(e.modelValue?.request?.model),1)])):_("",!0),e.modelValue?.request?.size?(a(),l("p",Gt,[o(r,{icon:"fa-solid fa-image",class:"mr-1"}),u(" "+s(e.$t("openaiimage.name.size"))+": "+s(e.modelValue?.request?.size),1)])):_("",!0),e.modelValue?.request?.action?(a(),l("p",St,[o(r,{icon:"fa-solid fa-bolt",class:"mr-1"}),u(" "+s(e.$t("openaiimage.name.task"))+": "+s(e.modelValue?.request?.action==="generate"?e.$t("openaiimage.name.generate"):e.$t("openaiimage.name.edits")),1)])):_("",!0),m("p",Pt,[o(r,{icon:"fa-solid fa-magic",class:"mr-1"}),u(" "+s(e.$t("openaiimage.name.taskId"))+": "+s(e.modelValue?.id)+" ",1),o(b,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])])]),_:1})]))])])}const Rt=w(tt,[["render",Ot],["__scopeId","data-v-87775c45"]]),qt=y({name:"RecentPanel",components:{TaskPreview:Rt,BotPlaceholder:ue,NoTasks:de,ScrollList:te},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?.()}}}),Ut={key:0},Ct={key:2,class:"w-full h-full flex items-center justify-center"};function Mt(e,t,c,i,p,h){const d=n("bot-placeholder"),g=n("task-preview"),$=n("scroll-list"),f=n("no-tasks");return a(),l(I,null,[e.tasks?.items===void 0?(a(),l("div",Ut,[o(d)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(a(),E($,{key:1,ref:"scrollList",class:"tasks h-full w-full overflow-y-auto",loading:e.loading,onReachTop:t[0]||(t[0]=k=>e.$emit("reach-top"))},{default:v(()=>[(a(!0),l(I,null,L(e.tasks?.items,k=>(a(),E(g,{key:k.id,"model-value":k},null,8,["model-value"]))),128))]),_:1},8,["loading"])):_("",!0),e.tasks?.items?.length===0?(a(),l("div",Ct,[o(f)])):_("",!0)],64)}const zt=w(qt,[["render",Mt]]),D="https://webhook.acedata.cloud/openaiimage",jt=y({name:"OpenAIImageIndex",components:{ConfigPanel:et,Layout:ve,RecentPanel:zt},inject:["initialized"],data(){return{task:void 0,job:0,loading:!1}},computed:{applicationsLoading(){return this.$store.state.openaiimage?.status?.getApplications===z.Request},tasksLoading(){return this.$store.state.openaiimage?.status?.getTasks===z.Request},credential(){return this.$store.state.openaiimage?.credential},config(){return this.$store.state.openaiimage?.config},application(){return this.$store.state.openaiimage?.application},tasks(){return this.$store.state.openaiimage?.tasks}},watch:{tasks:{handler(e,t){e?.items?.length>t?.items?.length&&console.debug("new tasks detected")},deep:!0},initialized:{async handler(e){e&&(console.debug("layout initialized"),await this.onGetTasks(),await this.onScrollDown(),this.job=window.setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){window.clearInterval(this.job)},methods:{async onReachTop(){if(console.debug("reached top"),this.loading||this.tasksLoading)return;const e=this.tasks?.total,t=this.tasks?.items?.length||0;if(e!==void 0&&e<=t)return;const c=this.tasks?.items?.[0];if(!c?.created_at)return;const p=this.$refs.recentPanel?.getScrollElement?.(),h=p?.scrollHeight||0,d=p?.scrollTop||0;this.loading=!0;try{if(await this.onGetTasks({createdAtMax:c.created_at}),await this.$nextTick(),p){const g=p.scrollHeight;p.scrollTop=g-h+d}}finally{this.loading=!1}},async onGetService(){console.debug("start onGetService"),await this.$store.dispatch("openaiimage/getService"),console.debug("end onGetService")},async onGetApplication(){console.debug("start onGetApplication"),await this.$store.dispatch("openaiimage/getApplications"),console.debug("end onGetApplication"),await this.onGetTasks()},async onScrollDown(){await this.$nextTick();const e=this.getTasksScrollElement();e&&(e.scrollTop=e.scrollHeight)},async onGetTasks(e){if(this.applicationsLoading||this.tasksLoading){console.debug("loading");return}console.debug("start onGetTasks",e);const{limit:t=20,createdAtMin:c,createdAtMax:i}=e||{};console.debug("limit",t,"createdAtMin",c,"createdAtMax",i),await this.$store.dispatch("openaiimage/getTasks",{limit:t,createdAtMin:c,createdAtMax:i})},async onGenerate(){const e={...this.config||{}},t=Array.isArray(e?.image_urls)&&e.image_urls.length>0;!t&&"image_urls"in e&&delete e.image_urls;const c={...e,action:"generate",callback_url:D},i={action:"edit",model:e?.model,prompt:e?.prompt,image_urls:e?.image_urls||[],callback_url:D},p=this.credential?.token;if(!p){console.error("no token specified");return}A.info(this.$t("openaiimage.message.startingTask")),ee("openaiimage",t?j.edit(i,{token:p}):j.generate(c,{token:p})).then(d=>{console.debug("task accepted",d.data?.task_id),A.success(this.$t("openaiimage.message.startTaskSuccess"))}).catch(d=>{const g=d?.response?.data;g?.error?.code===ie?A.error(this.$t("openaiimage.message.usedUp")):A.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?.()}}});function Dt(e,t,c,i,p,h){const d=n("config-panel"),g=n("recent-panel"),$=n("layout");return a(),E($,null,{config:v(()=>[o(d,{onGenerate:e.onGenerate},null,8,["onGenerate"])]),result:v(()=>[o(g,{ref:"recentPanel",loading:e.loading,onReachTop:e.onReachTop},null,8,["loading","onReachTop"])]),_:1})}const So=w(jt,[["render",Dt]]);export{So as default};
1
+ import{F as S}from"./index.es-DgRqc681.js";import{E as P}from"./index-BfYt3lpS.js";import{E as x}from"./index-D7TXnRb-.js";import{d as y,H as l,E as m,z as q,C as o,y as v,D as n,q as a,F as s,I as u,O as I,N as L,x as E,J as _,M as W,Q as O}from"./vendor-vue-NSDaktjZ.js";import{E as w,b8 as H,ch as Z,ci as J,cj as K,ck as Q,cl as X,cm as U,cn as C,co as M,cp as Y,cd as ee,aw as z}from"./index-BmskuvzR.js";import{I as R,S as te}from"./ScrollList-DMu-o4cw.js";import{E as oe}from"./index-C4cFnn6h.js";import{I as N}from"./ImagePreview-DGgsF-1W.js";import{E as se}from"./index-B5iae9JX.js";import{E as A}from"./index-Z6qAnijd.js";import{C as ae}from"./Consumption-DhMtSnnQ.js";import{a as ne}from"./price-BGnrujo6.js";import{E as B,a as F}from"./index-BYgw8Ne9.js";import{b as ie}from"./errorCode-Cqj9Td_Z.js";import{o as j}from"./openaiimage-AsNjvitU.js";import{C as le}from"./CopyToClipboard-DrzpK9ow.js";import{I as re}from"./ImageWrapper-D3SmhRJ2.js";import{E as ce}from"./index-X4RPhZd6.js";import{E as me}from"./index-JlXUmriI.js";import{E as pe}from"./index-BkJcEPcB.js";import{B as ue}from"./BotPlaceholder-Bxg1WSeO.js";import{N as de}from"./NoTasks-M-MqsF2Q.js";import"./use-form-item-7D-CUO4M.js";import"./index-BuyEbX8F.js";import"./vendor-axios-B8_nURbH.js";import"./vendor-dayjs-Cvgzdobq.js";import"./vendor-vue-router-Kg6s1a65.js";import"./typescript-D5w3x56R.js";import"./index-CEOn0L_0.js";import"./index-BvsGeWBq.js";import"./index-BxG3gwu6.js";import"./_baseClone-vd8PLpyA.js";import"./_Uint8Array-C3Lbt_45.js";import"./_initCloneObject-D5Z-CcL7.js";import"./isEqual-BPX3ojYz.js";import"./index-ys73P36s.js";import"./strings-beZM2Y-f.js";import"./castArray-BgN0ywwP.js";import"./debounce-CfLqwhiY.js";import"./_baseIteratee-BEktInjh.js";import"./index-BkRv-z3G.js";import"./index-Cq1B7Sqv.js";const ge=y({name:"LayoutNanobanana",components:{ElDrawer:x,ElButton:P,FontAwesomeIcon:S},data(){return{drawer:!1}}}),fe={class:"main flex flex-row flex-1"},he={class:"config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]"},_e={class:"result h-full p-6 flex-1 flex flex-col min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]"};function $e(e,t,c,i,p,h){const d=n("font-awesome-icon"),g=n("el-button"),$=n("el-drawer");return a(),l("div",fe,[m("div",he,[q(e.$slots,"config",{},void 0,!0)]),m("div",_e,[q(e.$slots,"result",{},void 0,!0)]),o(g,{circle:"",class:"menu",onClick:t[0]||(t[0]=f=>e.drawer=!0)},{default:v(()=>[o(d,{icon:"fa-solid fa-magic"})]),_:1}),o($,{modelValue:e.drawer,"onUpdate:modelValue":t[1]||(t[1]=f=>e.drawer=f),direction:"ltr","with-header":!1,size:"340px",class:"drawer"},{default:v(()=>[q(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const ve=w(ge,[["render",$e],["__scopeId","data-v-bfe5cd4b"]]),be="",ke=y({name:"PromptInput",components:{ElInput:oe,InfoIcon:R},computed:{prompt:{get(){return this.$store.state.openaiimage?.config?.prompt},set(e){console.debug("set prompt",e),this.$store.commit("openaiimage/setConfig",{...this.$store.state.openaiimage?.config,prompt:e})}}},mounted(){this.prompt||(this.prompt=be)}}),ye={class:"field"},we={class:"box"},Ie={class:"title font-bold"};function Ee(e,t,c,i,p,h){const d=n("info-icon"),g=n("el-input");return a(),l("div",ye,[m("div",we,[m("h2",Ie,s(e.$t("openaiimage.name.prompt")),1),o(d,{content:e.$t("openaiimage.description.prompt"),class:"info"},null,8,["content"])]),o(g,{modelValue:e.prompt,"onUpdate:modelValue":t[0]||(t[0]=$=>e.prompt=$),rows:3,type:"textarea",class:"prompt",placeholder:e.$t("openaiimage.placeholder.prompt")},null,8,["modelValue","placeholder"])])}const Ve=w(ke,[["render",Ee],["__scopeId","data-v-92f61e4a"]]),Ae=y({name:"ImageUrlsInput",components:{ElUpload:se,ElButton:P,InfoIcon:R,ImagePreview:N,FontAwesomeIcon:S},data(){return{fileList:[],uploadUrl:H()+"/api/v1/files/",suppressWatch:!1}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e?.response?.file_url).filter(e=>!!e)},value(){return this.$store.state.openaiimage?.config?.image_urls}},watch:{value:{immediate:!0,handler(e){if(this.suppressWatch)return;if(!e||e.length===0){const i=(this.fileList||[]).filter(p=>!p?.response?.file_url);this.fileList=i.length?i:[];return}const t=[];e.forEach(i=>{const p=this.fileList.find(h=>h?.response?.file_url===i||h?.url===i);p?t.push(p):t.push({name:i.split("/").pop()||i,url:i,status:"success",percentage:100,response:{file_url:i}})}),(this.fileList||[]).filter(i=>!i?.response?.file_url).forEach(i=>{t.some(h=>h===i||h?.url===i?.url||h?.response?.file_url===i?.response?.file_url)||t.push(i)}),this.fileList=t}}},mounted(){},methods:{onChange(e){if(!e?.url&&e?.raw)try{e.url=URL.createObjectURL(e.raw)}catch{}},onRemove(e){if(e?.url&&typeof e.url=="string"&&e.url.startsWith("blob:"))try{URL.revokeObjectURL(e.url)}catch{}this.onSetImageUrls()},onExceed(){A.warning(this.$t("openaiimage.message.uploadImageExceed"))},onError(){A.error(this.$t("openaiimage.message.uploadImageError"))},onSetImageUrls(){const e=this.urls;this.suppressWatch=!0,this.$store.commit("openaiimage/setConfig",{...this.$store.state.openaiimage?.config,image_urls:e}),this.$nextTick(()=>{this.suppressWatch=!1})},async onSuccess(e,t){e?.file_url&&(t.url=e.file_url,t.response=e),this.onSetImageUrls()},onRemovePreview(e,t){if(this.fileList.splice(e,1),t?.url&&typeof t.url=="string"&&t.url.startsWith("blob:"))try{URL.revokeObjectURL(t.url)}catch{}this.onSetImageUrls()}}}),Le={class:"field flex items-center justify-between"},Te={class:"title font-bold text-[14px] mb-[10px]"},Ge={class:"upload-wrapper flex flex-col items-start gap-[8px]"},Se={class:"controls flex items-center"},Pe={class:"file-list flex flex-wrap gap-[10px]"};function Oe(e,t,c,i,p,h){const d=n("font-awesome-icon"),g=n("el-button"),$=n("el-upload"),f=n("info-icon"),k=n("image-preview");return a(),l(I,null,[m("div",Le,[m("h2",Te,s(e.$t("openaiimage.name.imageUrls")),1),m("div",Ge,[m("div",Se,[o($,{"file-list":e.fileList,"onUpdate:fileList":t[0]||(t[0]=r=>e.fileList=r),accept:".png,.jpg,.jpeg,.gif,.bmp,.webp",name:"file",class:"value",limit:5,multiple:!0,"show-file-list":!1,action:e.uploadUrl,"on-exceed":e.onExceed,"on-error":e.onError,"on-success":e.onSuccess,"on-change":e.onChange,"on-remove":e.onRemove,headers:e.headers},{default:v(()=>[o(g,{size:"small",type:"primary",round:""},{default:v(()=>[o(d,{icon:"fa-solid fa-upload",class:"mr-1"}),u(" "+s(e.$t("openaiimage.button.uploadImageUrls")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-success","on-change","on-remove","headers"]),o(f,{content:e.$t("openaiimage.description.imageUrls"),class:"ml-2"},null,8,["content"])])])]),m("div",Pe,[(a(!0),l(I,null,L(e.fileList,(r,b)=>(a(),E(k,{key:r.uid||r?.response?.file_url||r.url||b,url:r.url||r?.response?.file_url,name:r.name,percentage:r.percentage,onRemove:T=>e.onRemovePreview(b,r)},null,8,["url","name","percentage","onRemove"]))),128))])],64)}const Re=w(Ae,[["render",Oe]]),qe=y({name:"OpenAIImageModelSelector",components:{ElSelect:F,ElOption:B,InfoIcon:R},data(){return{options:[{value:J,label:this.$t("openaiimage.model.gptImage1")},{value:K,label:this.$t("openaiimage.model.gptImage15")},{value:Q,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=Z)}}),Ue={class:"field"},Ce={class:"label"},Me={class:"box"},ze={class:"title font-bold"};function je(e,t,c,i,p,h){const d=n("info-icon"),g=n("el-option"),$=n("el-select");return a(),l("div",Ue,[m("div",Ce,[m("div",Me,[m("h2",ze,s(e.$t("openaiimage.name.model")),1),o(d,{content:e.modelDescription,class:"info"},null,8,["content"])])]),o($,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=f=>e.value=f),class:"value",placeholder:e.$t("openaiimage.placeholder.select")},{default:v(()=>[(a(!0),l(I,null,L(e.options,f=>(a(),E(g,{key:f.value,label:f.label,value:f.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const De=w(qe,[["render",je],["__scopeId","data-v-cec771bd"]]),Ne=y({name:"OpenAIImageSizeSelector",components:{ElSelect:F,ElOption:B,InfoIcon:R},data(){return{options:[{value:U,label:U},{value:C,label:C},{value:M,label:M}]}},computed:{value:{get(){return this.$store.state.openaiimage?.config?.size},set(e){this.$store.commit("openaiimage/setConfig",{...this.$store.state.openaiimage?.config,size:e})}}},mounted(){this.value||(this.value=X)}}),Be={class:"field"},Fe={class:"label"},xe={class:"box"},We={class:"title font-bold"};function He(e,t,c,i,p,h){const d=n("info-icon"),g=n("el-option"),$=n("el-select");return a(),l("div",Be,[m("div",Fe,[m("div",xe,[m("h2",We,s(e.$t("openaiimage.name.size")),1),o(d,{content:e.$t("openaiimage.description.size"),class:"info"},null,8,["content"])])]),o($,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=f=>e.value=f),class:"value",placeholder:e.$t("openaiimage.placeholder.select")},{default:v(()=>[(a(!0),l(I,null,L(e.options,f=>(a(),E(g,{key:f.value,label:f.label,value:f.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Ze=w(Ne,[["render",He],["__scopeId","data-v-11116785"]]),Je=y({name:"ConfigPanel",components:{ElButton:P,FontAwesomeIcon:S,PromptInput:Ve,Consumption:ae,ImageUrlsInput:Re,ModelSelector:De,ResolutionSelector:Ze},emits:["generate"],computed:{config(){return this.$store.state.openaiimage?.config},consumption(){const e={...this.config||{}};return ne({...e},this.service?.cost)},service(){return this.$store.state.openaiimage?.service}},methods:{onGenerate(){this.$emit("generate")}}}),Ke={class:"flex flex-col h-full"},Qe={class:"flex-1 overflow-y-auto p-5"},Xe={class:"flex flex-col items-center justify-center px-5 pb-5"};function Ye(e,t,c,i,p,h){const d=n("model-selector"),g=n("resolution-selector"),$=n("prompt-input"),f=n("image-urls-input"),k=n("consumption"),r=n("font-awesome-icon"),b=n("el-button");return a(),l("div",Ke,[m("div",Qe,[o(d,{class:"mb-4"}),o(g,{class:"mb-4"}),o($,{class:"mb-4"}),o(f,{class:"mb-4"})]),m("div",Xe,[o(k,{value:e.consumption,service:e.service},null,8,["value","service"]),o(b,{type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:v(()=>[o(r,{icon:"fa-solid fa-magic",class:"mr-2"}),u(" "+s(e.$t("openaiimage.button.generate")),1)]),_:1},8,["onClick"])])])}const et=w(Je,[["render",Ye]]),tt=y({name:"TaskPreview",components:{ElImage:pe,CopyToClipboard:le,FontAwesomeIcon:S,ElAlert:me,ImageWrapper:re,ElButton:P,ElTooltip:ce,ImagePreview:N},props:{modelValue:{type:Object,required:!0}},setup(){return{OPENAIIMAGE_LOGO:Y}},computed:{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(i=>typeof i=="string"&&i.length>0);const c=e.image;return Array.isArray(c)?c.filter(i=>typeof i=="string"&&i.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)}}}),ot={class:"preview"},st={class:"left"},at={class:"main"},nt={class:"bot"},it={class:"datetime"},lt={class:"info"},rt={key:0,class:"flex justify-start items-center gap-2 mt-2 w-full overflow-x-auto"},ct={key:1,class:"prompt mt-2"},mt={key:0},pt={key:0,class:O({content:!0,failed:!0})},ut={class:"flex justify-start items-center gap-4 w-full overflow-x-auto"},dt={class:O({operations:!0,"mt-2":!0,"mb-2":!0})},gt={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},ft={key:1,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},ht={key:2,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},_t={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},$t={key:3,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},vt={key:4,class:"text-[var(--el-text-color-regular)] text-xs mb-0"},bt={key:1,class:O({content:!0})},kt={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},yt={key:1,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},wt={key:2,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},It={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Et={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Vt={key:3,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},At={key:4,class:"text-[var(--el-text-color-regular)] text-xs mb-0"},Lt={key:2,class:O({content:!0})},Tt={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"},St={key:2,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Pt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"};function Ot(e,t,c,i,p,h){const d=n("el-image"),g=n("image-preview"),$=n("image-wrapper"),f=n("el-button"),k=n("el-tooltip"),r=n("font-awesome-icon"),b=n("copy-to-clipboard"),T=n("el-alert");return a(),l("div",ot,[m("div",st,[o(d,{src:e.OPENAIIMAGE_LOGO,class:"avatar"},null,8,["src"])]),m("div",at,[m("div",nt,[u(s(e.$t("openaiimage.name.openaiimageBot"))+" ",1),m("span",it,s(e.$dayjs.format(""+new Date(parseFloat((e.modelValue?.created_at||"").toString())*1e3))),1)]),m("div",lt,[e.referenceImages.length>0?(a(),l("div",rt,[(a(!0),l(I,null,L(e.referenceImages,(V,G)=>(a(),E(g,{key:G,url:V,name:`image-${G+1}`,closable:!1},null,8,["url","name"]))),128))])):_("",!0),e.modelValue?.request?.prompt?(a(),l("p",ct,[u(s(e.modelValue?.request?.prompt)+" ",1),e.modelValue?.response?_("",!0):(a(),l("span",mt," - ("+s(e.$t("openaiimage.status.pending"))+") ",1))])):_("",!0)]),e.modelValue?.response?.success===!0?(a(),l("div",pt,[m("div",ut,[(a(!0),l(I,null,L(e.images,(V,G)=>(a(),E($,{key:G,src:V?.image_url||V?.url||"","raw-src":V?.image_url||V?.url||""},null,8,["src","raw-src"]))),128))]),m("div",dt,[o(k,{class:"box-item",effect:"dark",content:e.$t("common.button.edit"),placement:"top-start"},{default:v(()=>[o(f,{type:"info",size:"small",class:"btn-action",onClick:t[0]||(t[0]=W(V=>e.onEdit(e.images?.[0]?.image_url||e.images?.[0]?.url),["stop"]))},{default:v(()=>[u(s(e.$t("common.button.edit")),1)]),_:1})]),_:1},8,["content"])]),o(T,{closable:!1,class:"mt-2 success"},{default:v(()=>[e.modelValue?.request?.model?(a(),l("p",gt,[o(r,{icon:"fa-solid fa-cube",class:"mr-1"}),u(" "+s(e.$t("openaiimage.name.model"))+": "+s(e.modelValue?.request?.model),1)])):_("",!0),e.modelValue?.request?.size?(a(),l("p",ft,[o(r,{icon:"fa-solid fa-image",class:"mr-1"}),u(" "+s(e.$t("openaiimage.name.size"))+": "+s(e.modelValue?.request?.size),1)])):_("",!0),e.modelValue?.request?.action?(a(),l("p",ht,[o(r,{icon:"fa-solid fa-bolt",class:"mr-1"}),u(" "+s(e.$t("openaiimage.name.task"))+": "+s(e.modelValue?.request?.action==="generate"?e.$t("openaiimage.name.generate"):e.$t("openaiimage.name.edits")),1)])):_("",!0),m("p",_t,[o(r,{icon:"fa-solid fa-magic",class:"mr-1"}),u(" "+s(e.$t("openaiimage.name.taskId"))+": "+s(e.modelValue?.id)+" ",1),o(b,{content:e.modelValue?.id,class:"btn-copy inline-block"},null,8,["content"])]),e.modelValue?.elapsed?(a(),l("p",$t,[o(r,{icon:"fa-solid fa-clock",class:"mr-1"}),u(" "+s(e.$t("openaiimage.name.elapsed"))+": "+s(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):_("",!0),e.modelValue?.response?.trace_id?(a(),l("p",vt,[o(r,{icon:"fa-solid fa-hashtag",class:"mr-1"}),u(" "+s(e.$t("openaiimage.name.traceId"))+": "+s(e.modelValue?.response?.trace_id)+" ",1),o(b,{content:e.modelValue?.response?.trace_id,class:"btn-copy inline-block"},null,8,["content"])])):_("",!0)]),_:1})])):e.modelValue?.response?.success===!1?(a(),l("div",bt,[o(T,{closable:!1,class:"failure"},{template:v(()=>[o(r,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),u(" "+s(e.$t("openaiimage.name.failure")),1)]),default:v(()=>[e.modelValue?.request?.model?(a(),l("p",kt,[o(r,{icon:"fa-solid fa-cube",class:"mr-1"}),u(" "+s(e.$t("openaiimage.name.model"))+": "+s(e.modelValue?.request?.model),1)])):_("",!0),e.modelValue?.request?.size?(a(),l("p",yt,[o(r,{icon:"fa-solid fa-image",class:"mr-1"}),u(" "+s(e.$t("openaiimage.name.size"))+": "+s(e.modelValue?.request?.size),1)])):_("",!0),e.modelValue?.request?.action?(a(),l("p",wt,[o(r,{icon:"fa-solid fa-bolt",class:"mr-1"}),u(" "+s(e.$t("openaiimage.name.task"))+": "+s(e.modelValue?.request?.action==="generate"?e.$t("openaiimage.name.generate"):e.$t("openaiimage.name.edits")),1)])):_("",!0),m("p",It,[o(r,{icon:"fa-solid fa-magic",class:"mr-1"}),u(" "+s(e.$t("openaiimage.name.taskId"))+": "+s(e.modelValue?.id)+" ",1),o(b,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])]),m("p",Et,[o(r,{icon:"fa-solid fa-circle-info",class:"mr-1"}),u(" "+s(e.$t("openaiimage.name.failureReason"))+": "+s(e.modelValue?.response?.error?.message)+" ",1),o(b,{content:e.modelValue?.response?.error?.message,class:"btn-copy"},null,8,["content"])]),e.modelValue?.elapsed?(a(),l("p",Vt,[o(r,{icon:"fa-solid fa-clock",class:"mr-1"}),u(" "+s(e.$t("openaiimage.name.elapsed"))+": "+s(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):_("",!0),e.modelValue?.response?.trace_id?(a(),l("p",At,[o(r,{icon:"fa-solid fa-hashtag",class:"mr-1"}),u(" "+s(e.$t("openaiimage.name.traceId"))+": "+s(e.modelValue?.response?.trace_id)+" ",1),o(b,{content:e.modelValue?.response?.trace_id,class:"btn-copy"},null,8,["content"])])):_("",!0)]),_:1})])):(a(),l("div",Lt,[o(T,{closable:!1,class:"info"},{template:v(()=>[o(r,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),u(" "+s(e.$t("openaiimage.name.failure")),1)]),default:v(()=>[e.modelValue?.request?.model?(a(),l("p",Tt,[o(r,{icon:"fa-solid fa-cube",class:"mr-1"}),u(" "+s(e.$t("openaiimage.name.model"))+": "+s(e.modelValue?.request?.model),1)])):_("",!0),e.modelValue?.request?.size?(a(),l("p",Gt,[o(r,{icon:"fa-solid fa-image",class:"mr-1"}),u(" "+s(e.$t("openaiimage.name.size"))+": "+s(e.modelValue?.request?.size),1)])):_("",!0),e.modelValue?.request?.action?(a(),l("p",St,[o(r,{icon:"fa-solid fa-bolt",class:"mr-1"}),u(" "+s(e.$t("openaiimage.name.task"))+": "+s(e.modelValue?.request?.action==="generate"?e.$t("openaiimage.name.generate"):e.$t("openaiimage.name.edits")),1)])):_("",!0),m("p",Pt,[o(r,{icon:"fa-solid fa-magic",class:"mr-1"}),u(" "+s(e.$t("openaiimage.name.taskId"))+": "+s(e.modelValue?.id)+" ",1),o(b,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])])]),_:1})]))])])}const Rt=w(tt,[["render",Ot],["__scopeId","data-v-87775c45"]]),qt=y({name:"RecentPanel",components:{TaskPreview:Rt,BotPlaceholder:ue,NoTasks:de,ScrollList:te},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?.()}}}),Ut={key:0},Ct={key:2,class:"w-full h-full flex items-center justify-center"};function Mt(e,t,c,i,p,h){const d=n("bot-placeholder"),g=n("task-preview"),$=n("scroll-list"),f=n("no-tasks");return a(),l(I,null,[e.tasks?.items===void 0?(a(),l("div",Ut,[o(d)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(a(),E($,{key:1,ref:"scrollList",class:"tasks h-full w-full overflow-y-auto",loading:e.loading,onReachTop:t[0]||(t[0]=k=>e.$emit("reach-top"))},{default:v(()=>[(a(!0),l(I,null,L(e.tasks?.items,k=>(a(),E(g,{key:k.id,"model-value":k},null,8,["model-value"]))),128))]),_:1},8,["loading"])):_("",!0),e.tasks?.items?.length===0?(a(),l("div",Ct,[o(f)])):_("",!0)],64)}const zt=w(qt,[["render",Mt]]),D="https://webhook.acedata.cloud/openaiimage",jt=y({name:"OpenAIImageIndex",components:{ConfigPanel:et,Layout:ve,RecentPanel:zt},inject:["initialized"],data(){return{task:void 0,job:0,loading:!1}},computed:{applicationsLoading(){return this.$store.state.openaiimage?.status?.getApplications===z.Request},tasksLoading(){return this.$store.state.openaiimage?.status?.getTasks===z.Request},credential(){return this.$store.state.openaiimage?.credential},config(){return this.$store.state.openaiimage?.config},application(){return this.$store.state.openaiimage?.application},tasks(){return this.$store.state.openaiimage?.tasks}},watch:{tasks:{handler(e,t){e?.items?.length>t?.items?.length&&console.debug("new tasks detected")},deep:!0},initialized:{async handler(e){e&&(console.debug("layout initialized"),await this.onGetTasks(),await this.onScrollDown(),this.job=window.setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){window.clearInterval(this.job)},methods:{async onReachTop(){if(console.debug("reached top"),this.loading||this.tasksLoading)return;const e=this.tasks?.total,t=this.tasks?.items?.length||0;if(e!==void 0&&e<=t)return;const c=this.tasks?.items?.[0];if(!c?.created_at)return;const p=this.$refs.recentPanel?.getScrollElement?.(),h=p?.scrollHeight||0,d=p?.scrollTop||0;this.loading=!0;try{if(await this.onGetTasks({createdAtMax:c.created_at}),await this.$nextTick(),p){const g=p.scrollHeight;p.scrollTop=g-h+d}}finally{this.loading=!1}},async onGetService(){console.debug("start onGetService"),await this.$store.dispatch("openaiimage/getService"),console.debug("end onGetService")},async onGetApplication(){console.debug("start onGetApplication"),await this.$store.dispatch("openaiimage/getApplications"),console.debug("end onGetApplication"),await this.onGetTasks()},async onScrollDown(){await this.$nextTick();const e=this.getTasksScrollElement();e&&(e.scrollTop=e.scrollHeight)},async onGetTasks(e){if(this.applicationsLoading||this.tasksLoading){console.debug("loading");return}console.debug("start onGetTasks",e);const{limit:t=20,createdAtMin:c,createdAtMax:i}=e||{};console.debug("limit",t,"createdAtMin",c,"createdAtMax",i),await this.$store.dispatch("openaiimage/getTasks",{limit:t,createdAtMin:c,createdAtMax:i})},async onGenerate(){const e={...this.config||{}},t=Array.isArray(e?.image_urls)&&e.image_urls.length>0;!t&&"image_urls"in e&&delete e.image_urls;const c={...e,action:"generate",callback_url:D},i={action:"edit",model:e?.model,prompt:e?.prompt,image_urls:e?.image_urls||[],callback_url:D},p=this.credential?.token;if(!p){console.error("no token specified");return}A.info(this.$t("openaiimage.message.startingTask")),ee("openaiimage",t?j.edit(i,{token:p}):j.generate(c,{token:p})).then(d=>{console.debug("task accepted",d.data?.task_id),A.success(this.$t("openaiimage.message.startTaskSuccess"))}).catch(d=>{const g=d?.response?.data;g?.error?.code===ie?A.error(this.$t("openaiimage.message.usedUp")):A.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?.()}}});function Dt(e,t,c,i,p,h){const d=n("config-panel"),g=n("recent-panel"),$=n("layout");return a(),E($,null,{config:v(()=>[o(d,{onGenerate:e.onGenerate},null,8,["onGenerate"])]),result:v(()=>[o(g,{ref:"recentPanel",loading:e.loading,onReachTop:e.onReachTop},null,8,["loading","onReachTop"])]),_:1})}const So=w(jt,[["render",Dt]]);export{So as default};