@acedatacloud/nexior 3.276.1 → 3.276.2

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 (124) hide show
  1. package/dist/assets/{ApiCodeButton-CYsbafW5.js → ApiCodeButton-C8TdRvY9.js} +1 -1
  2. package/dist/assets/{AskUserQuestionCard-C0g0CXFW.js → AskUserQuestionCard-jb8bzPLa.js} +1 -1
  3. package/dist/assets/{Auth-CiRBbchK.js → Auth-CevT-APY.js} +1 -1
  4. package/dist/assets/{Bare-DIrMb-SD.js → Bare-B1hu6q7Z.js} +1 -1
  5. package/dist/assets/{BotPlaceholder-By9wptjP.js → BotPlaceholder-DzIzZltA.js} +1 -1
  6. package/dist/assets/{BottomFooter-Uv4jMxMb.js → BottomFooter-BIZMLZ5i.js} +1 -1
  7. package/dist/assets/{Callback-C7CJR5pz.js → Callback-BnArHSvk.js} +1 -1
  8. package/dist/assets/{Console-DXmaxlAf.js → Console-BqpoQ6Rt.js} +1 -1
  9. package/dist/assets/{Consumption-Dlo2Ec9d.js → Consumption-DLzGFeUT.js} +1 -1
  10. package/dist/assets/{Conversation-CQAyzCiS.js → Conversation-BPaCX6gr.js} +1 -1
  11. package/dist/assets/{CopyToClipboard-Dnrr0G1l.js → CopyToClipboard-LZRed5aB.js} +1 -1
  12. package/dist/assets/{Detail-Cy86BsXm.js → Detail-CnZ-bcZY.js} +2 -2
  13. package/dist/assets/{Extra-D4jX7JNq.js → Extra-D6o35zFO.js} +1 -1
  14. package/dist/assets/{FilePreview-BSXA8G7D.js → FilePreview-Dj6VOjhF.js} +1 -1
  15. package/dist/assets/{Hailuo-hE8NOeDF.js → Hailuo-C2eHP_WO.js} +1 -1
  16. package/dist/assets/{History-BXlSABUg.js → History-BUdtyskA.js} +1 -1
  17. package/dist/assets/{ImagePreview-D9ovswSr.js → ImagePreview-B2FwyzyM.js} +1 -1
  18. package/dist/assets/{ImageWrapper-DHnmEVHU.js → ImageWrapper-_6c4eeKK.js} +1 -1
  19. package/dist/assets/{Index-Dd_knVh2.js → Index-BPbDPB0M.js} +1 -1
  20. package/dist/assets/{Index-ChYFpwVJ.js → Index-BRMiltIw.js} +1 -1
  21. package/dist/assets/{Index-CvGz__yA.js → Index-Bbr9Hgc0.js} +1 -1
  22. package/dist/assets/Index-Bm2glD67.js +1 -0
  23. package/dist/assets/{Index-Co_pnNJh.js → Index-BoG5tSrk.js} +1 -1
  24. package/dist/assets/{Index-CoK7DoWH.js → Index-BqLQt-5m.js} +1 -1
  25. package/dist/assets/{Index-BDmOZ8BK.js → Index-BzP5ATX6.js} +1 -1
  26. package/dist/assets/{Index-D-FyzuHL.js → Index-C6amW6vz.js} +1 -1
  27. package/dist/assets/{Index-DYOr_Bw7.js → Index-C9iJDxXm.js} +1 -1
  28. package/dist/assets/{Index-DWP04HF5.js → Index-CAAN1-_p.js} +1 -1
  29. package/dist/assets/{Index-COq5-NwQ.js → Index-CD1M-uJN.js} +1 -1
  30. package/dist/assets/{Index-DGWrLTJE.js → Index-CECIU01b.js} +1 -1
  31. package/dist/assets/{Index-DoxQqJpi.js → Index-CUKPMLC-.js} +1 -1
  32. package/dist/assets/{Index-D2ngXf5t.js → Index-CZKWwYGB.js} +1 -1
  33. package/dist/assets/{Index-BNbbHJf8.js → Index-CkITI13f.js} +1 -1
  34. package/dist/assets/{Index-DufJ3B-d.js → Index-Cu81R2TY.js} +1 -1
  35. package/dist/assets/{Index-BvbAkbHv.js → Index-CzZR-m2_.js} +1 -1
  36. package/dist/assets/{Index-CJEPmWEY.js → Index-DIAtAXGz.js} +1 -1
  37. package/dist/assets/{Index-BrduSgiQ.js → Index-DXBSOAj0.js} +1 -1
  38. package/dist/assets/{Index-D_hiDGh4.js → Index-DgPyFPeb.js} +1 -1
  39. package/dist/assets/{Index-003wVSFJ.js → Index-Dz4NPEQR.js} +1 -1
  40. package/dist/assets/{Index-BJvLg-Hr.js → Index-EpovLoMr.js} +1 -1
  41. package/dist/assets/{Index-58Qi_cxL.js → Index-F3vpxi6E.js} +1 -1
  42. package/dist/assets/{Index-DiYieqdu.js → Index-hX7fovd_.js} +1 -1
  43. package/dist/assets/{Index-BW8qTV1f.js → Index-rG7e6yXk.js} +1 -1
  44. package/dist/assets/{Index-BiOdQRhK.js → Index-rQFLYHuV.js} +1 -1
  45. package/dist/assets/{Invitees-C9f8nrLG.js → Invitees-BifLqHGu.js} +1 -1
  46. package/dist/assets/{List-CVJX6_3D.js → List-Br93CnR9.js} +1 -1
  47. package/dist/assets/{List-8yNIAZjy.js → List-CIOMae5H.js} +1 -1
  48. package/dist/assets/{List-CEy3lIJ0.js → List-CMDhlz5R.js} +1 -1
  49. package/dist/assets/{Main-3tlzviLh.js → Main-NAvdrrX0.js} +1 -1
  50. package/dist/assets/{Model-uD01Jd7q.js → Model-BUjfzCpS.js} +1 -1
  51. package/dist/assets/{Navigator-Bvk7Sg3-.js → Navigator-ym7KWo_7.js} +1 -1
  52. package/dist/assets/{NoTasks-BHtlhARF.js → NoTasks-Bk9F1-iz.js} +1 -1
  53. package/dist/assets/{NotFound-DRX8DGal.js → NotFound-m9TVl0hk.js} +1 -1
  54. package/dist/assets/{Pagination-BkCNO3tT.js → Pagination-ZFaMc_mv.js} +1 -1
  55. package/dist/assets/{Pay-BmHZYxVZ.js → Pay-DD8YE5fV.js} +1 -1
  56. package/dist/assets/{Player-DbKLHWva.js → Player-CTNTmM4y.js} +1 -1
  57. package/dist/assets/{Seedance-DaK5gz1R.js → Seedance-VRmh5uYq.js} +1 -1
  58. package/dist/assets/{Status-CFr2tKQI.js → Status-DvNWBZrq.js} +1 -1
  59. package/dist/assets/{Subscribe-BSt9SGNx.js → Subscribe-CgnDdnH3.js} +1 -1
  60. package/dist/assets/{TabSwitcher-BBJl8JER.js → TabSwitcher-BI7dOxCK.js} +1 -1
  61. package/dist/assets/{Tts-aZSlB020.js → Tts-DX6zLgZp.js} +1 -1
  62. package/dist/assets/{VideoPlayer-qDDLVH7_.js → VideoPlayer--5snxkv4.js} +1 -1
  63. package/dist/assets/{avatar-eCfCXYQZ.js → avatar-DoKzF3gM.js} +1 -1
  64. package/dist/assets/{basic-BkjEs-9l.js → basic-BrTbjgdS.js} +1 -1
  65. package/dist/assets/{chat-gDB9t_v4.js → chat-C8jjNDSm.js} +1 -1
  66. package/dist/assets/{codingBridge-DmIjokyi.js → codingBridge-oM7Uohq5.js} +1 -1
  67. package/dist/assets/{codingBridgeNotify-Bi55q9w-.js → codingBridgeNotify-B3rz48kE.js} +2 -2
  68. package/dist/assets/{collapse-CMbK4fuu.js → collapse-Ds9keFcU.js} +1 -1
  69. package/dist/assets/{createTaskActions-arWCKP9k.js → createTaskActions-_LT4UGX1.js} +1 -1
  70. package/dist/assets/{date-picker-Cltk5CTY.js → date-picker-ye73-4_d.js} +1 -1
  71. package/dist/assets/{dropdown-DAFrPSyk.js → dropdown-ByGJfhDP.js} +1 -1
  72. package/dist/assets/{esm-B0wbogpo.js → esm-BgbAZhOw.js} +1 -1
  73. package/dist/assets/{esm-DeGD4J_f.js → esm-BvAIkUfu.js} +1 -1
  74. package/dist/assets/{esm-DQZlBtbx.js → esm-C2P77e7r.js} +2 -2
  75. package/dist/assets/{esm-BA04Lj3L.js → esm-DJ62h-fH.js} +3 -3
  76. package/dist/assets/{esm-QvpHdnog.js → esm-L7PMWDOK.js} +2 -2
  77. package/dist/assets/{esm-Df6JthEK.js → esm-UykDnDSA.js} +1 -1
  78. package/dist/assets/esm-cc-LpyGe.js +1 -0
  79. package/dist/assets/{fish-C6pRkZNs.js → fish-5YNJOUMS.js} +1 -1
  80. package/dist/assets/{flux-BureCMjz.js → flux-D8BMfN_b.js} +1 -1
  81. package/dist/assets/{grokvideo-Be10n0vY.js → grokvideo-DAEDe2lC.js} +1 -1
  82. package/dist/assets/{hailuo-Chog44wU.js → hailuo-Ep2afX61.js} +1 -1
  83. package/dist/assets/{headshots-924vcn5Y.js → headshots-moxuhQ8q.js} +1 -1
  84. package/dist/assets/{image-D5iIL2A6.js → image-CUt2yKJT.js} +1 -1
  85. package/dist/assets/{index-uml6ohnH.js → index-Dzx62HWL.js} +3 -3
  86. package/dist/assets/{index.browser.esm-BY9GuW-m.js → index.browser.esm-DtVKnbsq.js} +1 -1
  87. package/dist/assets/{index.es-CcQaWbuV.js → index.es-BIezN10l.js} +1 -1
  88. package/dist/assets/{input-number-DmUFZAko.js → input-number-CXFB1_xE.js} +1 -1
  89. package/dist/assets/{kling-BHZFLFYK.js → kling-C0C920Il.js} +1 -1
  90. package/dist/assets/{luma-Dcv_K5RA.js → luma-btnACTNr.js} +1 -1
  91. package/dist/assets/{midjourney-DCMb48nF.js → midjourney-CnVJEo9h.js} +1 -1
  92. package/dist/assets/{nanobanana-DwRFnrye.js → nanobanana-uQnyuVgy.js} +1 -1
  93. package/dist/assets/{openaiimage-CLwqhOGr.js → openaiimage-B4szqKdR.js} +1 -1
  94. package/dist/assets/{pagination-BUM1iMKs.js → pagination-t1m3PdtM.js} +1 -1
  95. package/dist/assets/{pika-DAgJisHy.js → pika-B6ZkmISK.js} +1 -1
  96. package/dist/assets/{pixverse-C-TM8aUs.js → pixverse-CMewIDDG.js} +1 -1
  97. package/dist/assets/{popover-CyCHcVkr.js → popover-Dggo6GYh.js} +1 -1
  98. package/dist/assets/{producer-bq3G_r4Z.js → producer-CLqQs_Oy.js} +1 -1
  99. package/dist/assets/{qrart-B2vZfZTU.js → qrart-cUqnnNos.js} +1 -1
  100. package/dist/assets/{row-B7CXMj6b.js → row-Dpgq35ln.js} +1 -1
  101. package/dist/assets/{seedance-CL3W8t39.js → seedance-iA_B79lT.js} +1 -1
  102. package/dist/assets/{seedream-DS0jiQwY.js → seedream-DSZGr5VZ.js} +1 -1
  103. package/dist/assets/{select-CtOUS-1J.js → select-Byt7Qw1F.js} +1 -1
  104. package/dist/assets/{serp-CId26TBB.js → serp-BML2l1cV.js} +1 -1
  105. package/dist/assets/{slider-Cr206S1m.js → slider-Chudll8H.js} +1 -1
  106. package/dist/assets/{solana-wallets-uKka48OL.js → solana-wallets-DHdSmT1K.js} +2 -2
  107. package/dist/assets/{solana-wallets-vue-B_sh8k8r.js → solana-wallets-vue-F4mtRLNf.js} +1 -1
  108. package/dist/assets/{sora-CBCoTEze.js → sora-DBuX8eeJ.js} +1 -1
  109. package/dist/assets/{suno-BxABW3Fo.js → suno-BnJ56a_f.js} +1 -1
  110. package/dist/assets/{switch-D43pwmQF.js → switch-CqHzcX_8.js} +1 -1
  111. package/dist/assets/{tabs-B9RXb3Mw.js → tabs-DZcdINxf.js} +1 -1
  112. package/dist/assets/{upload-CnVhrWBT.js → upload-CDJi96y4.js} +1 -1
  113. package/dist/assets/{veo-CFkAWwwa.js → veo-Di_xCBIf.js} +1 -1
  114. package/dist/assets/{wan-BAsIAxdr.js → wan-DChv5HaI.js} +1 -1
  115. package/dist/assets/{web-DwGrAYkm.js → web-BlcKxuW2.js} +1 -1
  116. package/dist/assets/{web-B_OK9lb7.js → web-CKMhgTwv.js} +1 -1
  117. package/dist/assets/{web-C3b7WxdC.js → web-CXAG0ZQx.js} +1 -1
  118. package/dist/assets/{web-DmBwudd1.js → web-CmEs3R8h.js} +1 -1
  119. package/dist/assets/{web-DerH3-Qz.js → web-Hdenr60p.js} +1 -1
  120. package/dist/assets/{webextrator-4c9pQKbi.js → webextrator-CzvKAcAC.js} +1 -1
  121. package/dist/index.html +1 -1
  122. package/package.json +1 -1
  123. package/dist/assets/Index-CRbLsroT.js +0 -1
  124. package/dist/assets/esm-wjnzAblK.js +0 -1
