@acedatacloud/nexior 3.219.0 → 3.220.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 (230) hide show
  1. package/dist/assets/ApiCodeButton-B7U80J_X.css +1 -0
  2. package/dist/assets/{ApiCodeButton-ELLwtd41.js → ApiCodeButton-DdERRoj0.js} +1 -1
  3. package/dist/assets/{Auth-trEm5Zoj.js → Auth-BJd1rSsg.js} +1 -1
  4. package/dist/assets/{BotPlaceholder-BZ2BnCU8.js → BotPlaceholder-CMs0qZF7.js} +1 -1
  5. package/dist/assets/{Callback-g5M9GNIM.js → Callback-Dzomuvo8.js} +1 -1
  6. package/dist/assets/{Console-DevJUUSE.js → Console-B2KWFwa8.js} +1 -1
  7. package/dist/assets/{Consumption-HJqRoAYb.js → Consumption-BgQfeJho.js} +1 -1
  8. package/dist/assets/{Conversation-BKNPBujI.js → Conversation-C7gLvGYl.js} +1 -1
  9. package/dist/assets/{CopyToClipboard-B7-zpemN.js → CopyToClipboard-B3FBgh3x.js} +1 -1
  10. package/dist/assets/{Detail-C-Sxz9ns.js → Detail-JAWH2XZ9.js} +2 -2
  11. package/dist/assets/{Extra-BouaFakN.js → Extra-DmR1K9LZ.js} +1 -1
  12. package/dist/assets/{FilePreview-CRYdatUV.js → FilePreview-C6KMFmBi.js} +1 -1
  13. package/dist/assets/{Hailuo-BN7mwjAM.js → Hailuo-DKTim3hG.js} +1 -1
  14. package/dist/assets/{History-DD185nDy.js → History-C2xs-mhS.js} +1 -1
  15. package/dist/assets/{ImagePreview-DjnXpfFp.js → ImagePreview-CYYwR4zK.js} +1 -1
  16. package/dist/assets/{ImageWrapper-DTLK2LYV.js → ImageWrapper-D9p7vy0W.js} +1 -1
  17. package/dist/assets/{Index-a9zXx5q7.js → Index-B1QQwbRw.js} +1 -1
  18. package/dist/assets/{Index-C2C92VaJ.js → Index-B3DzYkpS.js} +1 -1
  19. package/dist/assets/{Index-CSQ8tA42.js → Index-BHwUw9Br.js} +1 -1
  20. package/dist/assets/{Index-DuKKsWcd.js → Index-BQHNMNDb.js} +1 -1
  21. package/dist/assets/{Index-BD6yjv7T.js → Index-BcGsvHsN.js} +1 -1
  22. package/dist/assets/{Index--Oo1kWOH.js → Index-Bey6rNRd.js} +1 -1
  23. package/dist/assets/{Index-CCqjlmXQ.js → Index-BhN8OcJH.js} +1 -1
  24. package/dist/assets/{Index-BuG_uY1E.js → Index-C02uk1N1.js} +1 -1
  25. package/dist/assets/{Index-CVYC4CDZ.js → Index-C1VzAZF_.js} +1 -1
  26. package/dist/assets/{Index-zbdWLpte.js → Index-C4hDoXPR.js} +1 -1
  27. package/dist/assets/{Index-BZ3PuJ8c.js → Index-C6xAHYHk.js} +1 -1
  28. package/dist/assets/{Index-lAHeKesS.js → Index-CHhFlhF5.js} +1 -1
  29. package/dist/assets/{Index-B3RqRsof.js → Index-CIn2CzVu.js} +1 -1
  30. package/dist/assets/{Index-D7gipS_U.js → Index-CM1FOamJ.js} +1 -1
  31. package/dist/assets/{Index-Dd6CRQ9F.js → Index-CPo5pIYF.js} +1 -1
  32. package/dist/assets/{Index-JkPsC8_D.js → Index-CdOcEqrx.js} +1 -1
  33. package/dist/assets/{Index-BTVglFzn.js → Index-CmYdRyZ-.js} +1 -1
  34. package/dist/assets/{Index-BJc9OpRi.js → Index-D00557ih.js} +1 -1
  35. package/dist/assets/{Index-COHcv13M.js → Index-D_dopSe4.js} +1 -1
  36. package/dist/assets/{Index-Cijsy52x.js → Index-DbpM7BrT.js} +1 -1
  37. package/dist/assets/{Index-Brm3vW78.js → Index-Dj277d_k.js} +1 -1
  38. package/dist/assets/{Index-BK_NmVPG.js → Index-DrzVW2wu.js} +1 -1
  39. package/dist/assets/{Index-DnfCljUJ.js → Index-Dz50z1gP.js} +1 -1
  40. package/dist/assets/{Index-DgItb9Tx.js → Index-YqpvRteV.js} +1 -1
  41. package/dist/assets/{Invitees-LlMaqybz.js → Invitees-DTht-4p7.js} +1 -1
  42. package/dist/assets/{List-CoJUNkiN.js → List-BPs1tTdL.js} +1 -1
  43. package/dist/assets/{List-DSRBYjs6.js → List-Br7iW5Vc.js} +1 -1
  44. package/dist/assets/{List-L4iG7egz.js → List-Dm5feANQ.js} +1 -1
  45. package/dist/assets/{Main-Bxb8Vtxm.js → Main-B0OgmDWf.js} +1 -1
  46. package/dist/assets/{Navigator-DWoKG7z5.js → Navigator-zHYmmGqA.js} +1 -1
  47. package/dist/assets/{NoTasks-B9brz0GL.js → NoTasks-d_8CfjZ-.js} +1 -1
  48. package/dist/assets/{NotFound-uUezcRdH.js → NotFound-cTfCurfy.js} +1 -1
  49. package/dist/assets/{Pagination-CvZ8cGSz.js → Pagination-DV1doTgi.js} +1 -1
  50. package/dist/assets/{Player.vue_vue_type_script_setup_true_lang-BeDKAkXQ.js → Player.vue_vue_type_script_setup_true_lang-DpHj4ZkA.js} +1 -1
  51. package/dist/assets/{Status-D2UxKz89.js → Status-BYLfAQe1.js} +1 -1
  52. package/dist/assets/{Subscribe-NrfA0d0T.js → Subscribe-Dxhd12St.js} +1 -1
  53. package/dist/assets/{Tts-6eg-V-K6.js → Tts-DiuASxEn.js} +1 -1
  54. package/dist/assets/{VideoPlayer-Be9rMTt8.js → VideoPlayer-BwloPwzx.js} +1 -1
  55. package/dist/assets/{_Uint8Array-Z75Sa3E8.js → _Uint8Array-BHztG1Lf.js} +1 -1
  56. package/dist/assets/{_baseClone-umQ6kPjt.js → _baseClone-DBPrtxYY.js} +1 -1
  57. package/dist/assets/{_baseIteratee-BL_LXYAx.js → _baseIteratee-DawPdq6H.js} +1 -1
  58. package/dist/assets/{_initCloneObject-CCK9Xyv4.js → _initCloneObject-RQtwP1G5.js} +1 -1
  59. package/dist/assets/{add-ByYD8bnm.js → add-gm7meNsz.js} +1 -1
  60. package/dist/assets/{all-wallets-D1TR-KLQ.js → all-wallets-CwkEyvGl.js} +1 -1
  61. package/dist/assets/{app-store-BSRMcZud.js → app-store-Bjd3blij.js} +1 -1
  62. package/dist/assets/{apple-X9_neDTd.js → apple-DU5PAH0e.js} +1 -1
  63. package/dist/assets/{arrow-bottom-CLH3u_Zg.js → arrow-bottom-BeB6Eowb.js} +1 -1
  64. package/dist/assets/{arrow-bottom-circle-BVAQ0ZYy.js → arrow-bottom-circle-DR-S_2BQ.js} +1 -1
  65. package/dist/assets/{arrow-left-CkK33_vY.js → arrow-left-MWUp6VIb.js} +1 -1
  66. package/dist/assets/{arrow-right-a9XvBhC-.js → arrow-right-qwzktYqm.js} +1 -1
  67. package/dist/assets/{arrow-top-BgCu8ABB.js → arrow-top-4tQI76OZ.js} +1 -1
  68. package/dist/assets/{avatar-SQgYfR-v.js → avatar-CvZ01KOx.js} +1 -1
  69. package/dist/assets/{bank-DxaEpJmr.js → bank-Bd8UgbfX.js} +1 -1
  70. package/dist/assets/{basic-DBb6Ub-j.js → basic-CH4gFOSh.js} +1 -1
  71. package/dist/assets/{browser-i5a9UY0a.js → browser-BT62Pti3.js} +1 -1
  72. package/dist/assets/{byokCredential-CplWPXCN.js → byokCredential-Dl2EOLqj.js} +1 -1
  73. package/dist/assets/{card-CsW2s4CI.js → card-DCTOPEOi.js} +1 -1
  74. package/dist/assets/{castArray-BOBSHmEl.js → castArray-CEKtna1X.js} +1 -1
  75. package/dist/assets/{chat-xl1qJWJT.js → chat-BEXqp_vI.js} +1 -1
  76. package/dist/assets/{checkmark-CY--hMQB.js → checkmark-ZotAD7qS.js} +1 -1
  77. package/dist/assets/{checkmark-bold-BXodqOTt.js → checkmark-bold-Y_3_YeQd.js} +1 -1
  78. package/dist/assets/{chevron-bottom-C7L10PH2.js → chevron-bottom-D9h3CQH4.js} +1 -1
  79. package/dist/assets/{chevron-left-D1CM3DJA.js → chevron-left-C7bUEC6D.js} +1 -1
  80. package/dist/assets/{chevron-right-3mvmy0sO.js → chevron-right-C7jDGbDi.js} +1 -1
  81. package/dist/assets/{chevron-top-BPF1cN3K.js → chevron-top-Dwdkwh4m.js} +1 -1
  82. package/dist/assets/{chrome-store-BtTWobgj.js → chrome-store-C2-4VJeH.js} +1 -1
  83. package/dist/assets/{clock-Db60RkQF.js → clock-7-qd4DY4.js} +1 -1
  84. package/dist/assets/{close-BzDqu-S3.js → close-CZ5nk0uO.js} +1 -1
  85. package/dist/assets/{coinPlaceholder-BkkOIav-.js → coinPlaceholder-BEFST07b.js} +1 -1
  86. package/dist/assets/{compass-rvBTmAxh.js → compass-BRNknpHl.js} +1 -1
  87. package/dist/assets/{copy-C8QKMhBD.js → copy-BgMiLEu2.js} +1 -1
  88. package/dist/assets/{createTaskActions-Ch5xga-f.js → createTaskActions-D3r1bCNh.js} +1 -1
  89. package/dist/assets/{cursor-ChT_SLON.js → cursor-CrBmCVZE.js} +1 -1
  90. package/dist/assets/{cursor-transparent-B6xaFBuS.js → cursor-transparent-DNjfiNb8.js} +1 -1
  91. package/dist/assets/{debounce-B-6yjswC.js → debounce-BzdywqWi.js} +1 -1
  92. package/dist/assets/{desktop-BtWEa6qH.js → desktop-BFT26rWT.js} +1 -1
  93. package/dist/assets/{disconnect-THH2iHmo.js → disconnect-BTxfeV_B.js} +1 -1
  94. package/dist/assets/{discord-DE1V_6fw.js → discord-BcB7XJ9T.js} +1 -1
  95. package/dist/assets/{distribution-D9Uosg17.js → distribution-D9L2VvU8.js} +1 -1
  96. package/dist/assets/{dropdown-97VRadx2.js → dropdown-CqVkry2k.js} +1 -1
  97. package/dist/assets/{etherscan-BiZrUJvY.js → etherscan-BL1G-Ktx.js} +1 -1
  98. package/dist/assets/{exclamation-triangle-DNHDfuZp.js → exclamation-triangle-Bi97HCgh.js} +1 -1
  99. package/dist/assets/{extension-Dpiqi3mK.js → extension-BxZXCJF1.js} +1 -1
  100. package/dist/assets/{external-link-CEsB41FR.js → external-link-8IiT5KI-.js} +1 -1
  101. package/dist/assets/{facebook-DyijMDQZ.js → facebook-BBXf4bv2.js} +1 -1
  102. package/dist/assets/{farcaster-B8JN6xIp.js → farcaster-BoXXgHyq.js} +1 -1
  103. package/dist/assets/{filters-DAcCbx0j.js → filters-DC8IKfi7.js} +1 -1
  104. package/dist/assets/{github-DJD_wXrA.js → github-CBf_njI8.js} +1 -1
  105. package/dist/assets/{google-Dd-_nqnP.js → google-DtjQp-Zf.js} +1 -1
  106. package/dist/assets/{help-circle-CQ5ZTgLL.js → help-circle-BA4vSPii.js} +1 -1
  107. package/dist/assets/{highlight-CxiUjIMX.js → highlight-D6Rf8-7-.js} +1 -1
  108. package/dist/assets/{id-C2waPdTg.js → id-CL8aw1w3.js} +1 -1
  109. package/dist/assets/{image-ObIpa0Qo.js → image-BTIVNhXO.js} +1 -1
  110. package/dist/assets/{index-COfTdmqq.js → index-9TnzSqSo.js} +1 -1
  111. package/dist/assets/{index-BybZK4kT.js → index-B5i9I9D0.js} +1 -1
  112. package/dist/assets/{index-DdbWvBNx.js → index-B8CSiOhn.js} +1 -1
  113. package/dist/assets/{index-BeBZA1p_.js → index-BG-KAGL3.js} +1 -1
  114. package/dist/assets/{index-D9kue-NB.js → index-BKiiWvXY.js} +1 -1
  115. package/dist/assets/{index-C-rnAsAl.js → index-BM28BQge.js} +1 -1
  116. package/dist/assets/{index-D0zoWl0t.js → index-BRfbHCvZ.js} +3 -3
  117. package/dist/assets/{index-Dm8WLAYA.js → index-BSKrtLfD.js} +1 -1
  118. package/dist/assets/{index-B4uEviPn.js → index-BYNyqWl4.js} +1 -1
  119. package/dist/assets/{index-93S-kjnW.js → index-BYrMMM1u.js} +1 -1
  120. package/dist/assets/{index-d6anveG0.js → index-BZkaFFuw.js} +1 -1
  121. package/dist/assets/{index-DmrLER-A.js → index-Bav7i68F.js} +1 -1
  122. package/dist/assets/{index-D8-5HTYV.js → index-BcIct0a2.js} +1 -1
  123. package/dist/assets/{index-DXCDKEv1.js → index-BckDmkd_.js} +1 -1
  124. package/dist/assets/{index-CmIsgGU2.js → index-BitIttnu.js} +1 -1
  125. package/dist/assets/{index-Bo14Ux3S.js → index-BnLROHuz.js} +1 -1
  126. package/dist/assets/{index-DRNfoZ1e.js → index-BnfMUAmr.js} +1 -1
  127. package/dist/assets/{index-X6wgkPd2.js → index-BtOQSaPZ.js} +1 -1
  128. package/dist/assets/{index-HyuSkpOc.js → index-ByRYubXn.js} +1 -1
  129. package/dist/assets/{index-DvwzAY2E.js → index-C-1t2sdo.js} +1 -1
  130. package/dist/assets/{index-BfcjcrkJ.js → index-C8L4L2UR.js} +1 -1
  131. package/dist/assets/{index-BK9xwgg3.js → index-C9PmnSwM.js} +1 -1
  132. package/dist/assets/{index-B-XPrVnp.js → index-CBKsfw4L.js} +1 -1
  133. package/dist/assets/{index-BgdH8W9S.js → index-CCD14HB5.js} +1 -1
  134. package/dist/assets/{index-BTcVnXUS.js → index-CJozFb-_.js} +1 -1
  135. package/dist/assets/{index-Kdmse2kS.js → index-CNtDq5Ox.js} +1 -1
  136. package/dist/assets/{index-Cq8TQPr3.js → index-CVuadntg.js} +1 -1
  137. package/dist/assets/{index-DhgEdWde.js → index-Cf4MWvor.js} +1 -1
  138. package/dist/assets/{index-DT1QCKyq.js → index-CiUV6rQ6.js} +1 -1
  139. package/dist/assets/{index-BgMRyztR.js → index-Cit52WsR.js} +3 -3
  140. package/dist/assets/{index-w92xJb9j.js → index-CnsbSkfL.js} +1 -1
  141. package/dist/assets/{index-DTS9X2Mx.js → index-D0K3XkBZ.js} +5 -5
  142. package/dist/assets/{index-BXXvYpXX.js → index-D63t9suS.js} +1 -1
  143. package/dist/assets/{index-DA0BpBj_.js → index-D6w9vM3v.js} +2 -2
  144. package/dist/assets/{index-CwEpfXg0.js → index-D7Dtp2wz.js} +1 -1
  145. package/dist/assets/{index-D2qrPHew.js → index-DJVt4Jyx.js} +1 -1
  146. package/dist/assets/{index-suj0HyLe.js → index-DMg5p5Q5.js} +1 -1
  147. package/dist/assets/{index-B1359XCd.js → index-DNgjX46H.js} +1 -1
  148. package/dist/assets/{index-IwNZXVST.js → index-DPqEZ0tz.js} +1 -1
  149. package/dist/assets/{index-Bu5gNvNl.js → index-DfiGO-z3.js} +1 -1
  150. package/dist/assets/{index-Dv0pO_ZY.js → index-DiX4F22c.js} +1 -1
  151. package/dist/assets/{index-BWI2gHU_.js → index-Dl-8_iZA.js} +1 -1
  152. package/dist/assets/{index-BSD6ArpD.js → index-DpqW15Ug.js} +1 -1
  153. package/dist/assets/{index-DqsshwKV.js → index-Dw9EHqzV.js} +1 -1
  154. package/dist/assets/{index-oKp4ydqC.js → index-DyVpSxMe.js} +1 -1
  155. package/dist/assets/{index-bvUTE5h2.js → index-LSBUkmpR.js} +1 -1
  156. package/dist/assets/{index-BPyr1thS.js → index-ONqkRIuc.js} +1 -1
  157. package/dist/assets/{index-sSPHtazF.js → index-PMRNSwyk.js} +1 -1
  158. package/dist/assets/{index-C4eWIBBB.js → index-TeXIMvfD.js} +1 -1
  159. package/dist/assets/{index-LgcDuoJg.js → index-UCV6svvp.js} +1 -1
  160. package/dist/assets/{index-gaqZ1RJb.js → index-UNwJ0Soc.js} +1 -1
  161. package/dist/assets/{index-Drtkio10.js → index-UlQJ4CNe.js} +1 -1
  162. package/dist/assets/{index-BpRk65Iu.js → index-_SpxdH4J.js} +1 -1
  163. package/dist/assets/{index-kzmFAFx4.js → index-k55SX5kl.js} +1 -1
  164. package/dist/assets/{index-CDyqPm2b.js → index-k5f0I2au.js} +1 -1
  165. package/dist/assets/{index-Da8qmxJG.js → index-kShYQ4pa.js} +1 -1
  166. package/dist/assets/{index-CkdQCAnp.js → index-pflhI7Gn.js} +1 -1
  167. package/dist/assets/{index-DZAGoZxO.js → index-qrkNmBs4.js} +1 -1
  168. package/dist/assets/{index-CwhBXyp0.js → index-r8zBJeUr.js} +1 -1
  169. package/dist/assets/{index-C1ck7INd.js → index-sQcU36Zu.js} +1 -1
  170. package/dist/assets/{index-BpS-uRzc.js → index-y6L6cZvE.js} +1 -1
  171. package/dist/assets/{index-BStjDDyx.js → index-zJe4TTTN.js} +1 -1
  172. package/dist/assets/{index.browser.esm-DFpkVJWs.js → index.browser.esm-B80jhgNq.js} +1 -1
  173. package/dist/assets/{index.es-CeLV7iDQ.js → index.es-BXrnqbDc.js} +1 -1
  174. package/dist/assets/{info-circle-CVMLwxIo.js → info-circle-gZGPj5j1.js} +1 -1
  175. package/dist/assets/{info-CshYgDvC.js → info-qXczUfMj.js} +1 -1
  176. package/dist/assets/{isEqual-CkVIwAaj.js → isEqual-DdIQEpjm.js} +1 -1
  177. package/dist/assets/{isPlainObject-6i_tcsGR.js → isPlainObject-CG3miWf6.js} +1 -1
  178. package/dist/assets/{lightbulb-C-32OCvD.js → lightbulb-DAV_SVzx.js} +1 -1
  179. package/dist/assets/{mail-C_Oh4b7x.js → mail-BSiQllr5.js} +1 -1
  180. package/dist/assets/{midjourney-ZKamLQgH.js → midjourney-Bk0pQ1GK.js} +1 -1
  181. package/dist/assets/{mobile-BMgLvRfS.js → mobile-D3L4uFbS.js} +1 -1
  182. package/dist/assets/{more-DbXTbZvY.js → more-DDHf70dL.js} +1 -1
  183. package/dist/assets/{network-placeholder-AxLwk9Yg.js → network-placeholder-DFUCBmFT.js} +1 -1
  184. package/dist/assets/{nftPlaceholder-R01VpO7T.js → nftPlaceholder-DG1XMQGo.js} +1 -1
  185. package/dist/assets/{off-CGCIfhZC.js → off-DoNg2U4X.js} +1 -1
  186. package/dist/assets/{order-35Ka3qhX.js → order-KT2UQOVv.js} +1 -1
  187. package/dist/assets/{pagination-LA4ZoJ7H.js → pagination-BJFvnhlr.js} +1 -1
  188. package/dist/assets/{play-store-CTwvDpGU.js → play-store-BS1DM-xn.js} +1 -1
  189. package/dist/assets/{plus-9qwloIXk.js → plus-BMI4G9vV.js} +1 -1
  190. package/dist/assets/{price-CkwsSMG5.js → price-Be1B_bvo.js} +1 -1
  191. package/dist/assets/{producer-BDhzUIkg.js → producer-QOy93416.js} +1 -1
  192. package/dist/assets/{qr-code-DCRLHNzs.js → qr-code-BohZYeDa.js} +1 -1
  193. package/dist/assets/{recycle-horizontal-CbugZW1D.js → recycle-horizontal-m74Coduu.js} +1 -1
  194. package/dist/assets/{refresh-BIPV7r6q.js → refresh-iCbrI8Sz.js} +1 -1
  195. package/dist/assets/{reown-logo-DhIViQAl.js → reown-logo-dZ2nrrUw.js} +1 -1
  196. package/dist/assets/{search-C4ZAejFC.js → search-Cie0_ZrT.js} +1 -1
  197. package/dist/assets/{secp256k1-Cighq2WG.js → secp256k1-CuNBwmlc.js} +1 -1
  198. package/dist/assets/{secp256k1-1UK_AUaQ.js → secp256k1-DPZfmnNX.js} +1 -1
  199. package/dist/assets/{seedream-a0yVj7ki.js → seedream-BsXIgMM0.js} +1 -1
  200. package/dist/assets/{send-CpDY58MT.js → send-CN0Ny1u-.js} +1 -1
  201. package/dist/assets/{service-Chp_BJ_f.js → service-QotgjH1Q.js} +1 -1
  202. package/dist/assets/{solana-wallets-Cw-I1OPP.js → solana-wallets-B333h0KT.js} +2 -2
  203. package/dist/assets/{solana-wallets-vue-Stz6o-M-.js → solana-wallets-vue-C4a6USBR.js} +1 -1
  204. package/dist/assets/{suno-DBc3K9MC.js → suno-D_uJA7kM.js} +1 -1
  205. package/dist/assets/{swapHorizontal-D2QOnZSo.js → swapHorizontal-D5cg03dU.js} +1 -1
  206. package/dist/assets/{swapHorizontalBold-QlMF54B8.js → swapHorizontalBold-DMMhbg1i.js} +1 -1
  207. package/dist/assets/{swapHorizontalMedium-DHx02txr.js → swapHorizontalMedium-B5SXjkLW.js} +1 -1
  208. package/dist/assets/{swapHorizontalRoundedBold-Bmn4B3Bo.js → swapHorizontalRoundedBold-j25a_yec.js} +1 -1
  209. package/dist/assets/{swapVertical-BHTVmt7x.js → swapVertical-ezx6dfbo.js} +1 -1
  210. package/dist/assets/{telegram-CL5dXfCy.js → telegram-4eorNWcv.js} +1 -1
  211. package/dist/assets/{three-dots-s4Xsmw_y.js → three-dots-BgKSlsl7.js} +1 -1
  212. package/dist/assets/{twitch-CFwyvaUE.js → twitch-DhNDAbk-.js} +1 -1
  213. package/dist/assets/{twitterIcon-D-dCwyGq.js → twitterIcon-g88ngSFl.js} +1 -1
  214. package/dist/assets/{typescript-Ckyw8f4Q.js → typescript-HOmQr8QU.js} +1 -1
  215. package/dist/assets/{use-form-item-DMNI7O3-.js → use-form-item-gFrK0FVf.js} +1 -1
  216. package/dist/assets/validator-CRted-PS.js +1 -0
  217. package/dist/assets/{verify-CksO1OsU.js → verify-asNJmMUr.js} +1 -1
  218. package/dist/assets/{verify-filled-BD5kQTkA.js → verify-filled-CixdipQ-.js} +1 -1
  219. package/dist/assets/{w3m-modal-B6E_wDN5.js → w3m-modal-CSQfGzwH.js} +1 -1
  220. package/dist/assets/{wallet-BAmH-5N9.js → wallet-fK1xJY87.js} +1 -1
  221. package/dist/assets/{wallet-placeholder-s_pFcS2t.js → wallet-placeholder-1i2FHh7s.js} +1 -1
  222. package/dist/assets/{walletconnect-DkDk8sUn.js → walletconnect-Cgec-pke.js} +1 -1
  223. package/dist/assets/{warning-circle-Ckt1IOjv.js → warning-circle-CCX7rdZ5.js} +1 -1
  224. package/dist/assets/{web-D0R-C6vl.js → web-DfC_D4jz.js} +1 -1
  225. package/dist/assets/{web-Boe1EAJ8.js → web-VZ_Nh7ej.js} +1 -1
  226. package/dist/assets/{x-Bk8PmAYG.js → x-CKC1jczW.js} +1 -1
  227. package/dist/index.html +1 -1
  228. package/package.json +1 -1
  229. package/dist/assets/ApiCodeButton-Fb8Q8veZ.css +0 -1
  230. package/dist/assets/validator-Ub8j9ViE.js +0 -1
