@acedatacloud/nexior 3.276.2 → 3.276.3
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.
- package/dist/assets/{ApiCodeButton-C8TdRvY9.js → ApiCodeButton-DpYCu-EK.js} +1 -1
- package/dist/assets/{AskUserQuestionCard-jb8bzPLa.js → AskUserQuestionCard-CFwxSrmZ.js} +1 -1
- package/dist/assets/{Auth-CevT-APY.js → Auth-7LLt4q3p.js} +1 -1
- package/dist/assets/{Bare-B1hu6q7Z.js → Bare-JAoG6sFQ.js} +1 -1
- package/dist/assets/{BotPlaceholder-DzIzZltA.js → BotPlaceholder-BVXWzbpi.js} +1 -1
- package/dist/assets/{BottomFooter-BIZMLZ5i.js → BottomFooter-BTcNTyiV.js} +1 -1
- package/dist/assets/{Callback-BnArHSvk.js → Callback-CW861dqy.js} +1 -1
- package/dist/assets/{Console-BqpoQ6Rt.js → Console-BOxYP152.js} +1 -1
- package/dist/assets/{Consumption-DLzGFeUT.js → Consumption-QfvilMcG.js} +1 -1
- package/dist/assets/{Conversation-BPaCX6gr.js → Conversation-C1Jb8AgW.js} +1 -1
- package/dist/assets/{CopyToClipboard-LZRed5aB.js → CopyToClipboard-C8gyDUMn.js} +1 -1
- package/dist/assets/{Detail-CnZ-bcZY.js → Detail-BMuX9lMp.js} +2 -2
- package/dist/assets/{Extra-D6o35zFO.js → Extra-BshQjZAE.js} +1 -1
- package/dist/assets/{FilePreview-Dj6VOjhF.js → FilePreview-sx756NB5.js} +1 -1
- package/dist/assets/{Hailuo-C2eHP_WO.js → Hailuo-y5ZOpsGB.js} +1 -1
- package/dist/assets/{History-BUdtyskA.js → History-CBejCufL.js} +1 -1
- package/dist/assets/{ImagePreview-B2FwyzyM.js → ImagePreview-DkXTeOKK.js} +1 -1
- package/dist/assets/{ImageWrapper-_6c4eeKK.js → ImageWrapper-3eqDS8_u.js} +1 -1
- package/dist/assets/{Index-BoG5tSrk.js → Index-05qa1gOC.js} +1 -1
- package/dist/assets/{Index-DgPyFPeb.js → Index-B8H2_z9_.js} +1 -1
- package/dist/assets/{Index-CECIU01b.js → Index-B9wup2zp.js} +1 -1
- package/dist/assets/{Index-C6amW6vz.js → Index-BCYh1z7D.js} +1 -1
- package/dist/assets/{Index-EpovLoMr.js → Index-BJ5FlOXw.js} +1 -1
- package/dist/assets/{Index-C9iJDxXm.js → Index-BJFLDUCM.js} +1 -1
- package/dist/assets/{Index-Dz4NPEQR.js → Index-BRWua7Pn.js} +1 -1
- package/dist/assets/{Index-BPbDPB0M.js → Index-BS_kWluw.js} +1 -1
- package/dist/assets/{Index-rG7e6yXk.js → Index-Be7Y4LIt.js} +1 -1
- package/dist/assets/{Index-CAAN1-_p.js → Index-Bi4e1Cno.js} +1 -1
- package/dist/assets/{Index-DIAtAXGz.js → Index-CEt4sPAp.js} +1 -1
- package/dist/assets/{Index-F3vpxi6E.js → Index-CKtL81ue.js} +1 -1
- package/dist/assets/{Index-BRMiltIw.js → Index-CLgbPHLC.js} +1 -1
- package/dist/assets/{Index-DXBSOAj0.js → Index-CpdPDUM5.js} +1 -1
- package/dist/assets/{Index-hX7fovd_.js → Index-D1ObDODx.js} +1 -1
- package/dist/assets/{Index-BqLQt-5m.js → Index-DREci_3x.js} +1 -1
- package/dist/assets/{Index-rQFLYHuV.js → Index-DbNh8zrA.js} +1 -1
- package/dist/assets/{Index-CD1M-uJN.js → Index-Di-zu-p8.js} +1 -1
- package/dist/assets/{Index-CUKPMLC-.js → Index-DlZMH8SN.js} +1 -1
- package/dist/assets/{Index-Cu81R2TY.js → Index-DuiQE6-J.js} +1 -1
- package/dist/assets/{Index-CkITI13f.js → Index-N6d4HE9o.js} +1 -1
- package/dist/assets/{Index-CZKWwYGB.js → Index-VyvPGs_5.js} +1 -1
- package/dist/assets/{Index-CzZR-m2_.js → Index-d635oMC0.js} +1 -1
- package/dist/assets/{Index-Bbr9Hgc0.js → Index-irgLZ7_Q.js} +1 -1
- package/dist/assets/{Index-BzP5ATX6.js → Index-twlRmX4y.js} +1 -1
- package/dist/assets/{Index-Bm2glD67.js → Index-vDMn1c6V.js} +1 -1
- package/dist/assets/{Invitees-BifLqHGu.js → Invitees-C0R3g-Zf.js} +1 -1
- package/dist/assets/{List-CIOMae5H.js → List-D6nFAmNC.js} +1 -1
- package/dist/assets/{List-Br93CnR9.js → List-DWwcbcPH.js} +1 -1
- package/dist/assets/{List-CMDhlz5R.js → List-DiYo0Int.js} +1 -1
- package/dist/assets/{Main-NAvdrrX0.js → Main-DXUAcE9k.js} +1 -1
- package/dist/assets/{Model-BUjfzCpS.js → Model-CqYI1sS8.js} +1 -1
- package/dist/assets/{Navigator-ym7KWo_7.js → Navigator-C2kRAciX.js} +1 -1
- package/dist/assets/{NoTasks-Bk9F1-iz.js → NoTasks-Dk1WXppl.js} +1 -1
- package/dist/assets/{NotFound-m9TVl0hk.js → NotFound-Bqzv83rR.js} +1 -1
- package/dist/assets/{Pagination-ZFaMc_mv.js → Pagination-DYjyzEjF.js} +1 -1
- package/dist/assets/{Pay-DD8YE5fV.js → Pay-DKdYx4a8.js} +1 -1
- package/dist/assets/{Player-CTNTmM4y.js → Player-5nZKlwHx.js} +1 -1
- package/dist/assets/{Seedance-VRmh5uYq.js → Seedance-CNYLui9X.js} +1 -1
- package/dist/assets/{Status-DvNWBZrq.js → Status-Dx6FNAbD.js} +1 -1
- package/dist/assets/{Subscribe-CgnDdnH3.js → Subscribe-Q4ATea2Y.js} +1 -1
- package/dist/assets/{TabSwitcher-BI7dOxCK.js → TabSwitcher-BRab7qRM.js} +1 -1
- package/dist/assets/{Tts-DX6zLgZp.js → Tts-DegoQTKa.js} +1 -1
- package/dist/assets/{VideoPlayer--5snxkv4.js → VideoPlayer-BLPGe-uP.js} +1 -1
- package/dist/assets/{avatar-DoKzF3gM.js → avatar-TKtEO4Yl.js} +1 -1
- package/dist/assets/{basic-BrTbjgdS.js → basic-Db4GCedU.js} +1 -1
- package/dist/assets/{chat-C8jjNDSm.js → chat-C6NbygCS.js} +1 -1
- package/dist/assets/codingBridge-Df_5ydBi.js +2 -0
- package/dist/assets/{codingBridgeNotify-B3rz48kE.js → codingBridgeNotify-4sUlZ3Lg.js} +2 -2
- package/dist/assets/{collapse-Ds9keFcU.js → collapse-BH0qROl8.js} +1 -1
- package/dist/assets/{createTaskActions-_LT4UGX1.js → createTaskActions-xgaPM_qk.js} +1 -1
- package/dist/assets/{date-picker-ye73-4_d.js → date-picker-DnWtfIDn.js} +1 -1
- package/dist/assets/{dropdown-ByGJfhDP.js → dropdown-BpL2qpyg.js} +1 -1
- package/dist/assets/{esm-DJ62h-fH.js → esm-D7H9sAYC.js} +3 -3
- package/dist/assets/{esm-BvAIkUfu.js → esm-D8MgG7kP.js} +1 -1
- package/dist/assets/{esm-L7PMWDOK.js → esm-DRVKxMaD.js} +2 -2
- package/dist/assets/esm-I-Ydzkdh.js +1 -0
- package/dist/assets/{esm-C2P77e7r.js → esm-SCvm8sjU.js} +2 -2
- package/dist/assets/{esm-UykDnDSA.js → esm-y0EduL6s.js} +1 -1
- package/dist/assets/{esm-BgbAZhOw.js → esm-yeJT_40P.js} +1 -1
- package/dist/assets/{fish-5YNJOUMS.js → fish-C13ospyo.js} +1 -1
- package/dist/assets/{flux-D8BMfN_b.js → flux-CuTQgrEI.js} +1 -1
- package/dist/assets/{grokvideo-DAEDe2lC.js → grokvideo-Cxkcup4s.js} +1 -1
- package/dist/assets/{hailuo-Ep2afX61.js → hailuo-ld7fCVPo.js} +1 -1
- package/dist/assets/{headshots-moxuhQ8q.js → headshots-BmUEgkoj.js} +1 -1
- package/dist/assets/{image-CUt2yKJT.js → image-CjzS-up0.js} +1 -1
- package/dist/assets/{index-Dzx62HWL.js → index-BY8YIwDb.js} +3 -3
- package/dist/assets/{index.browser.esm-DtVKnbsq.js → index.browser.esm-li52u8xd.js} +1 -1
- package/dist/assets/{index.es-BIezN10l.js → index.es-CH5vwGaN.js} +1 -1
- package/dist/assets/{input-number-CXFB1_xE.js → input-number-N0auilju.js} +1 -1
- package/dist/assets/{kling-C0C920Il.js → kling-COeQELLT.js} +1 -1
- package/dist/assets/{luma-btnACTNr.js → luma-sQSQhtbj.js} +1 -1
- package/dist/assets/{midjourney-CnVJEo9h.js → midjourney-CTQ-KItL.js} +1 -1
- package/dist/assets/{nanobanana-uQnyuVgy.js → nanobanana-C22a0oYN.js} +1 -1
- package/dist/assets/{openaiimage-B4szqKdR.js → openaiimage-Dq7MWBVX.js} +1 -1
- package/dist/assets/{pagination-t1m3PdtM.js → pagination-CjEVtILV.js} +1 -1
- package/dist/assets/{pika-B6ZkmISK.js → pika-DU0QitGG.js} +1 -1
- package/dist/assets/{pixverse-CMewIDDG.js → pixverse-C-xOT5MG.js} +1 -1
- package/dist/assets/{popover-Dggo6GYh.js → popover-1vWQQB0V.js} +1 -1
- package/dist/assets/{producer-CLqQs_Oy.js → producer-BGA_s87O.js} +1 -1
- package/dist/assets/{qrart-cUqnnNos.js → qrart-tF6e5Ure.js} +1 -1
- package/dist/assets/{row-Dpgq35ln.js → row-JqIo0dw3.js} +1 -1
- package/dist/assets/{seedance-iA_B79lT.js → seedance-CPhZgXeS.js} +1 -1
- package/dist/assets/{seedream-DSZGr5VZ.js → seedream-DueKINO1.js} +1 -1
- package/dist/assets/{select-Byt7Qw1F.js → select-B14L-681.js} +1 -1
- package/dist/assets/{serp-BML2l1cV.js → serp-DKsD2P4f.js} +1 -1
- package/dist/assets/{slider-Chudll8H.js → slider-ypi7YrnL.js} +1 -1
- package/dist/assets/{solana-wallets-DHdSmT1K.js → solana-wallets-B-Ar3QV5.js} +2 -2
- package/dist/assets/{solana-wallets-vue-F4mtRLNf.js → solana-wallets-vue-BxEXL9wo.js} +1 -1
- package/dist/assets/{sora-DBuX8eeJ.js → sora-Bvuj-CwF.js} +1 -1
- package/dist/assets/{suno-BnJ56a_f.js → suno-DBUXJjOG.js} +1 -1
- package/dist/assets/{switch-CqHzcX_8.js → switch-Dir3SgN_.js} +1 -1
- package/dist/assets/{tabs-DZcdINxf.js → tabs-CllsgUVI.js} +1 -1
- package/dist/assets/{upload-CDJi96y4.js → upload-CgRMUkQi.js} +1 -1
- package/dist/assets/{veo-Di_xCBIf.js → veo-DJcppRgO.js} +1 -1
- package/dist/assets/{wan-DChv5HaI.js → wan-CXX5Z70L.js} +1 -1
- package/dist/assets/{web-BlcKxuW2.js → web-AJVUYB9i.js} +1 -1
- package/dist/assets/{web-CKMhgTwv.js → web-B9iHXzqN.js} +1 -1
- package/dist/assets/{web-Hdenr60p.js → web-Bgfp9ZAB.js} +1 -1
- package/dist/assets/{web-CXAG0ZQx.js → web-Cr9qE3HH.js} +1 -1
- package/dist/assets/{web-CmEs3R8h.js → web-jBZ5VzL9.js} +1 -1
- package/dist/assets/{webextrator-CzvKAcAC.js → webextrator-CXlTr4A9.js} +1 -1
- package/dist/index.html +1 -1
- package/package.json +1 -1
- package/dist/assets/codingBridge-oM7Uohq5.js +0 -2
- package/dist/assets/esm-cc-LpyGe.js +0 -1
|
@@ -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-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};
|
|
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-B14L-681.js";import{t as v}from"./upload-CgRMUkQi.js";import{t as y}from"./tooltip-C3PYfh8V.js";import{t as b}from"./image-CjzS-up0.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-BY8YIwDb.js";import{t as N}from"./index.es-CH5vwGaN.js";import{t as P}from"./CopyToClipboard-C8gyDUMn.js";import{t as F}from"./ImagePreview-DkXTeOKK.js";import{t as I}from"./Hailuo-y5ZOpsGB.js";import{t as L}from"./BotPlaceholder-BVXWzbpi.js";import{i as R,n as z,t as B}from"./pagination-CjEVtILV.js";import{n as V,t as H}from"./NoTasks-Dk1WXppl.js";import{t as U}from"./Consumption-QfvilMcG.js";import{t as W}from"./ApiCodeButton-DpYCu-EK.js";import{t as G}from"./VideoPlayer-BLPGe-uP.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 +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
|
+
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-CgRMUkQi.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-BpL2qpyg.js";import{t as T}from"./popover-1vWQQB0V.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-BY8YIwDb.js";import"./vendor-highlight-BtIeKitL.js";import{t as I}from"./index.es-CH5vwGaN.js";import{t as ee}from"./CopyToClipboard-C8gyDUMn.js";import{n as te,t as ne}from"./AskUserQuestionCard-CFwxSrmZ.js";import{s as re,t as ie}from"./codingBridgeNotify-4sUlZ3Lg.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{D as e,E as t,N as n,P as r,Ut as i,X as a,et as o,lt as s,tt as c,ut as l}from"./vendor-chart-mdwpew_o.js";import{n as u,t as d}from"./table-fY8LUehs.js";import{t as f}from"./card-B1OoUKT4.js";import{n as p,t as m}from"./row-
|
|
1
|
+
import"./rolldown-runtime--c01j_DQ.js";import{D as e,E as t,N as n,P as r,Ut as i,X as a,et as o,lt as s,tt as c,ut as l}from"./vendor-chart-mdwpew_o.js";import{n as u,t as d}from"./table-fY8LUehs.js";import{t as f}from"./card-B1OoUKT4.js";import{n as p,t as m}from"./row-JqIo0dw3.js";import{t as h}from"./Pagination-DYjyzEjF.js";import{E as g,kn as _}from"./index-BY8YIwDb.js";import{t as v}from"./CopyToClipboard-C8gyDUMn.js";var y=r({name:`ConsoleDistributionInvitees`,components:{Pagination:h,CopyToClipboard:v,ElRow:m,ElCol:p,ElTable:d,ElTableColumn:u,ElCard:f},data(){return{invitees:[],loading:!1,total:void 0,limit:10}},computed:{redirect(){return this.$route.query.redirect},page(){return parseInt(this.$route.query.page?.toString()||`1`)}},watch:{page:{handler(){this.onFetchData()}}},mounted(){this.onFetchData()},methods:{onPageChange(e){this.$router.push({name:this.$route.name?.toString(),query:{page:e}})},onFetchData(){this.loading=!0,Promise.all([this.onFetchInvitees()]).finally(()=>{this.loading=!1})},async onFetchInvitees(){let{data:e}=await _.getInvitees({limit:this.limit,offset:(this.page-1)*this.limit,ordering:`-created_at`});this.invitees=e.items,this.total=e.count}}}),b={class:`title`},x={class:`key`},S={class:`copy`},C={class:`description`},w={class:`description`},T={class:`description`},E={class:`created-at`},D={class:`pagination m-v-lg`};function O(r,u,d,f,p,m){let h=o(`el-col`),g=o(`el-row`),_=o(`copy-to-clipboard`),v=o(`el-table-column`),y=o(`el-table`),O=o(`el-card`),k=o(`pagination`),A=c(`loading`);return a(),e(g,{class:`panel`},{default:s(()=>[n(h,{span:24},{default:s(()=>[n(g,null,{default:s(()=>[n(h,{span:24},{default:s(()=>[t(`h2`,b,i(r.$t(`common.title.invitee`)),1)]),_:1})]),_:1}),n(g,null,{default:s(()=>[n(h,{span:24},{default:s(()=>[n(O,{shadow:`hover`},{default:s(()=>[l((a(),e(y,{data:r.invitees,stripe:``},{default:s(()=>[n(v,{prop:`id`,label:r.$t(`user.field.id`),"class-name":`text-center`,width:`350px`},{default:s(e=>[t(`span`,x,i(e.row.id),1),t(`span`,S,[n(_,{content:e.row.id},null,8,[`content`])])]),_:1},8,[`label`]),n(v,{label:r.$t(`user.field.username`),width:`300px`},{default:s(e=>[t(`span`,C,i(e.row?.username),1)]),_:1},8,[`label`]),n(v,{label:r.$t(`user.field.email`),width:`300px`},{default:s(e=>[t(`span`,w,i(e.row?.email),1)]),_:1},8,[`label`]),n(v,{label:r.$t(`user.field.nickname`),width:`200px`},{default:s(e=>[t(`span`,T,i(e.row.nickname),1)]),_:1},8,[`label`]),n(v,{label:r.$t(`user.field.dateJoined`)},{default:s(e=>[t(`span`,E,i(r.$dayjs.format(e.row.date_joined)),1)]),_:1},8,[`label`])]),_:1},8,[`data`])),[[A,r.loading]])]),_:1})]),_:1})]),_:1}),n(g,null,{default:s(()=>[n(h,{span:10,offset:14},{default:s(()=>[t(`div`,D,[n(k,{"current-page":r.page,"page-size":r.limit,total:r.total,onChange:r.onPageChange},null,8,[`current-page`,`page-size`,`total`,`onChange`])])]),_:1})]),_:1})]),_:1})]),_:1})}var k=g(y,[[`render`,O],[`__scopeId`,`data-v-4556864d`]]);export{k as default};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import"./rolldown-runtime--c01j_DQ.js";import{D as e,E as t,M as n,N as r,O as i,P as a,Q as o,Ut as s,X as c,_ as l,a as u,c as d,et as f,i as ee,k as p,lt as m,n as h,o as g,r as _,s as v,t as y,tt as b,ut as x,x as S}from"./vendor-chart-mdwpew_o.js";import{t as C}from"./button-DWzbdjZV.js";import{r as w,t as T}from"./select-Byt7Qw1F.js";import{n as E,t as D}from"./table-fY8LUehs.js";import{n as O,t as k}from"./tabs-DZcdINxf.js";import{t as A}from"./date-picker-ye73-4_d.js";import{t as j}from"./card-B1OoUKT4.js";import{n as M,r as N}from"./radio-IJQsW93X.js";import{n as P,t as F}from"./row-Dpgq35ln.js";import{t as I}from"./Pagination-ZFaMc_mv.js";import{n as L,t as R}from"./skeleton-Cn4UY-T8.js";import{An as z,E as B,En as V,Mr as H,Pr as U,Tn as W,_r as G,lr as K,ur as q,wn as J}from"./index-Dzx62HWL.js";import{t as Y}from"./index.es-BIezN10l.js";import{t as X}from"./CopyToClipboard-LZRed5aB.js";ee.register(_,u,h,v,d,g);var Z=a({name:`ConsoleUsageList`,components:{Pagination:I,ElTag:U,ElDatePicker:A,ElTable:D,ElSelect:w,ElOption:T,CopyToClipboard:X,ElRow:F,ElCol:P,ElTableColumn:E,ElCard:j,ElRadioButton:M,ElRadioGroup:N,ElSkeleton:R,ElSkeletonItem:L,ElDialog:H,ElTabs:O,ElTabPane:k,ElButton:C,FontAwesomeIcon:Y,BarChart:y},data(){return{applicationIds:this.$route.query.application_id?.toString()?this.$route.query.application_id?.toString().split(`,`):[],apiIds:this.$route.query.api_id?.toString()?this.$route.query.api_id?.toString().split(`,`):[],applications:[],apis:[],apisLoading:!1,credentialType:K,serviceType:q,apiUsages:[],proxyUsages:[],createdAtRange:(()=>{let e=this.$route.query.created_at_to?.toString(),t=this.$route.query.created_at_from?.toString();if(t&&e)return[new Date(t),new Date(e)];let n=new Date,r=new Date;return r.setDate(1),r.setHours(0,0,0,0),[r,n]})(),shortcuts:[{text:this.$t(`usage.shortcuts.thisMonth`),value:()=>{let e=new Date,t=new Date;return t.setDate(1),t.setHours(0,0,0,0),[t,e]}},{text:this.$t(`usage.shortcuts.today`),value:()=>{let e=new Date,t=new Date;return t.setHours(0,0,0,0),[t,e]}},{text:this.$t(`usage.shortcuts.last1Day`),value:()=>{let e=new Date,t=new Date;return t.setDate(t.getDate()-1),[t,e]}},{text:this.$t(`usage.shortcuts.last3Days`),value:()=>{let e=new Date,t=new Date;return t.setDate(t.getDate()-3),[t,e]}},{text:this.$t(`usage.shortcuts.last7Days`),value:()=>{let e=new Date,t=new Date;return t.setDate(t.getDate()-7),[t,e]}},{text:this.$t(`usage.shortcuts.last1Month`),value:()=>{let e=new Date,t=new Date;return t.setMonth(t.getMonth()-1),[t,e]}}],type:this.$route.query.type?.toString()||q.API,loading:!1,total:void 0,limit:15,totalUsed:0,barChartLabels:[],barChartSeries:[],aggLoading:!1,detailDialogVisible:!1,detailRow:null,detailActiveTab:`request`,detailLoading:!1,exporting:!1,statusCodeFilter:this.$route.query.status_code?.toString()||``,statusCodeOptions:[],statusCodeOptionsLoading:!1}},computed:{redirect(){return this.$route.query?.redirect},page(){return parseInt(this.$route.query.page?.toString()||`1`)},totalUsedString(){return`${(this.totalUsed||0).toFixed(2)}`},barChartData(){return{labels:this.barChartLabels,datasets:this.barChartSeries.map(e=>({label:e.label,data:e.data,backgroundColor:e.color}))}},barChartOptions(){return{responsive:!0,plugins:{legend:{position:`top`,onClick:(e,t,n)=>{let r=n?.chart;if(!r||t?.datasetIndex===void 0)return;let i=t.datasetIndex,a=r.data?.datasets||[];a.some((e,t)=>t!==i&&r.isDatasetVisible(t))?a.forEach((e,t)=>r.setDatasetVisibility(t,t===i)):a.forEach((e,t)=>r.setDatasetVisibility(t,!0)),r.update()}},title:{display:!0,text:this.$t(`usage.title.usageTrend`)}},scales:{x:{stacked:!0},y:{stacked:!0,beginAtZero:!0}}}}},watch:{page:{handler(){this.onFetchUsages()}},type:{handler(){this.applicationIds=[],this.apiIds=[],this.onApplicationsChange(this.applicationIds),this.onFetchApplications(),this.onFetchApis(),this.onFetchUsages(),this.onFetchAggregate(),this.onFetchStatusCodeOptions()}}},mounted(){this.onFetchApplications(),this.onFetchApis(),this.onFetchUsages(),this.onFetchAggregate(),this.onFetchStatusCodeOptions()},methods:{async onFetchUsages(){this.type===q.API?this.onFetchApiUsages():this.type===q.Proxy&&this.onFetchProxyUsages()},async onApiChange(e){await this.$router.push({name:this.$route.name?.toString(),query:{...this.$route.query,api_id:e}}),this.onFetchApiUsages(),this.onFetchAggregate()},async onApisChange(e){await this.$router.push({name:this.$route.name?.toString(),query:{...this.$route.query,api_id:e&&e.length?e.join(`,`):``}}),this.onFetchApiUsages(),this.onFetchAggregate()},async onTimeRangeChanged(){console.log(`onTimeRangeChanged`,this.createdAtRange),await this.$router.push({name:this.$route.name?.toString(),query:{...this.$route.query,created_at_from:this.createdAtRange?this.$dayjs.format(this.createdAtRange[0].toString(),`YYYY-MM-DDTHH:mm:ss.SSSSSSZ`):``,created_at_to:this.createdAtRange?this.$dayjs.format(this.createdAtRange[1].toString(),`YYYY-MM-DDTHH:mm:ss.SSSSSSZ`):``}}),this.onFetchUsages(),this.onFetchAggregate(),this.onFetchStatusCodeOptions()},async onApplicationChange(e){await this.$router.push({name:this.$route.name?.toString(),query:{...this.$route.query,application_id:e}}),this.onFetchUsages(),this.onFetchAggregate()},async onApplicationsChange(e){await this.$router.push({name:this.$route.name?.toString(),query:{...this.$route.query,application_id:e&&e.length?e.join(`,`):``}}),this.onFetchUsages(),this.onFetchAggregate()},onPageChange(e){this.$router.push({name:this.$route.name?.toString(),query:{...this.$route.query,page:e}})},getRemainingAmount(e){if(e.remaining_amount===void 0||e.remaining_amount===null)return``;let t=this.$t(`service.unit.${e?.service?.unit||`credit`}s`);return`${e.remaining_amount?.toFixed(6)} ${t}`},getUsedAmount(e){if(e.used_amount===void 0||e.used_amount===null)return``;let t=this.$t(`service.unit.${e?.service?.unit||`credit`}s`);return`${e.used_amount?.toFixed(6)} ${t}`},getDeductedAmount(e){if(e?.deducted_amount===void 0||e?.deducted_amount===null)return``;let t=this.$t(`service.unit.${e?.service?.unit||`credit`}s`);return`${e.deducted_amount?.toFixed(6)} ${t}`},getOriginalAmount(e){if(e?.original_amount===void 0||e?.original_amount===null)return``;let t=this.$t(`service.unit.${e?.service?.unit||`credit`}s`);return`${e.original_amount?.toFixed(6)} ${t}`},onStatusCodeChange(e){let t={...this.$route.query},n=(e||``).trim();n?t.status_code=n:delete t.status_code,delete t.status_code_filter,this.$router.push({name:this.$route.name?.toString(),query:t}),this.onFetchUsages(),this.onFetchAggregate()},async onFetchStatusCodeOptions(){this.statusCodeOptionsLoading=!0;try{let{data:e}=await W.getStatusCodes({user_id:this.$store.getters.user.id,...this.applicationIds&&this.applicationIds.length?{application_id:this.applicationIds}:{},...this.apiIds&&this.apiIds.length?{api_id:this.apiIds}:{},...this.createdAtRange?.[0]?{created_at_from:this.createdAtRange[0]}:{},...this.createdAtRange?.[1]?{created_at_to:this.createdAtRange[1]}:{}});this.statusCodeOptions=(e?.items||[]).slice().sort((e,t)=>e-t)}catch{this.statusCodeOptions=[]}finally{this.statusCodeOptionsLoading=!1}},formatElapsed(e){return e==null||Number.isNaN(e)?`-`:e<1?`${Math.round(e*1e3)} ms`:`${e.toFixed(2)} s`},getSimpleMetadata(e){if(!e)return{};let t={};for(let[n,r]of Object.entries(e))n===`request`||n===`response`||typeof r==`object`&&r||(t[n]=r);return t},onShowDetail(e){this.detailRow={...e,metadata:void 0},this.detailActiveTab=`request`,this.detailDialogVisible=!0,this.detailLoading=!0,e.id&&W.get(e.id).then(e=>{this.detailRow=e.data}).finally(()=>{this.detailLoading=!1})},formatJson(e){try{return JSON.stringify(e,null,2)}catch{return String(e)}},onFetchApplications(){z.getAll({limit:100,offset:0,user_id:this.$store.getters.user.id,ordering:`-created_at`,type:G.USAGE}).then(({data:e})=>{this.applications=e.items.filter(e=>e?.service?.type===this.type)}).catch(()=>{})},onFetchApis(){this.apisLoading=!0,J.getAll({limit:100,offset:0,ordering:`-created_at`}).then(({data:e})=>{this.apis=e.items}).catch(()=>{}).finally(()=>{this.apisLoading=!1})},onFetchApiUsages(){console.log(`onFetchApiUsages`,this.createdAtRange),this.loading=!0,W.getAll({limit:this.limit,offset:(this.page-1)*this.limit,user_id:this.$store.getters.user.id,ordering:`-created_at`,...this.createdAtRange?.[0]?{created_at_from:this.createdAtRange[0]}:{},...this.createdAtRange?.[1]?{created_at_to:this.createdAtRange[1]}:{},...this.applicationIds&&this.applicationIds.length?{application_id:this.applicationIds}:{},...this.apiIds&&this.apiIds.length?{api_id:this.apiIds}:{},...this.statusCodeFilter?{status_code:this.statusCodeFilter}:{}}).then(({data:e})=>{this.apiUsages=e.items,this.loading=!1,this.total=e.count}).catch(()=>{this.loading=!1})},onFetchProxyUsages(){this.loading=!0,V.getAll({limit:this.limit,offset:(this.page-1)*this.limit,user_id:this.$store.getters.user.id,ordering:`-created_at`,...this.applicationIds&&this.applicationIds.length?{application_id:this.applicationIds}:{}}).then(({data:e})=>{this.proxyUsages=e.items,this.loading=!1,this.total=e.count}).catch(()=>{this.loading=!1})},onExport(){this.exporting=!0,W.exportCsv({user_id:this.$store.getters.user.id,...this.createdAtRange?.[0]?{created_at_from:this.createdAtRange[0]}:{},...this.createdAtRange?.[1]?{created_at_to:this.createdAtRange[1]}:{},...this.applicationIds&&this.applicationIds.length?{application_id:this.applicationIds}:{},...this.apiIds&&this.apiIds.length?{api_id:this.apiIds}:{},...this.statusCodeFilter?{status_code:this.statusCodeFilter}:{}}).then(({data:e})=>{let t=window.URL.createObjectURL(e),n=document.createElement(`a`);n.href=t,n.download=`usages.csv`,n.click(),window.URL.revokeObjectURL(t)}).catch(()=>{}).finally(()=>{this.exporting=!1})},async onFetchAggregate(){if(this.aggLoading=!0,this.type!==this.serviceType.API)return;let e={user_id:this.$store.getters.user.id,...this.applicationIds&&this.applicationIds.length?{application_id:this.applicationIds}:{},...this.apiIds&&this.apiIds.length?{api_id:this.apiIds}:{},...this.createdAtRange?.[0]?{created_at_from:this.createdAtRange[0]}:{},...this.createdAtRange?.[1]?{created_at_to:this.createdAtRange[1]}:{}};try{let{data:t}=await W.getAggregate(e);this.totalUsed=t.total||0;let n=Array.from(new Set((t.items||[]).map(e=>e.date))).sort(),r=Array.from(new Set((t.items||[]).map(e=>e.api_id))),i=e=>`hsl(${e*57%360}, 70%, 60%)`,a=r.map((e,r)=>{let a=t.apis?.[e]?.title||e,o={};return(t.items||[]).filter(t=>t.api_id===e).forEach(e=>{o[e.date]=e.amount||0}),{key:e,label:a,data:n.map(e=>o[e]||0),color:i(r)}});this.barChartLabels=n,this.barChartSeries=a}finally{this.aggLoading=!1}}}}),Q={class:`text-[26px] font-bold mb-5 text-[var(--el-text-color-primary)]`},$={class:`inline-block w-9`},te={class:`inline-block`},ne={key:1,class:`summary-card`},re={class:`icon-wrapper`},ie={class:`text-left`},ae={class:`description`},oe={class:`value`},se={class:`chart-wrapper`},ce={key:0},le={key:1},ue={class:`flex flex-wrap gap-2`},de={class:`key`},fe={key:0,class:`cursor-pointer`},pe={class:`created-at`},me={class:`created-at`},he={key:1,class:`detail-json`},ge={key:2,class:`text-gray-400`},_e={key:1,class:`detail-json`},ve={key:2,class:`text-gray-400`},ye={class:`float-right`};function be(a,u,d,ee,h,g){let _=f(`el-col`),v=f(`el-row`),y=f(`el-radio-button`),C=f(`el-radio-group`),w=f(`el-option`),T=f(`el-select`),E=f(`el-skeleton-item`),D=f(`el-skeleton`),O=f(`el-date-picker`),k=f(`font-awesome-icon`),A=f(`el-button`),j=f(`el-card`),M=f(`bar-chart`),N=f(`el-table-column`),P=f(`el-tag`),F=f(`copy-to-clipboard`),I=f(`el-table`),L=f(`el-tab-pane`),R=f(`el-tabs`),z=f(`el-dialog`),B=f(`pagination`),V=b(`loading`);return c(),e(v,null,{default:m(()=>[r(_,{span:24},{default:m(()=>[r(v,null,{default:m(()=>[r(_,{span:24},{default:m(()=>[t(`h2`,Q,s(a.$t(`common.title.allUsages`)),1)]),_:1})]),_:1}),r(v,null,{default:m(()=>[r(_,{md:4,xs:24,class:`mb-5 flex px-2 gap-2 items-center`},{default:m(()=>[t(`span`,null,s(a.$t(`application.field.type`)),1),r(C,{modelValue:a.type,"onUpdate:modelValue":u[0]||=e=>a.type=e},{default:m(()=>[r(y,{value:a.serviceType.API,label:a.$t(`application.field.api`)},null,8,[`value`,`label`]),r(y,{value:a.serviceType.Proxy,label:a.$t(`application.field.proxy`)},null,8,[`value`,`label`])]),_:1},8,[`modelValue`])]),_:1}),x(r(_,{md:6,xs:24,class:`mb-5 flex px-2 gap-2 items-center`},{default:m(()=>[t(`span`,$,s(a.$t(`usage.field.application`)),1),r(T,{modelValue:a.applicationIds,"onUpdate:modelValue":u[1]||=e=>a.applicationIds=e,placeholder:a.$t(`usage.field.application`),clearable:``,multiple:``,"collapse-tags":``,"collapse-tags-tooltip":``,class:`w-full`,onChange:a.onApplicationsChange},{default:m(()=>[(c(!0),p(S,null,o(a.applications,t=>(c(),e(w,{key:t.id,label:t.service?.title,value:t?.id},null,8,[`label`,`value`]))),128))]),_:1},8,[`modelValue`,`placeholder`,`onChange`])]),_:1},512),[[l,!1]]),a.type===a.serviceType.API?(c(),e(_,{key:0,md:6,xs:24,class:`mb-5 flex px-2 gap-2 items-center`},{default:m(()=>[t(`span`,te,s(a.$t(`usage.field.api`)),1),a.apisLoading?(c(),e(D,{key:0,animated:``,class:`w-full`},{template:m(()=>[r(E,{variant:`rect`,style:{height:`32px`,"border-radius":`4px`}})]),_:1})):(c(),e(T,{key:1,modelValue:a.apiIds,"onUpdate:modelValue":u[2]||=e=>a.apiIds=e,placeholder:a.$t(`usage.field.api`),clearable:``,filterable:``,multiple:``,"collapse-tags":``,"collapse-tags-tooltip":``,class:`w-full`,onChange:a.onApisChange},{default:m(()=>[(c(!0),p(S,null,o(a.apis,t=>(c(),e(w,{key:t?.id,label:t?.title,value:t?.id},null,8,[`label`,`value`]))),128))]),_:1},8,[`modelValue`,`placeholder`,`onChange`]))]),_:1})):i(``,!0),a.type===a.serviceType.API?(c(),e(_,{key:1,md:8,xs:24,class:`mb-5 flex px-2 gap-2 items-center`},{default:m(()=>[r(O,{modelValue:a.createdAtRange,"onUpdate:modelValue":u[3]||=e=>a.createdAtRange=e,type:`datetimerange`,class:`w-full`,shortcuts:a.shortcuts,"range-separator":a.$t(`usage.placeholder.to`),"start-placeholder":a.$t(`usage.placeholder.startDate`),"end-placeholder":a.$t(`usage.placeholder.endDate`),onChange:a.onTimeRangeChanged},null,8,[`modelValue`,`shortcuts`,`range-separator`,`start-placeholder`,`end-placeholder`,`onChange`])]),_:1})):i(``,!0),a.type===a.serviceType.API?(c(),e(_,{key:2,md:3,xs:24,class:`mb-5 flex px-2 gap-2 items-center`},{default:m(()=>[r(T,{modelValue:a.statusCodeFilter,"onUpdate:modelValue":u[4]||=e=>a.statusCodeFilter=e,placeholder:a.$t(`usage.option.statusCodeAll`),class:`w-full`,clearable:``,filterable:``,"allow-create":``,"default-first-option":``,loading:a.statusCodeOptionsLoading,onChange:a.onStatusCodeChange},{default:m(()=>[(c(!0),p(S,null,o(a.statusCodeOptions,t=>(c(),e(w,{key:t,label:String(t),value:String(t)},null,8,[`label`,`value`]))),128))]),_:1},8,[`modelValue`,`placeholder`,`loading`,`onChange`])]),_:1})):i(``,!0),a.type===a.serviceType.API?(c(),e(_,{key:3,md:3,xs:24,class:`mb-5 flex px-2 gap-2 items-center justify-end`},{default:m(()=>[r(A,{type:`primary`,plain:``,loading:a.exporting,class:`w-full whitespace-nowrap`,onClick:a.onExport},{default:m(()=>[r(k,{icon:`fa-solid fa-file-export`,class:`mr-1`}),n(` `+s(a.$t(`usage.button.export`)),1)]),_:1},8,[`loading`,`onClick`])]),_:1})):i(``,!0)]),_:1}),r(v,null,{default:m(()=>[r(_,{span:24},{default:m(()=>[a.type===a.serviceType.API?(c(),e(v,{key:0,gutter:24,class:`mb-5`},{default:m(()=>[r(_,{md:6,xs:24},{default:m(()=>[r(j,{shadow:`hover`,class:`h-full`},{default:m(()=>[a.aggLoading?(c(),e(D,{key:0})):(c(),p(`div`,ne,[t(`div`,re,[r(k,{icon:`fa-solid fa-cubes`,class:`icon`})]),t(`div`,ie,[t(`p`,ae,s(a.$t(`usage.title.totalUsed`)),1),t(`p`,oe,s(a.totalUsedString),1)])]))]),_:1})]),_:1}),r(_,{md:18,xs:24},{default:m(()=>[r(j,{shadow:`hover`,class:`h-full`},{default:m(()=>[t(`div`,se,[a.aggLoading?(c(),e(D,{key:0,class:`w-full`})):(c(),e(M,{key:1,data:a.barChartData,options:a.barChartOptions,class:`chart`},null,8,[`data`,`options`]))])]),_:1})]),_:1})]),_:1})):i(``,!0),r(j,{shadow:`hover`},{default:m(()=>[a.type===a.serviceType.API?x((c(),e(I,{key:0,data:a.apiUsages,stripe:``,"table-layout":`fixed`,"empty-text":a.$t(`common.message.noData`),class:`min-h-[calc(100vh-350px)] mb-5`},{default:m(()=>[r(N,{label:a.$t(`application.field.name`),width:`160px`},{default:m(e=>[t(`span`,null,s(e.row?.api?.title),1)]),_:1},8,[`label`]),r(N,{label:a.$t(`usage.field.statusCode`),width:`120px`},{default:m(e=>[t(`span`,null,s(e.row.status_code),1)]),_:1},8,[`label`]),r(N,{label:a.$t(`usage.field.elapsed`),width:`120px`},{default:m(e=>[t(`span`,null,s(a.formatElapsed(e.row.elapsed)),1)]),_:1},8,[`label`]),r(N,{prop:`deducted_amount`,label:a.$t(`usage.field.deductedAmount`),width:`150px`,"class-name":`text-center`},{default:m(e=>[a.getDeductedAmount(e.row)===a.getOriginalAmount(e.row)?(c(),p(`div`,ce,[t(`span`,null,s(a.getDeductedAmount(e.row)),1)])):(c(),p(`div`,le,[u[7]||=t(`p`,null,null,-1),t(`p`,null,[t(`span`,null,s(a.getDeductedAmount(e.row)),1)]),t(`p`,null,[t(`del`,null,s(a.getOriginalAmount(e.row)),1)])]))]),_:1},8,[`label`]),r(N,{prop:`remaining_amount`,label:a.$t(`usage.field.balanceAfter`),width:`160px`,"class-name":`text-center`},{default:m(e=>[t(`span`,null,s(a.getRemainingAmount(e.row)),1)]),_:1},8,[`label`]),r(N,{prop:`metadata`,label:a.$t(`usage.field.metadata`),width:`260px`,"class-name":`text-center`},{default:m(r=>[t(`div`,ue,[r.row.original_amount>r.row.deducted_amount&&r.row.original_amount>0?(c(),e(P,{key:0,type:`success`,style:{textWrap:`wrap`,height:`fit-content`,lineHeight:`20px`,borderRadius:`10px`}},{default:m(()=>[n(s(((r.row.original_amount-r.row.deducted_amount)*100/r.row.original_amount).toFixed(0)+`% OFF`),1)]),_:2},1024)):i(``,!0),(c(!0),p(S,null,o(a.getSimpleMetadata(r.row.metadata),(t,r)=>(c(),e(P,{key:r,style:{textWrap:`wrap`,height:`fit-content`,lineHeight:`20px`,borderRadius:`10px`}},{default:m(()=>[n(s(r)+`: `+s(t),1)]),_:2},1024))),128))])]),_:1},8,[`label`]),r(N,{label:a.$t(`usage.button.viewDetail`),width:`120px`,"class-name":`text-center`},{default:m(t=>[t.row.id?(c(),e(A,{key:0,type:`primary`,plain:``,size:`small`,class:`!px-2 !py-1 !text-xs !h-auto !min-h-0`,onClick:e=>a.onShowDetail(t.row)},{default:m(()=>[n(s(a.$t(`usage.button.viewDetail`)),1)]),_:1},8,[`onClick`])):i(``,!0)]),_:1},8,[`label`]),r(N,{prop:`trace_id`,label:a.$t(`application.field.traceId`),width:`200px`,"class-name":`text-center`},{default:m(e=>[t(`span`,de,s(e.row.trace_id),1),e.row.trace_id?(c(),p(`span`,fe,[r(F,{content:e.row.trace_id,class:`inline-block`},null,8,[`content`])])):i(``,!0)]),_:1},8,[`label`]),r(N,{label:a.$t(`usage.field.createdAt`),width:`200px`},{default:m(e=>[t(`span`,pe,s(a.$dayjs.format(e.row.created_at)),1)]),_:1},8,[`label`])]),_:1},8,[`data`,`empty-text`])),[[V,a.loading]]):i(``,!0),a.type===a.serviceType.Proxy?x((c(),e(I,{key:1,data:a.proxyUsages,stripe:``,"table-layout":`fixed`,"empty-text":a.$t(`common.message.noData`),class:`min-h-[calc(100vh-350px)] mb-5`},{default:m(()=>[r(N,{label:a.$t(`application.field.name`),width:`160px`},{default:m(e=>[t(`span`,null,s(e.row?.service?.title),1)]),_:1},8,[`label`]),r(N,{prop:`remaining_amount`,label:a.$t(`usage.field.remainingAmount`),width:`160px`,"class-name":`text-center`},{default:m(e=>[t(`span`,null,s(a.getRemainingAmount(e.row)),1),t(`span`,null,s(a.getOriginalAmount(e.row)),1)]),_:1},8,[`label`]),r(N,{prop:`deducted_amount`,label:a.$t(`usage.field.deductedAmount`),width:`150px`,"class-name":`text-center`},{default:m(e=>[t(`span`,null,s(a.getDeductedAmount(e.row)),1)]),_:1},8,[`label`]),r(N,{label:a.$t(`usage.field.balanceAfter`),width:`160px`,"class-name":`text-center`},{default:m(e=>[t(`span`,null,s(a.getRemainingAmount(e.row)),1)]),_:1},8,[`label`]),r(N,{prop:`metadata`,label:a.$t(`usage.field.metadata`),width:`200px`,"class-name":`text-center`},{default:m(t=>[(c(!0),p(S,null,o(t.row.metadata,(t,r)=>(c(),e(P,{key:r,class:`mb-2`},{default:m(()=>[n(s(r)+`: `+s(t),1)]),_:2},1024))),128))]),_:1},8,[`label`]),r(N,{label:a.$t(`usage.field.createdAt`),width:`200px`},{default:m(e=>[t(`span`,me,s(a.$dayjs.format(e.row.created_at)),1)]),_:1},8,[`label`])]),_:1},8,[`data`,`empty-text`])),[[V,a.loading]]):i(``,!0)]),_:1})]),_:1})]),_:1}),r(z,{modelValue:a.detailDialogVisible,"onUpdate:modelValue":u[6]||=e=>a.detailDialogVisible=e,title:a.$t(`usage.dialog.detailTitle`),width:`70%`,top:`5vh`,"destroy-on-close":``},{default:m(()=>[r(R,{modelValue:a.detailActiveTab,"onUpdate:modelValue":u[5]||=e=>a.detailActiveTab=e},{default:m(()=>[r(L,{label:a.$t(`usage.dialog.request`),name:`request`},{default:m(()=>[a.detailLoading?(c(),e(D,{key:0,rows:6,animated:``})):a.detailRow?.metadata?.request?(c(),p(`pre`,he,s(a.formatJson(a.detailRow.metadata.request)),1)):(c(),p(`p`,ge,s(a.$t(`usage.dialog.noData`)),1))]),_:1},8,[`label`]),r(L,{label:a.$t(`usage.dialog.response`),name:`response`},{default:m(()=>[a.detailLoading?(c(),e(D,{key:0,rows:6,animated:``})):a.detailRow?.metadata?.response?(c(),p(`pre`,_e,s(a.formatJson(a.detailRow.metadata.response)),1)):(c(),p(`p`,ve,s(a.$t(`usage.dialog.noData`)),1))]),_:1},8,[`label`])]),_:1},8,[`modelValue`])]),_:1},8,[`modelValue`,`title`]),r(v,null,{default:m(()=>[r(_,{span:10,offset:14},{default:m(()=>[t(`div`,ye,[r(B,{"current-page":a.page,"page-size":a.limit,total:a.total,onChange:a.onPageChange},null,8,[`current-page`,`page-size`,`total`,`onChange`])])]),_:1})]),_:1})]),_:1})]),_:1})}var xe=B(Z,[[`render`,be],[`__scopeId`,`data-v-38f1845c`]]);export{xe as default};
|
|
1
|
+
import"./rolldown-runtime--c01j_DQ.js";import{D as e,E as t,M as n,N as r,O as i,P as a,Q as o,Ut as s,X as c,_ as l,a as u,c as d,et as f,i as ee,k as p,lt as m,n as h,o as g,r as _,s as v,t as y,tt as b,ut as x,x as S}from"./vendor-chart-mdwpew_o.js";import{t as C}from"./button-DWzbdjZV.js";import{r as w,t as T}from"./select-B14L-681.js";import{n as E,t as D}from"./table-fY8LUehs.js";import{n as O,t as k}from"./tabs-CllsgUVI.js";import{t as A}from"./date-picker-DnWtfIDn.js";import{t as j}from"./card-B1OoUKT4.js";import{n as M,r as N}from"./radio-IJQsW93X.js";import{n as P,t as F}from"./row-JqIo0dw3.js";import{t as I}from"./Pagination-DYjyzEjF.js";import{n as L,t as R}from"./skeleton-Cn4UY-T8.js";import{An as z,E as B,En as V,Mr as H,Pr as U,Tn as W,_r as G,lr as K,ur as q,wn as J}from"./index-BY8YIwDb.js";import{t as Y}from"./index.es-CH5vwGaN.js";import{t as X}from"./CopyToClipboard-C8gyDUMn.js";ee.register(_,u,h,v,d,g);var Z=a({name:`ConsoleUsageList`,components:{Pagination:I,ElTag:U,ElDatePicker:A,ElTable:D,ElSelect:w,ElOption:T,CopyToClipboard:X,ElRow:F,ElCol:P,ElTableColumn:E,ElCard:j,ElRadioButton:M,ElRadioGroup:N,ElSkeleton:R,ElSkeletonItem:L,ElDialog:H,ElTabs:O,ElTabPane:k,ElButton:C,FontAwesomeIcon:Y,BarChart:y},data(){return{applicationIds:this.$route.query.application_id?.toString()?this.$route.query.application_id?.toString().split(`,`):[],apiIds:this.$route.query.api_id?.toString()?this.$route.query.api_id?.toString().split(`,`):[],applications:[],apis:[],apisLoading:!1,credentialType:K,serviceType:q,apiUsages:[],proxyUsages:[],createdAtRange:(()=>{let e=this.$route.query.created_at_to?.toString(),t=this.$route.query.created_at_from?.toString();if(t&&e)return[new Date(t),new Date(e)];let n=new Date,r=new Date;return r.setDate(1),r.setHours(0,0,0,0),[r,n]})(),shortcuts:[{text:this.$t(`usage.shortcuts.thisMonth`),value:()=>{let e=new Date,t=new Date;return t.setDate(1),t.setHours(0,0,0,0),[t,e]}},{text:this.$t(`usage.shortcuts.today`),value:()=>{let e=new Date,t=new Date;return t.setHours(0,0,0,0),[t,e]}},{text:this.$t(`usage.shortcuts.last1Day`),value:()=>{let e=new Date,t=new Date;return t.setDate(t.getDate()-1),[t,e]}},{text:this.$t(`usage.shortcuts.last3Days`),value:()=>{let e=new Date,t=new Date;return t.setDate(t.getDate()-3),[t,e]}},{text:this.$t(`usage.shortcuts.last7Days`),value:()=>{let e=new Date,t=new Date;return t.setDate(t.getDate()-7),[t,e]}},{text:this.$t(`usage.shortcuts.last1Month`),value:()=>{let e=new Date,t=new Date;return t.setMonth(t.getMonth()-1),[t,e]}}],type:this.$route.query.type?.toString()||q.API,loading:!1,total:void 0,limit:15,totalUsed:0,barChartLabels:[],barChartSeries:[],aggLoading:!1,detailDialogVisible:!1,detailRow:null,detailActiveTab:`request`,detailLoading:!1,exporting:!1,statusCodeFilter:this.$route.query.status_code?.toString()||``,statusCodeOptions:[],statusCodeOptionsLoading:!1}},computed:{redirect(){return this.$route.query?.redirect},page(){return parseInt(this.$route.query.page?.toString()||`1`)},totalUsedString(){return`${(this.totalUsed||0).toFixed(2)}`},barChartData(){return{labels:this.barChartLabels,datasets:this.barChartSeries.map(e=>({label:e.label,data:e.data,backgroundColor:e.color}))}},barChartOptions(){return{responsive:!0,plugins:{legend:{position:`top`,onClick:(e,t,n)=>{let r=n?.chart;if(!r||t?.datasetIndex===void 0)return;let i=t.datasetIndex,a=r.data?.datasets||[];a.some((e,t)=>t!==i&&r.isDatasetVisible(t))?a.forEach((e,t)=>r.setDatasetVisibility(t,t===i)):a.forEach((e,t)=>r.setDatasetVisibility(t,!0)),r.update()}},title:{display:!0,text:this.$t(`usage.title.usageTrend`)}},scales:{x:{stacked:!0},y:{stacked:!0,beginAtZero:!0}}}}},watch:{page:{handler(){this.onFetchUsages()}},type:{handler(){this.applicationIds=[],this.apiIds=[],this.onApplicationsChange(this.applicationIds),this.onFetchApplications(),this.onFetchApis(),this.onFetchUsages(),this.onFetchAggregate(),this.onFetchStatusCodeOptions()}}},mounted(){this.onFetchApplications(),this.onFetchApis(),this.onFetchUsages(),this.onFetchAggregate(),this.onFetchStatusCodeOptions()},methods:{async onFetchUsages(){this.type===q.API?this.onFetchApiUsages():this.type===q.Proxy&&this.onFetchProxyUsages()},async onApiChange(e){await this.$router.push({name:this.$route.name?.toString(),query:{...this.$route.query,api_id:e}}),this.onFetchApiUsages(),this.onFetchAggregate()},async onApisChange(e){await this.$router.push({name:this.$route.name?.toString(),query:{...this.$route.query,api_id:e&&e.length?e.join(`,`):``}}),this.onFetchApiUsages(),this.onFetchAggregate()},async onTimeRangeChanged(){console.log(`onTimeRangeChanged`,this.createdAtRange),await this.$router.push({name:this.$route.name?.toString(),query:{...this.$route.query,created_at_from:this.createdAtRange?this.$dayjs.format(this.createdAtRange[0].toString(),`YYYY-MM-DDTHH:mm:ss.SSSSSSZ`):``,created_at_to:this.createdAtRange?this.$dayjs.format(this.createdAtRange[1].toString(),`YYYY-MM-DDTHH:mm:ss.SSSSSSZ`):``}}),this.onFetchUsages(),this.onFetchAggregate(),this.onFetchStatusCodeOptions()},async onApplicationChange(e){await this.$router.push({name:this.$route.name?.toString(),query:{...this.$route.query,application_id:e}}),this.onFetchUsages(),this.onFetchAggregate()},async onApplicationsChange(e){await this.$router.push({name:this.$route.name?.toString(),query:{...this.$route.query,application_id:e&&e.length?e.join(`,`):``}}),this.onFetchUsages(),this.onFetchAggregate()},onPageChange(e){this.$router.push({name:this.$route.name?.toString(),query:{...this.$route.query,page:e}})},getRemainingAmount(e){if(e.remaining_amount===void 0||e.remaining_amount===null)return``;let t=this.$t(`service.unit.${e?.service?.unit||`credit`}s`);return`${e.remaining_amount?.toFixed(6)} ${t}`},getUsedAmount(e){if(e.used_amount===void 0||e.used_amount===null)return``;let t=this.$t(`service.unit.${e?.service?.unit||`credit`}s`);return`${e.used_amount?.toFixed(6)} ${t}`},getDeductedAmount(e){if(e?.deducted_amount===void 0||e?.deducted_amount===null)return``;let t=this.$t(`service.unit.${e?.service?.unit||`credit`}s`);return`${e.deducted_amount?.toFixed(6)} ${t}`},getOriginalAmount(e){if(e?.original_amount===void 0||e?.original_amount===null)return``;let t=this.$t(`service.unit.${e?.service?.unit||`credit`}s`);return`${e.original_amount?.toFixed(6)} ${t}`},onStatusCodeChange(e){let t={...this.$route.query},n=(e||``).trim();n?t.status_code=n:delete t.status_code,delete t.status_code_filter,this.$router.push({name:this.$route.name?.toString(),query:t}),this.onFetchUsages(),this.onFetchAggregate()},async onFetchStatusCodeOptions(){this.statusCodeOptionsLoading=!0;try{let{data:e}=await W.getStatusCodes({user_id:this.$store.getters.user.id,...this.applicationIds&&this.applicationIds.length?{application_id:this.applicationIds}:{},...this.apiIds&&this.apiIds.length?{api_id:this.apiIds}:{},...this.createdAtRange?.[0]?{created_at_from:this.createdAtRange[0]}:{},...this.createdAtRange?.[1]?{created_at_to:this.createdAtRange[1]}:{}});this.statusCodeOptions=(e?.items||[]).slice().sort((e,t)=>e-t)}catch{this.statusCodeOptions=[]}finally{this.statusCodeOptionsLoading=!1}},formatElapsed(e){return e==null||Number.isNaN(e)?`-`:e<1?`${Math.round(e*1e3)} ms`:`${e.toFixed(2)} s`},getSimpleMetadata(e){if(!e)return{};let t={};for(let[n,r]of Object.entries(e))n===`request`||n===`response`||typeof r==`object`&&r||(t[n]=r);return t},onShowDetail(e){this.detailRow={...e,metadata:void 0},this.detailActiveTab=`request`,this.detailDialogVisible=!0,this.detailLoading=!0,e.id&&W.get(e.id).then(e=>{this.detailRow=e.data}).finally(()=>{this.detailLoading=!1})},formatJson(e){try{return JSON.stringify(e,null,2)}catch{return String(e)}},onFetchApplications(){z.getAll({limit:100,offset:0,user_id:this.$store.getters.user.id,ordering:`-created_at`,type:G.USAGE}).then(({data:e})=>{this.applications=e.items.filter(e=>e?.service?.type===this.type)}).catch(()=>{})},onFetchApis(){this.apisLoading=!0,J.getAll({limit:100,offset:0,ordering:`-created_at`}).then(({data:e})=>{this.apis=e.items}).catch(()=>{}).finally(()=>{this.apisLoading=!1})},onFetchApiUsages(){console.log(`onFetchApiUsages`,this.createdAtRange),this.loading=!0,W.getAll({limit:this.limit,offset:(this.page-1)*this.limit,user_id:this.$store.getters.user.id,ordering:`-created_at`,...this.createdAtRange?.[0]?{created_at_from:this.createdAtRange[0]}:{},...this.createdAtRange?.[1]?{created_at_to:this.createdAtRange[1]}:{},...this.applicationIds&&this.applicationIds.length?{application_id:this.applicationIds}:{},...this.apiIds&&this.apiIds.length?{api_id:this.apiIds}:{},...this.statusCodeFilter?{status_code:this.statusCodeFilter}:{}}).then(({data:e})=>{this.apiUsages=e.items,this.loading=!1,this.total=e.count}).catch(()=>{this.loading=!1})},onFetchProxyUsages(){this.loading=!0,V.getAll({limit:this.limit,offset:(this.page-1)*this.limit,user_id:this.$store.getters.user.id,ordering:`-created_at`,...this.applicationIds&&this.applicationIds.length?{application_id:this.applicationIds}:{}}).then(({data:e})=>{this.proxyUsages=e.items,this.loading=!1,this.total=e.count}).catch(()=>{this.loading=!1})},onExport(){this.exporting=!0,W.exportCsv({user_id:this.$store.getters.user.id,...this.createdAtRange?.[0]?{created_at_from:this.createdAtRange[0]}:{},...this.createdAtRange?.[1]?{created_at_to:this.createdAtRange[1]}:{},...this.applicationIds&&this.applicationIds.length?{application_id:this.applicationIds}:{},...this.apiIds&&this.apiIds.length?{api_id:this.apiIds}:{},...this.statusCodeFilter?{status_code:this.statusCodeFilter}:{}}).then(({data:e})=>{let t=window.URL.createObjectURL(e),n=document.createElement(`a`);n.href=t,n.download=`usages.csv`,n.click(),window.URL.revokeObjectURL(t)}).catch(()=>{}).finally(()=>{this.exporting=!1})},async onFetchAggregate(){if(this.aggLoading=!0,this.type!==this.serviceType.API)return;let e={user_id:this.$store.getters.user.id,...this.applicationIds&&this.applicationIds.length?{application_id:this.applicationIds}:{},...this.apiIds&&this.apiIds.length?{api_id:this.apiIds}:{},...this.createdAtRange?.[0]?{created_at_from:this.createdAtRange[0]}:{},...this.createdAtRange?.[1]?{created_at_to:this.createdAtRange[1]}:{}};try{let{data:t}=await W.getAggregate(e);this.totalUsed=t.total||0;let n=Array.from(new Set((t.items||[]).map(e=>e.date))).sort(),r=Array.from(new Set((t.items||[]).map(e=>e.api_id))),i=e=>`hsl(${e*57%360}, 70%, 60%)`,a=r.map((e,r)=>{let a=t.apis?.[e]?.title||e,o={};return(t.items||[]).filter(t=>t.api_id===e).forEach(e=>{o[e.date]=e.amount||0}),{key:e,label:a,data:n.map(e=>o[e]||0),color:i(r)}});this.barChartLabels=n,this.barChartSeries=a}finally{this.aggLoading=!1}}}}),Q={class:`text-[26px] font-bold mb-5 text-[var(--el-text-color-primary)]`},$={class:`inline-block w-9`},te={class:`inline-block`},ne={key:1,class:`summary-card`},re={class:`icon-wrapper`},ie={class:`text-left`},ae={class:`description`},oe={class:`value`},se={class:`chart-wrapper`},ce={key:0},le={key:1},ue={class:`flex flex-wrap gap-2`},de={class:`key`},fe={key:0,class:`cursor-pointer`},pe={class:`created-at`},me={class:`created-at`},he={key:1,class:`detail-json`},ge={key:2,class:`text-gray-400`},_e={key:1,class:`detail-json`},ve={key:2,class:`text-gray-400`},ye={class:`float-right`};function be(a,u,d,ee,h,g){let _=f(`el-col`),v=f(`el-row`),y=f(`el-radio-button`),C=f(`el-radio-group`),w=f(`el-option`),T=f(`el-select`),E=f(`el-skeleton-item`),D=f(`el-skeleton`),O=f(`el-date-picker`),k=f(`font-awesome-icon`),A=f(`el-button`),j=f(`el-card`),M=f(`bar-chart`),N=f(`el-table-column`),P=f(`el-tag`),F=f(`copy-to-clipboard`),I=f(`el-table`),L=f(`el-tab-pane`),R=f(`el-tabs`),z=f(`el-dialog`),B=f(`pagination`),V=b(`loading`);return c(),e(v,null,{default:m(()=>[r(_,{span:24},{default:m(()=>[r(v,null,{default:m(()=>[r(_,{span:24},{default:m(()=>[t(`h2`,Q,s(a.$t(`common.title.allUsages`)),1)]),_:1})]),_:1}),r(v,null,{default:m(()=>[r(_,{md:4,xs:24,class:`mb-5 flex px-2 gap-2 items-center`},{default:m(()=>[t(`span`,null,s(a.$t(`application.field.type`)),1),r(C,{modelValue:a.type,"onUpdate:modelValue":u[0]||=e=>a.type=e},{default:m(()=>[r(y,{value:a.serviceType.API,label:a.$t(`application.field.api`)},null,8,[`value`,`label`]),r(y,{value:a.serviceType.Proxy,label:a.$t(`application.field.proxy`)},null,8,[`value`,`label`])]),_:1},8,[`modelValue`])]),_:1}),x(r(_,{md:6,xs:24,class:`mb-5 flex px-2 gap-2 items-center`},{default:m(()=>[t(`span`,$,s(a.$t(`usage.field.application`)),1),r(T,{modelValue:a.applicationIds,"onUpdate:modelValue":u[1]||=e=>a.applicationIds=e,placeholder:a.$t(`usage.field.application`),clearable:``,multiple:``,"collapse-tags":``,"collapse-tags-tooltip":``,class:`w-full`,onChange:a.onApplicationsChange},{default:m(()=>[(c(!0),p(S,null,o(a.applications,t=>(c(),e(w,{key:t.id,label:t.service?.title,value:t?.id},null,8,[`label`,`value`]))),128))]),_:1},8,[`modelValue`,`placeholder`,`onChange`])]),_:1},512),[[l,!1]]),a.type===a.serviceType.API?(c(),e(_,{key:0,md:6,xs:24,class:`mb-5 flex px-2 gap-2 items-center`},{default:m(()=>[t(`span`,te,s(a.$t(`usage.field.api`)),1),a.apisLoading?(c(),e(D,{key:0,animated:``,class:`w-full`},{template:m(()=>[r(E,{variant:`rect`,style:{height:`32px`,"border-radius":`4px`}})]),_:1})):(c(),e(T,{key:1,modelValue:a.apiIds,"onUpdate:modelValue":u[2]||=e=>a.apiIds=e,placeholder:a.$t(`usage.field.api`),clearable:``,filterable:``,multiple:``,"collapse-tags":``,"collapse-tags-tooltip":``,class:`w-full`,onChange:a.onApisChange},{default:m(()=>[(c(!0),p(S,null,o(a.apis,t=>(c(),e(w,{key:t?.id,label:t?.title,value:t?.id},null,8,[`label`,`value`]))),128))]),_:1},8,[`modelValue`,`placeholder`,`onChange`]))]),_:1})):i(``,!0),a.type===a.serviceType.API?(c(),e(_,{key:1,md:8,xs:24,class:`mb-5 flex px-2 gap-2 items-center`},{default:m(()=>[r(O,{modelValue:a.createdAtRange,"onUpdate:modelValue":u[3]||=e=>a.createdAtRange=e,type:`datetimerange`,class:`w-full`,shortcuts:a.shortcuts,"range-separator":a.$t(`usage.placeholder.to`),"start-placeholder":a.$t(`usage.placeholder.startDate`),"end-placeholder":a.$t(`usage.placeholder.endDate`),onChange:a.onTimeRangeChanged},null,8,[`modelValue`,`shortcuts`,`range-separator`,`start-placeholder`,`end-placeholder`,`onChange`])]),_:1})):i(``,!0),a.type===a.serviceType.API?(c(),e(_,{key:2,md:3,xs:24,class:`mb-5 flex px-2 gap-2 items-center`},{default:m(()=>[r(T,{modelValue:a.statusCodeFilter,"onUpdate:modelValue":u[4]||=e=>a.statusCodeFilter=e,placeholder:a.$t(`usage.option.statusCodeAll`),class:`w-full`,clearable:``,filterable:``,"allow-create":``,"default-first-option":``,loading:a.statusCodeOptionsLoading,onChange:a.onStatusCodeChange},{default:m(()=>[(c(!0),p(S,null,o(a.statusCodeOptions,t=>(c(),e(w,{key:t,label:String(t),value:String(t)},null,8,[`label`,`value`]))),128))]),_:1},8,[`modelValue`,`placeholder`,`loading`,`onChange`])]),_:1})):i(``,!0),a.type===a.serviceType.API?(c(),e(_,{key:3,md:3,xs:24,class:`mb-5 flex px-2 gap-2 items-center justify-end`},{default:m(()=>[r(A,{type:`primary`,plain:``,loading:a.exporting,class:`w-full whitespace-nowrap`,onClick:a.onExport},{default:m(()=>[r(k,{icon:`fa-solid fa-file-export`,class:`mr-1`}),n(` `+s(a.$t(`usage.button.export`)),1)]),_:1},8,[`loading`,`onClick`])]),_:1})):i(``,!0)]),_:1}),r(v,null,{default:m(()=>[r(_,{span:24},{default:m(()=>[a.type===a.serviceType.API?(c(),e(v,{key:0,gutter:24,class:`mb-5`},{default:m(()=>[r(_,{md:6,xs:24},{default:m(()=>[r(j,{shadow:`hover`,class:`h-full`},{default:m(()=>[a.aggLoading?(c(),e(D,{key:0})):(c(),p(`div`,ne,[t(`div`,re,[r(k,{icon:`fa-solid fa-cubes`,class:`icon`})]),t(`div`,ie,[t(`p`,ae,s(a.$t(`usage.title.totalUsed`)),1),t(`p`,oe,s(a.totalUsedString),1)])]))]),_:1})]),_:1}),r(_,{md:18,xs:24},{default:m(()=>[r(j,{shadow:`hover`,class:`h-full`},{default:m(()=>[t(`div`,se,[a.aggLoading?(c(),e(D,{key:0,class:`w-full`})):(c(),e(M,{key:1,data:a.barChartData,options:a.barChartOptions,class:`chart`},null,8,[`data`,`options`]))])]),_:1})]),_:1})]),_:1})):i(``,!0),r(j,{shadow:`hover`},{default:m(()=>[a.type===a.serviceType.API?x((c(),e(I,{key:0,data:a.apiUsages,stripe:``,"table-layout":`fixed`,"empty-text":a.$t(`common.message.noData`),class:`min-h-[calc(100vh-350px)] mb-5`},{default:m(()=>[r(N,{label:a.$t(`application.field.name`),width:`160px`},{default:m(e=>[t(`span`,null,s(e.row?.api?.title),1)]),_:1},8,[`label`]),r(N,{label:a.$t(`usage.field.statusCode`),width:`120px`},{default:m(e=>[t(`span`,null,s(e.row.status_code),1)]),_:1},8,[`label`]),r(N,{label:a.$t(`usage.field.elapsed`),width:`120px`},{default:m(e=>[t(`span`,null,s(a.formatElapsed(e.row.elapsed)),1)]),_:1},8,[`label`]),r(N,{prop:`deducted_amount`,label:a.$t(`usage.field.deductedAmount`),width:`150px`,"class-name":`text-center`},{default:m(e=>[a.getDeductedAmount(e.row)===a.getOriginalAmount(e.row)?(c(),p(`div`,ce,[t(`span`,null,s(a.getDeductedAmount(e.row)),1)])):(c(),p(`div`,le,[u[7]||=t(`p`,null,null,-1),t(`p`,null,[t(`span`,null,s(a.getDeductedAmount(e.row)),1)]),t(`p`,null,[t(`del`,null,s(a.getOriginalAmount(e.row)),1)])]))]),_:1},8,[`label`]),r(N,{prop:`remaining_amount`,label:a.$t(`usage.field.balanceAfter`),width:`160px`,"class-name":`text-center`},{default:m(e=>[t(`span`,null,s(a.getRemainingAmount(e.row)),1)]),_:1},8,[`label`]),r(N,{prop:`metadata`,label:a.$t(`usage.field.metadata`),width:`260px`,"class-name":`text-center`},{default:m(r=>[t(`div`,ue,[r.row.original_amount>r.row.deducted_amount&&r.row.original_amount>0?(c(),e(P,{key:0,type:`success`,style:{textWrap:`wrap`,height:`fit-content`,lineHeight:`20px`,borderRadius:`10px`}},{default:m(()=>[n(s(((r.row.original_amount-r.row.deducted_amount)*100/r.row.original_amount).toFixed(0)+`% OFF`),1)]),_:2},1024)):i(``,!0),(c(!0),p(S,null,o(a.getSimpleMetadata(r.row.metadata),(t,r)=>(c(),e(P,{key:r,style:{textWrap:`wrap`,height:`fit-content`,lineHeight:`20px`,borderRadius:`10px`}},{default:m(()=>[n(s(r)+`: `+s(t),1)]),_:2},1024))),128))])]),_:1},8,[`label`]),r(N,{label:a.$t(`usage.button.viewDetail`),width:`120px`,"class-name":`text-center`},{default:m(t=>[t.row.id?(c(),e(A,{key:0,type:`primary`,plain:``,size:`small`,class:`!px-2 !py-1 !text-xs !h-auto !min-h-0`,onClick:e=>a.onShowDetail(t.row)},{default:m(()=>[n(s(a.$t(`usage.button.viewDetail`)),1)]),_:1},8,[`onClick`])):i(``,!0)]),_:1},8,[`label`]),r(N,{prop:`trace_id`,label:a.$t(`application.field.traceId`),width:`200px`,"class-name":`text-center`},{default:m(e=>[t(`span`,de,s(e.row.trace_id),1),e.row.trace_id?(c(),p(`span`,fe,[r(F,{content:e.row.trace_id,class:`inline-block`},null,8,[`content`])])):i(``,!0)]),_:1},8,[`label`]),r(N,{label:a.$t(`usage.field.createdAt`),width:`200px`},{default:m(e=>[t(`span`,pe,s(a.$dayjs.format(e.row.created_at)),1)]),_:1},8,[`label`])]),_:1},8,[`data`,`empty-text`])),[[V,a.loading]]):i(``,!0),a.type===a.serviceType.Proxy?x((c(),e(I,{key:1,data:a.proxyUsages,stripe:``,"table-layout":`fixed`,"empty-text":a.$t(`common.message.noData`),class:`min-h-[calc(100vh-350px)] mb-5`},{default:m(()=>[r(N,{label:a.$t(`application.field.name`),width:`160px`},{default:m(e=>[t(`span`,null,s(e.row?.service?.title),1)]),_:1},8,[`label`]),r(N,{prop:`remaining_amount`,label:a.$t(`usage.field.remainingAmount`),width:`160px`,"class-name":`text-center`},{default:m(e=>[t(`span`,null,s(a.getRemainingAmount(e.row)),1),t(`span`,null,s(a.getOriginalAmount(e.row)),1)]),_:1},8,[`label`]),r(N,{prop:`deducted_amount`,label:a.$t(`usage.field.deductedAmount`),width:`150px`,"class-name":`text-center`},{default:m(e=>[t(`span`,null,s(a.getDeductedAmount(e.row)),1)]),_:1},8,[`label`]),r(N,{label:a.$t(`usage.field.balanceAfter`),width:`160px`,"class-name":`text-center`},{default:m(e=>[t(`span`,null,s(a.getRemainingAmount(e.row)),1)]),_:1},8,[`label`]),r(N,{prop:`metadata`,label:a.$t(`usage.field.metadata`),width:`200px`,"class-name":`text-center`},{default:m(t=>[(c(!0),p(S,null,o(t.row.metadata,(t,r)=>(c(),e(P,{key:r,class:`mb-2`},{default:m(()=>[n(s(r)+`: `+s(t),1)]),_:2},1024))),128))]),_:1},8,[`label`]),r(N,{label:a.$t(`usage.field.createdAt`),width:`200px`},{default:m(e=>[t(`span`,me,s(a.$dayjs.format(e.row.created_at)),1)]),_:1},8,[`label`])]),_:1},8,[`data`,`empty-text`])),[[V,a.loading]]):i(``,!0)]),_:1})]),_:1})]),_:1}),r(z,{modelValue:a.detailDialogVisible,"onUpdate:modelValue":u[6]||=e=>a.detailDialogVisible=e,title:a.$t(`usage.dialog.detailTitle`),width:`70%`,top:`5vh`,"destroy-on-close":``},{default:m(()=>[r(R,{modelValue:a.detailActiveTab,"onUpdate:modelValue":u[5]||=e=>a.detailActiveTab=e},{default:m(()=>[r(L,{label:a.$t(`usage.dialog.request`),name:`request`},{default:m(()=>[a.detailLoading?(c(),e(D,{key:0,rows:6,animated:``})):a.detailRow?.metadata?.request?(c(),p(`pre`,he,s(a.formatJson(a.detailRow.metadata.request)),1)):(c(),p(`p`,ge,s(a.$t(`usage.dialog.noData`)),1))]),_:1},8,[`label`]),r(L,{label:a.$t(`usage.dialog.response`),name:`response`},{default:m(()=>[a.detailLoading?(c(),e(D,{key:0,rows:6,animated:``})):a.detailRow?.metadata?.response?(c(),p(`pre`,_e,s(a.formatJson(a.detailRow.metadata.response)),1)):(c(),p(`p`,ve,s(a.$t(`usage.dialog.noData`)),1))]),_:1},8,[`label`])]),_:1},8,[`modelValue`])]),_:1},8,[`modelValue`,`title`]),r(v,null,{default:m(()=>[r(_,{span:10,offset:14},{default:m(()=>[t(`div`,ye,[r(B,{"current-page":a.page,"page-size":a.limit,total:a.total,onChange:a.onPageChange},null,8,[`current-page`,`page-size`,`total`,`onChange`])])]),_:1})]),_:1})]),_:1})]),_:1})}var xe=B(Z,[[`render`,be],[`__scopeId`,`data-v-38f1845c`]]);export{xe as default};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import"./rolldown-runtime--c01j_DQ.js";import{D as e,E as t,M as n,N as r,P as i,Q as a,Ut as o,X as s,et as c,k as l,lt as u,tt as d,ut as ee,x as f}from"./vendor-chart-mdwpew_o.js";import{t as p}from"./button-DWzbdjZV.js";import{r as m,t as h}from"./select-Byt7Qw1F.js";import{n as g,t as _}from"./table-fY8LUehs.js";import{t as v}from"./date-picker-ye73-4_d.js";import{t as y}from"./card-B1OoUKT4.js";import{n as b,t as x}from"./row-Dpgq35ln.js";import{t as S}from"./Pagination-ZFaMc_mv.js";import{t as C}from"./skeleton-Cn4UY-T8.js";import{Cn as w,E as T,Pr as E,Pt as D,dr as O}from"./index-Dzx62HWL.js";import{t as k}from"./index.es-BIezN10l.js";import{t as A}from"./CopyToClipboard-LZRed5aB.js";var j={total_count:0,total_spent:0,state_counts:{}},M=i({name:`ConsoleOrderList`,components:{Pagination:S,CopyToClipboard:A,ElRow:x,ElCol:b,ElTable:_,ElTableColumn:g,ElButton:p,ElTag:E,ElCard:y,ElSelect:m,ElOption:h,ElDatePicker:v,ElSkeleton:C,FontAwesomeIcon:k},data(){return{OrderState:O,orders:[],loading:!1,total:void 0,limit:10,filterState:this.$route.query.state?.toString()||``,filterPayWay:this.$route.query.pay_way?.toString()||``,createdAtRange:(()=>{let e=this.$route.query.created_at_from?.toString(),t=this.$route.query.created_at_to?.toString();if(e&&t)return[new Date(e),new Date(t)]})(),summary:{...j},summaryLoading:!1,exporting:!1,shortcuts:[{text:this.$t(`usage.shortcuts.today`),value:()=>{let e=new Date,t=new Date;return t.setHours(0,0,0,0),[t,e]}},{text:this.$t(`usage.shortcuts.last7Days`),value:()=>{let e=new Date,t=new Date;return t.setDate(t.getDate()-7),[t,e]}},{text:this.$t(`usage.shortcuts.last1Month`),value:()=>{let e=new Date,t=new Date;return t.setMonth(t.getMonth()-1),[t,e]}}]}},computed:{page(){return parseInt(this.$route.query.page?.toString()||`1`)},stateOptions(){return[{value:O.PENDING,label:this.$t(`order.state.pending`)},{value:O.FINISHED,label:this.$t(`order.state.finished`)},{value:O.PAID,label:this.$t(`order.state.paid`)},{value:O.EXPIRED,label:this.$t(`order.state.expired`)},{value:O.FAILED,label:this.$t(`order.state.failed`)},{value:O.REFUNDED,label:this.$t(`order.state.refunded`)}]},payWayOptions(){return[{value:`WechatPay`,label:this.$t(`order.title.wechatPay`)},{value:`Stripe`,label:this.$t(`order.title.stripe`)},{value:`AliPay`,label:this.$t(`order.title.aliPay`)},{value:`X402`,label:this.$t(`order.title.x402`)},{value:`PayPal`,label:this.$t(`order.title.paypal`)}]},filterQuery(){let e={user_id:this.$store.getters.user?.id};return this.filterState&&(e.state=this.filterState),this.filterPayWay&&(e.pay_way=this.filterPayWay),this.createdAtRange?.[0]&&(e.created_at_from=this.createdAtRange[0]),this.createdAtRange?.[1]&&(e.created_at_to=this.createdAtRange[1]),e}},watch:{page:{handler(){this.onFetchData()}}},mounted(){this.onFetchData(),this.onFetchSummary()},methods:{getPriceString:D,stateTagType(e){return e===O.FINISHED||e===O.PAID?`success`:e===O.EXPIRED||e===O.FAILED?`danger`:e===O.REFUNDED?`warning`:`info`},stateLabel(e){return{[O.PENDING]:this.$t(`order.state.pending`),[O.PAID]:this.$t(`order.state.paid`),[O.FINISHED]:this.$t(`order.state.finished`),[O.EXPIRED]:this.$t(`order.state.expired`),[O.FAILED]:this.$t(`order.state.failed`),[O.REFUNDED]:this.$t(`order.state.refunded`)}[e]||e},isPendingAction(e){return e!==O.PAID&&e!==O.FINISHED&&e!==O.EXPIRED&&e!==O.FAILED&&e!==O.REFUNDED},goToDetail(e){this.$router.push({name:`console-order-detail`,params:{id:e}})},async onFilterChange(){await this.$router.push({name:this.$route.name?.toString(),query:{page:1,...this.filterState?{state:this.filterState}:{},...this.filterPayWay?{pay_way:this.filterPayWay}:{},...this.createdAtRange?.[0]?{created_at_from:this.createdAtRange[0].toISOString()}:{},...this.createdAtRange?.[1]?{created_at_to:this.createdAtRange[1].toISOString()}:{}}}),this.onFetchData(),this.onFetchSummary()},onPageChange(e){this.$router.push({name:this.$route.name?.toString(),query:{...this.$route.query,page:e}})},onFetchData(){this.loading=!0,w.getAll({ordering:`-created_at`,limit:this.limit,offset:(this.page-1)*this.limit,...this.filterQuery}).then(({data:e})=>{this.orders=e.items,this.total=e.count}).catch(()=>{}).finally(()=>{this.loading=!1})},onFetchSummary(){this.summaryLoading=!0,w.getSummary(this.filterQuery).then(({data:e})=>{this.summary=e}).catch(()=>{this.summary={...j}}).finally(()=>{this.summaryLoading=!1})},onExport(){this.exporting=!0,w.exportCsv(this.filterQuery).then(({data:e})=>{let t=window.URL.createObjectURL(e),n=document.createElement(`a`);n.href=t,n.download=`orders.csv`,n.click(),window.URL.revokeObjectURL(t)}).catch(()=>{}).finally(()=>{this.exporting=!1})}}}),N={class:`title`},P={key:1,class:`card-content`},F={class:`icon-wrapper`},I={class:`description`},L={class:`value`},R={key:1,class:`card-content`},z={class:`icon-wrapper`},B={class:`description`},V={class:`value`},H={key:1,class:`card-content`},U={class:`icon-wrapper`},te={class:`description`},W={class:`value`},G={key:1,class:`card-content`},K={class:`icon-wrapper`},q={class:`description`},J={class:`value`},Y={class:`filter-row mb-3`},X={class:`key`},Z={class:`cursor-pointer`},Q={class:`price`},ne={class:`description`},re={class:`text-gray-500`},$={class:`created-at`},ie={class:`flex items-center justify-center flex-wrap`},ae={class:`float-right`};function oe(i,p,m,h,g,_){let v=c(`el-col`),y=c(`el-row`),b=c(`el-skeleton`),x=c(`font-awesome-icon`),S=c(`el-card`),C=c(`el-option`),w=c(`el-select`),T=c(`el-date-picker`),E=c(`el-button`),D=c(`copy-to-clipboard`),O=c(`el-table-column`),k=c(`el-tag`),A=c(`el-table`),j=c(`pagination`),M=d(`loading`);return s(),e(y,{class:`panel`},{default:u(()=>[r(v,{span:24},{default:u(()=>[r(y,null,{default:u(()=>[r(v,{span:24},{default:u(()=>[t(`h2`,N,o(i.$t(`common.title.allOrders`)),1)]),_:1})]),_:1}),r(y,{gutter:16},{default:u(()=>[r(v,{md:6,sm:12,xs:24},{default:u(()=>[r(S,{shadow:`hover`,class:`item-mini mb-3`},{default:u(()=>[i.summaryLoading?(s(),e(b,{key:0})):(s(),l(`div`,P,[t(`div`,F,[r(x,{icon:`fa-solid fa-receipt`,class:`icon`})]),t(`p`,I,o(i.$t(`order.title.totalOrders`)),1),t(`p`,L,o(i.summary.total_count),1)]))]),_:1})]),_:1}),r(v,{md:6,sm:12,xs:24},{default:u(()=>[r(S,{shadow:`hover`,class:`item-mini mb-3`},{default:u(()=>[i.summaryLoading?(s(),e(b,{key:0})):(s(),l(`div`,R,[t(`div`,z,[r(x,{icon:`fa-solid fa-dollar-sign`,class:`icon`})]),t(`p`,B,o(i.$t(`order.title.totalSpent`)),1),t(`p`,V,o(i.getPriceString({value:i.summary.total_spent})),1)]))]),_:1})]),_:1}),r(v,{md:6,sm:12,xs:24},{default:u(()=>[r(S,{shadow:`hover`,class:`item-mini mb-3`},{default:u(()=>[i.summaryLoading?(s(),e(b,{key:0})):(s(),l(`div`,H,[t(`div`,U,[r(x,{icon:`fa-solid fa-check-circle`,class:`icon`})]),t(`p`,te,o(i.$t(`order.title.finishedOrders`)),1),t(`p`,W,o(i.summary.state_counts?.Finished||0),1)]))]),_:1})]),_:1}),r(v,{md:6,sm:12,xs:24},{default:u(()=>[r(S,{shadow:`hover`,class:`item-mini mb-3`},{default:u(()=>[i.summaryLoading?(s(),e(b,{key:0})):(s(),l(`div`,G,[t(`div`,K,[r(x,{icon:`fa-solid fa-clock`,class:`icon`})]),t(`p`,q,o(i.$t(`order.title.pendingOrders`)),1),t(`p`,J,o(i.summary.state_counts?.Pending||0),1)]))]),_:1})]),_:1})]),_:1}),t(`div`,Y,[r(w,{modelValue:i.filterState,"onUpdate:modelValue":p[0]||=e=>i.filterState=e,clearable:``,placeholder:i.$t(`order.field.allStates`),class:`filter-select`,onChange:i.onFilterChange},{default:u(()=>[(s(!0),l(f,null,a(i.stateOptions,t=>(s(),e(C,{key:t.value,label:t.label,value:t.value},null,8,[`label`,`value`]))),128))]),_:1},8,[`modelValue`,`placeholder`,`onChange`]),r(w,{modelValue:i.filterPayWay,"onUpdate:modelValue":p[1]||=e=>i.filterPayWay=e,clearable:``,placeholder:i.$t(`order.field.allPayWays`),class:`filter-select`,onChange:i.onFilterChange},{default:u(()=>[(s(!0),l(f,null,a(i.payWayOptions,t=>(s(),e(C,{key:t.value,label:t.label,value:t.value},null,8,[`label`,`value`]))),128))]),_:1},8,[`modelValue`,`placeholder`,`onChange`]),r(T,{modelValue:i.createdAtRange,"onUpdate:modelValue":p[2]||=e=>i.createdAtRange=e,type:`datetimerange`,shortcuts:i.shortcuts,"range-separator":i.$t(`usage.placeholder.to`),"start-placeholder":i.$t(`usage.placeholder.startDate`),"end-placeholder":i.$t(`usage.placeholder.endDate`),onChange:i.onFilterChange},null,8,[`modelValue`,`shortcuts`,`range-separator`,`start-placeholder`,`end-placeholder`,`onChange`]),r(E,{type:`primary`,plain:``,loading:i.exporting,onClick:i.onExport},{default:u(()=>[r(x,{icon:`fa-solid fa-file-export`,class:`mr-1`}),n(` `+o(i.$t(`order.button.export`)),1)]),_:1},8,[`loading`,`onClick`])]),r(y,null,{default:u(()=>[r(v,{span:24},{default:u(()=>[r(S,{shadow:`hover`},{default:u(()=>[ee((s(),e(A,{data:i.orders,stripe:``,"empty-text":i.$t(`common.message.noData`),class:`min-h-[calc(100vh-450px)] mb-[20px]`},{default:u(()=>[r(O,{prop:`id`,label:i.$t(`order.field.id`),"class-name":`text-center`,width:`200px`},{default:u(e=>[t(`span`,X,o(e.row.id),1),t(`span`,Z,[r(D,{content:e.row.id,class:`inline-block`},null,8,[`content`])])]),_:1},8,[`label`]),r(O,{label:i.$t(`order.field.price`),width:`110px`,align:`center`},{default:u(e=>[t(`span`,Q,o(i.getPriceString({value:e.row?.price})),1)]),_:1},8,[`label`]),r(O,{label:i.$t(`order.field.description`),"min-width":`220px`,"class-name":`hidden md:table-cell`,"label-class-name":`hidden md:table-cell`},{default:u(e=>[t(`span`,ne,o(e.row.description),1)]),_:1},8,[`label`]),r(O,{prop:`state`,label:i.$t(`order.field.state`),width:`130px`,align:`center`},{default:u(e=>[r(k,{type:i.stateTagType(e.row.state),class:`mx-1`,effect:`dark`,round:``,size:`small`},{default:u(()=>[n(o(i.stateLabel(e.row.state)),1)]),_:2},1032,[`type`])]),_:1},8,[`label`]),r(O,{label:i.$t(`order.field.payWay`),width:`120px`,align:`center`,"class-name":`hidden md:table-cell`,"label-class-name":`hidden md:table-cell`},{default:u(e=>[t(`span`,re,o(e.row.pay_way||`-`),1)]),_:1},8,[`label`]),r(O,{label:i.$t(`order.field.createdAt`),width:`200px`,"class-name":`hidden sm:table-cell`,"label-class-name":`hidden sm:table-cell`},{default:u(e=>[t(`span`,$,o(i.$dayjs.format(e.row.created_at)),1)]),_:1},8,[`label`]),r(O,{"min-width":`130px`,fixed:`right`},{default:u(r=>[t(`div`,ie,[i.isPendingAction(r.row.state)?(s(),e(E,{key:0,type:`primary`,size:`small`,onClick:e=>i.goToDetail(r.row.id)},{default:u(()=>[n(o(i.$t(`order.button.continuePay`)),1)]),_:1},8,[`onClick`])):(s(),e(E,{key:1,size:`small`,onClick:e=>i.goToDetail(r.row.id)},{default:u(()=>[n(o(i.$t(`order.button.checkDetail`)),1)]),_:1},8,[`onClick`]))])]),_:1})]),_:1},8,[`data`,`empty-text`])),[[M,i.loading]])]),_:1})]),_:1})]),_:1}),r(y,null,{default:u(()=>[r(v,{span:10,offset:14},{default:u(()=>[t(`div`,ae,[r(j,{"current-page":i.page,"page-size":i.limit,total:i.total,onChange:i.onPageChange},null,8,[`current-page`,`page-size`,`total`,`onChange`])])]),_:1})]),_:1})]),_:1})]),_:1})}var se=T(M,[[`render`,oe],[`__scopeId`,`data-v-350ab467`]]);export{se as default};
|
|
1
|
+
import"./rolldown-runtime--c01j_DQ.js";import{D as e,E as t,M as n,N as r,P as i,Q as a,Ut as o,X as s,et as c,k as l,lt as u,tt as d,ut as ee,x as f}from"./vendor-chart-mdwpew_o.js";import{t as p}from"./button-DWzbdjZV.js";import{r as m,t as h}from"./select-B14L-681.js";import{n as g,t as _}from"./table-fY8LUehs.js";import{t as v}from"./date-picker-DnWtfIDn.js";import{t as y}from"./card-B1OoUKT4.js";import{n as b,t as x}from"./row-JqIo0dw3.js";import{t as S}from"./Pagination-DYjyzEjF.js";import{t as C}from"./skeleton-Cn4UY-T8.js";import{Cn as w,E as T,Pr as E,Pt as D,dr as O}from"./index-BY8YIwDb.js";import{t as k}from"./index.es-CH5vwGaN.js";import{t as A}from"./CopyToClipboard-C8gyDUMn.js";var j={total_count:0,total_spent:0,state_counts:{}},M=i({name:`ConsoleOrderList`,components:{Pagination:S,CopyToClipboard:A,ElRow:x,ElCol:b,ElTable:_,ElTableColumn:g,ElButton:p,ElTag:E,ElCard:y,ElSelect:m,ElOption:h,ElDatePicker:v,ElSkeleton:C,FontAwesomeIcon:k},data(){return{OrderState:O,orders:[],loading:!1,total:void 0,limit:10,filterState:this.$route.query.state?.toString()||``,filterPayWay:this.$route.query.pay_way?.toString()||``,createdAtRange:(()=>{let e=this.$route.query.created_at_from?.toString(),t=this.$route.query.created_at_to?.toString();if(e&&t)return[new Date(e),new Date(t)]})(),summary:{...j},summaryLoading:!1,exporting:!1,shortcuts:[{text:this.$t(`usage.shortcuts.today`),value:()=>{let e=new Date,t=new Date;return t.setHours(0,0,0,0),[t,e]}},{text:this.$t(`usage.shortcuts.last7Days`),value:()=>{let e=new Date,t=new Date;return t.setDate(t.getDate()-7),[t,e]}},{text:this.$t(`usage.shortcuts.last1Month`),value:()=>{let e=new Date,t=new Date;return t.setMonth(t.getMonth()-1),[t,e]}}]}},computed:{page(){return parseInt(this.$route.query.page?.toString()||`1`)},stateOptions(){return[{value:O.PENDING,label:this.$t(`order.state.pending`)},{value:O.FINISHED,label:this.$t(`order.state.finished`)},{value:O.PAID,label:this.$t(`order.state.paid`)},{value:O.EXPIRED,label:this.$t(`order.state.expired`)},{value:O.FAILED,label:this.$t(`order.state.failed`)},{value:O.REFUNDED,label:this.$t(`order.state.refunded`)}]},payWayOptions(){return[{value:`WechatPay`,label:this.$t(`order.title.wechatPay`)},{value:`Stripe`,label:this.$t(`order.title.stripe`)},{value:`AliPay`,label:this.$t(`order.title.aliPay`)},{value:`X402`,label:this.$t(`order.title.x402`)},{value:`PayPal`,label:this.$t(`order.title.paypal`)}]},filterQuery(){let e={user_id:this.$store.getters.user?.id};return this.filterState&&(e.state=this.filterState),this.filterPayWay&&(e.pay_way=this.filterPayWay),this.createdAtRange?.[0]&&(e.created_at_from=this.createdAtRange[0]),this.createdAtRange?.[1]&&(e.created_at_to=this.createdAtRange[1]),e}},watch:{page:{handler(){this.onFetchData()}}},mounted(){this.onFetchData(),this.onFetchSummary()},methods:{getPriceString:D,stateTagType(e){return e===O.FINISHED||e===O.PAID?`success`:e===O.EXPIRED||e===O.FAILED?`danger`:e===O.REFUNDED?`warning`:`info`},stateLabel(e){return{[O.PENDING]:this.$t(`order.state.pending`),[O.PAID]:this.$t(`order.state.paid`),[O.FINISHED]:this.$t(`order.state.finished`),[O.EXPIRED]:this.$t(`order.state.expired`),[O.FAILED]:this.$t(`order.state.failed`),[O.REFUNDED]:this.$t(`order.state.refunded`)}[e]||e},isPendingAction(e){return e!==O.PAID&&e!==O.FINISHED&&e!==O.EXPIRED&&e!==O.FAILED&&e!==O.REFUNDED},goToDetail(e){this.$router.push({name:`console-order-detail`,params:{id:e}})},async onFilterChange(){await this.$router.push({name:this.$route.name?.toString(),query:{page:1,...this.filterState?{state:this.filterState}:{},...this.filterPayWay?{pay_way:this.filterPayWay}:{},...this.createdAtRange?.[0]?{created_at_from:this.createdAtRange[0].toISOString()}:{},...this.createdAtRange?.[1]?{created_at_to:this.createdAtRange[1].toISOString()}:{}}}),this.onFetchData(),this.onFetchSummary()},onPageChange(e){this.$router.push({name:this.$route.name?.toString(),query:{...this.$route.query,page:e}})},onFetchData(){this.loading=!0,w.getAll({ordering:`-created_at`,limit:this.limit,offset:(this.page-1)*this.limit,...this.filterQuery}).then(({data:e})=>{this.orders=e.items,this.total=e.count}).catch(()=>{}).finally(()=>{this.loading=!1})},onFetchSummary(){this.summaryLoading=!0,w.getSummary(this.filterQuery).then(({data:e})=>{this.summary=e}).catch(()=>{this.summary={...j}}).finally(()=>{this.summaryLoading=!1})},onExport(){this.exporting=!0,w.exportCsv(this.filterQuery).then(({data:e})=>{let t=window.URL.createObjectURL(e),n=document.createElement(`a`);n.href=t,n.download=`orders.csv`,n.click(),window.URL.revokeObjectURL(t)}).catch(()=>{}).finally(()=>{this.exporting=!1})}}}),N={class:`title`},P={key:1,class:`card-content`},F={class:`icon-wrapper`},I={class:`description`},L={class:`value`},R={key:1,class:`card-content`},z={class:`icon-wrapper`},B={class:`description`},V={class:`value`},H={key:1,class:`card-content`},U={class:`icon-wrapper`},te={class:`description`},W={class:`value`},G={key:1,class:`card-content`},K={class:`icon-wrapper`},q={class:`description`},J={class:`value`},Y={class:`filter-row mb-3`},X={class:`key`},Z={class:`cursor-pointer`},Q={class:`price`},ne={class:`description`},re={class:`text-gray-500`},$={class:`created-at`},ie={class:`flex items-center justify-center flex-wrap`},ae={class:`float-right`};function oe(i,p,m,h,g,_){let v=c(`el-col`),y=c(`el-row`),b=c(`el-skeleton`),x=c(`font-awesome-icon`),S=c(`el-card`),C=c(`el-option`),w=c(`el-select`),T=c(`el-date-picker`),E=c(`el-button`),D=c(`copy-to-clipboard`),O=c(`el-table-column`),k=c(`el-tag`),A=c(`el-table`),j=c(`pagination`),M=d(`loading`);return s(),e(y,{class:`panel`},{default:u(()=>[r(v,{span:24},{default:u(()=>[r(y,null,{default:u(()=>[r(v,{span:24},{default:u(()=>[t(`h2`,N,o(i.$t(`common.title.allOrders`)),1)]),_:1})]),_:1}),r(y,{gutter:16},{default:u(()=>[r(v,{md:6,sm:12,xs:24},{default:u(()=>[r(S,{shadow:`hover`,class:`item-mini mb-3`},{default:u(()=>[i.summaryLoading?(s(),e(b,{key:0})):(s(),l(`div`,P,[t(`div`,F,[r(x,{icon:`fa-solid fa-receipt`,class:`icon`})]),t(`p`,I,o(i.$t(`order.title.totalOrders`)),1),t(`p`,L,o(i.summary.total_count),1)]))]),_:1})]),_:1}),r(v,{md:6,sm:12,xs:24},{default:u(()=>[r(S,{shadow:`hover`,class:`item-mini mb-3`},{default:u(()=>[i.summaryLoading?(s(),e(b,{key:0})):(s(),l(`div`,R,[t(`div`,z,[r(x,{icon:`fa-solid fa-dollar-sign`,class:`icon`})]),t(`p`,B,o(i.$t(`order.title.totalSpent`)),1),t(`p`,V,o(i.getPriceString({value:i.summary.total_spent})),1)]))]),_:1})]),_:1}),r(v,{md:6,sm:12,xs:24},{default:u(()=>[r(S,{shadow:`hover`,class:`item-mini mb-3`},{default:u(()=>[i.summaryLoading?(s(),e(b,{key:0})):(s(),l(`div`,H,[t(`div`,U,[r(x,{icon:`fa-solid fa-check-circle`,class:`icon`})]),t(`p`,te,o(i.$t(`order.title.finishedOrders`)),1),t(`p`,W,o(i.summary.state_counts?.Finished||0),1)]))]),_:1})]),_:1}),r(v,{md:6,sm:12,xs:24},{default:u(()=>[r(S,{shadow:`hover`,class:`item-mini mb-3`},{default:u(()=>[i.summaryLoading?(s(),e(b,{key:0})):(s(),l(`div`,G,[t(`div`,K,[r(x,{icon:`fa-solid fa-clock`,class:`icon`})]),t(`p`,q,o(i.$t(`order.title.pendingOrders`)),1),t(`p`,J,o(i.summary.state_counts?.Pending||0),1)]))]),_:1})]),_:1})]),_:1}),t(`div`,Y,[r(w,{modelValue:i.filterState,"onUpdate:modelValue":p[0]||=e=>i.filterState=e,clearable:``,placeholder:i.$t(`order.field.allStates`),class:`filter-select`,onChange:i.onFilterChange},{default:u(()=>[(s(!0),l(f,null,a(i.stateOptions,t=>(s(),e(C,{key:t.value,label:t.label,value:t.value},null,8,[`label`,`value`]))),128))]),_:1},8,[`modelValue`,`placeholder`,`onChange`]),r(w,{modelValue:i.filterPayWay,"onUpdate:modelValue":p[1]||=e=>i.filterPayWay=e,clearable:``,placeholder:i.$t(`order.field.allPayWays`),class:`filter-select`,onChange:i.onFilterChange},{default:u(()=>[(s(!0),l(f,null,a(i.payWayOptions,t=>(s(),e(C,{key:t.value,label:t.label,value:t.value},null,8,[`label`,`value`]))),128))]),_:1},8,[`modelValue`,`placeholder`,`onChange`]),r(T,{modelValue:i.createdAtRange,"onUpdate:modelValue":p[2]||=e=>i.createdAtRange=e,type:`datetimerange`,shortcuts:i.shortcuts,"range-separator":i.$t(`usage.placeholder.to`),"start-placeholder":i.$t(`usage.placeholder.startDate`),"end-placeholder":i.$t(`usage.placeholder.endDate`),onChange:i.onFilterChange},null,8,[`modelValue`,`shortcuts`,`range-separator`,`start-placeholder`,`end-placeholder`,`onChange`]),r(E,{type:`primary`,plain:``,loading:i.exporting,onClick:i.onExport},{default:u(()=>[r(x,{icon:`fa-solid fa-file-export`,class:`mr-1`}),n(` `+o(i.$t(`order.button.export`)),1)]),_:1},8,[`loading`,`onClick`])]),r(y,null,{default:u(()=>[r(v,{span:24},{default:u(()=>[r(S,{shadow:`hover`},{default:u(()=>[ee((s(),e(A,{data:i.orders,stripe:``,"empty-text":i.$t(`common.message.noData`),class:`min-h-[calc(100vh-450px)] mb-[20px]`},{default:u(()=>[r(O,{prop:`id`,label:i.$t(`order.field.id`),"class-name":`text-center`,width:`200px`},{default:u(e=>[t(`span`,X,o(e.row.id),1),t(`span`,Z,[r(D,{content:e.row.id,class:`inline-block`},null,8,[`content`])])]),_:1},8,[`label`]),r(O,{label:i.$t(`order.field.price`),width:`110px`,align:`center`},{default:u(e=>[t(`span`,Q,o(i.getPriceString({value:e.row?.price})),1)]),_:1},8,[`label`]),r(O,{label:i.$t(`order.field.description`),"min-width":`220px`,"class-name":`hidden md:table-cell`,"label-class-name":`hidden md:table-cell`},{default:u(e=>[t(`span`,ne,o(e.row.description),1)]),_:1},8,[`label`]),r(O,{prop:`state`,label:i.$t(`order.field.state`),width:`130px`,align:`center`},{default:u(e=>[r(k,{type:i.stateTagType(e.row.state),class:`mx-1`,effect:`dark`,round:``,size:`small`},{default:u(()=>[n(o(i.stateLabel(e.row.state)),1)]),_:2},1032,[`type`])]),_:1},8,[`label`]),r(O,{label:i.$t(`order.field.payWay`),width:`120px`,align:`center`,"class-name":`hidden md:table-cell`,"label-class-name":`hidden md:table-cell`},{default:u(e=>[t(`span`,re,o(e.row.pay_way||`-`),1)]),_:1},8,[`label`]),r(O,{label:i.$t(`order.field.createdAt`),width:`200px`,"class-name":`hidden sm:table-cell`,"label-class-name":`hidden sm:table-cell`},{default:u(e=>[t(`span`,$,o(i.$dayjs.format(e.row.created_at)),1)]),_:1},8,[`label`]),r(O,{"min-width":`130px`,fixed:`right`},{default:u(r=>[t(`div`,ie,[i.isPendingAction(r.row.state)?(s(),e(E,{key:0,type:`primary`,size:`small`,onClick:e=>i.goToDetail(r.row.id)},{default:u(()=>[n(o(i.$t(`order.button.continuePay`)),1)]),_:1},8,[`onClick`])):(s(),e(E,{key:1,size:`small`,onClick:e=>i.goToDetail(r.row.id)},{default:u(()=>[n(o(i.$t(`order.button.checkDetail`)),1)]),_:1},8,[`onClick`]))])]),_:1})]),_:1},8,[`data`,`empty-text`])),[[M,i.loading]])]),_:1})]),_:1})]),_:1}),r(y,null,{default:u(()=>[r(v,{span:10,offset:14},{default:u(()=>[t(`div`,ae,[r(j,{"current-page":i.page,"page-size":i.limit,total:i.total,onChange:i.onPageChange},null,8,[`current-page`,`page-size`,`total`,`onChange`])])]),_:1})]),_:1})]),_:1})]),_:1})}var se=T(M,[[`render`,oe],[`__scopeId`,`data-v-350ab467`]]);export{se as default};
|