@@ -0,0 +1 @@
1
+ import"./rolldown-runtime--c01j_DQ.js";import{Bt as e,D as t,E as n,M as r,N as i,O as a,P as o,Q as s,Ut as c,X as l,et as u,k as d,lt as f,tt as p,ut as m,v as h,x as g,y as _}from"./vendor-chart-mdwpew_o.js";import{t as v}from"./button-DWzbdjZV.js";import{t as y}from"./upload-CDJi96y4.js";import{t as b}from"./checkbox-hfJFSY6z.js";import{t as x}from"./drawer-BvYPSxXh.js";import{n as S,r as C,t as w}from"./dropdown-ByGJfhDP.js";import{t as T}from"./popover-Dggo6GYh.js";import{Dr as E,E as D,Ft as O,Ir as k,Mr as A,Or as j,Sr as M,jt as N,kr as P,yr as F}from"./index-Dzx62HWL.js";import"./vendor-highlight-BtIeKitL.js";import{t as I}from"./index.es-BIezN10l.js";import{t as ee}from"./CopyToClipboard-LZRed5aB.js";import{n as te,t as ne}from"./AskUserQuestionCard-jb8bzPLa.js";import{s as re,t as ie}from"./codingBridgeNotify-B3rz48kE.js";var ae=o({name:`CodingBridgeNotificationToggle`,components:{ElButton:v,FontAwesomeIcon:I},data(){return{enabled:!1,busy:!1}},computed:{supported(){return E()||re()}},mounted(){this.enabled=!E()&&ie()===`granted`},methods:{async onToggle(){this.busy=!0;try{if(this.enabled){await this.$store.dispatch(`codingBridge/disableNotifications`),this.enabled=!1,P.success(this.$t(`codingBridge.notify.disabled`));return}let e=await this.$store.dispatch(`codingBridge/enableNotifications`);e===`enabled`?(this.enabled=!0,P.success(this.$t(`codingBridge.notify.enabled`))):e===`denied`?P.warning(this.$t(`codingBridge.notify.denied`)):P.warning(this.$t(`codingBridge.notify.unsupported`))}catch{P.error(this.$t(`codingBridge.notify.failed`))}finally{this.busy=!1}}}});function oe(e,n,r,i,o,s){let c=u(`font-awesome-icon`),d=u(`el-button`);return e.supported?(l(),t(d,{key:0,circle:``,size:`small`,type:e.enabled?`primary`:`default`,title:e.enabled?e.$t(`codingBridge.notify.disable`):e.$t(`codingBridge.notify.enable`),disabled:e.busy,onClick:e.onToggle},{default:f(()=>[e.busy?(l(),t(c,{key:0,icon:`fa-solid fa-spinner`,spin:``})):(l(),t(c,{key:1,icon:e.enabled?`fa-solid fa-bell`:`fa-regular fa-bell`},null,8,[`icon`]))]),_:1},8,[`type`,`title`,`disabled`,`onClick`])):a(``,!0)}var L=o({name:`CodingBridgeNodeList`,components:{ElButton:v,FontAwesomeIcon:I,NotificationToggle:D(ae,[[`render`,oe]])},emits:[`pair`],computed:{nodes(){return this.$store.state.codingBridge?.nodes??[]},currentNodeId(){return this.$store.state.codingBridge?.currentNodeId},connection(){return this.$store.state.codingBridge?.connection??`disconnected`},connectionLabel(){return this.$t(`codingBridge.connection.${this.connection}`)},connectionDotClass(){switch(this.connection){case`connected`:return`bg-[var(--el-color-success)]`;case`connecting`:return`bg-[var(--el-color-warning)]`;case`error`:return`bg-[var(--el-color-danger)]`;default:return`bg-[var(--app-text-subtle)]`}}},methods:{onSelect(e){this.$store.dispatch(`codingBridge/selectNode`,e)},onRefresh(){this.$store.dispatch(`codingBridge/getNodes`)},async onDelete(e){try{await j.confirm(this.$t(`codingBridge.nodeList.removeConfirm`,{name:e.name}),this.$t(`codingBridge.nodeList.remove`),{confirmButtonText:this.$t(`codingBridge.nodeList.remove`),cancelButtonText:this.$t(`common.button.cancel`),type:`warning`})}catch{return}try{await this.$store.dispatch(`codingBridge/deleteNode`,e.node_id),P.success(this.$t(`codingBridge.nodeList.removeSuccess`))}catch{P.error(this.$t(`codingBridge.nodeList.removeFailed`))}}}}),R={class:`node-list flex flex-col h-full bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]`},z={class:`flex items-center justify-between px-4 py-3 border-b border-[var(--app-border-subtle)]`},B={class:`flex items-center gap-2 font-medium`},V={class:`flex items-center gap-1`},H={class:`flex items-center gap-2 px-4 py-2 text-xs border-b border-[var(--app-border-subtle)]`},U={class:`text-[var(--app-text-subtle)]`},W={class:`flex-1 overflow-y-auto`},G={key:0,class:`p-6 text-center text-sm text-[var(--app-text-subtle)]`},K={class:`mb-3`},q={key:1,class:`list-none m-0 p-0`},se=[`onClick`],ce={class:`flex-1 min-w-0`},le={class:`flex items-center gap-2`},ue={class:`truncate font-medium`},de=[`title`],fe={class:`text-xs text-[var(--app-text-subtle)] truncate`};function pe(t,a,o,p,m,h){let v=u(`font-awesome-icon`),y=u(`notification-toggle`),b=u(`el-button`);return l(),d(`div`,R,[n(`div`,z,[n(`div`,B,[i(v,{icon:`fa-solid fa-laptop-code`}),n(`span`,null,c(t.$t(`codingBridge.nodeList.title`)),1)]),n(`div`,V,[i(y),i(b,{circle:``,size:`small`,title:t.$t(`codingBridge.nodeList.refresh`),onClick:t.onRefresh},{default:f(()=>[i(v,{icon:`fa-solid fa-rotate-right`})]),_:1},8,[`title`,`onClick`]),i(b,{type:`primary`,circle:``,size:`small`,title:t.$t(`codingBridge.nodeList.pair`),onClick:a[0]||=e=>t.$emit(`pair`)},{default:f(()=>[i(v,{icon:`fa-solid fa-plus`})]),_:1},8,[`title`])])]),n(`div`,H,[n(`span`,{class:e([`inline-block w-2 h-2 rounded-full`,t.connectionDotClass])},null,2),n(`span`,U,c(t.connectionLabel),1)]),n(`div`,W,[t.nodes.length?(l(),d(`ul`,q,[(l(!0),d(g,null,s(t.nodes,r=>(l(),d(`li`,{key:r.node_id,class:e([`group flex items-center gap-3 px-4 py-3 cursor-pointer border-b border-[var(--app-border-subtle)] hover:bg-[var(--app-content-bg)]`,{"bg-[var(--app-content-bg)]":r.node_id===t.currentNodeId}]),onClick:e=>t.onSelect(r.node_id)},[i(v,{icon:`fa-solid fa-desktop`,class:`text-[var(--app-text-subtle)]`}),n(`div`,ce,[n(`div`,le,[n(`span`,ue,c(r.name),1),n(`span`,{class:e([`inline-block w-2 h-2 rounded-full flex-none`,r.status===`online`?`bg-[var(--el-color-success)]`:`bg-[var(--app-text-subtle)]`]),title:r.status===`online`?t.$t(`codingBridge.status.online`):t.$t(`codingBridge.status.offline`)},null,10,de)]),n(`div`,fe,c(r.status===`online`?t.$t(`codingBridge.status.online`):t.$t(`codingBridge.status.offline`)),1)]),i(b,{class:`opacity-0 group-hover:opacity-100`,text:``,circle:``,size:`small`,title:t.$t(`codingBridge.nodeList.remove`),onClick:_(e=>t.onDelete(r),[`stop`])},{default:f(()=>[i(v,{icon:`fa-solid fa-trash`})]),_:1},8,[`title`,`onClick`])],10,se))),128))])):(l(),d(`div`,G,[n(`p`,K,c(t.$t(`codingBridge.nodeList.empty`)),1),i(b,{type:`primary`,round:``,size:`small`,onClick:a[1]||=e=>t.$emit(`pair`)},{default:f(()=>[i(v,{icon:`fa-solid fa-plus`,class:`mr-1`}),r(` `+c(t.$t(`codingBridge.nodeList.pairFirst`)),1)]),_:1})]))])])}var me=D(L,[[`render`,pe]]),he=e=>{let t=e?.questions;return Array.isArray(t)&&t.length>0&&t.every(e=>e&&typeof e.question==`string`&&Array.isArray(e.options))},J=e=>e?(e.tool||``).toLowerCase()===`askuserquestion`?!0:he(e.input):!1,ge=e=>({questions:e.input?.questions??[]}),_e=o({name:`CodingBridgeTranscriptItem`,directives:{highlight:O},components:{FontAwesomeIcon:I,VueMarkdown:te},props:{event:{type:Object,required:!0},editable:{type:Boolean,default:!1}},emits:[`edit`],computed:{commandText(){let e=this.event.input;if(!e)return``;for(let t of[`command`,`cmd`,`script`]){let n=e[t];if(typeof n==`string`&&n.trim())return n}return``},filePath(){let e=this.event.input;if(!e)return``;for(let t of[`file_path`,`filePath`,`path`,`notebook_path`,`filename`]){let n=e[t];if(typeof n==`string`&&n.trim())return n}return``},toolDescription(){let e=this.event.input?.description;return typeof e==`string`?e:``},toolIcon(){if(this.commandText)return`fa-solid fa-terminal`;let e=(this.event.tool??``).toLowerCase();return/read|cat|view/.test(e)?`fa-solid fa-file-lines`:/write|edit|create|update|insert/.test(e)?`fa-solid fa-pen`:/grep|glob|search|find|list/.test(e)?`fa-solid fa-magnifying-glass`:`fa-solid fa-code`},questionLines(){let e=(this.event.tool??``).toLowerCase(),t=this.event.input?.questions;return!(e===`askuserquestion`||Array.isArray(t))||!Array.isArray(t)?[]:t.filter(e=>e&&typeof e.question==`string`).map(e=>({header:typeof e.header==`string`?e.header:``,question:e.question}))},inputText(){let e=this.event.input;if(!e)return``;let t={};for(let[n,r]of Object.entries(e))n===`timeout`||n===`description`||(t[n]=r);if(Object.keys(t).length===0)return``;try{return JSON.stringify(t,null,2)}catch{return String(e)}},resultText(){let e=this.event.content;return typeof e==`string`&&e.length>0?e:`—`},resultLabel(){let e=[];return this.event.is_error?e.push(this.$t(`codingBridge.transcript.turnFailed`)):e.push(this.$t(`codingBridge.transcript.turnDone`)),typeof this.event.cost_usd==`number`&&this.event.cost_usd>0&&e.push(`$${this.event.cost_usd.toFixed(4)}`),e.join(` · `)},hasAttachments(){return!!this.event.attachments?.length},noticeText(){let e=this.event.subtype,t=this.event.command;if(t){if(e===`slash_unavailable`)return this.$t(`codingBridge.notice.slashUnavailable`,{command:t});if(e===`slash_codex_unsupported`)return this.$t(`codingBridge.notice.slashCodexUnsupported`,{command:t})}return this.event.text||``}}}),ve={key:0,class:`group flex items-end justify-end gap-1.5`},ye=[`title`,`aria-label`],be={class:`max-w-[85%] rounded-lg px-3 py-2 bg-[var(--el-color-primary)] text-white whitespace-pre-wrap break-words`},xe=[`src`],Se=[`href`],Ce=[`src`],we={key:1,class:`flex h-9 w-9 items-center justify-center rounded bg-white/15`},Te={class:`min-w-0 truncate`},Ee={key:2},De={key:2,class:`whitespace-pre-wrap break-words italic text-[var(--app-text-subtle)] border-l-2 border-[var(--app-border-subtle)] pl-3`},Oe={key:3,class:`overflow-hidden rounded-md bg-[var(--app-sidebar-bg)] border border-[var(--app-border-subtle)]`},ke={class:`flex items-center gap-2 px-2.5 py-1.5 font-medium text-[var(--app-text-subtle)]`},Ae={key:0,class:`min-w-0 truncate text-xs font-normal opacity-70`},je={key:0,class:`flex flex-col gap-1.5 px-2.5 pb-2`},Me={key:0,class:`font-medium text-[var(--app-text)]`},Ne={class:`whitespace-pre-wrap break-words text-[var(--app-text-subtle)]`},Pe={key:1,class:`px-2.5 pb-2`},Fe={class:`flex gap-2 overflow-x-auto rounded border border-[var(--app-border-subtle)] bg-[var(--app-content-bg)] px-2.5 py-1.5 font-mono text-xs`},Ie={class:`whitespace-pre-wrap break-words`},Le={key:2,class:`px-2.5 pb-2 font-mono text-xs break-all text-[var(--app-text-subtle)]`},Re={key:3,class:`m-0 overflow-x-auto whitespace-pre-wrap break-words px-2.5 pb-2 text-xs text-[var(--app-text-subtle)]`},ze={key:5,class:`flex items-center gap-2 text-xs text-[var(--app-text-subtle)]`},Be={key:6,class:`flex items-start gap-2 rounded-md bg-[var(--app-sidebar-bg)] border border-[var(--app-border-subtle)] text-[var(--app-text-subtle)] px-3 py-2 text-xs`},Ve={class:`whitespace-pre-wrap break-words`},He={key:7,class:`rounded-md bg-[var(--el-color-danger-light-9)] text-[var(--el-color-danger)] px-3 py-2 whitespace-pre-wrap break-words`};function Ue(t,r,o,f,h,_){let v=u(`font-awesome-icon`),y=u(`vue-markdown`),b=p(`highlight`);return l(),d(`div`,{class:e([`transcript-item text-sm leading-relaxed`,`kind-${t.event.kind}`])},[t.event.kind===`prompt`?(l(),d(`div`,ve,[t.editable?(l(),d(`button`,{key:0,type:`button`,class:`cb-edit-btn opacity-0 transition-opacity group-hover:opacity-100 focus-visible:opacity-100`,title:t.$t(`codingBridge.session.editPrompt`),"aria-label":t.$t(`codingBridge.session.editPrompt`),onClick:r[0]||=e=>t.$emit(`edit`,t.event)},[i(v,{icon:`fa-solid fa-pen`})],8,ye)):a(``,!0),n(`div`,be,[t.event.images&&t.event.images.length?(l(),d(`div`,{key:0,class:e([`flex flex-wrap gap-1.5`,{"mb-1.5":t.event.text||t.hasAttachments}])},[(l(!0),d(g,null,s(t.event.images,(e,t)=>(l(),d(`img`,{key:t,src:e,class:`w-16 h-16 rounded object-cover`,alt:``},null,8,xe))),128))],2)):a(``,!0),t.hasAttachments?(l(),d(`div`,{key:1,class:e([`flex flex-wrap gap-1.5`,{"mb-1.5":t.event.text}])},[(l(!0),d(g,null,s(t.event.attachments,(e,t)=>(l(),d(`a`,{key:`${e.url}-${t}`,href:e.url,target:`_blank`,rel:`noopener noreferrer`,class:`flex max-w-[220px] items-center gap-2 rounded-md bg-white/15 px-2 py-1.5 text-xs text-white hover:bg-white/20`},[e.type===`image`?(l(),d(`img`,{key:0,src:e.url,class:`h-9 w-9 rounded object-cover`,alt:``},null,8,Ce)):(l(),d(`span`,we,[i(v,{icon:`fa-solid fa-file`})])),n(`span`,Te,c(e.name||e.url),1)],8,Se))),128))],2)):a(``,!0),t.event.text?(l(),d(`span`,Ee,c(t.event.text),1)):a(``,!0)])])):t.event.kind===`text`?(l(),d(`div`,{key:1,class:e([`cb-stream-text`,{"is-streaming":t.event.streaming}])},[m(i(y,{source:t.event.text||``,class:`markdown-body bg-transparent text-[var(--app-text)]`},null,8,[`source`]),[[b]])],2)):t.event.kind===`thinking`?(l(),d(`div`,De,c(t.event.text),1)):t.event.kind===`tool_use`?(l(),d(`div`,Oe,[n(`div`,ke,[i(v,{icon:t.toolIcon,class:`text-[var(--el-color-primary)]`},null,8,[`icon`]),n(`span`,null,c(t.event.tool),1),t.toolDescription?(l(),d(`span`,Ae,c(t.toolDescription),1)):a(``,!0)]),t.questionLines.length?(l(),d(`div`,je,[(l(!0),d(g,null,s(t.questionLines,(e,t)=>(l(),d(`div`,{key:t,class:`rounded border border-[var(--app-border-subtle)] bg-[var(--app-content-bg)] px-2.5 py-1.5 text-xs`},[e.header?(l(),d(`div`,Me,c(e.header),1)):a(``,!0),n(`div`,Ne,c(e.question),1)]))),128))])):t.commandText?(l(),d(`div`,Pe,[n(`div`,Fe,[r[1]||=n(`span`,{class:`select-none text-[var(--el-color-success)]`},`$`,-1),n(`span`,Ie,c(t.commandText),1)])])):t.filePath?(l(),d(`div`,Le,c(t.filePath),1)):t.inputText?(l(),d(`pre`,Re,c(t.inputText),1)):a(``,!0)])):t.event.kind===`tool_result`?(l(),d(`div`,{key:4,class:e([`overflow-hidden rounded-md`,t.event.is_error?`bg-[var(--el-color-danger-light-9)]`:`bg-[var(--app-sidebar-bg)]`])},[n(`pre`,{class:e([`m-0 max-h-72 overflow-auto whitespace-pre-wrap break-words px-2.5 py-2 font-mono text-xs`,t.event.is_error?`text-[var(--el-color-danger)]`:`text-[var(--app-text-subtle)]`])},c(t.resultText),3)],2)):t.event.kind===`result`?(l(),d(`div`,ze,[i(v,{icon:t.event.is_error?`fa-solid fa-xmark`:`fa-solid fa-check`},null,8,[`icon`]),n(`span`,null,c(t.resultLabel),1)])):t.event.kind===`notice`?(l(),d(`div`,Be,[i(v,{icon:`fa-solid fa-circle-info`,class:`mt-0.5 flex-none text-[var(--el-color-primary)]`}),n(`span`,Ve,c(t.noticeText),1)])):t.event.kind===`error`?(l(),d(`div`,He,c(t.event.text),1)):a(``,!0)],2)}var We=D(_e,[[`render`,Ue],[`__scopeId`,`data-v-17816a06`]]),Y=[`⠋`,`⠙`,`⠹`,`⠸`,`⠼`,`⠴`,`⠦`,`⠧`,`⠇`,`⠏`],Ge=`Pondering.Noodling.Conjuring.Brewing.Cooking.Crafting.Churning.Simmering.Percolating.Ruminating.Musing.Marinating.Synthesizing.Computing.Hatching.Forging.Vibing.Working.Thinking.Cogitating.Mulling.Stewing.Tinkering.Wrangling.Spinning.Reticulating.Manifesting.Deliberating`.split(`.`),Ke=[`思考中`,`酝酿中`,`沉思中`,`推敲中`,`构思中`,`计算中`,`琢磨中`,`捣鼓中`,`炼制中`,`召唤中`,`编织中`,`烹饪中`,`咀嚼中`,`盘算中`,`发酵中`,`运转中`,`冥想中`,`鼓捣中`,`熬制中`,`神游中`,`演算中`,`雕琢中`,`头脑风暴中`,`反复斟酌中`],qe=80,X=60,Je=1500,Z=28,Ye=o({name:`CodingBridgeThinkingIndicator`,data(){return{spinnerIndex:0,display:``,elapsed:0,charIndex:0,phase:`typing`,currentWord:``,spinnerTimer:0,elapsedTimer:0,typeTimer:0}},computed:{spinnerFrame(){return Y[this.spinnerIndex]},words(){return this.$i18n.locale.startsWith(`zh`)?Ke:Ge}},mounted(){this.currentWord=this.pickWord(),this.spinnerTimer=window.setInterval(()=>{this.spinnerIndex=(this.spinnerIndex+1)%Y.length},qe),this.elapsedTimer=window.setInterval(()=>{this.elapsed+=1},1e3),this.scheduleType(X)},beforeUnmount(){window.clearInterval(this.spinnerTimer),window.clearInterval(this.elapsedTimer),window.clearTimeout(this.typeTimer)},methods:{pickWord(){let e=this.words;if(e.length<=1)return e[0]??``;let t=this.currentWord;for(;t===this.currentWord;)t=e[Math.floor(Math.random()*e.length)];return t},scheduleType(e){this.typeTimer=window.setTimeout(this.advance,e)},advance(){let e=this.currentWord;this.phase===`typing`?(this.charIndex+=1,this.display=e.slice(0,this.charIndex),this.charIndex>=e.length?(this.phase=`holding`,this.scheduleType(Je)):this.scheduleType(X)):this.phase===`holding`?(this.phase=`deleting`,this.scheduleType(Z)):(--this.charIndex,this.display=e.slice(0,Math.max(0,this.charIndex)),this.charIndex<=0?(this.currentWord=this.pickWord(),this.phase=`typing`,this.scheduleType(X)):this.scheduleType(Z))}}}),Xe={class:`cb-thinking flex items-center gap-2 text-sm text-[var(--app-text-subtle)] py-1`},Ze={class:`cb-thinking__spinner text-[var(--el-color-primary)]`},Qe={class:`cb-thinking__word`},$e={class:`cb-thinking__elapsed tabular-nums opacity-60`};function et(e,t,i,a,o,s){return l(),d(`div`,Xe,[n(`span`,Ze,c(e.spinnerFrame),1),n(`span`,Qe,[r(c(e.display),1),t[0]||=n(`span`,{class:`cb-thinking__caret`},`▋`,-1)]),n(`span`,$e,`(`+c(e.elapsed)+`s)`,1)])}var tt=D(Ye,[[`render`,et],[`__scopeId`,`data-v-6087e9e6`]]),nt=o({name:`CodingBridgeDirectoryDialog`,components:{ElDialog:A,ElButton:v,FontAwesomeIcon:I},props:{visible:{type:Boolean,default:!1},initialPath:{type:String,default:``}},emits:[`update:visible`,`select`],computed:{listing(){return this.$store.state.codingBridge?.directory},loading(){return this.$store.state.codingBridge?.directoryLoading===!0},directories(){return(this.listing?.entries??[]).filter(e=>e.type===`dir`)},files(){return(this.listing?.entries??[]).filter(e=>e.type===`file`)},isEmpty(){return!!this.listing&&!this.listing.error&&(this.listing.entries??[]).length===0}},methods:{onOpen(){this.$store.dispatch(`codingBridge/browseDir`,this.initialPath||void 0)},onVisibleChange(e){this.$emit(`update:visible`,e),e||this.$store.dispatch(`codingBridge/clearDirectory`)},openDir(e){this.$store.dispatch(`codingBridge/browseDir`,e)},goParent(){this.listing?.parent&&this.$store.dispatch(`codingBridge/browseDir`,this.listing.parent)},refresh(){this.$store.dispatch(`codingBridge/browseDir`,this.listing?.path||this.initialPath||void 0)},chooseCurrent(){this.listing&&!this.listing.error&&(this.$emit(`select`,this.listing.path),this.onVisibleChange(!1))}}}),rt={class:`flex flex-col gap-2`},it={class:`flex items-center gap-2 min-w-0`},at={class:`text-xs text-[var(--app-text-subtle)] truncate flex-1`,dir:`ltr`},ot={class:`h-72 overflow-y-auto border border-[var(--app-border-subtle)] rounded-md divide-y divide-[var(--app-border-subtle)]`},st={key:0,class:`h-full flex items-center justify-center text-sm text-[var(--app-text-subtle)]`},ct={key:1,class:`h-full flex items-center justify-center text-sm text-[var(--el-color-danger)]`},lt=[`onClick`],ut={class:`truncate`,dir:`ltr`},dt={class:`truncate`,dir:`ltr`},ft={key:0,class:`h-full flex items-center justify-center text-sm text-[var(--app-text-subtle)] py-8`},pt={key:0,class:`text-[11px] text-[var(--app-text-subtle)] px-1`},mt={class:`flex items-center justify-end gap-2`};function ht(e,o,p,m,h,_){let v=u(`font-awesome-icon`),y=u(`el-button`),b=u(`el-dialog`);return l(),t(b,{"model-value":e.visible,title:e.$t(`codingBridge.directory.title`),width:`520px`,"append-to-body":``,"onUpdate:modelValue":e.onVisibleChange,onOpen:e.onOpen},{footer:f(()=>[n(`div`,mt,[i(y,{round:``,onClick:o[0]||=t=>e.onVisibleChange(!1)},{default:f(()=>[r(c(e.$t(`common.button.cancel`)),1)]),_:1}),i(y,{type:`primary`,round:``,disabled:!e.listing||!!e.listing.error,onClick:e.chooseCurrent},{default:f(()=>[r(c(e.$t(`codingBridge.directory.choose`)),1)]),_:1},8,[`disabled`,`onClick`])])]),default:f(()=>[n(`div`,rt,[n(`div`,it,[i(y,{size:`small`,circle:``,disabled:!e.listing||!e.listing.parent||e.loading,title:e.$t(`codingBridge.directory.up`),onClick:e.goParent},{default:f(()=>[i(v,{icon:`fa-solid fa-arrow-up`})]),_:1},8,[`disabled`,`title`,`onClick`]),n(`span`,at,c(e.listing?e.listing.path:`…`),1),i(y,{size:`small`,circle:``,disabled:e.loading,title:e.$t(`codingBridge.directory.refresh`),onClick:e.refresh},{default:f(()=>[i(v,{icon:`fa-solid fa-rotate-right`,spin:e.loading},null,8,[`spin`])]),_:1},8,[`disabled`,`title`,`onClick`])]),n(`div`,ot,[e.loading&&!e.listing?(l(),d(`div`,st,c(e.$t(`codingBridge.directory.loading`)),1)):e.listing&&e.listing.error?(l(),d(`div`,ct,c(e.listing.error),1)):(l(),d(g,{key:2},[(l(!0),d(g,null,s(e.directories,t=>(l(),d(`button`,{key:t.path,type:`button`,class:`w-full flex items-center gap-2 px-3 py-2 text-left text-sm hover:bg-[var(--app-content-hover-bg)]`,onClick:n=>e.openDir(t.path)},[i(v,{icon:`fa-solid fa-folder`,class:`text-[var(--el-color-warning)]`}),n(`span`,ut,c(t.name),1)],8,lt))),128)),(l(!0),d(g,null,s(e.files,e=>(l(),d(`div`,{key:e.path,class:`w-full flex items-center gap-2 px-3 py-2 text-sm text-[var(--app-text-subtle)]`},[i(v,{icon:`fa-solid fa-file`}),n(`span`,dt,c(e.name),1)]))),128)),e.isEmpty?(l(),d(`div`,ft,c(e.$t(`codingBridge.directory.empty`)),1)):a(``,!0)],64))]),e.listing&&e.listing.truncated?(l(),d(`p`,pt,c(e.$t(`codingBridge.directory.truncated`)),1)):a(``,!0)])]),_:1},8,[`model-value`,`title`,`onUpdate:modelValue`,`onOpen`])}var gt=D(nt,[[`render`,ht]]),_t=`data:image/svg+xml,%3csvg%20fill='%23D97757'%20role='img'%20viewBox='0%200%2024%2024'%20xmlns='http://www.w3.org/2000/svg'%3e%3ctitle%3eClaude%3c/title%3e%3cpath%20d='m4.7144%2015.9555%204.7174-2.6471.079-.2307-.079-.1275h-.2307l-.7893-.0486-2.6956-.0729-2.3375-.0971-2.2646-.1214-.5707-.1215-.5343-.7042.0546-.3522.4797-.3218.686.0608%201.5179.1032%202.2767.1578%201.6514.0972%202.4468.255h.3886l.0546-.1579-.1336-.0971-.1032-.0972L6.973%209.8356l-2.55-1.6879-1.3356-.9714-.7225-.4918-.3643-.4614-.1578-1.0078.6557-.7225.8803.0607.2246.0607.8925.686%201.9064%201.4754%202.4893%201.8336.3643.3035.1457-.1032.0182-.0728-.164-.2733-1.3539-2.4467-1.445-2.4893-.6435-1.032-.17-.6194c-.0607-.255-.1032-.4674-.1032-.7285L6.287.1335%206.6997%200l.9957.1336.419.3642.6192%201.4147%201.0018%202.2282%201.5543%203.0296.4553.8985.2429.8318.091.255h.1579v-.1457l.1275-1.706.2368-2.0947.2307-2.6957.0789-.7589.3764-.9107.7468-.4918.5828.2793.4797.686-.0668.4433-.2853%201.8517-.5586%202.9021-.3643%201.9429h.2125l.2429-.2429.9835-1.3053%201.6514-2.0643.7286-.8196.85-.9046.5464-.4311h1.0321l.759%201.1293-.34%201.1657-1.0625%201.3478-.8804%201.1414-1.2628%201.7-.7893%201.36.0729.1093.1882-.0183%202.8535-.607%201.5421-.2794%201.8396-.3157.8318.3886.091.3946-.3278.8075-1.967.4857-2.3072.4614-3.4364.8136-.0425.0304.0486.0607%201.5482.1457.6618.0364h1.621l3.0175.2247.7892.522.4736.6376-.079.4857-1.2142.6193-1.6393-.3886-3.825-.9107-1.3113-.3279h-.1822v.1093l1.0929%201.0686%202.0035%201.8092%202.5075%202.3314.1275.5768-.3218.4554-.34-.0486-2.2039-1.6575-.85-.7468-1.9246-1.621h-.1275v.17l.4432.6496%202.3436%203.5214.1214%201.0807-.17.3521-.6071.2125-.6679-.1214-1.3721-1.9246L14.38%2017.959l-1.1414-1.9428-.1397.079-.674%207.2552-.3156.3703-.7286.2793-.6071-.4614-.3218-.7468.3218-1.4753.3886-1.9246.3157-1.53.2853-1.9004.17-.6314-.0121-.0425-.1397.0182-1.4328%201.9672-2.1796%202.9446-1.7243%201.8456-.4128.164-.7164-.3704.0667-.6618.4008-.5889%202.386-3.0357%201.4389-1.882.929-1.0868-.0062-.1579h-.0546l-6.3385%204.1164-1.1293.1457-.4857-.4554.0608-.7467.2307-.2429%201.9064-1.3114Z'/%3e%3c/svg%3e`,vt=`data:image/svg+xml,%3csvg%20fill='%23000000'%20role='img'%20viewBox='0%200%2024%2024'%20xmlns='http://www.w3.org/2000/svg'%3e%3ctitle%3eOpenAI%3c/title%3e%3cpath%20d='M22.282%209.821a5.985%205.985%200%200%200-.516-4.91%206.046%206.046%200%200%200-6.51-2.9A6.065%206.065%200%200%200%204.981%204.18a5.985%205.985%200%200%200-3.998%202.9%206.046%206.046%200%200%200%20.743%207.097%205.98%205.98%200%200%200%20.51%204.911%206.051%206.051%200%200%200%206.515%202.9A5.985%205.985%200%200%200%2013.26%2024a6.056%206.056%200%200%200%205.772-4.206%205.99%205.99%200%200%200%203.997-2.9%206.056%206.056%200%200%200-.747-7.073zM13.26%2022.43a4.476%204.476%200%200%201-2.876-1.04l.141-.081%204.779-2.758a.795.795%200%200%200%20.392-.681v-6.737l2.02%201.168a.071.071%200%200%201%20.038.052v5.583a4.504%204.504%200%200%201-4.494%204.494zM3.6%2018.304a4.47%204.47%200%200%201-.535-3.014l.142.085%204.783%202.759a.771.771%200%200%200%20.78%200l5.843-3.369v2.332a.08.08%200%200%201-.033.062L9.74%2019.95a4.5%204.5%200%200%201-6.14-1.646zM2.34%207.896a4.485%204.485%200%200%201%202.366-1.973V11.6a.766.766%200%200%200%20.388.676l5.815%203.355-2.02%201.168a.076.076%200%200%201-.071%200l-4.83-2.786A4.504%204.504%200%200%201%202.34%207.872zm16.597%203.855l-5.833-3.387L15.119%207.2a.076.076%200%200%201%20.071%200l4.83%202.791a4.494%204.494%200%200%201-.676%208.105v-5.678a.79.79%200%200%200-.407-.667zm2.01-3.023l-.141-.085-4.774-2.782a.776.776%200%200%200-.785%200L9.409%209.23V6.897a.066.066%200%200%201%20.028-.061l4.83-2.787a4.5%204.5%200%200%201%206.68%204.66zm-12.64%204.135l-2.02-1.164a.08.08%200%200%201-.038-.057V6.075a4.5%204.5%200%200%201%207.375-3.453l-.142.08L8.704%205.46a.795.795%200%200%200-.393.681zm1.097-2.365l2.602-1.5%202.607%201.5v2.999l-2.597%201.5-2.607-1.5z'/%3e%3c/svg%3e`,yt=50*1024*1024,Q=10,bt={claude:{src:_t,invertOnDark:!1},codex:{src:vt,invertOnDark:!0}},xt=o({name:`CodingBridgeSessionView`,components:{ElInput:k,ElButton:v,ElPopover:T,ElDropdown:w,ElDropdownMenu:C,ElDropdownItem:S,ElUpload:y,ElCheckbox:b,FontAwesomeIcon:I,TranscriptItem:We,ThinkingIndicator:tt,DirectoryDialog:gt,AskUserQuestionCard:ne,CopyToClipboard:ee},mixins:[N],emits:[`history`],data(){return{prompt:``,cwd:``,model:``,customModelDraft:``,permissionMode:`default`,provider:`claude`,effort:``,directoryVisible:!1,slashMenuOpen:!1,slashActiveIndex:0,editingEventId:``,restoreCode:!1,attachmentFileList:[],uploadUrl:M()+`/api/v1/files/`,maxAttachments:Q}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},currentNodeId(){return this.$store.state.codingBridge?.currentNodeId},lastComposer(){let e=this.currentNodeId;return(e?this.$store.state.codingBridge?.lastComposer?.[e]:void 0)??{}},currentNode(){return this.$store.state.codingBridge?.nodes?.find(e=>e.node_id===this.currentNodeId)},nodeOnline(){return this.currentNode?.status===`online`},currentSessionId(){return this.$store.state.codingBridge?.currentSessionId},currentSession(){let e=this.currentSessionId;return e?this.$store.state.codingBridge?.sessions?.[e]:void 0},events(){let e=this.currentSessionId;return e?this.$store.state.codingBridge?.events?.[e]??[]:[]},pendingQuestion(){let e=this.currentSessionId;if(!e)return;let t=(this.$store.state.codingBridge?.permissions??[]).find(t=>t.session_id===e&&J(t));return t?{request_id:t.request_id,payload:ge(t)}:void 0},isNewSession(){return!this.currentSessionId},readonly(){return this.currentSession?.readonly===!0},resumeHint(){return!!this.currentSession?.provider&&!this.currentSession?.started&&!this.readonly},replayLabel(){return!this.currentSession?.provider||this.currentSession?.started?``:this.currentSession.provider===`codex`?this.$t(`codingBridge.history.codexLabel`):this.$t(`codingBridge.history.claudeLabel`)},running(){let e=this.currentSession?.status;return e===`running`||e===`starting`},thinking(){return this.running&&!this.pendingQuestion},connected(){return this.$store.state.codingBridge?.connection===`connected`},canRetry(){return this.currentSession?.status===`error`&&!this.readonly&&this.connected&&this.nodeOnline&&this.events.some(e=>e.kind===`prompt`)},attachments(){return(this.attachmentFileList||[]).map(e=>{let t=e.response?.file_url||(typeof e.url==`string`&&!e.url.startsWith(`blob:`)?e.url:``);if(!t)return;let n=e.raw,r=n?.type||e.mime_type||``;return{type:this.isImageAttachment(e)?`image`:`file`,url:t,name:e.name,mime_type:r,size:n?.size}}).filter(e=>!!e)},uploadingAttachments(){return(this.attachmentFileList||[]).some(e=>this.isAttachmentUploading(e))},canSend(){return(!!this.prompt.trim()||this.attachments.length>0)&&!this.uploadingAttachments&&this.connected&&this.nodeOnline&&this.currentProviderAvailable},composerHint(){return this.uploadingAttachments?this.$t(`codingBridge.session.uploadingAttachment`):this.providerCaps.length&&!this.currentProviderAvailable?this.$t(`codingBridge.session.providerUnavailableHint`,{name:this.providerName(this.provider)}):this.resumeHint?this.$t(`codingBridge.history.resumeHint`):this.$t(`codingBridge.session.enterHint`)},nodeCapabilities(){let e=this.currentNodeId;return e?this.$store.state.codingBridge?.capabilities?.[e]:void 0},providerCaps(){return this.nodeCapabilities?.providers??[]},currentProviderCap(){return this.providerCaps.find(e=>e.name===this.provider)},canEdit(){return this.readonly?!1:!!this.providerCaps.find(e=>e.name===this.activeProviderName)?.supports_edit},canRestoreCode(){return!!this.providerCaps.find(e=>e.name===this.activeProviderName)?.supports_code_restore},editingActive(){return!!this.editingEventId},currentProviderAvailable(){return this.providerCaps.length?this.currentProviderCap?.available!==!1:!0},providerOptions(){return this.providerCaps.length?this.providerCaps.map(e=>({value:e.name,label:e.label,available:e.available!==!1})):[{label:this.$t(`codingBridge.session.providerClaude`),value:`claude`,available:!0},{label:this.$t(`codingBridge.session.providerCodex`),value:`codex`,available:!0}]},modelOptions(){return this.currentProviderCap?.models??[]},allowCustomModel(){return this.currentProviderCap?.allow_custom_model??!0},effortOptions(){let e=this.currentProviderCap?.efforts;return(e&&e.length?e:[``]).map(e=>({value:e,label:this.effortLabel(e)}))},permissionModeOptions(){let e=this.currentProviderCap?.permission_modes;return(e&&e.length?e:[`default`,`acceptEdits`,`plan`,`bypassPermissions`]).map(e=>({value:e,label:this.permissionModeLabel(e)}))},sessionMeta(){let e=this.currentSession;if(!e)return``;let t=[];return e.provider&&t.push(this.providerName(e.provider)),e.cwd&&t.push(e.cwd),e.model&&t.push(e.model),t.join(` · `)},activeProviderName(){return this.currentSession?.provider||this.provider},slashCommands(){let e=this.activeProviderName;return this.providerCaps.find(t=>t.name===e)?.commands??[]},slashMatches(){let e=this.prompt.match(/^\/(\S*)$/);if(!e)return[];let t=e[1].toLowerCase();return this.slashCommands.filter(e=>[e.name,...e.aliases??[]].some(e=>e.toLowerCase().startsWith(t)))},slashMenuVisible(){return this.slashMenuOpen&&this.slashMatches.length>0},diagnostics(){let e=[];return this.currentNodeId&&e.push({label:this.$t(`codingBridge.session.nodeId`),value:this.currentNodeId}),this.currentSessionId&&e.push({label:this.$t(`codingBridge.session.sessionId`),value:this.currentSessionId}),this.currentSession?.trace_id&&e.push({label:this.$t(`codingBridge.session.traceId`),value:this.currentSession.trace_id}),e}},watch:{events(){this.scrollToBottom()},pendingQuestion(){this.scrollToBottom()},thinking(){this.scrollToBottom()},currentSessionId(){this.scrollToBottom(),this.editingEventId=``,this.restoreCode=!1,this.syncSessionSettings()},currentNodeId(){this.requestCapabilities(),this.isNewSession&&this.restoreComposerPrefs()},providerCaps(){if(!this.isNewSession||!this.providerCaps.length)return;let e=this.providerCaps.find(e=>e.name===this.provider);if(!e||e.available===!1){let e=this.providerCaps.find(e=>e.available!==!1);e&&(this.provider=e.name)}},provider(){this.isNewSession&&(this.model=``,this.effort=``)},prompt(e){this.slashMenuOpen=/^\/\S*$/.test(e),this.slashActiveIndex>=this.slashMatches.length&&(this.slashActiveIndex=0)}},mounted(){this.requestCapabilities(),this.syncSessionSettings()},methods:{requestCapabilities(){this.currentNodeId&&this.$store.dispatch(`codingBridge/getCapabilities`,this.currentNodeId)},effortLabel(e){let t={"":`codingBridge.session.effortDefault`,low:`codingBridge.session.effortLow`,medium:`codingBridge.session.effortMedium`,high:`codingBridge.session.effortHigh`,max:`codingBridge.session.effortMax`}[e];return t?this.$t(t):e},permissionModeLabel(e){let t={default:`codingBridge.session.permissionModeDefault`,acceptEdits:`codingBridge.session.permissionModeAcceptEdits`,plan:`codingBridge.session.permissionModePlan`,bypassPermissions:`codingBridge.session.permissionModeBypass`}[e];return t?this.$t(t):e},providerName(e){let t=this.providerCaps.find(t=>t.name===e);return t?t.label:e===`codex`?this.$t(`codingBridge.session.providerCodex`):this.$t(`codingBridge.session.providerClaude`)},providerIcon(e){return bt[e]??null},syncSessionSettings(){let e=this.currentSession;if(!e){this.restoreComposerPrefs();return}e.provider&&(this.provider=e.provider),this.model=e.model??``,this.customModelDraft=``,e.cwd&&(this.cwd=e.cwd)},selectModel(e){this.model=e,this.customModelDraft=``,this.closeModelPopover()},applyCustomModel(){let e=this.customModelDraft.trim();e&&(this.model=e,this.customModelDraft=``,this.closeModelPopover())},closeModelPopover(){this.$refs.modelPopover?.hide?.()},onComposerEnter(e){let t=e;t.isComposing||t.keyCode===229||t.shiftKey||t.ctrlKey||t.metaKey||t.altKey||(t.preventDefault(),this.onSend())},onComposerKeydown(e){let t=e;if(this.slashMenuVisible&&!t.isComposing&&t.keyCode!==229){if(t.key===`ArrowDown`){t.preventDefault(),this.moveSlash(1);return}if(t.key===`ArrowUp`){t.preventDefault(),this.moveSlash(-1);return}if(t.key===`Escape`){t.preventDefault(),this.slashMenuOpen=!1;return}if(t.key===`Tab`||t.key===`Enter`&&!t.shiftKey){t.preventDefault(),this.applySlash(this.slashMatches[this.slashActiveIndex]);return}}t.key===`Enter`&&this.onComposerEnter(t)},moveSlash(e){let t=this.slashMatches.length;t&&(this.slashActiveIndex=(this.slashActiveIndex+e+t)%t,this.$nextTick(()=>{(this.$el?.querySelector?.(`.cb-slash-menu__item--active`))?.scrollIntoView({block:`nearest`})}))},applySlash(e){e&&(this.prompt=`/${e.name} `,this.slashMenuOpen=!1,this.slashActiveIndex=0)},onSend(){if(!this.canSend)return;let e=this.attachments;if(this.editingEventId){this.$store.dispatch(`codingBridge/editPrompt`,{eventId:this.editingEventId,prompt:this.prompt,model:this.model,permissionMode:this.permissionMode,effort:this.effort,attachments:e.length?e:void 0,restoreCode:this.restoreCode}),this.resetComposer();return}this.currentNodeId&&this.$store.commit(`codingBridge/setLastComposer`,{node_id:this.currentNodeId,prefs:{cwd:this.cwd,provider:this.provider,model:this.model,permissionMode:this.permissionMode,effort:this.effort}}),this.$store.dispatch(`codingBridge/sendPrompt`,{prompt:this.prompt,cwd:this.cwd,model:this.model,permissionMode:this.permissionMode,provider:this.provider,effort:this.effort,attachments:e.length?e:void 0}),this.resetComposer()},resetComposer(){this.prompt=``,this.slashMenuOpen=!1,this.slashActiveIndex=0,this.editingEventId=``,this.restoreCode=!1,this.clearAttachments()},cancelEdit(){this.resetComposer()},onAnswerQuestion(e){this.$store.dispatch(`codingBridge/answerQuestion`,{request_id:e.tool_use_id,output:e.output})},onSkipQuestion(e){this.$store.dispatch(`codingBridge/resolvePermission`,{request_id:e.tool_use_id,decision:`deny`})},beforeAttachmentUpload(e){return this.attachmentFileList.length>=Q?(P.warning(this.$t(`codingBridge.session.attachmentLimit`,{count:Q})),!1):e.size>yt?(P.warning(this.$t(`codingBridge.session.attachmentTooLarge`)),!1):!0},onAttachmentChange(e){if(!e.url&&e.raw&&this.isImageAttachment(e))try{e.url=URL.createObjectURL(e.raw)}catch{}},onAttachmentSuccess(e,t){e?.file_url&&(this.revokeBlobUrl(t),t.url=e.file_url,t.response=e)},onAttachmentError(){P.error(this.$t(`codingBridge.session.attachmentUploadError`))},onAttachmentExceed(){P.warning(this.$t(`codingBridge.session.attachmentLimit`,{count:Q}))},onTriggerAttachmentUpload(){this.$nextTick(()=>{let e=this.$refs.uploader?.$el;(e?.querySelector(`input.el-upload__input`)||e?.querySelector(`input[type="file"]`))?.click()})},isAttachmentUploading(e){return e.status===`ready`||e.status===`uploading`},isImageAttachment(e){return(e.raw?.type||``).startsWith(`image/`)?!0:/\.(png|jpe?g|gif|webp|bmp|svg)$/i.test(e.name||e.url||``)},attachmentPreviewUrl(e){return this.isImageAttachment(e)&&(e.url||e.response?.file_url)||``},removeAttachment(e,t){this.revokeBlobUrl(t),this.attachmentFileList.splice(e,1)},clearAttachments(){for(let e of this.attachmentFileList)this.revokeBlobUrl(e);this.attachmentFileList=[]},revokeBlobUrl(e){if(e.url?.startsWith(`blob:`))try{URL.revokeObjectURL(e.url)}catch{}},onInterrupt(){this.$store.dispatch(`codingBridge/interruptSession`)},onRetry(){this.$store.dispatch(`codingBridge/retryLastPrompt`)},onEditPrompt(e){this.canEdit&&(this.editingEventId=e.id,this.restoreCode=!1,this.prompt=e.text??``,this.slashMenuOpen=!1,this.slashActiveIndex=0,this.clearAttachments(),this.attachmentFileList=(e.attachments??[]).map((e,t)=>({name:e.name||e.url,url:e.url,status:`success`,percentage:100,uid:Date.now()+t,response:{file_url:e.url},mime_type:e.mime_type})),this.$nextTick(()=>{(this.$el?.querySelector?.(`.cb-composer__input textarea`))?.focus()}))},openDirectory(){this.directoryVisible=!0},onDirectorySelect(e){this.cwd=e},onNewSession(){this.$store.dispatch(`codingBridge/newSession`),this.restoreComposerPrefs(),this.resetComposer()},restoreComposerPrefs(){let e=this.lastComposer;this.cwd=e.cwd??``,this.provider=e.provider??`claude`,this.permissionMode=e.permissionMode??`default`,this.customModelDraft=``,this.$nextTick(()=>{this.model=e.model??``,this.effort=e.effort??``})},scrollToBottom(){this.$nextTick(()=>{let e=this.$refs.transcript;e&&(e.scrollTop=e.scrollHeight)})}}}),St={class:`session-view flex flex-col h-full bg-[var(--app-content-bg)]`},Ct={key:0,class:`flex-1 flex flex-col items-center justify-center text-center p-8 text-[var(--app-text-subtle)]`},wt={class:`text-sm`},Tt={class:`flex items-center justify-between gap-3 px-5 py-3 border-b border-[var(--app-border-subtle)]`},Et={class:`min-w-0`},Dt={class:`flex items-center gap-2 font-medium`},Ot={class:`truncate`},kt={key:0,class:`text-xs text-[var(--app-text-subtle)] truncate`},At={key:0,class:`text-[var(--el-color-primary)]`},jt={class:`flex items-center gap-2 flex-none`},Mt={key:0,class:`px-5 py-2 text-xs bg-[var(--el-color-warning-light-9)] text-[var(--el-color-warning)] border-b border-[var(--app-border-subtle)]`},Nt={key:1,class:`flex flex-wrap items-center gap-x-4 gap-y-1 px-5 py-1.5 text-[11px] text-[var(--app-text-subtle)] border-b border-[var(--app-border-subtle)]`},Pt={class:`opacity-70 flex-none`},Ft=[`title`],It={ref:`transcript`,class:`flex-1 min-h-0 overflow-y-auto px-5 py-4 flex flex-col gap-3`},Lt={key:0,class:`m-auto text-center text-sm text-[var(--app-text-subtle)]`},Rt={key:2,class:`flex justify-center pt-1`},zt={key:2,class:`cb-question-dock flex-none px-5`},Bt={class:`border-t border-[var(--app-border-subtle)] p-3`},Vt={key:0,class:`flex items-center gap-2 text-xs text-[var(--app-text-subtle)] px-1 py-2`},Ht={key:0,class:`mb-2 flex flex-wrap items-center gap-x-3 gap-y-1.5 rounded-lg bg-[var(--el-color-primary-light-9)] px-3 py-2 text-xs text-[var(--app-text)]`},Ut={class:`inline-flex items-center gap-1.5`},Wt={class:`cb-composer rounded-2xl border border-[var(--app-border-subtle)] bg-[var(--app-content-bg)] px-3 py-2.5 transition-colors focus-within:border-[var(--el-color-primary-light-5)]`},Gt={key:0,class:`flex flex-wrap gap-2 pb-2`},Kt=[`src`,`alt`],qt={key:1,class:`flex h-8 w-8 items-center justify-center rounded bg-[var(--app-content-bg)]`},Jt=[`title`],Yt={key:2,class:`text-[10px] text-[var(--app-text-subtle)]`},Xt=[`title`,`onClick`],Zt={key:1,class:`cb-slash-menu`},Qt=[`onMousedown`,`onMouseenter`],$t={class:`cb-slash-menu__name`},en={key:0,class:`cb-slash-menu__hint`},tn={key:1,class:`cb-slash-menu__desc`},nn={ref:`attachmentUploadTrigger`,class:`block h-0 w-0`,"aria-hidden":`true`},rn={class:`mt-1.5 flex items-center gap-1.5`},an=[`title`],on={class:`flex min-w-0 flex-1 flex-wrap items-center gap-1.5`},sn={type:`button`,class:`cb-pill`},cn=[`src`],ln={class:`truncate`},un=[`src`],dn={key:1,class:`ml-1 text-xs opacity-60`},fn={key:1,class:`cb-pill cb-pill--static`},pn=[`src`],mn={class:`truncate`},hn={type:`button`,class:`cb-pill`},gn={class:`truncate`},_n={class:`cb-model-menu`},vn={class:`truncate`},yn=[`onClick`],bn={class:`truncate`},xn={key:0,class:`cb-model-custom`},Sn={type:`button`,class:`cb-pill`},Cn={class:`truncate`},wn={type:`button`,class:`cb-pill`},Tn={class:`truncate`},En={type:`button`,class:`cb-pill`},Dn={class:`truncate`},On=[`title`,`aria-label`],kn={key:3,class:`cb-pill cb-pill--static`},An={class:`truncate`},jn={class:`text-[11px] text-[var(--app-text-subtle)] mt-1 px-1`};function Mn(o,p,m,v,y,b){let x=u(`font-awesome-icon`),S=u(`el-button`),C=u(`copy-to-clipboard`),w=u(`transcript-item`),T=u(`thinking-indicator`),E=u(`ask-user-question-card`),D=u(`el-checkbox`),O=u(`el-input`),k=u(`el-upload`),A=u(`el-dropdown-item`),j=u(`el-dropdown-menu`),M=u(`el-dropdown`),N=u(`el-popover`),P=u(`directory-dialog`);return l(),d(`div`,St,[o.currentNode?(l(),d(g,{key:1},[n(`div`,Tt,[n(`div`,Et,[n(`div`,Dt,[n(`span`,Ot,c(o.currentNode.name),1),n(`span`,{class:e([`inline-block w-2 h-2 rounded-full flex-none`,o.nodeOnline?`bg-[var(--el-color-success)]`:`bg-[var(--app-text-subtle)]`])},null,2)]),o.currentSession?(l(),d(`div`,kt,[n(`span`,null,c(o.sessionMeta),1),o.replayLabel?(l(),d(`span`,At,` · `+c(o.replayLabel),1)):a(``,!0)])):a(``,!0)]),n(`div`,jt,[i(S,{size:`small`,round:``,onClick:p[0]||=e=>o.$emit(`history`)},{default:f(()=>[i(x,{icon:`fa-solid fa-clock-rotate-left`,class:`mr-1`}),r(` `+c(o.$t(`codingBridge.history.button`)),1)]),_:1}),o.currentSessionId?(l(),t(S,{key:0,size:`small`,round:``,onClick:o.onNewSession},{default:f(()=>[i(x,{icon:`fa-solid fa-plus`,class:`mr-1`}),r(` `+c(o.$t(`codingBridge.session.newSession`)),1)]),_:1},8,[`onClick`])):a(``,!0)])]),o.nodeOnline?a(``,!0):(l(),d(`div`,Mt,c(o.$t(`codingBridge.session.deviceOffline`)),1)),o.diagnostics.length?(l(),d(`div`,Nt,[(l(!0),d(g,null,s(o.diagnostics,e=>(l(),d(`span`,{key:e.label,class:`inline-flex items-center gap-1 min-w-0`},[n(`span`,Pt,c(e.label)+`:`,1),n(`span`,{class:`font-mono break-all`,title:e.value},c(e.value),9,Ft),i(C,{content:e.value,class:`inline-block flex-none`},null,8,[`content`])]))),128))])):a(``,!0),n(`div`,It,[o.events.length?a(``,!0):(l(),d(`div`,Lt,c(o.$t(`codingBridge.session.startHint`)),1)),(l(!0),d(g,null,s(o.events,e=>(l(),t(w,{key:e.id,event:e,editable:o.canEdit,onEdit:o.onEditPrompt},null,8,[`event`,`editable`,`onEdit`]))),128)),o.thinking?(l(),t(T,{key:1})):a(``,!0),o.canRetry?(l(),d(`div`,Rt,[i(S,{size:`small`,round:``,onClick:o.onRetry},{default:f(()=>[i(x,{icon:`fa-solid fa-rotate-right`,class:`mr-1`}),r(` `+c(o.$t(`codingBridge.session.retry`)),1)]),_:1},8,[`onClick`])])):a(``,!0)],512),o.pendingQuestion?(l(),d(`div`,zt,[(l(),t(E,{key:o.pendingQuestion.request_id,"tool-use-id":o.pendingQuestion.request_id,payload:o.pendingQuestion.payload,onSubmit:o.onAnswerQuestion,onSkip:o.onSkipQuestion},null,8,[`tool-use-id`,`payload`,`onSubmit`,`onSkip`]))])):a(``,!0),n(`div`,Bt,[o.readonly?(l(),d(`div`,Vt,[i(x,{icon:`fa-solid fa-eye`}),n(`span`,null,c(o.$t(`codingBridge.history.readonly`)),1),i(S,{class:`ml-auto`,size:`small`,round:``,onClick:o.onNewSession},{default:f(()=>[r(c(o.$t(`codingBridge.session.newSession`)),1)]),_:1},8,[`onClick`])])):(l(),d(g,{key:1},[o.editingActive?(l(),d(`div`,Ht,[n(`span`,Ut,[i(x,{icon:`fa-solid fa-pen`,class:`text-[var(--el-color-primary)]`}),r(` `+c(o.$t(`codingBridge.session.editingBanner`)),1)]),o.canRestoreCode?(l(),t(D,{key:0,modelValue:o.restoreCode,"onUpdate:modelValue":p[1]||=e=>o.restoreCode=e,size:`small`,class:`cb-restore-code`},{default:f(()=>[r(c(o.$t(`codingBridge.session.editRestoreCode`)),1)]),_:1},8,[`modelValue`])):a(``,!0),n(`button`,{type:`button`,class:`ml-auto cb-edit-cancel`,onClick:p[2]||=(...e)=>o.cancelEdit&&o.cancelEdit(...e)},c(o.$t(`codingBridge.session.editCancel`)),1)])):a(``,!0),n(`div`,Wt,[o.attachmentFileList.length?(l(),d(`div`,Gt,[(l(!0),d(g,null,s(o.attachmentFileList,(e,t)=>(l(),d(`div`,{key:e.uid||e.name||t,class:`group relative flex max-w-[220px] items-center gap-2 rounded-md border border-[var(--app-border-subtle)] bg-[var(--app-sidebar-bg)] px-2 py-1.5 text-xs`},[o.attachmentPreviewUrl(e)?(l(),d(`img`,{key:0,src:o.attachmentPreviewUrl(e),class:`h-8 w-8 rounded object-cover`,alt:o.$t(`codingBridge.session.attachmentImageAlt`)},null,8,Kt)):(l(),d(`span`,qt,[i(x,{icon:`fa-solid fa-file`})])),n(`span`,{class:`min-w-0 flex-1 truncate`,title:e.name},c(e.name),9,Jt),o.isAttachmentUploading(e)?(l(),d(`span`,Yt,c(Math.round(e.percentage||0))+`% `,1)):a(``,!0),n(`button`,{type:`button`,class:`flex h-5 w-5 items-center justify-center rounded-full text-[var(--app-text-subtle)] hover:bg-[var(--app-content-hover-bg)] hover:text-[var(--el-color-danger)]`,title:o.$t(`codingBridge.session.removeAttachment`),onClick:n=>o.removeAttachment(t,e)},[i(x,{icon:`fa-solid fa-xmark`})],8,Xt)]))),128))])):a(``,!0),o.slashMenuVisible?(l(),d(`ul`,Zt,[(l(!0),d(g,null,s(o.slashMatches,(t,r)=>(l(),d(`li`,{key:t.name,class:e([`cb-slash-menu__item`,{"cb-slash-menu__item--active":r===o.slashActiveIndex}]),onMousedown:_(e=>o.applySlash(t),[`prevent`]),onMouseenter:e=>o.slashActiveIndex=r},[n(`span`,$t,`/`+c(t.name),1),t.argument_hint?(l(),d(`span`,en,c(t.argument_hint),1)):a(``,!0),t.description?(l(),d(`span`,tn,c(t.description),1)):a(``,!0)],42,Qt))),128))])):a(``,!0),i(O,{modelValue:o.prompt,"onUpdate:modelValue":p[3]||=e=>o.prompt=e,type:`textarea`,autosize:{minRows:2,maxRows:12},resize:`none`,class:`cb-composer__input`,placeholder:o.$t(`codingBridge.session.promptPlaceholder`),onKeydown:o.onComposerKeydown},null,8,[`modelValue`,`placeholder`,`onKeydown`]),i(k,{ref:`uploader`,"file-list":o.attachmentFileList,"onUpdate:fileList":p[4]||=e=>o.attachmentFileList=e,class:`h-0 w-0 overflow-hidden opacity-0`,name:`file`,action:o.uploadUrl,headers:o.headers,multiple:!0,limit:o.maxAttachments,"show-file-list":!1,"before-upload":o.beforeAttachmentUpload,"on-change":o.onAttachmentChange,"on-success":o.onAttachmentSuccess,"on-error":o.onAttachmentError,"on-exceed":o.onAttachmentExceed},{default:f(()=>[n(`span`,nn,null,512)]),_:1},8,[`file-list`,`action`,`headers`,`limit`,`before-upload`,`on-change`,`on-success`,`on-error`,`on-exceed`]),n(`div`,rn,[n(`button`,{type:`button`,class:`cb-icon-btn`,title:o.$t(`codingBridge.session.attachFile`),onClick:p[5]||=(...e)=>o.onTriggerAttachmentUpload&&o.onTriggerAttachmentUpload(...e)},[i(x,{icon:`fa-solid fa-paperclip`})],8,an),n(`div`,on,[o.isNewSession?(l(),t(M,{key:0,trigger:`click`,onCommand:p[6]||=e=>o.provider=e},{dropdown:f(()=>[i(j,null,{default:f(()=>[(l(!0),d(g,null,s(o.providerOptions,n=>(l(),t(A,{key:n.value,command:n.value,disabled:!n.available},{default:f(()=>[i(x,{icon:`fa-solid fa-check`,class:e([`mr-2`,n.value===o.provider?`opacity-100`:`opacity-0`])},null,8,[`class`]),o.providerIcon(n.value)?(l(),d(`img`,{key:0,src:o.providerIcon(n.value).src,class:e([`cb-pill__brand mr-1.5`,{"cb-pill__brand--invert":o.providerIcon(n.value).invertOnDark}]),alt:``},null,10,un)):a(``,!0),r(` `+c(n.label)+` `,1),n.available?a(``,!0):(l(),d(`span`,dn,c(o.$t(`codingBridge.session.providerUnavailable`)),1))]),_:2},1032,[`command`,`disabled`]))),128))]),_:1})]),default:f(()=>[n(`button`,sn,[o.providerIcon(o.provider)?(l(),d(`img`,{key:0,src:o.providerIcon(o.provider).src,class:e([`cb-pill__brand`,{"cb-pill__brand--invert":o.providerIcon(o.provider).invertOnDark}]),alt:``},null,10,cn)):(l(),t(x,{key:1,icon:`fa-solid fa-code`,class:`cb-pill__icon`})),n(`span`,ln,c(o.providerName(o.provider)),1),i(x,{icon:`fa-solid fa-chevron-down`,class:`cb-pill__caret`})])]),_:1})):(l(),d(`span`,fn,[o.providerIcon(o.currentSession?.provider||`claude`)?(l(),d(`img`,{key:0,src:o.providerIcon(o.currentSession?.provider||`claude`).src,class:e([`cb-pill__brand`,{"cb-pill__brand--invert":o.providerIcon(o.currentSession?.provider||`claude`).invertOnDark}]),alt:``},null,10,pn)):(l(),t(x,{key:1,icon:`fa-solid fa-code`,class:`cb-pill__icon`})),n(`span`,mn,c(o.providerName(o.currentSession?.provider||`claude`)),1)])),i(N,{ref:`modelPopover`,trigger:`click`,placement:`top-start`,width:260},{reference:f(()=>[n(`button`,hn,[i(x,{icon:`fa-solid fa-brain`,class:`cb-pill__icon`}),n(`span`,gn,c(o.model||o.$t(`codingBridge.session.modelDefault`)),1),i(x,{icon:`fa-solid fa-chevron-down`,class:`cb-pill__caret`})])]),default:f(()=>[n(`div`,_n,[n(`button`,{type:`button`,class:`cb-model-option`,onClick:p[7]||=e=>o.selectModel(``)},[i(x,{icon:`fa-solid fa-check`,class:e([`cb-model-option__check`,o.model?`opacity-0`:`opacity-100`])},null,8,[`class`]),n(`span`,vn,c(o.$t(`codingBridge.session.modelDefault`)),1)]),(l(!0),d(g,null,s(o.modelOptions,t=>(l(),d(`button`,{key:t.value,type:`button`,class:`cb-model-option`,onClick:e=>o.selectModel(t.value)},[i(x,{icon:`fa-solid fa-check`,class:e([`cb-model-option__check`,t.value===o.model?`opacity-100`:`opacity-0`])},null,8,[`class`]),n(`span`,bn,c(t.label),1)],8,yn))),128)),o.allowCustomModel?(l(),d(`div`,xn,[i(O,{modelValue:o.customModelDraft,"onUpdate:modelValue":p[8]||=e=>o.customModelDraft=e,size:`small`,placeholder:o.$t(`codingBridge.session.modelPlaceholder`),onKeyup:h(o.applyCustomModel,[`enter`])},{append:f(()=>[i(S,{disabled:!o.customModelDraft.trim(),onClick:o.applyCustomModel},{default:f(()=>[i(x,{icon:`fa-solid fa-check`})]),_:1},8,[`disabled`,`onClick`])]),_:1},8,[`modelValue`,`placeholder`,`onKeyup`])])):a(``,!0)])]),_:1},512),o.isNewSession?(l(),d(g,{key:2},[o.effortOptions.length>1?(l(),t(M,{key:0,trigger:`click`,onCommand:p[9]||=e=>o.effort=e},{dropdown:f(()=>[i(j,null,{default:f(()=>[(l(!0),d(g,null,s(o.effortOptions,n=>(l(),t(A,{key:n.value,command:n.value},{default:f(()=>[i(x,{icon:`fa-solid fa-check`,class:e([`mr-2`,n.value===o.effort?`opacity-100`:`opacity-0`])},null,8,[`class`]),r(` `+c(n.label),1)]),_:2},1032,[`command`]))),128))]),_:1})]),default:f(()=>[n(`button`,Sn,[i(x,{icon:`fa-solid fa-gauge-high`,class:`cb-pill__icon`}),n(`span`,Cn,c(o.effortLabel(o.effort)),1),i(x,{icon:`fa-solid fa-chevron-down`,class:`cb-pill__caret`})])]),_:1})):a(``,!0),i(M,{trigger:`click`,onCommand:p[10]||=e=>o.permissionMode=e},{dropdown:f(()=>[i(j,null,{default:f(()=>[(l(!0),d(g,null,s(o.permissionModeOptions,n=>(l(),t(A,{key:n.value,command:n.value},{default:f(()=>[i(x,{icon:`fa-solid fa-check`,class:e([`mr-2`,n.value===o.permissionMode?`opacity-100`:`opacity-0`])},null,8,[`class`]),r(` `+c(n.label),1)]),_:2},1032,[`command`]))),128))]),_:1})]),default:f(()=>[n(`button`,wn,[i(x,{icon:`fa-solid fa-shield-halved`,class:`cb-pill__icon`}),n(`span`,Tn,c(o.permissionModeLabel(o.permissionMode)),1),i(x,{icon:`fa-solid fa-chevron-down`,class:`cb-pill__caret`})])]),_:1}),i(N,{trigger:`click`,placement:`top-start`,width:320},{reference:f(()=>[n(`button`,En,[i(x,{icon:`fa-solid fa-folder-open`,class:`cb-pill__icon`}),n(`span`,Dn,c(o.cwd||o.$t(`codingBridge.session.cwdDefault`)),1),i(x,{icon:`fa-solid fa-chevron-down`,class:`cb-pill__caret`})])]),default:f(()=>[i(O,{modelValue:o.cwd,"onUpdate:modelValue":p[14]||=e=>o.cwd=e,size:`small`,clearable:``,class:`cb-cwd-input`,placeholder:o.$t(`codingBridge.session.cwdPlaceholder`)},{suffix:f(()=>[n(`span`,{class:`cb-cwd-browse`,role:`button`,tabindex:`0`,title:o.$t(`codingBridge.directory.title`),"aria-label":o.$t(`codingBridge.directory.title`),onClick:p[11]||=(...e)=>o.openDirectory&&o.openDirectory(...e),onKeydown:[p[12]||=h(_((...e)=>o.openDirectory&&o.openDirectory(...e),[`prevent`]),[`enter`]),p[13]||=h(_((...e)=>o.openDirectory&&o.openDirectory(...e),[`prevent`]),[`space`])]},[i(x,{icon:`fa-solid fa-folder-open`})],40,On)]),_:1},8,[`modelValue`,`placeholder`])]),_:1})],64)):a(``,!0),!o.isNewSession&&o.currentSession?.cwd?(l(),d(`span`,kn,[i(x,{icon:`fa-solid fa-folder-open`,class:`cb-pill__icon`}),n(`span`,An,c(o.currentSession?.cwd),1)])):a(``,!0)]),o.running?(l(),t(S,{key:0,circle:``,onClick:o.onInterrupt},{default:f(()=>[i(x,{icon:`fa-solid fa-stop`})]),_:1},8,[`onClick`])):a(``,!0),i(S,{type:`primary`,round:``,disabled:!o.canSend,onClick:o.onSend},{default:f(()=>[r(c(o.editingActive?o.$t(`codingBridge.session.editSubmit`):o.$t(`codingBridge.session.send`)),1)]),_:1},8,[`disabled`,`onClick`])])]),n(`p`,jn,c(o.composerHint),1)],64))])],64)):(l(),d(`div`,Ct,[i(x,{icon:`fa-solid fa-laptop-code`,class:`text-4xl mb-3`}),n(`p`,wt,c(o.$t(`codingBridge.session.noDevice`)),1)])),i(P,{visible:o.directoryVisible,"onUpdate:visible":p[15]||=e=>o.directoryVisible=e,"initial-path":o.cwd,onSelect:o.onDirectorySelect},null,8,[`visible`,`initial-path`,`onSelect`])])}var Nn=D(xt,[[`render`,Mn],[`__scopeId`,`data-v-f89ef2a0`]]),Pn=o({name:`CodingBridgePairDialog`,components:{ElDialog:A,ElInput:k,ElButton:v,FontAwesomeIcon:I},props:{visible:{type:Boolean,default:!1},initialCode:{type:String,default:``}},emits:[`update:visible`],data(){return{code:``}},computed:{claiming(){return this.$store.state.codingBridge?.status?.claimPair===F.Request}},watch:{visible(e){e&&this.initialCode&&(this.code=this.initialCode)},initialCode(e){e&&(this.code=e)}},methods:{async onClaim(){let e=this.code.trim();if(e)try{let t=await this.$store.dispatch(`codingBridge/claimPair`,e);P.success(this.$t(`codingBridge.pair.success`,{name:t})),this.code=``,this.$emit(`update:visible`,!1)}catch(e){let t=e?.response?.status;t===404?P.error(this.$t(`codingBridge.pair.invalidCode`)):t===409?P.error(this.$t(`codingBridge.pair.usedCode`)):P.error(this.$t(`codingBridge.pair.failed`))}}}}),Fn={class:`content`},In={class:`text-sm text-[var(--app-text-subtle)] mb-4`},Ln={class:`steps list-none m-0 p-0 mb-4`},Rn={class:`flex gap-3 mb-3`},zn={class:`flex-1 min-w-0`},Bn={class:`text-sm mb-1`},Vn={class:`flex gap-3 mb-3`},Hn={class:`flex-1 min-w-0`},Un={class:`text-sm mb-1`},Wn={class:`flex gap-3`},Gn={class:`flex-1 min-w-0`},Kn={class:`text-sm`};function qn(e,a,o,s,d,p){let m=u(`el-input`),g=u(`font-awesome-icon`),_=u(`el-button`),v=u(`el-dialog`);return l(),t(v,{"model-value":e.visible,width:`520px`,title:e.$t(`codingBridge.pair.title`),center:``,"onUpdate:modelValue":a[1]||=t=>e.$emit(`update:visible`,t)},{default:f(()=>[n(`div`,Fn,[n(`p`,In,c(e.$t(`codingBridge.pair.intro`)),1),n(`ol`,Ln,[n(`li`,Rn,[a[3]||=n(`span`,{class:`step-index`},`1`,-1),n(`div`,zn,[n(`p`,Bn,c(e.$t(`codingBridge.pair.step1`)),1),a[2]||=n(`code`,{class:`cmd`},`pip install coding-bridge-agent`,-1)])]),n(`li`,Vn,[a[5]||=n(`span`,{class:`step-index`},`2`,-1),n(`div`,Hn,[n(`p`,Un,c(e.$t(`codingBridge.pair.step2`)),1),a[4]||=n(`code`,{class:`cmd`},`coding-bridge-agent up`,-1)])]),n(`li`,Wn,[a[6]||=n(`span`,{class:`step-index`},`3`,-1),n(`div`,Gn,[n(`p`,Kn,c(e.$t(`codingBridge.pair.step3`)),1)])])]),i(m,{modelValue:e.code,"onUpdate:modelValue":a[0]||=t=>e.code=t,size:`large`,class:`mb-3`,placeholder:e.$t(`codingBridge.pair.codePlaceholder`),clearable:``,onKeyup:h(e.onClaim,[`enter`])},null,8,[`modelValue`,`placeholder`,`onKeyup`]),i(_,{type:`primary`,round:``,class:`w-full`,loading:e.claiming,disabled:!e.code.trim(),onClick:e.onClaim},{default:f(()=>[i(g,{icon:`fa-solid fa-link`,class:`mr-1`}),r(` `+c(e.$t(`codingBridge.pair.claim`)),1)]),_:1},8,[`loading`,`disabled`,`onClick`])])]),_:1},8,[`model-value`,`title`])}var Jn=D(Pn,[[`render`,qn],[`__scopeId`,`data-v-3d1ed01f`]]),Yn=o({name:`CodingBridgePermissionDialog`,components:{ElDialog:A,ElButton:v,FontAwesomeIcon:I},computed:{request(){return(this.$store.state.codingBridge?.permissions??[]).find(e=>!J(e))},hasInput(){return!!this.request?.input&&Object.keys(this.request.input).length>0},inputText(){try{return JSON.stringify(this.request?.input,null,2)}catch{return String(this.request?.input??``)}}},methods:{onAllow(){this.request&&this.$store.dispatch(`codingBridge/resolvePermission`,{request_id:this.request.request_id,decision:`allow`})},onDeny(){this.request&&this.$store.dispatch(`codingBridge/resolvePermission`,{request_id:this.request.request_id,decision:`deny`})}}}),Xn={key:0,class:`content`},Zn={class:`text-sm text-[var(--app-text-subtle)] mb-3`},Qn={class:`rounded-md border border-[var(--app-border-subtle)] p-3 mb-3`},$n={class:`flex items-center gap-2 font-medium`},er={key:0,class:`text-xs text-[var(--app-text-subtle)] mt-1`},tr={key:1,class:`mt-2 text-xs overflow-x-auto whitespace-pre-wrap break-words text-[var(--app-text-subtle)] max-h-[200px]`},nr={class:`flex justify-end gap-2`};function rr(e,o,s,p,m,h){let g=u(`font-awesome-icon`),_=u(`el-button`),v=u(`el-dialog`);return l(),t(v,{"model-value":!!e.request,width:`480px`,title:e.$t(`codingBridge.permission.title`),"close-on-click-modal":!1,"show-close":!1,center:``},{footer:f(()=>[n(`div`,nr,[i(_,{round:``,onClick:e.onDeny},{default:f(()=>[i(g,{icon:`fa-solid fa-xmark`,class:`mr-1`}),r(` `+c(e.$t(`codingBridge.permission.deny`)),1)]),_:1},8,[`onClick`]),i(_,{type:`primary`,round:``,onClick:e.onAllow},{default:f(()=>[i(g,{icon:`fa-solid fa-check`,class:`mr-1`}),r(` `+c(e.$t(`codingBridge.permission.allow`)),1)]),_:1},8,[`onClick`])])]),default:f(()=>[e.request?(l(),d(`div`,Xn,[n(`p`,Zn,c(e.$t(`codingBridge.permission.subtitle`)),1),n(`div`,Qn,[n(`div`,$n,[i(g,{icon:`fa-solid fa-code`}),n(`span`,null,c(e.request.display_name||e.request.title||e.request.tool),1)]),e.request.description?(l(),d(`p`,er,c(e.request.description),1)):a(``,!0),e.hasInput?(l(),d(`pre`,tr,c(e.inputText),1)):a(``,!0)])])):a(``,!0)]),_:1},8,[`model-value`,`title`])}var ir=D(Yn,[[`render`,rr]]),ar=o({name:`CodingBridgeHistoryDrawer`,components:{ElDrawer:x,ElButton:v,FontAwesomeIcon:I},props:{visible:{type:Boolean,default:!1}},emits:[`update:visible`],computed:{currentNodeId(){return this.$store.state.codingBridge?.currentNodeId},loading(){return this.$store.state.codingBridge?.status?.getHistory===F.Request},sessions(){let e=this.currentNodeId;return[...e?this.$store.state.codingBridge?.history?.[e]??[]:[]].sort((e,t)=>(t.updated_at??0)-(e.updated_at??0))}},watch:{visible(e){e&&this.currentNodeId&&this.$store.dispatch(`codingBridge/getHistory`,this.currentNodeId)}},methods:{refresh(){this.currentNodeId&&this.$store.dispatch(`codingBridge/getHistory`,this.currentNodeId)},open(e){this.currentNodeId&&(this.$store.dispatch(`codingBridge/getHistoryDetail`,{node_id:this.currentNodeId,provider:e.provider,session_id:e.session_id}),this.$emit(`update:visible`,!1))},formatTime(e){try{return new Date(e).toLocaleString()}catch{return``}}}}),or={class:`flex flex-col h-full`},sr={class:`flex items-center justify-between mb-3`},$={class:`text-xs text-[var(--app-text-subtle)] m-0`},cr={key:0,class:`m-auto text-sm text-[var(--app-text-subtle)]`},lr={key:1,class:`m-auto text-sm text-[var(--app-text-subtle)]`},ur={key:2,class:`m-auto text-sm text-[var(--app-text-subtle)] text-center`},dr={key:3,class:`list-none m-0 p-0 flex-1 overflow-y-auto flex flex-col gap-2`},fr=[`onClick`],pr={class:`flex items-center gap-2 mb-1`},mr={class:`text-sm font-medium truncate flex-1`},hr={class:`text-[11px] text-[var(--app-text-subtle)] truncate`},gr={key:0},_r={key:1},vr={class:`text-[11px] text-[var(--app-text-subtle)] mt-0.5`},yr={key:0},br={key:1};function xr(o,p,m,h,_,v){let y=u(`font-awesome-icon`),b=u(`el-button`),x=u(`el-drawer`);return l(),t(x,{"model-value":o.visible,direction:`rtl`,size:`380px`,title:o.$t(`codingBridge.history.title`),"onUpdate:modelValue":p[0]||=e=>o.$emit(`update:visible`,e)},{default:f(()=>[n(`div`,or,[n(`div`,sr,[n(`p`,$,c(o.$t(`codingBridge.history.intro`)),1),i(b,{size:`small`,round:``,loading:o.loading,onClick:o.refresh},{default:f(()=>[o.loading?a(``,!0):(l(),t(y,{key:0,icon:`fa-solid fa-rotate-right`,class:`mr-1`})),r(` `+c(o.$t(`codingBridge.history.refresh`)),1)]),_:1},8,[`loading`,`onClick`])]),o.currentNodeId?o.loading&&!o.sessions.length?(l(),d(`div`,lr,c(o.$t(`codingBridge.history.loading`)),1)):o.sessions.length?(l(),d(`ul`,dr,[(l(!0),d(g,null,s(o.sessions,t=>(l(),d(`li`,{key:t.provider+`:`+t.session_id,class:`item rounded-lg p-3 cursor-pointer border border-[var(--app-border-subtle)]`,onClick:e=>o.open(t)},[n(`div`,pr,[n(`span`,{class:e([`provider-tag`,t.provider])},c(t.provider===`codex`?`Codex`:`Claude`),3),n(`span`,mr,c(t.title),1)]),n(`div`,hr,[t.cwd?(l(),d(`span`,gr,c(t.cwd),1)):a(``,!0),t.git_branch?(l(),d(`span`,_r,` · `+c(t.git_branch),1)):a(``,!0)]),n(`div`,vr,[t.updated_at?(l(),d(`span`,yr,c(o.formatTime(t.updated_at)),1)):a(``,!0),t.message_count?(l(),d(`span`,br,` · `+c(o.$t(`codingBridge.history.messages`,{count:t.message_count})),1)):a(``,!0)])],8,fr))),128))])):(l(),d(`div`,ur,c(o.$t(`codingBridge.history.empty`)),1)):(l(),d(`div`,cr,c(o.$t(`codingBridge.session.noDevice`)),1))])]),_:1},8,[`model-value`,`title`])}var Sr=o({name:`CodingBridgeIndex`,components:{ElButton:v,ElDrawer:x,FontAwesomeIcon:I,NodeList:me,SessionView:Nn,PairDialog:Jn,PermissionDialog:ir,HistoryDrawer:D(ar,[[`render`,xr],[`__scopeId`,`data-v-3414881a`]])},data(){return{drawer:!1,pairVisible:!1,historyVisible:!1,initialCode:``}},mounted(){this.$store.dispatch(`codingBridge/connect`),this.$store.dispatch(`codingBridge/getNodes`);let e=this.$route.query.code;typeof e==`string`&&e&&(this.initialCode=e,this.pairVisible=!0),this.handleNotificationDeepLink()},beforeUnmount(){this.$store.dispatch(`codingBridge/disconnect`)},methods:{openPair(){this.initialCode=``,this.pairVisible=!0},openPairFromDrawer(){this.drawer=!1,this.openPair()},handleNotificationDeepLink(){let e=this.$route.query.node;typeof e==`string`&&e&&(this.$store.dispatch(`codingBridge/selectNode`,e),this.$store.dispatch(`codingBridge/requestPendingPermissions`,e))}}}),Cr={class:`coding-bridge flex flex-row h-full relative`};function wr(e,t,n,r,a,o){let s=u(`node-list`),c=u(`session-view`),p=u(`font-awesome-icon`),m=u(`el-button`),h=u(`el-drawer`),g=u(`pair-dialog`),_=u(`permission-dialog`),v=u(`history-drawer`);return l(),d(`div`,Cr,[i(s,{class:`sidebar w-[300px] flex-none`,onPair:e.openPair},null,8,[`onPair`]),i(c,{class:`flex-1 min-w-0`,onHistory:t[0]||=t=>e.historyVisible=!0}),i(m,{circle:``,class:`menu`,onClick:t[1]||=t=>e.drawer=!0},{default:f(()=>[i(p,{icon:`fa-solid fa-laptop-code`})]),_:1}),i(h,{modelValue:e.drawer,"onUpdate:modelValue":t[2]||=t=>e.drawer=t,direction:`ltr`,"with-header":!1,size:`300px`,class:`drawer`},{default:f(()=>[i(s,{onPair:e.openPairFromDrawer},null,8,[`onPair`])]),_:1},8,[`modelValue`]),i(g,{visible:e.pairVisible,"onUpdate:visible":t[3]||=t=>e.pairVisible=t,"initial-code":e.initialCode},null,8,[`visible`,`initial-code`]),i(_),i(v,{visible:e.historyVisible,"onUpdate:visible":t[4]||=t=>e.historyVisible=t},null,8,[`visible`])])}var Tr=D(Sr,[[`render`,wr],[`__scopeId`,`data-v-44a88ff4`]]);export{Tr as default};
@@ -1 +1 @@
1
- import"./rolldown-runtime--c01j_DQ.js";import{$ as e,Bt as t,D as n,E as r,M as i,N as a,O as o,P as s,Q as c,Ut as l,X as u,_ as d,et as f,k as p,lt as m,ut as h,x as g,y as _}from"./vendor-chart-mdwpew_o.js";import{t as v}from"./button-DWzbdjZV.js";import{n as y,r as b,t as x}from"./select-CtOUS-1J.js";import{t as S}from"./upload-CnVhrWBT.js";import{t as C}from"./tooltip-C3PYfh8V.js";import{t as w}from"./image-D5iIL2A6.js";import{t as T}from"./alert-BJj7gY4q.js";import{t as E}from"./drawer-BvYPSxXh.js";import{t as D}from"./input-number-DmUFZAko.js";import{t as O}from"./switch-D43pwmQF.js";import{Cn as k,Sn as A,_n as j,dn as M,fn as N,gn as P,hn as ee,mn as te,pi as ne,pn as re,vn as ie,xn as F,yn as I}from"./constants-C-bSXdJ_.js";import{At as L,E as R,Fn as z,Nt as B,Ot as V,Sr as H,en as U,kr as W,kt as G,yr as K}from"./index-uml6ohnH.js";import{t as q}from"./index.es-CcQaWbuV.js";import{t as J}from"./CopyToClipboard-Dnrr0G1l.js";import{t as Y}from"./ImagePreview-D9ovswSr.js";import{n as ae}from"./taskDrawerMixin-Cr17Yxqk.js";import{t as oe}from"./BotPlaceholder-By9wptjP.js";import{i as X,n as se,t as ce}from"./pagination-BUM1iMKs.js";import{n as le,t as ue}from"./NoTasks-BHtlhARF.js";import{t as de}from"./Consumption-Dlo2Ec9d.js";import{t as fe}from"./ApiCodeButton-CYsbafW5.js";import{t as pe}from"./ImageWrapper-DHnmEVHU.js";var me=s({name:`LayoutNanobanana`,components:{ElDrawer:E,ElButton:v,FontAwesomeIcon:q},mixins:[ae]}),he={class:`main flex flex-row flex-1`},ge={class:`config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]`},_e={class:`result h-full p-6 flex-1 flex flex-col min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]`};function ve(t,n,i,o,s,c){let l=f(`font-awesome-icon`),g=f(`el-button`),_=f(`el-drawer`);return u(),p(`div`,he,[r(`div`,ge,[e(t.$slots,`config`,{},void 0,!0)]),r(`div`,_e,[e(t.$slots,`result`,{},void 0,!0)]),h(a(g,{circle:``,class:`menu`,onClick:n[0]||=e=>t.drawer=!0},{default:m(()=>[a(l,{icon:`fa-solid fa-magic`})]),_:1},512),[[d,!t.tasksEmpty]]),a(_,{modelValue:t.drawer,"onUpdate:modelValue":n[1]||=e=>t.drawer=e,direction:`ltr`,"with-header":!1,size:`340px`,class:`drawer`},{default:m(()=>[e(t.$slots,`config`,{},void 0,!0)]),_:3},8,[`modelValue`])])}var ye=R(me,[[`render`,ve],[`__scopeId`,`data-v-cca80bbd`]]),be=s({name:`PromptInput`,components:{PromptTextarea:le},computed:{prompt:{get(){return this.$store.state.openaiimage?.config?.prompt},set(e){this.$store.commit(`openaiimage/setConfig`,{...this.$store.state.openaiimage?.config,prompt:e})}}},mounted(){this.prompt||=``}});function xe(e,t,r,i,a,o){let s=f(`prompt-textarea`);return u(),n(s,{modelValue:e.prompt,"onUpdate:modelValue":t[0]||=t=>e.prompt=t,title:e.$t(`openaiimage.name.prompt`),info:e.$t(`openaiimage.description.prompt`),placeholder:e.$t(`openaiimage.placeholder.prompt`)},null,8,[`modelValue`,`title`,`info`,`placeholder`])}var Se=R(be,[[`render`,xe]]),Ce=s({name:`ImageUrlsInput`,components:{ElUpload:S,ElButton:v,InfoIcon:X,ImagePreview:Y,FontAwesomeIcon:q},mixins:[G],data(){return{fileList:[],uploadUrl:H()+`/api/v1/files/`,suppressWatch:!1}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e?.response?.file_url).filter(e=>!!e)},value(){return this.$store.state.openaiimage?.config?.image_urls}},watch:{value:{immediate:!0,handler(e){if(this.suppressWatch)return;if(!e||e.length===0){let e=(this.fileList||[]).filter(e=>!e?.response?.file_url);this.fileList=e.length?e:[];return}let t=[];e.forEach(e=>{let n=this.fileList.find(t=>t?.response?.file_url===e||t?.url===e);n?t.push(n):t.push({name:e.split(`/`).pop()||e,url:e,status:`success`,percentage:100,response:{file_url:e}})}),(this.fileList||[]).filter(e=>!e?.response?.file_url).forEach(e=>{t.some(t=>t===e||t?.url===e?.url||t?.response?.file_url===e?.response?.file_url)||t.push(e)}),this.fileList=t}}},mounted(){},methods:{onChange(e){if(!e?.url&&e?.raw)try{e.url=URL.createObjectURL(e.raw)}catch{}},onRemove(e){if(e?.url&&typeof e.url==`string`&&e.url.startsWith(`blob:`))try{URL.revokeObjectURL(e.url)}catch{}this.onSetImageUrls()},onExceed(){W.warning(this.$t(`openaiimage.message.uploadImageExceed`))},onError(){W.error(this.$t(`openaiimage.message.uploadImageError`))},onSetImageUrls(){let e=this.urls;this.suppressWatch=!0,this.$store.commit(`openaiimage/setConfig`,{...this.$store.state.openaiimage?.config,image_urls:e}),this.$nextTick(()=>{this.suppressWatch=!1})},async onSuccess(e,t){e?.file_url&&(t.url=e.file_url,t.response=e),this.onSetImageUrls()},onRemovePreview(e,t){if(this.fileList.splice(e,1),t?.url&&typeof t.url==`string`&&t.url.startsWith(`blob:`))try{URL.revokeObjectURL(t.url)}catch{}this.onSetImageUrls()}}}),we={class:`field flex items-center justify-between`},Te={class:`title font-bold text-[14px] mb-[10px]`},Ee={class:`upload-wrapper flex flex-col items-start gap-[8px]`},De={class:`controls flex items-center`},Oe={class:`file-list flex flex-wrap gap-[10px]`};function ke(e,t,o,s,d,h){let _=f(`font-awesome-icon`),v=f(`el-button`),y=f(`el-upload`),b=f(`info-icon`),x=f(`image-preview`);return u(),p(g,null,[r(`div`,we,[r(`h2`,Te,l(e.$t(`openaiimage.name.imageUrls`)),1),r(`div`,Ee,[r(`div`,De,[a(y,{"file-list":e.fileList,"onUpdate:fileList":t[0]||=t=>e.fileList=t,accept:`.png,.jpg,.jpeg,.gif,.bmp,.webp`,name:`file`,class:`value`,limit:5,multiple:!0,"show-file-list":!1,action:e.uploadUrl,"on-exceed":e.onExceed,"on-error":e.onError,"on-success":e.onSuccess,"on-change":e.onChange,"on-remove":e.onRemove,headers:e.headers},{default:m(()=>[a(v,{size:`small`,type:`primary`,round:``},{default:m(()=>[a(_,{icon:`fa-solid fa-upload`,class:`mr-1`}),i(` `+l(e.$t(`openaiimage.button.uploadImageUrls`)),1)]),_:1})]),_:1},8,[`file-list`,`action`,`on-exceed`,`on-error`,`on-success`,`on-change`,`on-remove`,`headers`]),a(b,{content:e.$t(`openaiimage.description.imageUrls`),class:`ml-2`},null,8,[`content`])])])]),r(`div`,Oe,[(u(!0),p(g,null,c(e.fileList,(t,r)=>(u(),n(x,{key:t.uid||t?.response?.file_url||t.url||r,url:t.url||t?.response?.file_url,name:t.name,percentage:t.percentage,onRemove:n=>e.onRemovePreview(r,t)},null,8,[`url`,`name`,`percentage`,`onRemove`]))),128))])],64)}var Ae=R(Ce,[[`render`,ke]]),je=s({name:`OpenAIImageModelSelector`,components:{ElSelect:b,ElOption:x,InfoIcon:X},data(){return{options:[{value:P,label:this.$t(`openaiimage.model.gptImage1`)},{value:j,label:this.$t(`openaiimage.model.gptImage15`)},{value:ie,label:this.$t(`openaiimage.model.gptImage2`)}]}},computed:{value:{get(){return this.$store.state.openaiimage?.config?.model},set(e){this.$store.commit(`openaiimage/setConfig`,{...this.$store.state.openaiimage?.config,model:e})}},modelDescription(){return this.$t(`openaiimage.description.model`)}},mounted(){this.value||=te}}),Me={class:`field`},Ne={class:`label`},Pe={class:`box`},Fe={class:`title font-bold`};function Ie(e,t,i,o,s,d){let h=f(`info-icon`),_=f(`el-option`),v=f(`el-select`);return u(),p(`div`,Me,[r(`div`,Ne,[r(`div`,Pe,[r(`h2`,Fe,l(e.$t(`openaiimage.name.model`)),1),a(h,{content:e.modelDescription,class:`info`},null,8,[`content`])])]),a(v,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,class:`value`,placeholder:e.$t(`openaiimage.placeholder.select`)},{default:m(()=>[(u(!0),p(g,null,c(e.options,e=>(u(),n(_,{key:e.value,label:e.label,value:e.value},null,8,[`label`,`value`]))),128))]),_:1},8,[`modelValue`,`placeholder`])])}var Le=R(je,[[`render`,Ie],[`__scopeId`,`data-v-cec771bd`]]);function Z(e){if(!e)return;let t=/^(\d+)x(\d+)$/.exec(e);if(t)return{w:Number(t[1]),h:Number(t[2])}}var Re=s({name:`OpenAIImageSizeSelector`,components:{ElSelect:b,ElOption:x,ElOptionGroup:y,ElSwitch:O,ElInputNumber:D,InfoIcon:X},data(){return{customMode:!1,customWidth:1024,customHeight:1024}},computed:{model(){return this.$store.state.openaiimage?.config?.model||`gpt-image-2`},storedSize(){return this.$store.state.openaiimage?.config?.size},emptySizeValue(){return``},customSupported(){return re.includes(this.model)},presets(){return I[this.model]??I[`gpt-image-2`]??[]},presetGroups(){return this.model===`gpt-image-2`?[{label:this.$t(`openaiimage.sizeGroup.standard1k`),options:F},{label:this.$t(`openaiimage.sizeGroup.preset2k`),options:A},{label:this.$t(`openaiimage.sizeGroup.preset4k`),options:k}]:[{label:this.$t(`openaiimage.sizeGroup.standard1k`),options:this.presets}]},useCustom:{get(){return this.customSupported&&this.customMode},set(e){if(!(e&&!this.customSupported))if(this.customMode=e,e){if(this.customError)return;this.commitSize(`${this.customWidth}x${this.customHeight}`)}else this.commitSize()}},presetValue:{get(){let e=this.storedSize;return e&&this.presets.includes(e)?e:this.emptySizeValue},set(e){this.customMode=!1,this.commitSize(e||void 0)}},multiple(){return 16},minSide(){return 256},maxSide(){return M},customError(){let e=this.customWidth,t=this.customHeight;return!Number.isFinite(e)||!Number.isFinite(t)||e<=0||t<=0?this.$t(`openaiimage.error.customSizePositive`):e%this.multiple!==0||t%this.multiple!==0?this.$t(`openaiimage.error.customSizeMultiple`,{multiple:this.multiple}):e<this.minSide||t<this.minSide?this.$t(`openaiimage.error.customSizeMin`,{min:this.minSide}):Math.max(e,t)>this.maxSide?this.$t(`openaiimage.error.customSizeMax`,{max:this.maxSide}):e*t>8294400?this.$t(`openaiimage.error.customSizePixels`,{pixels:N.toLocaleString()}):``}},watch:{model:{immediate:!1,handler(){this.customSupported||(this.customMode=!1);let e=this.storedSize;if(!e||this.presets.includes(e))return;let t=Z(e);t&&this.customSupported&&(this.customMode=!0,this.customWidth=t.w,this.customHeight=t.h,!this.customError)||this.commitSize()}},storedSize(e){if(!e){this.customMode=!1;return}if(this.presets.includes(e)){this.customMode=!1;return}let t=Z(e);t&&this.customSupported&&(this.customMode=!0,this.customWidth!==t.w&&(this.customWidth=t.w),this.customHeight!==t.h&&(this.customHeight=t.h))},customWidth(){this.syncCustomToStore()},customHeight(){this.syncCustomToStore()}},mounted(){let e=this.storedSize,t=Z(e);e&&t&&this.customSupported&&!this.presets.includes(e)&&(this.customMode=!0,this.customWidth=t.w,this.customHeight=t.h)},methods:{commitSize(e){let t={...this.$store.state.openaiimage?.config};e?t.size=e:delete t.size,this.$store.commit(`openaiimage/setConfig`,t)},syncCustomToStore(){this.useCustom&&(this.customError||this.commitSize(`${this.customWidth}x${this.customHeight}`))}}}),ze={class:`resolution`},Be={class:`field`},Ve={class:`label`},He={class:`box`},Ue={class:`title font-bold`},We={class:`field custom-toggle`},Ge={class:`label`},Ke={class:`box`},qe={class:`title font-bold`},Je={key:0,class:`custom-inputs`},Ye={class:`row`},Xe={class:`row-label`},Ze={class:`row`},Qe={class:`row-label`},$e={key:0,class:`error`};function et(e,t,i,s,d,h){let _=f(`info-icon`),v=f(`el-option`),y=f(`el-option-group`),b=f(`el-select`),x=f(`el-switch`),S=f(`el-input-number`);return u(),p(`div`,ze,[r(`div`,Be,[r(`div`,Ve,[r(`div`,He,[r(`h2`,Ue,l(e.$t(`openaiimage.name.size`)),1),a(_,{content:e.$t(`openaiimage.description.size`),class:`info`},null,8,[`content`])])]),a(b,{modelValue:e.presetValue,"onUpdate:modelValue":t[0]||=t=>e.presetValue=t,class:`value`,placeholder:e.$t(`openaiimage.placeholder.select`),disabled:e.useCustom},{default:m(()=>[a(v,{label:e.$t(`suno.gender.auto`),value:e.emptySizeValue},null,8,[`label`,`value`]),(u(!0),p(g,null,c(e.presetGroups,e=>(u(),n(y,{key:e.label,label:e.label},{default:m(()=>[(u(!0),p(g,null,c(e.options,e=>(u(),n(v,{key:e,label:e,value:e},null,8,[`label`,`value`]))),128))]),_:2},1032,[`label`]))),128))]),_:1},8,[`modelValue`,`placeholder`,`disabled`])]),e.customSupported?(u(),p(g,{key:0},[r(`div`,We,[r(`div`,Ge,[r(`div`,Ke,[r(`h2`,qe,l(e.$t(`openaiimage.name.customSize`)),1),a(_,{content:e.$t(`openaiimage.description.customSize`),class:`info`},null,8,[`content`])])]),a(x,{modelValue:e.useCustom,"onUpdate:modelValue":t[1]||=t=>e.useCustom=t,class:`value-switch`},null,8,[`modelValue`])]),e.useCustom?(u(),p(`div`,Je,[r(`div`,Ye,[r(`span`,Xe,l(e.$t(`openaiimage.name.width`)),1),a(S,{modelValue:e.customWidth,"onUpdate:modelValue":t[2]||=t=>e.customWidth=t,class:`row-input`,min:e.minSide,max:e.maxSide,step:e.multiple,"step-strictly":!0,"controls-position":`right`},null,8,[`modelValue`,`min`,`max`,`step`])]),r(`div`,Ze,[r(`span`,Qe,l(e.$t(`openaiimage.name.height`)),1),a(S,{modelValue:e.customHeight,"onUpdate:modelValue":t[3]||=t=>e.customHeight=t,class:`row-input`,min:e.minSide,max:e.maxSide,step:e.multiple,"step-strictly":!0,"controls-position":`right`},null,8,[`modelValue`,`min`,`max`,`step`])]),e.customError?(u(),p(`div`,$e,l(e.customError),1)):o(``,!0)])):o(``,!0)],64)):o(``,!0)])}var tt=s({name:`ConfigPanel`,components:{ElButton:v,FontAwesomeIcon:q,PromptInput:Se,Consumption:de,ImageUrlsInput:Ae,ModelSelector:Le,ResolutionSelector:R(Re,[[`render`,et],[`__scopeId`,`data-v-d5544d69`]])},emits:[`generate`],computed:{config(){return this.$store.state.openaiimage?.config},consumption(){return B({...this.config||{}},this.service?.cost)},service(){return this.$store.state.openaiimage?.service}},methods:{onGenerate(){this.$emit(`generate`)}}}),nt={class:`flex flex-col h-full`},rt={class:`flex-1 overflow-y-auto p-5`},it={class:`flex flex-col items-center justify-center px-5 pb-5`};function at(e,t,n,o,s,c){let d=f(`model-selector`),h=f(`resolution-selector`),g=f(`prompt-input`),_=f(`image-urls-input`),v=f(`consumption`),y=f(`font-awesome-icon`),b=f(`el-button`);return u(),p(`div`,nt,[r(`div`,rt,[a(d,{class:`mb-4`}),a(h,{class:`mb-4`}),a(g,{class:`mb-4`}),a(_,{class:`mb-4`})]),r(`div`,it,[a(v,{value:e.consumption,service:e.service},null,8,[`value`,`service`]),a(b,{type:`primary`,class:`btn w-full`,round:``,onClick:e.onGenerate},{default:m(()=>[a(y,{icon:`fa-solid fa-magic`,class:`mr-2`}),i(` `+l(e.$t(`openaiimage.button.generate`)),1)]),_:1},8,[`onClick`])])])}var ot=R(tt,[[`render`,at]]),st=s({name:`TaskPreview`,components:{ElImage:w,CopyToClipboard:J,FontAwesomeIcon:q,ElAlert:T,ImageWrapper:pe,ElButton:v,ElTooltip:C,ImagePreview:Y,ApiCodeButton:fe},props:{modelValue:{type:Object,required:!0}},setup(){return{OPENAIIMAGE_LOGO:ee}},computed:{isEditRequest(){let e=this.modelValue?.request;return this.modelValue?.type===`images_edits`||e?.action===`edit`||this.referenceImages.length>0},showTaskType(){return!!(this.modelValue?.request?.action||this.modelValue?.type||this.referenceImages.length>0)},taskTypeLabel(){return this.isEditRequest?this.$t(`openaiimage.name.edits`):this.$t(`openaiimage.name.generate`)},openaiimagePath(){return this.isEditRequest?`/openai/images/edits`:`/openai/images/generations`},openaiimageCodeBody(){let e=this.modelValue?.request;if(!e)return;let t={...e};if(delete t.action,delete t.callback_url,this.isEditRequest){delete t.image_urls,delete t.image;let e=this.referenceImages;e.length===1?t.image=e[0]:e.length>1&&(t.image=e)}else delete t.image_urls,delete t.image;return t},images(){let e=[];return Array.isArray(this.modelValue?.response?.data)&&this.modelValue?.response?.data?.forEach(t=>{let n=t;if(n?.image_url||n?.url){e.push(n);return}n?.b64_json&&e.push({...n,url:`data:image/png;base64,${n.b64_json}`})}),e},referenceImages(){let e=this.modelValue?.request;if(!e)return[];let t=Array.isArray(e.image_urls)?e.image_urls:[];if(t.length>0)return t.filter(e=>typeof e==`string`&&e.length>0);let n=e.image;return Array.isArray(n)?n.filter(e=>typeof e==`string`&&e.length>0):typeof n==`string`&&n.length>0?[n]:Array.isArray(e.images)?e.images.map(e=>{if(typeof e==`string`)return e;if(e&&typeof e==`object`)return e.image_url}).filter(e=>typeof e==`string`&&e.length>0):[]}},methods:{onEdit(e){if(!e)return;console.debug(`Edit image:`,e);let t={...this.$store.state.openaiimage?.config||{}};t.image_urls=[e],this.$store.commit(`openaiimage/setConfig`,t)}}}),ct={class:`preview`},lt={class:`left`},ut={class:`main`},dt={class:`bot`},ft={class:`datetime`},pt={class:`info`},mt={key:0,class:`flex justify-start items-center gap-2 mt-2 w-full overflow-x-auto`},ht={key:1,class:`prompt mt-2`},gt={key:0},_t={key:0,class:t({content:!0,failed:!0})},vt={class:`flex justify-start items-center gap-4 w-full overflow-x-auto`},yt={class:t({operations:!0,"mt-2":!0,"mb-2":!0})},bt={key:0,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},xt={key:1,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},St={key:2,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},Ct={class:`text-[var(--el-text-color-regular)] text-xs mb-2`},wt={key:3,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},Tt={key:4,class:`text-[var(--el-text-color-regular)] text-xs mb-0`},Et={key:1,class:t({content:!0})},Dt={key:0,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},Ot={key:1,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},kt={key:2,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},At={class:`text-[var(--el-text-color-regular)] text-xs mb-2`},jt={class:`text-[var(--el-text-color-regular)] text-xs mb-2`},Mt={key:3,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},Nt={key:4,class:`text-[var(--el-text-color-regular)] text-xs mb-0`},Pt={key:2,class:t({content:!0})},Q={key:0,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},Ft={key:1,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},It={key:2,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},Lt={class:`text-[var(--el-text-color-regular)] text-xs mb-2`};function Rt(e,t,s,d,h,v){let y=f(`el-image`),b=f(`image-preview`),x=f(`image-wrapper`),S=f(`el-button`),C=f(`el-tooltip`),w=f(`api-code-button`),T=f(`font-awesome-icon`),E=f(`copy-to-clipboard`),D=f(`el-alert`);return u(),p(`div`,ct,[r(`div`,lt,[a(y,{src:e.OPENAIIMAGE_LOGO,class:`avatar`},null,8,[`src`])]),r(`div`,ut,[r(`div`,dt,[i(l(e.$t(`openaiimage.name.openaiimageBot`))+` `,1),r(`span`,ft,l(e.$dayjs.format(``+new Date(parseFloat((e.modelValue?.created_at||``).toString())*1e3))),1)]),r(`div`,pt,[e.referenceImages.length>0?(u(),p(`div`,mt,[(u(!0),p(g,null,c(e.referenceImages,(e,t)=>(u(),n(b,{key:t,url:e,name:`image-${t+1}`,closable:!1},null,8,[`url`,`name`]))),128))])):o(``,!0),e.modelValue?.request?.prompt?(u(),p(`p`,ht,[i(l(e.modelValue?.request?.prompt)+` `,1),e.modelValue?.response?o(``,!0):(u(),p(`span`,gt,` - (`+l(e.$t(`openaiimage.status.pending`))+`) `,1))])):o(``,!0)]),e.modelValue?.response?.success===!0?(u(),p(`div`,_t,[r(`div`,vt,[(u(!0),p(g,null,c(e.images,(e,t)=>(u(),n(x,{key:t,src:e?.image_url||e?.url||``,"raw-src":e?.image_url||e?.url||``},null,8,[`src`,`raw-src`]))),128))]),r(`div`,yt,[a(C,{class:`box-item`,effect:`dark`,content:e.$t(`common.button.edit`),placement:`top-start`},{default:m(()=>[a(S,{type:`info`,size:`small`,class:`btn-action`,onClick:t[0]||=_(t=>e.onEdit(e.images?.[0]?.image_url||e.images?.[0]?.url),[`stop`])},{default:m(()=>[i(l(e.$t(`common.button.edit`)),1)]),_:1})]),_:1},8,[`content`]),a(w,{path:e.openaiimagePath,body:e.openaiimageCodeBody},null,8,[`path`,`body`])]),a(D,{closable:!1,class:`mt-2 success`},{default:m(()=>[e.modelValue?.request?.model?(u(),p(`p`,bt,[a(T,{icon:`fa-solid fa-cube`,class:`mr-1`}),i(` `+l(e.$t(`openaiimage.name.model`))+`: `+l(e.modelValue?.request?.model),1)])):o(``,!0),e.modelValue?.request?.size?(u(),p(`p`,xt,[a(T,{icon:`fa-solid fa-image`,class:`mr-1`}),i(` `+l(e.$t(`openaiimage.name.size`))+`: `+l(e.modelValue?.request?.size),1)])):o(``,!0),e.showTaskType?(u(),p(`p`,St,[a(T,{icon:`fa-solid fa-bolt`,class:`mr-1`}),i(` `+l(e.$t(`openaiimage.name.task`))+`: `+l(e.taskTypeLabel),1)])):o(``,!0),r(`p`,Ct,[a(T,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+l(e.$t(`openaiimage.name.taskId`))+`: `+l(e.modelValue?.id)+` `,1),a(E,{content:e.modelValue?.id,class:`btn-copy inline-block`},null,8,[`content`])]),e.modelValue?.elapsed?(u(),p(`p`,wt,[a(T,{icon:`fa-solid fa-clock`,class:`mr-1`}),i(` `+l(e.$t(`openaiimage.name.elapsed`))+`: `+l(e.modelValue?.elapsed?.toFixed(2))+`s `,1)])):o(``,!0),e.modelValue?.response?.trace_id?(u(),p(`p`,Tt,[a(T,{icon:`fa-solid fa-hashtag`,class:`mr-1`}),i(` `+l(e.$t(`openaiimage.name.traceId`))+`: `+l(e.modelValue?.response?.trace_id)+` `,1),a(E,{content:e.modelValue?.response?.trace_id,class:`btn-copy inline-block`},null,8,[`content`])])):o(``,!0)]),_:1})])):e.modelValue?.response?.success===!1?(u(),p(`div`,Et,[a(D,{closable:!1,class:`failure`},{template:m(()=>[a(T,{icon:`fa-solid fa-exclamation-triangle`,class:`mr-1`}),i(` `+l(e.$t(`openaiimage.name.failure`)),1)]),default:m(()=>[e.modelValue?.request?.model?(u(),p(`p`,Dt,[a(T,{icon:`fa-solid fa-cube`,class:`mr-1`}),i(` `+l(e.$t(`openaiimage.name.model`))+`: `+l(e.modelValue?.request?.model),1)])):o(``,!0),e.modelValue?.request?.size?(u(),p(`p`,Ot,[a(T,{icon:`fa-solid fa-image`,class:`mr-1`}),i(` `+l(e.$t(`openaiimage.name.size`))+`: `+l(e.modelValue?.request?.size),1)])):o(``,!0),e.showTaskType?(u(),p(`p`,kt,[a(T,{icon:`fa-solid fa-bolt`,class:`mr-1`}),i(` `+l(e.$t(`openaiimage.name.task`))+`: `+l(e.taskTypeLabel),1)])):o(``,!0),r(`p`,At,[a(T,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+l(e.$t(`openaiimage.name.taskId`))+`: `+l(e.modelValue?.id)+` `,1),a(E,{content:e.modelValue?.id,class:`btn-copy`},null,8,[`content`])]),r(`p`,jt,[a(T,{icon:`fa-solid fa-circle-info`,class:`mr-1`}),i(` `+l(e.$t(`openaiimage.name.failureReason`))+`: `+l(e.modelValue?.response?.error?.message)+` `,1),a(E,{content:e.modelValue?.response?.error?.message,class:`btn-copy`},null,8,[`content`])]),e.modelValue?.elapsed?(u(),p(`p`,Mt,[a(T,{icon:`fa-solid fa-clock`,class:`mr-1`}),i(` `+l(e.$t(`openaiimage.name.elapsed`))+`: `+l(e.modelValue?.elapsed?.toFixed(2))+`s `,1)])):o(``,!0),e.modelValue?.response?.trace_id?(u(),p(`p`,Nt,[a(T,{icon:`fa-solid fa-hashtag`,class:`mr-1`}),i(` `+l(e.$t(`openaiimage.name.traceId`))+`: `+l(e.modelValue?.response?.trace_id)+` `,1),a(E,{content:e.modelValue?.response?.trace_id,class:`btn-copy`},null,8,[`content`])])):o(``,!0)]),_:1})])):(u(),p(`div`,Pt,[a(D,{closable:!1,class:`info`},{template:m(()=>[a(T,{icon:`fa-solid fa-exclamation-triangle`,class:`mr-1`}),i(` `+l(e.$t(`openaiimage.name.failure`)),1)]),default:m(()=>[e.modelValue?.request?.model?(u(),p(`p`,Q,[a(T,{icon:`fa-solid fa-cube`,class:`mr-1`}),i(` `+l(e.$t(`openaiimage.name.model`))+`: `+l(e.modelValue?.request?.model),1)])):o(``,!0),e.modelValue?.request?.size?(u(),p(`p`,Ft,[a(T,{icon:`fa-solid fa-image`,class:`mr-1`}),i(` `+l(e.$t(`openaiimage.name.size`))+`: `+l(e.modelValue?.request?.size),1)])):o(``,!0),e.showTaskType?(u(),p(`p`,It,[a(T,{icon:`fa-solid fa-bolt`,class:`mr-1`}),i(` `+l(e.$t(`openaiimage.name.task`))+`: `+l(e.taskTypeLabel),1)])):o(``,!0),r(`p`,Lt,[a(T,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+l(e.$t(`openaiimage.name.taskId`))+`: `+l(e.modelValue?.id)+` `,1),a(E,{content:e.modelValue?.id,class:`btn-copy`},null,8,[`content`])])]),_:1})]))])])}var zt=s({name:`RecentPanel`,components:{TaskPreview:R(st,[[`render`,Rt],[`__scopeId`,`data-v-8ee5fb87`]]),BotPlaceholder:oe,NoTasks:ue,ScrollList:se},props:{loading:{type:Boolean,default:!1}},emits:[`reach-top`],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.openaiimage?.tasks,items:this.$store.state.openaiimage?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),Bt={key:0},Vt={key:2,class:`w-full h-full flex items-center justify-center`};function Ht(e,t,r,i,s,l){let d=f(`bot-placeholder`),h=f(`task-preview`),_=f(`scroll-list`),v=f(`no-tasks`);return u(),p(g,null,[e.tasks?.items===void 0?(u(),p(`div`,Bt,[a(d)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(u(),n(_,{key:1,ref:`scrollList`,class:`tasks h-full w-full overflow-y-auto`,loading:e.loading,onReachTop:t[0]||=t=>e.$emit(`reach-top`)},{default:m(()=>[(u(!0),p(g,null,c(e.tasks?.items,e=>(u(),n(h,{key:e.id,"model-value":e},null,8,[`model-value`]))),128))]),_:1},8,[`loading`])):o(``,!0),e.tasks?.items?.length===0?(u(),p(`div`,Vt,[a(v)])):o(``,!0)],64)}var Ut=R(zt,[[`render`,Ht]]),$=ne(`openaiimage`),Wt=s({name:`OpenAIImageIndex`,components:{ConfigPanel:ot,Layout:ye,RecentPanel:Ut},mixins:[L],inject:[`initialized`],data(){return{task:void 0,job:0,loading:!1}},computed:{applicationsLoading(){return this.$store.state.openaiimage?.status?.getApplications===K.Request},tasksLoading(){return this.$store.state.openaiimage?.status?.getTasks===K.Request},credential(){return this.$store.state.openaiimage?.credential},config(){return this.$store.state.openaiimage?.config},application(){return this.$store.state.openaiimage?.application},tasks(){return this.$store.state.openaiimage?.tasks}},watch:{tasks:{handler(e,t){e?.items?.length>t?.items?.length&&console.debug(`new tasks detected`)},deep:!0},initialized:{async handler(e){e&&(console.debug(`layout initialized`),await this.onGetTasks(),await this.onScrollDown(),this.job=window.setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){window.clearInterval(this.job)},methods:{async onReachTop(){await ce({tasks:this.tasks,getTasks:()=>this.tasks,loading:this.loading,setLoading:e=>this.loading=e,isBlocked:()=>this.tasksLoading,fetch:e=>this.onGetTasks({createdAtMax:e}),getScrollElement:()=>this.getTasksScrollElement()})},async onGetService(){console.debug(`start onGetService`),await this.$store.dispatch(`openaiimage/getService`),console.debug(`end onGetService`)},async onGetApplication(){console.debug(`start onGetApplication`),await this.$store.dispatch(`openaiimage/getApplications`),console.debug(`end onGetApplication`),await this.onGetTasks()},async onScrollDown(){await this.$nextTick();let e=this.getTasksScrollElement();e&&(e.scrollTop=e.scrollHeight)},async onGetTasks(e){if(this.applicationsLoading||this.tasksLoading){console.debug(`loading`);return}console.debug(`start onGetTasks`,e);let{limit:t=20,createdAtMin:n,createdAtMax:r}=e||{};console.debug(`limit`,t,`createdAtMin`,n,`createdAtMax`,r),await this.$store.dispatch(`openaiimage/getTasks`,{limit:t,createdAtMin:n,createdAtMax:r})},async onGenerate(){if(!V(this.uploadTracker,e=>this.$t(e),e=>W.warning(e)))return;let e={...this.config||{}},t=Array.isArray(e?.image_urls)&&e.image_urls.length>0;if(!this.hasText(e.prompt)){W.error(this.$t(`openaiimage.message.promptRequired`));return}e.prompt=e.prompt.trim(),!t&&`image_urls`in e&&delete e.image_urls,e.size||delete e.size;let n={...e,action:`generate`,callback_url:$},r={action:`edit`,model:e?.model,prompt:e?.prompt,size:e?.size,image_urls:e?.image_urls||[],callback_url:$},i=this.credential?.token;if(!i){console.error(`no token specified`);return}W.info(this.$t(`openaiimage.message.startingTask`)),z(`openaiimage`,t?U.edit(r,{token:i}):U.generate(n,{token:i})).then(e=>{console.debug(`task accepted`,e.data?.task_id),W.success(this.$t(`openaiimage.message.startTaskSuccess`))}).catch(e=>{let t=e?.response?.data;t?.error?.code===`used_up`?W.error(this.$t(`openaiimage.message.usedUp`)):W.error(this.$t(`openaiimage.message.startTaskFailed`)+(t?.error?.message||``))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()},hasText(e){return typeof e==`string`&&e.trim().length>0}}});function Gt(e,t,r,i,o,s){let c=f(`config-panel`),l=f(`recent-panel`),d=f(`layout`);return u(),n(d,null,{config:m(()=>[a(c,{onGenerate:e.onGenerate},null,8,[`onGenerate`])]),result:m(()=>[a(l,{ref:`recentPanel`,loading:e.loading,onReachTop:e.onReachTop},null,8,[`loading`,`onReachTop`])]),_:1})}var Kt=R(Wt,[[`render`,Gt]]);export{Kt as default};
1
+ import"./rolldown-runtime--c01j_DQ.js";import{$ as e,Bt as t,D as n,E as r,M as i,N as a,O as o,P as s,Q as c,Ut as l,X as u,_ as d,et as f,k as p,lt as m,ut as h,x as g,y as _}from"./vendor-chart-mdwpew_o.js";import{t as v}from"./button-DWzbdjZV.js";import{n as y,r as b,t as x}from"./select-Byt7Qw1F.js";import{t as S}from"./upload-CDJi96y4.js";import{t as C}from"./tooltip-C3PYfh8V.js";import{t as w}from"./image-CUt2yKJT.js";import{t as T}from"./alert-BJj7gY4q.js";import{t as E}from"./drawer-BvYPSxXh.js";import{t as D}from"./input-number-CXFB1_xE.js";import{t as O}from"./switch-CqHzcX_8.js";import{Cn as k,Sn as A,_n as j,dn as M,fn as N,gn as P,hn as ee,mn as te,pi as ne,pn as re,vn as ie,xn as F,yn as I}from"./constants-C-bSXdJ_.js";import{At as L,E as R,Fn as z,Nt as B,Ot as V,Sr as H,en as U,kr as W,kt as G,yr as K}from"./index-Dzx62HWL.js";import{t as q}from"./index.es-BIezN10l.js";import{t as J}from"./CopyToClipboard-LZRed5aB.js";import{t as Y}from"./ImagePreview-B2FwyzyM.js";import{n as ae}from"./taskDrawerMixin-Cr17Yxqk.js";import{t as oe}from"./BotPlaceholder-DzIzZltA.js";import{i as X,n as se,t as ce}from"./pagination-t1m3PdtM.js";import{n as le,t as ue}from"./NoTasks-Bk9F1-iz.js";import{t as de}from"./Consumption-DLzGFeUT.js";import{t as fe}from"./ApiCodeButton-C8TdRvY9.js";import{t as pe}from"./ImageWrapper-_6c4eeKK.js";var me=s({name:`LayoutNanobanana`,components:{ElDrawer:E,ElButton:v,FontAwesomeIcon:q},mixins:[ae]}),he={class:`main flex flex-row flex-1`},ge={class:`config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]`},_e={class:`result h-full p-6 flex-1 flex flex-col min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]`};function ve(t,n,i,o,s,c){let l=f(`font-awesome-icon`),g=f(`el-button`),_=f(`el-drawer`);return u(),p(`div`,he,[r(`div`,ge,[e(t.$slots,`config`,{},void 0,!0)]),r(`div`,_e,[e(t.$slots,`result`,{},void 0,!0)]),h(a(g,{circle:``,class:`menu`,onClick:n[0]||=e=>t.drawer=!0},{default:m(()=>[a(l,{icon:`fa-solid fa-magic`})]),_:1},512),[[d,!t.tasksEmpty]]),a(_,{modelValue:t.drawer,"onUpdate:modelValue":n[1]||=e=>t.drawer=e,direction:`ltr`,"with-header":!1,size:`340px`,class:`drawer`},{default:m(()=>[e(t.$slots,`config`,{},void 0,!0)]),_:3},8,[`modelValue`])])}var ye=R(me,[[`render`,ve],[`__scopeId`,`data-v-cca80bbd`]]),be=s({name:`PromptInput`,components:{PromptTextarea:le},computed:{prompt:{get(){return this.$store.state.openaiimage?.config?.prompt},set(e){this.$store.commit(`openaiimage/setConfig`,{...this.$store.state.openaiimage?.config,prompt:e})}}},mounted(){this.prompt||=``}});function xe(e,t,r,i,a,o){let s=f(`prompt-textarea`);return u(),n(s,{modelValue:e.prompt,"onUpdate:modelValue":t[0]||=t=>e.prompt=t,title:e.$t(`openaiimage.name.prompt`),info:e.$t(`openaiimage.description.prompt`),placeholder:e.$t(`openaiimage.placeholder.prompt`)},null,8,[`modelValue`,`title`,`info`,`placeholder`])}var Se=R(be,[[`render`,xe]]),Ce=s({name:`ImageUrlsInput`,components:{ElUpload:S,ElButton:v,InfoIcon:X,ImagePreview:Y,FontAwesomeIcon:q},mixins:[G],data(){return{fileList:[],uploadUrl:H()+`/api/v1/files/`,suppressWatch:!1}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e?.response?.file_url).filter(e=>!!e)},value(){return this.$store.state.openaiimage?.config?.image_urls}},watch:{value:{immediate:!0,handler(e){if(this.suppressWatch)return;if(!e||e.length===0){let e=(this.fileList||[]).filter(e=>!e?.response?.file_url);this.fileList=e.length?e:[];return}let t=[];e.forEach(e=>{let n=this.fileList.find(t=>t?.response?.file_url===e||t?.url===e);n?t.push(n):t.push({name:e.split(`/`).pop()||e,url:e,status:`success`,percentage:100,response:{file_url:e}})}),(this.fileList||[]).filter(e=>!e?.response?.file_url).forEach(e=>{t.some(t=>t===e||t?.url===e?.url||t?.response?.file_url===e?.response?.file_url)||t.push(e)}),this.fileList=t}}},mounted(){},methods:{onChange(e){if(!e?.url&&e?.raw)try{e.url=URL.createObjectURL(e.raw)}catch{}},onRemove(e){if(e?.url&&typeof e.url==`string`&&e.url.startsWith(`blob:`))try{URL.revokeObjectURL(e.url)}catch{}this.onSetImageUrls()},onExceed(){W.warning(this.$t(`openaiimage.message.uploadImageExceed`))},onError(){W.error(this.$t(`openaiimage.message.uploadImageError`))},onSetImageUrls(){let e=this.urls;this.suppressWatch=!0,this.$store.commit(`openaiimage/setConfig`,{...this.$store.state.openaiimage?.config,image_urls:e}),this.$nextTick(()=>{this.suppressWatch=!1})},async onSuccess(e,t){e?.file_url&&(t.url=e.file_url,t.response=e),this.onSetImageUrls()},onRemovePreview(e,t){if(this.fileList.splice(e,1),t?.url&&typeof t.url==`string`&&t.url.startsWith(`blob:`))try{URL.revokeObjectURL(t.url)}catch{}this.onSetImageUrls()}}}),we={class:`field flex items-center justify-between`},Te={class:`title font-bold text-[14px] mb-[10px]`},Ee={class:`upload-wrapper flex flex-col items-start gap-[8px]`},De={class:`controls flex items-center`},Oe={class:`file-list flex flex-wrap gap-[10px]`};function ke(e,t,o,s,d,h){let _=f(`font-awesome-icon`),v=f(`el-button`),y=f(`el-upload`),b=f(`info-icon`),x=f(`image-preview`);return u(),p(g,null,[r(`div`,we,[r(`h2`,Te,l(e.$t(`openaiimage.name.imageUrls`)),1),r(`div`,Ee,[r(`div`,De,[a(y,{"file-list":e.fileList,"onUpdate:fileList":t[0]||=t=>e.fileList=t,accept:`.png,.jpg,.jpeg,.gif,.bmp,.webp`,name:`file`,class:`value`,limit:5,multiple:!0,"show-file-list":!1,action:e.uploadUrl,"on-exceed":e.onExceed,"on-error":e.onError,"on-success":e.onSuccess,"on-change":e.onChange,"on-remove":e.onRemove,headers:e.headers},{default:m(()=>[a(v,{size:`small`,type:`primary`,round:``},{default:m(()=>[a(_,{icon:`fa-solid fa-upload`,class:`mr-1`}),i(` `+l(e.$t(`openaiimage.button.uploadImageUrls`)),1)]),_:1})]),_:1},8,[`file-list`,`action`,`on-exceed`,`on-error`,`on-success`,`on-change`,`on-remove`,`headers`]),a(b,{content:e.$t(`openaiimage.description.imageUrls`),class:`ml-2`},null,8,[`content`])])])]),r(`div`,Oe,[(u(!0),p(g,null,c(e.fileList,(t,r)=>(u(),n(x,{key:t.uid||t?.response?.file_url||t.url||r,url:t.url||t?.response?.file_url,name:t.name,percentage:t.percentage,onRemove:n=>e.onRemovePreview(r,t)},null,8,[`url`,`name`,`percentage`,`onRemove`]))),128))])],64)}var Ae=R(Ce,[[`render`,ke]]),je=s({name:`OpenAIImageModelSelector`,components:{ElSelect:b,ElOption:x,InfoIcon:X},data(){return{options:[{value:P,label:this.$t(`openaiimage.model.gptImage1`)},{value:j,label:this.$t(`openaiimage.model.gptImage15`)},{value:ie,label:this.$t(`openaiimage.model.gptImage2`)}]}},computed:{value:{get(){return this.$store.state.openaiimage?.config?.model},set(e){this.$store.commit(`openaiimage/setConfig`,{...this.$store.state.openaiimage?.config,model:e})}},modelDescription(){return this.$t(`openaiimage.description.model`)}},mounted(){this.value||=te}}),Me={class:`field`},Ne={class:`label`},Pe={class:`box`},Fe={class:`title font-bold`};function Ie(e,t,i,o,s,d){let h=f(`info-icon`),_=f(`el-option`),v=f(`el-select`);return u(),p(`div`,Me,[r(`div`,Ne,[r(`div`,Pe,[r(`h2`,Fe,l(e.$t(`openaiimage.name.model`)),1),a(h,{content:e.modelDescription,class:`info`},null,8,[`content`])])]),a(v,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,class:`value`,placeholder:e.$t(`openaiimage.placeholder.select`)},{default:m(()=>[(u(!0),p(g,null,c(e.options,e=>(u(),n(_,{key:e.value,label:e.label,value:e.value},null,8,[`label`,`value`]))),128))]),_:1},8,[`modelValue`,`placeholder`])])}var Le=R(je,[[`render`,Ie],[`__scopeId`,`data-v-cec771bd`]]);function Z(e){if(!e)return;let t=/^(\d+)x(\d+)$/.exec(e);if(t)return{w:Number(t[1]),h:Number(t[2])}}var Re=s({name:`OpenAIImageSizeSelector`,components:{ElSelect:b,ElOption:x,ElOptionGroup:y,ElSwitch:O,ElInputNumber:D,InfoIcon:X},data(){return{customMode:!1,customWidth:1024,customHeight:1024}},computed:{model(){return this.$store.state.openaiimage?.config?.model||`gpt-image-2`},storedSize(){return this.$store.state.openaiimage?.config?.size},emptySizeValue(){return``},customSupported(){return re.includes(this.model)},presets(){return I[this.model]??I[`gpt-image-2`]??[]},presetGroups(){return this.model===`gpt-image-2`?[{label:this.$t(`openaiimage.sizeGroup.standard1k`),options:F},{label:this.$t(`openaiimage.sizeGroup.preset2k`),options:A},{label:this.$t(`openaiimage.sizeGroup.preset4k`),options:k}]:[{label:this.$t(`openaiimage.sizeGroup.standard1k`),options:this.presets}]},useCustom:{get(){return this.customSupported&&this.customMode},set(e){if(!(e&&!this.customSupported))if(this.customMode=e,e){if(this.customError)return;this.commitSize(`${this.customWidth}x${this.customHeight}`)}else this.commitSize()}},presetValue:{get(){let e=this.storedSize;return e&&this.presets.includes(e)?e:this.emptySizeValue},set(e){this.customMode=!1,this.commitSize(e||void 0)}},multiple(){return 16},minSide(){return 256},maxSide(){return M},customError(){let e=this.customWidth,t=this.customHeight;return!Number.isFinite(e)||!Number.isFinite(t)||e<=0||t<=0?this.$t(`openaiimage.error.customSizePositive`):e%this.multiple!==0||t%this.multiple!==0?this.$t(`openaiimage.error.customSizeMultiple`,{multiple:this.multiple}):e<this.minSide||t<this.minSide?this.$t(`openaiimage.error.customSizeMin`,{min:this.minSide}):Math.max(e,t)>this.maxSide?this.$t(`openaiimage.error.customSizeMax`,{max:this.maxSide}):e*t>8294400?this.$t(`openaiimage.error.customSizePixels`,{pixels:N.toLocaleString()}):``}},watch:{model:{immediate:!1,handler(){this.customSupported||(this.customMode=!1);let e=this.storedSize;if(!e||this.presets.includes(e))return;let t=Z(e);t&&this.customSupported&&(this.customMode=!0,this.customWidth=t.w,this.customHeight=t.h,!this.customError)||this.commitSize()}},storedSize(e){if(!e){this.customMode=!1;return}if(this.presets.includes(e)){this.customMode=!1;return}let t=Z(e);t&&this.customSupported&&(this.customMode=!0,this.customWidth!==t.w&&(this.customWidth=t.w),this.customHeight!==t.h&&(this.customHeight=t.h))},customWidth(){this.syncCustomToStore()},customHeight(){this.syncCustomToStore()}},mounted(){let e=this.storedSize,t=Z(e);e&&t&&this.customSupported&&!this.presets.includes(e)&&(this.customMode=!0,this.customWidth=t.w,this.customHeight=t.h)},methods:{commitSize(e){let t={...this.$store.state.openaiimage?.config};e?t.size=e:delete t.size,this.$store.commit(`openaiimage/setConfig`,t)},syncCustomToStore(){this.useCustom&&(this.customError||this.commitSize(`${this.customWidth}x${this.customHeight}`))}}}),ze={class:`resolution`},Be={class:`field`},Ve={class:`label`},He={class:`box`},Ue={class:`title font-bold`},We={class:`field custom-toggle`},Ge={class:`label`},Ke={class:`box`},qe={class:`title font-bold`},Je={key:0,class:`custom-inputs`},Ye={class:`row`},Xe={class:`row-label`},Ze={class:`row`},Qe={class:`row-label`},$e={key:0,class:`error`};function et(e,t,i,s,d,h){let _=f(`info-icon`),v=f(`el-option`),y=f(`el-option-group`),b=f(`el-select`),x=f(`el-switch`),S=f(`el-input-number`);return u(),p(`div`,ze,[r(`div`,Be,[r(`div`,Ve,[r(`div`,He,[r(`h2`,Ue,l(e.$t(`openaiimage.name.size`)),1),a(_,{content:e.$t(`openaiimage.description.size`),class:`info`},null,8,[`content`])])]),a(b,{modelValue:e.presetValue,"onUpdate:modelValue":t[0]||=t=>e.presetValue=t,class:`value`,placeholder:e.$t(`openaiimage.placeholder.select`),disabled:e.useCustom},{default:m(()=>[a(v,{label:e.$t(`suno.gender.auto`),value:e.emptySizeValue},null,8,[`label`,`value`]),(u(!0),p(g,null,c(e.presetGroups,e=>(u(),n(y,{key:e.label,label:e.label},{default:m(()=>[(u(!0),p(g,null,c(e.options,e=>(u(),n(v,{key:e,label:e,value:e},null,8,[`label`,`value`]))),128))]),_:2},1032,[`label`]))),128))]),_:1},8,[`modelValue`,`placeholder`,`disabled`])]),e.customSupported?(u(),p(g,{key:0},[r(`div`,We,[r(`div`,Ge,[r(`div`,Ke,[r(`h2`,qe,l(e.$t(`openaiimage.name.customSize`)),1),a(_,{content:e.$t(`openaiimage.description.customSize`),class:`info`},null,8,[`content`])])]),a(x,{modelValue:e.useCustom,"onUpdate:modelValue":t[1]||=t=>e.useCustom=t,class:`value-switch`},null,8,[`modelValue`])]),e.useCustom?(u(),p(`div`,Je,[r(`div`,Ye,[r(`span`,Xe,l(e.$t(`openaiimage.name.width`)),1),a(S,{modelValue:e.customWidth,"onUpdate:modelValue":t[2]||=t=>e.customWidth=t,class:`row-input`,min:e.minSide,max:e.maxSide,step:e.multiple,"step-strictly":!0,"controls-position":`right`},null,8,[`modelValue`,`min`,`max`,`step`])]),r(`div`,Ze,[r(`span`,Qe,l(e.$t(`openaiimage.name.height`)),1),a(S,{modelValue:e.customHeight,"onUpdate:modelValue":t[3]||=t=>e.customHeight=t,class:`row-input`,min:e.minSide,max:e.maxSide,step:e.multiple,"step-strictly":!0,"controls-position":`right`},null,8,[`modelValue`,`min`,`max`,`step`])]),e.customError?(u(),p(`div`,$e,l(e.customError),1)):o(``,!0)])):o(``,!0)],64)):o(``,!0)])}var tt=s({name:`ConfigPanel`,components:{ElButton:v,FontAwesomeIcon:q,PromptInput:Se,Consumption:de,ImageUrlsInput:Ae,ModelSelector:Le,ResolutionSelector:R(Re,[[`render`,et],[`__scopeId`,`data-v-d5544d69`]])},emits:[`generate`],computed:{config(){return this.$store.state.openaiimage?.config},consumption(){return B({...this.config||{}},this.service?.cost)},service(){return this.$store.state.openaiimage?.service}},methods:{onGenerate(){this.$emit(`generate`)}}}),nt={class:`flex flex-col h-full`},rt={class:`flex-1 overflow-y-auto p-5`},it={class:`flex flex-col items-center justify-center px-5 pb-5`};function at(e,t,n,o,s,c){let d=f(`model-selector`),h=f(`resolution-selector`),g=f(`prompt-input`),_=f(`image-urls-input`),v=f(`consumption`),y=f(`font-awesome-icon`),b=f(`el-button`);return u(),p(`div`,nt,[r(`div`,rt,[a(d,{class:`mb-4`}),a(h,{class:`mb-4`}),a(g,{class:`mb-4`}),a(_,{class:`mb-4`})]),r(`div`,it,[a(v,{value:e.consumption,service:e.service},null,8,[`value`,`service`]),a(b,{type:`primary`,class:`btn w-full`,round:``,onClick:e.onGenerate},{default:m(()=>[a(y,{icon:`fa-solid fa-magic`,class:`mr-2`}),i(` `+l(e.$t(`openaiimage.button.generate`)),1)]),_:1},8,[`onClick`])])])}var ot=R(tt,[[`render`,at]]),st=s({name:`TaskPreview`,components:{ElImage:w,CopyToClipboard:J,FontAwesomeIcon:q,ElAlert:T,ImageWrapper:pe,ElButton:v,ElTooltip:C,ImagePreview:Y,ApiCodeButton:fe},props:{modelValue:{type:Object,required:!0}},setup(){return{OPENAIIMAGE_LOGO:ee}},computed:{isEditRequest(){let e=this.modelValue?.request;return this.modelValue?.type===`images_edits`||e?.action===`edit`||this.referenceImages.length>0},showTaskType(){return!!(this.modelValue?.request?.action||this.modelValue?.type||this.referenceImages.length>0)},taskTypeLabel(){return this.isEditRequest?this.$t(`openaiimage.name.edits`):this.$t(`openaiimage.name.generate`)},openaiimagePath(){return this.isEditRequest?`/openai/images/edits`:`/openai/images/generations`},openaiimageCodeBody(){let e=this.modelValue?.request;if(!e)return;let t={...e};if(delete t.action,delete t.callback_url,this.isEditRequest){delete t.image_urls,delete t.image;let e=this.referenceImages;e.length===1?t.image=e[0]:e.length>1&&(t.image=e)}else delete t.image_urls,delete t.image;return t},images(){let e=[];return Array.isArray(this.modelValue?.response?.data)&&this.modelValue?.response?.data?.forEach(t=>{let n=t;if(n?.image_url||n?.url){e.push(n);return}n?.b64_json&&e.push({...n,url:`data:image/png;base64,${n.b64_json}`})}),e},referenceImages(){let e=this.modelValue?.request;if(!e)return[];let t=Array.isArray(e.image_urls)?e.image_urls:[];if(t.length>0)return t.filter(e=>typeof e==`string`&&e.length>0);let n=e.image;return Array.isArray(n)?n.filter(e=>typeof e==`string`&&e.length>0):typeof n==`string`&&n.length>0?[n]:Array.isArray(e.images)?e.images.map(e=>{if(typeof e==`string`)return e;if(e&&typeof e==`object`)return e.image_url}).filter(e=>typeof e==`string`&&e.length>0):[]}},methods:{onEdit(e){if(!e)return;console.debug(`Edit image:`,e);let t={...this.$store.state.openaiimage?.config||{}};t.image_urls=[e],this.$store.commit(`openaiimage/setConfig`,t)}}}),ct={class:`preview`},lt={class:`left`},ut={class:`main`},dt={class:`bot`},ft={class:`datetime`},pt={class:`info`},mt={key:0,class:`flex justify-start items-center gap-2 mt-2 w-full overflow-x-auto`},ht={key:1,class:`prompt mt-2`},gt={key:0},_t={key:0,class:t({content:!0,failed:!0})},vt={class:`flex justify-start items-center gap-4 w-full overflow-x-auto`},yt={class:t({operations:!0,"mt-2":!0,"mb-2":!0})},bt={key:0,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},xt={key:1,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},St={key:2,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},Ct={class:`text-[var(--el-text-color-regular)] text-xs mb-2`},wt={key:3,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},Tt={key:4,class:`text-[var(--el-text-color-regular)] text-xs mb-0`},Et={key:1,class:t({content:!0})},Dt={key:0,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},Ot={key:1,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},kt={key:2,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},At={class:`text-[var(--el-text-color-regular)] text-xs mb-2`},jt={class:`text-[var(--el-text-color-regular)] text-xs mb-2`},Mt={key:3,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},Nt={key:4,class:`text-[var(--el-text-color-regular)] text-xs mb-0`},Pt={key:2,class:t({content:!0})},Q={key:0,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},Ft={key:1,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},It={key:2,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},Lt={class:`text-[var(--el-text-color-regular)] text-xs mb-2`};function Rt(e,t,s,d,h,v){let y=f(`el-image`),b=f(`image-preview`),x=f(`image-wrapper`),S=f(`el-button`),C=f(`el-tooltip`),w=f(`api-code-button`),T=f(`font-awesome-icon`),E=f(`copy-to-clipboard`),D=f(`el-alert`);return u(),p(`div`,ct,[r(`div`,lt,[a(y,{src:e.OPENAIIMAGE_LOGO,class:`avatar`},null,8,[`src`])]),r(`div`,ut,[r(`div`,dt,[i(l(e.$t(`openaiimage.name.openaiimageBot`))+` `,1),r(`span`,ft,l(e.$dayjs.format(``+new Date(parseFloat((e.modelValue?.created_at||``).toString())*1e3))),1)]),r(`div`,pt,[e.referenceImages.length>0?(u(),p(`div`,mt,[(u(!0),p(g,null,c(e.referenceImages,(e,t)=>(u(),n(b,{key:t,url:e,name:`image-${t+1}`,closable:!1},null,8,[`url`,`name`]))),128))])):o(``,!0),e.modelValue?.request?.prompt?(u(),p(`p`,ht,[i(l(e.modelValue?.request?.prompt)+` `,1),e.modelValue?.response?o(``,!0):(u(),p(`span`,gt,` - (`+l(e.$t(`openaiimage.status.pending`))+`) `,1))])):o(``,!0)]),e.modelValue?.response?.success===!0?(u(),p(`div`,_t,[r(`div`,vt,[(u(!0),p(g,null,c(e.images,(e,t)=>(u(),n(x,{key:t,src:e?.image_url||e?.url||``,"raw-src":e?.image_url||e?.url||``},null,8,[`src`,`raw-src`]))),128))]),r(`div`,yt,[a(C,{class:`box-item`,effect:`dark`,content:e.$t(`common.button.edit`),placement:`top-start`},{default:m(()=>[a(S,{type:`info`,size:`small`,class:`btn-action`,onClick:t[0]||=_(t=>e.onEdit(e.images?.[0]?.image_url||e.images?.[0]?.url),[`stop`])},{default:m(()=>[i(l(e.$t(`common.button.edit`)),1)]),_:1})]),_:1},8,[`content`]),a(w,{path:e.openaiimagePath,body:e.openaiimageCodeBody},null,8,[`path`,`body`])]),a(D,{closable:!1,class:`mt-2 success`},{default:m(()=>[e.modelValue?.request?.model?(u(),p(`p`,bt,[a(T,{icon:`fa-solid fa-cube`,class:`mr-1`}),i(` `+l(e.$t(`openaiimage.name.model`))+`: `+l(e.modelValue?.request?.model),1)])):o(``,!0),e.modelValue?.request?.size?(u(),p(`p`,xt,[a(T,{icon:`fa-solid fa-image`,class:`mr-1`}),i(` `+l(e.$t(`openaiimage.name.size`))+`: `+l(e.modelValue?.request?.size),1)])):o(``,!0),e.showTaskType?(u(),p(`p`,St,[a(T,{icon:`fa-solid fa-bolt`,class:`mr-1`}),i(` `+l(e.$t(`openaiimage.name.task`))+`: `+l(e.taskTypeLabel),1)])):o(``,!0),r(`p`,Ct,[a(T,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+l(e.$t(`openaiimage.name.taskId`))+`: `+l(e.modelValue?.id)+` `,1),a(E,{content:e.modelValue?.id,class:`btn-copy inline-block`},null,8,[`content`])]),e.modelValue?.elapsed?(u(),p(`p`,wt,[a(T,{icon:`fa-solid fa-clock`,class:`mr-1`}),i(` `+l(e.$t(`openaiimage.name.elapsed`))+`: `+l(e.modelValue?.elapsed?.toFixed(2))+`s `,1)])):o(``,!0),e.modelValue?.response?.trace_id?(u(),p(`p`,Tt,[a(T,{icon:`fa-solid fa-hashtag`,class:`mr-1`}),i(` `+l(e.$t(`openaiimage.name.traceId`))+`: `+l(e.modelValue?.response?.trace_id)+` `,1),a(E,{content:e.modelValue?.response?.trace_id,class:`btn-copy inline-block`},null,8,[`content`])])):o(``,!0)]),_:1})])):e.modelValue?.response?.success===!1?(u(),p(`div`,Et,[a(D,{closable:!1,class:`failure`},{template:m(()=>[a(T,{icon:`fa-solid fa-exclamation-triangle`,class:`mr-1`}),i(` `+l(e.$t(`openaiimage.name.failure`)),1)]),default:m(()=>[e.modelValue?.request?.model?(u(),p(`p`,Dt,[a(T,{icon:`fa-solid fa-cube`,class:`mr-1`}),i(` `+l(e.$t(`openaiimage.name.model`))+`: `+l(e.modelValue?.request?.model),1)])):o(``,!0),e.modelValue?.request?.size?(u(),p(`p`,Ot,[a(T,{icon:`fa-solid fa-image`,class:`mr-1`}),i(` `+l(e.$t(`openaiimage.name.size`))+`: `+l(e.modelValue?.request?.size),1)])):o(``,!0),e.showTaskType?(u(),p(`p`,kt,[a(T,{icon:`fa-solid fa-bolt`,class:`mr-1`}),i(` `+l(e.$t(`openaiimage.name.task`))+`: `+l(e.taskTypeLabel),1)])):o(``,!0),r(`p`,At,[a(T,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+l(e.$t(`openaiimage.name.taskId`))+`: `+l(e.modelValue?.id)+` `,1),a(E,{content:e.modelValue?.id,class:`btn-copy`},null,8,[`content`])]),r(`p`,jt,[a(T,{icon:`fa-solid fa-circle-info`,class:`mr-1`}),i(` `+l(e.$t(`openaiimage.name.failureReason`))+`: `+l(e.modelValue?.response?.error?.message)+` `,1),a(E,{content:e.modelValue?.response?.error?.message,class:`btn-copy`},null,8,[`content`])]),e.modelValue?.elapsed?(u(),p(`p`,Mt,[a(T,{icon:`fa-solid fa-clock`,class:`mr-1`}),i(` `+l(e.$t(`openaiimage.name.elapsed`))+`: `+l(e.modelValue?.elapsed?.toFixed(2))+`s `,1)])):o(``,!0),e.modelValue?.response?.trace_id?(u(),p(`p`,Nt,[a(T,{icon:`fa-solid fa-hashtag`,class:`mr-1`}),i(` `+l(e.$t(`openaiimage.name.traceId`))+`: `+l(e.modelValue?.response?.trace_id)+` `,1),a(E,{content:e.modelValue?.response?.trace_id,class:`btn-copy`},null,8,[`content`])])):o(``,!0)]),_:1})])):(u(),p(`div`,Pt,[a(D,{closable:!1,class:`info`},{template:m(()=>[a(T,{icon:`fa-solid fa-exclamation-triangle`,class:`mr-1`}),i(` `+l(e.$t(`openaiimage.name.failure`)),1)]),default:m(()=>[e.modelValue?.request?.model?(u(),p(`p`,Q,[a(T,{icon:`fa-solid fa-cube`,class:`mr-1`}),i(` `+l(e.$t(`openaiimage.name.model`))+`: `+l(e.modelValue?.request?.model),1)])):o(``,!0),e.modelValue?.request?.size?(u(),p(`p`,Ft,[a(T,{icon:`fa-solid fa-image`,class:`mr-1`}),i(` `+l(e.$t(`openaiimage.name.size`))+`: `+l(e.modelValue?.request?.size),1)])):o(``,!0),e.showTaskType?(u(),p(`p`,It,[a(T,{icon:`fa-solid fa-bolt`,class:`mr-1`}),i(` `+l(e.$t(`openaiimage.name.task`))+`: `+l(e.taskTypeLabel),1)])):o(``,!0),r(`p`,Lt,[a(T,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+l(e.$t(`openaiimage.name.taskId`))+`: `+l(e.modelValue?.id)+` `,1),a(E,{content:e.modelValue?.id,class:`btn-copy`},null,8,[`content`])])]),_:1})]))])])}var zt=s({name:`RecentPanel`,components:{TaskPreview:R(st,[[`render`,Rt],[`__scopeId`,`data-v-8ee5fb87`]]),BotPlaceholder:oe,NoTasks:ue,ScrollList:se},props:{loading:{type:Boolean,default:!1}},emits:[`reach-top`],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.openaiimage?.tasks,items:this.$store.state.openaiimage?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),Bt={key:0},Vt={key:2,class:`w-full h-full flex items-center justify-center`};function Ht(e,t,r,i,s,l){let d=f(`bot-placeholder`),h=f(`task-preview`),_=f(`scroll-list`),v=f(`no-tasks`);return u(),p(g,null,[e.tasks?.items===void 0?(u(),p(`div`,Bt,[a(d)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(u(),n(_,{key:1,ref:`scrollList`,class:`tasks h-full w-full overflow-y-auto`,loading:e.loading,onReachTop:t[0]||=t=>e.$emit(`reach-top`)},{default:m(()=>[(u(!0),p(g,null,c(e.tasks?.items,e=>(u(),n(h,{key:e.id,"model-value":e},null,8,[`model-value`]))),128))]),_:1},8,[`loading`])):o(``,!0),e.tasks?.items?.length===0?(u(),p(`div`,Vt,[a(v)])):o(``,!0)],64)}var Ut=R(zt,[[`render`,Ht]]),$=ne(`openaiimage`),Wt=s({name:`OpenAIImageIndex`,components:{ConfigPanel:ot,Layout:ye,RecentPanel:Ut},mixins:[L],inject:[`initialized`],data(){return{task:void 0,job:0,loading:!1}},computed:{applicationsLoading(){return this.$store.state.openaiimage?.status?.getApplications===K.Request},tasksLoading(){return this.$store.state.openaiimage?.status?.getTasks===K.Request},credential(){return this.$store.state.openaiimage?.credential},config(){return this.$store.state.openaiimage?.config},application(){return this.$store.state.openaiimage?.application},tasks(){return this.$store.state.openaiimage?.tasks}},watch:{tasks:{handler(e,t){e?.items?.length>t?.items?.length&&console.debug(`new tasks detected`)},deep:!0},initialized:{async handler(e){e&&(console.debug(`layout initialized`),await this.onGetTasks(),await this.onScrollDown(),this.job=window.setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){window.clearInterval(this.job)},methods:{async onReachTop(){await ce({tasks:this.tasks,getTasks:()=>this.tasks,loading:this.loading,setLoading:e=>this.loading=e,isBlocked:()=>this.tasksLoading,fetch:e=>this.onGetTasks({createdAtMax:e}),getScrollElement:()=>this.getTasksScrollElement()})},async onGetService(){console.debug(`start onGetService`),await this.$store.dispatch(`openaiimage/getService`),console.debug(`end onGetService`)},async onGetApplication(){console.debug(`start onGetApplication`),await this.$store.dispatch(`openaiimage/getApplications`),console.debug(`end onGetApplication`),await this.onGetTasks()},async onScrollDown(){await this.$nextTick();let e=this.getTasksScrollElement();e&&(e.scrollTop=e.scrollHeight)},async onGetTasks(e){if(this.applicationsLoading||this.tasksLoading){console.debug(`loading`);return}console.debug(`start onGetTasks`,e);let{limit:t=20,createdAtMin:n,createdAtMax:r}=e||{};console.debug(`limit`,t,`createdAtMin`,n,`createdAtMax`,r),await this.$store.dispatch(`openaiimage/getTasks`,{limit:t,createdAtMin:n,createdAtMax:r})},async onGenerate(){if(!V(this.uploadTracker,e=>this.$t(e),e=>W.warning(e)))return;let e={...this.config||{}},t=Array.isArray(e?.image_urls)&&e.image_urls.length>0;if(!this.hasText(e.prompt)){W.error(this.$t(`openaiimage.message.promptRequired`));return}e.prompt=e.prompt.trim(),!t&&`image_urls`in e&&delete e.image_urls,e.size||delete e.size;let n={...e,action:`generate`,callback_url:$},r={action:`edit`,model:e?.model,prompt:e?.prompt,size:e?.size,image_urls:e?.image_urls||[],callback_url:$},i=this.credential?.token;if(!i){console.error(`no token specified`);return}W.info(this.$t(`openaiimage.message.startingTask`)),z(`openaiimage`,t?U.edit(r,{token:i}):U.generate(n,{token:i})).then(e=>{console.debug(`task accepted`,e.data?.task_id),W.success(this.$t(`openaiimage.message.startTaskSuccess`))}).catch(e=>{let t=e?.response?.data;t?.error?.code===`used_up`?W.error(this.$t(`openaiimage.message.usedUp`)):W.error(this.$t(`openaiimage.message.startTaskFailed`)+(t?.error?.message||``))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()},hasText(e){return typeof e==`string`&&e.trim().length>0}}});function Gt(e,t,r,i,o,s){let c=f(`config-panel`),l=f(`recent-panel`),d=f(`layout`);return u(),n(d,null,{config:m(()=>[a(c,{onGenerate:e.onGenerate},null,8,[`onGenerate`])]),result:m(()=>[a(l,{ref:`recentPanel`,loading:e.loading,onReachTop:e.onReachTop},null,8,[`loading`,`onReachTop`])]),_:1})}var Kt=R(Wt,[[`render`,Gt]]);export{Kt as default};
@@ -1 +1 @@
1
- import"./rolldown-runtime--c01j_DQ.js";import{$ as e,D as t,E as n,M as r,N as i,O as a,P as o,Q as s,Ut as c,X as l,et as u,j as d,k as f,lt as p,x as m}from"./vendor-chart-mdwpew_o.js";import{t as h}from"./button-DWzbdjZV.js";import{r as g,t as _}from"./select-CtOUS-1J.js";import{n as v,t as y}from"./collapse-CMbK4fuu.js";import{t as b}from"./drawer-BvYPSxXh.js";import"./constants-C-bSXdJ_.js";import{E as x,Ir as S,Nt as C,kr as w,yr as T}from"./index-uml6ohnH.js";import{t as E}from"./index.es-CcQaWbuV.js";import{t as ee}from"./Consumption-Dlo2Ec9d.js";var te=o({name:`LayoutSerp`,components:{ElDrawer:b,ElButton:h,FontAwesomeIcon:E},data(){return{drawer:!1}}}),D={class:`main flex flex-row flex-1`},O={class:`config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]`},k={class:`result h-full flex-1 flex flex-col min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]`};function A(t,r,a,o,s,c){let d=u(`font-awesome-icon`),m=u(`el-button`),h=u(`el-drawer`);return l(),f(`div`,D,[n(`div`,O,[e(t.$slots,`config`,{},void 0,!0)]),n(`div`,k,[e(t.$slots,`result`,{},void 0,!0)]),i(m,{circle:``,class:`menu`,onClick:r[0]||=e=>t.drawer=!0},{default:p(()=>[i(d,{icon:`fa-solid fa-search`})]),_:1}),i(h,{modelValue:t.drawer,"onUpdate:modelValue":r[1]||=e=>t.drawer=e,direction:`ltr`,"with-header":!1,size:`340px`,class:`drawer`},{default:p(()=>[e(t.$slots,`config`,{},void 0,!0)]),_:3},8,[`modelValue`])])}var j=x(te,[[`render`,A],[`__scopeId`,`data-v-72398911`]]),M=o({name:`QueryInput`,components:{ElInput:S},computed:{query:{get(){return this.$store.state.serp?.config?.query},set(e){this.$store.commit(`serp/setConfig`,{...this.$store.state.serp?.config,query:e})}}}}),N={class:`field`},P={class:`box`},F={class:`title font-bold`};function I(e,t,r,a,o,s){let d=u(`el-input`);return l(),f(`div`,N,[n(`div`,P,[n(`h2`,F,c(e.$t(`serp.name.query`)),1)]),i(d,{modelValue:e.query,"onUpdate:modelValue":t[0]||=t=>e.query=t,rows:3,type:`textarea`,class:`prompt`,placeholder:e.$t(`serp.placeholder.query`)},null,8,[`modelValue`,`placeholder`])])}var L=x(M,[[`render`,I],[`__scopeId`,`data-v-3582b195`]]),R=o({name:`TypeSelector`,components:{ElSelect:g,ElOption:_},computed:{value:{get(){return this.$store.state.serp?.config?.type},set(e){this.$store.commit(`serp/setConfig`,{...this.$store.state.serp?.config,type:e})}}},mounted(){this.value||=`search`}}),z={class:`field`},B={class:`title font-bold`};function V(e,t,r,a,o,s){let d=u(`el-option`),m=u(`el-select`);return l(),f(`div`,z,[n(`h2`,B,c(e.$t(`serp.name.type`)),1),i(m,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,class:`value`},{default:p(()=>[i(d,{value:`search`,label:e.$t(`serp.type.search`)},null,8,[`label`]),i(d,{value:`images`,label:e.$t(`serp.type.images`)},null,8,[`label`]),i(d,{value:`news`,label:e.$t(`serp.type.news`)},null,8,[`label`]),i(d,{value:`videos`,label:e.$t(`serp.type.videos`)},null,8,[`label`])]),_:1},8,[`modelValue`])])}var H=x(R,[[`render`,V],[`__scopeId`,`data-v-2913fb62`]]),U=o({name:`CountryInput`,components:{ElInput:S},computed:{value:{get(){return this.$store.state.serp?.config?.country},set(e){this.$store.commit(`serp/setConfig`,{...this.$store.state.serp?.config,country:e})}}},mounted(){this.value||=`US`}}),W={class:`field`},G={class:`title font-bold`};function K(e,t,r,a,o,s){let d=u(`el-input`);return l(),f(`div`,W,[n(`h2`,G,c(e.$t(`serp.name.country`)),1),i(d,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,class:`value`,placeholder:e.$t(`serp.placeholder.country`)},null,8,[`modelValue`,`placeholder`])])}var q=x(U,[[`render`,K],[`__scopeId`,`data-v-f0672cc6`]]),J=o({name:`LanguageInput`,components:{ElInput:S},computed:{value:{get(){return this.$store.state.serp?.config?.language},set(e){this.$store.commit(`serp/setConfig`,{...this.$store.state.serp?.config,language:e})}}},mounted(){this.value||=`en`}}),Y={class:`field`},X={class:`title font-bold`};function Z(e,t,r,a,o,s){let d=u(`el-input`);return l(),f(`div`,Y,[n(`h2`,X,c(e.$t(`serp.name.language`)),1),i(d,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,class:`value`,placeholder:e.$t(`serp.placeholder.language`)},null,8,[`modelValue`,`placeholder`])])}var Q=o({name:`SearchPanel`,components:{ElButton:h,FontAwesomeIcon:E,QueryInput:L,TypeSelector:H,CountryInput:q,LanguageInput:x(J,[[`render`,Z],[`__scopeId`,`data-v-dc1c94b7`]]),Consumption:ee},emits:[`search`],computed:{config(){return this.$store.state.serp?.config},consumption(){return C(this.config,this.service?.cost)},service(){return this.$store.state.serp?.service},searching(){return this.$store.state.serp?.status?.search===T.Request}},methods:{onSearch(){this.$emit(`search`)}}}),ne={class:`flex flex-col h-full`},re={class:`flex-1 overflow-y-auto p-5`},ie={class:`flex flex-col items-center justify-center px-5 pb-5`};function ae(e,t,a,o,s,d){let m=u(`query-input`),h=u(`type-selector`),g=u(`country-input`),_=u(`language-input`),v=u(`consumption`),y=u(`font-awesome-icon`),b=u(`el-button`);return l(),f(`div`,ne,[n(`div`,re,[i(m,{class:`mb-4`}),i(h,{class:`mb-4`}),i(g,{class:`mb-4`}),i(_,{class:`mb-4`})]),n(`div`,ie,[i(v,{value:e.consumption,service:e.service},null,8,[`value`,`service`]),i(b,{type:`primary`,class:`btn w-full`,round:``,loading:e.searching,onClick:e.onSearch},{default:p(()=>[i(y,{icon:`fa-solid fa-search`,class:`mr-2`}),r(` `+c(e.$t(`serp.button.search`)),1)]),_:1},8,[`loading`,`onClick`])])])}var oe=x(Q,[[`render`,ae]]),se=o({name:`KnowledgeGraph`,props:{data:{type:Object,required:!0}}}),ce={class:`knowledge-graph rounded-xl border border-[var(--el-border-color-lighter)] p-5 bg-[var(--el-fill-color-blank)]`},le={class:`flex flex-row gap-4`},ue=[`src`,`alt`],de={class:`flex-1 min-w-0`},fe={key:0,class:`text-xs text-[var(--el-text-color-disabled)] mb-1 uppercase tracking-wide`},pe={class:`text-xl font-bold mb-1.5`},me={key:1,class:`text-sm text-[var(--el-text-color-regular)] mb-3 leading-relaxed`},he=[`href`],ge={key:2,class:`text-sm`},_e={class:`text-[var(--el-text-color-disabled)] flex-none font-medium`},ve={class:`text-[var(--el-text-color-regular)]`};function ye(e,t,i,o,u,d){return l(),f(`div`,ce,[n(`div`,le,[e.data.image_url?(l(),f(`img`,{key:0,src:e.data.image_url,alt:e.data.title,class:`w-28 h-28 rounded-lg object-cover flex-none shadow-sm`},null,8,ue)):a(``,!0),n(`div`,de,[e.data.type?(l(),f(`div`,fe,c(e.data.type),1)):a(``,!0),n(`h3`,pe,c(e.data.title),1),e.data.description?(l(),f(`p`,me,[r(c(e.data.description)+` `,1),e.data.description_link?(l(),f(`a`,{key:0,href:e.data.description_link,target:`_blank`,rel:`noopener noreferrer`,class:`text-[var(--el-color-primary)] hover:underline ml-1`},c(e.data.description_source||`Source`),9,he)):a(``,!0)])):a(``,!0),e.data.attributes&&Object.keys(e.data.attributes).length?(l(),f(`div`,ge,[(l(!0),f(m,null,s(e.data.attributes,(e,t)=>(l(),f(`div`,{key:t,class:`flex gap-2 mb-1 py-0.5`},[n(`span`,_e,c(t)+`:`,1),n(`span`,ve,c(e),1)]))),128))])):a(``,!0)])])])}var be=x(se,[[`render`,ye]]),xe=o({name:`OrganicResult`,props:{data:{type:Object,required:!0}},data(){return{faviconFailed:!1}},computed:{hostname(){if(!this.data.link)return``;try{return new URL(this.data.link).hostname}catch{return``}},pathname(){if(!this.data.link)return``;try{let e=new URL(this.data.link).pathname;return e===`/`?``:e}catch{return``}},displayUrl(){return this.hostname},faviconUrl(){return this.faviconFailed||!this.hostname?``:`https://www.google.com/s2/favicons?domain=${this.hostname}&sz=32`}},methods:{onFaviconError(e){this.faviconFailed=!0,e.target.style.display=`none`}}}),Se={class:`organic-result rounded-lg p-4 transition-all duration-200 hover:bg-[var(--el-fill-color-lighter)]`},Ce={key:0,class:`flex items-center gap-2 mb-1.5`},we=[`src`,`alt`],Te={class:`text-xs text-[var(--el-text-color-secondary)] truncate`},Ee={class:`text-xs text-[var(--el-text-color-disabled)]`},De=[`href`],Oe={key:1,class:`text-xs text-[var(--el-text-color-disabled)] mt-1`},ke={key:2,class:`text-sm text-[var(--el-text-color-regular)] mt-1.5 leading-relaxed line-clamp-3`},Ae={key:3,class:`mt-3 flex flex-wrap gap-x-4 gap-y-1`},je=[`href`];function Me(e,t,r,i,o,u){return l(),f(`div`,Se,[e.displayUrl?(l(),f(`div`,Ce,[n(`img`,{src:e.faviconUrl,alt:e.hostname,class:`w-4 h-4 rounded-sm flex-none`,loading:`lazy`,onError:t[0]||=(...t)=>e.onFaviconError&&e.onFaviconError(...t)},null,40,we),n(`span`,Te,c(e.hostname),1),n(`span`,Ee,c(e.pathname),1)])):a(``,!0),n(`a`,{href:e.data.link,target:`_blank`,rel:`noopener noreferrer`,class:`text-base font-semibold text-[var(--el-color-primary)] hover:underline leading-snug block`},c(e.data.title),9,De),e.data.date?(l(),f(`div`,Oe,c(e.data.date),1)):a(``,!0),e.data.snippet?(l(),f(`p`,ke,c(e.data.snippet),1)):a(``,!0),e.data.sitelinks?.length?(l(),f(`div`,Ae,[(l(!0),f(m,null,s(e.data.sitelinks,(e,t)=>(l(),f(`a`,{key:t,href:e.link,target:`_blank`,rel:`noopener noreferrer`,class:`text-xs text-[var(--el-color-primary-light-3)] hover:text-[var(--el-color-primary)] hover:underline transition-colors`},c(e.title),9,je))),128))])):a(``,!0)])}var Ne=x(xe,[[`render`,Me]]),Pe=o({name:`ImageResults`,props:{data:{type:Array,required:!0}}}),Fe={class:`rounded-xl border border-[var(--el-border-color-lighter)] p-5 bg-[var(--el-fill-color-blank)]`},Ie={class:`text-base font-bold mb-3`},Le={class:`grid grid-cols-2 sm:grid-cols-3 md:grid-cols-4 gap-3`},Re=[`href`],ze=[`src`,`alt`],Be={class:`absolute inset-x-0 bottom-0 bg-gradient-to-t from-black/70 to-transparent p-2.5 opacity-0 group-hover:opacity-100 transition-opacity duration-200`},Ve={class:`text-xs text-white line-clamp-2`};function He(e,t,r,i,o,u){return l(),f(`div`,Fe,[n(`h3`,Ie,c(e.$t(`serp.name.imageResults`)),1),n(`div`,Le,[(l(!0),f(m,null,s(e.data,(e,t)=>(l(),f(`a`,{key:t,href:e.link,target:`_blank`,rel:`noopener noreferrer`,class:`group relative rounded-lg overflow-hidden bg-[var(--el-fill-color-light)] aspect-square`},[e.image_url?(l(),f(`img`,{key:0,src:e.image_url,alt:e.title,class:`w-full h-full object-cover transition-transform duration-300 group-hover:scale-105`,loading:`lazy`},null,8,ze)):a(``,!0),n(`div`,Be,[n(`span`,Ve,c(e.title),1)])],8,Re))),128))])])}var Ue=x(Pe,[[`render`,He]]),We=o({name:`VideoResults`,props:{data:{type:Array,required:!0}}}),Ge={class:`text-base font-bold mb-3`},Ke={class:`space-y-4`},qe=[`href`],Je={class:`relative flex-shrink-0 w-40 h-24 rounded overflow-hidden bg-gray-100 dark:bg-gray-800`},Ye=[`src`,`alt`],Xe={key:1,class:`absolute bottom-1 right-1 bg-black/80 text-white text-xs px-1 rounded`},Ze={class:`flex-1 min-w-0`},Qe={class:`text-blue-600 group-hover:underline font-medium line-clamp-2`},$e={class:`text-xs text-gray-400 mt-1`},et={key:0},tt={key:1},nt={key:2},rt={key:0,class:`text-sm text-gray-600 dark:text-gray-300 mt-1 line-clamp-2`};function it(e,t,r,i,o,u){return l(),f(`div`,null,[n(`h3`,Ge,c(e.$t(`serp.name.videoResults`)),1),n(`div`,Ke,[(l(!0),f(m,null,s(e.data,(e,t)=>(l(),f(`a`,{key:t,href:e.link,target:`_blank`,rel:`noopener noreferrer`,class:`flex gap-4 group`},[n(`div`,Je,[e.image_url?(l(),f(`img`,{key:0,src:e.image_url,alt:e.title,class:`w-full h-full object-cover`,loading:`lazy`},null,8,Ye)):a(``,!0),e.duration?(l(),f(`div`,Xe,c(e.duration),1)):a(``,!0)]),n(`div`,Ze,[n(`div`,Qe,c(e.title),1),n(`div`,$e,[e.source?(l(),f(`span`,et,c(e.source),1)):a(``,!0),e.channel?(l(),f(`span`,tt,` · `+c(e.channel),1)):a(``,!0),e.date?(l(),f(`span`,nt,` · `+c(e.date),1)):a(``,!0)]),e.snippet?(l(),f(`p`,rt,c(e.snippet),1)):a(``,!0)])],8,qe))),128))])])}var at=x(We,[[`render`,it]]),ot=o({name:`NewsResults`,props:{data:{type:Array,required:!0}}}),st={class:`text-base font-bold mb-3`},ct={class:`space-y-4`},lt=[`href`],ut={class:`flex-1 min-w-0`},dt={class:`text-blue-600 group-hover:underline font-medium line-clamp-2`},ft={class:`text-xs text-gray-400 mt-1`},pt={key:0},mt={key:1},ht={key:0,class:`text-sm text-gray-600 dark:text-gray-300 mt-1 line-clamp-2`},gt={key:0,class:`flex-shrink-0 w-24 h-24 rounded overflow-hidden bg-gray-100 dark:bg-gray-800`},_t=[`src`,`alt`];function vt(e,t,r,i,o,u){return l(),f(`div`,null,[n(`h3`,st,c(e.$t(`serp.name.newsResults`)),1),n(`div`,ct,[(l(!0),f(m,null,s(e.data,(e,t)=>(l(),f(`a`,{key:t,href:e.link,target:`_blank`,rel:`noopener noreferrer`,class:`flex gap-4 group`},[n(`div`,ut,[n(`div`,dt,c(e.title),1),n(`div`,ft,[e.source?(l(),f(`span`,pt,c(e.source),1)):a(``,!0),e.date?(l(),f(`span`,mt,` · `+c(e.date),1)):a(``,!0)]),e.snippet?(l(),f(`p`,ht,c(e.snippet),1)):a(``,!0)]),e.image_url?(l(),f(`div`,gt,[n(`img`,{src:e.image_url,alt:e.title,class:`w-full h-full object-cover`,loading:`lazy`},null,8,_t)])):a(``,!0)],8,lt))),128))])])}var yt=x(ot,[[`render`,vt]]),bt=o({name:`PeopleAlsoAsk`,components:{ElCollapse:y,ElCollapseItem:v},props:{data:{type:Array,required:!0}}}),xt={class:`rounded-xl border border-[var(--el-border-color-lighter)] p-5 bg-[var(--el-fill-color-blank)]`},St={class:`text-base font-bold mb-3`},Ct={key:0,class:`text-sm text-[var(--el-text-color-regular)] mb-2 leading-relaxed`},wt=[`href`];function Tt(e,r,o,d,h,g){let _=u(`el-collapse-item`),v=u(`el-collapse`);return l(),f(`div`,xt,[n(`h3`,St,c(e.$t(`serp.name.peopleAlsoAsk`)),1),i(v,null,{default:p(()=>[(l(!0),f(m,null,s(e.data,(e,n)=>(l(),t(_,{key:n,title:e.question||e.title||``},{default:p(()=>[e.snippet?(l(),f(`p`,Ct,c(e.snippet),1)):a(``,!0),e.link?(l(),f(`a`,{key:1,href:e.link,target:`_blank`,rel:`noopener noreferrer`,class:`text-xs text-[var(--el-color-primary)] hover:underline`},c(e.title||e.link),9,wt)):a(``,!0)]),_:2},1032,[`title`]))),128))]),_:1})])}var Et=x(bt,[[`render`,Tt]]),Dt=o({name:`RelatedSearches`,components:{FontAwesomeIcon:E},props:{data:{type:Array,required:!0}},emits:[`search`],methods:{onSearch(e){e&&this.$emit(`search`,e)}}}),Ot={class:`rounded-xl border border-[var(--el-border-color-lighter)] p-5 bg-[var(--el-fill-color-blank)]`},kt={class:`text-base font-bold mb-3`},At={class:`flex flex-wrap gap-2`},jt=[`onClick`];function Mt(e,t,a,o,d,p){let h=u(`font-awesome-icon`);return l(),f(`div`,Ot,[n(`h3`,kt,c(e.$t(`serp.name.relatedSearches`)),1),n(`div`,At,[(l(!0),f(m,null,s(e.data,(t,n)=>(l(),f(`button`,{key:n,class:`inline-flex items-center gap-1.5 px-3 py-1.5 rounded-full text-sm bg-[var(--el-fill-color-light)] text-[var(--el-text-color-regular)] hover:bg-[var(--el-color-primary-light-9)] hover:text-[var(--el-color-primary)] transition-colors cursor-pointer border-none`,onClick:n=>e.onSearch(t.query)},[i(h,{icon:`fa-solid fa-magnifying-glass`,class:`text-xs opacity-50`}),r(` `+c(t.query),1)],8,jt))),128))])])}var Nt=o({name:`ResultPanel`,components:{FontAwesomeIcon:E,KnowledgeGraph:be,OrganicResult:Ne,ImageResults:Ue,VideoResults:at,NewsResults:yt,PeopleAlsoAsk:Et,RelatedSearches:x(Dt,[[`render`,Mt]])},emits:[`related-search`],computed:{results(){return this.$store.state.serp?.results},searching(){return this.$store.state.serp?.status?.search===T.Request},noResults(){return this.$store.state.serp?.status?.search===T.Success&&this.results&&!this.results.organic?.length&&!this.results.images?.length&&!this.results.videos?.length&&!this.results.news?.length&&!this.results.knowledge_graph?.title}},methods:{onRelatedSearch(e){this.$emit(`related-search`,e)}}}),$={class:`h-full overflow-y-auto p-6`},Pt={key:0,class:`max-w-3xl mx-auto py-8`},Ft={key:1,class:`flex flex-col items-center justify-center py-24 text-[var(--el-text-color-disabled)]`},It={class:`text-base`},Lt={key:2,class:`max-w-3xl mx-auto`},Rt={key:1,class:`mb-6`},zt={key:3,class:`flex flex-col items-center justify-center py-24 text-[var(--el-text-color-disabled)]`},Bt={class:`text-base`};function Vt(e,r,o,p,h,g){let _=u(`font-awesome-icon`),v=u(`knowledge-graph`),y=u(`organic-result`),b=u(`image-results`),x=u(`video-results`),S=u(`news-results`),C=u(`people-also-ask`),w=u(`related-searches`);return l(),f(`div`,$,[e.searching?(l(),f(`div`,Pt,[(l(),f(m,null,s(4,e=>n(`div`,{key:e,class:`mb-6 animate-pulse`},[...r[0]||=[d(`<div class="flex items-center gap-2 mb-2"><div class="w-4 h-4 rounded-sm bg-[var(--el-fill-color-darker)]"></div><div class="h-3 w-32 rounded bg-[var(--el-fill-color-darker)]"></div></div><div class="h-4 w-3/4 rounded bg-[var(--el-fill-color-dark)] mb-2"></div><div class="h-3 w-full rounded bg-[var(--el-fill-color)] mb-1"></div><div class="h-3 w-5/6 rounded bg-[var(--el-fill-color)]"></div>`,4)]])),64))])):e.noResults?(l(),f(`div`,Ft,[i(_,{icon:`fa-solid fa-face-meh`,class:`text-5xl mb-4 opacity-40`}),n(`p`,It,c(e.$t(`serp.message.noResults`)),1)])):e.results?(l(),f(`div`,Lt,[e.results.knowledge_graph?.title?(l(),t(v,{key:0,data:e.results.knowledge_graph,class:`mb-6`},null,8,[`data`])):a(``,!0),e.results.organic?.length?(l(),f(`div`,Rt,[(l(!0),f(m,null,s(e.results.organic,(e,n)=>(l(),t(y,{key:n,data:e,class:`mb-1`},null,8,[`data`]))),128))])):a(``,!0),e.results.images?.length?(l(),t(b,{key:2,data:e.results.images,class:`mb-6`},null,8,[`data`])):a(``,!0),e.results.videos?.length?(l(),t(x,{key:3,data:e.results.videos,class:`mb-6`},null,8,[`data`])):a(``,!0),e.results.news?.length?(l(),t(S,{key:4,data:e.results.news,class:`mb-6`},null,8,[`data`])):a(``,!0),e.results.people_also_ask?.length?(l(),t(C,{key:5,data:e.results.people_also_ask,class:`mb-6`},null,8,[`data`])):a(``,!0),e.results.related_searches?.length?(l(),t(w,{key:6,data:e.results.related_searches,class:`mb-6`,onSearch:e.onRelatedSearch},null,8,[`data`,`onSearch`])):a(``,!0)])):(l(),f(`div`,zt,[i(_,{icon:`fa-solid fa-globe`,class:`text-5xl mb-4 opacity-30`}),n(`p`,Bt,c(e.$t(`serp.description.query`)),1)]))])}var Ht=o({name:`SerpIndex`,components:{Layout:j,SearchPanel:oe,ResultPanel:x(Nt,[[`render`,Vt]])},inject:[`initialized`],async mounted(){await this.onGetService()},methods:{async onGetService(){console.debug(`start onGetService`),await this.$store.dispatch(`serp/getService`),console.debug(`end onGetService`)},async onSearch(){if(this.$store.state.serp?.config?.query){w.info(this.$t(`serp.message.searching`));try{await this.$store.dispatch(`serp/search`),w.success(this.$t(`serp.message.searchSuccess`))}catch(e){(e?.response?.data)?.error?.code===`used_up`?w.error(this.$t(`serp.message.usedUp`)):w.error(this.$t(`serp.message.searchFailed`))}}},async onRelatedSearch(e){this.$store.commit(`serp/setConfig`,{...this.$store.state.serp?.config,query:e}),await this.onSearch()}}});function Ut(e,n,r,a,o,s){let c=u(`search-panel`),d=u(`result-panel`),f=u(`layout`);return l(),t(f,null,{config:p(()=>[i(c,{onSearch:e.onSearch},null,8,[`onSearch`])]),result:p(()=>[i(d,{onRelatedSearch:e.onRelatedSearch},null,8,[`onRelatedSearch`])]),_:1})}var Wt=x(Ht,[[`render`,Ut]]);export{Wt as default};
1
+ import"./rolldown-runtime--c01j_DQ.js";import{$ as e,D as t,E as n,M as r,N as i,O as a,P as o,Q as s,Ut as c,X as l,et as u,j as d,k as f,lt as p,x as m}from"./vendor-chart-mdwpew_o.js";import{t as h}from"./button-DWzbdjZV.js";import{r as g,t as _}from"./select-Byt7Qw1F.js";import{n as v,t as y}from"./collapse-Ds9keFcU.js";import{t as b}from"./drawer-BvYPSxXh.js";import"./constants-C-bSXdJ_.js";import{E as x,Ir as S,Nt as C,kr as w,yr as T}from"./index-Dzx62HWL.js";import{t as E}from"./index.es-BIezN10l.js";import{t as ee}from"./Consumption-DLzGFeUT.js";var te=o({name:`LayoutSerp`,components:{ElDrawer:b,ElButton:h,FontAwesomeIcon:E},data(){return{drawer:!1}}}),D={class:`main flex flex-row flex-1`},O={class:`config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]`},k={class:`result h-full flex-1 flex flex-col min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]`};function A(t,r,a,o,s,c){let d=u(`font-awesome-icon`),m=u(`el-button`),h=u(`el-drawer`);return l(),f(`div`,D,[n(`div`,O,[e(t.$slots,`config`,{},void 0,!0)]),n(`div`,k,[e(t.$slots,`result`,{},void 0,!0)]),i(m,{circle:``,class:`menu`,onClick:r[0]||=e=>t.drawer=!0},{default:p(()=>[i(d,{icon:`fa-solid fa-search`})]),_:1}),i(h,{modelValue:t.drawer,"onUpdate:modelValue":r[1]||=e=>t.drawer=e,direction:`ltr`,"with-header":!1,size:`340px`,class:`drawer`},{default:p(()=>[e(t.$slots,`config`,{},void 0,!0)]),_:3},8,[`modelValue`])])}var j=x(te,[[`render`,A],[`__scopeId`,`data-v-72398911`]]),M=o({name:`QueryInput`,components:{ElInput:S},computed:{query:{get(){return this.$store.state.serp?.config?.query},set(e){this.$store.commit(`serp/setConfig`,{...this.$store.state.serp?.config,query:e})}}}}),N={class:`field`},P={class:`box`},F={class:`title font-bold`};function I(e,t,r,a,o,s){let d=u(`el-input`);return l(),f(`div`,N,[n(`div`,P,[n(`h2`,F,c(e.$t(`serp.name.query`)),1)]),i(d,{modelValue:e.query,"onUpdate:modelValue":t[0]||=t=>e.query=t,rows:3,type:`textarea`,class:`prompt`,placeholder:e.$t(`serp.placeholder.query`)},null,8,[`modelValue`,`placeholder`])])}var L=x(M,[[`render`,I],[`__scopeId`,`data-v-3582b195`]]),R=o({name:`TypeSelector`,components:{ElSelect:g,ElOption:_},computed:{value:{get(){return this.$store.state.serp?.config?.type},set(e){this.$store.commit(`serp/setConfig`,{...this.$store.state.serp?.config,type:e})}}},mounted(){this.value||=`search`}}),z={class:`field`},B={class:`title font-bold`};function V(e,t,r,a,o,s){let d=u(`el-option`),m=u(`el-select`);return l(),f(`div`,z,[n(`h2`,B,c(e.$t(`serp.name.type`)),1),i(m,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,class:`value`},{default:p(()=>[i(d,{value:`search`,label:e.$t(`serp.type.search`)},null,8,[`label`]),i(d,{value:`images`,label:e.$t(`serp.type.images`)},null,8,[`label`]),i(d,{value:`news`,label:e.$t(`serp.type.news`)},null,8,[`label`]),i(d,{value:`videos`,label:e.$t(`serp.type.videos`)},null,8,[`label`])]),_:1},8,[`modelValue`])])}var H=x(R,[[`render`,V],[`__scopeId`,`data-v-2913fb62`]]),U=o({name:`CountryInput`,components:{ElInput:S},computed:{value:{get(){return this.$store.state.serp?.config?.country},set(e){this.$store.commit(`serp/setConfig`,{...this.$store.state.serp?.config,country:e})}}},mounted(){this.value||=`US`}}),W={class:`field`},G={class:`title font-bold`};function K(e,t,r,a,o,s){let d=u(`el-input`);return l(),f(`div`,W,[n(`h2`,G,c(e.$t(`serp.name.country`)),1),i(d,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,class:`value`,placeholder:e.$t(`serp.placeholder.country`)},null,8,[`modelValue`,`placeholder`])])}var q=x(U,[[`render`,K],[`__scopeId`,`data-v-f0672cc6`]]),J=o({name:`LanguageInput`,components:{ElInput:S},computed:{value:{get(){return this.$store.state.serp?.config?.language},set(e){this.$store.commit(`serp/setConfig`,{...this.$store.state.serp?.config,language:e})}}},mounted(){this.value||=`en`}}),Y={class:`field`},X={class:`title font-bold`};function Z(e,t,r,a,o,s){let d=u(`el-input`);return l(),f(`div`,Y,[n(`h2`,X,c(e.$t(`serp.name.language`)),1),i(d,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,class:`value`,placeholder:e.$t(`serp.placeholder.language`)},null,8,[`modelValue`,`placeholder`])])}var Q=o({name:`SearchPanel`,components:{ElButton:h,FontAwesomeIcon:E,QueryInput:L,TypeSelector:H,CountryInput:q,LanguageInput:x(J,[[`render`,Z],[`__scopeId`,`data-v-dc1c94b7`]]),Consumption:ee},emits:[`search`],computed:{config(){return this.$store.state.serp?.config},consumption(){return C(this.config,this.service?.cost)},service(){return this.$store.state.serp?.service},searching(){return this.$store.state.serp?.status?.search===T.Request}},methods:{onSearch(){this.$emit(`search`)}}}),ne={class:`flex flex-col h-full`},re={class:`flex-1 overflow-y-auto p-5`},ie={class:`flex flex-col items-center justify-center px-5 pb-5`};function ae(e,t,a,o,s,d){let m=u(`query-input`),h=u(`type-selector`),g=u(`country-input`),_=u(`language-input`),v=u(`consumption`),y=u(`font-awesome-icon`),b=u(`el-button`);return l(),f(`div`,ne,[n(`div`,re,[i(m,{class:`mb-4`}),i(h,{class:`mb-4`}),i(g,{class:`mb-4`}),i(_,{class:`mb-4`})]),n(`div`,ie,[i(v,{value:e.consumption,service:e.service},null,8,[`value`,`service`]),i(b,{type:`primary`,class:`btn w-full`,round:``,loading:e.searching,onClick:e.onSearch},{default:p(()=>[i(y,{icon:`fa-solid fa-search`,class:`mr-2`}),r(` `+c(e.$t(`serp.button.search`)),1)]),_:1},8,[`loading`,`onClick`])])])}var oe=x(Q,[[`render`,ae]]),se=o({name:`KnowledgeGraph`,props:{data:{type:Object,required:!0}}}),ce={class:`knowledge-graph rounded-xl border border-[var(--el-border-color-lighter)] p-5 bg-[var(--el-fill-color-blank)]`},le={class:`flex flex-row gap-4`},ue=[`src`,`alt`],de={class:`flex-1 min-w-0`},fe={key:0,class:`text-xs text-[var(--el-text-color-disabled)] mb-1 uppercase tracking-wide`},pe={class:`text-xl font-bold mb-1.5`},me={key:1,class:`text-sm text-[var(--el-text-color-regular)] mb-3 leading-relaxed`},he=[`href`],ge={key:2,class:`text-sm`},_e={class:`text-[var(--el-text-color-disabled)] flex-none font-medium`},ve={class:`text-[var(--el-text-color-regular)]`};function ye(e,t,i,o,u,d){return l(),f(`div`,ce,[n(`div`,le,[e.data.image_url?(l(),f(`img`,{key:0,src:e.data.image_url,alt:e.data.title,class:`w-28 h-28 rounded-lg object-cover flex-none shadow-sm`},null,8,ue)):a(``,!0),n(`div`,de,[e.data.type?(l(),f(`div`,fe,c(e.data.type),1)):a(``,!0),n(`h3`,pe,c(e.data.title),1),e.data.description?(l(),f(`p`,me,[r(c(e.data.description)+` `,1),e.data.description_link?(l(),f(`a`,{key:0,href:e.data.description_link,target:`_blank`,rel:`noopener noreferrer`,class:`text-[var(--el-color-primary)] hover:underline ml-1`},c(e.data.description_source||`Source`),9,he)):a(``,!0)])):a(``,!0),e.data.attributes&&Object.keys(e.data.attributes).length?(l(),f(`div`,ge,[(l(!0),f(m,null,s(e.data.attributes,(e,t)=>(l(),f(`div`,{key:t,class:`flex gap-2 mb-1 py-0.5`},[n(`span`,_e,c(t)+`:`,1),n(`span`,ve,c(e),1)]))),128))])):a(``,!0)])])])}var be=x(se,[[`render`,ye]]),xe=o({name:`OrganicResult`,props:{data:{type:Object,required:!0}},data(){return{faviconFailed:!1}},computed:{hostname(){if(!this.data.link)return``;try{return new URL(this.data.link).hostname}catch{return``}},pathname(){if(!this.data.link)return``;try{let e=new URL(this.data.link).pathname;return e===`/`?``:e}catch{return``}},displayUrl(){return this.hostname},faviconUrl(){return this.faviconFailed||!this.hostname?``:`https://www.google.com/s2/favicons?domain=${this.hostname}&sz=32`}},methods:{onFaviconError(e){this.faviconFailed=!0,e.target.style.display=`none`}}}),Se={class:`organic-result rounded-lg p-4 transition-all duration-200 hover:bg-[var(--el-fill-color-lighter)]`},Ce={key:0,class:`flex items-center gap-2 mb-1.5`},we=[`src`,`alt`],Te={class:`text-xs text-[var(--el-text-color-secondary)] truncate`},Ee={class:`text-xs text-[var(--el-text-color-disabled)]`},De=[`href`],Oe={key:1,class:`text-xs text-[var(--el-text-color-disabled)] mt-1`},ke={key:2,class:`text-sm text-[var(--el-text-color-regular)] mt-1.5 leading-relaxed line-clamp-3`},Ae={key:3,class:`mt-3 flex flex-wrap gap-x-4 gap-y-1`},je=[`href`];function Me(e,t,r,i,o,u){return l(),f(`div`,Se,[e.displayUrl?(l(),f(`div`,Ce,[n(`img`,{src:e.faviconUrl,alt:e.hostname,class:`w-4 h-4 rounded-sm flex-none`,loading:`lazy`,onError:t[0]||=(...t)=>e.onFaviconError&&e.onFaviconError(...t)},null,40,we),n(`span`,Te,c(e.hostname),1),n(`span`,Ee,c(e.pathname),1)])):a(``,!0),n(`a`,{href:e.data.link,target:`_blank`,rel:`noopener noreferrer`,class:`text-base font-semibold text-[var(--el-color-primary)] hover:underline leading-snug block`},c(e.data.title),9,De),e.data.date?(l(),f(`div`,Oe,c(e.data.date),1)):a(``,!0),e.data.snippet?(l(),f(`p`,ke,c(e.data.snippet),1)):a(``,!0),e.data.sitelinks?.length?(l(),f(`div`,Ae,[(l(!0),f(m,null,s(e.data.sitelinks,(e,t)=>(l(),f(`a`,{key:t,href:e.link,target:`_blank`,rel:`noopener noreferrer`,class:`text-xs text-[var(--el-color-primary-light-3)] hover:text-[var(--el-color-primary)] hover:underline transition-colors`},c(e.title),9,je))),128))])):a(``,!0)])}var Ne=x(xe,[[`render`,Me]]),Pe=o({name:`ImageResults`,props:{data:{type:Array,required:!0}}}),Fe={class:`rounded-xl border border-[var(--el-border-color-lighter)] p-5 bg-[var(--el-fill-color-blank)]`},Ie={class:`text-base font-bold mb-3`},Le={class:`grid grid-cols-2 sm:grid-cols-3 md:grid-cols-4 gap-3`},Re=[`href`],ze=[`src`,`alt`],Be={class:`absolute inset-x-0 bottom-0 bg-gradient-to-t from-black/70 to-transparent p-2.5 opacity-0 group-hover:opacity-100 transition-opacity duration-200`},Ve={class:`text-xs text-white line-clamp-2`};function He(e,t,r,i,o,u){return l(),f(`div`,Fe,[n(`h3`,Ie,c(e.$t(`serp.name.imageResults`)),1),n(`div`,Le,[(l(!0),f(m,null,s(e.data,(e,t)=>(l(),f(`a`,{key:t,href:e.link,target:`_blank`,rel:`noopener noreferrer`,class:`group relative rounded-lg overflow-hidden bg-[var(--el-fill-color-light)] aspect-square`},[e.image_url?(l(),f(`img`,{key:0,src:e.image_url,alt:e.title,class:`w-full h-full object-cover transition-transform duration-300 group-hover:scale-105`,loading:`lazy`},null,8,ze)):a(``,!0),n(`div`,Be,[n(`span`,Ve,c(e.title),1)])],8,Re))),128))])])}var Ue=x(Pe,[[`render`,He]]),We=o({name:`VideoResults`,props:{data:{type:Array,required:!0}}}),Ge={class:`text-base font-bold mb-3`},Ke={class:`space-y-4`},qe=[`href`],Je={class:`relative flex-shrink-0 w-40 h-24 rounded overflow-hidden bg-gray-100 dark:bg-gray-800`},Ye=[`src`,`alt`],Xe={key:1,class:`absolute bottom-1 right-1 bg-black/80 text-white text-xs px-1 rounded`},Ze={class:`flex-1 min-w-0`},Qe={class:`text-blue-600 group-hover:underline font-medium line-clamp-2`},$e={class:`text-xs text-gray-400 mt-1`},et={key:0},tt={key:1},nt={key:2},rt={key:0,class:`text-sm text-gray-600 dark:text-gray-300 mt-1 line-clamp-2`};function it(e,t,r,i,o,u){return l(),f(`div`,null,[n(`h3`,Ge,c(e.$t(`serp.name.videoResults`)),1),n(`div`,Ke,[(l(!0),f(m,null,s(e.data,(e,t)=>(l(),f(`a`,{key:t,href:e.link,target:`_blank`,rel:`noopener noreferrer`,class:`flex gap-4 group`},[n(`div`,Je,[e.image_url?(l(),f(`img`,{key:0,src:e.image_url,alt:e.title,class:`w-full h-full object-cover`,loading:`lazy`},null,8,Ye)):a(``,!0),e.duration?(l(),f(`div`,Xe,c(e.duration),1)):a(``,!0)]),n(`div`,Ze,[n(`div`,Qe,c(e.title),1),n(`div`,$e,[e.source?(l(),f(`span`,et,c(e.source),1)):a(``,!0),e.channel?(l(),f(`span`,tt,` · `+c(e.channel),1)):a(``,!0),e.date?(l(),f(`span`,nt,` · `+c(e.date),1)):a(``,!0)]),e.snippet?(l(),f(`p`,rt,c(e.snippet),1)):a(``,!0)])],8,qe))),128))])])}var at=x(We,[[`render`,it]]),ot=o({name:`NewsResults`,props:{data:{type:Array,required:!0}}}),st={class:`text-base font-bold mb-3`},ct={class:`space-y-4`},lt=[`href`],ut={class:`flex-1 min-w-0`},dt={class:`text-blue-600 group-hover:underline font-medium line-clamp-2`},ft={class:`text-xs text-gray-400 mt-1`},pt={key:0},mt={key:1},ht={key:0,class:`text-sm text-gray-600 dark:text-gray-300 mt-1 line-clamp-2`},gt={key:0,class:`flex-shrink-0 w-24 h-24 rounded overflow-hidden bg-gray-100 dark:bg-gray-800`},_t=[`src`,`alt`];function vt(e,t,r,i,o,u){return l(),f(`div`,null,[n(`h3`,st,c(e.$t(`serp.name.newsResults`)),1),n(`div`,ct,[(l(!0),f(m,null,s(e.data,(e,t)=>(l(),f(`a`,{key:t,href:e.link,target:`_blank`,rel:`noopener noreferrer`,class:`flex gap-4 group`},[n(`div`,ut,[n(`div`,dt,c(e.title),1),n(`div`,ft,[e.source?(l(),f(`span`,pt,c(e.source),1)):a(``,!0),e.date?(l(),f(`span`,mt,` · `+c(e.date),1)):a(``,!0)]),e.snippet?(l(),f(`p`,ht,c(e.snippet),1)):a(``,!0)]),e.image_url?(l(),f(`div`,gt,[n(`img`,{src:e.image_url,alt:e.title,class:`w-full h-full object-cover`,loading:`lazy`},null,8,_t)])):a(``,!0)],8,lt))),128))])])}var yt=x(ot,[[`render`,vt]]),bt=o({name:`PeopleAlsoAsk`,components:{ElCollapse:y,ElCollapseItem:v},props:{data:{type:Array,required:!0}}}),xt={class:`rounded-xl border border-[var(--el-border-color-lighter)] p-5 bg-[var(--el-fill-color-blank)]`},St={class:`text-base font-bold mb-3`},Ct={key:0,class:`text-sm text-[var(--el-text-color-regular)] mb-2 leading-relaxed`},wt=[`href`];function Tt(e,r,o,d,h,g){let _=u(`el-collapse-item`),v=u(`el-collapse`);return l(),f(`div`,xt,[n(`h3`,St,c(e.$t(`serp.name.peopleAlsoAsk`)),1),i(v,null,{default:p(()=>[(l(!0),f(m,null,s(e.data,(e,n)=>(l(),t(_,{key:n,title:e.question||e.title||``},{default:p(()=>[e.snippet?(l(),f(`p`,Ct,c(e.snippet),1)):a(``,!0),e.link?(l(),f(`a`,{key:1,href:e.link,target:`_blank`,rel:`noopener noreferrer`,class:`text-xs text-[var(--el-color-primary)] hover:underline`},c(e.title||e.link),9,wt)):a(``,!0)]),_:2},1032,[`title`]))),128))]),_:1})])}var Et=x(bt,[[`render`,Tt]]),Dt=o({name:`RelatedSearches`,components:{FontAwesomeIcon:E},props:{data:{type:Array,required:!0}},emits:[`search`],methods:{onSearch(e){e&&this.$emit(`search`,e)}}}),Ot={class:`rounded-xl border border-[var(--el-border-color-lighter)] p-5 bg-[var(--el-fill-color-blank)]`},kt={class:`text-base font-bold mb-3`},At={class:`flex flex-wrap gap-2`},jt=[`onClick`];function Mt(e,t,a,o,d,p){let h=u(`font-awesome-icon`);return l(),f(`div`,Ot,[n(`h3`,kt,c(e.$t(`serp.name.relatedSearches`)),1),n(`div`,At,[(l(!0),f(m,null,s(e.data,(t,n)=>(l(),f(`button`,{key:n,class:`inline-flex items-center gap-1.5 px-3 py-1.5 rounded-full text-sm bg-[var(--el-fill-color-light)] text-[var(--el-text-color-regular)] hover:bg-[var(--el-color-primary-light-9)] hover:text-[var(--el-color-primary)] transition-colors cursor-pointer border-none`,onClick:n=>e.onSearch(t.query)},[i(h,{icon:`fa-solid fa-magnifying-glass`,class:`text-xs opacity-50`}),r(` `+c(t.query),1)],8,jt))),128))])])}var Nt=o({name:`ResultPanel`,components:{FontAwesomeIcon:E,KnowledgeGraph:be,OrganicResult:Ne,ImageResults:Ue,VideoResults:at,NewsResults:yt,PeopleAlsoAsk:Et,RelatedSearches:x(Dt,[[`render`,Mt]])},emits:[`related-search`],computed:{results(){return this.$store.state.serp?.results},searching(){return this.$store.state.serp?.status?.search===T.Request},noResults(){return this.$store.state.serp?.status?.search===T.Success&&this.results&&!this.results.organic?.length&&!this.results.images?.length&&!this.results.videos?.length&&!this.results.news?.length&&!this.results.knowledge_graph?.title}},methods:{onRelatedSearch(e){this.$emit(`related-search`,e)}}}),$={class:`h-full overflow-y-auto p-6`},Pt={key:0,class:`max-w-3xl mx-auto py-8`},Ft={key:1,class:`flex flex-col items-center justify-center py-24 text-[var(--el-text-color-disabled)]`},It={class:`text-base`},Lt={key:2,class:`max-w-3xl mx-auto`},Rt={key:1,class:`mb-6`},zt={key:3,class:`flex flex-col items-center justify-center py-24 text-[var(--el-text-color-disabled)]`},Bt={class:`text-base`};function Vt(e,r,o,p,h,g){let _=u(`font-awesome-icon`),v=u(`knowledge-graph`),y=u(`organic-result`),b=u(`image-results`),x=u(`video-results`),S=u(`news-results`),C=u(`people-also-ask`),w=u(`related-searches`);return l(),f(`div`,$,[e.searching?(l(),f(`div`,Pt,[(l(),f(m,null,s(4,e=>n(`div`,{key:e,class:`mb-6 animate-pulse`},[...r[0]||=[d(`<div class="flex items-center gap-2 mb-2"><div class="w-4 h-4 rounded-sm bg-[var(--el-fill-color-darker)]"></div><div class="h-3 w-32 rounded bg-[var(--el-fill-color-darker)]"></div></div><div class="h-4 w-3/4 rounded bg-[var(--el-fill-color-dark)] mb-2"></div><div class="h-3 w-full rounded bg-[var(--el-fill-color)] mb-1"></div><div class="h-3 w-5/6 rounded bg-[var(--el-fill-color)]"></div>`,4)]])),64))])):e.noResults?(l(),f(`div`,Ft,[i(_,{icon:`fa-solid fa-face-meh`,class:`text-5xl mb-4 opacity-40`}),n(`p`,It,c(e.$t(`serp.message.noResults`)),1)])):e.results?(l(),f(`div`,Lt,[e.results.knowledge_graph?.title?(l(),t(v,{key:0,data:e.results.knowledge_graph,class:`mb-6`},null,8,[`data`])):a(``,!0),e.results.organic?.length?(l(),f(`div`,Rt,[(l(!0),f(m,null,s(e.results.organic,(e,n)=>(l(),t(y,{key:n,data:e,class:`mb-1`},null,8,[`data`]))),128))])):a(``,!0),e.results.images?.length?(l(),t(b,{key:2,data:e.results.images,class:`mb-6`},null,8,[`data`])):a(``,!0),e.results.videos?.length?(l(),t(x,{key:3,data:e.results.videos,class:`mb-6`},null,8,[`data`])):a(``,!0),e.results.news?.length?(l(),t(S,{key:4,data:e.results.news,class:`mb-6`},null,8,[`data`])):a(``,!0),e.results.people_also_ask?.length?(l(),t(C,{key:5,data:e.results.people_also_ask,class:`mb-6`},null,8,[`data`])):a(``,!0),e.results.related_searches?.length?(l(),t(w,{key:6,data:e.results.related_searches,class:`mb-6`,onSearch:e.onRelatedSearch},null,8,[`data`,`onSearch`])):a(``,!0)])):(l(),f(`div`,zt,[i(_,{icon:`fa-solid fa-globe`,class:`text-5xl mb-4 opacity-30`}),n(`p`,Bt,c(e.$t(`serp.description.query`)),1)]))])}var Ht=o({name:`SerpIndex`,components:{Layout:j,SearchPanel:oe,ResultPanel:x(Nt,[[`render`,Vt]])},inject:[`initialized`],async mounted(){await this.onGetService()},methods:{async onGetService(){console.debug(`start onGetService`),await this.$store.dispatch(`serp/getService`),console.debug(`end onGetService`)},async onSearch(){if(this.$store.state.serp?.config?.query){w.info(this.$t(`serp.message.searching`));try{await this.$store.dispatch(`serp/search`),w.success(this.$t(`serp.message.searchSuccess`))}catch(e){(e?.response?.data)?.error?.code===`used_up`?w.error(this.$t(`serp.message.usedUp`)):w.error(this.$t(`serp.message.searchFailed`))}}},async onRelatedSearch(e){this.$store.commit(`serp/setConfig`,{...this.$store.state.serp?.config,query:e}),await this.onSearch()}}});function Ut(e,n,r,a,o,s){let c=u(`search-panel`),d=u(`result-panel`),f=u(`layout`);return l(),t(f,null,{config:p(()=>[i(c,{onSearch:e.onSearch},null,8,[`onSearch`])]),result:p(()=>[i(d,{onRelatedSearch:e.onRelatedSearch},null,8,[`onRelatedSearch`])]),_:1})}var Wt=x(Ht,[[`render`,Ut]]);export{Wt as default};
@@ -1 +1 @@
1
- import"./rolldown-runtime--c01j_DQ.js";import{Bt as e,D as t,E as n,M as r,N as i,O as a,P as o,Q as s,Ut as c,X as l,et as u,k as d,lt as f,x as p,y as m}from"./vendor-chart-mdwpew_o.js";import{t as h}from"./button-DWzbdjZV.js";import{r as g,t as _}from"./select-CtOUS-1J.js";import{t as v}from"./upload-CnVhrWBT.js";import{t as y}from"./tooltip-C3PYfh8V.js";import{t as b}from"./image-D5iIL2A6.js";import{t as x}from"./alert-BJj7gY4q.js";import{Ln as S,pi as C}from"./constants-C-bSXdJ_.js";import{At as w,E as T,Fn as E,Nt as D,Ot as ee,Sr as te,cn as O,jt as k,kr as A,kt as j,yr as M}from"./index-uml6ohnH.js";import{t as N}from"./index.es-CcQaWbuV.js";import{t as P}from"./CopyToClipboard-Dnrr0G1l.js";import{t as F}from"./ImagePreview-D9ovswSr.js";import{t as I}from"./Hailuo-hE8NOeDF.js";import{t as L}from"./BotPlaceholder-By9wptjP.js";import{i as R,n as z,t as B}from"./pagination-BUM1iMKs.js";import{n as V,t as H}from"./NoTasks-BHtlhARF.js";import{t as U}from"./Consumption-Dlo2Ec9d.js";import{t as W}from"./ApiCodeButton-CYsbafW5.js";import{t as G}from"./VideoPlayer-qDDLVH7_.js";var K=o({name:`ModelSelector`,components:{ElSelect:g,ElOption:_},data(){return{}},computed:{options(){return[{value:`minimax-t2v`,label:this.$t(`hailuo.button.model1`)},{value:`minimax-i2v`,label:this.$t(`hailuo.button.model2`)},{value:`minimax-i2v-director`,label:this.$t(`hailuo.button.model3`)}]},value:{get(){return this.$store.state.hailuo?.config?.model},set(e){this.$store.commit(`hailuo/setConfig`,{...this.$store.state.hailuo?.config,model:e})}}},mounted(){this.value||=S}}),q={class:`field`},J={class:`title font-bold`},Y={class:`float-left`};function X(e,r,a,o,m,h){let g=u(`el-option`),_=u(`el-select`);return l(),d(`div`,q,[n(`h2`,J,c(e.$t(`hailuo.name.model`)),1),i(_,{modelValue:e.value,"onUpdate:modelValue":r[0]||=t=>e.value=t,class:`value`,placeholder:e.$t(`hailuo.placeholder.select`),clearable:``},{default:f(()=>[(l(!0),d(p,null,s(e.options,e=>(l(),t(g,{key:e.value,label:e.label,value:e.value},{default:f(()=>[n(`span`,Y,c(e.label),1)]),_:2},1032,[`label`,`value`]))),128))]),_:1},8,[`modelValue`,`placeholder`])])}var Z=T(K,[[`render`,X],[`__scopeId`,`data-v-a768fbd9`]]),Q=o({name:`StartImageUrlInput`,components:{ElUpload:v,ElButton:h,InfoIcon:R,ImagePreview:F},mixins:[k,j],data(){return{fileList:[],uploadUrl:te()+`/api/v1/files/`}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e.url).filter(e=>e!==void 0)},value:{get(){return this.$store.state.hailuo?.config?.first_image_url},set(){let e=this.urls?.[0];this.$store.commit(`hailuo/setConfig`,{...this.$store.state.hailuo?.config,first_image_url:e})}}},mounted(){this.value||=void 0,this.onSetStartImageUrl()},methods:{onExceed(){A.warning(this.$t(`hailuo.message.uploadStartImageExceed`))},onError(){A.error(this.$t(`hailuo.message.uploadStartImageError`))},async onRemove(){A.error(this.$t(`hailuo.message.uploadStartImageError`))},onSetStartImageUrl(){let e=this.urls?.[0];this.$store.commit(`hailuo/setConfig`,{...this.$store.state.hailuo?.config,first_image_url:e})},async onSuccess(){this.onSetStartImageUrl()}}}),ne={class:`relative`},re={class:`flex justify-between`},ie={class:`flex justify-start items-center`},ae={class:`text-sm font-bold`};function oe(e,o,s,p,m,h){let g=u(`info-icon`),_=u(`image-preview`),v=u(`el-button`),y=u(`el-upload`);return l(),d(`div`,ne,[n(`div`,re,[n(`div`,ie,[n(`span`,ae,c(e.$t(`hailuo.name.startImageUrl`)),1),i(g,{content:e.$t(`hailuo.description.startImageUrl`),class:`info`},null,8,[`content`])])]),i(y,{ref:`uploader`,"file-list":e.fileList,"onUpdate:fileList":o[0]||=t=>e.fileList=t,accept:`.png,.jpg,.jpeg,.gif,.bmp,.webp`,name:`file`,"show-file-list":!0,limit:1,multiple:!1,"list-type":`picture`,action:e.uploadUrl,"on-exceed":e.onExceed,"on-error":e.onError,"on-remove":e.onRemove,"on-success":e.onSuccess,headers:e.headers},{file:f(({file:n})=>[n.url&&n.percentage!==void 0?(l(),t(_,{key:0,url:n.url,name:n.name,percentage:n.percentage,onRemove:t=>e.fileList.splice(e.fileList.indexOf(n),1)},null,8,[`url`,`name`,`percentage`,`onRemove`])):a(``,!0)]),default:f(()=>[i(v,{size:`small`,type:`primary`,class:`btn btn-upload`,round:``},{default:f(()=>[r(c(e.$t(`hailuo.button.uploadStartImageUrl`)),1)]),_:1})]),_:1},8,[`file-list`,`action`,`on-exceed`,`on-error`,`on-remove`,`on-success`,`headers`])])}var se=T(Q,[[`render`,oe],[`__scopeId`,`data-v-fbf49b06`]]),ce=o({name:`PromptInput`,components:{PromptTextarea:V},computed:{prompt:{get(){return this.$store.state.hailuo?.config?.prompt},set(e){this.$store.commit(`hailuo/setConfig`,{...this.$store.state.hailuo?.config,prompt:e})}}},mounted(){this.prompt||=``}});function le(e,n,r,i,a,o){let s=u(`prompt-textarea`);return l(),t(s,{modelValue:e.prompt,"onUpdate:modelValue":n[0]||=t=>e.prompt=t,title:e.$t(`hailuo.name.prompt`),info:e.$t(`hailuo.description.prompt`),placeholder:e.$t(`hailuo.placeholder.prompt`)},null,8,[`modelValue`,`title`,`info`,`placeholder`])}var ue=o({name:`PresetPanel`,components:{ElButton:h,FontAwesomeIcon:N,PromptInput:T(ce,[[`render`,le]]),StartImageUrlInput:se,ModelSelector:Z,Consumption:U},emits:[`generate`],computed:{config(){return this.$store.state.hailuo?.config},consumption(){return D(this.config,this.service?.cost)},service(){return this.$store.state.hailuo?.service}},methods:{onGenerate(){this.$emit(`generate`)}}}),de={class:`flex flex-col h-full`},fe={class:`flex-1 overflow-y-auto p-5`},pe={class:`flex flex-col items-center justify-center px-5 pb-5`};function me(e,o,s,p,m,h){let g=u(`prompt-input`),_=u(`model-selector`),v=u(`start-image-url-input`),y=u(`consumption`),b=u(`font-awesome-icon`),x=u(`el-button`);return l(),d(`div`,de,[n(`div`,fe,[i(g,{class:`mb-4`}),i(_,{class:`mb-4`}),e.config?.model===`minimax-i2v`?(l(),t(v,{key:0,class:`mb-2`})):a(``,!0)]),n(`div`,pe,[i(y,{value:e.consumption,service:e.service},null,8,[`value`,`service`]),e.config?.video_url!==void 0||e.config?.custom?(l(),t(x,{key:0,type:`primary`,class:`btn w-full`,round:``,onClick:e.onGenerate},{default:f(()=>[i(b,{icon:`fa-solid fa-magic`,class:`mr-2`}),r(` `+c(e.$t(`hailuo.button.extend`)),1)]),_:1},8,[`onClick`])):(l(),t(x,{key:1,type:`primary`,class:`btn w-full`,round:``,onClick:e.onGenerate},{default:f(()=>[i(b,{icon:`fa-solid fa-magic`,class:`mr-2`}),r(` `+c(e.$t(`hailuo.button.generate`)),1)]),_:1},8,[`onClick`]))])])}var he=T(ue,[[`render`,me]]),ge=o({name:`TaskPreview`,components:{ElImage:b,CopyToClipboard:P,FontAwesomeIcon:N,ElAlert:x,VideoPlayer:G,ElTooltip:y,ElButton:h,ApiCodeButton:W},props:{modelValue:{type:Object,required:!0}},computed:{application(){return this.$store.state.hailuo?.application},config(){return this.$store.state.hailuo?.config},video(){return this.modelValue?.response?.data?.[0]}},methods:{onDownload(e){console.debug(`on download hailuo video`,e),window.open(e,`_blank`)}}}),_e={class:`preview`},ve={class:`left`},ye={class:`main`},be={class:`bot`},xe={class:`datetime`},Se={class:`info`},Ce={key:0,class:`prompt mt-2`},we={key:0},Te={key:1},Ee={key:0,class:e({content:!0,failed:!0})},De={key:0,class:`mb-4`},Oe={key:1,class:e({operations:!0,"mt-2":!0})},ke={key:0,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},Ae={class:`text-[var(--el-text-color-regular)] text-xs mb-2`},je={key:1,class:`text-[var(--el-text-color-regular)] text-xs mb-0`},Me={key:1,class:e({content:!0})},Ne={class:`text-[var(--el-text-color-regular)] text-xs mb-2`},Pe={class:`text-[var(--el-text-color-regular)] text-xs mb-2`},$={key:0,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},Fe={class:`text-[var(--el-text-color-regular)] text-xs mb-0`},Ie={key:2,class:e({content:!0})},Le={class:`text-[var(--el-text-color-regular)] text-xs mb-0`};function Re(e,o,s,p,h,g){let _=u(`el-image`),v=u(`video-player`),y=u(`el-button`),b=u(`el-tooltip`),x=u(`api-code-button`),S=u(`font-awesome-icon`),C=u(`copy-to-clipboard`),w=u(`el-alert`);return l(),d(`div`,_e,[n(`div`,ve,[i(_,{src:`https://cdn.acedata.cloud/0qg4gp.png`,class:`avatar`})]),n(`div`,ye,[n(`div`,be,[r(c(e.$t(`hailuo.name.hailuoBot`))+` `,1),n(`span`,xe,c(e.$dayjs.format(``+new Date(parseFloat((e.modelValue?.created_at||``).toString())*1e3))),1)]),n(`div`,Se,[e.modelValue?.request?.prompt?(l(),d(`p`,Ce,[r(c(e.modelValue?.request?.prompt)+` `,1),e.modelValue?.response?a(``,!0):(l(),d(`span`,we,` - (`+c(e.$t(`hailuo.status.pending`))+`) `,1)),e.video?.state===`processing`||e.video?.state===`pending`||e.video?.state===`running`?(l(),d(`span`,Te,` - (`+c(e.$t(`hailuo.status.processing`))+`) `,1)):a(``,!0)])):a(``,!0)]),e.modelValue?.response?.success===!0?(l(),d(`div`,Ee,[e.video?.video_url?(l(),d(`div`,De,[i(v,{src:e.video?.video_url},null,8,[`src`])])):a(``,!0),e.video?(l(),d(`div`,Oe,[i(b,{class:`box-item`,effect:`dark`,content:e.$t(`hailuo.message.downloadVideo`),placement:`top-start`},{default:f(()=>[e.video?.video_url?(l(),t(y,{key:0,type:`info`,size:`small`,class:`mb-2`,onClick:o[0]||=m(t=>e.onDownload(e.video?.video_url),[`stop`])},{default:f(()=>[r(c(e.$t(`hailuo.button.download`)),1)]),_:1})):a(``,!0)]),_:1},8,[`content`]),i(x,{path:`/hailuo/videos`,body:e.modelValue?.request},null,8,[`body`])])):a(``,!0),i(w,{closable:!1,class:`mt-2 success`},{default:f(()=>[e.modelValue?.request?.model?(l(),d(`p`,ke,[i(S,{icon:`fa-solid fa-hashtag`,class:`mr-1`}),r(` `+c(e.$t(`hailuo.name.model`))+`: `+c(e.modelValue?.request?.model)+` `,1),i(C,{content:e.modelValue?.id},null,8,[`content`])])):a(``,!0),n(`p`,Ae,[i(S,{icon:`fa-solid fa-magic`,class:`mr-1`}),r(` `+c(e.$t(`hailuo.name.taskId`))+`: `+c(e.modelValue?.id)+` `,1),i(C,{content:e.modelValue?.id},null,8,[`content`])]),e.modelValue?.elapsed?(l(),d(`p`,je,[i(S,{icon:`fa-solid fa-clock`,class:`mr-1`}),r(` `+c(e.$t(`hailuo.name.elapsed`))+`: `+c(e.modelValue?.elapsed?.toFixed(2))+`s `,1)])):a(``,!0)]),_:1})])):a(``,!0),e.modelValue?.response?.success===!1?(l(),d(`div`,Me,[i(w,{closable:!1,class:`failure`},{template:f(()=>[i(S,{icon:`fa-solid fa-exclamation-triangle`,class:`mr-1`}),r(` `+c(e.$t(`hailuo.name.failure`)),1)]),default:f(()=>[n(`p`,Ne,[i(S,{icon:`fa-solid fa-magic`,class:`mr-1`}),r(` `+c(e.$t(`hailuo.name.taskId`))+`: `+c(e.modelValue?.id)+` `,1),i(C,{content:e.modelValue?.id},null,8,[`content`])]),n(`p`,Pe,[i(S,{icon:`fa-solid fa-circle-info`,class:`mr-1`}),r(` `+c(e.$t(`hailuo.name.failureReason`))+`: `+c(e.modelValue?.response?.error?.message)+` `,1),i(C,{content:e.modelValue?.response?.error?.message},null,8,[`content`])]),e.modelValue?.elapsed?(l(),d(`p`,$,[i(S,{icon:`fa-solid fa-clock`,class:`mr-1`}),r(` `+c(e.$t(`hailuo.name.elapsed`))+`: `+c(e.modelValue?.elapsed?.toFixed(2))+`s `,1)])):a(``,!0),n(`p`,Fe,[i(S,{icon:`fa-solid fa-hashtag`,class:`mr-1`}),r(` `+c(e.$t(`hailuo.name.traceId`))+`: `+c(e.modelValue?.response?.trace_id)+` `,1),i(C,{content:e.modelValue?.response?.trace_id},null,8,[`content`])])]),_:1})])):a(``,!0),e.modelValue?.response?.success===void 0?(l(),d(`div`,Ie,[i(w,{closable:!1,class:`info`},{template:f(()=>[i(S,{icon:`fa-solid fa-exclamation-triangle`,class:`mr-1`}),r(` `+c(e.$t(`hailuo.name.failure`)),1)]),default:f(()=>[n(`p`,Le,[i(S,{icon:`fa-solid fa-magic`,class:`mr-1`}),r(` `+c(e.$t(`hailuo.name.taskId`))+`: `+c(e.modelValue?.id)+` `,1),i(C,{content:e.modelValue?.id},null,8,[`content`])])]),_:1})])):a(``,!0)])])}var ze=o({name:`RecentPanel`,components:{TaskPreview:T(ge,[[`render`,Re],[`__scopeId`,`data-v-53d13da4`]]),BotPlaceholder:L,NoTasks:H,ScrollList:z},props:{loading:{type:Boolean,default:!1}},emits:[`reach-top`],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.hailuo?.tasks,items:this.$store.state.hailuo?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),Be={key:0},Ve={key:2,class:`w-full h-full flex items-center justify-center`};function He(e,n,r,o,c,m){let h=u(`bot-placeholder`),g=u(`task-preview`),_=u(`scroll-list`),v=u(`no-tasks`);return l(),d(p,null,[e.tasks?.items===void 0?(l(),d(`div`,Be,[i(h)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(l(),t(_,{key:1,ref:`scrollList`,class:`tasks w-full h-full overflow-y-auto`,loading:e.loading,onReachTop:n[0]||=t=>e.$emit(`reach-top`)},{default:f(()=>[(l(!0),d(p,null,s(e.tasks?.items,e=>(l(),t(g,{key:e.id,"model-value":e},null,8,[`model-value`]))),128))]),_:1},8,[`loading`])):a(``,!0),e.tasks?.items?.length===0?(l(),d(`div`,Ve,[i(v)])):a(``,!0)],64)}var Ue=T(ze,[[`render`,He]]),We=C(`hailuo`),Ge=o({name:`HailuoIndex`,components:{ConfigPanel:he,Layout:I,RecentPanel:Ue},mixins:[w],inject:[`initialized`],data(){return{task:void 0,job:0,timer:void 0,loadingMore:!1,fetchingTasks:!1}},computed:{applicationsLoading(){return this.$store.state.hailuo?.status?.getApplications===M.Request},tasksLoading(){return this.$store.state.hailuo?.status?.getTasks===M.Request||this.fetchingTasks},credential(){return this.$store.state.hailuo.credential},config(){return this.$store.state.hailuo.config},application(){return this.$store.state.hailuo.application},tasks(){return this.$store.state.hailuo.tasks}},watch:{tasks:{handler(e,t){e?.items?.length>t?.items?.length&&console.debug(`new tasks detected`)},deep:!0},initialized:{async handler(e){e&&(console.debug(`layout initialized`),await this.onGetTasks(),await this.onScrollDown(),this.job=window.setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){window.clearInterval(this.job)},methods:{async onReachTop(){await B({tasks:this.tasks,getTasks:()=>this.tasks,loading:this.loadingMore,setLoading:e=>this.loadingMore=e,isBlocked:()=>this.tasksLoading||this.applicationsLoading,fetch:e=>this.onGetTasks({createdAtMax:e}),getScrollElement:()=>this.getTasksScrollElement()})},async onGetService(){console.debug(`start onGetService`),await this.$store.dispatch(`hailuo/getService`),console.debug(`end onGetService`)},async onGetApplication(){console.debug(`start onGetApplication`),await this.$store.dispatch(`hailuo/getApplications`),console.debug(`end onGetApplication`),await this.onGetTasks()},async onScrollDown(){await this.$nextTick();let e=this.getTasksScrollElement();e&&(e.scrollTop=e.scrollHeight)},async onGetTasks(e){if(this.applicationsLoading||this.fetchingTasks){console.debug(`loading`);return}console.debug(`start onGetTasks`,e);let{limit:t=5,createdAtMin:n,createdAtMax:r}=e||{};console.debug(`limit`,t,`createdAtMin`,n,`createdAtMax`,r),this.fetchingTasks=!0;try{await this.$store.dispatch(`hailuo/getTasks`,{limit:t,createdAtMin:n,createdAtMax:r})}finally{this.fetchingTasks=!1}},async onGenerate(){if(!ee(this.uploadTracker,e=>this.$t(e),e=>A.warning(e)))return;let e={...this.config,callback_url:We},t=this.credential?.token;if(!t){console.error(`no token specified`);return}A.info(this.$t(`hailuo.message.startingTask`)),E(`hailuo`,O.generate(e,{token:t})).then(()=>{A.success(this.$t(`hailuo.message.startTaskSuccess`))}).catch(e=>{(e?.response?.data)?.error?.code===`used_up`?A.error(this.$t(`hailuo.message.usedUp`)):A.error(this.$t(`hailuo.message.startTaskFailed`))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function Ke(e,n,r,a,o,s){let c=u(`config-panel`),d=u(`recent-panel`),p=u(`layout`);return l(),t(p,null,{config:f(()=>[i(c,{onGenerate:e.onGenerate},null,8,[`onGenerate`])]),result:f(()=>[i(d,{ref:`recentPanel`,loading:e.loadingMore,onReachTop:e.onReachTop},null,8,[`loading`,`onReachTop`])]),_:1})}var qe=T(Ge,[[`render`,Ke]]);export{qe as default};
1
+ import"./rolldown-runtime--c01j_DQ.js";import{Bt as e,D as t,E as n,M as r,N as i,O as a,P as o,Q as s,Ut as c,X as l,et as u,k as d,lt as f,x as p,y as m}from"./vendor-chart-mdwpew_o.js";import{t as h}from"./button-DWzbdjZV.js";import{r as g,t as _}from"./select-Byt7Qw1F.js";import{t as v}from"./upload-CDJi96y4.js";import{t as y}from"./tooltip-C3PYfh8V.js";import{t as b}from"./image-CUt2yKJT.js";import{t as x}from"./alert-BJj7gY4q.js";import{Ln as S,pi as C}from"./constants-C-bSXdJ_.js";import{At as w,E as T,Fn as E,Nt as D,Ot as ee,Sr as te,cn as O,jt as k,kr as A,kt as j,yr as M}from"./index-Dzx62HWL.js";import{t as N}from"./index.es-BIezN10l.js";import{t as P}from"./CopyToClipboard-LZRed5aB.js";import{t as F}from"./ImagePreview-B2FwyzyM.js";import{t as I}from"./Hailuo-C2eHP_WO.js";import{t as L}from"./BotPlaceholder-DzIzZltA.js";import{i as R,n as z,t as B}from"./pagination-t1m3PdtM.js";import{n as V,t as H}from"./NoTasks-Bk9F1-iz.js";import{t as U}from"./Consumption-DLzGFeUT.js";import{t as W}from"./ApiCodeButton-C8TdRvY9.js";import{t as G}from"./VideoPlayer--5snxkv4.js";var K=o({name:`ModelSelector`,components:{ElSelect:g,ElOption:_},data(){return{}},computed:{options(){return[{value:`minimax-t2v`,label:this.$t(`hailuo.button.model1`)},{value:`minimax-i2v`,label:this.$t(`hailuo.button.model2`)},{value:`minimax-i2v-director`,label:this.$t(`hailuo.button.model3`)}]},value:{get(){return this.$store.state.hailuo?.config?.model},set(e){this.$store.commit(`hailuo/setConfig`,{...this.$store.state.hailuo?.config,model:e})}}},mounted(){this.value||=S}}),q={class:`field`},J={class:`title font-bold`},Y={class:`float-left`};function X(e,r,a,o,m,h){let g=u(`el-option`),_=u(`el-select`);return l(),d(`div`,q,[n(`h2`,J,c(e.$t(`hailuo.name.model`)),1),i(_,{modelValue:e.value,"onUpdate:modelValue":r[0]||=t=>e.value=t,class:`value`,placeholder:e.$t(`hailuo.placeholder.select`),clearable:``},{default:f(()=>[(l(!0),d(p,null,s(e.options,e=>(l(),t(g,{key:e.value,label:e.label,value:e.value},{default:f(()=>[n(`span`,Y,c(e.label),1)]),_:2},1032,[`label`,`value`]))),128))]),_:1},8,[`modelValue`,`placeholder`])])}var Z=T(K,[[`render`,X],[`__scopeId`,`data-v-a768fbd9`]]),Q=o({name:`StartImageUrlInput`,components:{ElUpload:v,ElButton:h,InfoIcon:R,ImagePreview:F},mixins:[k,j],data(){return{fileList:[],uploadUrl:te()+`/api/v1/files/`}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e.url).filter(e=>e!==void 0)},value:{get(){return this.$store.state.hailuo?.config?.first_image_url},set(){let e=this.urls?.[0];this.$store.commit(`hailuo/setConfig`,{...this.$store.state.hailuo?.config,first_image_url:e})}}},mounted(){this.value||=void 0,this.onSetStartImageUrl()},methods:{onExceed(){A.warning(this.$t(`hailuo.message.uploadStartImageExceed`))},onError(){A.error(this.$t(`hailuo.message.uploadStartImageError`))},async onRemove(){A.error(this.$t(`hailuo.message.uploadStartImageError`))},onSetStartImageUrl(){let e=this.urls?.[0];this.$store.commit(`hailuo/setConfig`,{...this.$store.state.hailuo?.config,first_image_url:e})},async onSuccess(){this.onSetStartImageUrl()}}}),ne={class:`relative`},re={class:`flex justify-between`},ie={class:`flex justify-start items-center`},ae={class:`text-sm font-bold`};function oe(e,o,s,p,m,h){let g=u(`info-icon`),_=u(`image-preview`),v=u(`el-button`),y=u(`el-upload`);return l(),d(`div`,ne,[n(`div`,re,[n(`div`,ie,[n(`span`,ae,c(e.$t(`hailuo.name.startImageUrl`)),1),i(g,{content:e.$t(`hailuo.description.startImageUrl`),class:`info`},null,8,[`content`])])]),i(y,{ref:`uploader`,"file-list":e.fileList,"onUpdate:fileList":o[0]||=t=>e.fileList=t,accept:`.png,.jpg,.jpeg,.gif,.bmp,.webp`,name:`file`,"show-file-list":!0,limit:1,multiple:!1,"list-type":`picture`,action:e.uploadUrl,"on-exceed":e.onExceed,"on-error":e.onError,"on-remove":e.onRemove,"on-success":e.onSuccess,headers:e.headers},{file:f(({file:n})=>[n.url&&n.percentage!==void 0?(l(),t(_,{key:0,url:n.url,name:n.name,percentage:n.percentage,onRemove:t=>e.fileList.splice(e.fileList.indexOf(n),1)},null,8,[`url`,`name`,`percentage`,`onRemove`])):a(``,!0)]),default:f(()=>[i(v,{size:`small`,type:`primary`,class:`btn btn-upload`,round:``},{default:f(()=>[r(c(e.$t(`hailuo.button.uploadStartImageUrl`)),1)]),_:1})]),_:1},8,[`file-list`,`action`,`on-exceed`,`on-error`,`on-remove`,`on-success`,`headers`])])}var se=T(Q,[[`render`,oe],[`__scopeId`,`data-v-fbf49b06`]]),ce=o({name:`PromptInput`,components:{PromptTextarea:V},computed:{prompt:{get(){return this.$store.state.hailuo?.config?.prompt},set(e){this.$store.commit(`hailuo/setConfig`,{...this.$store.state.hailuo?.config,prompt:e})}}},mounted(){this.prompt||=``}});function le(e,n,r,i,a,o){let s=u(`prompt-textarea`);return l(),t(s,{modelValue:e.prompt,"onUpdate:modelValue":n[0]||=t=>e.prompt=t,title:e.$t(`hailuo.name.prompt`),info:e.$t(`hailuo.description.prompt`),placeholder:e.$t(`hailuo.placeholder.prompt`)},null,8,[`modelValue`,`title`,`info`,`placeholder`])}var ue=o({name:`PresetPanel`,components:{ElButton:h,FontAwesomeIcon:N,PromptInput:T(ce,[[`render`,le]]),StartImageUrlInput:se,ModelSelector:Z,Consumption:U},emits:[`generate`],computed:{config(){return this.$store.state.hailuo?.config},consumption(){return D(this.config,this.service?.cost)},service(){return this.$store.state.hailuo?.service}},methods:{onGenerate(){this.$emit(`generate`)}}}),de={class:`flex flex-col h-full`},fe={class:`flex-1 overflow-y-auto p-5`},pe={class:`flex flex-col items-center justify-center px-5 pb-5`};function me(e,o,s,p,m,h){let g=u(`prompt-input`),_=u(`model-selector`),v=u(`start-image-url-input`),y=u(`consumption`),b=u(`font-awesome-icon`),x=u(`el-button`);return l(),d(`div`,de,[n(`div`,fe,[i(g,{class:`mb-4`}),i(_,{class:`mb-4`}),e.config?.model===`minimax-i2v`?(l(),t(v,{key:0,class:`mb-2`})):a(``,!0)]),n(`div`,pe,[i(y,{value:e.consumption,service:e.service},null,8,[`value`,`service`]),e.config?.video_url!==void 0||e.config?.custom?(l(),t(x,{key:0,type:`primary`,class:`btn w-full`,round:``,onClick:e.onGenerate},{default:f(()=>[i(b,{icon:`fa-solid fa-magic`,class:`mr-2`}),r(` `+c(e.$t(`hailuo.button.extend`)),1)]),_:1},8,[`onClick`])):(l(),t(x,{key:1,type:`primary`,class:`btn w-full`,round:``,onClick:e.onGenerate},{default:f(()=>[i(b,{icon:`fa-solid fa-magic`,class:`mr-2`}),r(` `+c(e.$t(`hailuo.button.generate`)),1)]),_:1},8,[`onClick`]))])])}var he=T(ue,[[`render`,me]]),ge=o({name:`TaskPreview`,components:{ElImage:b,CopyToClipboard:P,FontAwesomeIcon:N,ElAlert:x,VideoPlayer:G,ElTooltip:y,ElButton:h,ApiCodeButton:W},props:{modelValue:{type:Object,required:!0}},computed:{application(){return this.$store.state.hailuo?.application},config(){return this.$store.state.hailuo?.config},video(){return this.modelValue?.response?.data?.[0]}},methods:{onDownload(e){console.debug(`on download hailuo video`,e),window.open(e,`_blank`)}}}),_e={class:`preview`},ve={class:`left`},ye={class:`main`},be={class:`bot`},xe={class:`datetime`},Se={class:`info`},Ce={key:0,class:`prompt mt-2`},we={key:0},Te={key:1},Ee={key:0,class:e({content:!0,failed:!0})},De={key:0,class:`mb-4`},Oe={key:1,class:e({operations:!0,"mt-2":!0})},ke={key:0,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},Ae={class:`text-[var(--el-text-color-regular)] text-xs mb-2`},je={key:1,class:`text-[var(--el-text-color-regular)] text-xs mb-0`},Me={key:1,class:e({content:!0})},Ne={class:`text-[var(--el-text-color-regular)] text-xs mb-2`},Pe={class:`text-[var(--el-text-color-regular)] text-xs mb-2`},$={key:0,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},Fe={class:`text-[var(--el-text-color-regular)] text-xs mb-0`},Ie={key:2,class:e({content:!0})},Le={class:`text-[var(--el-text-color-regular)] text-xs mb-0`};function Re(e,o,s,p,h,g){let _=u(`el-image`),v=u(`video-player`),y=u(`el-button`),b=u(`el-tooltip`),x=u(`api-code-button`),S=u(`font-awesome-icon`),C=u(`copy-to-clipboard`),w=u(`el-alert`);return l(),d(`div`,_e,[n(`div`,ve,[i(_,{src:`https://cdn.acedata.cloud/0qg4gp.png`,class:`avatar`})]),n(`div`,ye,[n(`div`,be,[r(c(e.$t(`hailuo.name.hailuoBot`))+` `,1),n(`span`,xe,c(e.$dayjs.format(``+new Date(parseFloat((e.modelValue?.created_at||``).toString())*1e3))),1)]),n(`div`,Se,[e.modelValue?.request?.prompt?(l(),d(`p`,Ce,[r(c(e.modelValue?.request?.prompt)+` `,1),e.modelValue?.response?a(``,!0):(l(),d(`span`,we,` - (`+c(e.$t(`hailuo.status.pending`))+`) `,1)),e.video?.state===`processing`||e.video?.state===`pending`||e.video?.state===`running`?(l(),d(`span`,Te,` - (`+c(e.$t(`hailuo.status.processing`))+`) `,1)):a(``,!0)])):a(``,!0)]),e.modelValue?.response?.success===!0?(l(),d(`div`,Ee,[e.video?.video_url?(l(),d(`div`,De,[i(v,{src:e.video?.video_url},null,8,[`src`])])):a(``,!0),e.video?(l(),d(`div`,Oe,[i(b,{class:`box-item`,effect:`dark`,content:e.$t(`hailuo.message.downloadVideo`),placement:`top-start`},{default:f(()=>[e.video?.video_url?(l(),t(y,{key:0,type:`info`,size:`small`,class:`mb-2`,onClick:o[0]||=m(t=>e.onDownload(e.video?.video_url),[`stop`])},{default:f(()=>[r(c(e.$t(`hailuo.button.download`)),1)]),_:1})):a(``,!0)]),_:1},8,[`content`]),i(x,{path:`/hailuo/videos`,body:e.modelValue?.request},null,8,[`body`])])):a(``,!0),i(w,{closable:!1,class:`mt-2 success`},{default:f(()=>[e.modelValue?.request?.model?(l(),d(`p`,ke,[i(S,{icon:`fa-solid fa-hashtag`,class:`mr-1`}),r(` `+c(e.$t(`hailuo.name.model`))+`: `+c(e.modelValue?.request?.model)+` `,1),i(C,{content:e.modelValue?.id},null,8,[`content`])])):a(``,!0),n(`p`,Ae,[i(S,{icon:`fa-solid fa-magic`,class:`mr-1`}),r(` `+c(e.$t(`hailuo.name.taskId`))+`: `+c(e.modelValue?.id)+` `,1),i(C,{content:e.modelValue?.id},null,8,[`content`])]),e.modelValue?.elapsed?(l(),d(`p`,je,[i(S,{icon:`fa-solid fa-clock`,class:`mr-1`}),r(` `+c(e.$t(`hailuo.name.elapsed`))+`: `+c(e.modelValue?.elapsed?.toFixed(2))+`s `,1)])):a(``,!0)]),_:1})])):a(``,!0),e.modelValue?.response?.success===!1?(l(),d(`div`,Me,[i(w,{closable:!1,class:`failure`},{template:f(()=>[i(S,{icon:`fa-solid fa-exclamation-triangle`,class:`mr-1`}),r(` `+c(e.$t(`hailuo.name.failure`)),1)]),default:f(()=>[n(`p`,Ne,[i(S,{icon:`fa-solid fa-magic`,class:`mr-1`}),r(` `+c(e.$t(`hailuo.name.taskId`))+`: `+c(e.modelValue?.id)+` `,1),i(C,{content:e.modelValue?.id},null,8,[`content`])]),n(`p`,Pe,[i(S,{icon:`fa-solid fa-circle-info`,class:`mr-1`}),r(` `+c(e.$t(`hailuo.name.failureReason`))+`: `+c(e.modelValue?.response?.error?.message)+` `,1),i(C,{content:e.modelValue?.response?.error?.message},null,8,[`content`])]),e.modelValue?.elapsed?(l(),d(`p`,$,[i(S,{icon:`fa-solid fa-clock`,class:`mr-1`}),r(` `+c(e.$t(`hailuo.name.elapsed`))+`: `+c(e.modelValue?.elapsed?.toFixed(2))+`s `,1)])):a(``,!0),n(`p`,Fe,[i(S,{icon:`fa-solid fa-hashtag`,class:`mr-1`}),r(` `+c(e.$t(`hailuo.name.traceId`))+`: `+c(e.modelValue?.response?.trace_id)+` `,1),i(C,{content:e.modelValue?.response?.trace_id},null,8,[`content`])])]),_:1})])):a(``,!0),e.modelValue?.response?.success===void 0?(l(),d(`div`,Ie,[i(w,{closable:!1,class:`info`},{template:f(()=>[i(S,{icon:`fa-solid fa-exclamation-triangle`,class:`mr-1`}),r(` `+c(e.$t(`hailuo.name.failure`)),1)]),default:f(()=>[n(`p`,Le,[i(S,{icon:`fa-solid fa-magic`,class:`mr-1`}),r(` `+c(e.$t(`hailuo.name.taskId`))+`: `+c(e.modelValue?.id)+` `,1),i(C,{content:e.modelValue?.id},null,8,[`content`])])]),_:1})])):a(``,!0)])])}var ze=o({name:`RecentPanel`,components:{TaskPreview:T(ge,[[`render`,Re],[`__scopeId`,`data-v-53d13da4`]]),BotPlaceholder:L,NoTasks:H,ScrollList:z},props:{loading:{type:Boolean,default:!1}},emits:[`reach-top`],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.hailuo?.tasks,items:this.$store.state.hailuo?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),Be={key:0},Ve={key:2,class:`w-full h-full flex items-center justify-center`};function He(e,n,r,o,c,m){let h=u(`bot-placeholder`),g=u(`task-preview`),_=u(`scroll-list`),v=u(`no-tasks`);return l(),d(p,null,[e.tasks?.items===void 0?(l(),d(`div`,Be,[i(h)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(l(),t(_,{key:1,ref:`scrollList`,class:`tasks w-full h-full overflow-y-auto`,loading:e.loading,onReachTop:n[0]||=t=>e.$emit(`reach-top`)},{default:f(()=>[(l(!0),d(p,null,s(e.tasks?.items,e=>(l(),t(g,{key:e.id,"model-value":e},null,8,[`model-value`]))),128))]),_:1},8,[`loading`])):a(``,!0),e.tasks?.items?.length===0?(l(),d(`div`,Ve,[i(v)])):a(``,!0)],64)}var Ue=T(ze,[[`render`,He]]),We=C(`hailuo`),Ge=o({name:`HailuoIndex`,components:{ConfigPanel:he,Layout:I,RecentPanel:Ue},mixins:[w],inject:[`initialized`],data(){return{task:void 0,job:0,timer:void 0,loadingMore:!1,fetchingTasks:!1}},computed:{applicationsLoading(){return this.$store.state.hailuo?.status?.getApplications===M.Request},tasksLoading(){return this.$store.state.hailuo?.status?.getTasks===M.Request||this.fetchingTasks},credential(){return this.$store.state.hailuo.credential},config(){return this.$store.state.hailuo.config},application(){return this.$store.state.hailuo.application},tasks(){return this.$store.state.hailuo.tasks}},watch:{tasks:{handler(e,t){e?.items?.length>t?.items?.length&&console.debug(`new tasks detected`)},deep:!0},initialized:{async handler(e){e&&(console.debug(`layout initialized`),await this.onGetTasks(),await this.onScrollDown(),this.job=window.setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){window.clearInterval(this.job)},methods:{async onReachTop(){await B({tasks:this.tasks,getTasks:()=>this.tasks,loading:this.loadingMore,setLoading:e=>this.loadingMore=e,isBlocked:()=>this.tasksLoading||this.applicationsLoading,fetch:e=>this.onGetTasks({createdAtMax:e}),getScrollElement:()=>this.getTasksScrollElement()})},async onGetService(){console.debug(`start onGetService`),await this.$store.dispatch(`hailuo/getService`),console.debug(`end onGetService`)},async onGetApplication(){console.debug(`start onGetApplication`),await this.$store.dispatch(`hailuo/getApplications`),console.debug(`end onGetApplication`),await this.onGetTasks()},async onScrollDown(){await this.$nextTick();let e=this.getTasksScrollElement();e&&(e.scrollTop=e.scrollHeight)},async onGetTasks(e){if(this.applicationsLoading||this.fetchingTasks){console.debug(`loading`);return}console.debug(`start onGetTasks`,e);let{limit:t=5,createdAtMin:n,createdAtMax:r}=e||{};console.debug(`limit`,t,`createdAtMin`,n,`createdAtMax`,r),this.fetchingTasks=!0;try{await this.$store.dispatch(`hailuo/getTasks`,{limit:t,createdAtMin:n,createdAtMax:r})}finally{this.fetchingTasks=!1}},async onGenerate(){if(!ee(this.uploadTracker,e=>this.$t(e),e=>A.warning(e)))return;let e={...this.config,callback_url:We},t=this.credential?.token;if(!t){console.error(`no token specified`);return}A.info(this.$t(`hailuo.message.startingTask`)),E(`hailuo`,O.generate(e,{token:t})).then(()=>{A.success(this.$t(`hailuo.message.startTaskSuccess`))}).catch(e=>{(e?.response?.data)?.error?.code===`used_up`?A.error(this.$t(`hailuo.message.usedUp`)):A.error(this.$t(`hailuo.message.startTaskFailed`))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function Ke(e,n,r,a,o,s){let c=u(`config-panel`),d=u(`recent-panel`),p=u(`layout`);return l(),t(p,null,{config:f(()=>[i(c,{onGenerate:e.onGenerate},null,8,[`onGenerate`])]),result:f(()=>[i(d,{ref:`recentPanel`,loading:e.loadingMore,onReachTop:e.onReachTop},null,8,[`loading`,`onReachTop`])]),_:1})}var qe=T(Ge,[[`render`,Ke]]);export{qe as default};