@@ -1 +1 @@
1
- import{F as L}from"./index.es-CeLV7iDQ.js";import{E as N}from"./index-HyuSkpOc.js";import{E as se}from"./index-sSPHtazF.js";import{d as S,H as c,E as s,z as Z,C as o,y as a,D as n,q as r,F as i,O as I,N as j,J as p,x as v,I as w,G,K as B,M as E,L as ne}from"./vendor-vue-NSDaktjZ.js";import{H as U,bm as re,dG as H,dH as K,X as q,Y as ie,S as F,cq as x,dI as ae,cp as le,o as de}from"./index-D0zoWl0t.js";import{a as ce}from"./errorCode-Cqj9Td_Z.js";import{p as T}from"./producer-BDhzUIkg.js";import{I as A,A as ue,S as pe,l as me}from"./pagination-LA4ZoJ7H.js";import{a as fe}from"./producer-BGNC4QeM.js";import{E as he}from"./index-C4eWIBBB.js";import{E as _e,a as $e}from"./index-Bu5gNvNl.js";import{E as ee,a as te}from"./index-93S-kjnW.js";import{E as ge}from"./index-BXXvYpXX.js";import{E as k}from"./index-DdbWvBNx.js";import{P as ve,N as ye}from"./NoTasks-B9brz0GL.js";import{E as M}from"./index-DhgEdWde.js";import{u as Y,F as be,_ as ke}from"./Player.vue_vue_type_script_setup_true_lang-BeDKAkXQ.js";import{E as J}from"./index-C-rnAsAl.js";import{E as D}from"./index-Cq8TQPr3.js";import{E as we}from"./index-COfTdmqq.js";import{E as Ce,a as Ve}from"./index-BgdH8W9S.js";import{C as Se}from"./Consumption-HJqRoAYb.js";import{a as Ue}from"./price-CkwsSMG5.js";import{E as Pe,a as Ee}from"./index-CwhBXyp0.js";import{E as Ae,b as Te,a as Fe}from"./index-D2qrPHew.js";import{E as Ie}from"./index-d6anveG0.js";import{a as Le,E as Ge}from"./index-Dm8WLAYA.js";import{E as De}from"./index-B4uEviPn.js";import"./use-form-item-DMNI7O3-.js";import"./index-BuyEbX8F.js";import"./vendor-axios-B8_nURbH.js";import"./vendor-dayjs-v0j1UNZp.js";import"./vendor-vue-router-Df5ITouH.js";import"./highlight-CxiUjIMX.js";import"./index-BLjywj98.js";import"./vendor-highlight-lEWW1Jxd.js";import"./validator-Ub8j9ViE.js";import"./index-BTcVnXUS.js";import"./index-X6wgkPd2.js";import"./typescript-Ckyw8f4Q.js";import"./strings-beZM2Y-f.js";import"./isEqual-CkVIwAaj.js";import"./_Uint8Array-Z75Sa3E8.js";import"./castArray-BOBSHmEl.js";import"./debounce-B-6yjswC.js";import"./_baseIteratee-BL_LXYAx.js";import"./index-bvUTE5h2.js";import"./index-Bo14Ux3S.js";import"./_baseClone-umQ6kPjt.js";import"./_initCloneObject-CCK9Xyv4.js";import"./index-BStjDDyx.js";import"./index-BpS-uRzc.js";import"./dropdown-97VRadx2.js";import"./index-Cu41y2Fl.js";import"./index-Dv0pO_ZY.js";import"./isPlainObject-6i_tcsGR.js";const ze=S({name:"LayoutProducer",components:{ElDrawer:se,ElButton:N,FontAwesomeIcon:L},data(){return{drawer:!1,preview:!1}},computed:{}}),Re={class:"main flex flex-row flex-1"},Ze={class:"config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]"},je={class:"result h-full flex flex-col flex-1 min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]"},Ne={class:"preview h-full w-[300px] flex flex-col"};function Be(e,t,m,l,y,b){const d=n("font-awesome-icon"),f=n("el-button"),h=n("el-drawer");return r(),c("div",Re,[s("div",Ze,[Z(e.$slots,"config",{},void 0,!0)]),s("div",je,[Z(e.$slots,"result",{},void 0,!0)]),s("div",Ne,[Z(e.$slots,"preview",{},void 0,!0)]),o(f,{circle:"",class:"menu",onClick:t[0]||(t[0]=g=>e.drawer=!0)},{default:a(()=>[o(d,{icon:"fa-solid fa-magic"})]),_:1}),o(h,{modelValue:e.drawer,"onUpdate:modelValue":t[1]||(t[1]=g=>e.drawer=g),direction:"ltr","with-header":!1,size:"340px",class:"drawer"},{default:a(()=>[Z(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const qe=U(ze,[["render",Be],["__scopeId","data-v-03e2979b"]]),Me=S({name:"TypeSelector",components:{ElSelect:$e,ElOption:_e,ElSwitch:he,InfoIcon:A},data(){return{options:[{label:"FUZZ-2.0 Pro",value:"FUZZ-2.0 Pro",desc:this.$t("producer.model.fuzz20proDesc")},{label:"FUZZ-2.0",value:"FUZZ-2.0",desc:this.$t("producer.model.fuzz20desc")},{label:"FUZZ-2.0 Raw",value:"FUZZ-2.0 Raw",desc:this.$t("producer.model.fuzz20rawDesc")},{label:"FUZZ-1.1 Pro",value:"FUZZ-1.1 Pro",desc:this.$t("producer.model.fuzz11proDesc")},{label:"FUZZ-1.1",value:"FUZZ-1.1",desc:this.$t("producer.model.fuzz11desc")},{label:"FUZZ-1.0 Pro",value:"FUZZ-1.0 Pro",desc:this.$t("producer.model.fuzz10proDesc")},{label:"FUZZ-1.0",value:"FUZZ-1.0",desc:this.$t("producer.model.fuzz10desc")},{label:"FUZZ-0.8",value:"FUZZ-0.8",desc:this.$t("producer.model.fuzz08desc")}]}},computed:{custom:{get(){return this.$store.state.producer?.config?.custom||!1},set(e){this.$store.commit("producer/setConfig",{...this.$store.state.producer?.config,custom:e})}},instrumental:{get(){return this.$store.state.producer?.config?.instrumental||!1},set(e){this.$store.commit("producer/setConfig",{...this.$store.state.producer?.config,instrumental:e})}},model:{get(){return this.$store.state.producer?.config?.model},set(e){this.$store.commit("producer/setConfig",{...this.$store.state.producer?.config,model:e})}}},mounted(){this.model||(this.model=fe)}}),Oe={class:"mb-3"},We={class:"flex items-center mb-1"},He={class:"text-sm font-bold"},Ke={class:"model-option"},Ye={class:"model-option-name"},Je={class:"model-option-desc"},Xe={key:0,class:"flex items-center justify-between mb-3"},Qe={class:"flex items-center"},xe={class:"text-sm font-bold"};function et(e,t,m,l,y,b){const d=n("el-option"),f=n("el-select"),h=n("info-icon"),g=n("el-switch");return r(),c("div",null,[s("div",Oe,[s("div",We,[s("span",He,i(e.$t("producer.name.model")),1)]),o(f,{modelValue:e.model,"onUpdate:modelValue":t[0]||(t[0]=_=>e.model=_),class:"w-full model-select",size:"default",placeholder:e.$t("producer.placeholder.select")},{default:a(()=>[(r(!0),c(I,null,j(e.options,_=>(r(),v(d,{key:_.value,label:_.label,value:_.value},{default:a(()=>[s("div",Ke,[s("span",Ye,i(_.label),1),s("span",Je,i(_.desc),1)])]),_:2},1032,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])]),e.custom?(r(),c("div",Xe,[s("div",Qe,[s("span",xe,i(e.$t("producer.name.instrumental")),1),o(h,{content:e.$t("producer.description.instrumental")},null,8,["content"])]),o(g,{modelValue:e.instrumental,"onUpdate:modelValue":t[1]||(t[1]=_=>e.instrumental=_)},null,8,["modelValue"])])):p("",!0)])}const tt=U(Me,[["render",et],["__scopeId","data-v-42496b9a"]]),ot=S({name:"UploadAudio",components:{ElUpload:ge,ElButton:N,ElRadioGroup:te,ElRadioButton:ee,InfoIcon:A,FontAwesomeIcon:L},emits:["change"],data(){return{fileList:[],uploadUrl:re()+"/api/v1/files/",audioPreviewUrl:null,uploading:!1}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},credential(){return this.$store.state.producer.credential},config(){return this.$store.state.producer.config},urls(){return this.fileList.map(e=>e?.response?.file_url)},hasUploadedAudio(){const e=this.$store.state.producer?.config?.action;return e==="upload_extend"||e==="upload_cover"},uploadAction:{get(){return this.$store.state.producer?.config?.action||"upload_extend"},set(e){this.$store.commit("producer/setConfig",{...this.$store.state.producer?.config,action:e})}}},watch:{urls:{handler(e){this.$emit("change",e)}}},methods:{onExceed(){k.warning(this.$t("producer.message.uploadReferencesExceed"))},onError(){this.uploading=!1,k.error(this.$t("producer.message.uploadReferencesError"))},async onSuccess(){const e=this.urls?.[0];if(!e){this.uploading=!1;return}this.audioPreviewUrl=e,await this.onGenerateAudioId(e)},async onGenerateAudioId(e){const t={audio_url:e},m=this.credential?.token;if(!m){console.error("no token specified"),this.uploading=!1;return}this.uploading=!0,k.info(this.$t("producer.message.startingUploadAudio"));try{const y=(await T.upload(t,{token:m})).data?.data.audio_id;this.$store.commit("producer/setConfig",{...this.$store.state.producer?.config,audio_id:y,action:"upload_extend"}),k.success(this.$t("producer.message.startUploadAudioSuccess"))}catch(l){k.error(l?.response?.data?.error?.message||this.$t("producer.message.startUploadAudioFailed"))}finally{this.uploading=!1}}}}),st={class:"relative"},nt={class:"flex justify-between items-center mb-2"},rt={class:"flex justify-start items-center"},it={class:"text-sm font-bold"},at={key:0,class:"mb-2"},lt=["src"],dt={key:1,class:"mt-1"};function ct(e,t,m,l,y,b){const d=n("info-icon"),f=n("font-awesome-icon"),h=n("el-button"),g=n("el-upload"),_=n("el-radio-button"),P=n("el-radio-group");return r(),c("div",st,[s("div",nt,[s("div",rt,[s("span",it,i(e.$t("producer.name.referenceAudios")),1),o(d,{content:e.$t("producer.description.uploadAudios")},null,8,["content"])]),o(g,{"file-list":e.fileList,"onUpdate:fileList":t[0]||(t[0]=$=>e.fileList=$),name:"file",limit:1,class:"upload-wrapper inline-upload",action:e.uploadUrl,accept:".mp3,.wav,.m4a,audio/*","show-file-list":!1,"on-exceed":e.onExceed,"on-error":e.onError,"on-success":e.onSuccess,headers:e.headers},{default:a(()=>[o(h,{round:"",type:"primary",size:"small",loading:e.uploading},{default:a(()=>[o(f,{icon:"fa-solid fa-upload",class:"icon mr-1"}),w(" "+i(e.$t("producer.button.uploadAudios")),1)]),_:1},8,["loading"])]),_:1},8,["file-list","action","on-exceed","on-error","on-success","headers"])]),e.audioPreviewUrl?(r(),c("div",at,[s("audio",{src:e.audioPreviewUrl,controls:"",class:"w-full"},null,8,lt)])):p("",!0),e.hasUploadedAudio?(r(),c("div",dt,[o(P,{modelValue:e.uploadAction,"onUpdate:modelValue":t[1]||(t[1]=$=>e.uploadAction=$),size:"small"},{default:a(()=>[o(_,{value:"upload_extend"},{default:a(()=>[w(i(e.$t("producer.button.extend")),1)]),_:1}),o(_,{value:"upload_cover"},{default:a(()=>[w(i(e.$t("producer.button.cover_music")),1)]),_:1})]),_:1},8,["modelValue"])])):p("",!0)])}const ut=U(ot,[["render",ct],["__scopeId","data-v-355e932b"]]),pt="",mt=S({name:"PromptInput",components:{PromptTextarea:ve},computed:{prompt:{get(){return this.$store.state.producer?.config?.prompt},set(e){this.$store.commit("producer/setConfig",{...this.$store.state.producer?.config,prompt:e})}}},mounted(){this.prompt||(this.prompt=pt)}});function ft(e,t,m,l,y,b){const d=n("prompt-textarea");return r(),v(d,{modelValue:e.prompt,"onUpdate:modelValue":t[0]||(t[0]=f=>e.prompt=f),title:e.$t("producer.name.songDescription"),info:e.$t("producer.description.prompt"),placeholder:e.$t("producer.placeholder.prompt"),"min-rows":5,"max-rows":14},null,8,["modelValue","title","info","placeholder"])}const ht=U(mt,[["render",ft]]),_t="",$t=S({name:"LyricInput",components:{ElInput:M,ElButton:N,FontAwesomeIcon:L,InfoIcon:A},data(){return{generatingLyrics:!1}},computed:{lyric:{get(){return this.$store.state.producer?.config?.lyric},set(e){this.$store.commit("producer/setConfig",{...this.$store.state.producer?.config,lyric:e})}},config(){return this.$store.state.producer?.config},credential(){return this.$store.state.producer?.credential}},mounted(){this.lyric||(this.lyric=_t)},methods:{async onGenerateLyrics(){const e=this.credential?.token;if(!e)return;const t=this.config?.style||this.config?.title||"a beautiful song";this.generatingLyrics=!0,k.info(this.$t("producer.message.generatingLyrics"));try{const l=(await T.lyric({prompt:t},{token:e})).data?.data;l?.text&&(this.lyric=l.text,l?.title&&!this.config?.title&&this.$store.commit("producer/setConfig",{...this.$store.state.producer?.config,lyric:l.text,title:l.title}),k.success(this.$t("producer.message.generateLyricsSuccess")))}catch{k.error(this.$t("producer.message.generateLyricsFailed"))}finally{this.generatingLyrics=!1}}}}),gt={class:"field"},vt={class:"flex items-center justify-between mb-1"},yt={class:"flex items-center"},bt={class:"text-sm font-bold"};function kt(e,t,m,l,y,b){const d=n("info-icon"),f=n("font-awesome-icon"),h=n("el-button"),g=n("el-input");return r(),c("div",gt,[s("div",vt,[s("div",yt,[s("span",bt,i(e.$t("producer.name.lyrics")),1),o(d,{content:e.$t("producer.description.lyrics")},null,8,["content"])]),e.config?.action!=="extend"?(r(),v(h,{key:0,size:"small",loading:e.generatingLyrics,round:"",onClick:e.onGenerateLyrics},{default:a(()=>[e.generatingLyrics?p("",!0):(r(),v(f,{key:0,icon:"fa-solid fa-wand-magic-sparkles",class:"mr-1"})),w(" "+i(e.$t("producer.button.generate_lyrics")),1)]),_:1},8,["loading","onClick"])):p("",!0)]),e.config?.action!=="extend"?(r(),v(g,{key:0,modelValue:e.lyric,"onUpdate:modelValue":t[0]||(t[0]=_=>e.lyric=_),rows:5,type:"textarea",class:"lyrics",placeholder:e.$t("producer.placeholder.lyrics")},null,8,["modelValue","placeholder"])):(r(),v(g,{key:1,modelValue:e.lyric,"onUpdate:modelValue":t[1]||(t[1]=_=>e.lyric=_),rows:5,type:"textarea",class:"lyrics",placeholder:e.$t("producer.placeholder.extend.lyrics")},null,8,["modelValue","placeholder"]))])}const wt=U($t,[["render",kt],["__scopeId","data-v-88c6da2b"]]),Ct=S({name:"StyleInput",components:{ElInput:M,InfoIcon:A},computed:{style:{get(){return this.$store.state.producer?.config?.style},set(e){this.$store.commit("producer/setConfig",{...this.$store.state.producer?.config,style:e})}}}}),Vt={class:"field"},St={class:"flex items-center justify-between mb-1"},Ut={class:"flex items-center"},Pt={class:"text-sm font-bold"};function Et(e,t,m,l,y,b){const d=n("info-icon"),f=n("el-input");return r(),c("div",Vt,[s("div",St,[s("div",Ut,[s("span",Pt,i(e.$t("producer.name.style")),1),o(d,{content:e.$t("producer.description.style")},null,8,["content"])])]),o(f,{modelValue:e.style,"onUpdate:modelValue":t[0]||(t[0]=h=>e.style=h),rows:2,type:"textarea",placeholder:e.$t("producer.placeholder.style")},null,8,["modelValue","placeholder"])])}const At=U(Ct,[["render",Et]]),Tt=S({name:"TitleInput",components:{ElInput:M,InfoIcon:A},computed:{title:{get(){return this.$store.state.producer?.config?.title},set(e){this.$store.commit("producer/setConfig",{...this.$store.state.producer?.config,title:e})}}}}),Ft={class:"field"},It={class:"flex items-center mb-1"},Lt={class:"text-sm font-bold"};function Gt(e,t,m,l,y,b){const d=n("info-icon"),f=n("el-input");return r(),c("div",Ft,[s("div",It,[s("span",Lt,i(e.$t("producer.name.title")),1),o(d,{content:e.$t("producer.description.title")},null,8,["content"])]),o(f,{modelValue:e.title,"onUpdate:modelValue":t[0]||(t[0]=h=>e.title=h),placeholder:e.$t("producer.placeholder.title")},null,8,["modelValue","placeholder"])])}const Dt=U(Tt,[["render",Gt]]),zt=S({name:"ExtendFromInput",components:{ElImage:D,ElIcon:q,ElInputNumber:J,VideoPlay:K,VideoPause:H},data(){return{}},computed:{audio(){return this.$store.state.producer?.config?.audio},value:{get(){return this.$store.state.producer?.config?.continue_at},set(e){console.debug("set continue_at",e),this.$store.commit("producer/setConfig",{...this.$store.state.producer?.config,continue_at:e?parseInt(e):void 0})}}},mounted(){this.value||(this.value=void 0)},methods:{handleChange(e){if(e===void 0){this.value=void 0;return}e<0?this.value=0:e>this.audio?.duration?this.value=this.audio?.duration:this.value=e},useFormatDuring:Y,onPlay(e){this.$store.dispatch("producer/setAudio",{...this.$store.state.producer.audio,...e,state:"playing"}),console.log("on play")},onPause(e){this.$store.dispatch("producer/setAudio",{...this.$store.state.producer.audio,...e,state:"paused"}),console.log("on pause")},onClick(e){this.$store.state?.producer?.audio?.id!==e.id&&this.onPlay({...e,progress:0})}}}),Rt={class:"field"},Zt={class:"box"},jt={class:"title font-bold"},Nt={class:"input-wrapper"},Bt={class:"task"},qt={class:"left"},Mt={key:2,class:"duration"},Ot={class:"info"},Wt={class:"title"},Ht={class:"style"};function Kt(e,t,m,l,y,b){const d=n("el-input-number"),f=n("el-image"),h=n("video-pause"),g=n("el-icon"),_=n("video-play"),P=B("loading");return r(),c("div",Rt,[s("div",Zt,[s("h2",jt,i(e.$t("producer.name.extend")),1),s("div",Nt,[o(d,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=$=>e.value=$),class:"value",min:0,max:e.audio?.duration,controls:!1,placeholder:e.$t("producer.placeholder.extend.continue_at"),onChange:e.handleChange},null,8,["modelValue","max","placeholder","onChange"])])]),s("div",Bt,[e.audio?(r(),c("div",{key:0,class:"audio",onClick:t[3]||(t[3]=$=>e.onClick(e.audio))},[G((r(),c("div",qt,[o(f,{src:e.audio?.image_url,class:"cover",fit:"cover"},null,8,["src"]),e.audio?.audio_url&&e.$store.state?.producer?.audio?.id===e.audio.id&&e.$store.state?.producer?.audio?.state==="playing"?(r(),c("div",{key:0,class:"overlay",onClick:t[1]||(t[1]=$=>e.onPause(e.audio))},[o(g,null,{default:a(()=>[o(h)]),_:1})])):p("",!0),e.audio?.audio_url&&(e.$store.state?.producer?.audio?.id!==e.audio.id||e.$store.state?.producer?.audio?.id===e.audio.id&&e.$store.state?.producer?.audio?.state==="paused")?(r(),c("div",{key:1,class:"overlay",onClick:t[2]||(t[2]=$=>e.onPlay(e.audio))},[o(g,null,{default:a(()=>[o(_)]),_:1})])):p("",!0),e.audio?.duration?(r(),c("div",Mt,i(e.useFormatDuring(e.audio?.duration)),1)):p("",!0)])),[[P,!e.audio?.audio_url]]),s("div",Ot,[s("h2",Wt,i(e.audio?.title),1),s("p",Ht,i(e.audio?.style),1)])])):p("",!0)])])}const Yt=U(zt,[["render",Kt],["__scopeId","data-v-26d43480"]]),Jt=S({name:"CoverFromInput",components:{ElImage:D,ElIcon:q,VideoPlay:K,VideoPause:H},data(){return{}},computed:{audio(){return this.$store.state.producer?.config?.audio},value:{get(){return this.$store.state.producer?.config?.continue_at},set(e){console.debug("set continue_at",e),this.$store.commit("producer/setConfig",{...this.$store.state.producer?.config,continue_at:e?parseInt(e):void 0})}}},mounted(){this.value||(this.value=void 0)},methods:{handleChange(e){e<0?this.value=0:e>this.audio?.duration?this.value=this.audio?.duration:this.value=e},useFormatDuring:Y,onPlay(e){this.$store.dispatch("producer/setAudio",{...this.$store.state.producer.audio,...e,state:"playing"}),console.log("on play")},onPause(e){this.$store.dispatch("producer/setAudio",{...this.$store.state.producer.audio,...e,state:"paused"}),console.log("on pause")},onClick(e){this.$store.state?.producer?.audio?.id!==e.id&&this.onPlay({...e,progress:0})}}}),Xt={class:"field"},Qt={class:"box"},xt={class:"title font-bold"},eo={class:"task"},to={class:"left"},oo={key:2,class:"duration"},so={class:"info"},no={class:"title"},ro={class:"style"};function io(e,t,m,l,y,b){const d=n("el-image"),f=n("video-pause"),h=n("el-icon"),g=n("video-play"),_=B("loading");return r(),c("div",Xt,[s("div",Qt,[s("h2",xt,i(e.$t("producer.name.cover")),1)]),s("div",eo,[e.audio?(r(),c("div",{key:0,class:"audio",onClick:t[2]||(t[2]=P=>e.onClick(e.audio))},[G((r(),c("div",to,[o(d,{src:e.audio?.image_url,class:"cover",fit:"cover"},null,8,["src"]),e.audio?.audio_url&&e.$store.state?.producer?.audio?.id===e.audio.id&&e.$store.state?.producer?.audio?.state==="playing"?(r(),c("div",{key:0,class:"overlay",onClick:t[0]||(t[0]=P=>e.onPause(e.audio))},[o(h,null,{default:a(()=>[o(f)]),_:1})])):p("",!0),e.audio?.audio_url&&(e.$store.state?.producer?.audio?.id!==e.audio.id||e.$store.state?.producer?.audio?.id===e.audio.id&&e.$store.state?.producer?.audio?.state==="paused")?(r(),c("div",{key:1,class:"overlay",onClick:t[1]||(t[1]=P=>e.onPlay(e.audio))},[o(h,null,{default:a(()=>[o(g)]),_:1})])):p("",!0),e.audio?.duration?(r(),c("div",oo,i(e.useFormatDuring(e.audio?.duration)),1)):p("",!0)])),[[_,!e.audio?.audio_url]]),s("div",so,[s("h2",no,i(e.audio?.title),1),s("p",ro,i(e.audio?.style),1)])])):p("",!0)])])}const ao=U(Jt,[["render",io],["__scopeId","data-v-d8a8e583"]]),lo=S({name:"VocalGenderSelector",components:{ElRadioGroup:te,ElRadioButton:ee,InfoIcon:A},computed:{vocalGender:{get(){return this.$store.state.producer?.config?.vocal_gender||""},set(e){this.$store.commit("producer/setConfig",{...this.$store.state.producer?.config,vocal_gender:e||void 0})}}}}),co={class:"mb-2"},uo={class:"flex items-center mb-1"},po={class:"text-sm font-bold"};function mo(e,t,m,l,y,b){const d=n("info-icon"),f=n("el-radio-button"),h=n("el-radio-group");return r(),c("div",co,[s("div",uo,[s("span",po,i(e.$t("producer.name.vocalGender")),1),o(d,{content:e.$t("producer.description.vocalGender")},null,8,["content"])]),o(h,{modelValue:e.vocalGender,"onUpdate:modelValue":t[0]||(t[0]=g=>e.vocalGender=g)},{default:a(()=>[o(f,{value:""},{default:a(()=>[w(i(e.$t("producer.gender.auto")),1)]),_:1}),o(f,{value:"f"},{default:a(()=>[w(i(e.$t("producer.gender.female")),1)]),_:1}),o(f,{value:"m"},{default:a(()=>[w(i(e.$t("producer.gender.male")),1)]),_:1})]),_:1},8,["modelValue"])])}const fo=U(lo,[["render",mo]]),ho=S({name:"AdvancedParams",components:{ElCollapse:Ve,ElCollapseItem:Ce,ElInput:M,ElSlider:we,ElInputNumber:J,InfoIcon:A},data(){return{activeNames:[]}},computed:{config(){return this.$store.state.producer?.config},styleNegative:{get(){return this.$store.state.producer?.config?.style_negative||""},set(e){this.$store.commit("producer/setConfig",{...this.$store.state.producer?.config,style_negative:e||void 0})}},lyricPrompt:{get(){return this.$store.state.producer?.config?.lyric_prompt||""},set(e){this.$store.commit("producer/setConfig",{...this.$store.state.producer?.config,lyric_prompt:e||void 0})}},weirdness:{get(){return this.$store.state.producer?.config?.weirdness??50},set(e){this.$store.commit("producer/setConfig",{...this.$store.state.producer?.config,weirdness:e})}},soundStrength:{get(){return this.$store.state.producer?.config?.sound_strength??50},set(e){this.$store.commit("producer/setConfig",{...this.$store.state.producer?.config,sound_strength:e})}},lyricsStrength:{get(){return this.$store.state.producer?.config?.lyrics_strength??50},set(e){this.$store.commit("producer/setConfig",{...this.$store.state.producer?.config,lyrics_strength:e})}},seed:{get(){return this.$store.state.producer?.config?.seed},set(e){this.$store.commit("producer/setConfig",{...this.$store.state.producer?.config,seed:e})}}}}),_o={key:0,class:"mb-3"},$o={class:"flex items-center mb-1"},go={class:"text-xs font-bold"},vo={key:1,class:"mb-3"},yo={class:"flex items-center mb-1"},bo={class:"text-xs font-bold"},ko={class:"mb-3"},wo={class:"flex items-center justify-between mb-1"},Co={class:"flex items-center"},Vo={class:"text-xs font-bold"},So={class:"text-xs text-[var(--el-text-color-secondary)]"},Uo={class:"mb-3"},Po={class:"flex items-center justify-between mb-1"},Eo={class:"flex items-center"},Ao={class:"text-xs font-bold"},To={class:"text-xs text-[var(--el-text-color-secondary)]"},Fo={key:2,class:"mb-3"},Io={class:"flex items-center justify-between mb-1"},Lo={class:"flex items-center"},Go={class:"text-xs font-bold"},Do={class:"text-xs text-[var(--el-text-color-secondary)]"},zo={class:"mb-3"},Ro={class:"flex items-center mb-1"},Zo={class:"text-xs font-bold"};function jo(e,t,m,l,y,b){const d=n("info-icon"),f=n("el-input"),h=n("el-slider"),g=n("el-input-number"),_=n("el-collapse-item"),P=n("el-collapse");return r(),v(P,{modelValue:e.activeNames,"onUpdate:modelValue":t[6]||(t[6]=$=>e.activeNames=$),class:"advanced-collapse"},{default:a(()=>[o(_,{title:e.$t("producer.name.advancedParams"),name:"advanced"},{default:a(()=>[e.config?.custom?(r(),c("div",_o,[s("div",$o,[s("span",go,i(e.$t("producer.name.styleNegative")),1),o(d,{content:e.$t("producer.description.styleNegative")},null,8,["content"])]),o(f,{modelValue:e.styleNegative,"onUpdate:modelValue":t[0]||(t[0]=$=>e.styleNegative=$),size:"small",placeholder:e.$t("producer.placeholder.styleNegative")},null,8,["modelValue","placeholder"])])):p("",!0),e.config?.custom&&!e.config?.instrumental?(r(),c("div",vo,[s("div",yo,[s("span",bo,i(e.$t("producer.name.lyricPrompt")),1),o(d,{content:e.$t("producer.description.lyricPrompt")},null,8,["content"])]),o(f,{modelValue:e.lyricPrompt,"onUpdate:modelValue":t[1]||(t[1]=$=>e.lyricPrompt=$),size:"small",placeholder:e.$t("producer.placeholder.lyricPrompt")},null,8,["modelValue","placeholder"])])):p("",!0),s("div",ko,[s("div",wo,[s("div",Co,[s("span",Vo,i(e.$t("producer.name.weirdness")),1),o(d,{content:e.$t("producer.description.weirdness")},null,8,["content"])]),s("span",So,i(e.weirdness??50),1)]),o(h,{modelValue:e.weirdness,"onUpdate:modelValue":t[2]||(t[2]=$=>e.weirdness=$),min:0,max:100,step:1},null,8,["modelValue"])]),s("div",Uo,[s("div",Po,[s("div",Eo,[s("span",Ao,i(e.$t("producer.name.soundStrength")),1),o(d,{content:e.$t("producer.description.soundStrength")},null,8,["content"])]),s("span",To,i(e.soundStrength??50),1)]),o(h,{modelValue:e.soundStrength,"onUpdate:modelValue":t[3]||(t[3]=$=>e.soundStrength=$),min:0,max:100,step:1},null,8,["modelValue"])]),e.config?.custom&&!e.config?.instrumental?(r(),c("div",Fo,[s("div",Io,[s("div",Lo,[s("span",Go,i(e.$t("producer.name.lyricsStrength")),1),o(d,{content:e.$t("producer.description.lyricsStrength")},null,8,["content"])]),s("span",Do,i(e.lyricsStrength??50),1)]),o(h,{modelValue:e.lyricsStrength,"onUpdate:modelValue":t[4]||(t[4]=$=>e.lyricsStrength=$),min:0,max:100,step:1},null,8,["modelValue"])])):p("",!0),s("div",zo,[s("div",Ro,[s("span",Zo,i(e.$t("producer.name.seed")),1),o(d,{content:e.$t("producer.description.seed")},null,8,["content"])]),o(g,{modelValue:e.seed,"onUpdate:modelValue":t[5]||(t[5]=$=>e.seed=$),min:0,controls:!1,size:"small",placeholder:e.$t("producer.placeholder.seed"),class:"w-full"},null,8,["modelValue","placeholder"])])]),_:1},8,["title"])]),_:1},8,["modelValue"])}const No=U(ho,[["render",jo],["__scopeId","data-v-44ad862b"]]),Bo=S({name:"ReplaceSectionInput",components:{ElInputNumber:J,ElImage:D,InfoIcon:A},computed:{audio(){return this.$store.state.producer?.config?.audio},replaceSectionStart:{get(){return this.$store.state.producer?.config?.replace_section_start},set(e){this.$store.commit("producer/setConfig",{...this.$store.state.producer?.config,replace_section_start:e})}},replaceSectionEnd:{get(){return this.$store.state.producer?.config?.replace_section_end},set(e){this.$store.commit("producer/setConfig",{...this.$store.state.producer?.config,replace_section_end:e})}}},methods:{onClick(e){this.$store.dispatch("producer/setAudio",{...this.$store.state.producer.audio,...e,state:"playing"})}}}),qo={class:"field"},Mo={class:"flex items-center mb-2"},Oo={class:"text-sm font-bold m-0"},Wo={key:0,class:"task mb-2"},Ho={class:"left relative w-[50px] h-[50px] mr-3 flex-shrink-0"},Ko={class:"info flex-1 min-w-0"},Yo={class:"text-sm font-bold m-0 truncate"},Jo={class:"text-xs text-[var(--el-text-color-secondary)] m-0 truncate"},Xo={class:"flex gap-2"};function Qo(e,t,m,l,y,b){const d=n("info-icon"),f=n("el-image"),h=n("el-input-number"),g=B("loading");return r(),c("div",qo,[s("div",Mo,[s("h2",Oo,i(e.$t("producer.name.replaceSection")),1),o(d,{content:e.$t("producer.description.replaceSection")},null,8,["content"])]),e.audio?(r(),c("div",Wo,[s("div",{class:"audio flex items-center",onClick:t[0]||(t[0]=_=>e.onClick(e.audio))},[G((r(),c("div",Ho,[o(f,{src:e.audio?.image_url,class:"w-full h-full rounded",fit:"cover"},null,8,["src"])])),[[g,!e.audio?.audio_url]]),s("div",Ko,[s("h2",Yo,i(e.audio?.title),1),s("p",Jo,i(e.audio?.style),1)])])])):p("",!0),s("div",Xo,[o(h,{modelValue:e.replaceSectionStart,"onUpdate:modelValue":t[1]||(t[1]=_=>e.replaceSectionStart=_),class:"flex-1",min:0,max:e.audio?.duration,controls:!1,placeholder:e.$t("producer.placeholder.replaceSectionStart")},null,8,["modelValue","max","placeholder"]),o(h,{modelValue:e.replaceSectionEnd,"onUpdate:modelValue":t[2]||(t[2]=_=>e.replaceSectionEnd=_),class:"flex-1",min:e.replaceSectionStart||0,max:e.audio?.duration,controls:!1,placeholder:e.$t("producer.placeholder.replaceSectionEnd")},null,8,["modelValue","min","max","placeholder"])])])}const xo=U(Bo,[["render",Qo]]),es=S({name:"PresetPanel",components:{TypeSelector:tt,PromptInput:ht,LyricInput:wt,StyleInput:At,TitleInput:Dt,ExtendFromInput:Yt,CoverFromInput:ao,UploadAudio:ut,VocalGenderSelector:fo,AdvancedParams:No,ReplaceSectionInput:xo,FontAwesomeIcon:L,ElButton:N,ElTabs:Ee,ElTabPane:Pe,Consumption:Se},emits:["generate"],computed:{config(){return this.$store.state.producer?.config},mode:{get(){return this.$store.state.producer?.config?.custom?"custom":"simple"},set(e){this.$store.commit("producer/setConfig",{...this.$store.state.producer?.config,custom:e==="custom"})}},consumption(){return Ue(this.config,this.service?.cost)},service(){return this.$store.state.producer?.service},generateButtonText(){const e=this.config?.action;return e==="extend"||e==="upload_extend"?this.$t("producer.button.extend"):e==="cover"||e==="upload_cover"?this.$t("producer.button.cover_music"):e==="variation"?this.$t("producer.button.variation"):e==="replace_section"?this.$t("producer.button.replace_section"):e==="stems"?this.$t("producer.button.get_stems"):e==="swap_vocals"?this.$t("producer.button.swap_vocals"):e==="swap_instrumentals"?this.$t("producer.button.swap_instrumentals"):this.$t("producer.button.generate")}},methods:{onGenerate(){this.$emit("generate")},onClearAll(){this.$store.commit("producer/setConfig",{custom:this.$store.state.producer?.config?.custom||!1,instrumental:!1,prompt:"",lyric:"",style:"",title:"",model:this.$store.state.producer?.config?.model})}}}),ts={class:"flex flex-col h-full"},os={class:"flex-1 overflow-y-auto p-5"},ss={class:"pt-2 px-1"},ns={class:"pt-2 px-1"},rs={class:"flex flex-col items-center justify-center px-5 pb-5 gap-2"},is={class:"flex gap-2 w-full"};function as(e,t,m,l,y,b){const d=n("type-selector"),f=n("upload-audio"),h=n("prompt-input"),g=n("extend-from-input"),_=n("cover-from-input"),P=n("replace-section-input"),$=n("advanced-params"),C=n("el-tab-pane"),z=n("lyric-input"),R=n("style-input"),O=n("title-input"),W=n("vocal-gender-selector"),u=n("el-tabs"),V=n("consumption"),X=n("font-awesome-icon"),Q=n("el-button");return r(),c("div",ts,[s("div",os,[o(u,{modelValue:e.mode,"onUpdate:modelValue":t[0]||(t[0]=oe=>e.mode=oe),class:"producer-mode-tabs",stretch:""},{default:a(()=>[o(C,{label:e.$t("producer.mode.simple"),name:"simple"},{default:a(()=>[s("div",ss,[o(d,{class:"mb-4"}),o(f,{class:"mb-4"}),o(h,{class:"mb-4"}),e.config?.action==="extend"?(r(),v(g,{key:0,class:"mb-4"})):p("",!0),e.config?.action==="cover"?(r(),v(_,{key:1,class:"mb-4"})):p("",!0),e.config?.action==="replace_section"?(r(),v(P,{key:2,class:"mb-4"})):p("",!0),o($,{class:"mb-4"})])]),_:1},8,["label"]),o(C,{label:e.$t("producer.mode.custom"),name:"custom"},{default:a(()=>[s("div",ns,[o(d,{class:"mb-4"}),o(f,{class:"mb-4"}),e.config?.instrumental?p("",!0):(r(),v(z,{key:0,class:"mb-4"})),o(R,{class:"mb-4"}),o(O,{class:"mb-4"}),e.config?.instrumental?p("",!0):(r(),v(W,{key:1,class:"mb-4"})),e.config?.action==="extend"?(r(),v(g,{key:2,class:"mb-4"})):p("",!0),e.config?.action==="cover"?(r(),v(_,{key:3,class:"mb-4"})):p("",!0),e.config?.action==="replace_section"?(r(),v(P,{key:4,class:"mb-4"})):p("",!0),o($,{class:"mb-4"})])]),_:1},8,["label"])]),_:1},8,["modelValue"])]),s("div",rs,[o(V,{value:e.consumption,service:e.service},null,8,["value","service"]),s("div",is,[o(Q,{class:"flex-1",onClick:e.onClearAll},{default:a(()=>[o(X,{icon:"fa-solid fa-broom",class:"mr-1"}),w(" "+i(e.$t("producer.button.clear_all")),1)]),_:1},8,["onClick"]),o(Q,{type:"primary",class:"flex-1",round:"",onClick:e.onGenerate},{default:a(()=>[o(X,{icon:"fa-solid fa-magic",class:"mr-2"}),w(" "+i(e.generateButtonText),1)]),_:1},8,["onClick"])])])])}const ls=U(es,[["render",as],["__scopeId","data-v-4a4b209e"]]),ds=x("producer"),cs=S({name:"TaskPreview",components:{ElImage:D,ElIcon:q,ElTooltip:Ie,FontAwesomeIcon:L,VideoPlay:K,VideoPause:H,ElDropdown:Fe,ElDropdownMenu:Te,ElDropdownItem:Ae,Loading:ie,ApiCodeDialog:ue},props:{modelValue:{type:Object,required:!0}},data(){return{isFetchingVideoUrl:!1,isFetchingWav:!1,apiCodeVisible:!1,apiCodePath:"/producer/audios",apiCodeBody:{}}},computed:{loading(){return this.$store.state.producer?.status?.getApplications===F.Request},credential(){return this.$store.state.producer.credential},config(){return this.$store.state.producer.config},task(){return this.$store.state.producer?.tasks},audios(){const e=this.modelValue?.response?.data??[],t=this.modelValue?.request?.action;return t?e.map(m=>({...m,action:t})):e},application(){return this.$store.state.producer?.application},active(){return this.$store.state.producer?.tasks?.active}},methods:{useFormatDuring:Y,onViewCode(){const e=this.modelValue?.request||{},t={};Object.entries(e).forEach(([m,l])=>{m==="application_id"||m==="callback_url"||l!=null&&(typeof l=="string"&&l===""||Array.isArray(l)&&l.length===0||(t[m]=l))}),this.apiCodeBody=t,this.apiCodePath="/producer/audios",this.apiCodeVisible=!0},onPlay(e){this.$store.dispatch("producer/setAudio",{...this.$store.state.producer.audio,...e,state:"playing"}),console.log("on play")},onPause(e){this.$store.dispatch("producer/setAudio",{...this.$store.state.producer.audio,...e,state:"paused"}),console.log("on pause")},onClick(e){this.$store.state?.producer?.audio?.id!==e.id&&this.onPlay({...e,progress:0})},onExtend(e,t){e.stopPropagation(),console.debug("set config",t),this.$store.commit("producer/setConfig",{...this.$store.state.producer?.config,model:t.model,custom:!0,instrumental:!1,style:t.style,action:"extend",audio:t,audio_id:t.id,continue_at:t.duration})},onDownload(e,t){e&&e.stopPropagation();const l=new URL(t).pathname,y=l.substring(l.lastIndexOf("/")+1);fetch(t).then(b=>b.blob()).then(b=>{be.saveAs(b,y)})},async handleVideoDownload(e){if(e.video_url){this.onDownload(null,e.video_url);return}if(!this.isFetchingVideoUrl)try{this.isFetchingVideoUrl=!0;const t=await this.fetchVideoUrlFromApi(e?.id);console.log(`get videoUrl: ${t}`),e.video_url=t,this.onDownload(null,t)}catch(t){console.error("get videoUrl failed:",t),k.error(this.$t("producer.message.getVideoUrlFailed"))}finally{this.isFetchingVideoUrl=!1}},async fetchVideoUrlFromApi(e){return new Promise((t,m)=>{const l={audio_id:e},y=this.credential?.token;if(!y){console.error("no token specified"),m(new Error("No token specified"));return}T.video(l,{token:y}).then(b=>{const d=b.data?.data?.video_url;d?t(d):m(new Error("Video URL not found in response"))}).catch(b=>{m(b)})})},onPreview(e,t){e.stopPropagation(),window.open(t,"_blank")},async onGetStems(e){await this.onGenerateAudioUrl("stems",e)},onCover(e){this.$store.commit("producer/setConfig",{...this.$store.state.producer?.config,model:e.model,custom:!0,instrumental:!1,style:e.style,action:"cover",audio:e,audio_id:e.id})},onVariation(e){this.$store.commit("producer/setConfig",{...this.$store.state.producer?.config,model:e.model,custom:!0,style:e.style,action:"variation",audio:e,audio_id:e.id})},async onSwapVocals(e){await this.onGenerateAudioUrl("swap_vocals",e)},async onSwapInstrumentals(e){await this.onGenerateAudioUrl("swap_instrumentals",e)},async onGetAllStems(e){await this.onGenerateAudioUrl("all_stems",e)},onReplaceSection(e){this.$store.commit("producer/setConfig",{...this.$store.state.producer?.config,model:e.model,custom:!0,instrumental:!1,style:e.style,action:"replace_section",audio:e,audio_id:e.id,replace_section_start:0,replace_section_end:Math.min(30,e.duration||30)})},async handleWavDownload(e){if(!e?.id||this.isFetchingWav)return;const t=this.credential?.token;if(t)try{this.isFetchingWav=!0,k.info(this.$t("producer.message.fetchingWav"));const l=(await T.wav({audio_id:e.id},{token:t})).data?.data,y=Array.isArray(l)?l[0]?.file_url:l?.file_url||l?.audio_url;y?this.onDownload(null,y):k.error(this.$t("producer.message.fetchWavFailed"))}catch{k.error(this.$t("producer.message.fetchWavFailed"))}finally{this.isFetchingWav=!1}},async onGenerateAudioUrl(e,t){const m={action:e,audio_id:t,callback_url:ds},l=this.credential?.token;if(!l){console.error("no token specified");return}k.info(this.$t("producer.message.startingTask")),T.audio(m,{token:l}).then(()=>{k.success(this.$t("producer.message.startTaskSuccess"))}).catch(y=>{k.error(y?.response?.data?.error?.message||this.$t("producer.message.startTaskFailed"))}).finally(async()=>{await this.onGetTasks(),await this.onScrollDown()})},async onScrollDown(){setTimeout(()=>{const e=document.querySelector(".tasks");e&&(e.scrollTop=e.scrollHeight)},1e3)},async onGetTasks(){if(this.loading){console.debug("loading");return}await this.$store.dispatch("producer/getTasks",{limit:30,offset:0})}}}),us={class:"task"},ps=["onClick"],ms={class:"left"},fs=["onClick"],hs=["onClick"],_s={key:2,class:"duration"},$s={class:"info"},gs={class:"title"},vs={class:"style"},ys={class:"right"},bs={class:"el-dropdown-link"},ks={class:"flex items-center min-w-[120px]"},ws={class:"flex items-center min-w-[120px]"},Cs={class:"el-dropdown-link"};function Vs(e,t,m,l,y,b){const d=n("el-image"),f=n("video-pause"),h=n("el-icon"),g=n("video-play"),_=n("font-awesome-icon"),P=n("el-tooltip"),$=n("Loading"),C=n("el-dropdown-item"),z=n("el-dropdown-menu"),R=n("el-dropdown"),O=n("api-code-dialog"),W=B("loading");return r(),c("div",us,[(r(!0),c(I,null,j(e.audios,u=>(r(),c("div",{key:u.id,class:"audio",onClick:E(V=>e.onClick(u),["stop"])},[G((r(),c("div",ms,[o(d,{src:u?.image_url,class:"cover",fit:"cover",lazy:""},null,8,["src"]),u?.audio_url&&e.$store.state?.producer?.audio?.id===u.id&&e.$store.state?.producer?.audio?.state==="playing"?(r(),c("div",{key:0,class:"overlay",onClick:E(V=>e.onPause(u),["stop"])},[o(h,null,{default:a(()=>[o(f)]),_:1})],8,fs)):p("",!0),u?.audio_url&&(e.$store.state?.producer?.audio?.id!==u.id||e.$store.state?.producer?.audio?.id===u.id&&e.$store.state?.producer?.audio?.state==="paused")?(r(),c("div",{key:1,class:"overlay",onClick:E(V=>e.onPlay(u),["stop"])},[o(h,null,{default:a(()=>[o(g)]),_:1})],8,hs)):p("",!0),u?.duration?(r(),c("div",_s,i(e.useFormatDuring(u?.duration)),1)):p("",!0)])),[[W,!u?.audio_url]]),s("div",$s,[s("h2",gs,i(u?.title),1),s("p",vs,i(u?.style),1)]),s("div",ys,[o(R,null,{dropdown:a(()=>[o(z,null,{default:a(()=>[o(C,{disabled:e.isFetchingVideoUrl,onClick:V=>e.handleVideoDownload(u)},{default:a(()=>[s("div",ks,[e.isFetchingVideoUrl?(r(),v(h,{key:0,class:"is-loading mr-2"},{default:a(()=>[o($)]),_:1})):p("",!0),s("span",null,i(e.$t("producer.button.download_video")),1)])]),_:1},8,["disabled","onClick"]),u?.audio_url?(r(),v(C,{key:0,onClick:E(V=>e.onDownload(V,u?.audio_url),["stop"])},{default:a(()=>[w(i(e.$t("producer.button.download_audio")),1)]),_:1},8,["onClick"])):p("",!0),o(C,{disabled:e.isFetchingWav,onClick:V=>e.handleWavDownload(u)},{default:a(()=>[s("div",ws,[e.isFetchingWav?(r(),v(h,{key:0,class:"is-loading mr-2"},{default:a(()=>[o($)]),_:1})):p("",!0),s("span",null,i(e.$t("producer.button.download_wav")),1)])]),_:1},8,["disabled","onClick"])]),_:2},1024)]),default:a(()=>[s("span",bs,[o(P,{effect:"dark",content:e.$t("producer.button.download"),placement:"top"},{default:a(()=>[u?.audio_url||u?.video_url?(r(),v(_,{key:0,icon:"fa-solid fa-download",class:"icon icon-download"})):p("",!0)]),_:2},1032,["content"])])]),_:2},1024),o(R,null,{dropdown:a(()=>[o(z,null,{default:a(()=>[u?.audio_url?(r(),v(C,{key:0,onClick:E(V=>e.onExtend(V,u),["stop"])},{default:a(()=>[w(i(e.$t("producer.button.extend")),1)]),_:1},8,["onClick"])):p("",!0),u.id?(r(),v(C,{key:1,onClick:E(V=>e.onGetStems(u.id),["stop"])},{default:a(()=>[w(i(e.$t("producer.button.get_stems")),1)]),_:1},8,["onClick"])):p("",!0),u.id?(r(),v(C,{key:2,onClick:E(V=>e.onGetAllStems(u.id),["stop"])},{default:a(()=>[w(i(e.$t("producer.button.all_stems")),1)]),_:1},8,["onClick"])):p("",!0),o(C,{onClick:E(V=>e.onCover(u),["stop"])},{default:a(()=>[w(i(e.$t("producer.button.cover_music")),1)]),_:1},8,["onClick"]),u?.id?(r(),v(C,{key:3,onClick:E(V=>e.onVariation(u),["stop"])},{default:a(()=>[w(i(e.$t("producer.button.variation")),1)]),_:1},8,["onClick"])):p("",!0),u?.id?(r(),v(C,{key:4,onClick:E(V=>e.onSwapVocals(u.id),["stop"])},{default:a(()=>[w(i(e.$t("producer.button.swap_vocals")),1)]),_:1},8,["onClick"])):p("",!0),u?.id?(r(),v(C,{key:5,onClick:E(V=>e.onSwapInstrumentals(u.id),["stop"])},{default:a(()=>[w(i(e.$t("producer.button.swap_instrumentals")),1)]),_:1},8,["onClick"])):p("",!0),u?.id?(r(),v(C,{key:6,onClick:E(V=>e.onReplaceSection(u),["stop"])},{default:a(()=>[w(i(e.$t("producer.button.replace_section")),1)]),_:1},8,["onClick"])):p("",!0),o(C,{onClick:E(e.onViewCode,["stop"])},{default:a(()=>[o(_,{icon:"fa-solid fa-code",class:"mr-1"}),w(" "+i(e.$t("common.button.viewCode")),1)]),_:1},8,["onClick"])]),_:2},1024)]),default:a(()=>[s("span",Cs,[o(P,{effect:"dark",content:e.$t("producer.button.more"),placement:"top"},{default:a(()=>[u?.audio_url||u?.video_url?(r(),v(_,{key:0,icon:"fa-solid fa-ellipsis",class:"icon icon-ellipsis"})):p("",!0)]),_:2},1032,["content"])])]),_:2},1024)])],8,ps))),128)),o(O,{visible:e.apiCodeVisible,"onUpdate:visible":t[0]||(t[0]=u=>e.apiCodeVisible=u),method:"POST",path:e.apiCodePath,body:e.apiCodeBody,token:e.$store.state.producer?.credential?.token||""},null,8,["visible","path","body","token"])])}const Ss=U(cs,[["render",Vs]]),Us=S({name:"RecentPanel",components:{ElSkeletonItem:Ge,ElSkeleton:Le,TaskPreview:Ss,Player:ke,NoTasks:ye,ScrollList:pe},props:{loading:{type:Boolean,default:!1}},emits:["reach-top"],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.producer?.tasks,items:this.$store.state.producer?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),Ps={key:0,class:"tasks"},Es={class:"left w-[70px] p-[10px] flex items-center"},As={class:"main w-[calc(100%-70px)] flex-1 p-[10px]"},Ts={key:2,class:"w-full flex-1 flex items-center justify-center"},Fs={class:"h-20"};function Is(e,t,m,l,y,b){const d=n("el-skeleton-item"),f=n("el-skeleton"),h=n("task-preview"),g=n("scroll-list"),_=n("no-tasks"),P=n("player");return r(),c(I,null,[e.tasks?.items===void 0?(r(),c("div",Ps,[(r(),c(I,null,j(3,$=>s("div",{key:$,class:"flex"},[s("div",Es,[o(f,{animated:""},{template:a(()=>[o(d,{variant:"image",class:"avatar w-[50px] h-[50px]"})]),_:1})]),s("div",As,[o(f,{animated:""},{template:a(()=>[o(d,{variant:"p",class:"w-[200px] h-[15px] mb-[5px] mt-[10px]"}),o(d,{variant:"text"})]),_:1})])])),64))])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(r(),v(g,{key:1,ref:"scrollList",class:"flex-1 w-full overflow-y-auto tasks p-2",loading:e.loading,onReachTop:t[0]||(t[0]=$=>e.$emit("reach-top"))},{default:a(()=>[(r(!0),c(I,null,j(e.tasks?.items,($,C)=>(r(),v(h,{key:C,"model-value":$,class:"preview"},null,8,["model-value"]))),128))]),_:1},8,["loading"])):p("",!0),e.tasks?.items?.length===0?(r(),c("div",Ts,[o(_)])):p("",!0),G(s("div",Fs,[o(P,{namespace:"producer"})],512),[[ne,!!e.$store?.state?.producer?.audio?.object]])],64)}const Ls=U(Us,[["render",Is]]),Gs=S({name:"TaskPreview",components:{IconPicture:ae,ElImage:D,ElAvatar:De,ElIcon:q},computed:{audio(){return this.$store.state.producer?.audio}}}),Ds={key:0,class:"size-full overflow-hidden"},zs={class:"relative h-[300px]"},Rs={class:"flex items-center justify-center size-full bg-[var(--el-bg-color)]"},Zs={class:"absolute bottom-0 left-0 right-0 m-0 p-4 text-white z-10 bg-gradient-to-t from-black/70 to-transparent"},js={class:"p-4"},Ns={class:"flex items-center font-bold mb-2"},Bs={class:"text-[var(--el-text-color-regular)] mb-2"},qs={class:"text-xs text-[var(--el-text-color-regular)]"},Ms={class:"mt-4 text-sm leading-[25px] whitespace-pre-wrap"},Os={key:1,class:"w-full h-full"};function Ws(e,t,m,l,y,b){const d=n("icon-picture"),f=n("el-icon"),h=n("el-image"),g=n("el-avatar");return e.audio?.object?(r(),c("div",Ds,[s("div",zs,[o(h,{src:e.audio.image_url,fit:"cover",class:"size-full"},{error:a(()=>[s("div",Rs,[o(f,{class:"text-3xl"},{default:a(()=>[o(d)]),_:1})])]),_:1},8,["src"]),s("h2",Zs,i(e.audio?.title),1)]),s("div",js,[s("div",Ns,[o(g,{size:30,src:e.audio?.image_url,class:"mr-2"},null,8,["src"]),s("span",null,i(e.audio?.title),1)]),s("p",Bs,i(e.audio?.style),1),s("p",qs,i(e.$dayjs.format(e.audio?.created_at)),1),s("div",Ms,[s("p",null,i(e.audio?.lyric),1)])])])):(r(),c("div",Os))}const Hs=U(Gs,[["render",Ws]]),Ks=x("producer"),Ys=S({name:"ProducerIndex",components:{Layout:qe,ConfigPanel:ls,RecentPanel:Ls,PreviewPanel:Hs},inject:["initialized"],data(){return{task:void 0,job:0,loadingMore:!1,fetchingTasks:!1}},computed:{applicationsLoading(){return this.$store.state.producer?.status?.getApplications===F.Request},tasksLoading(){return this.$store.state.producer?.status?.getTasks===F.Request||this.fetchingTasks},service(){return this.$store.state.producer.service},credential(){return this.$store.state.producer.credential},config(){return this.$store.state.producer.config},initializing(){return this.$store.state.producer.status.getApplications===F.Request},needApply(){return this.$store.state.producer.status.getApplications===F.Success&&!this.application},application(){return this.$store.state.producer.application},tasks(){return this.$store.state.producer.tasks},applications(){return this.$store.state.producer.applications}},watch:{tasks:{handler(e,t){e?.items?.length>t?.items?.length&&console.debug("new tasks detected")},deep:!0},initialized:{async handler(e){e&&(console.debug("layout initialized"),await this.onGetTasks(),await this.onScrollDown(),this.job=window.setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){window.clearInterval(this.job)},methods:{async onReachTop(){await me({tasks:this.tasks,getTasks:()=>this.tasks,loading:this.loadingMore,setLoading:e=>this.loadingMore=e,isBlocked:()=>this.tasksLoading||this.applicationsLoading,fetch:e=>this.onGetTasks({createdAtMax:e}),getScrollElement:()=>this.getTasksScrollElement()})},async onGetService(){console.debug("start onGetService"),await this.$store.dispatch("producer/getService"),console.debug("end onGetService")},async onGetApplication(){console.debug("start onGetApplications"),await this.$store.dispatch("producer/getApplications"),console.debug("end onGetApplications"),await this.onGetTasks()},onApply(){de.create({application:this.application}).then(({data:e})=>{this.application=e,k.success(this.$t("application.message.applySuccessfully"))}).catch(e=>{e?.response?.data?.code===ce&&k.error(this.$t("application.message.alreadyApplied"))})},async onScrollDown(){await this.$nextTick();const e=this.getTasksScrollElement();e&&(e.scrollTop=e.scrollHeight)},async onGetTasks(e){if(this.applicationsLoading||this.fetchingTasks){console.debug("loading");return}console.debug("start onGetTasks",e);const{limit:t=5,createdAtMin:m,createdAtMax:l}=e||{};console.debug("limit",t,"createdAtMin",m,"createdAtMax",l),this.fetchingTasks=!0;try{await this.$store.dispatch("producer/getTasks",{limit:t,createdAtMin:m,createdAtMax:l})}finally{this.fetchingTasks=!1}},async onGenerateAudio(){const e={...this.config,callback_url:Ks},t=this.credential?.token;if(!t){console.error("no token specified");return}k.info(this.$t("producer.message.startingTask")),le("producer",T.audio(e,{token:t})).then(()=>{k.success(this.$t("producer.message.startTaskSuccess"))}).catch(m=>{k.error(m?.response?.data?.error?.message||this.$t("producer.message.startTaskFailed"))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function Js(e,t,m,l,y,b){const d=n("config-panel"),f=n("recent-panel"),h=n("preview-panel"),g=n("layout");return r(),v(g,null,{config:a(()=>[o(d,{onGenerate:e.onGenerateAudio},null,8,["onGenerate"])]),result:a(()=>[o(f,{ref:"recentPanel",class:"panel recent",loading:e.loadingMore,onReachTop:e.onReachTop},null,8,["loading","onReachTop"])]),preview:a(()=>[o(h)]),_:1})}const er=U(Ys,[["render",Js],["__scopeId","data-v-d6806962"]]);export{er as default};
1
+ import{F as L}from"./index.es-BXrnqbDc.js";import{E as N}from"./index-ByRYubXn.js";import{E as se}from"./index-PMRNSwyk.js";import{d as S,H as c,E as s,z as Z,C as o,y as a,D as n,q as r,F as i,O as I,N as j,J as p,x as v,I as w,G,K as B,M as E,L as ne}from"./vendor-vue-NSDaktjZ.js";import{H as U,bm as re,dG as H,dH as K,X as q,Y as ie,S as F,cq as x,dI as ae,cp as le,o as de}from"./index-BRfbHCvZ.js";import{a as ce}from"./errorCode-Cqj9Td_Z.js";import{p as T}from"./producer-QOy93416.js";import{I as A,A as ue,S as pe,l as me}from"./pagination-BJFvnhlr.js";import{a as fe}from"./producer-BGNC4QeM.js";import{E as he}from"./index-TeXIMvfD.js";import{E as _e,a as $e}from"./index-DfiGO-z3.js";import{E as ee,a as te}from"./index-BYrMMM1u.js";import{E as ge}from"./index-D63t9suS.js";import{E as k}from"./index-B8CSiOhn.js";import{P as ve,N as ye}from"./NoTasks-d_8CfjZ-.js";import{E as M}from"./index-Cf4MWvor.js";import{u as Y,F as be,_ as ke}from"./Player.vue_vue_type_script_setup_true_lang-DpHj4ZkA.js";import{E as J}from"./index-BM28BQge.js";import{E as D}from"./index-CVuadntg.js";import{E as we}from"./index-9TnzSqSo.js";import{E as Ce,a as Ve}from"./index-CCD14HB5.js";import{C as Se}from"./Consumption-BgQfeJho.js";import{a as Ue}from"./price-Be1B_bvo.js";import{E as Pe,a as Ee}from"./index-r8zBJeUr.js";import{E as Ae,b as Te,a as Fe}from"./index-DJVt4Jyx.js";import{E as Ie}from"./index-BZkaFFuw.js";import{a as Le,E as Ge}from"./index-BSKrtLfD.js";import{E as De}from"./index-BYNyqWl4.js";import"./use-form-item-gFrK0FVf.js";import"./index-BuyEbX8F.js";import"./vendor-axios-B8_nURbH.js";import"./vendor-dayjs-v0j1UNZp.js";import"./vendor-vue-router-Df5ITouH.js";import"./highlight-D6Rf8-7-.js";import"./index-BLjywj98.js";import"./vendor-highlight-lEWW1Jxd.js";import"./validator-CRted-PS.js";import"./index-CJozFb-_.js";import"./index-BtOQSaPZ.js";import"./typescript-HOmQr8QU.js";import"./strings-beZM2Y-f.js";import"./isEqual-DdIQEpjm.js";import"./_Uint8Array-BHztG1Lf.js";import"./castArray-CEKtna1X.js";import"./debounce-BzdywqWi.js";import"./_baseIteratee-DawPdq6H.js";import"./index-LSBUkmpR.js";import"./index-BnLROHuz.js";import"./_baseClone-DBPrtxYY.js";import"./_initCloneObject-RQtwP1G5.js";import"./index-zJe4TTTN.js";import"./index-y6L6cZvE.js";import"./dropdown-CqVkry2k.js";import"./index-Cu41y2Fl.js";import"./index-DiX4F22c.js";import"./isPlainObject-CG3miWf6.js";const ze=S({name:"LayoutProducer",components:{ElDrawer:se,ElButton:N,FontAwesomeIcon:L},data(){return{drawer:!1,preview:!1}},computed:{}}),Re={class:"main flex flex-row flex-1"},Ze={class:"config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]"},je={class:"result h-full flex flex-col flex-1 min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]"},Ne={class:"preview h-full w-[300px] flex flex-col"};function Be(e,t,m,l,y,b){const d=n("font-awesome-icon"),f=n("el-button"),h=n("el-drawer");return r(),c("div",Re,[s("div",Ze,[Z(e.$slots,"config",{},void 0,!0)]),s("div",je,[Z(e.$slots,"result",{},void 0,!0)]),s("div",Ne,[Z(e.$slots,"preview",{},void 0,!0)]),o(f,{circle:"",class:"menu",onClick:t[0]||(t[0]=g=>e.drawer=!0)},{default:a(()=>[o(d,{icon:"fa-solid fa-magic"})]),_:1}),o(h,{modelValue:e.drawer,"onUpdate:modelValue":t[1]||(t[1]=g=>e.drawer=g),direction:"ltr","with-header":!1,size:"340px",class:"drawer"},{default:a(()=>[Z(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const qe=U(ze,[["render",Be],["__scopeId","data-v-03e2979b"]]),Me=S({name:"TypeSelector",components:{ElSelect:$e,ElOption:_e,ElSwitch:he,InfoIcon:A},data(){return{options:[{label:"FUZZ-2.0 Pro",value:"FUZZ-2.0 Pro",desc:this.$t("producer.model.fuzz20proDesc")},{label:"FUZZ-2.0",value:"FUZZ-2.0",desc:this.$t("producer.model.fuzz20desc")},{label:"FUZZ-2.0 Raw",value:"FUZZ-2.0 Raw",desc:this.$t("producer.model.fuzz20rawDesc")},{label:"FUZZ-1.1 Pro",value:"FUZZ-1.1 Pro",desc:this.$t("producer.model.fuzz11proDesc")},{label:"FUZZ-1.1",value:"FUZZ-1.1",desc:this.$t("producer.model.fuzz11desc")},{label:"FUZZ-1.0 Pro",value:"FUZZ-1.0 Pro",desc:this.$t("producer.model.fuzz10proDesc")},{label:"FUZZ-1.0",value:"FUZZ-1.0",desc:this.$t("producer.model.fuzz10desc")},{label:"FUZZ-0.8",value:"FUZZ-0.8",desc:this.$t("producer.model.fuzz08desc")}]}},computed:{custom:{get(){return this.$store.state.producer?.config?.custom||!1},set(e){this.$store.commit("producer/setConfig",{...this.$store.state.producer?.config,custom:e})}},instrumental:{get(){return this.$store.state.producer?.config?.instrumental||!1},set(e){this.$store.commit("producer/setConfig",{...this.$store.state.producer?.config,instrumental:e})}},model:{get(){return this.$store.state.producer?.config?.model},set(e){this.$store.commit("producer/setConfig",{...this.$store.state.producer?.config,model:e})}}},mounted(){this.model||(this.model=fe)}}),Oe={class:"mb-3"},We={class:"flex items-center mb-1"},He={class:"text-sm font-bold"},Ke={class:"model-option"},Ye={class:"model-option-name"},Je={class:"model-option-desc"},Xe={key:0,class:"flex items-center justify-between mb-3"},Qe={class:"flex items-center"},xe={class:"text-sm font-bold"};function et(e,t,m,l,y,b){const d=n("el-option"),f=n("el-select"),h=n("info-icon"),g=n("el-switch");return r(),c("div",null,[s("div",Oe,[s("div",We,[s("span",He,i(e.$t("producer.name.model")),1)]),o(f,{modelValue:e.model,"onUpdate:modelValue":t[0]||(t[0]=_=>e.model=_),class:"w-full model-select",size:"default",placeholder:e.$t("producer.placeholder.select")},{default:a(()=>[(r(!0),c(I,null,j(e.options,_=>(r(),v(d,{key:_.value,label:_.label,value:_.value},{default:a(()=>[s("div",Ke,[s("span",Ye,i(_.label),1),s("span",Je,i(_.desc),1)])]),_:2},1032,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])]),e.custom?(r(),c("div",Xe,[s("div",Qe,[s("span",xe,i(e.$t("producer.name.instrumental")),1),o(h,{content:e.$t("producer.description.instrumental")},null,8,["content"])]),o(g,{modelValue:e.instrumental,"onUpdate:modelValue":t[1]||(t[1]=_=>e.instrumental=_)},null,8,["modelValue"])])):p("",!0)])}const tt=U(Me,[["render",et],["__scopeId","data-v-42496b9a"]]),ot=S({name:"UploadAudio",components:{ElUpload:ge,ElButton:N,ElRadioGroup:te,ElRadioButton:ee,InfoIcon:A,FontAwesomeIcon:L},emits:["change"],data(){return{fileList:[],uploadUrl:re()+"/api/v1/files/",audioPreviewUrl:null,uploading:!1}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},credential(){return this.$store.state.producer.credential},config(){return this.$store.state.producer.config},urls(){return this.fileList.map(e=>e?.response?.file_url)},hasUploadedAudio(){const e=this.$store.state.producer?.config?.action;return e==="upload_extend"||e==="upload_cover"},uploadAction:{get(){return this.$store.state.producer?.config?.action||"upload_extend"},set(e){this.$store.commit("producer/setConfig",{...this.$store.state.producer?.config,action:e})}}},watch:{urls:{handler(e){this.$emit("change",e)}}},methods:{onExceed(){k.warning(this.$t("producer.message.uploadReferencesExceed"))},onError(){this.uploading=!1,k.error(this.$t("producer.message.uploadReferencesError"))},async onSuccess(){const e=this.urls?.[0];if(!e){this.uploading=!1;return}this.audioPreviewUrl=e,await this.onGenerateAudioId(e)},async onGenerateAudioId(e){const t={audio_url:e},m=this.credential?.token;if(!m){console.error("no token specified"),this.uploading=!1;return}this.uploading=!0,k.info(this.$t("producer.message.startingUploadAudio"));try{const y=(await T.upload(t,{token:m})).data?.data.audio_id;this.$store.commit("producer/setConfig",{...this.$store.state.producer?.config,audio_id:y,action:"upload_extend"}),k.success(this.$t("producer.message.startUploadAudioSuccess"))}catch(l){k.error(l?.response?.data?.error?.message||this.$t("producer.message.startUploadAudioFailed"))}finally{this.uploading=!1}}}}),st={class:"relative"},nt={class:"flex justify-between items-center mb-2"},rt={class:"flex justify-start items-center"},it={class:"text-sm font-bold"},at={key:0,class:"mb-2"},lt=["src"],dt={key:1,class:"mt-1"};function ct(e,t,m,l,y,b){const d=n("info-icon"),f=n("font-awesome-icon"),h=n("el-button"),g=n("el-upload"),_=n("el-radio-button"),P=n("el-radio-group");return r(),c("div",st,[s("div",nt,[s("div",rt,[s("span",it,i(e.$t("producer.name.referenceAudios")),1),o(d,{content:e.$t("producer.description.uploadAudios")},null,8,["content"])]),o(g,{"file-list":e.fileList,"onUpdate:fileList":t[0]||(t[0]=$=>e.fileList=$),name:"file",limit:1,class:"upload-wrapper inline-upload",action:e.uploadUrl,accept:".mp3,.wav,.m4a,audio/*","show-file-list":!1,"on-exceed":e.onExceed,"on-error":e.onError,"on-success":e.onSuccess,headers:e.headers},{default:a(()=>[o(h,{round:"",type:"primary",size:"small",loading:e.uploading},{default:a(()=>[o(f,{icon:"fa-solid fa-upload",class:"icon mr-1"}),w(" "+i(e.$t("producer.button.uploadAudios")),1)]),_:1},8,["loading"])]),_:1},8,["file-list","action","on-exceed","on-error","on-success","headers"])]),e.audioPreviewUrl?(r(),c("div",at,[s("audio",{src:e.audioPreviewUrl,controls:"",class:"w-full"},null,8,lt)])):p("",!0),e.hasUploadedAudio?(r(),c("div",dt,[o(P,{modelValue:e.uploadAction,"onUpdate:modelValue":t[1]||(t[1]=$=>e.uploadAction=$),size:"small"},{default:a(()=>[o(_,{value:"upload_extend"},{default:a(()=>[w(i(e.$t("producer.button.extend")),1)]),_:1}),o(_,{value:"upload_cover"},{default:a(()=>[w(i(e.$t("producer.button.cover_music")),1)]),_:1})]),_:1},8,["modelValue"])])):p("",!0)])}const ut=U(ot,[["render",ct],["__scopeId","data-v-355e932b"]]),pt="",mt=S({name:"PromptInput",components:{PromptTextarea:ve},computed:{prompt:{get(){return this.$store.state.producer?.config?.prompt},set(e){this.$store.commit("producer/setConfig",{...this.$store.state.producer?.config,prompt:e})}}},mounted(){this.prompt||(this.prompt=pt)}});function ft(e,t,m,l,y,b){const d=n("prompt-textarea");return r(),v(d,{modelValue:e.prompt,"onUpdate:modelValue":t[0]||(t[0]=f=>e.prompt=f),title:e.$t("producer.name.songDescription"),info:e.$t("producer.description.prompt"),placeholder:e.$t("producer.placeholder.prompt"),"min-rows":5,"max-rows":14},null,8,["modelValue","title","info","placeholder"])}const ht=U(mt,[["render",ft]]),_t="",$t=S({name:"LyricInput",components:{ElInput:M,ElButton:N,FontAwesomeIcon:L,InfoIcon:A},data(){return{generatingLyrics:!1}},computed:{lyric:{get(){return this.$store.state.producer?.config?.lyric},set(e){this.$store.commit("producer/setConfig",{...this.$store.state.producer?.config,lyric:e})}},config(){return this.$store.state.producer?.config},credential(){return this.$store.state.producer?.credential}},mounted(){this.lyric||(this.lyric=_t)},methods:{async onGenerateLyrics(){const e=this.credential?.token;if(!e)return;const t=this.config?.style||this.config?.title||"a beautiful song";this.generatingLyrics=!0,k.info(this.$t("producer.message.generatingLyrics"));try{const l=(await T.lyric({prompt:t},{token:e})).data?.data;l?.text&&(this.lyric=l.text,l?.title&&!this.config?.title&&this.$store.commit("producer/setConfig",{...this.$store.state.producer?.config,lyric:l.text,title:l.title}),k.success(this.$t("producer.message.generateLyricsSuccess")))}catch{k.error(this.$t("producer.message.generateLyricsFailed"))}finally{this.generatingLyrics=!1}}}}),gt={class:"field"},vt={class:"flex items-center justify-between mb-1"},yt={class:"flex items-center"},bt={class:"text-sm font-bold"};function kt(e,t,m,l,y,b){const d=n("info-icon"),f=n("font-awesome-icon"),h=n("el-button"),g=n("el-input");return r(),c("div",gt,[s("div",vt,[s("div",yt,[s("span",bt,i(e.$t("producer.name.lyrics")),1),o(d,{content:e.$t("producer.description.lyrics")},null,8,["content"])]),e.config?.action!=="extend"?(r(),v(h,{key:0,size:"small",loading:e.generatingLyrics,round:"",onClick:e.onGenerateLyrics},{default:a(()=>[e.generatingLyrics?p("",!0):(r(),v(f,{key:0,icon:"fa-solid fa-wand-magic-sparkles",class:"mr-1"})),w(" "+i(e.$t("producer.button.generate_lyrics")),1)]),_:1},8,["loading","onClick"])):p("",!0)]),e.config?.action!=="extend"?(r(),v(g,{key:0,modelValue:e.lyric,"onUpdate:modelValue":t[0]||(t[0]=_=>e.lyric=_),rows:5,type:"textarea",class:"lyrics",placeholder:e.$t("producer.placeholder.lyrics")},null,8,["modelValue","placeholder"])):(r(),v(g,{key:1,modelValue:e.lyric,"onUpdate:modelValue":t[1]||(t[1]=_=>e.lyric=_),rows:5,type:"textarea",class:"lyrics",placeholder:e.$t("producer.placeholder.extend.lyrics")},null,8,["modelValue","placeholder"]))])}const wt=U($t,[["render",kt],["__scopeId","data-v-88c6da2b"]]),Ct=S({name:"StyleInput",components:{ElInput:M,InfoIcon:A},computed:{style:{get(){return this.$store.state.producer?.config?.style},set(e){this.$store.commit("producer/setConfig",{...this.$store.state.producer?.config,style:e})}}}}),Vt={class:"field"},St={class:"flex items-center justify-between mb-1"},Ut={class:"flex items-center"},Pt={class:"text-sm font-bold"};function Et(e,t,m,l,y,b){const d=n("info-icon"),f=n("el-input");return r(),c("div",Vt,[s("div",St,[s("div",Ut,[s("span",Pt,i(e.$t("producer.name.style")),1),o(d,{content:e.$t("producer.description.style")},null,8,["content"])])]),o(f,{modelValue:e.style,"onUpdate:modelValue":t[0]||(t[0]=h=>e.style=h),rows:2,type:"textarea",placeholder:e.$t("producer.placeholder.style")},null,8,["modelValue","placeholder"])])}const At=U(Ct,[["render",Et]]),Tt=S({name:"TitleInput",components:{ElInput:M,InfoIcon:A},computed:{title:{get(){return this.$store.state.producer?.config?.title},set(e){this.$store.commit("producer/setConfig",{...this.$store.state.producer?.config,title:e})}}}}),Ft={class:"field"},It={class:"flex items-center mb-1"},Lt={class:"text-sm font-bold"};function Gt(e,t,m,l,y,b){const d=n("info-icon"),f=n("el-input");return r(),c("div",Ft,[s("div",It,[s("span",Lt,i(e.$t("producer.name.title")),1),o(d,{content:e.$t("producer.description.title")},null,8,["content"])]),o(f,{modelValue:e.title,"onUpdate:modelValue":t[0]||(t[0]=h=>e.title=h),placeholder:e.$t("producer.placeholder.title")},null,8,["modelValue","placeholder"])])}const Dt=U(Tt,[["render",Gt]]),zt=S({name:"ExtendFromInput",components:{ElImage:D,ElIcon:q,ElInputNumber:J,VideoPlay:K,VideoPause:H},data(){return{}},computed:{audio(){return this.$store.state.producer?.config?.audio},value:{get(){return this.$store.state.producer?.config?.continue_at},set(e){console.debug("set continue_at",e),this.$store.commit("producer/setConfig",{...this.$store.state.producer?.config,continue_at:e?parseInt(e):void 0})}}},mounted(){this.value||(this.value=void 0)},methods:{handleChange(e){if(e===void 0){this.value=void 0;return}e<0?this.value=0:e>this.audio?.duration?this.value=this.audio?.duration:this.value=e},useFormatDuring:Y,onPlay(e){this.$store.dispatch("producer/setAudio",{...this.$store.state.producer.audio,...e,state:"playing"}),console.log("on play")},onPause(e){this.$store.dispatch("producer/setAudio",{...this.$store.state.producer.audio,...e,state:"paused"}),console.log("on pause")},onClick(e){this.$store.state?.producer?.audio?.id!==e.id&&this.onPlay({...e,progress:0})}}}),Rt={class:"field"},Zt={class:"box"},jt={class:"title font-bold"},Nt={class:"input-wrapper"},Bt={class:"task"},qt={class:"left"},Mt={key:2,class:"duration"},Ot={class:"info"},Wt={class:"title"},Ht={class:"style"};function Kt(e,t,m,l,y,b){const d=n("el-input-number"),f=n("el-image"),h=n("video-pause"),g=n("el-icon"),_=n("video-play"),P=B("loading");return r(),c("div",Rt,[s("div",Zt,[s("h2",jt,i(e.$t("producer.name.extend")),1),s("div",Nt,[o(d,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=$=>e.value=$),class:"value",min:0,max:e.audio?.duration,controls:!1,placeholder:e.$t("producer.placeholder.extend.continue_at"),onChange:e.handleChange},null,8,["modelValue","max","placeholder","onChange"])])]),s("div",Bt,[e.audio?(r(),c("div",{key:0,class:"audio",onClick:t[3]||(t[3]=$=>e.onClick(e.audio))},[G((r(),c("div",qt,[o(f,{src:e.audio?.image_url,class:"cover",fit:"cover"},null,8,["src"]),e.audio?.audio_url&&e.$store.state?.producer?.audio?.id===e.audio.id&&e.$store.state?.producer?.audio?.state==="playing"?(r(),c("div",{key:0,class:"overlay",onClick:t[1]||(t[1]=$=>e.onPause(e.audio))},[o(g,null,{default:a(()=>[o(h)]),_:1})])):p("",!0),e.audio?.audio_url&&(e.$store.state?.producer?.audio?.id!==e.audio.id||e.$store.state?.producer?.audio?.id===e.audio.id&&e.$store.state?.producer?.audio?.state==="paused")?(r(),c("div",{key:1,class:"overlay",onClick:t[2]||(t[2]=$=>e.onPlay(e.audio))},[o(g,null,{default:a(()=>[o(_)]),_:1})])):p("",!0),e.audio?.duration?(r(),c("div",Mt,i(e.useFormatDuring(e.audio?.duration)),1)):p("",!0)])),[[P,!e.audio?.audio_url]]),s("div",Ot,[s("h2",Wt,i(e.audio?.title),1),s("p",Ht,i(e.audio?.style),1)])])):p("",!0)])])}const Yt=U(zt,[["render",Kt],["__scopeId","data-v-26d43480"]]),Jt=S({name:"CoverFromInput",components:{ElImage:D,ElIcon:q,VideoPlay:K,VideoPause:H},data(){return{}},computed:{audio(){return this.$store.state.producer?.config?.audio},value:{get(){return this.$store.state.producer?.config?.continue_at},set(e){console.debug("set continue_at",e),this.$store.commit("producer/setConfig",{...this.$store.state.producer?.config,continue_at:e?parseInt(e):void 0})}}},mounted(){this.value||(this.value=void 0)},methods:{handleChange(e){e<0?this.value=0:e>this.audio?.duration?this.value=this.audio?.duration:this.value=e},useFormatDuring:Y,onPlay(e){this.$store.dispatch("producer/setAudio",{...this.$store.state.producer.audio,...e,state:"playing"}),console.log("on play")},onPause(e){this.$store.dispatch("producer/setAudio",{...this.$store.state.producer.audio,...e,state:"paused"}),console.log("on pause")},onClick(e){this.$store.state?.producer?.audio?.id!==e.id&&this.onPlay({...e,progress:0})}}}),Xt={class:"field"},Qt={class:"box"},xt={class:"title font-bold"},eo={class:"task"},to={class:"left"},oo={key:2,class:"duration"},so={class:"info"},no={class:"title"},ro={class:"style"};function io(e,t,m,l,y,b){const d=n("el-image"),f=n("video-pause"),h=n("el-icon"),g=n("video-play"),_=B("loading");return r(),c("div",Xt,[s("div",Qt,[s("h2",xt,i(e.$t("producer.name.cover")),1)]),s("div",eo,[e.audio?(r(),c("div",{key:0,class:"audio",onClick:t[2]||(t[2]=P=>e.onClick(e.audio))},[G((r(),c("div",to,[o(d,{src:e.audio?.image_url,class:"cover",fit:"cover"},null,8,["src"]),e.audio?.audio_url&&e.$store.state?.producer?.audio?.id===e.audio.id&&e.$store.state?.producer?.audio?.state==="playing"?(r(),c("div",{key:0,class:"overlay",onClick:t[0]||(t[0]=P=>e.onPause(e.audio))},[o(h,null,{default:a(()=>[o(f)]),_:1})])):p("",!0),e.audio?.audio_url&&(e.$store.state?.producer?.audio?.id!==e.audio.id||e.$store.state?.producer?.audio?.id===e.audio.id&&e.$store.state?.producer?.audio?.state==="paused")?(r(),c("div",{key:1,class:"overlay",onClick:t[1]||(t[1]=P=>e.onPlay(e.audio))},[o(h,null,{default:a(()=>[o(g)]),_:1})])):p("",!0),e.audio?.duration?(r(),c("div",oo,i(e.useFormatDuring(e.audio?.duration)),1)):p("",!0)])),[[_,!e.audio?.audio_url]]),s("div",so,[s("h2",no,i(e.audio?.title),1),s("p",ro,i(e.audio?.style),1)])])):p("",!0)])])}const ao=U(Jt,[["render",io],["__scopeId","data-v-d8a8e583"]]),lo=S({name:"VocalGenderSelector",components:{ElRadioGroup:te,ElRadioButton:ee,InfoIcon:A},computed:{vocalGender:{get(){return this.$store.state.producer?.config?.vocal_gender||""},set(e){this.$store.commit("producer/setConfig",{...this.$store.state.producer?.config,vocal_gender:e||void 0})}}}}),co={class:"mb-2"},uo={class:"flex items-center mb-1"},po={class:"text-sm font-bold"};function mo(e,t,m,l,y,b){const d=n("info-icon"),f=n("el-radio-button"),h=n("el-radio-group");return r(),c("div",co,[s("div",uo,[s("span",po,i(e.$t("producer.name.vocalGender")),1),o(d,{content:e.$t("producer.description.vocalGender")},null,8,["content"])]),o(h,{modelValue:e.vocalGender,"onUpdate:modelValue":t[0]||(t[0]=g=>e.vocalGender=g)},{default:a(()=>[o(f,{value:""},{default:a(()=>[w(i(e.$t("producer.gender.auto")),1)]),_:1}),o(f,{value:"f"},{default:a(()=>[w(i(e.$t("producer.gender.female")),1)]),_:1}),o(f,{value:"m"},{default:a(()=>[w(i(e.$t("producer.gender.male")),1)]),_:1})]),_:1},8,["modelValue"])])}const fo=U(lo,[["render",mo]]),ho=S({name:"AdvancedParams",components:{ElCollapse:Ve,ElCollapseItem:Ce,ElInput:M,ElSlider:we,ElInputNumber:J,InfoIcon:A},data(){return{activeNames:[]}},computed:{config(){return this.$store.state.producer?.config},styleNegative:{get(){return this.$store.state.producer?.config?.style_negative||""},set(e){this.$store.commit("producer/setConfig",{...this.$store.state.producer?.config,style_negative:e||void 0})}},lyricPrompt:{get(){return this.$store.state.producer?.config?.lyric_prompt||""},set(e){this.$store.commit("producer/setConfig",{...this.$store.state.producer?.config,lyric_prompt:e||void 0})}},weirdness:{get(){return this.$store.state.producer?.config?.weirdness??50},set(e){this.$store.commit("producer/setConfig",{...this.$store.state.producer?.config,weirdness:e})}},soundStrength:{get(){return this.$store.state.producer?.config?.sound_strength??50},set(e){this.$store.commit("producer/setConfig",{...this.$store.state.producer?.config,sound_strength:e})}},lyricsStrength:{get(){return this.$store.state.producer?.config?.lyrics_strength??50},set(e){this.$store.commit("producer/setConfig",{...this.$store.state.producer?.config,lyrics_strength:e})}},seed:{get(){return this.$store.state.producer?.config?.seed},set(e){this.$store.commit("producer/setConfig",{...this.$store.state.producer?.config,seed:e})}}}}),_o={key:0,class:"mb-3"},$o={class:"flex items-center mb-1"},go={class:"text-xs font-bold"},vo={key:1,class:"mb-3"},yo={class:"flex items-center mb-1"},bo={class:"text-xs font-bold"},ko={class:"mb-3"},wo={class:"flex items-center justify-between mb-1"},Co={class:"flex items-center"},Vo={class:"text-xs font-bold"},So={class:"text-xs text-[var(--el-text-color-secondary)]"},Uo={class:"mb-3"},Po={class:"flex items-center justify-between mb-1"},Eo={class:"flex items-center"},Ao={class:"text-xs font-bold"},To={class:"text-xs text-[var(--el-text-color-secondary)]"},Fo={key:2,class:"mb-3"},Io={class:"flex items-center justify-between mb-1"},Lo={class:"flex items-center"},Go={class:"text-xs font-bold"},Do={class:"text-xs text-[var(--el-text-color-secondary)]"},zo={class:"mb-3"},Ro={class:"flex items-center mb-1"},Zo={class:"text-xs font-bold"};function jo(e,t,m,l,y,b){const d=n("info-icon"),f=n("el-input"),h=n("el-slider"),g=n("el-input-number"),_=n("el-collapse-item"),P=n("el-collapse");return r(),v(P,{modelValue:e.activeNames,"onUpdate:modelValue":t[6]||(t[6]=$=>e.activeNames=$),class:"advanced-collapse"},{default:a(()=>[o(_,{title:e.$t("producer.name.advancedParams"),name:"advanced"},{default:a(()=>[e.config?.custom?(r(),c("div",_o,[s("div",$o,[s("span",go,i(e.$t("producer.name.styleNegative")),1),o(d,{content:e.$t("producer.description.styleNegative")},null,8,["content"])]),o(f,{modelValue:e.styleNegative,"onUpdate:modelValue":t[0]||(t[0]=$=>e.styleNegative=$),size:"small",placeholder:e.$t("producer.placeholder.styleNegative")},null,8,["modelValue","placeholder"])])):p("",!0),e.config?.custom&&!e.config?.instrumental?(r(),c("div",vo,[s("div",yo,[s("span",bo,i(e.$t("producer.name.lyricPrompt")),1),o(d,{content:e.$t("producer.description.lyricPrompt")},null,8,["content"])]),o(f,{modelValue:e.lyricPrompt,"onUpdate:modelValue":t[1]||(t[1]=$=>e.lyricPrompt=$),size:"small",placeholder:e.$t("producer.placeholder.lyricPrompt")},null,8,["modelValue","placeholder"])])):p("",!0),s("div",ko,[s("div",wo,[s("div",Co,[s("span",Vo,i(e.$t("producer.name.weirdness")),1),o(d,{content:e.$t("producer.description.weirdness")},null,8,["content"])]),s("span",So,i(e.weirdness??50),1)]),o(h,{modelValue:e.weirdness,"onUpdate:modelValue":t[2]||(t[2]=$=>e.weirdness=$),min:0,max:100,step:1},null,8,["modelValue"])]),s("div",Uo,[s("div",Po,[s("div",Eo,[s("span",Ao,i(e.$t("producer.name.soundStrength")),1),o(d,{content:e.$t("producer.description.soundStrength")},null,8,["content"])]),s("span",To,i(e.soundStrength??50),1)]),o(h,{modelValue:e.soundStrength,"onUpdate:modelValue":t[3]||(t[3]=$=>e.soundStrength=$),min:0,max:100,step:1},null,8,["modelValue"])]),e.config?.custom&&!e.config?.instrumental?(r(),c("div",Fo,[s("div",Io,[s("div",Lo,[s("span",Go,i(e.$t("producer.name.lyricsStrength")),1),o(d,{content:e.$t("producer.description.lyricsStrength")},null,8,["content"])]),s("span",Do,i(e.lyricsStrength??50),1)]),o(h,{modelValue:e.lyricsStrength,"onUpdate:modelValue":t[4]||(t[4]=$=>e.lyricsStrength=$),min:0,max:100,step:1},null,8,["modelValue"])])):p("",!0),s("div",zo,[s("div",Ro,[s("span",Zo,i(e.$t("producer.name.seed")),1),o(d,{content:e.$t("producer.description.seed")},null,8,["content"])]),o(g,{modelValue:e.seed,"onUpdate:modelValue":t[5]||(t[5]=$=>e.seed=$),min:0,controls:!1,size:"small",placeholder:e.$t("producer.placeholder.seed"),class:"w-full"},null,8,["modelValue","placeholder"])])]),_:1},8,["title"])]),_:1},8,["modelValue"])}const No=U(ho,[["render",jo],["__scopeId","data-v-44ad862b"]]),Bo=S({name:"ReplaceSectionInput",components:{ElInputNumber:J,ElImage:D,InfoIcon:A},computed:{audio(){return this.$store.state.producer?.config?.audio},replaceSectionStart:{get(){return this.$store.state.producer?.config?.replace_section_start},set(e){this.$store.commit("producer/setConfig",{...this.$store.state.producer?.config,replace_section_start:e})}},replaceSectionEnd:{get(){return this.$store.state.producer?.config?.replace_section_end},set(e){this.$store.commit("producer/setConfig",{...this.$store.state.producer?.config,replace_section_end:e})}}},methods:{onClick(e){this.$store.dispatch("producer/setAudio",{...this.$store.state.producer.audio,...e,state:"playing"})}}}),qo={class:"field"},Mo={class:"flex items-center mb-2"},Oo={class:"text-sm font-bold m-0"},Wo={key:0,class:"task mb-2"},Ho={class:"left relative w-[50px] h-[50px] mr-3 flex-shrink-0"},Ko={class:"info flex-1 min-w-0"},Yo={class:"text-sm font-bold m-0 truncate"},Jo={class:"text-xs text-[var(--el-text-color-secondary)] m-0 truncate"},Xo={class:"flex gap-2"};function Qo(e,t,m,l,y,b){const d=n("info-icon"),f=n("el-image"),h=n("el-input-number"),g=B("loading");return r(),c("div",qo,[s("div",Mo,[s("h2",Oo,i(e.$t("producer.name.replaceSection")),1),o(d,{content:e.$t("producer.description.replaceSection")},null,8,["content"])]),e.audio?(r(),c("div",Wo,[s("div",{class:"audio flex items-center",onClick:t[0]||(t[0]=_=>e.onClick(e.audio))},[G((r(),c("div",Ho,[o(f,{src:e.audio?.image_url,class:"w-full h-full rounded",fit:"cover"},null,8,["src"])])),[[g,!e.audio?.audio_url]]),s("div",Ko,[s("h2",Yo,i(e.audio?.title),1),s("p",Jo,i(e.audio?.style),1)])])])):p("",!0),s("div",Xo,[o(h,{modelValue:e.replaceSectionStart,"onUpdate:modelValue":t[1]||(t[1]=_=>e.replaceSectionStart=_),class:"flex-1",min:0,max:e.audio?.duration,controls:!1,placeholder:e.$t("producer.placeholder.replaceSectionStart")},null,8,["modelValue","max","placeholder"]),o(h,{modelValue:e.replaceSectionEnd,"onUpdate:modelValue":t[2]||(t[2]=_=>e.replaceSectionEnd=_),class:"flex-1",min:e.replaceSectionStart||0,max:e.audio?.duration,controls:!1,placeholder:e.$t("producer.placeholder.replaceSectionEnd")},null,8,["modelValue","min","max","placeholder"])])])}const xo=U(Bo,[["render",Qo]]),es=S({name:"PresetPanel",components:{TypeSelector:tt,PromptInput:ht,LyricInput:wt,StyleInput:At,TitleInput:Dt,ExtendFromInput:Yt,CoverFromInput:ao,UploadAudio:ut,VocalGenderSelector:fo,AdvancedParams:No,ReplaceSectionInput:xo,FontAwesomeIcon:L,ElButton:N,ElTabs:Ee,ElTabPane:Pe,Consumption:Se},emits:["generate"],computed:{config(){return this.$store.state.producer?.config},mode:{get(){return this.$store.state.producer?.config?.custom?"custom":"simple"},set(e){this.$store.commit("producer/setConfig",{...this.$store.state.producer?.config,custom:e==="custom"})}},consumption(){return Ue(this.config,this.service?.cost)},service(){return this.$store.state.producer?.service},generateButtonText(){const e=this.config?.action;return e==="extend"||e==="upload_extend"?this.$t("producer.button.extend"):e==="cover"||e==="upload_cover"?this.$t("producer.button.cover_music"):e==="variation"?this.$t("producer.button.variation"):e==="replace_section"?this.$t("producer.button.replace_section"):e==="stems"?this.$t("producer.button.get_stems"):e==="swap_vocals"?this.$t("producer.button.swap_vocals"):e==="swap_instrumentals"?this.$t("producer.button.swap_instrumentals"):this.$t("producer.button.generate")}},methods:{onGenerate(){this.$emit("generate")},onClearAll(){this.$store.commit("producer/setConfig",{custom:this.$store.state.producer?.config?.custom||!1,instrumental:!1,prompt:"",lyric:"",style:"",title:"",model:this.$store.state.producer?.config?.model})}}}),ts={class:"flex flex-col h-full"},os={class:"flex-1 overflow-y-auto p-5"},ss={class:"pt-2 px-1"},ns={class:"pt-2 px-1"},rs={class:"flex flex-col items-center justify-center px-5 pb-5 gap-2"},is={class:"flex gap-2 w-full"};function as(e,t,m,l,y,b){const d=n("type-selector"),f=n("upload-audio"),h=n("prompt-input"),g=n("extend-from-input"),_=n("cover-from-input"),P=n("replace-section-input"),$=n("advanced-params"),C=n("el-tab-pane"),z=n("lyric-input"),R=n("style-input"),O=n("title-input"),W=n("vocal-gender-selector"),u=n("el-tabs"),V=n("consumption"),X=n("font-awesome-icon"),Q=n("el-button");return r(),c("div",ts,[s("div",os,[o(u,{modelValue:e.mode,"onUpdate:modelValue":t[0]||(t[0]=oe=>e.mode=oe),class:"producer-mode-tabs",stretch:""},{default:a(()=>[o(C,{label:e.$t("producer.mode.simple"),name:"simple"},{default:a(()=>[s("div",ss,[o(d,{class:"mb-4"}),o(f,{class:"mb-4"}),o(h,{class:"mb-4"}),e.config?.action==="extend"?(r(),v(g,{key:0,class:"mb-4"})):p("",!0),e.config?.action==="cover"?(r(),v(_,{key:1,class:"mb-4"})):p("",!0),e.config?.action==="replace_section"?(r(),v(P,{key:2,class:"mb-4"})):p("",!0),o($,{class:"mb-4"})])]),_:1},8,["label"]),o(C,{label:e.$t("producer.mode.custom"),name:"custom"},{default:a(()=>[s("div",ns,[o(d,{class:"mb-4"}),o(f,{class:"mb-4"}),e.config?.instrumental?p("",!0):(r(),v(z,{key:0,class:"mb-4"})),o(R,{class:"mb-4"}),o(O,{class:"mb-4"}),e.config?.instrumental?p("",!0):(r(),v(W,{key:1,class:"mb-4"})),e.config?.action==="extend"?(r(),v(g,{key:2,class:"mb-4"})):p("",!0),e.config?.action==="cover"?(r(),v(_,{key:3,class:"mb-4"})):p("",!0),e.config?.action==="replace_section"?(r(),v(P,{key:4,class:"mb-4"})):p("",!0),o($,{class:"mb-4"})])]),_:1},8,["label"])]),_:1},8,["modelValue"])]),s("div",rs,[o(V,{value:e.consumption,service:e.service},null,8,["value","service"]),s("div",is,[o(Q,{class:"flex-1",onClick:e.onClearAll},{default:a(()=>[o(X,{icon:"fa-solid fa-broom",class:"mr-1"}),w(" "+i(e.$t("producer.button.clear_all")),1)]),_:1},8,["onClick"]),o(Q,{type:"primary",class:"flex-1",round:"",onClick:e.onGenerate},{default:a(()=>[o(X,{icon:"fa-solid fa-magic",class:"mr-2"}),w(" "+i(e.generateButtonText),1)]),_:1},8,["onClick"])])])])}const ls=U(es,[["render",as],["__scopeId","data-v-4a4b209e"]]),ds=x("producer"),cs=S({name:"TaskPreview",components:{ElImage:D,ElIcon:q,ElTooltip:Ie,FontAwesomeIcon:L,VideoPlay:K,VideoPause:H,ElDropdown:Fe,ElDropdownMenu:Te,ElDropdownItem:Ae,Loading:ie,ApiCodeDialog:ue},props:{modelValue:{type:Object,required:!0}},data(){return{isFetchingVideoUrl:!1,isFetchingWav:!1,apiCodeVisible:!1,apiCodePath:"/producer/audios",apiCodeBody:{}}},computed:{loading(){return this.$store.state.producer?.status?.getApplications===F.Request},credential(){return this.$store.state.producer.credential},config(){return this.$store.state.producer.config},task(){return this.$store.state.producer?.tasks},audios(){const e=this.modelValue?.response?.data??[],t=this.modelValue?.request?.action;return t?e.map(m=>({...m,action:t})):e},application(){return this.$store.state.producer?.application},active(){return this.$store.state.producer?.tasks?.active}},methods:{useFormatDuring:Y,onViewCode(){const e=this.modelValue?.request||{},t={};Object.entries(e).forEach(([m,l])=>{m==="application_id"||m==="callback_url"||l!=null&&(typeof l=="string"&&l===""||Array.isArray(l)&&l.length===0||(t[m]=l))}),this.apiCodeBody=t,this.apiCodePath="/producer/audios",this.apiCodeVisible=!0},onPlay(e){this.$store.dispatch("producer/setAudio",{...this.$store.state.producer.audio,...e,state:"playing"}),console.log("on play")},onPause(e){this.$store.dispatch("producer/setAudio",{...this.$store.state.producer.audio,...e,state:"paused"}),console.log("on pause")},onClick(e){this.$store.state?.producer?.audio?.id!==e.id&&this.onPlay({...e,progress:0})},onExtend(e,t){e.stopPropagation(),console.debug("set config",t),this.$store.commit("producer/setConfig",{...this.$store.state.producer?.config,model:t.model,custom:!0,instrumental:!1,style:t.style,action:"extend",audio:t,audio_id:t.id,continue_at:t.duration})},onDownload(e,t){e&&e.stopPropagation();const l=new URL(t).pathname,y=l.substring(l.lastIndexOf("/")+1);fetch(t).then(b=>b.blob()).then(b=>{be.saveAs(b,y)})},async handleVideoDownload(e){if(e.video_url){this.onDownload(null,e.video_url);return}if(!this.isFetchingVideoUrl)try{this.isFetchingVideoUrl=!0;const t=await this.fetchVideoUrlFromApi(e?.id);console.log(`get videoUrl: ${t}`),e.video_url=t,this.onDownload(null,t)}catch(t){console.error("get videoUrl failed:",t),k.error(this.$t("producer.message.getVideoUrlFailed"))}finally{this.isFetchingVideoUrl=!1}},async fetchVideoUrlFromApi(e){return new Promise((t,m)=>{const l={audio_id:e},y=this.credential?.token;if(!y){console.error("no token specified"),m(new Error("No token specified"));return}T.video(l,{token:y}).then(b=>{const d=b.data?.data?.video_url;d?t(d):m(new Error("Video URL not found in response"))}).catch(b=>{m(b)})})},onPreview(e,t){e.stopPropagation(),window.open(t,"_blank")},async onGetStems(e){await this.onGenerateAudioUrl("stems",e)},onCover(e){this.$store.commit("producer/setConfig",{...this.$store.state.producer?.config,model:e.model,custom:!0,instrumental:!1,style:e.style,action:"cover",audio:e,audio_id:e.id})},onVariation(e){this.$store.commit("producer/setConfig",{...this.$store.state.producer?.config,model:e.model,custom:!0,style:e.style,action:"variation",audio:e,audio_id:e.id})},async onSwapVocals(e){await this.onGenerateAudioUrl("swap_vocals",e)},async onSwapInstrumentals(e){await this.onGenerateAudioUrl("swap_instrumentals",e)},async onGetAllStems(e){await this.onGenerateAudioUrl("all_stems",e)},onReplaceSection(e){this.$store.commit("producer/setConfig",{...this.$store.state.producer?.config,model:e.model,custom:!0,instrumental:!1,style:e.style,action:"replace_section",audio:e,audio_id:e.id,replace_section_start:0,replace_section_end:Math.min(30,e.duration||30)})},async handleWavDownload(e){if(!e?.id||this.isFetchingWav)return;const t=this.credential?.token;if(t)try{this.isFetchingWav=!0,k.info(this.$t("producer.message.fetchingWav"));const l=(await T.wav({audio_id:e.id},{token:t})).data?.data,y=Array.isArray(l)?l[0]?.file_url:l?.file_url||l?.audio_url;y?this.onDownload(null,y):k.error(this.$t("producer.message.fetchWavFailed"))}catch{k.error(this.$t("producer.message.fetchWavFailed"))}finally{this.isFetchingWav=!1}},async onGenerateAudioUrl(e,t){const m={action:e,audio_id:t,callback_url:ds},l=this.credential?.token;if(!l){console.error("no token specified");return}k.info(this.$t("producer.message.startingTask")),T.audio(m,{token:l}).then(()=>{k.success(this.$t("producer.message.startTaskSuccess"))}).catch(y=>{k.error(y?.response?.data?.error?.message||this.$t("producer.message.startTaskFailed"))}).finally(async()=>{await this.onGetTasks(),await this.onScrollDown()})},async onScrollDown(){setTimeout(()=>{const e=document.querySelector(".tasks");e&&(e.scrollTop=e.scrollHeight)},1e3)},async onGetTasks(){if(this.loading){console.debug("loading");return}await this.$store.dispatch("producer/getTasks",{limit:30,offset:0})}}}),us={class:"task"},ps=["onClick"],ms={class:"left"},fs=["onClick"],hs=["onClick"],_s={key:2,class:"duration"},$s={class:"info"},gs={class:"title"},vs={class:"style"},ys={class:"right"},bs={class:"el-dropdown-link"},ks={class:"flex items-center min-w-[120px]"},ws={class:"flex items-center min-w-[120px]"},Cs={class:"el-dropdown-link"};function Vs(e,t,m,l,y,b){const d=n("el-image"),f=n("video-pause"),h=n("el-icon"),g=n("video-play"),_=n("font-awesome-icon"),P=n("el-tooltip"),$=n("Loading"),C=n("el-dropdown-item"),z=n("el-dropdown-menu"),R=n("el-dropdown"),O=n("api-code-dialog"),W=B("loading");return r(),c("div",us,[(r(!0),c(I,null,j(e.audios,u=>(r(),c("div",{key:u.id,class:"audio",onClick:E(V=>e.onClick(u),["stop"])},[G((r(),c("div",ms,[o(d,{src:u?.image_url,class:"cover",fit:"cover",lazy:""},null,8,["src"]),u?.audio_url&&e.$store.state?.producer?.audio?.id===u.id&&e.$store.state?.producer?.audio?.state==="playing"?(r(),c("div",{key:0,class:"overlay",onClick:E(V=>e.onPause(u),["stop"])},[o(h,null,{default:a(()=>[o(f)]),_:1})],8,fs)):p("",!0),u?.audio_url&&(e.$store.state?.producer?.audio?.id!==u.id||e.$store.state?.producer?.audio?.id===u.id&&e.$store.state?.producer?.audio?.state==="paused")?(r(),c("div",{key:1,class:"overlay",onClick:E(V=>e.onPlay(u),["stop"])},[o(h,null,{default:a(()=>[o(g)]),_:1})],8,hs)):p("",!0),u?.duration?(r(),c("div",_s,i(e.useFormatDuring(u?.duration)),1)):p("",!0)])),[[W,!u?.audio_url]]),s("div",$s,[s("h2",gs,i(u?.title),1),s("p",vs,i(u?.style),1)]),s("div",ys,[o(R,null,{dropdown:a(()=>[o(z,null,{default:a(()=>[o(C,{disabled:e.isFetchingVideoUrl,onClick:V=>e.handleVideoDownload(u)},{default:a(()=>[s("div",ks,[e.isFetchingVideoUrl?(r(),v(h,{key:0,class:"is-loading mr-2"},{default:a(()=>[o($)]),_:1})):p("",!0),s("span",null,i(e.$t("producer.button.download_video")),1)])]),_:1},8,["disabled","onClick"]),u?.audio_url?(r(),v(C,{key:0,onClick:E(V=>e.onDownload(V,u?.audio_url),["stop"])},{default:a(()=>[w(i(e.$t("producer.button.download_audio")),1)]),_:1},8,["onClick"])):p("",!0),o(C,{disabled:e.isFetchingWav,onClick:V=>e.handleWavDownload(u)},{default:a(()=>[s("div",ws,[e.isFetchingWav?(r(),v(h,{key:0,class:"is-loading mr-2"},{default:a(()=>[o($)]),_:1})):p("",!0),s("span",null,i(e.$t("producer.button.download_wav")),1)])]),_:1},8,["disabled","onClick"])]),_:2},1024)]),default:a(()=>[s("span",bs,[o(P,{effect:"dark",content:e.$t("producer.button.download"),placement:"top"},{default:a(()=>[u?.audio_url||u?.video_url?(r(),v(_,{key:0,icon:"fa-solid fa-download",class:"icon icon-download"})):p("",!0)]),_:2},1032,["content"])])]),_:2},1024),o(R,null,{dropdown:a(()=>[o(z,null,{default:a(()=>[u?.audio_url?(r(),v(C,{key:0,onClick:E(V=>e.onExtend(V,u),["stop"])},{default:a(()=>[w(i(e.$t("producer.button.extend")),1)]),_:1},8,["onClick"])):p("",!0),u.id?(r(),v(C,{key:1,onClick:E(V=>e.onGetStems(u.id),["stop"])},{default:a(()=>[w(i(e.$t("producer.button.get_stems")),1)]),_:1},8,["onClick"])):p("",!0),u.id?(r(),v(C,{key:2,onClick:E(V=>e.onGetAllStems(u.id),["stop"])},{default:a(()=>[w(i(e.$t("producer.button.all_stems")),1)]),_:1},8,["onClick"])):p("",!0),o(C,{onClick:E(V=>e.onCover(u),["stop"])},{default:a(()=>[w(i(e.$t("producer.button.cover_music")),1)]),_:1},8,["onClick"]),u?.id?(r(),v(C,{key:3,onClick:E(V=>e.onVariation(u),["stop"])},{default:a(()=>[w(i(e.$t("producer.button.variation")),1)]),_:1},8,["onClick"])):p("",!0),u?.id?(r(),v(C,{key:4,onClick:E(V=>e.onSwapVocals(u.id),["stop"])},{default:a(()=>[w(i(e.$t("producer.button.swap_vocals")),1)]),_:1},8,["onClick"])):p("",!0),u?.id?(r(),v(C,{key:5,onClick:E(V=>e.onSwapInstrumentals(u.id),["stop"])},{default:a(()=>[w(i(e.$t("producer.button.swap_instrumentals")),1)]),_:1},8,["onClick"])):p("",!0),u?.id?(r(),v(C,{key:6,onClick:E(V=>e.onReplaceSection(u),["stop"])},{default:a(()=>[w(i(e.$t("producer.button.replace_section")),1)]),_:1},8,["onClick"])):p("",!0),o(C,{onClick:E(e.onViewCode,["stop"])},{default:a(()=>[o(_,{icon:"fa-solid fa-code",class:"mr-1"}),w(" "+i(e.$t("common.button.viewCode")),1)]),_:1},8,["onClick"])]),_:2},1024)]),default:a(()=>[s("span",Cs,[o(P,{effect:"dark",content:e.$t("producer.button.more"),placement:"top"},{default:a(()=>[u?.audio_url||u?.video_url?(r(),v(_,{key:0,icon:"fa-solid fa-ellipsis",class:"icon icon-ellipsis"})):p("",!0)]),_:2},1032,["content"])])]),_:2},1024)])],8,ps))),128)),o(O,{visible:e.apiCodeVisible,"onUpdate:visible":t[0]||(t[0]=u=>e.apiCodeVisible=u),method:"POST",path:e.apiCodePath,body:e.apiCodeBody,token:e.$store.state.producer?.credential?.token||""},null,8,["visible","path","body","token"])])}const Ss=U(cs,[["render",Vs]]),Us=S({name:"RecentPanel",components:{ElSkeletonItem:Ge,ElSkeleton:Le,TaskPreview:Ss,Player:ke,NoTasks:ye,ScrollList:pe},props:{loading:{type:Boolean,default:!1}},emits:["reach-top"],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.producer?.tasks,items:this.$store.state.producer?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),Ps={key:0,class:"tasks"},Es={class:"left w-[70px] p-[10px] flex items-center"},As={class:"main w-[calc(100%-70px)] flex-1 p-[10px]"},Ts={key:2,class:"w-full flex-1 flex items-center justify-center"},Fs={class:"h-20"};function Is(e,t,m,l,y,b){const d=n("el-skeleton-item"),f=n("el-skeleton"),h=n("task-preview"),g=n("scroll-list"),_=n("no-tasks"),P=n("player");return r(),c(I,null,[e.tasks?.items===void 0?(r(),c("div",Ps,[(r(),c(I,null,j(3,$=>s("div",{key:$,class:"flex"},[s("div",Es,[o(f,{animated:""},{template:a(()=>[o(d,{variant:"image",class:"avatar w-[50px] h-[50px]"})]),_:1})]),s("div",As,[o(f,{animated:""},{template:a(()=>[o(d,{variant:"p",class:"w-[200px] h-[15px] mb-[5px] mt-[10px]"}),o(d,{variant:"text"})]),_:1})])])),64))])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(r(),v(g,{key:1,ref:"scrollList",class:"flex-1 w-full overflow-y-auto tasks p-2",loading:e.loading,onReachTop:t[0]||(t[0]=$=>e.$emit("reach-top"))},{default:a(()=>[(r(!0),c(I,null,j(e.tasks?.items,($,C)=>(r(),v(h,{key:C,"model-value":$,class:"preview"},null,8,["model-value"]))),128))]),_:1},8,["loading"])):p("",!0),e.tasks?.items?.length===0?(r(),c("div",Ts,[o(_)])):p("",!0),G(s("div",Fs,[o(P,{namespace:"producer"})],512),[[ne,!!e.$store?.state?.producer?.audio?.object]])],64)}const Ls=U(Us,[["render",Is]]),Gs=S({name:"TaskPreview",components:{IconPicture:ae,ElImage:D,ElAvatar:De,ElIcon:q},computed:{audio(){return this.$store.state.producer?.audio}}}),Ds={key:0,class:"size-full overflow-hidden"},zs={class:"relative h-[300px]"},Rs={class:"flex items-center justify-center size-full bg-[var(--el-bg-color)]"},Zs={class:"absolute bottom-0 left-0 right-0 m-0 p-4 text-white z-10 bg-gradient-to-t from-black/70 to-transparent"},js={class:"p-4"},Ns={class:"flex items-center font-bold mb-2"},Bs={class:"text-[var(--el-text-color-regular)] mb-2"},qs={class:"text-xs text-[var(--el-text-color-regular)]"},Ms={class:"mt-4 text-sm leading-[25px] whitespace-pre-wrap"},Os={key:1,class:"w-full h-full"};function Ws(e,t,m,l,y,b){const d=n("icon-picture"),f=n("el-icon"),h=n("el-image"),g=n("el-avatar");return e.audio?.object?(r(),c("div",Ds,[s("div",zs,[o(h,{src:e.audio.image_url,fit:"cover",class:"size-full"},{error:a(()=>[s("div",Rs,[o(f,{class:"text-3xl"},{default:a(()=>[o(d)]),_:1})])]),_:1},8,["src"]),s("h2",Zs,i(e.audio?.title),1)]),s("div",js,[s("div",Ns,[o(g,{size:30,src:e.audio?.image_url,class:"mr-2"},null,8,["src"]),s("span",null,i(e.audio?.title),1)]),s("p",Bs,i(e.audio?.style),1),s("p",qs,i(e.$dayjs.format(e.audio?.created_at)),1),s("div",Ms,[s("p",null,i(e.audio?.lyric),1)])])])):(r(),c("div",Os))}const Hs=U(Gs,[["render",Ws]]),Ks=x("producer"),Ys=S({name:"ProducerIndex",components:{Layout:qe,ConfigPanel:ls,RecentPanel:Ls,PreviewPanel:Hs},inject:["initialized"],data(){return{task:void 0,job:0,loadingMore:!1,fetchingTasks:!1}},computed:{applicationsLoading(){return this.$store.state.producer?.status?.getApplications===F.Request},tasksLoading(){return this.$store.state.producer?.status?.getTasks===F.Request||this.fetchingTasks},service(){return this.$store.state.producer.service},credential(){return this.$store.state.producer.credential},config(){return this.$store.state.producer.config},initializing(){return this.$store.state.producer.status.getApplications===F.Request},needApply(){return this.$store.state.producer.status.getApplications===F.Success&&!this.application},application(){return this.$store.state.producer.application},tasks(){return this.$store.state.producer.tasks},applications(){return this.$store.state.producer.applications}},watch:{tasks:{handler(e,t){e?.items?.length>t?.items?.length&&console.debug("new tasks detected")},deep:!0},initialized:{async handler(e){e&&(console.debug("layout initialized"),await this.onGetTasks(),await this.onScrollDown(),this.job=window.setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){window.clearInterval(this.job)},methods:{async onReachTop(){await me({tasks:this.tasks,getTasks:()=>this.tasks,loading:this.loadingMore,setLoading:e=>this.loadingMore=e,isBlocked:()=>this.tasksLoading||this.applicationsLoading,fetch:e=>this.onGetTasks({createdAtMax:e}),getScrollElement:()=>this.getTasksScrollElement()})},async onGetService(){console.debug("start onGetService"),await this.$store.dispatch("producer/getService"),console.debug("end onGetService")},async onGetApplication(){console.debug("start onGetApplications"),await this.$store.dispatch("producer/getApplications"),console.debug("end onGetApplications"),await this.onGetTasks()},onApply(){de.create({application:this.application}).then(({data:e})=>{this.application=e,k.success(this.$t("application.message.applySuccessfully"))}).catch(e=>{e?.response?.data?.code===ce&&k.error(this.$t("application.message.alreadyApplied"))})},async onScrollDown(){await this.$nextTick();const e=this.getTasksScrollElement();e&&(e.scrollTop=e.scrollHeight)},async onGetTasks(e){if(this.applicationsLoading||this.fetchingTasks){console.debug("loading");return}console.debug("start onGetTasks",e);const{limit:t=5,createdAtMin:m,createdAtMax:l}=e||{};console.debug("limit",t,"createdAtMin",m,"createdAtMax",l),this.fetchingTasks=!0;try{await this.$store.dispatch("producer/getTasks",{limit:t,createdAtMin:m,createdAtMax:l})}finally{this.fetchingTasks=!1}},async onGenerateAudio(){const e={...this.config,callback_url:Ks},t=this.credential?.token;if(!t){console.error("no token specified");return}k.info(this.$t("producer.message.startingTask")),le("producer",T.audio(e,{token:t})).then(()=>{k.success(this.$t("producer.message.startTaskSuccess"))}).catch(m=>{k.error(m?.response?.data?.error?.message||this.$t("producer.message.startTaskFailed"))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function Js(e,t,m,l,y,b){const d=n("config-panel"),f=n("recent-panel"),h=n("preview-panel"),g=n("layout");return r(),v(g,null,{config:a(()=>[o(d,{onGenerate:e.onGenerateAudio},null,8,["onGenerate"])]),result:a(()=>[o(f,{ref:"recentPanel",class:"panel recent",loading:e.loadingMore,onReachTop:e.onReachTop},null,8,["loading","onReachTop"])]),preview:a(()=>[o(h)]),_:1})}const er=U(Ys,[["render",Js],["__scopeId","data-v-d6806962"]]);export{er as default};
@@ -1 +1 @@
1
- import{F as x}from"./index.es-CeLV7iDQ.js";import{E as A}from"./index-HyuSkpOc.js";import{E as O}from"./index-sSPHtazF.js";import{d as h,H as o,E as r,z as E,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{H as m,S as V}from"./index-D0zoWl0t.js";import{E as U}from"./index-DhgEdWde.js";import{E as N,a as P}from"./index-Bu5gNvNl.js";import{C as L}from"./Consumption-HJqRoAYb.js";import{a as G}from"./price-CkwsSMG5.js";import{E as B,a as D}from"./index-BgdH8W9S.js";import{b as T}from"./errorCode-Cqj9Td_Z.js";import{E as w}from"./index-DdbWvBNx.js";import"./use-form-item-DMNI7O3-.js";import"./index-BuyEbX8F.js";import"./vendor-axios-B8_nURbH.js";import"./vendor-dayjs-v0j1UNZp.js";import"./vendor-vue-router-Df5ITouH.js";import"./typescript-Ckyw8f4Q.js";import"./index-BTcVnXUS.js";import"./index-BStjDDyx.js";import"./index-d6anveG0.js";import"./index-X6wgkPd2.js";import"./strings-beZM2Y-f.js";import"./isEqual-CkVIwAaj.js";import"./_Uint8Array-Z75Sa3E8.js";import"./castArray-BOBSHmEl.js";import"./debounce-B-6yjswC.js";import"./_baseIteratee-BL_LXYAx.js";import"./index-bvUTE5h2.js";import"./index-Dv0pO_ZY.js";const H=h({name:"LayoutSerp",components:{ElDrawer:O,ElButton:A,FontAwesomeIcon:x},data(){return{drawer:!1}}}),K={class:"main flex flex-row flex-1"},Q={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",K,[r("div",Q,[E(e.$slots,"config",{},void 0,!0)]),r("div",J,[E(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(()=>[E(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const W=m(H,[["render",M],["__scopeId","data-v-72398911"]]),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"],Ce={class:"flex-1 min-w-0"},Ee={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",Ce,[e.data.type?(t(),o("div",Ee,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"],He={key:1,class:"text-xs text-[var(--el-text-color-disabled)] mt-1"},Ke={key:2,class:"text-sm text-[var(--el-text-color-regular)] mt-1.5 leading-relaxed line-clamp-3"},Qe={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",He,a(e.data.date),1)):c("",!0),e.data.snippet?(t(),o("p",Ke,a(e.data.snippet),1)):c("",!0),e.data.sitelinks?.length?(t(),o("div",Qe,[(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"},Ct={class:"text-blue-600 group-hover:underline font-medium line-clamp-2"},Et={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",Ct,a(s.title),1),r("div",Et,[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)}}}),Ht={class:"rounded-xl border border-[var(--el-border-color-lighter)] p-5 bg-[var(--el-fill-color-blank)]"},Kt={class:"text-base font-bold mb-3"},Qt={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",Ht,[r("h3",Kt,a(e.$t("serp.name.relatedSearches")),1),r("div",Qt,[(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,C=>r("div",{key:C,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,(C,F)=>(t(),v(u,{key:F,data:C,class:"mb-1"},null,8,["data"]))),128))])):c("",!0),e.results.images?.length?(t(),v($,{key:2,data:e.results.images,class:"mb-6"},null,8,["data"])):c("",!0),e.results.videos?.length?(t(),v(S,{key:3,data:e.results.videos,class:"mb-6"},null,8,["data"])):c("",!0),e.results.news?.length?(t(),v(R,{key:4,data:e.results.news,class:"mb-6"},null,8,["data"])):c("",!0),e.results.people_also_ask?.length?(t(),v(q,{key:5,data:e.results.people_also_ask,class:"mb-6"},null,8,["data"])):c("",!0),e.results.related_searches?.length?(t(),v(j,{key:6,data:e.results.related_searches,class:"mb-6",onSearch:e.onRelatedSearch},null,8,["data","onSearch"])):c("",!0)])):(t(),o("div",rs,[d(s,{icon:"fa-solid fa-globe",class:"text-5xl mb-4 opacity-30"}),r("p",as,a(e.$t("serp.description.query")),1)]))])}const ls=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-BXrnqbDc.js";import{E as A}from"./index-ByRYubXn.js";import{E as O}from"./index-PMRNSwyk.js";import{d as h,H as o,E as r,z as E,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{H as m,S as V}from"./index-BRfbHCvZ.js";import{E as U}from"./index-Cf4MWvor.js";import{E as N,a as P}from"./index-DfiGO-z3.js";import{C as L}from"./Consumption-BgQfeJho.js";import{a as G}from"./price-Be1B_bvo.js";import{E as B,a as D}from"./index-CCD14HB5.js";import{b as T}from"./errorCode-Cqj9Td_Z.js";import{E as w}from"./index-B8CSiOhn.js";import"./use-form-item-gFrK0FVf.js";import"./index-BuyEbX8F.js";import"./vendor-axios-B8_nURbH.js";import"./vendor-dayjs-v0j1UNZp.js";import"./vendor-vue-router-Df5ITouH.js";import"./typescript-HOmQr8QU.js";import"./index-CJozFb-_.js";import"./index-zJe4TTTN.js";import"./index-BZkaFFuw.js";import"./index-BtOQSaPZ.js";import"./strings-beZM2Y-f.js";import"./isEqual-DdIQEpjm.js";import"./_Uint8Array-BHztG1Lf.js";import"./castArray-CEKtna1X.js";import"./debounce-BzdywqWi.js";import"./_baseIteratee-DawPdq6H.js";import"./index-LSBUkmpR.js";import"./index-DiX4F22c.js";const H=h({name:"LayoutSerp",components:{ElDrawer:O,ElButton:A,FontAwesomeIcon:x},data(){return{drawer:!1}}}),K={class:"main flex flex-row flex-1"},Q={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",K,[r("div",Q,[E(e.$slots,"config",{},void 0,!0)]),r("div",J,[E(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(()=>[E(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const W=m(H,[["render",M],["__scopeId","data-v-72398911"]]),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"],Ce={class:"flex-1 min-w-0"},Ee={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",Ce,[e.data.type?(t(),o("div",Ee,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"],He={key:1,class:"text-xs text-[var(--el-text-color-disabled)] mt-1"},Ke={key:2,class:"text-sm text-[var(--el-text-color-regular)] mt-1.5 leading-relaxed line-clamp-3"},Qe={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",He,a(e.data.date),1)):c("",!0),e.data.snippet?(t(),o("p",Ke,a(e.data.snippet),1)):c("",!0),e.data.sitelinks?.length?(t(),o("div",Qe,[(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"},Ct={class:"text-blue-600 group-hover:underline font-medium line-clamp-2"},Et={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",Ct,a(s.title),1),r("div",Et,[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)}}}),Ht={class:"rounded-xl border border-[var(--el-border-color-lighter)] p-5 bg-[var(--el-fill-color-blank)]"},Kt={class:"text-base font-bold mb-3"},Qt={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",Ht,[r("h3",Kt,a(e.$t("serp.name.relatedSearches")),1),r("div",Qt,[(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,C=>r("div",{key:C,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,(C,F)=>(t(),v(u,{key:F,data:C,class:"mb-1"},null,8,["data"]))),128))])):c("",!0),e.results.images?.length?(t(),v($,{key:2,data:e.results.images,class:"mb-6"},null,8,["data"])):c("",!0),e.results.videos?.length?(t(),v(S,{key:3,data:e.results.videos,class:"mb-6"},null,8,["data"])):c("",!0),e.results.news?.length?(t(),v(R,{key:4,data:e.results.news,class:"mb-6"},null,8,["data"])):c("",!0),e.results.people_also_ask?.length?(t(),v(q,{key:5,data:e.results.people_also_ask,class:"mb-6"},null,8,["data"])):c("",!0),e.results.related_searches?.length?(t(),v(j,{key:6,data:e.results.related_searches,class:"mb-6",onSearch:e.onRelatedSearch},null,8,["data","onSearch"])):c("",!0)])):(t(),o("div",rs,[d(s,{icon:"fa-solid fa-globe",class:"text-5xl mb-4 opacity-30"}),r("p",as,a(e.$t("serp.description.query")),1)]))])}const ls=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 R}from"./index.es-CeLV7iDQ.js";import{E as S}from"./index-HyuSkpOc.js";import{E as D}from"./index-sSPHtazF.js";import{d as v,H as r,E as i,z as C,C as t,y as c,D as o,q as s,F as a,O as I,N as U,x as $,I as f,J as p,M,Q as L}from"./vendor-vue-NSDaktjZ.js";import{H as b,bm as O,cp as B,b3 as j,S as P,cq as F}from"./index-D0zoWl0t.js";import{a as N,b as q}from"./wan-DKq-jYOo.js";import{E as A,a as G}from"./index-Bu5gNvNl.js";import{p as z}from"./pasteUploadMixin-BurWbGNQ.js";import{I as W,S as H,l as J}from"./pagination-LA4ZoJ7H.js";import{I as K}from"./ImagePreview-DjnXpfFp.js";import{E as Q}from"./index-BXXvYpXX.js";import{E as T}from"./index-DdbWvBNx.js";import{P as X,N as Y}from"./NoTasks-B9brz0GL.js";import{C as Z}from"./Consumption-HJqRoAYb.js";import{a as x}from"./price-CkwsSMG5.js";import{b as ee}from"./errorCode-Cqj9Td_Z.js";import{C as te}from"./CopyToClipboard-B7-zpemN.js";import{V as oe}from"./VideoPlayer-Be9rMTt8.js";import{A as se}from"./ApiCodeButton-ELLwtd41.js";import{E as ne}from"./index-d6anveG0.js";import{E as ae}from"./index-DmrLER-A.js";import{E as le}from"./index-Cq8TQPr3.js";import{B as re}from"./BotPlaceholder-BZ2BnCU8.js";import"./use-form-item-DMNI7O3-.js";import"./index-BuyEbX8F.js";import"./vendor-axios-B8_nURbH.js";import"./vendor-dayjs-v0j1UNZp.js";import"./vendor-vue-router-Df5ITouH.js";import"./index-X6wgkPd2.js";import"./typescript-Ckyw8f4Q.js";import"./index-BTcVnXUS.js";import"./strings-beZM2Y-f.js";import"./isEqual-CkVIwAaj.js";import"./_Uint8Array-Z75Sa3E8.js";import"./castArray-BOBSHmEl.js";import"./index-DhgEdWde.js";import"./index-BStjDDyx.js";import"./debounce-B-6yjswC.js";import"./_baseIteratee-BL_LXYAx.js";import"./index-bvUTE5h2.js";import"./highlight-CxiUjIMX.js";import"./index-BLjywj98.js";import"./vendor-highlight-lEWW1Jxd.js";import"./index-Bo14Ux3S.js";import"./_baseClone-umQ6kPjt.js";import"./_initCloneObject-CCK9Xyv4.js";import"./vue-plyr-BO2nlN4c.js";import"./index-Dm8WLAYA.js";const ie=v({name:"LayoutWan",components:{ElDrawer:D,ElButton:S,FontAwesomeIcon:R},data(){return{drawer:!1}}}),ce={class:"main flex flex-row flex-1"},de={class:"config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]"},ue={class:"result h-full p-6 flex-1 flex flex-col min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]"};function pe(e,n,h,_,k,y){const d=o("font-awesome-icon"),u=o("el-button"),l=o("el-drawer");return s(),r("div",ce,[i("div",de,[C(e.$slots,"config",{},void 0,!0)]),i("div",ue,[C(e.$slots,"result",{},void 0,!0)]),t(u,{circle:"",class:"menu",onClick:n[0]||(n[0]=w=>e.drawer=!0)},{default:c(()=>[t(d,{icon:"fa-solid fa-magic"})]),_:1}),t(l,{modelValue:e.drawer,"onUpdate:modelValue":n[1]||(n[1]=w=>e.drawer=w),direction:"ltr","with-header":!1,size:"340px"},{default:c(()=>[C(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const me=b(ie,[["render",pe],["__scopeId","data-v-3b0702a7"]]),fe=v({name:"ModelSelector",components:{ElSelect:G,ElOption:A},data(){return{}},computed:{options(){return[{value:"wan2.6-t2v",label:this.$t("wan.button.modelT2v")},{value:"wan2.6-i2v",label:this.$t("wan.button.modelI2v")},{value:"wan2.6-i2v-flash",label:this.$t("wan.button.modelI2vFlash")},{value:"wan2.6-r2v",label:this.$t("wan.button.modelR2v")}]},value:{get(){return this.$store.state.wan?.config?.model},set(e){this.$store.commit("wan/setConfig",{...this.$store.state.wan?.config,model:e})}}},mounted(){this.value||(this.value=N)}}),he={class:"field"},_e={class:"title font-bold"},ge={class:"float-left"};function $e(e,n,h,_,k,y){const d=o("el-option"),u=o("el-select");return s(),r("div",he,[i("h2",_e,a(e.$t("wan.name.model")),1),t(u,{modelValue:e.value,"onUpdate:modelValue":n[0]||(n[0]=l=>e.value=l),class:"value",placeholder:e.$t("wan.placeholder.select"),clearable:""},{default:c(()=>[(s(!0),r(I,null,U(e.options,l=>(s(),$(d,{key:l.value,label:l.label,value:l.value},{default:c(()=>[i("span",ge,a(l.label),1)]),_:2},1032,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const we=b(fe,[["render",$e],["__scopeId","data-v-eb090beb"]]),ve="720p",be=v({name:"ResolutionSelector",components:{ElSelect:G,ElOption:A},computed:{options(){return[{value:"480p",label:this.$t("wan.name.resolution480p")},{value:"720p",label:this.$t("wan.name.resolution720p")},{value:"1080p",label:this.$t("wan.name.resolution1080p")}]},value:{get(){return this.$store.state.wan?.config?.resolution},set(e){this.$store.commit("wan/setConfig",{...this.$store.state.wan?.config,resolution:e})}}},mounted(){this.value||(this.value=ve)}}),ke={class:"field"},ye={class:"title font-bold"},Ve={class:"float-left"};function Te(e,n,h,_,k,y){const d=o("el-option"),u=o("el-select");return s(),r("div",ke,[i("h2",ye,a(e.$t("wan.name.resolution")),1),t(u,{modelValue:e.value,"onUpdate:modelValue":n[0]||(n[0]=l=>e.value=l),class:"value",placeholder:e.$t("wan.placeholder.select"),clearable:""},{default:c(()=>[(s(!0),r(I,null,U(e.options,l=>(s(),$(d,{key:l.value,label:l.label,value:l.value},{default:c(()=>[i("span",Ve,a(l.label),1)]),_:2},1032,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Ee=b(be,[["render",Te],["__scopeId","data-v-3e39f44e"]]),Ie=5,Se=v({name:"DurationSelector",components:{ElSelect:G,ElOption:A},computed:{options(){return[{value:5,label:this.$t("wan.name.duration5s")},{value:10,label:this.$t("wan.name.duration10s")},{value:15,label:this.$t("wan.name.duration15s")}]},value:{get(){return this.$store.state.wan?.config?.duration},set(e){this.$store.commit("wan/setConfig",{...this.$store.state.wan?.config,duration:e})}}},mounted(){this.value||(this.value=Ie)}}),Ue={class:"field"},Le={class:"title font-bold"},Ce={class:"float-left"};function Re(e,n,h,_,k,y){const d=o("el-option"),u=o("el-select");return s(),r("div",Ue,[i("h2",Le,a(e.$t("wan.name.duration")),1),t(u,{modelValue:e.value,"onUpdate:modelValue":n[0]||(n[0]=l=>e.value=l),class:"value",placeholder:e.$t("wan.placeholder.select"),clearable:""},{default:c(()=>[(s(!0),r(I,null,U(e.options,l=>(s(),$(d,{key:l.value,label:l.label,value:l.value},{default:c(()=>[i("span",Ce,a(l.label),1)]),_:2},1032,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Ae=b(Se,[["render",Re],["__scopeId","data-v-5f35a2cf"]]),Ge=v({name:"ImageUrlInput",components:{ElUpload:Q,ElButton:S,InfoIcon:W,ImagePreview:K},mixins:[z],data(){return{fileList:[],uploadUrl:O()+"/api/v1/files/"}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e.url).filter(e=>e!==void 0)},value:{get(){return this.$store.state.wan?.config?.image_url},set(){const e=this.urls?.[0];this.$store.commit("wan/setConfig",{...this.$store.state.wan?.config,image_url:e})}}},mounted(){this.value||(this.value=void 0),this.onSetImageUrl()},methods:{onExceed(){T.warning(this.$t("wan.message.uploadImageExceed"))},onError(){T.error(this.$t("wan.message.uploadImageError"))},async onRemove(){T.error(this.$t("wan.message.uploadImageError"))},onSetImageUrl(){const e=this.urls?.[0];this.$store.commit("wan/setConfig",{...this.$store.state.wan?.config,image_url:e})},async onSuccess(){this.onSetImageUrl()}}}),Pe={class:"relative"},De={class:"flex justify-between"},Me={class:"flex justify-start items-center"},Oe={class:"text-sm font-bold"};function Be(e,n,h,_,k,y){const d=o("info-icon"),u=o("image-preview"),l=o("el-button"),w=o("el-upload");return s(),r("div",Pe,[i("div",De,[i("div",Me,[i("span",Oe,a(e.$t("wan.name.imageUrl")),1),t(d,{content:e.$t("wan.description.imageUrl"),class:"info"},null,8,["content"])])]),t(w,{"file-list":e.fileList,"onUpdate:fileList":n[0]||(n[0]=m=>e.fileList=m),accept:".png,.jpg,.jpeg,.gif,.bmp,.webp",name:"file","show-file-list":!0,limit:1,multiple:!1,"list-type":"picture",action:e.uploadUrl,"on-exceed":e.onExceed,"on-error":e.onError,"on-remove":e.onRemove,"on-success":e.onSuccess,headers:e.headers},{file:c(({file:m})=>[m.url&&m.percentage!==void 0?(s(),$(u,{key:0,url:m.url,name:m.name,percentage:m.percentage,onRemove:g=>e.fileList.splice(e.fileList.indexOf(m),1)},null,8,["url","name","percentage","onRemove"])):p("",!0)]),default:c(()=>[t(l,{size:"small",type:"primary",class:"btn btn-upload",round:""},{default:c(()=>[f(a(e.$t("wan.button.uploadImageUrl")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-remove","on-success","headers"])])}const je=b(Ge,[["render",Be],["__scopeId","data-v-c9ebe1b1"]]),Fe="",Ne=v({name:"PromptInput",components:{PromptTextarea:X},computed:{prompt:{get(){return this.$store.state.wan?.config?.prompt},set(e){this.$store.commit("wan/setConfig",{...this.$store.state.wan?.config,prompt:e})}}},mounted(){this.prompt||(this.prompt=Fe)}});function qe(e,n,h,_,k,y){const d=o("prompt-textarea");return s(),$(d,{modelValue:e.prompt,"onUpdate:modelValue":n[0]||(n[0]=u=>e.prompt=u),title:e.$t("wan.name.prompt"),info:e.$t("wan.description.prompt"),placeholder:e.$t("wan.placeholder.prompt")},null,8,["modelValue","title","info","placeholder"])}const ze=b(Ne,[["render",qe]]),We=v({name:"PresetPanel",components:{ElButton:S,FontAwesomeIcon:R,PromptInput:ze,ImageUrlInput:je,ModelSelector:we,ResolutionSelector:Ee,DurationSelector:Ae,Consumption:Z},emits:["generate"],computed:{config(){return this.$store.state.wan?.config},consumption(){return x(this.config,this.service?.cost)},service(){return this.$store.state.wan?.service},supportsResolution(){const e=this.config?.model;return e==="wan2.6-t2v"||e==="wan2.6-i2v"||e==="wan2.6-i2v-flash"},supportsDuration(){return this.config?.model==="wan2.6-t2v"},supportsImageUrl(){const e=this.config?.model;return e==="wan2.6-i2v"||e==="wan2.6-i2v-flash"}},methods:{onGenerate(){this.$emit("generate")}}}),He={class:"flex flex-col h-full"},Je={class:"flex-1 overflow-y-auto p-5"},Ke={class:"flex flex-col items-center justify-center px-5 pb-5"};function Qe(e,n,h,_,k,y){const d=o("prompt-input"),u=o("model-selector"),l=o("resolution-selector"),w=o("duration-selector"),m=o("image-url-input"),g=o("consumption"),V=o("font-awesome-icon"),E=o("el-button");return s(),r("div",He,[i("div",Je,[t(d,{class:"mb-4"}),t(u,{class:"mb-4"}),e.supportsResolution?(s(),$(l,{key:0,class:"mb-4"})):p("",!0),e.supportsDuration?(s(),$(w,{key:1,class:"mb-4"})):p("",!0),e.supportsImageUrl?(s(),$(m,{key:2,class:"mb-2"})):p("",!0)]),i("div",Ke,[t(g,{value:e.consumption,service:e.service},null,8,["value","service"]),t(E,{type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:c(()=>[t(V,{icon:"fa-solid fa-magic",class:"mr-2"}),f(" "+a(e.$t("wan.button.generate")),1)]),_:1},8,["onClick"])])])}const Xe=b(We,[["render",Qe]]),Ye=v({name:"TaskPreview",components:{ElImage:le,CopyToClipboard:te,FontAwesomeIcon:R,ElAlert:ae,VideoPlayer:oe,ElTooltip:ne,ElButton:S,ApiCodeButton:se},props:{modelValue:{type:Object,required:!0}},setup(){return{WAN_LOGO:q}},computed:{application(){return this.$store.state.wan?.application},config(){return this.$store.state.wan?.config}},methods:{onDownload(e){console.debug("on download wan video",e),window.open(e,"_blank")}}}),Ze={class:"preview"},xe={class:"left"},et={class:"main"},tt={class:"bot"},ot={class:"datetime"},st={class:"info"},nt={key:0,class:"prompt mt-2"},at={key:0},lt={key:1},rt={key:0,class:L({content:!0,failed:!0})},it={key:0,class:"mb-4"},ct={key:1,class:L({operations:!0,"mt-2":!0})},dt={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},ut={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},pt={key:1,class:"text-[var(--el-text-color-regular)] text-xs mb-0"},mt={key:1,class:L({content:!0})},ft={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},ht={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},_t={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},gt={class:"text-[var(--el-text-color-regular)] text-xs mb-0"},$t={key:2,class:L({content:!0})},wt={class:"text-[var(--el-text-color-regular)] text-xs mb-0"};function vt(e,n,h,_,k,y){const d=o("el-image"),u=o("video-player"),l=o("el-button"),w=o("el-tooltip"),m=o("api-code-button"),g=o("font-awesome-icon"),V=o("copy-to-clipboard"),E=o("el-alert");return s(),r("div",Ze,[i("div",xe,[t(d,{src:e.WAN_LOGO,class:"avatar"},null,8,["src"])]),i("div",et,[i("div",tt,[f(a(e.$t("wan.name.wanBot"))+" ",1),i("span",ot,a(e.$dayjs.format(""+new Date(parseFloat((e.modelValue?.created_at||"").toString())*1e3))),1)]),i("div",st,[e.modelValue?.request?.prompt?(s(),r("p",nt,[f(a(e.modelValue?.request?.prompt)+" ",1),e.modelValue?.response?p("",!0):(s(),r("span",at," - ("+a(e.$t("wan.status.pending"))+") ",1)),e.modelValue?.response?.state==="processing"||e.modelValue?.response?.state==="pending"||e.modelValue?.response?.state==="running"?(s(),r("span",lt," - ("+a(e.$t("wan.status.processing"))+") ",1)):p("",!0)])):p("",!0)]),e.modelValue?.response?.success===!0?(s(),r("div",rt,[e.modelValue?.response?.video_url?(s(),r("div",it,[t(u,{src:e.modelValue?.response?.video_url},null,8,["src"])])):p("",!0),e.modelValue?.response?.video_url?(s(),r("div",ct,[t(w,{class:"box-item",effect:"dark",content:e.$t("wan.message.downloadVideo"),placement:"top-start"},{default:c(()=>[t(l,{type:"info",size:"small",class:"mb-2",onClick:n[0]||(n[0]=M(Lt=>e.onDownload(e.modelValue?.response?.video_url),["stop"]))},{default:c(()=>[f(a(e.$t("wan.button.download")),1)]),_:1})]),_:1},8,["content"]),t(m,{path:"/wan/videos",body:e.modelValue?.request},null,8,["body"])])):p("",!0),t(E,{closable:!1,class:"mt-2 success"},{default:c(()=>[e.modelValue?.request?.model?(s(),r("p",dt,[t(g,{icon:"fa-solid fa-hashtag",class:"mr-1"}),f(" "+a(e.$t("wan.name.model"))+": "+a(e.modelValue?.request?.model)+" ",1),t(V,{content:e.modelValue?.id},null,8,["content"])])):p("",!0),i("p",ut,[t(g,{icon:"fa-solid fa-magic",class:"mr-1"}),f(" "+a(e.$t("wan.name.taskId"))+": "+a(e.modelValue?.id)+" ",1),t(V,{content:e.modelValue?.id},null,8,["content"])]),e.modelValue?.elapsed?(s(),r("p",pt,[t(g,{icon:"fa-solid fa-clock",class:"mr-1"}),f(" "+a(e.$t("wan.name.elapsed"))+": "+a(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):p("",!0)]),_:1})])):p("",!0),e.modelValue?.response?.success===!1?(s(),r("div",mt,[t(E,{closable:!1,class:"failure"},{template:c(()=>[t(g,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),f(" "+a(e.$t("wan.name.failure")),1)]),default:c(()=>[i("p",ft,[t(g,{icon:"fa-solid fa-magic",class:"mr-1"}),f(" "+a(e.$t("wan.name.taskId"))+": "+a(e.modelValue?.id)+" ",1),t(V,{content:e.modelValue?.id},null,8,["content"])]),i("p",ht,[t(g,{icon:"fa-solid fa-circle-info",class:"mr-1"}),f(" "+a(e.$t("wan.name.failureReason"))+": "+a(e.modelValue?.response?.error?.message)+" ",1),t(V,{content:e.modelValue?.response?.error?.message},null,8,["content"])]),e.modelValue?.elapsed?(s(),r("p",_t,[t(g,{icon:"fa-solid fa-clock",class:"mr-1"}),f(" "+a(e.$t("wan.name.elapsed"))+": "+a(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):p("",!0),i("p",gt,[t(g,{icon:"fa-solid fa-hashtag",class:"mr-1"}),f(" "+a(e.$t("wan.name.traceId"))+": "+a(e.modelValue?.response?.trace_id)+" ",1),t(V,{content:e.modelValue?.response?.trace_id},null,8,["content"])])]),_:1})])):p("",!0),e.modelValue?.response?.success===void 0?(s(),r("div",$t,[t(E,{closable:!1,class:"info"},{template:c(()=>[t(g,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),f(" "+a(e.$t("wan.name.failure")),1)]),default:c(()=>[i("p",wt,[t(g,{icon:"fa-solid fa-magic",class:"mr-1"}),f(" "+a(e.$t("wan.name.taskId"))+": "+a(e.modelValue?.id)+" ",1),t(V,{content:e.modelValue?.id},null,8,["content"])])]),_:1})])):p("",!0)])])}const bt=b(Ye,[["render",vt],["__scopeId","data-v-ae98ca4a"]]),kt=v({name:"RecentPanel",components:{TaskPreview:bt,BotPlaceholder:re,NoTasks:Y,ScrollList:H},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?.()}}}),yt={key:0},Vt={key:2,class:"w-full h-full flex items-center justify-center"};function Tt(e,n,h,_,k,y){const d=o("bot-placeholder"),u=o("task-preview"),l=o("scroll-list"),w=o("no-tasks");return s(),r(I,null,[e.tasks?.items===void 0?(s(),r("div",yt,[t(d)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(s(),$(l,{key:1,ref:"scrollList",class:"tasks w-full h-full overflow-y-auto",loading:e.loading,onReachTop:n[0]||(n[0]=m=>e.$emit("reach-top"))},{default:c(()=>[(s(!0),r(I,null,U(e.tasks?.items,m=>(s(),$(u,{key:m.id,"model-value":m},null,8,["model-value"]))),128))]),_:1},8,["loading"])):p("",!0),e.tasks?.items?.length===0?(s(),r("div",Vt,[t(w)])):p("",!0)],64)}const Et=b(kt,[["render",Tt]]),It=F("wan"),St=v({name:"WanIndex",components:{ConfigPanel:Xe,Layout:me,RecentPanel:Et},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===P.Request},tasksLoading(){return this.$store.state.wan?.status?.getTasks===P.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 J({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:It},n=this.credential?.token;if(!n){console.error("no token specified");return}T.info(this.$t("wan.message.startingTask")),B("wan",j.generate(e,{token:n})).then(()=>{T.success(this.$t("wan.message.startTaskSuccess"))}).catch(h=>{h?.response?.data?.error?.code===ee?T.error(this.$t("wan.message.usedUp")):T.error(this.$t("wan.message.startTaskFailed"))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function Ut(e,n,h,_,k,y){const d=o("config-panel"),u=o("recent-panel"),l=o("layout");return s(),$(l,null,{config:c(()=>[t(d,{onGenerate:e.onGenerate},null,8,["onGenerate"])]),result:c(()=>[t(u,{ref:"recentPanel",loading:e.loadingMore,onReachTop:e.onReachTop},null,8,["loading","onReachTop"])]),_:1})}const Eo=b(St,[["render",Ut]]);export{Eo as default};
1
+ import{F as R}from"./index.es-BXrnqbDc.js";import{E as S}from"./index-ByRYubXn.js";import{E as D}from"./index-PMRNSwyk.js";import{d as v,H as r,E as i,z as C,C as t,y as c,D as o,q as s,F as a,O as I,N as U,x as $,I as f,J as p,M,Q as L}from"./vendor-vue-NSDaktjZ.js";import{H as b,bm as O,cp as B,b3 as j,S as P,cq as F}from"./index-BRfbHCvZ.js";import{a as N,b as q}from"./wan-DKq-jYOo.js";import{E as A,a as G}from"./index-DfiGO-z3.js";import{p as z}from"./pasteUploadMixin-BurWbGNQ.js";import{I as W,S as H,l as J}from"./pagination-BJFvnhlr.js";import{I as K}from"./ImagePreview-CYYwR4zK.js";import{E as Q}from"./index-D63t9suS.js";import{E as T}from"./index-B8CSiOhn.js";import{P as X,N as Y}from"./NoTasks-d_8CfjZ-.js";import{C as Z}from"./Consumption-BgQfeJho.js";import{a as x}from"./price-Be1B_bvo.js";import{b as ee}from"./errorCode-Cqj9Td_Z.js";import{C as te}from"./CopyToClipboard-B3FBgh3x.js";import{V as oe}from"./VideoPlayer-BwloPwzx.js";import{A as se}from"./ApiCodeButton-DdERRoj0.js";import{E as ne}from"./index-BZkaFFuw.js";import{E as ae}from"./index-Bav7i68F.js";import{E as le}from"./index-CVuadntg.js";import{B as re}from"./BotPlaceholder-CMs0qZF7.js";import"./use-form-item-gFrK0FVf.js";import"./index-BuyEbX8F.js";import"./vendor-axios-B8_nURbH.js";import"./vendor-dayjs-v0j1UNZp.js";import"./vendor-vue-router-Df5ITouH.js";import"./index-BtOQSaPZ.js";import"./typescript-HOmQr8QU.js";import"./index-CJozFb-_.js";import"./strings-beZM2Y-f.js";import"./isEqual-DdIQEpjm.js";import"./_Uint8Array-BHztG1Lf.js";import"./castArray-CEKtna1X.js";import"./index-Cf4MWvor.js";import"./index-zJe4TTTN.js";import"./debounce-BzdywqWi.js";import"./_baseIteratee-DawPdq6H.js";import"./index-LSBUkmpR.js";import"./highlight-D6Rf8-7-.js";import"./index-BLjywj98.js";import"./vendor-highlight-lEWW1Jxd.js";import"./index-BnLROHuz.js";import"./_baseClone-DBPrtxYY.js";import"./_initCloneObject-RQtwP1G5.js";import"./vue-plyr-BO2nlN4c.js";import"./index-BSKrtLfD.js";const ie=v({name:"LayoutWan",components:{ElDrawer:D,ElButton:S,FontAwesomeIcon:R},data(){return{drawer:!1}}}),ce={class:"main flex flex-row flex-1"},de={class:"config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]"},ue={class:"result h-full p-6 flex-1 flex flex-col min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]"};function pe(e,n,h,_,k,y){const d=o("font-awesome-icon"),u=o("el-button"),l=o("el-drawer");return s(),r("div",ce,[i("div",de,[C(e.$slots,"config",{},void 0,!0)]),i("div",ue,[C(e.$slots,"result",{},void 0,!0)]),t(u,{circle:"",class:"menu",onClick:n[0]||(n[0]=w=>e.drawer=!0)},{default:c(()=>[t(d,{icon:"fa-solid fa-magic"})]),_:1}),t(l,{modelValue:e.drawer,"onUpdate:modelValue":n[1]||(n[1]=w=>e.drawer=w),direction:"ltr","with-header":!1,size:"340px"},{default:c(()=>[C(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const me=b(ie,[["render",pe],["__scopeId","data-v-3b0702a7"]]),fe=v({name:"ModelSelector",components:{ElSelect:G,ElOption:A},data(){return{}},computed:{options(){return[{value:"wan2.6-t2v",label:this.$t("wan.button.modelT2v")},{value:"wan2.6-i2v",label:this.$t("wan.button.modelI2v")},{value:"wan2.6-i2v-flash",label:this.$t("wan.button.modelI2vFlash")},{value:"wan2.6-r2v",label:this.$t("wan.button.modelR2v")}]},value:{get(){return this.$store.state.wan?.config?.model},set(e){this.$store.commit("wan/setConfig",{...this.$store.state.wan?.config,model:e})}}},mounted(){this.value||(this.value=N)}}),he={class:"field"},_e={class:"title font-bold"},ge={class:"float-left"};function $e(e,n,h,_,k,y){const d=o("el-option"),u=o("el-select");return s(),r("div",he,[i("h2",_e,a(e.$t("wan.name.model")),1),t(u,{modelValue:e.value,"onUpdate:modelValue":n[0]||(n[0]=l=>e.value=l),class:"value",placeholder:e.$t("wan.placeholder.select"),clearable:""},{default:c(()=>[(s(!0),r(I,null,U(e.options,l=>(s(),$(d,{key:l.value,label:l.label,value:l.value},{default:c(()=>[i("span",ge,a(l.label),1)]),_:2},1032,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const we=b(fe,[["render",$e],["__scopeId","data-v-eb090beb"]]),ve="720p",be=v({name:"ResolutionSelector",components:{ElSelect:G,ElOption:A},computed:{options(){return[{value:"480p",label:this.$t("wan.name.resolution480p")},{value:"720p",label:this.$t("wan.name.resolution720p")},{value:"1080p",label:this.$t("wan.name.resolution1080p")}]},value:{get(){return this.$store.state.wan?.config?.resolution},set(e){this.$store.commit("wan/setConfig",{...this.$store.state.wan?.config,resolution:e})}}},mounted(){this.value||(this.value=ve)}}),ke={class:"field"},ye={class:"title font-bold"},Ve={class:"float-left"};function Te(e,n,h,_,k,y){const d=o("el-option"),u=o("el-select");return s(),r("div",ke,[i("h2",ye,a(e.$t("wan.name.resolution")),1),t(u,{modelValue:e.value,"onUpdate:modelValue":n[0]||(n[0]=l=>e.value=l),class:"value",placeholder:e.$t("wan.placeholder.select"),clearable:""},{default:c(()=>[(s(!0),r(I,null,U(e.options,l=>(s(),$(d,{key:l.value,label:l.label,value:l.value},{default:c(()=>[i("span",Ve,a(l.label),1)]),_:2},1032,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Ee=b(be,[["render",Te],["__scopeId","data-v-3e39f44e"]]),Ie=5,Se=v({name:"DurationSelector",components:{ElSelect:G,ElOption:A},computed:{options(){return[{value:5,label:this.$t("wan.name.duration5s")},{value:10,label:this.$t("wan.name.duration10s")},{value:15,label:this.$t("wan.name.duration15s")}]},value:{get(){return this.$store.state.wan?.config?.duration},set(e){this.$store.commit("wan/setConfig",{...this.$store.state.wan?.config,duration:e})}}},mounted(){this.value||(this.value=Ie)}}),Ue={class:"field"},Le={class:"title font-bold"},Ce={class:"float-left"};function Re(e,n,h,_,k,y){const d=o("el-option"),u=o("el-select");return s(),r("div",Ue,[i("h2",Le,a(e.$t("wan.name.duration")),1),t(u,{modelValue:e.value,"onUpdate:modelValue":n[0]||(n[0]=l=>e.value=l),class:"value",placeholder:e.$t("wan.placeholder.select"),clearable:""},{default:c(()=>[(s(!0),r(I,null,U(e.options,l=>(s(),$(d,{key:l.value,label:l.label,value:l.value},{default:c(()=>[i("span",Ce,a(l.label),1)]),_:2},1032,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Ae=b(Se,[["render",Re],["__scopeId","data-v-5f35a2cf"]]),Ge=v({name:"ImageUrlInput",components:{ElUpload:Q,ElButton:S,InfoIcon:W,ImagePreview:K},mixins:[z],data(){return{fileList:[],uploadUrl:O()+"/api/v1/files/"}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e.url).filter(e=>e!==void 0)},value:{get(){return this.$store.state.wan?.config?.image_url},set(){const e=this.urls?.[0];this.$store.commit("wan/setConfig",{...this.$store.state.wan?.config,image_url:e})}}},mounted(){this.value||(this.value=void 0),this.onSetImageUrl()},methods:{onExceed(){T.warning(this.$t("wan.message.uploadImageExceed"))},onError(){T.error(this.$t("wan.message.uploadImageError"))},async onRemove(){T.error(this.$t("wan.message.uploadImageError"))},onSetImageUrl(){const e=this.urls?.[0];this.$store.commit("wan/setConfig",{...this.$store.state.wan?.config,image_url:e})},async onSuccess(){this.onSetImageUrl()}}}),Pe={class:"relative"},De={class:"flex justify-between"},Me={class:"flex justify-start items-center"},Oe={class:"text-sm font-bold"};function Be(e,n,h,_,k,y){const d=o("info-icon"),u=o("image-preview"),l=o("el-button"),w=o("el-upload");return s(),r("div",Pe,[i("div",De,[i("div",Me,[i("span",Oe,a(e.$t("wan.name.imageUrl")),1),t(d,{content:e.$t("wan.description.imageUrl"),class:"info"},null,8,["content"])])]),t(w,{"file-list":e.fileList,"onUpdate:fileList":n[0]||(n[0]=m=>e.fileList=m),accept:".png,.jpg,.jpeg,.gif,.bmp,.webp",name:"file","show-file-list":!0,limit:1,multiple:!1,"list-type":"picture",action:e.uploadUrl,"on-exceed":e.onExceed,"on-error":e.onError,"on-remove":e.onRemove,"on-success":e.onSuccess,headers:e.headers},{file:c(({file:m})=>[m.url&&m.percentage!==void 0?(s(),$(u,{key:0,url:m.url,name:m.name,percentage:m.percentage,onRemove:g=>e.fileList.splice(e.fileList.indexOf(m),1)},null,8,["url","name","percentage","onRemove"])):p("",!0)]),default:c(()=>[t(l,{size:"small",type:"primary",class:"btn btn-upload",round:""},{default:c(()=>[f(a(e.$t("wan.button.uploadImageUrl")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-remove","on-success","headers"])])}const je=b(Ge,[["render",Be],["__scopeId","data-v-c9ebe1b1"]]),Fe="",Ne=v({name:"PromptInput",components:{PromptTextarea:X},computed:{prompt:{get(){return this.$store.state.wan?.config?.prompt},set(e){this.$store.commit("wan/setConfig",{...this.$store.state.wan?.config,prompt:e})}}},mounted(){this.prompt||(this.prompt=Fe)}});function qe(e,n,h,_,k,y){const d=o("prompt-textarea");return s(),$(d,{modelValue:e.prompt,"onUpdate:modelValue":n[0]||(n[0]=u=>e.prompt=u),title:e.$t("wan.name.prompt"),info:e.$t("wan.description.prompt"),placeholder:e.$t("wan.placeholder.prompt")},null,8,["modelValue","title","info","placeholder"])}const ze=b(Ne,[["render",qe]]),We=v({name:"PresetPanel",components:{ElButton:S,FontAwesomeIcon:R,PromptInput:ze,ImageUrlInput:je,ModelSelector:we,ResolutionSelector:Ee,DurationSelector:Ae,Consumption:Z},emits:["generate"],computed:{config(){return this.$store.state.wan?.config},consumption(){return x(this.config,this.service?.cost)},service(){return this.$store.state.wan?.service},supportsResolution(){const e=this.config?.model;return e==="wan2.6-t2v"||e==="wan2.6-i2v"||e==="wan2.6-i2v-flash"},supportsDuration(){return this.config?.model==="wan2.6-t2v"},supportsImageUrl(){const e=this.config?.model;return e==="wan2.6-i2v"||e==="wan2.6-i2v-flash"}},methods:{onGenerate(){this.$emit("generate")}}}),He={class:"flex flex-col h-full"},Je={class:"flex-1 overflow-y-auto p-5"},Ke={class:"flex flex-col items-center justify-center px-5 pb-5"};function Qe(e,n,h,_,k,y){const d=o("prompt-input"),u=o("model-selector"),l=o("resolution-selector"),w=o("duration-selector"),m=o("image-url-input"),g=o("consumption"),V=o("font-awesome-icon"),E=o("el-button");return s(),r("div",He,[i("div",Je,[t(d,{class:"mb-4"}),t(u,{class:"mb-4"}),e.supportsResolution?(s(),$(l,{key:0,class:"mb-4"})):p("",!0),e.supportsDuration?(s(),$(w,{key:1,class:"mb-4"})):p("",!0),e.supportsImageUrl?(s(),$(m,{key:2,class:"mb-2"})):p("",!0)]),i("div",Ke,[t(g,{value:e.consumption,service:e.service},null,8,["value","service"]),t(E,{type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:c(()=>[t(V,{icon:"fa-solid fa-magic",class:"mr-2"}),f(" "+a(e.$t("wan.button.generate")),1)]),_:1},8,["onClick"])])])}const Xe=b(We,[["render",Qe]]),Ye=v({name:"TaskPreview",components:{ElImage:le,CopyToClipboard:te,FontAwesomeIcon:R,ElAlert:ae,VideoPlayer:oe,ElTooltip:ne,ElButton:S,ApiCodeButton:se},props:{modelValue:{type:Object,required:!0}},setup(){return{WAN_LOGO:q}},computed:{application(){return this.$store.state.wan?.application},config(){return this.$store.state.wan?.config}},methods:{onDownload(e){console.debug("on download wan video",e),window.open(e,"_blank")}}}),Ze={class:"preview"},xe={class:"left"},et={class:"main"},tt={class:"bot"},ot={class:"datetime"},st={class:"info"},nt={key:0,class:"prompt mt-2"},at={key:0},lt={key:1},rt={key:0,class:L({content:!0,failed:!0})},it={key:0,class:"mb-4"},ct={key:1,class:L({operations:!0,"mt-2":!0})},dt={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},ut={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},pt={key:1,class:"text-[var(--el-text-color-regular)] text-xs mb-0"},mt={key:1,class:L({content:!0})},ft={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},ht={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},_t={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},gt={class:"text-[var(--el-text-color-regular)] text-xs mb-0"},$t={key:2,class:L({content:!0})},wt={class:"text-[var(--el-text-color-regular)] text-xs mb-0"};function vt(e,n,h,_,k,y){const d=o("el-image"),u=o("video-player"),l=o("el-button"),w=o("el-tooltip"),m=o("api-code-button"),g=o("font-awesome-icon"),V=o("copy-to-clipboard"),E=o("el-alert");return s(),r("div",Ze,[i("div",xe,[t(d,{src:e.WAN_LOGO,class:"avatar"},null,8,["src"])]),i("div",et,[i("div",tt,[f(a(e.$t("wan.name.wanBot"))+" ",1),i("span",ot,a(e.$dayjs.format(""+new Date(parseFloat((e.modelValue?.created_at||"").toString())*1e3))),1)]),i("div",st,[e.modelValue?.request?.prompt?(s(),r("p",nt,[f(a(e.modelValue?.request?.prompt)+" ",1),e.modelValue?.response?p("",!0):(s(),r("span",at," - ("+a(e.$t("wan.status.pending"))+") ",1)),e.modelValue?.response?.state==="processing"||e.modelValue?.response?.state==="pending"||e.modelValue?.response?.state==="running"?(s(),r("span",lt," - ("+a(e.$t("wan.status.processing"))+") ",1)):p("",!0)])):p("",!0)]),e.modelValue?.response?.success===!0?(s(),r("div",rt,[e.modelValue?.response?.video_url?(s(),r("div",it,[t(u,{src:e.modelValue?.response?.video_url},null,8,["src"])])):p("",!0),e.modelValue?.response?.video_url?(s(),r("div",ct,[t(w,{class:"box-item",effect:"dark",content:e.$t("wan.message.downloadVideo"),placement:"top-start"},{default:c(()=>[t(l,{type:"info",size:"small",class:"mb-2",onClick:n[0]||(n[0]=M(Lt=>e.onDownload(e.modelValue?.response?.video_url),["stop"]))},{default:c(()=>[f(a(e.$t("wan.button.download")),1)]),_:1})]),_:1},8,["content"]),t(m,{path:"/wan/videos",body:e.modelValue?.request},null,8,["body"])])):p("",!0),t(E,{closable:!1,class:"mt-2 success"},{default:c(()=>[e.modelValue?.request?.model?(s(),r("p",dt,[t(g,{icon:"fa-solid fa-hashtag",class:"mr-1"}),f(" "+a(e.$t("wan.name.model"))+": "+a(e.modelValue?.request?.model)+" ",1),t(V,{content:e.modelValue?.id},null,8,["content"])])):p("",!0),i("p",ut,[t(g,{icon:"fa-solid fa-magic",class:"mr-1"}),f(" "+a(e.$t("wan.name.taskId"))+": "+a(e.modelValue?.id)+" ",1),t(V,{content:e.modelValue?.id},null,8,["content"])]),e.modelValue?.elapsed?(s(),r("p",pt,[t(g,{icon:"fa-solid fa-clock",class:"mr-1"}),f(" "+a(e.$t("wan.name.elapsed"))+": "+a(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):p("",!0)]),_:1})])):p("",!0),e.modelValue?.response?.success===!1?(s(),r("div",mt,[t(E,{closable:!1,class:"failure"},{template:c(()=>[t(g,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),f(" "+a(e.$t("wan.name.failure")),1)]),default:c(()=>[i("p",ft,[t(g,{icon:"fa-solid fa-magic",class:"mr-1"}),f(" "+a(e.$t("wan.name.taskId"))+": "+a(e.modelValue?.id)+" ",1),t(V,{content:e.modelValue?.id},null,8,["content"])]),i("p",ht,[t(g,{icon:"fa-solid fa-circle-info",class:"mr-1"}),f(" "+a(e.$t("wan.name.failureReason"))+": "+a(e.modelValue?.response?.error?.message)+" ",1),t(V,{content:e.modelValue?.response?.error?.message},null,8,["content"])]),e.modelValue?.elapsed?(s(),r("p",_t,[t(g,{icon:"fa-solid fa-clock",class:"mr-1"}),f(" "+a(e.$t("wan.name.elapsed"))+": "+a(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):p("",!0),i("p",gt,[t(g,{icon:"fa-solid fa-hashtag",class:"mr-1"}),f(" "+a(e.$t("wan.name.traceId"))+": "+a(e.modelValue?.response?.trace_id)+" ",1),t(V,{content:e.modelValue?.response?.trace_id},null,8,["content"])])]),_:1})])):p("",!0),e.modelValue?.response?.success===void 0?(s(),r("div",$t,[t(E,{closable:!1,class:"info"},{template:c(()=>[t(g,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),f(" "+a(e.$t("wan.name.failure")),1)]),default:c(()=>[i("p",wt,[t(g,{icon:"fa-solid fa-magic",class:"mr-1"}),f(" "+a(e.$t("wan.name.taskId"))+": "+a(e.modelValue?.id)+" ",1),t(V,{content:e.modelValue?.id},null,8,["content"])])]),_:1})])):p("",!0)])])}const bt=b(Ye,[["render",vt],["__scopeId","data-v-ae98ca4a"]]),kt=v({name:"RecentPanel",components:{TaskPreview:bt,BotPlaceholder:re,NoTasks:Y,ScrollList:H},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?.()}}}),yt={key:0},Vt={key:2,class:"w-full h-full flex items-center justify-center"};function Tt(e,n,h,_,k,y){const d=o("bot-placeholder"),u=o("task-preview"),l=o("scroll-list"),w=o("no-tasks");return s(),r(I,null,[e.tasks?.items===void 0?(s(),r("div",yt,[t(d)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(s(),$(l,{key:1,ref:"scrollList",class:"tasks w-full h-full overflow-y-auto",loading:e.loading,onReachTop:n[0]||(n[0]=m=>e.$emit("reach-top"))},{default:c(()=>[(s(!0),r(I,null,U(e.tasks?.items,m=>(s(),$(u,{key:m.id,"model-value":m},null,8,["model-value"]))),128))]),_:1},8,["loading"])):p("",!0),e.tasks?.items?.length===0?(s(),r("div",Vt,[t(w)])):p("",!0)],64)}const Et=b(kt,[["render",Tt]]),It=F("wan"),St=v({name:"WanIndex",components:{ConfigPanel:Xe,Layout:me,RecentPanel:Et},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===P.Request},tasksLoading(){return this.$store.state.wan?.status?.getTasks===P.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 J({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:It},n=this.credential?.token;if(!n){console.error("no token specified");return}T.info(this.$t("wan.message.startingTask")),B("wan",j.generate(e,{token:n})).then(()=>{T.success(this.$t("wan.message.startTaskSuccess"))}).catch(h=>{h?.response?.data?.error?.code===ee?T.error(this.$t("wan.message.usedUp")):T.error(this.$t("wan.message.startTaskFailed"))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function Ut(e,n,h,_,k,y){const d=o("config-panel"),u=o("recent-panel"),l=o("layout");return s(),$(l,null,{config:c(()=>[t(d,{onGenerate:e.onGenerate},null,8,["onGenerate"])]),result:c(()=>[t(u,{ref:"recentPanel",loading:e.loadingMore,onReachTop:e.onReachTop},null,8,["loading","onReachTop"])]),_:1})}const Eo=b(St,[["render",Ut]]);export{Eo as default};