@acedatacloud/nexior 3.25.3 → 3.25.5
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/Auth-CJ0DaPHM.js +1 -0
- package/dist/assets/BotPlaceholder-CbNYjS1E.js +1 -0
- package/dist/assets/Callback-CB_2XSiA.js +1 -0
- package/dist/assets/Console-NwT2bGyI.js +1 -0
- package/dist/assets/Conversation-C5ZhOzsL.css +1 -0
- package/dist/assets/Conversation-CgUpOKXk.js +2 -0
- package/dist/assets/CopyToClipboard-ZLH7uqrY.js +1 -0
- package/dist/assets/Detail-Bd0gq1yC.js +1 -0
- package/dist/assets/EditArray-CJlPXh_Q.js +1 -0
- package/dist/assets/Extra-B6QX3VEK.js +1 -0
- package/dist/assets/FilePreview-DLsXfWXH.js +1 -0
- package/dist/assets/History-CJYU-Tmf.js +1 -0
- package/dist/assets/ImagePreview-DsZM4u3Y.js +1 -0
- package/dist/assets/ImageWrapper-DqojA33M.js +1 -0
- package/dist/assets/Index-B2o5W9u6.js +1 -0
- package/dist/assets/Index-BJygeqrX.js +1 -0
- package/dist/assets/Index-BNRXk1Rj.js +1 -0
- package/dist/assets/Index-BT_9uBF9.js +1 -0
- package/dist/assets/Index-BTe3niR4.js +1 -0
- package/dist/assets/Index-BtXmnr9E.js +1 -0
- package/dist/assets/Index-Bu4HVIld.js +1 -0
- package/dist/assets/Index-CEwpppRo.js +1 -0
- package/dist/assets/Index-CLVFxYyc.js +1 -0
- package/dist/assets/Index-CfArDmXT.js +1 -0
- package/dist/assets/Index-Crt1Y1Qh.js +1 -0
- package/dist/assets/Index-DHnc_KAQ.js +1 -0
- package/dist/assets/Index-DMbgfEC7.js +1 -0
- package/dist/assets/Index-VIyMnOKp.js +1 -0
- package/dist/assets/Index-hOJoQGFw.js +1 -0
- package/dist/assets/Index-qlOE81B4.js +1 -0
- package/dist/assets/Invitees-BL-KvLxZ.js +1 -0
- package/dist/assets/List-DVAPLnZ_.js +1 -0
- package/dist/assets/List-HGKe7w9p.js +1 -0
- package/dist/assets/List-j3lhFo7i.js +1 -0
- package/dist/assets/Login-C54AEkPD.js +1 -0
- package/dist/assets/Main-BHyj3G_S.js +1 -0
- package/dist/assets/Navigator-C4u93_mi.js +1 -0
- package/dist/assets/NoTasks-C4GBAEFK.js +1 -0
- package/dist/assets/Pagination-B7408PXm.js +1 -0
- package/dist/assets/ScrollList-CsMofi7R.js +1 -0
- package/dist/assets/Status-D9NZiT2g.js +1 -0
- package/dist/assets/Subscribe-CKCx3O2H.js +1 -0
- package/dist/assets/VideoPlayer-CUqP_b1_.js +1 -0
- package/dist/assets/distribution-BpIng5_3.js +1 -0
- package/dist/assets/index-B9SFMWwY.js +3 -0
- package/dist/assets/{index-B2k0ADfO.css → index-BCMAhGTb.css} +1 -1
- package/dist/assets/order-CwymXjrK.js +1 -0
- package/dist/assets/pagination-DjyMgG1D.js +1 -0
- package/dist/assets/price-Cw72dIAB.js +1 -0
- package/dist/assets/vendor-C8YexQz0.css +1 -0
- package/dist/assets/vendor-CdFdgkAf.js +662 -0
- package/dist/assets/vendor-axios-NIGUFBhG.js +6 -0
- package/dist/assets/vendor-chart-CCwTaxpO.js +13 -0
- package/dist/assets/vendor-dayjs-DbiJaq7z.js +1 -0
- package/dist/assets/vendor-element-plus-BFf0lqAh.js +6 -0
- package/dist/assets/vendor-highlight-B6IKYKoD.js +5 -0
- package/dist/assets/vendor-highlight-t6bI8mSi.css +1 -0
- package/dist/assets/vendor-katex-CIur2ABi.css +1 -0
- package/dist/assets/vendor-katex-DHBGsivc.js +261 -0
- package/dist/assets/vendor-vue-router-BTuxvTV5.js +5 -0
- package/dist/assets/vendor-vue-xzGp4vaJ.js +17 -0
- package/dist/index.html +11 -2
- package/package.json +1 -1
- package/dist/assets/Auth-BAVRMp6L.js +0 -1
- package/dist/assets/BotPlaceholder-CtFILLeB.js +0 -1
- package/dist/assets/Callback-DpIM_838.js +0 -1
- package/dist/assets/Console-CDJURLxP.js +0 -1
- package/dist/assets/Conversation-B-OZlC82.css +0 -1
- package/dist/assets/Conversation-D_P8GMTY.js +0 -283
- package/dist/assets/CopyToClipboard-CKnPT0Yy.js +0 -1
- package/dist/assets/Detail-Cim8PyGl.js +0 -1
- package/dist/assets/EditArray-DHQtoDhh.js +0 -1
- package/dist/assets/Extra-CjYvGoiS.js +0 -1
- package/dist/assets/FilePreview-KrsId5y0.js +0 -1
- package/dist/assets/History-FGagPbIH.js +0 -1
- package/dist/assets/ImagePreview-C3EplpU3.js +0 -1
- package/dist/assets/ImageWrapper-B0Hctn8N.js +0 -1
- package/dist/assets/Index-BEzQfqZW.js +0 -1
- package/dist/assets/Index-BoUh8rE4.js +0 -1
- package/dist/assets/Index-CPOeHkg3.js +0 -1
- package/dist/assets/Index-CYAU948Y.js +0 -1
- package/dist/assets/Index-Cm4W7u2z.js +0 -1
- package/dist/assets/Index-CyMW6_MG.js +0 -1
- package/dist/assets/Index-CyrPGsQw.js +0 -1
- package/dist/assets/Index-CzWh3OHC.js +0 -1
- package/dist/assets/Index-D0PkMT8b.js +0 -1
- package/dist/assets/Index-DXpUSliV.js +0 -1
- package/dist/assets/Index-Ef7vPll2.js +0 -1
- package/dist/assets/Index-IRicAOyv.js +0 -1
- package/dist/assets/Index-O4780d4s.js +0 -1
- package/dist/assets/Index-QED7V_pF.js +0 -1
- package/dist/assets/Index-b3bFQjNF.js +0 -1
- package/dist/assets/Index-rqyiXP2a.js +0 -1
- package/dist/assets/Invitees-DlL3K0F2.js +0 -1
- package/dist/assets/List-BAG6RXL7.js +0 -1
- package/dist/assets/List-C0b_eaw4.js +0 -1
- package/dist/assets/List-Ccd3AMjw.js +0 -18
- package/dist/assets/Login-BQpldml9.js +0 -1
- package/dist/assets/Main-Dao43QYb.js +0 -1
- package/dist/assets/Navigator-MlLx66A3.js +0 -1
- package/dist/assets/NoTasks-DQ7pIoDL.js +0 -1
- package/dist/assets/Pagination-BeOOFcDV.js +0 -1
- package/dist/assets/ScrollList-C4AvmP4t.js +0 -1
- package/dist/assets/Status-vZ1rQ3lN.js +0 -1
- package/dist/assets/Subscribe-D_qxrpO3.js +0 -1
- package/dist/assets/VideoPlayer-DY5ni_KU.js +0 -1
- package/dist/assets/_baseClone-DLKkk350.js +0 -1
- package/dist/assets/_baseIteratee-h4YesYRm.js +0 -1
- package/dist/assets/_initCloneObject-x8T6HgBa.js +0 -1
- package/dist/assets/ar-D1hnTQ2h.js +0 -1
- package/dist/assets/castArray-BE-37zzM.js +0 -1
- package/dist/assets/de-BZu7ZZ9y.js +0 -1
- package/dist/assets/debounce-jV-EFVoU.js +0 -1
- package/dist/assets/distribution-CQdKw898.js +0 -1
- package/dist/assets/dropdown-0eUq7NmC.js +0 -1
- package/dist/assets/el-DJ93mLwP.js +0 -1
- package/dist/assets/es-Idilhmtq.js +0 -1
- package/dist/assets/fi-BhhlDzr_.js +0 -1
- package/dist/assets/fr-fyTGkfid.js +0 -1
- package/dist/assets/index-B5XgLesb.js +0 -1
- package/dist/assets/index-BC-mE-tS.js +0 -1
- package/dist/assets/index-BCjzbT-b.js +0 -1
- package/dist/assets/index-BEyVHt6t.js +0 -1
- package/dist/assets/index-BMPWNh9b.js +0 -1
- package/dist/assets/index-Bc_Nx_id.js +0 -1
- package/dist/assets/index-BfF_0NJH.js +0 -1
- package/dist/assets/index-BgXxVbPA.js +0 -1
- package/dist/assets/index-Bho_18eF.js +0 -1
- package/dist/assets/index-CJ7_cRvg.js +0 -1
- package/dist/assets/index-CMw1UhQp.js +0 -1
- package/dist/assets/index-CkVl7iBl.js +0 -1
- package/dist/assets/index-ColRDeFN.js +0 -1
- package/dist/assets/index-Ctzntth0.js +0 -12
- package/dist/assets/index-Cw9L-zKb.js +0 -1
- package/dist/assets/index-D6ExfvwJ.js +0 -1
- package/dist/assets/index-DA6TtE0k.js +0 -14
- package/dist/assets/index-DNGtZjAF.js +0 -6
- package/dist/assets/index-Di3ATEOn.js +0 -1
- package/dist/assets/index-Dnu2OPRk.js +0 -638
- package/dist/assets/index-DrVAEdYb.js +0 -10
- package/dist/assets/index-EfId_jUB.js +0 -1
- package/dist/assets/index-HtOPMbaD.js +0 -1
- package/dist/assets/index-IoPWd1CW.js +0 -1
- package/dist/assets/index-QURzAjz3.js +0 -1
- package/dist/assets/index-YQkAS5Xe.js +0 -1
- package/dist/assets/index-ic1fhPbo.js +0 -1
- package/dist/assets/index-qutB5SLT.js +0 -1
- package/dist/assets/index-r5W6hzzQ.js +0 -1
- package/dist/assets/index-sdnXBDq8.js +0 -1
- package/dist/assets/index-tefvU5dL.js +0 -1
- package/dist/assets/index.es-DYon9dPn.js +0 -1
- package/dist/assets/isEqual-DKKEkL9d.js +0 -1
- package/dist/assets/isPlainObject-CJztbzXj.js +0 -1
- package/dist/assets/it-CLf6lrMi.js +0 -1
- package/dist/assets/ja-DFyNu3tl.js +0 -1
- package/dist/assets/ko-DUrUYy0R.js +0 -1
- package/dist/assets/order-DK-NCLNt.js +0 -1
- package/dist/assets/pagination-CbSBe_dl.js +0 -1
- package/dist/assets/pl-By8ttK5W.js +0 -1
- package/dist/assets/price-C1dIgmfP.js +0 -1
- package/dist/assets/pt-iBE8V_rF.js +0 -1
- package/dist/assets/ru-a9O4dLvt.js +0 -1
- package/dist/assets/sr-BuqPpavQ.js +0 -1
- package/dist/assets/strings-BehOGHwd.js +0 -1
- package/dist/assets/sv-CiSSmJ4h.js +0 -1
- package/dist/assets/typescript-DcpNvO9f.js +0 -1
- package/dist/assets/uk-Ci2KIGcW.js +0 -1
- package/dist/assets/use-form-item-lM5U-69n.js +0 -1
- package/dist/assets/vue-plyr-BqJN4-Iw.css +0 -1
- package/dist/assets/vue-plyr-QZFBikSk.js +0 -2
- package/dist/assets/zh-cn-CnyULPxw.js +0 -1
- package/dist/assets/zh-tw-ZQmLUxJy.js +0 -1
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{c as s,d as c}from"./vendor-element-plus-BFf0lqAh.js";import{f as i,Q as m,R as t,t as e,ak as o,j as p}from"./vendor-vue-xzGp4vaJ.js";import{_}from"./index-B9SFMWwY.js";import"./vendor-CdFdgkAf.js";import"./vendor-katex-DHBGsivc.js";import"./vendor-dayjs-DbiJaq7z.js";import"./vendor-axios-NIGUFBhG.js";import"./vendor-vue-router-BTuxvTV5.js";const l=i({name:"LayoutAuth",components:{ElContainer:c,ElMain:s}});function f(u,d,h,v,x,C){const n=o("router-view"),r=o("el-main"),a=o("el-container");return p(),m(a,null,{default:t(()=>[e(r,{class:"h-[100vh]"},{default:t(()=>[e(n)]),_:1})]),_:1})}const L=_(l,[["render",f]]);export{L as default};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{S as p,F as c}from"./vendor-element-plus-BFf0lqAh.js";import{f as r,h as m,ah as i,F as _,ak as s,j as d,i as o,t as e,R as n}from"./vendor-vue-xzGp4vaJ.js";import{_ as x}from"./index-B9SFMWwY.js";const f=r({name:"BotPlaceholder",components:{ElSkeleton:c,ElSkeletonItem:p}}),k={class:"w-[70px] p-[10px]"},h={class:"flex-1 p-[10px]"};function u(v,w,B,b,$,C){const t=s("el-skeleton-item"),a=s("el-skeleton");return d(),m(_,null,i(3,l=>o("div",{key:l,class:"flex mb-[10px]"},[o("div",k,[e(a,{animated:""},{template:n(()=>[e(t,{variant:"image",class:"w-[50px] h-[50px] rounded-full"})]),_:1})]),o("div",h,[e(a,{animated:""},{template:n(()=>[e(t,{variant:"p",class:"w-[200px] h-[20px] mb-[15px] block"}),e(t,{variant:"p",class:"w-full h-[200px] max-w-[300px] block"})]),_:1})])])),64)}const g=x(f,[["render",u]]);export{g as B};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{f as t}from"./vendor-vue-xzGp4vaJ.js";import{_ as r}from"./index-B9SFMWwY.js";import"./vendor-CdFdgkAf.js";import"./vendor-katex-DHBGsivc.js";import"./vendor-axios-NIGUFBhG.js";import"./vendor-vue-router-BTuxvTV5.js";import"./vendor-element-plus-BFf0lqAh.js";import"./vendor-dayjs-DbiJaq7z.js";const e=t({name:"AuthCallback",data(){return{redirect:this.$route.query.redirect?.toString()}},async mounted(){this.redirect?await this.$router.push(this.redirect):await this.$router.push("/")}}),d=r(e,[["__scopeId","data-v-0779b8a8"]]);export{d as default};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{N as h}from"./Navigator-C4u93_mi.js";import{R as $,a as v,b as w,c as N,i as O,_ as l}from"./index-B9SFMWwY.js";import{bN as g}from"./vendor-CdFdgkAf.js";import{f as d,h as a,i as s,F as L,ah as C,ak as i,j as t,U as E,t as r,Y as b,Q as k,V as I}from"./vendor-vue-xzGp4vaJ.js";import"./vendor-element-plus-BFf0lqAh.js";import"./vendor-dayjs-DbiJaq7z.js";import"./EditArray-CJlPXh_Q.js";import"./vendor-axios-NIGUFBhG.js";import"./vendor-vue-router-BTuxvTV5.js";import"./vendor-katex-DHBGsivc.js";const S=d({name:"Navigator",components:{FontAwesomeIcon:g},computed:{isOfficial(){return O()},active(){return this.$route.matched[0].path},user(){return this.$store.getters.user},links(){return[{key:"application-list",text:this.$t("console.menu.applicationList"),name:v,icon:"fa-solid fa-cube"},{key:"order-list",text:this.$t("console.menu.orderList"),name:w,icon:"fa-solid fa-store"},{key:"usage-list",text:this.$t("console.menu.usageList"),name:N,icon:"fa-solid fa-rotate-left"}]}},mounted(){},methods:{onHome(){this.$router.push({name:$})},onNavigate(e){e.name?this.$router.push({name:e.name}):e.href&&window.open(e.href,"_blank")}}}),x={class:"side"},T={class:"links"},y=["onClick"],R={class:"icon"},U={class:"text"},A={class:"outer"};function B(e,c,_,p,u,f){const n=i("font-awesome-icon");return t(),a("div",x,[s("div",T,[(t(!0),a(L,null,C(e.links,(o,m)=>(t(),a("a",{key:m,class:E({link:!0,active:e.$route.name===o.name}),onClick:W=>e.onNavigate(o)},[s("span",R,[r(n,{icon:o.icon,class:"text-sm"},null,8,["icon"])]),s("span",U,b(o.text),1),s("span",A,[!o.name&&o.href?(t(),k(n,{key:0,icon:"fa-solid fa-up-right-from-square",class:"text-sm ml-2"})):I("",!0)]),c[0]||(c[0]=s("span",{class:"suffix"},null,-1))],10,y))),128))])])}const V=l(S,[["render",B],["__scopeId","data-v-fe27dc30"]]),D=d({name:"LayoutConsole",components:{SidePanel:V,Navigator:h},data(){return{mobile:window.innerWidth<768}},mounted(){window.addEventListener("resize",()=>{this.mobile=window.innerWidth<768})}}),F={class:"console"},P={class:"main"};function z(e,c,_,p,u,f){const n=i("side-panel"),o=i("router-view"),m=i("navigator");return t(),a("div",F,[s("div",P,[r(n,{class:"side"}),r(o,{class:"panel"})]),r(m,{class:"navigator",direction:e.mobile?"row":"column"},null,8,["direction"])])}const Z=l(D,[["render",z],["__scopeId","data-v-b192cbb4"]]);export{Z as default};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
@keyframes blink{0%{opacity:1}50%{opacity:0}to{opacity:1}}.mark{width:2px;height:16px;margin-top:3px;background-color:var(--el-text-color-primary);animation:blink 1s infinite}.markdown-body{--base-size-4: .25rem;--base-size-8: .5rem;--base-size-16: 1rem;--base-size-24: 1.5rem;--base-size-40: 2.5rem;--base-text-weight-normal: 400;--base-text-weight-medium: 500;--base-text-weight-semibold: 600;--fontStack-monospace: ui-monospace, SFMono-Regular, SF Mono, Menlo, Consolas, Liberation Mono, monospace;--fgColor-accent: Highlight}@media (prefers-color-scheme: dark){.markdown-body,[data-theme=dark]{color-scheme:dark;--focus-outlineColor: #1f6feb;--fgColor-default: #f0f6fc;--fgColor-muted: #9198a1;--fgColor-accent: #4493f8;--fgColor-success: #3fb950;--fgColor-attention: #d29922;--fgColor-danger: #f85149;--fgColor-done: #ab7df8;--bgColor-default: #0d1117;--bgColor-muted: #151b23;--bgColor-neutral-muted: #656c7633;--bgColor-attention-muted: #bb800926;--borderColor-default: #3d444d;--borderColor-muted: #3d444db3;--borderColor-neutral-muted: #3d444db3;--borderColor-accent-emphasis: #1f6feb;--borderColor-success-emphasis: #238636;--borderColor-attention-emphasis: #9e6a03;--borderColor-danger-emphasis: #da3633;--borderColor-done-emphasis: #8957e5;--color-prettylights-syntax-comment: #9198a1;--color-prettylights-syntax-constant: #79c0ff;--color-prettylights-syntax-constant-other-reference-link: #a5d6ff;--color-prettylights-syntax-entity: #d2a8ff;--color-prettylights-syntax-storage-modifier-import: #f0f6fc;--color-prettylights-syntax-entity-tag: #7ee787;--color-prettylights-syntax-keyword: #ff7b72;--color-prettylights-syntax-string: #a5d6ff;--color-prettylights-syntax-variable: #ffa657;--color-prettylights-syntax-brackethighlighter-unmatched: #f85149;--color-prettylights-syntax-brackethighlighter-angle: #9198a1;--color-prettylights-syntax-invalid-illegal-text: #f0f6fc;--color-prettylights-syntax-invalid-illegal-bg: #8e1519;--color-prettylights-syntax-carriage-return-text: #f0f6fc;--color-prettylights-syntax-carriage-return-bg: #b62324;--color-prettylights-syntax-string-regexp: #7ee787;--color-prettylights-syntax-markup-list: #f2cc60;--color-prettylights-syntax-markup-heading: #1f6feb;--color-prettylights-syntax-markup-italic: #f0f6fc;--color-prettylights-syntax-markup-bold: #f0f6fc;--color-prettylights-syntax-markup-deleted-text: #ffdcd7;--color-prettylights-syntax-markup-deleted-bg: #67060c;--color-prettylights-syntax-markup-inserted-text: #aff5b4;--color-prettylights-syntax-markup-inserted-bg: #033a16;--color-prettylights-syntax-markup-changed-text: #ffdfb6;--color-prettylights-syntax-markup-changed-bg: #5a1e02;--color-prettylights-syntax-markup-ignored-text: #f0f6fc;--color-prettylights-syntax-markup-ignored-bg: #1158c7;--color-prettylights-syntax-meta-diff-range: #d2a8ff;--color-prettylights-syntax-sublimelinter-gutter-mark: #3d444d}}@media (prefers-color-scheme: light){.markdown-body,[data-theme=light]{color-scheme:light;--focus-outlineColor: #0969da;--fgColor-default: #1f2328;--fgColor-muted: #59636e;--fgColor-accent: #0969da;--fgColor-success: #1a7f37;--fgColor-attention: #9a6700;--fgColor-danger: #d1242f;--fgColor-done: #8250df;--bgColor-default: #ffffff;--bgColor-muted: #f6f8fa;--bgColor-neutral-muted: #818b981f;--bgColor-attention-muted: #fff8c5;--borderColor-default: #d1d9e0;--borderColor-muted: #d1d9e0b3;--borderColor-neutral-muted: #d1d9e0b3;--borderColor-accent-emphasis: #0969da;--borderColor-success-emphasis: #1a7f37;--borderColor-attention-emphasis: #9a6700;--borderColor-danger-emphasis: #cf222e;--borderColor-done-emphasis: #8250df;--color-prettylights-syntax-comment: #59636e;--color-prettylights-syntax-constant: #0550ae;--color-prettylights-syntax-constant-other-reference-link: #0a3069;--color-prettylights-syntax-entity: #6639ba;--color-prettylights-syntax-storage-modifier-import: #1f2328;--color-prettylights-syntax-entity-tag: #0550ae;--color-prettylights-syntax-keyword: #cf222e;--color-prettylights-syntax-string: #0a3069;--color-prettylights-syntax-variable: #953800;--color-prettylights-syntax-brackethighlighter-unmatched: #82071e;--color-prettylights-syntax-brackethighlighter-angle: #59636e;--color-prettylights-syntax-invalid-illegal-text: #f6f8fa;--color-prettylights-syntax-invalid-illegal-bg: #82071e;--color-prettylights-syntax-carriage-return-text: #f6f8fa;--color-prettylights-syntax-carriage-return-bg: #cf222e;--color-prettylights-syntax-string-regexp: #116329;--color-prettylights-syntax-markup-list: #3b2300;--color-prettylights-syntax-markup-heading: #0550ae;--color-prettylights-syntax-markup-italic: #1f2328;--color-prettylights-syntax-markup-bold: #1f2328;--color-prettylights-syntax-markup-deleted-text: #82071e;--color-prettylights-syntax-markup-deleted-bg: #ffebe9;--color-prettylights-syntax-markup-inserted-text: #116329;--color-prettylights-syntax-markup-inserted-bg: #dafbe1;--color-prettylights-syntax-markup-changed-text: #953800;--color-prettylights-syntax-markup-changed-bg: #ffd8b5;--color-prettylights-syntax-markup-ignored-text: #d1d9e0;--color-prettylights-syntax-markup-ignored-bg: #0550ae;--color-prettylights-syntax-meta-diff-range: #8250df;--color-prettylights-syntax-sublimelinter-gutter-mark: #818b98}}.markdown-body{-ms-text-size-adjust:100%;-webkit-text-size-adjust:100%;margin:0;color:var(--fgColor-default);background-color:var(--bgColor-default);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Noto Sans,Helvetica,Arial,sans-serif,"Apple Color Emoji","Segoe UI Emoji";font-size:16px;line-height:1.5;word-wrap:break-word}.markdown-body .octicon{display:inline-block;fill:currentColor;vertical-align:text-bottom}.markdown-body h1:hover .anchor .octicon-link:before,.markdown-body h2:hover .anchor .octicon-link:before,.markdown-body h3:hover .anchor .octicon-link:before,.markdown-body h4:hover .anchor .octicon-link:before,.markdown-body h5:hover .anchor .octicon-link:before,.markdown-body h6:hover .anchor .octicon-link:before{width:16px;height:16px;content:" ";display:inline-block;background-color:currentColor;-webkit-mask-image:url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' version='1.1' aria-hidden='true'><path fill-rule='evenodd' d='M7.775 3.275a.75.75 0 001.06 1.06l1.25-1.25a2 2 0 112.83 2.83l-2.5 2.5a2 2 0 01-2.83 0 .75.75 0 00-1.06 1.06 3.5 3.5 0 004.95 0l2.5-2.5a3.5 3.5 0 00-4.95-4.95l-1.25 1.25zm-4.69 9.64a2 2 0 010-2.83l2.5-2.5a2 2 0 012.83 0 .75.75 0 001.06-1.06 3.5 3.5 0 00-4.95 0l-2.5 2.5a3.5 3.5 0 004.95 4.95l1.25-1.25a.75.75 0 00-1.06-1.06l-1.25 1.25a2 2 0 01-2.83 0z'></path></svg>");mask-image:url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' version='1.1' aria-hidden='true'><path fill-rule='evenodd' d='M7.775 3.275a.75.75 0 001.06 1.06l1.25-1.25a2 2 0 112.83 2.83l-2.5 2.5a2 2 0 01-2.83 0 .75.75 0 00-1.06 1.06 3.5 3.5 0 004.95 0l2.5-2.5a3.5 3.5 0 00-4.95-4.95l-1.25 1.25zm-4.69 9.64a2 2 0 010-2.83l2.5-2.5a2 2 0 012.83 0 .75.75 0 001.06-1.06 3.5 3.5 0 00-4.95 0l-2.5 2.5a3.5 3.5 0 004.95 4.95l1.25-1.25a.75.75 0 00-1.06-1.06l-1.25 1.25a2 2 0 01-2.83 0z'></path></svg>")}.markdown-body details,.markdown-body figcaption,.markdown-body figure{display:block}.markdown-body summary{display:list-item}.markdown-body [hidden]{display:none!important}.markdown-body a{background-color:transparent;color:var(--fgColor-accent);text-decoration:none}.markdown-body abbr[title]{border-bottom:none;-webkit-text-decoration:underline dotted;text-decoration:underline dotted}.markdown-body b,.markdown-body strong{font-weight:var(--base-text-weight-semibold, 600)}.markdown-body dfn{font-style:italic}.markdown-body h1{margin:.67em 0;font-weight:var(--base-text-weight-semibold, 600);padding-bottom:.3em;font-size:2em;border-bottom:1px solid var(--borderColor-muted)}.markdown-body mark{background-color:var(--bgColor-attention-muted);color:var(--fgColor-default)}.markdown-body small{font-size:90%}.markdown-body sub,.markdown-body sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}.markdown-body sub{bottom:-.25em}.markdown-body sup{top:-.5em}.markdown-body img{border-style:none;max-width:100%;box-sizing:content-box}.markdown-body code,.markdown-body kbd,.markdown-body pre,.markdown-body samp{font-family:monospace;font-size:1em}.markdown-body figure{margin:1em var(--base-size-40)}.markdown-body hr{box-sizing:content-box;overflow:hidden;background:transparent;border-bottom:1px solid var(--borderColor-muted);height:.25em;padding:0;margin:var(--base-size-24) 0;background-color:var(--borderColor-default);border:0}.markdown-body input{font:inherit;margin:0;overflow:visible;font-family:inherit;font-size:inherit;line-height:inherit}.markdown-body [type=button],.markdown-body [type=reset],.markdown-body [type=submit]{-webkit-appearance:button;-moz-appearance:button;appearance:button}.markdown-body [type=checkbox],.markdown-body [type=radio]{box-sizing:border-box;padding:0}.markdown-body [type=number]::-webkit-inner-spin-button,.markdown-body [type=number]::-webkit-outer-spin-button{height:auto}.markdown-body [type=search]::-webkit-search-cancel-button,.markdown-body [type=search]::-webkit-search-decoration{-webkit-appearance:none;appearance:none}.markdown-body ::-webkit-input-placeholder{color:inherit;opacity:.54}.markdown-body ::-webkit-file-upload-button{-webkit-appearance:button;appearance:button;font:inherit}.markdown-body a:hover{text-decoration:underline}.markdown-body ::-moz-placeholder{color:var(--fgColor-muted);opacity:1}.markdown-body ::placeholder{color:var(--fgColor-muted);opacity:1}.markdown-body hr:before{display:table;content:""}.markdown-body hr:after{display:table;clear:both;content:""}.markdown-body table{border-spacing:0;border-collapse:collapse;display:block;width:-moz-max-content;width:max-content;max-width:100%;overflow:auto;font-variant:tabular-nums}.markdown-body td,.markdown-body th{padding:0}.markdown-body details summary{cursor:pointer}.markdown-body a:focus,.markdown-body [role=button]:focus,.markdown-body input[type=radio]:focus,.markdown-body input[type=checkbox]:focus{outline:2px solid var(--focus-outlineColor);outline-offset:-2px;box-shadow:none}.markdown-body a:focus:not(:focus-visible),.markdown-body [role=button]:focus:not(:focus-visible),.markdown-body input[type=radio]:focus:not(:focus-visible),.markdown-body input[type=checkbox]:focus:not(:focus-visible){outline:solid 1px transparent}.markdown-body a:focus-visible,.markdown-body [role=button]:focus-visible,.markdown-body input[type=radio]:focus-visible,.markdown-body input[type=checkbox]:focus-visible{outline:2px solid var(--focus-outlineColor);outline-offset:-2px;box-shadow:none}.markdown-body a:not([class]):focus,.markdown-body a:not([class]):focus-visible,.markdown-body input[type=radio]:focus,.markdown-body input[type=radio]:focus-visible,.markdown-body input[type=checkbox]:focus,.markdown-body input[type=checkbox]:focus-visible{outline-offset:0}.markdown-body kbd{display:inline-block;padding:var(--base-size-4);font:11px var(--fontStack-monospace, ui-monospace, SFMono-Regular, SF Mono, Menlo, Consolas, Liberation Mono, monospace);line-height:10px;color:var(--fgColor-default);vertical-align:middle;background-color:var(--bgColor-muted);border:solid 1px var(--borderColor-neutral-muted);border-bottom-color:var(--borderColor-neutral-muted);border-radius:6px;box-shadow:inset 0 -1px 0 var(--borderColor-neutral-muted)}.markdown-body h1,.markdown-body h2,.markdown-body h3,.markdown-body h4,.markdown-body h5,.markdown-body h6{margin-top:var(--base-size-24);margin-bottom:var(--base-size-16);font-weight:var(--base-text-weight-semibold, 600);line-height:1.25}.markdown-body h2{font-weight:var(--base-text-weight-semibold, 600);padding-bottom:.3em;font-size:1.5em;border-bottom:1px solid var(--borderColor-muted)}.markdown-body h3{font-weight:var(--base-text-weight-semibold, 600);font-size:1.25em}.markdown-body h4{font-weight:var(--base-text-weight-semibold, 600);font-size:1em}.markdown-body h5{font-weight:var(--base-text-weight-semibold, 600);font-size:.875em}.markdown-body h6{font-weight:var(--base-text-weight-semibold, 600);font-size:.85em;color:var(--fgColor-muted)}.markdown-body p{margin-top:0;margin-bottom:10px}.markdown-body blockquote{margin:0;padding:0 1em;color:var(--fgColor-muted);border-left:.25em solid var(--borderColor-default)}.markdown-body ul,.markdown-body ol{margin-top:0;margin-bottom:0;padding-left:2em}.markdown-body ol ol,.markdown-body ul ol{list-style-type:lower-roman}.markdown-body ul ul ol,.markdown-body ul ol ol,.markdown-body ol ul ol,.markdown-body ol ol ol{list-style-type:lower-alpha}.markdown-body dd{margin-left:0}.markdown-body tt,.markdown-body code,.markdown-body samp{font-family:var(--fontStack-monospace, ui-monospace, SFMono-Regular, SF Mono, Menlo, Consolas, Liberation Mono, monospace);font-size:12px}.markdown-body pre{margin-top:0;margin-bottom:0;font-family:var(--fontStack-monospace, ui-monospace, SFMono-Regular, SF Mono, Menlo, Consolas, Liberation Mono, monospace);font-size:12px;word-wrap:normal}.markdown-body .octicon{display:inline-block;overflow:visible!important;vertical-align:text-bottom;fill:currentColor}.markdown-body input::-webkit-outer-spin-button,.markdown-body input::-webkit-inner-spin-button{margin:0;-webkit-appearance:none;appearance:none}.markdown-body .mr-2{margin-right:var(--base-size-8, 8px)!important}.markdown-body:before{display:table;content:""}.markdown-body:after{display:table;clear:both;content:""}.markdown-body>*:first-child{margin-top:0!important}.markdown-body>*:last-child{margin-bottom:0!important}.markdown-body a:not([href]){color:inherit;text-decoration:none}.markdown-body .absent{color:var(--fgColor-danger)}.markdown-body .anchor{float:left;padding-right:var(--base-size-4);margin-left:-20px;line-height:1}.markdown-body .anchor:focus{outline:none}.markdown-body p,.markdown-body blockquote,.markdown-body ul,.markdown-body ol,.markdown-body dl,.markdown-body table,.markdown-body pre,.markdown-body details{margin-top:0;margin-bottom:var(--base-size-16)}.markdown-body blockquote>:first-child{margin-top:0}.markdown-body blockquote>:last-child{margin-bottom:0}.markdown-body h1 .octicon-link,.markdown-body h2 .octicon-link,.markdown-body h3 .octicon-link,.markdown-body h4 .octicon-link,.markdown-body h5 .octicon-link,.markdown-body h6 .octicon-link{color:var(--fgColor-default);vertical-align:middle;visibility:hidden}.markdown-body h1:hover .anchor,.markdown-body h2:hover .anchor,.markdown-body h3:hover .anchor,.markdown-body h4:hover .anchor,.markdown-body h5:hover .anchor,.markdown-body h6:hover .anchor{text-decoration:none}.markdown-body h1:hover .anchor .octicon-link,.markdown-body h2:hover .anchor .octicon-link,.markdown-body h3:hover .anchor .octicon-link,.markdown-body h4:hover .anchor .octicon-link,.markdown-body h5:hover .anchor .octicon-link,.markdown-body h6:hover .anchor .octicon-link{visibility:visible}.markdown-body h1 tt,.markdown-body h1 code,.markdown-body h2 tt,.markdown-body h2 code,.markdown-body h3 tt,.markdown-body h3 code,.markdown-body h4 tt,.markdown-body h4 code,.markdown-body h5 tt,.markdown-body h5 code,.markdown-body h6 tt,.markdown-body h6 code{padding:0 .2em;font-size:inherit}.markdown-body summary h1,.markdown-body summary h2,.markdown-body summary h3,.markdown-body summary h4,.markdown-body summary h5,.markdown-body summary h6{display:inline-block}.markdown-body summary h1 .anchor,.markdown-body summary h2 .anchor,.markdown-body summary h3 .anchor,.markdown-body summary h4 .anchor,.markdown-body summary h5 .anchor,.markdown-body summary h6 .anchor{margin-left:-40px}.markdown-body summary h1,.markdown-body summary h2{padding-bottom:0;border-bottom:0}.markdown-body ul.no-list,.markdown-body ol.no-list{padding:0;list-style-type:none}.markdown-body ol[type="a s"]{list-style-type:lower-alpha}.markdown-body ol[type="A s"]{list-style-type:upper-alpha}.markdown-body ol[type="i s"]{list-style-type:lower-roman}.markdown-body ol[type="I s"]{list-style-type:upper-roman}.markdown-body ol[type="1"]{list-style-type:decimal}.markdown-body div>ol:not([type]){list-style-type:decimal}.markdown-body ul ul,.markdown-body ul ol,.markdown-body ol ol,.markdown-body ol ul{margin-top:0;margin-bottom:0}.markdown-body li>p{margin-top:var(--base-size-16)}.markdown-body li+li{margin-top:.25em}.markdown-body dl{padding:0}.markdown-body dl dt{padding:0;margin-top:var(--base-size-16);font-size:1em;font-style:italic;font-weight:var(--base-text-weight-semibold, 600)}.markdown-body dl dd{padding:0 var(--base-size-16);margin-bottom:var(--base-size-16)}.markdown-body table th{font-weight:var(--base-text-weight-semibold, 600)}.markdown-body table th,.markdown-body table td{padding:6px 13px;border:1px solid var(--borderColor-default)}.markdown-body table td>:last-child{margin-bottom:0}.markdown-body table tr{background-color:var(--bgColor-default);border-top:1px solid var(--borderColor-muted)}.markdown-body table tr:nth-child(2n){background-color:var(--bgColor-muted)}.markdown-body table img{background-color:transparent}.markdown-body img[align=right]{padding-left:20px}.markdown-body img[align=left]{padding-right:20px}.markdown-body .emoji{max-width:none;vertical-align:text-top;background-color:transparent}.markdown-body span.frame{display:block;overflow:hidden}.markdown-body span.frame>span{display:block;float:left;width:auto;padding:7px;margin:13px 0 0;overflow:hidden;border:1px solid var(--borderColor-default)}.markdown-body span.frame span img{display:block;float:left}.markdown-body span.frame span span{display:block;padding:5px 0 0;clear:both;color:var(--fgColor-default)}.markdown-body span.align-center{display:block;overflow:hidden;clear:both}.markdown-body span.align-center>span{display:block;margin:13px auto 0;overflow:hidden;text-align:center}.markdown-body span.align-center span img{margin:0 auto;text-align:center}.markdown-body span.align-right{display:block;overflow:hidden;clear:both}.markdown-body span.align-right>span{display:block;margin:13px 0 0;overflow:hidden;text-align:right}.markdown-body span.align-right span img{margin:0;text-align:right}.markdown-body span.float-left{display:block;float:left;margin-right:13px;overflow:hidden}.markdown-body span.float-left span{margin:13px 0 0}.markdown-body span.float-right{display:block;float:right;margin-left:13px;overflow:hidden}.markdown-body span.float-right>span{display:block;margin:13px auto 0;overflow:hidden;text-align:right}.markdown-body code,.markdown-body tt{padding:.2em .4em;margin:0;font-size:85%;white-space:break-spaces;background-color:var(--bgColor-neutral-muted);border-radius:6px}.markdown-body code br,.markdown-body tt br{display:none}.markdown-body del code{text-decoration:inherit}.markdown-body samp{font-size:85%}.markdown-body pre code{font-size:100%}.markdown-body pre>code{padding:0;margin:0;word-break:normal;white-space:pre;background:transparent;border:0}.markdown-body .highlight{margin-bottom:var(--base-size-16)}.markdown-body .highlight pre{margin-bottom:0;word-break:normal}.markdown-body .highlight pre,.markdown-body pre{padding:var(--base-size-16);overflow:auto;font-size:85%;line-height:1.45;color:var(--fgColor-default);background-color:var(--bgColor-muted);border-radius:6px}.markdown-body pre code,.markdown-body pre tt{display:inline;max-width:auto;padding:0;margin:0;overflow:visible;line-height:inherit;word-wrap:normal;background-color:transparent;border:0}.markdown-body .csv-data td,.markdown-body .csv-data th{padding:5px;overflow:hidden;font-size:12px;line-height:1;text-align:left;white-space:nowrap}.markdown-body .csv-data .blob-num{padding:10px var(--base-size-8) 9px;text-align:right;background:var(--bgColor-default);border:0}.markdown-body .csv-data tr{border-top:0}.markdown-body .csv-data th{font-weight:var(--base-text-weight-semibold, 600);background:var(--bgColor-muted);border-top:0}.markdown-body [data-footnote-ref]:before{content:"["}.markdown-body [data-footnote-ref]:after{content:"]"}.markdown-body .footnotes{font-size:12px;color:var(--fgColor-muted);border-top:1px solid var(--borderColor-default)}.markdown-body .footnotes ol{padding-left:var(--base-size-16)}.markdown-body .footnotes ol ul{display:inline-block;padding-left:var(--base-size-16);margin-top:var(--base-size-16)}.markdown-body .footnotes li{position:relative}.markdown-body .footnotes li:target:before{position:absolute;top:calc(var(--base-size-8)*-1);right:calc(var(--base-size-8)*-1);bottom:calc(var(--base-size-8)*-1);left:calc(var(--base-size-24)*-1);pointer-events:none;content:"";border:2px solid var(--borderColor-accent-emphasis);border-radius:6px}.markdown-body .footnotes li:target{color:var(--fgColor-default)}.markdown-body .footnotes .data-footnote-backref g-emoji{font-family:monospace}.markdown-body body:has(:modal){padding-right:var(--dialog-scrollgutter)!important}.markdown-body .pl-c{color:var(--color-prettylights-syntax-comment)}.markdown-body .pl-c1,.markdown-body .pl-s .pl-v{color:var(--color-prettylights-syntax-constant)}.markdown-body .pl-e,.markdown-body .pl-en{color:var(--color-prettylights-syntax-entity)}.markdown-body .pl-smi,.markdown-body .pl-s .pl-s1{color:var(--color-prettylights-syntax-storage-modifier-import)}.markdown-body .pl-ent{color:var(--color-prettylights-syntax-entity-tag)}.markdown-body .pl-k{color:var(--color-prettylights-syntax-keyword)}.markdown-body .pl-s,.markdown-body .pl-pds,.markdown-body .pl-s .pl-pse .pl-s1,.markdown-body .pl-sr,.markdown-body .pl-sr .pl-cce,.markdown-body .pl-sr .pl-sre,.markdown-body .pl-sr .pl-sra{color:var(--color-prettylights-syntax-string)}.markdown-body .pl-v,.markdown-body .pl-smw{color:var(--color-prettylights-syntax-variable)}.markdown-body .pl-bu{color:var(--color-prettylights-syntax-brackethighlighter-unmatched)}.markdown-body .pl-ii{color:var(--color-prettylights-syntax-invalid-illegal-text);background-color:var(--color-prettylights-syntax-invalid-illegal-bg)}.markdown-body .pl-c2{color:var(--color-prettylights-syntax-carriage-return-text);background-color:var(--color-prettylights-syntax-carriage-return-bg)}.markdown-body .pl-sr .pl-cce{font-weight:700;color:var(--color-prettylights-syntax-string-regexp)}.markdown-body .pl-ml{color:var(--color-prettylights-syntax-markup-list)}.markdown-body .pl-mh,.markdown-body .pl-mh .pl-en,.markdown-body .pl-ms{font-weight:700;color:var(--color-prettylights-syntax-markup-heading)}.markdown-body .pl-mi{font-style:italic;color:var(--color-prettylights-syntax-markup-italic)}.markdown-body .pl-mb{font-weight:700;color:var(--color-prettylights-syntax-markup-bold)}.markdown-body .pl-md{color:var(--color-prettylights-syntax-markup-deleted-text);background-color:var(--color-prettylights-syntax-markup-deleted-bg)}.markdown-body .pl-mi1{color:var(--color-prettylights-syntax-markup-inserted-text);background-color:var(--color-prettylights-syntax-markup-inserted-bg)}.markdown-body .pl-mc{color:var(--color-prettylights-syntax-markup-changed-text);background-color:var(--color-prettylights-syntax-markup-changed-bg)}.markdown-body .pl-mi2{color:var(--color-prettylights-syntax-markup-ignored-text);background-color:var(--color-prettylights-syntax-markup-ignored-bg)}.markdown-body .pl-mdr{font-weight:700;color:var(--color-prettylights-syntax-meta-diff-range)}.markdown-body .pl-ba{color:var(--color-prettylights-syntax-brackethighlighter-angle)}.markdown-body .pl-sg{color:var(--color-prettylights-syntax-sublimelinter-gutter-mark)}.markdown-body .pl-corl{text-decoration:underline;color:var(--color-prettylights-syntax-constant-other-reference-link)}.markdown-body [role=button]:focus:not(:focus-visible),.markdown-body [role=tabpanel][tabindex="0"]:focus:not(:focus-visible),.markdown-body button:focus:not(:focus-visible),.markdown-body summary:focus:not(:focus-visible),.markdown-body a:focus:not(:focus-visible){outline:none;box-shadow:none}.markdown-body [tabindex="0"]:focus:not(:focus-visible),.markdown-body details-dialog:focus:not(:focus-visible){outline:none}.markdown-body g-emoji{display:inline-block;min-width:1ch;font-family:"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol;font-size:1em;font-style:normal!important;font-weight:var(--base-text-weight-normal, 400);line-height:1;vertical-align:-.075em}.markdown-body g-emoji img{width:1em;height:1em}.markdown-body .task-list-item{list-style-type:none}.markdown-body .task-list-item label{font-weight:var(--base-text-weight-normal, 400)}.markdown-body .task-list-item.enabled label{cursor:pointer}.markdown-body .task-list-item+.task-list-item{margin-top:var(--base-size-4)}.markdown-body .task-list-item .handle{display:none}.markdown-body .task-list-item-checkbox{margin:0 .2em .25em -1.4em;vertical-align:middle}.markdown-body ul:dir(rtl) .task-list-item-checkbox{margin:0 -1.6em .25em .2em}.markdown-body ol:dir(rtl) .task-list-item-checkbox{margin:0 -1.6em .25em .2em}.markdown-body .contains-task-list:hover .task-list-item-convert-container,.markdown-body .contains-task-list:focus-within .task-list-item-convert-container{display:block;width:auto;height:24px;overflow:visible;clip:auto}.markdown-body ::-webkit-calendar-picker-indicator{filter:invert(50%)}.markdown-body .markdown-alert{padding:var(--base-size-8) var(--base-size-16);margin-bottom:var(--base-size-16);color:inherit;border-left:.25em solid var(--borderColor-default)}.markdown-body .markdown-alert>:first-child{margin-top:0}.markdown-body .markdown-alert>:last-child{margin-bottom:0}.markdown-body .markdown-alert .markdown-alert-title{display:flex;font-weight:var(--base-text-weight-medium, 500);align-items:center;line-height:1}.markdown-body .markdown-alert.markdown-alert-note{border-left-color:var(--borderColor-accent-emphasis)}.markdown-body .markdown-alert.markdown-alert-note .markdown-alert-title{color:var(--fgColor-accent)}.markdown-body .markdown-alert.markdown-alert-important{border-left-color:var(--borderColor-done-emphasis)}.markdown-body .markdown-alert.markdown-alert-important .markdown-alert-title{color:var(--fgColor-done)}.markdown-body .markdown-alert.markdown-alert-warning{border-left-color:var(--borderColor-attention-emphasis)}.markdown-body .markdown-alert.markdown-alert-warning .markdown-alert-title{color:var(--fgColor-attention)}.markdown-body .markdown-alert.markdown-alert-tip{border-left-color:var(--borderColor-success-emphasis)}.markdown-body .markdown-alert.markdown-alert-tip .markdown-alert-title{color:var(--fgColor-success)}.markdown-body .markdown-alert.markdown-alert-caution{border-left-color:var(--borderColor-danger-emphasis)}.markdown-body .markdown-alert.markdown-alert-caution .markdown-alert-title{color:var(--fgColor-danger)}.markdown-body>*:first-child>.heading-element:first-child{margin-top:0!important}.markdown-body .highlight pre:has(+.zeroclipboard-container){min-height:52px}.markdown-body ol[data-v-de1f7a52]{list-style:initial}.markdown-body pre code[data-v-de1f7a52]{color:#fff}.icon-sync[data-v-90e169cb]{margin-left:5px;cursor:pointer;color:inherit}.icon-edit[data-v-8e947e8f]{cursor:pointer;color:inherit}.error[data-v-a2be8b8f]{width:-moz-fit-content;width:fit-content;padding:10px 10px 8px;height:45px;border-radius:15px}.btn-buy[data-v-a2be8b8f]{margin:10px auto;border-radius:20px}.message[data-v-a2be8b8f]{display:flex;flex-direction:row;margin-bottom:15px}.message[role=system][data-v-a2be8b8f],.message.hidden[data-v-a2be8b8f]{display:none}.message .author[data-v-a2be8b8f]{width:50px;padding:10px}.message .author .avatar[data-v-a2be8b8f]{width:30px;height:30px;border-radius:50%;border:1px solid var(--el-border-color)}.message .main[data-v-a2be8b8f]{flex:1;width:calc(100% - 50px);display:flex;flex-direction:column}.message.assistant[data-v-a2be8b8f]{align-items:start}.message.assistant .content[data-v-a2be8b8f]{color:var(--el-text-color-primary)}.message.assistant .btn-buy[data-v-a2be8b8f]{display:inline-block;margin-left:5px}.message.user .main[data-v-a2be8b8f]{align-items:flex-end}.message.user .content[data-v-a2be8b8f]{background-color:var(--el-bg-color-page);color:var(--el-text-color-primary);position:relative;width:-moz-fit-content;width:fit-content;max-width:90%}.message.user .content .edits[data-v-a2be8b8f]{background-color:var(--el-bg-color-page);padding:0;min-width:500px;width:100%;height:100%;font-size:16px}.message.user .content .edits .btn-confirm[data-v-a2be8b8f]{background-color:var(--el-color-black);border-color:var(--el-color-black)}@media (max-width: 767px){.message.user .content .edits[data-v-a2be8b8f]{min-width:350px}}.message .content[data-v-a2be8b8f]{border-radius:15px;padding:8px 15px;width:100%;max-width:800px;margin-bottom:5px}.message .content .image[data-v-a2be8b8f]{max-width:100%;max-height:300px;margin:5px 0;border-radius:10px}.message .content .edit-area[data-v-a2be8b8f]{width:100%;min-height:100px;border-radius:10px;padding:8px;margin-bottom:10px}.message .content .edit-buttons[data-v-a2be8b8f]{display:flex;justify-content:flex-end;gap:10px}.message .operations[data-v-a2be8b8f]{display:flex;gap:10px;margin-left:5px;color:var(--el-text-color-regular)}.message .operations .btn-edit[data-v-a2be8b8f]{visibility:hidden}.message .operations .btn-restart[data-v-a2be8b8f],.message .operations .btn-copy[data-v-a2be8b8f]{font-size:12px}.message:hover .operations .btn-edit[data-v-a2be8b8f]{visibility:visible}.message.user .content .edits textarea{outline:none;box-shadow:none;border-radius:0;font-size:16px;border-color:var(--el-bg-color-page);resize:none;background-color:var(--el-bg-color-page);color:var(--el-text-color-primary)}textarea.input{font-size:14px;min-height:55px;max-height:150px;border:none;background:none;box-shadow:none;resize:none;line-height:25px;width:calc(100% - 80px);font-family:var(--el-font-family);padding-top:6px}textarea.input:focus{outline:none}.composer{position:relative}.composer .input textarea{max-height:100px;border:none;background:none;box-shadow:none;resize:none;line-height:35px}.composer .el-upload-list{position:absolute;bottom:-5px;left:50px;height:50px;width:700px;margin:0;padding:0;display:flex;flex-direction:row;align-items:center;justify-content:flex-start;overflow-x:auto;gap:5px;overflow-y:scroll;flex-wrap:wrap}.composer .el-upload-list .el-upload-list__item{margin:0;width:-moz-fit-content;width:fit-content;height:50px;padding:0;border-radius:10px;position:relative}.composer .el-textarea.is-disabled .el-textarea__inner{background-color:initial}.composer[data-v-02d367c1]{width:100%;max-width:800px;margin:auto;position:relative;border-radius:20px;border:1px solid var(--el-border-color-lighter);padding:5px}.composer .upload[data-v-02d367c1]{display:inline-block}.composer .upload.disabled .btn-upload[data-v-02d367c1]{cursor:not-allowed;pointer-events:none;color:var(--el-text-color-disabled)!important}.composer .upload.disabled .btn-upload .icon-attachment[data-v-02d367c1]{color:var(--el-text-color-disabled)!important}.composer .input[data-v-02d367c1]{border:none;width:calc(100% - 16px);margin-left:8px;margin-top:5px;font-size:16px;margin-bottom:50px}.composer .tools[data-v-02d367c1]{position:absolute;left:15px;bottom:15px;display:flex;flex-direction:row;align-items:flex-start}.composer .tools .btn[data-v-02d367c1]{display:block;margin-right:10px;z-index:100;cursor:pointer;border:1px solid var(--el-border-color-lighter);width:-moz-fit-content;width:fit-content;height:36px;line-height:36px;-webkit-user-select:none;-moz-user-select:none;user-select:none}.composer .tools .btn.btn-upload[data-v-02d367c1]{border-radius:50%;width:36px;text-align:center;color:var(--el-text-color-secondary)}.composer .tools .btn.btn-upload .icon-attachment[data-v-02d367c1]{font-size:16px;color:var(--el-text-color-primary)}.composer .btn-send[data-v-02d367c1],.composer .btn-stop[data-v-02d367c1]{--el-button-bg-color: var(--el-color-black);--el-button-border-color: var(--el-color-black);--el-button-outline-color: var(--el-color-info);--el-button-active-color: var(--el-color-info);--el-button-hover-text-color: var(--el-color-white);--el-button-hover-link-text-color: var(--el-color-info);--el-button-hover-bg-color: var(--el-color-info);--el-button-hover-border-color: var(--el-color-info);--el-button-active-bg-color: var(--el-color-info);--el-button-active-border-color: var(--el-color-info);--el-button-disabled-text-color: var(--el-color-white);--el-button-disabled-bg-color: var(--el-color-info);--el-button-disabled-border-color: var(--el-color-info);position:absolute;bottom:15px;right:15px;border-radius:50%;width:36px;height:36px;line-height:36px;text-align:center;font-size:16px}.selector[data-v-6b1200e4]{cursor:pointer;padding:7px 6px;border-radius:15px;margin-bottom:10px}.selector .name[data-v-6b1200e4]{font-size:16px;font-weight:700;display:inline-block;margin-right:5px}.selector .angle[data-v-6b1200e4]{display:inline-block;width:15px}.icon[data-v-6b1200e4]{display:flex;justify-content:center;align-items:center;margin-right:5px}.icon img[data-v-6b1200e4]{width:18px;height:18px;border-radius:50%}.item[data-v-6b1200e4]{display:flex;flex-direction:row}.item .icon img[data-v-6b1200e4]{width:30px;height:30px;border-radius:50%}.item .info[data-v-6b1200e4]{width:calc(100% - 15px)}.item .info .name[data-v-6b1200e4]{font-size:14px;font-weight:700;color:var(--el-text-color-primary);margin:0}.item .info .description[data-v-6b1200e4]{font-size:12px;color:var(--el-text-color-secondary);margin:0}.disclaimer[data-v-d2d980ab]{font-size:12px;color:var(--el-text-color-secondary)}.panel[data-v-c54ecd1a]{display:flex;flex-direction:column;align-items:flex-end;padding:10px;width:250px;height:100%;border-right:none}.panel .conversations[data-v-c54ecd1a]{width:100%;display:flex;flex-direction:column;align-items:center}.panel .conversations .group[data-v-c54ecd1a]{width:100%;display:flex;flex-direction:column;margin-top:10px}.panel .conversations .group .key[data-v-c54ecd1a]{font-size:12px;font-weight:600;width:100%;line-height:40px;padding-left:10px;color:var(--el-text-color-secondary)}.panel .conversations .conversation[data-v-c54ecd1a]{width:100%;height:40px;display:flex;flex-direction:row;line-height:40px;border-radius:10px;padding:0 10px;color:var(--el-text-color-primary);cursor:pointer}.panel .conversations .conversation.active[data-v-c54ecd1a],.panel .conversations .conversation[data-v-c54ecd1a]:hover{background-color:var(--el-bg-color-page)}.panel .conversations .conversation.active .operations[data-v-c54ecd1a],.panel .conversations .conversation:hover .operations[data-v-c54ecd1a]{display:flex;align-items:center;width:50px;gap:8px}.panel .conversations .conversation.active .operations .icon[data-v-c54ecd1a],.panel .conversations .conversation:hover .operations .icon[data-v-c54ecd1a]{cursor:pointer;font-size:14px}.panel .conversations .conversation .icons[data-v-c54ecd1a]{width:30px;padding-left:10px}.panel .conversations .conversation .icons .icon[data-v-c54ecd1a]{font-size:14px}.panel .conversations .conversation .title[data-v-c54ecd1a]{flex:1;font-size:14px;line-height:40px;overflow:hidden;text-overflow:ellipsis;padding-right:8px;color:var(--el-text-color-primary)}.panel .conversations .conversation .operations[data-v-c54ecd1a]{display:none;color:var(--el-text-color-regular)}.menu[data-v-38ff8add]{display:none}@media (max-width: 767px){.main .side[data-v-38ff8add]{display:none}.main .chat[data-v-38ff8add]{width:100%;padding:50px 15px 0 10px}.main .menu[data-v-38ff8add]{display:block;position:fixed;left:20px;top:50px;z-index:2000}}.selector[data-v-8f6d22cf]{width:-moz-max-content;width:max-content;margin-bottom:10px;position:absolute;left:10px;top:10px;z-index:100}.setting[data-v-8f6d22cf]{position:absolute;top:10px;right:10px;margin-bottom:10px}@media (max-width: 767px){.setting[data-v-8f6d22cf]{display:none}}.dialogue[data-v-8f6d22cf]{display:flex;flex-direction:column;width:100%;height:100%;overflow-y:auto;position:relative}.dialogue .disclaimer[data-v-8f6d22cf]{width:100%;text-align:center;font-size:12px;margin:5px 0}.dialogue.empty[data-v-8f6d22cf]{position:relative}.dialogue.empty .starter[data-v-8f6d22cf]{position:absolute;width:100%;top:50%;left:50%;transform:translate(-50%,-50%)}.dialogue .messages[data-v-8f6d22cf]{padding-top:10px;padding:0 calc(50% - 400px);flex:1;overflow-y:scroll}@media (max-width: 1159px){.dialogue .messages[data-v-8f6d22cf]{width:100%;padding:0 15px}}.dialogue .messages .setting[data-v-8f6d22cf]{display:none}.dialogue .messages .message[data-v-8f6d22cf]{margin-bottom:15px}.dialogue .starter[data-v-8f6d22cf]{height:-moz-fit-content;height:fit-content;overflow:hidden}@media (max-width: 1159px){.dialogue .starter[data-v-8f6d22cf]{width:100%;padding:0 15px}}.bottom[data-v-8f6d22cf]{width:100%}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
const __vite__mapDeps=(i,m=__vite__mapDeps,d=(m.f||(m.f=["assets/vendor-highlight-B6IKYKoD.js","assets/vendor-CdFdgkAf.js","assets/vendor-vue-xzGp4vaJ.js","assets/vendor-katex-DHBGsivc.js","assets/vendor-katex-CIur2ABi.css","assets/vendor-C8YexQz0.css","assets/vendor-highlight-t6bI8mSi.css"])))=>i.map(i=>d[i]);
|
|
2
|
+
import{a as le}from"./vendor-axios-NIGUFBhG.js";import{f as k,h as u,j as s,e as de,m as ce,S as A,Q as m,ak as c,ar as Z,R as y,t as p,i as f,V as _,Y as b,F as O,ah as M,ai as F,a0 as I,X as N,U as R,Z as ue,as as pe,a1 as he,M as j}from"./vendor-vue-xzGp4vaJ.js";import{a4 as z,_ as E,Z as me,a5 as q,a6 as W,a7 as x,a8 as ee,a9 as T,aa as ge,ab as fe,ac as _e,ad as ye,ae as $e,af as ve,ag as S,ah as te,S as we,ai as L,aj as K,ak as Q,al as X,am as Y,an as G,a3 as V,ao as Ce,ap as U,aq as be,ar as ke}from"./index-B9SFMWwY.js";import{aj as Ee,bT as se,bW as Se,bX as Re,bN as D}from"./vendor-CdFdgkAf.js";import"./vendor-katex-DHBGsivc.js";import"./vendor-highlight-B6IKYKoD.js";import{C as qe}from"./CopyToClipboard-ZLH7uqrY.js";import{n as P,p as oe,i as Ie,o as B,D as De,q as Ge,r as J,f as Ae,g as Oe,h as Me,F as Te,O as Ne}from"./vendor-element-plus-BFf0lqAh.js";import{F as ne}from"./FilePreview-DLsXfWXH.js";import{I as Le}from"./ImagePreview-DsZM4u3Y.js";import"./vendor-vue-router-BTuxvTV5.js";import"./vendor-dayjs-DbiJaq7z.js";const Ue=async e=>{const t=(await Ee(async()=>{const{default:d}=await import("./vendor-highlight-B6IKYKoD.js");return{default:d}},__vite__mapDeps([0,1,2,3,4,5,6]))).default;e.querySelectorAll("pre code").forEach(d=>{const r=d.parentElement;if(!r)return;if(r.dataset.hasCopy==="1"){"highlightElement"in t?t.highlightElement(d):t.highlightBlock(d);return}const i=document.createElement("div");i.className="relative",r.parentNode.insertBefore(i,r),i.appendChild(r),r.classList.add("overflow-auto");const a=document.createElement("button");a.type="button",a.dataset.copyBtn="1",a.className="absolute top-1 right-1 z-10 rounded-md px-2 py-1 text-xs bg-zinc-800 text-white hover:bg-zinc-700 active:scale-95",a.textContent=z.global.t("common.button.copy").toString(),a.addEventListener("click",()=>{se(d.innerText);const n=a.textContent;a.textContent=z.global.t("common.button.copied")?.toString(),setTimeout(()=>a.textContent=n,5e3)}),i.appendChild(a),r.dataset.hasCopy="1","highlightElement"in t?t.highlightElement(d):t.highlightBlock(d)})},Ve=k({name:"AnsweringMark",data(){return{}},computed:{conversationId(){return this.$route.params?.id?.toString()}}}),Fe={class:"mark"};function Pe(e,t,o,d,r,i){return s(),u("div",Fe)}const Be=E(Ve,[["render",Pe]]),He=k({name:"VueMarkdown",props:{source:{type:String,required:!0},options:{type:Object,default:()=>({}),required:!1}},setup(e,{attrs:t}){const o=new Se({...e.options,html:!0}).use(Re,{delimiters:"all",throwOnError:!1,errorColor:"#cc0000",mathFence:!0}),d=de(()=>{const r=e.source;return o?.render(r).replace(/<think>/g,'<div class="think">').replace(/<\/think>/g,"</div>")});return()=>ce("div",{...t,innerHTML:d.value})}}),je=k({name:"MarkdownRenderer",directives:{highlight:Ue},components:{VueMarkdown:He},props:{content:{type:String,required:!1,default:""}}});function ze(e,t,o,d,r,i){const a=c("vue-markdown"),n=Z("highlight");return A((s(),m(a,{source:e.content,class:"markdown-body bg-transparent pt-[3px] text-[inherit]"},null,8,["source"])),[[n]])}const We=E(je,[["render",ze],["__scopeId","data-v-de1f7a52"]]),Ke=k({name:"CopyToClipboard",components:{FontAwesomeIcon:D,ElTooltip:P},props:{messages:{type:Array,required:!1,default:()=>[]}},emits:["restart"],data(){return{copied:!1}},methods:{onRestart(){this.$emit("restart")}}});function Qe(e,t,o,d,r,i){const a=c("font-awesome-icon"),n=c("el-tooltip");return s(),m(n,{effect:"dark",content:e.$t("common.button.restart"),placement:"bottom"},{default:y(()=>[p(a,{icon:"fa-solid fa-sync",class:"icon-sync",onClick:e.onRestart},null,8,["onClick"])]),_:1},8,["content"])}const Xe=E(Ke,[["render",Qe],["__scopeId","data-v-90e169cb"]]),Ye=k({name:"EditMessage",components:{FontAwesomeIcon:D,ElTooltip:P},props:{messages:{type:Array,required:!1,default:()=>[]}},emits:["click"],data(){return{copied:!1}},methods:{onEdit(){this.$emit("click")}}});function Je(e,t,o,d,r,i){const a=c("font-awesome-icon"),n=c("el-tooltip");return s(),u("span",null,[p(n,{effect:"dark",content:e.$t("common.button.restart"),placement:"bottom"},{default:y(()=>[p(a,{icon:"fa-solid fa-edit",class:"icon icon-edit",onClick:e.onEdit},null,8,["onClick"])]),_:1},8,["content"])])}const Ze=E(Ye,[["render",Je],["__scopeId","data-v-8e947e8f"]]),xe=k({name:"Message",components:{EditMessage:Ze,CopyToClipboard:qe,RestartToGenerate:Xe,AnsweringMark:Be,MarkdownRenderer:We,ElAlert:De,FilePreview:ne,ElButton:B,ElImage:Ie,ElInput:oe},props:{messages:{type:Array,required:!1,default:()=>[]},message:{type:Object,required:!0},application:{type:Object,required:!0}},emits:["stop","edit","restart"],data(){return{copied:!1,isEditing:!1,questionValue:this.message.content,messageState:S}},computed:{modelGroup(){return this.$store.state.chat.modelGroup},errorText(){if(console.debug("error",this.message.error),!(!this.message.error||!this.message.error?.code)){if(this.message.error?.message)return this.message.error.message;switch(this.message.error?.code){case W:return this.$t("chat.message.errorUsedUp");case ve:return this.$t("chat.message.errorApiError");case $e:return this.$t("chat.message.errorBadRequest");case ye:return this.$t("chat.message.errorTimeout");case _e:return this.$t("chat.message.errorBusy");case fe:return this.$t("chat.message.errorContentTooLarge");case ge:return this.$t("chat.message.errorTooManyRequests");case T:return this.$t("chat.message.errorNotApplied");case ee:return;case x:default:return this.$t("chat.message.errorUnknown")}}},showBuyMore(){return this.message.role===q&&this.message.error?.code===W}},watch:{},methods:{startEditing(){this.isEditing=!0,this.questionValue=this.message.content,console.debug("start to get answer",this.message)},cancelEdit(){this.isEditing=!1},onRestart(){this.$emit("restart",this.message)},onEdit(){this.isEditing=!1,this.onSubmit()},onSubmit(){this.$emit("edit",this.message,this.questionValue)},onCopy(){se(this.message.content.toString(),{debug:!0}),this.copied=!0,setTimeout(()=>{this.copied=!1},3e3)},onBuyMore(){this.$router.push({name:me,params:{id:this.application?.id}})}}}),et=["role"],tt={class:"author"},st={key:0,class:"main"},ot={initial:{opacity:0,y:5},enter:{opacity:1,y:0,scale:1},delay:300,duration:400,layout:!0,transition:{enter:{delay:.3,duration:.5},layout:{duration:.4,easing:"ease-in-out"}},class:"content"},nt={key:0,class:"message-content"},at={key:0},it={key:1,class:"whitespace-pre-wrap break-words w-fit max-w-full py-1"},rt={key:1},lt=["src"],dt={key:2},ct={key:1,class:"whitespace-pre-wrap break-words w-fit max-w-full py-1"},ut={key:1,class:"edits"},pt={class:"flex justify-end"},ht={initial:{opacity:0,y:5},enter:{opacity:1,y:0,scale:1},delay:300,duration:400,layout:!0,transition:{enter:{delay:.3,duration:.5},layout:{duration:.4,easing:"ease-in-out"}},class:"operations"};function mt(e,t,o,d,r,i){const a=c("el-image"),n=c("markdown-renderer"),$=c("file-preview"),v=c("el-input"),g=c("el-button"),l=c("answering-mark"),h=c("edit-message"),w=c("copy-to-clipboard"),ae=c("restart-to-generate"),ie=c("el-alert"),H=Z("motion");return s(),u("div",{class:R({message:!0,[e.message.role]:!0}),role:e.message.role},[f("div",tt,[e.message.role==="assistant"?(s(),m(a,{key:0,src:e.modelGroup?.icon,fit:"cover",class:"avatar"},null,8,["src"])):_("",!0)]),e.errorText?(s(),m(ie,{key:1,class:"error",title:e.errorText,type:"error",closable:!1},null,8,["title"])):(s(),u("div",st,[A((s(),u("div",ot,[e.isEditing?(s(),u("div",ut,[p(v,{modelValue:e.questionValue,"onUpdate:modelValue":t[0]||(t[0]=C=>e.questionValue=C),type:"textarea",class:"mb-2",onKeydown:F(I(e.onEdit,["exact","prevent"]),["enter"])},null,8,["modelValue","onKeydown"]),f("div",pt,[p(g,{round:"",onClick:e.cancelEdit},{default:y(()=>[N(b(e.$t("common.button.cancel")),1)]),_:1},8,["onClick"]),p(g,{type:"primary",class:"btn-confirm",round:"",onClick:e.onEdit},{default:y(()=>[N(b(e.$t("common.button.confirm")),1)]),_:1},8,["onClick"])])])):(s(),u("div",nt,[Array.isArray(e.message.content)?(s(),u("div",rt,[(s(!0),u(O,null,M(e.message.content,(C,re)=>(s(),u("div",{key:re},[C.type==="image_url"?(s(),u("img",{key:0,src:typeof C?.image_url=="string"?C.image_url:C.image_url?.url,fit:"cover",class:"image"},null,8,lt)):_("",!0),C.file_url?(s(),m($,{key:1,name:typeof C?.file_url=="string"?C.file_url:C.file_url?.url,percentage:0,closable:!1,class:"mt-2"},null,8,["name"])):_("",!0),C.type==="text"?(s(),u("div",dt,[e.message.role==="assistant"?(s(),m(n,{key:0,content:C.text},null,8,["content"])):(s(),u("pre",ct,b(C.text?.trim()),1))])):_("",!0)]))),128))])):(s(),u("div",at,[e.message.role==="assistant"?(s(),m(n,{key:0,content:e.message?.content},null,8,["content"])):(s(),u("pre",it,b(e.message.content),1))]))])),e.message.state===e.messageState.PENDING?(s(),m(l,{key:2})):_("",!0)])),[[H]]),A((s(),u("div",ht,[e.message.role==="user"&&!e.isEditing&&!Array.isArray(e.message.content)?(s(),m(h,{key:0,class:"btn-edit",onClick:e.startEditing},null,8,["onClick"])):_("",!0),!Array.isArray(e.message.content)&&(e.message.state===e.messageState.FINISHED||e.message.state===e.messageState.FAILED)?(s(),m(w,{key:1,content:e.message.content,class:"btn-copy"},null,8,["content"])):_("",!0),!Array.isArray(e.message.content)&&(e.message.state===e.messageState.FINISHED||e.message.state===e.messageState.FAILED)&&e.message.role==="assistant"&&e.message===e.messages[e.messages.length-1]?(s(),m(ae,{key:2,class:"btn-restart",messages:e.messages,onRestart:e.onRestart},null,8,["messages","onRestart"])):_("",!0)])),[[H]])])),e.showBuyMore?(s(),m(g,{key:2,round:"",type:"primary",class:"btn btn-buy",size:"small",onClick:e.onBuyMore},{default:y(()=>[N(b(e.$t("common.button.buyMore")),1)]),_:1},8,["onClick"])):_("",!0)],10,et)}const gt=E(xe,[["render",mt],["__scopeId","data-v-a2be8b8f"]]),ft=k({name:"Composer",components:{FilePreview:ne,ImagePreview:Le,ElTooltip:P,FontAwesomeIcon:D,ElUpload:Ge,ElButton:B},props:{answering:{type:Boolean,required:!1,default:!1},references:{type:Array,required:!1,default:()=>[]},question:{type:String,required:!0}},emits:["update:question","update:references","submit","stop"],data(){return{inputHeight:"35px",questionValue:this.question||"",fileList:[],uploadUrl:we()+"/api/v1/files/"}},computed:{model(){return this.$store.state.chat.model},modelGroup(){return this.$store.state.chat.modelGroup},isFileSupported(){return this.model?.isFileSupported},isImageSupported(){return this.model?.isImageSupported},headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e?.response?.file_url)},uploading(){return!!this.fileList.find(e=>e.percentage!==void 0&&e.percentage>=0&&e.percentage<100)},extensions(){if(this.isFileSupported===!1&&this.isImageSupported===!0)return".png,.jpg,.jpeg,.gif,.bmp,.webp,.svg,.tiff,.ico,.heic"}},watch:{urls(e){console.debug("File URLs:",e),e.length>0&&this.$emit("update:references",e)},questionValue(e){this.$emit("update:question",e.trim())},question(e){e!==this.questionValue&&(this.questionValue=e)},references(e){console.debug("References updated:",e),e.length===0&&(this.fileList=[])},isFileSupported(e,t){t&&!e&&(this.fileList=[])}},methods:{isImageUrl:te,adjustTextareaHeight(){this.$nextTick(()=>{const e=this.$refs.textarea;e&&(e.style.height="35px",e.style.height=e.scrollHeight+"px")})},onSubmit(){!this.question||this.uploading||this.$emit("submit")},onStop(){this.$emit("stop")},onProgress(e,t){console.debug("File upload progress:",t.name,e.loaded,e.total,t.percentage)},onExceed(){J.warning(this.$t("chat.message.uploadReferencesExceed"))},onError(){J.error(this.$t("chat.message.uploadReferencesError"))}}}),_t={class:"composer"},yt={class:"tools"},$t=["disabled","placeholder"];function vt(e,t,o,d,r,i){const a=c("image-preview"),n=c("file-preview"),$=c("font-awesome-icon"),v=c("el-tooltip"),g=c("el-upload"),l=c("el-button");return s(),u("div",_t,[f("div",yt,[p(g,{"file-list":e.fileList,"onUpdate:fileList":t[0]||(t[0]=h=>e.fileList=h),class:R({upload:!0,disabled:!e.isFileSupported&&!e.isImageSupported||e.answering}),accept:e.extensions,disabled:!e.isFileSupported&&!e.isImageSupported||e.answering,name:"file",limit:10,multiple:!0,action:e.uploadUrl,"list-type":"picture","on-exceed":e.onExceed,"on-error":e.onError,"on-progress":e.onProgress,headers:e.headers},{file:y(({file:h})=>[e.isImageUrl(h.name)?(s(),m(a,{key:0,url:h.url||h.response?.file_url,name:h.name,percentage:h.percentage,onRemove:w=>e.fileList.splice(e.fileList.indexOf(h),1)},null,8,["url","name","percentage","onRemove"])):(s(),m(n,{key:1,name:h.name,percentage:h.percentage,onRemove:w=>e.fileList.splice(e.fileList.indexOf(h),1)},null,8,["name","percentage","onRemove"]))]),default:y(()=>[p(v,{class:"box-item",effect:"dark",content:e.$t("chat.message.uploadFile"),placement:"bottom"},{default:y(()=>[f("span",{class:R({btn:!0,"btn-upload":!0,disabled:!e.isFileSupported&&!e.isImageSupported||e.answering})},[p($,{icon:"fa-solid fa-plus",class:"icon icon-attachment"})],2)]),_:1},8,["content"])]),_:1},8,["file-list","class","accept","disabled","action","on-exceed","on-error","on-progress","headers"])]),p(l,{disabled:e.answering||!e.questionValue||e.uploading,type:"primary",class:R({btn:!0,"btn-send":!0}),onClick:e.onSubmit},{default:y(()=>[p($,{icon:"fa-solid fa-arrow-up",class:"icon icon-send"})]),_:1},8,["disabled","onClick"]),A(p(l,{disabled:!e.answering,type:"primary",class:R({btn:!0,"btn-stop":!0}),onClick:e.onStop},{default:y(()=>[p($,{icon:"fa-solid fa-stop",class:"icon icon-stop"})]),_:1},8,["disabled","onClick"]),[[ue,e.answering]]),A(f("textarea",{ref:"textarea","onUpdate:modelValue":t[1]||(t[1]=h=>e.questionValue=h),disabled:e.answering,class:"input",placeholder:e.$t("chat.message.newMessagePlaceholder"),style:he({height:e.inputHeight}),onKeydown:t[2]||(t[2]=F(I((...h)=>e.onSubmit&&e.onSubmit(...h),["exact","prevent"]),["enter"])),onInput:t[3]||(t[3]=(...h)=>e.adjustTextareaHeight&&e.adjustTextareaHeight(...h))},null,44,$t),[[pe,e.questionValue]])])}const wt=E(ft,[["render",vt],["__scopeId","data-v-02d367c1"]]),Ct=k({name:"ModelSelector",components:{ElDropdown:Me,ElDropdownMenu:Oe,ElDropdownItem:Ae,FontAwesomeIcon:D},emits:["update:modelValue","select","model-group-changed","model-changed"],data(){return{options:[L,K,Q,X,Y]}},computed:{model(){return console.log("model",this.$store.state.chat.model),this.$store.state.chat.model},modelGroup(){return this.$route.meta?.modelGroup||L}},watch:{modelGroup(e){console.debug("modelGroup from route changed",e),this.$store.dispatch("chat/setModelGroup",e),this.$store.dispatch("chat/setModel",e.models[0])}},mounted(){console.debug("ModelSelector mounted, checking model group");const t=[L,K,Q,X,Y].find(o=>o.name===this.modelGroup.name);console.debug("Found model group:",t),t&&(this.$store.dispatch("chat/setModelGroup",t),this.$store.dispatch("chat/setModel",t.models[0]))},methods:{onModelGroupChange(e){this.$store.dispatch("chat/setModelGroup",e),this.$emit("model-group-changed",e)},onModelChange(e){this.$store.dispatch("chat/setModel",e),this.$emit("model-changed",e)}}}),bt={class:"selector"},kt={class:"flex justify-center"},Et={class:"name"},St={class:"angle"},Rt={class:"item"},qt={class:"info"},It={key:0,class:"name"},Dt={key:1,class:"description"};function Gt(e,t,o,d,r,i){const a=c("font-awesome-icon"),n=c("el-dropdown-item"),$=c("el-dropdown-menu"),v=c("el-dropdown");return s(),u("div",bt,[p(v,{trigger:"click","popper-class":"popper"},{dropdown:y(()=>[e.modelGroup&&e.modelGroup?.models?(s(),m($,{key:0},{default:y(()=>[(s(!0),u(O,null,M(e.modelGroup?.models?.filter(g=>g.enabled),(g,l)=>(s(),m(n,{key:l,onClick:h=>e.onModelChange(g)},{default:y(()=>[f("div",Rt,[f("div",qt,[g?.getDisplayName?(s(),u("p",It,b(g?.getDisplayName()),1)):_("",!0),g?.getDescription?(s(),u("p",Dt,b(g?.getDescription()),1)):_("",!0)])])]),_:2},1032,["onClick"]))),128))]),_:1})):_("",!0)]),default:y(()=>[f("div",kt,[f("span",Et,b(e.model?.getDisplayName()),1),f("span",St,[p(a,{icon:"fa-solid fa-angle-down"})])])]),_:1})])}const At=E(Ct,[["render",Gt],["__scopeId","data-v-6b1200e4"]]),Ot={},Mt={class:"disclaimer"};function Tt(e,t){return s(),u("p",Mt,b(e.$t("chat.message.howToUse")),1)}const Nt=E(Ot,[["render",Tt],["__scopeId","data-v-d2d980ab"]]),Lt=k({name:"SidePanel",components:{ElInput:oe,FontAwesomeIcon:D,ElSkeleton:Te},props:{},emits:["change-conversation"],computed:{modelGroup(){return this.$store.state.chat.modelGroup},conversationId(){return console.debug("conversationId in side",this.$route.params?.id),this.$route.params?.id?.toString()},conversations(){let e=this.$store.state.chat.conversations;return console.debug("conversations",e),console.debug("modelGroup",this.modelGroup),e=e?.filter(t=>t?.model&&this.modelGroup?.models?.map(o=>o.name)?.includes(t?.model)),console.debug("filtered conversations",e),e},conversationGroups(){const e=new Date;e.setHours(0,0,0,0);const t=new Date(e);t.setDate(t.getDate()-1);const o=new Date(e);o.setDate(o.getDate()-e.getDay());const d=new Date(o);d.setDate(d.getDate()-7);const r=this.conversations?.reduce((i,a)=>{const n=new Date(a.updated_at*1e3);return n>=e?i.today.push(a):n>=t?i.yesterday.push(a):n>=o?i.thisWeek.push(a):i.earlier.push(a),i},{today:[],yesterday:[],thisWeek:[],earlier:[]});return{...r?.today?.length>0?{today:r?.today?.sort((i,a)=>a.updated_at-i.updated_at)}:{},...r?.yesterday?.length>0?{yesterday:r?.yesterday?.sort((i,a)=>a.updated_at-i.updated_at)}:{},...r?.thisWeek?.length>0?{thisWeek:r?.thisWeek?.sort((i,a)=>a.updated_at-i.updated_at)}:{},...r?.earlier?.length>0?{earlier:r?.earlier?.sort((i,a)=>a.updated_at-i.updated_at)}:{}}},application(){return this.$store.state.chat.application},loading(){return this.$store.state.chat.status.getConversations===V.Request},token(){return this.$store.state.chat?.credential?.token}},watch:{modelGroup(){console.debug("modelGroup changed, refreshing conversations");const e=this.conversations?.[0];this.$emit("change-conversation",e?.id)}},methods:{async onNewConversation(){console.debug("onNewConversation from side panel"),this.$emit("change-conversation",void 0)},async onConfirm(e){const t=this.token;if(!t){console.error("Token is not found");return}e?.deleting&&e.id?(await G.deleteConversation(e.id,{token:t}),await this.$store.dispatch("chat/getConversations")):e?.editing?(await G.updateConversation(e,{token:t}),await this.$store.dispatch("chat/getConversations")):e.editing=!0},onClickConversation(e){console.debug("onClickConversation in side panel",e),this.$emit("change-conversation",e)}}}),Ut={class:"panel"},Vt={key:1,class:"conversations"},Ft={class:"icons"},Pt={class:"title"},Bt={class:"key"},Ht=["onClick"],jt={class:"title"},zt={key:0},Wt={key:1},Kt={key:2},Qt={class:"operations"};function Xt(e,t,o,d,r,i){const a=c("el-skeleton"),n=c("font-awesome-icon"),$=c("el-input");return s(),u("div",Ut,[e.loading&&e.conversationGroups===void 0?(s(),m(a,{key:0})):(s(),u("div",Vt,[f("div",{class:"conversation",onClick:t[0]||(t[0]=(...v)=>e.onNewConversation&&e.onNewConversation(...v))},[f("div",Ft,[p(n,{icon:"fa-solid fa-plus",class:"icon"})]),f("div",Pt,b(e.$t("chat.message.startNewChat")),1)]),(s(!0),u(O,null,M(e.conversationGroups,(v,g)=>(s(),u("div",{key:g,class:"group"},[f("div",Bt,b(e.$t(`chat.group.${g}`)),1),(s(!0),u(O,null,M(v,(l,h)=>(s(),u("div",{key:h,class:R({conversation:!0,active:l.id===e.conversationId}),onClick:w=>e.onClickConversation(l.id)},[f("div",jt,[l?.deleting?(s(),u("span",zt,b(`${e.$t("chat.message.confirmDelete")}?`),1)):l?.editing?(s(),u("span",Wt,[p($,{modelValue:l.title,"onUpdate:modelValue":w=>l.title=w,onKeydown:F(w=>e.onConfirm(l),["enter"])},null,8,["modelValue","onUpdate:modelValue","onKeydown"])])):l?.title||l?.messages?(s(),u("span",Kt,b(l?.title||l?.messages?.[l?.messages.length-1]?.content||l?.messages?.[0]?.content),1)):_("",!0)]),f("div",Qt,[!l?.editing&&!l.deleting?(s(),m(n,{key:0,icon:"fa-solid fa-edit",class:"icon icon-edit",onClick:I(w=>l.editing=!0,["stop"])},null,8,["onClick"])):_("",!0),!l?.editing&&!l.deleting?(s(),m(n,{key:1,icon:"fa-solid fa-trash",class:"icon icon-delete",onClick:I(w=>l.deleting=!0,["stop"])},null,8,["onClick"])):_("",!0),l?.editing||l.deleting?(s(),m(n,{key:2,icon:"fa-solid fa-check",class:"icon icon-confirm",onClick:I(w=>e.onConfirm(l),["stop"])},null,8,["onClick"])):_("",!0),l?.editing||l.deleting?(s(),m(n,{key:3,icon:"fa-solid fa-xmark",class:"icon icon-cancel",onClick:I(w=>{l.editing=!1,l.deleting=!1},["stop"])},null,8,["onClick"])):_("",!0)])],10,Ht))),128))]))),128))]))])}const Yt=E(Lt,[["render",Xt],["__scopeId","data-v-c54ecd1a"]]),Jt=k({name:"LayoutChat",components:{SidePanel:Yt,ElDrawer:Ne,ElButton:B,FontAwesomeIcon:D},emits:["change-conversation"],data(){return{drawer:!1}},methods:{onChangeConversation(e){console.debug("onChangeConversation in layout",e),this.$emit("change-conversation",e)}}}),Zt={class:"main flex flex-row flex-1"},xt={class:"side w-[250px] h-full overflow-y-scroll border-r border-[var(--el-border-color)]"},es={class:"chat h-full w-[calc(100%-250px)] pt-[45px] flex-1 flex flex-col relative"};function ts(e,t,o,d,r,i){const a=c("side-panel"),n=c("font-awesome-icon"),$=c("el-button"),v=c("el-drawer");return s(),u("div",Zt,[f("div",xt,[j(e.$slots,"side",{},()=>[p(a,{onChangeConversation:e.onChangeConversation},null,8,["onChangeConversation"])],!0)]),f("div",es,[j(e.$slots,"chat",{},void 0,!0)]),p($,{round:"",class:"menu",onClick:t[0]||(t[0]=g=>e.drawer=!0)},{default:y(()=>[p(n,{icon:"fa-solid fa-bars"})]),_:1}),p(v,{modelValue:e.drawer,"onUpdate:modelValue":t[1]||(t[1]=g=>e.drawer=g),direction:"ltr","with-header":!1,size:"290px"},{default:y(()=>[p(a,{onChangeConversation:e.onChangeConversation},null,8,["onChangeConversation"])]),_:1},8,["modelValue"])])}const ss=E(Jt,[["render",ts],["__scopeId","data-v-38ff8add"]]),os=k({name:"ChatConversation",components:{Composer:wt,Disclaimer:Nt,ModelSelector:At,Message:gt,Layout:ss},data(){return{drawer:!1,question:"",references:[],upload:!1,answering:!1,canceler:void 0,messages:this.$store.state.chat.conversations?.find(e=>e.id===this.$route.params.id?.toString())?.messages||[]}},computed:{modelGroup(){return this.$store.state.chat.modelGroup},model(){return this.$store.state.chat.model},conversationId(){return this.$route.params.id?.toString()},conversation(){return this.$store.state.chat.conversations?.find(e=>e.id===this.conversationId)},service(){return this.$store.state.chat.service},application(){return this.$store.state.chat.application},applications(){return this.$store.state.chat.applications},credential(){return this.$store.state.chat?.credential},needApply(){return this.$store.state.chat.status.getApplications===V.Success&&!this.application},conversations(){return this.$store.state.chat.conversations},initializing(){return this.$store.state.chat.status.getApplications===V.Request}},watch:{async references(e){console.log("references changed",e)},async modelGroup(e){console.debug("modelGroup changed",e)},async conversationId(e){console.debug("conversationId changed",e)}},async mounted(){await this.onGetService(),await this.onGetApplication(),await this.onGetConversations()},methods:{async onGetService(){console.debug("start onGetService"),await this.$store.dispatch("chat/getService"),console.debug("end onGetService")},async onGetApplication(){console.debug("start onGetApplication"),await this.$store.dispatch("chat/getApplications"),console.debug("end onGetApplication")},async onGetConversations(){console.debug("start onGetConversations"),await this.$store.dispatch("chat/getConversations"),console.debug("end onGetConversations")},async onDraft(e){this.question=e,this.onSubmit()},async onStop(){this.canceler&&(this.canceler.abort(),this.answering=!1)},async onRestart(e){const t=this.messages.findIndex(n=>n===e),o=this.messages[t-1];let d=[];if(t!==-1){if(d=this.messages.slice(0,t-1),this.messages=this.messages.slice(0,t),this.references=[],typeof o.content=="string")this.question=o.content;else if(Array.isArray(o.content))for(let n=0;n<o?.content.length;n++)o.content[n].type==="image_url"&&(typeof o?.content?.[n]?.image_url=="string"?this.references.push(o?.content?.[n]?.image_url):this.references.push(o?.content?.[n]?.image_url?.url)),o.content[n].type==="file_url"&&(typeof o?.content?.[n]?.file_url=="string"?this.references.push(o?.content?.[n]?.file_url):this.references.push(o?.content?.[n]?.file_url?.url)),o.content[n].type==="text"&&(this.question=o.content[n].text)}console.debug("onRestart!",this.question,JSON.stringify(this.references));const r=this.credential?.token,i=this.question.trim();if(!r||!i){console.error("no token or endpoint or question"),this.messages.push({error:{code:T},role:q,state:S.FAILED});return}let a=this.conversationId;G.updateConversation({id:this.conversationId,messages:d},{token:r}).then(async()=>{await this.$store.dispatch("chat/setConversation",{id:a,messages:this.messages}),console.debug("finished update conversation",this.messages),console.debug("onRestart",this.question),await this.onRequest()}).catch(n=>{this.handleRequestError(n)})},async onEdit(e,t){const o=this.messages.findIndex(i=>i===e);o!==-1&&(this.messages=this.messages.slice(0,o)),this.question=t;const d=this.credential?.token;if(!d){console.error("no token or endpoint or question"),this.messages.push({error:{code:T},role:q,state:S.FAILED});return}let r=this.conversationId;G.updateConversation({id:this.conversationId,messages:this.messages},{token:d}).then(async()=>{await this.$store.dispatch("chat/setConversation",{id:r,messages:this.messages}),console.debug("finished update conversation",this.messages),this.messages.push({content:this.question,role:U}),console.debug("onEdit",this.question),await this.onRequest()}).catch(i=>{this.handleRequestError(i)})},async onNewConversation(){this.$router.push({params:{id:""}}),this.messages=[],this.question="",this.references=[]},async onRestoreConversation(e){console.debug("onRestoreConversation id",e);const t=this.conversations?.find(i=>i.id===e),o=t?.model;console.debug("conversation model",o);const d=be.find(i=>i.name===o);console.debug("target model",d);const r=ke.find(i=>i.name===d?.modelGroup);console.debug("target model group",r),this.$store.dispatch("chat/setModelGroup",r),this.$store.dispatch("chat/setModel",d),console.debug("conversation",t),console.debug("conversation messages",this.messages),this.messages=t?.messages||[],this.onScrollDown()},async onChangeConversation(e){console.log("onChangeConversation in conversation",e),await this.onStop(),e?this.onRestoreConversation(e):this.onNewConversation()},async onSubmit(){if(this.references.length>0){let e=[];e.push({type:"text",text:this.question.trim()});for(let t=0;t<this.references.length;t++)te(this.references[t])?e.push({type:"image_url",image_url:this.references[t]}):e.push({type:"file_url",file_url:this.references[t]});this.messages.push({content:e,role:U})}else this.messages.push({content:this.question.trim(),role:U});console.debug("onSubmit",this.question,this.references),await this.onRequest()},async onRequest(){console.debug("start to get answer",this.messages);const e=this.credential?.token,t=this.question.trim(),o=this.references;if(console.debug("validated",t,o),this.question="",this.references=[],!e||!t){console.error("no token or endpoint or question"),this.messages.push({error:{code:T},role:q,state:S.FAILED});return}let d=this.conversationId;this.messages.push({content:"",role:q,state:S.PENDING}),console.debug("start to get answer",this.messages),this.onScrollDown(),this.answering=!0,this.canceler=new AbortController,G.chatConversation({question:t,model:this.model.name,references:o,id:this.conversationId,stateful:!0},{token:e,stream:r=>{console.debug("stream response",r);const i=this.messages[this.messages.length-1];this.messages[this.messages.length-1]={role:q,content:r.answer,state:i?.state!==S.FINISHED?S.ANSWERING:i?.state},d=r?.id},signal:this.canceler.signal}).then(async()=>{console.debug("finished fetch answer",this.messages),this.messages[this.messages.length-1].state=S.FINISHED,console.debug("finished fetch answer",JSON.stringify(this.messages)),await this.$store.dispatch("chat/setConversation",{id:d,messages:this.messages}),this.answering=!1,d&&await this.$router.push({params:{id:d}}),this.onScrollDown(),await this.$store.dispatch("chat/getConversations"),await this.$store.dispatch("chat/getApplications")}).catch(r=>{this.handleRequestError(r)})},async handleRequestError(e){if(console.error("error happened",e),this.messages&&this.messages.length>0&&(this.messages[this.messages.length-1].state=S.FAILED),e.name==="AbortError"){console.error("aborted");return}else e instanceof Ce?(console.debug("BaseError",e),this.messages[this.messages.length-1].error={code:e.code,message:e.detail}):le.isCancel(e)?this.messages[this.messages.length-1].error={code:ee}:this.messages&&this.messages.length>0&&(this.messages[this.messages.length-1].error={code:x});this.answering=!1},async onScrollDown(){setTimeout(()=>{const e=document.querySelector(".messages");!e||!this.messages||this.messages.length===0||(e.scrollTop=e?.scrollHeight)},0)}}}),ns={key:0,class:"messages"},as={class:"starter"};function is(e,t,o,d,r,i){const a=c("model-selector"),n=c("message"),$=c("composer"),v=c("disclaimer"),g=c("layout");return s(),m(g,{onChangeConversation:t[4]||(t[4]=l=>e.onChangeConversation(l))},{chat:y(()=>[p(a,{class:"selector",onModelGroupChanged:t[0]||(t[0]=l=>e.onChangeConversation(void 0))}),f("div",{class:R({dialogue:!0,empty:e.messages.length===0})},[e.messages.length>0?(s(),u("div",ns,[(s(!0),u(O,null,M(e.messages,(l,h)=>(s(),m(n,{key:h,message:l,messages:e.messages,question:e.question,application:e.application,class:"message","onUpdate:question":t[1]||(t[1]=w=>e.question=w),onEdit:e.onEdit,onRestart:e.onRestart},null,8,["message","messages","question","application","onEdit","onRestart"]))),128))])):_("",!0),f("div",as,[p($,{question:e.question,"onUpdate:question":t[2]||(t[2]=l=>e.question=l),answering:e.answering,references:e.references,"onUpdate:references":t[3]||(t[3]=l=>e.references=l),onSubmit:e.onSubmit,onStop:e.onStop},null,8,["question","answering","references","onSubmit","onStop"]),p(v,{class:"disclaimer"})])],2)]),_:1})}const $s=E(os,[["render",is],["__scopeId","data-v-8f6d22cf"]]);export{$s as default};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{bN as p,bT as r}from"./vendor-CdFdgkAf.js";import{n as m}from"./vendor-element-plus-BFf0lqAh.js";import{f as l,Q as n,R as c,t as s,a0 as f,ak as a,j as i}from"./vendor-vue-xzGp4vaJ.js";import{_ as d}from"./index-B9SFMWwY.js";const u=l({name:"CopyToClipboard",components:{FontAwesomeIcon:p,ElTooltip:m},props:{content:{type:[String,Number],required:!1,default:""}},data(){return{copied:!1}},methods:{onCopy(){this.content&&(r(this.content.toString(),{debug:!0}),this.copied=!0,setTimeout(()=>{this.copied=!1},3e3))}}});function _(o,b,C,k,y,h){const e=a("font-awesome-icon"),t=a("el-tooltip");return o.copied?(i(),n(t,{key:1,visible:o.copied,effect:"dark",content:o.$t("common.message.copied"),placement:"bottom"},{default:c(()=>[s(e,{icon:"fa-solid fa-check",class:"icon-check"})]),_:1},8,["visible","content"])):(i(),n(t,{key:0,effect:"dark",content:o.$t("common.button.copy"),placement:"bottom"},{default:c(()=>[s(e,{icon:"fa-regular fa-copy",class:"icon-copy",onClick:f(o.onCopy,["stop"])},null,8,["onClick"])]),_:1},8,["content"]))}const v=d(u,[["render",_],["__scopeId","data-v-cc8e806b"]]);export{v as C};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{o as S}from"./order-CwymXjrK.js";import{_ as V}from"./index-B9SFMWwY.js";import{O as $}from"./order-CB3uOPHS.js";import{as as Z,ae as ee,bV as te}from"./vendor-CdFdgkAf.js";import{w as B,x as F,E as q,z as se,A as ie,e as re,B as L,a as H,C as U,D as j,o as z,r as O,m as ae,F as oe,s as ne}from"./vendor-element-plus-BFf0lqAh.js";import{f as N,Q as d,R as s,t as n,ak as l,i,V as u,Y as a,j as r,h as p,F as C,ah as T,X as v,U as R,a0 as le}from"./vendor-vue-xzGp4vaJ.js";import{C as Y}from"./CopyToClipboard-ZLH7uqrY.js";import{g as de}from"./price-Cw72dIAB.js";import"./vendor-axios-NIGUFBhG.js";import"./vendor-vue-router-BTuxvTV5.js";import"./vendor-dayjs-DbiJaq7z.js";import"./vendor-katex-DHBGsivc.js";function G(){const e=navigator.userAgent.toLowerCase();return/iphone|ipad|ipod|android|windows phone/i.test(e)}const pe=N({name:"PayOrderDialog",components:{ElDialog:q,QrCode:Z,ElRow:F,ElCol:B},props:{modelValue:{type:Object,required:!0},visible:{type:Boolean,required:!1,default:!1}},emits:["hide","update:modelValue"],data(){return{refreshTimer:void 0}},mounted(){this.onRefresh()},unmounted(){this.refreshTimer&&clearTimeout(this.refreshTimer)},methods:{onRefresh(){if(!this.modelValue.id){console.error("id does not exist");return}S.refresh(this.modelValue.id).then(({data:e})=>{e.state!==$.PAID?setTimeout(()=>{this.onRefresh()},2e3):this.$emit("hide"),this.$emit("update:modelValue",e)}).catch(()=>{setTimeout(()=>{this.onRefresh()},2e3)})}}}),ce={class:"paycode wechat"},ue={class:"help-text block bg-[#00c800] text-white text-[14px] h-[35px] w-[240px] text-center leading-[35px] mt-[10px] mx-auto"};function he(e,t,o,c,y,k){const h=l("qr-code"),f=l("el-col"),_=l("el-row"),b=l("el-dialog");return r(),d(b,{"model-value":e.visible,title:e.$t("application.title.buyService"),width:"500px",center:""},{default:s(()=>[n(_,{class:"paycodes py-[30px] w-[500px] mx-auto"},{default:s(()=>[n(f,{span:12},{default:s(()=>[i("div",ce,[e.modelValue?.pay_url?(r(),d(h,{key:0,value:e.modelValue?.pay_url,size:200,class:"qrcode m-auto w-[200px] h-[200px]",type:"image/png",color:{dark:"#000000",light:"#ffffff"}},null,8,["value"])):u("",!0),i("p",ue,a(e.$t("order.message.wechatPayHelp")),1)])]),_:1}),n(f,{span:12},{default:s(()=>t[0]||(t[0]=[i("div",{class:"help-img"},[i("img",{src:"https://midas.gtimg.cn/enterprise/images/ep_sys_wx_tip.jpg"})],-1)])),_:1,__:[0]})]),_:1})]),_:1},8,["model-value","title"])}const me=V(pe,[["render",he]]),ye=N({name:"PayOrderDialog",components:{ElDialog:q},props:{modelValue:{type:Object,required:!0},visible:{type:Boolean,required:!1,default:!1}},emits:["hide","update:modelValue"],data(){return{refreshTimer:void 0}},watch:{visible:{handler(e){e&&this.modelValue.pay_url&&window.open(this.modelValue.pay_url,"_blank")}}},mounted(){this.onRefresh()},unmounted(){this.refreshTimer&&clearTimeout(this.refreshTimer)},methods:{onRefresh(){if(!this.modelValue.id){console.error("id does not exist");return}S.refresh(this.modelValue.id).then(({data:e})=>{e.state!==$.PAID?setTimeout(()=>{this.onRefresh()},2e3):this.$emit("hide"),this.$emit("update:modelValue",e)}).catch(()=>{setTimeout(()=>{this.onRefresh()},5e3)})}}}),fe={class:"text-center"};function ge(e,t,o,c,y,k){const h=l("el-dialog");return r(),d(h,{"model-value":e.visible,title:e.$t("application.title.buyService"),width:"500px",center:""},{default:s(()=>[i("p",fe,a(e.$t("order.message.buyInExternalUrl")),1)]),_:1},8,["model-value","title"])}const ve=V(ye,[["render",ge],["__scopeId","data-v-fbea8aa1"]]),we=N({name:"PayOrderDialog",components:{ElDialog:q},props:{modelValue:{type:Object,required:!0},visible:{type:Boolean,required:!1,default:!1}},emits:["hide","update:modelValue"],data(){return{refreshTimer:void 0}},watch:{visible:{handler(e){e&&this.modelValue.pay_url&&window.open(this.modelValue.pay_url,"_blank")}}},mounted(){this.onRefresh()},unmounted(){this.refreshTimer&&clearTimeout(this.refreshTimer)},methods:{onRefresh(){if(!this.modelValue.id){console.error("id does not exist");return}S.refresh(this.modelValue.id).then(({data:e})=>{e.state!==$.PAID?setTimeout(()=>{this.onRefresh()},2e3):this.$emit("hide"),this.$emit("update:modelValue",e)}).catch(()=>{setTimeout(()=>{this.onRefresh()},5e3)})}}}),be={class:"text-center"};function ke(e,t,o,c,y,k){const h=l("el-dialog");return r(),d(h,{"model-value":e.visible,title:e.$t("application.title.buyService"),width:"500px",center:""},{default:s(()=>[i("p",be,a(e.$t("order.message.buyInExternalUrl")),1)]),_:1},8,["model-value","title"])}const Pe=V(we,[["render",ke]]),$e=N({name:"X402PayOrderDialog",components:{ElDialog:q,ElButton:z,ElAlert:j,ElDescriptions:U,ElTag:H,ElDescriptionsItem:L,ElIcon:re,ElTabs:ie,ElTabPane:se,CreditCard:te,Document:ee,CopyToClipboard:Y},props:{modelValue:{type:Object,required:!0},session:{type:Object,default:void 0},visible:{type:Boolean,default:!1}},emits:["hide","update:modelValue"],data(){return{docsUrl:"https://platform.acedata.cloud/documents/35bf9f88-e972-4c61-a795-b0096d261256#1.%20查看订单并记录收款信息",walletStates:{phantom:{connected:!1,address:void 0},metamask:{connected:!1,address:void 0}},connecting:!1,signing:!1,paying:!1,chainId:void 0,activeTab:"wallet",activeWallet:"phantom",installGuideVisible:!1,installGuideWallet:void 0}},computed:{dialogWidth(){return G()?"100%":"680px"},walletOptions(){return[{key:"phantom",label:"Phantom",icon:"https://cdn.acedata.cloud/42inc8.png"},{key:"metamask",label:"MetaMask",icon:"https://cdn.acedata.cloud/jvb98h.png"}]},currentWalletState(){return this.walletStates[this.activeWallet]},evmAddress(){return this.currentWalletState.address},primaryAccept(){if(Array.isArray(this.session?.accepts)&&this.session?.accepts.length>0)return this.session?.accepts[0]},orderMetadata(){const e=this.modelValue?.metadata;return e&&typeof e=="object"?e:void 0},paymentRequirements(){const e=this.session?.payment_requirements||this.session?.paymentRequirements;if(e&&typeof e=="object")return e;const t=this.orderMetadata?.payment_requirements||this.orderMetadata?.paymentRequirements;if(t&&typeof t=="object")return t},x402Metadata(){const e=this.session?.x402;if(e&&typeof e=="object")return e;const t=this.orderMetadata?.x402;if(t&&typeof t=="object")return t},displayResource(){return this.ensureHttps(this.pickFirstString([this.primaryAccept?.resource,this.primaryAccept?.resource_url,this.paymentRequirements?.resource,this.paymentRequirements?.resource_url,this.session?.resource,this.session?.resource_url,this.session?.facilitatorUrl,this.session?.facilitator_url,this.x402Metadata?.resource,this.x402Metadata?.facilitator_url,this.orderMetadata?.resource,this.orderMetadata?.resource_url,this.modelValue?.pay_url]))},displayPayTo(){return this.pickFirstString([this.primaryAccept?.payTo,this.primaryAccept?.pay_to,this.paymentRequirements?.payTo,this.paymentRequirements?.pay_to,this.session?.pay_to,this.session?.payTo,this.x402Metadata?.pay_to,this.orderMetadata?.pay_to])},displayNetwork(){return this.pickFirstString([this.primaryAccept?.network,this.paymentRequirements?.network,this.session?.network,this.x402Metadata?.network])},displayAsset(){const e=this.paymentRequirements?.extra?.name||this.primaryAccept?.extra?.name||this.session?.extra?.name,t=this.pickFirstString([this.paymentRequirements?.asset,this.primaryAccept?.asset,this.session?.asset]);return e&&t?`${e} (${t})`:e||t},hasDetails(){return!!(this.displayResource||this.displayPayTo||this.displayNetwork||this.displayAsset)},expectedNetwork(){return this.displayNetwork},expectedChainIdHex(){const e={base:"0x2105","base-sepolia":"0x14A34",ethereum:"0x1",sepolia:"0xAA36A7",polygon:"0x89",arbitrum:"0xA4B1",optimism:"0xA",bsc:"0x38",avalanche:"0xA86A"},t=(this.expectedNetwork||"").toLowerCase();return e[t]},networkMismatch(){return!!(this.evmAddress&&this.chainId&&this.expectedChainIdHex&&this.chainId.toLowerCase()!==this.expectedChainIdHex.toLowerCase())},hasEvmProvider(){return this.walletOptions.some(e=>this.isWalletAvailable(e.key))},hasEvmAccount(){return!!this.currentWalletState.address},requirementsAvailable(){return!!this.pickRequirements()},evmProvider(){if(this.currentWalletState.connected)return this.getWalletProvider(this.activeWallet)},installGuideWalletLabel(){return this.walletOptions.find(t=>t.key===this.installGuideWallet)?.label||this.walletOptions[0]?.label||"MetaMask"},installGuideSteps(){return[String(this.$t("order.message.x402InstallGuideStep1",{wallet:this.installGuideWalletLabel})),String(this.$t("order.message.x402InstallGuideStep2")),String(this.$t("order.message.x402InstallGuideStep3"))]},networkGuideSteps(){const e=this.displayNetwork||this.expectedNetwork||"Base";return[String(this.$t("order.message.x402NetworkGuideStep1",{network:e})),String(this.$t("order.message.x402NetworkGuideStep2",{network:e})),String(this.$t("order.message.x402NetworkGuideStep3"))]},networkGuideVisible(){return this.networkMismatch}},watch:{visible(e){e||(this.installGuideVisible=!1)}},methods:{getWalletDeepLink(e){if(!G()||typeof window>"u")return;const t=window.location.href;if(e==="phantom")return`https://phantom.app/ul/browse/${encodeURIComponent(t)}`;if(e==="metamask")return`https://metamask.app.link/dapp/${encodeURIComponent(t)}`},selectWallet(e){this.walletStates[e].connected&&(this.activeWallet=e)},connectWallet(e){this.onConnectWallet(e)},getPhantomProvider(){const e=window,t=e?.phantom,o=e?.ethereum,c=o?.providers;if(t?.ethereum)return t.ethereum;if(o?.isPhantom)return o;if(Array.isArray(c)&&c.length>0){const y=c.find(k=>k&&k.isPhantom);if(y)return y}},getMetamaskProvider(){const t=window?.ethereum,o=t?.providers;let c;return Array.isArray(o)&&o.length>0&&(c=o.find(y=>y&&y.isMetaMask)),!c&&t?.isMetaMask&&(c=t),c},getWalletProvider(e){if(e==="metamask")return this.getMetamaskProvider();if(e==="phantom")return this.getPhantomProvider()},isWalletAvailable(e){return!!this.getWalletProvider(e)},openWalletDownload(e){const t=this.getWalletDeepLink(e);if(t){window.location.href=t;return}let o="";e==="phantom"?o="https://phantom.app/download":e==="metamask"&&(o="https://metamask.io/download.html"),o&&(window.open(o,"_blank","noopener"),this.installGuideWallet=e,this.installGuideVisible=!0)},resetWalletState(e){this.walletStates[e].connected=!1,this.walletStates[e].address=void 0},async getFreshRequirements(){const e=this.pickRequirements();if(e)return e;try{const o=(await S.pay(this.modelValue.id,{pay_way:"X402"}))?.data;return Array.isArray(o?.accepts)&&o.accepts.length?o.accepts[0]:o?.payment_requirements?o.payment_requirements:void 0}catch(t){const o=t?.response?.data;if(o){if(Array.isArray(o?.accepts)&&o.accepts.length)return o.accepts[0];if(o?.payment_requirements)return o.payment_requirements}return}},onOpenDocs(){window.open(this.docsUrl,"_blank","noopener")},pickFirstString(e){for(const t of e)if(typeof t=="string"&&t.trim())return t.trim()},ensureHttps(e){return e&&(/^http:\/\//i.test(e)?e.replace(/^http:\/\//i,"https://"):e)},isUrl(e){return!!e&&/^https?:\/\//i.test(e)},async onConnectWallet(e){const t=this.getWalletProvider(e);if(!t){this.resetWalletState(e),this.openWalletDownload(e);return}this.connecting=!0;try{const o=await t.request({method:"eth_requestAccounts"}),c=Array.isArray(o)?o[0]:void 0;if(!c){this.resetWalletState(e);return}this.walletStates[e].address=c,this.walletStates[e].connected=!0,this.activeWallet=e,await this.refreshChainId()}catch{this.resetWalletState(e)}finally{this.connecting=!1,await this.ensureNetwork()}},async refreshChainId(){if(this.evmProvider)try{const e=await this.evmProvider.request({method:"eth_chainId"});typeof e=="string"&&(this.chainId=e)}catch{}},async ensureNetwork(){if(!(!this.evmProvider||!this.expectedChainIdHex)&&(await this.refreshChainId(),!(this.chainId&&this.chainId.toLowerCase()===this.expectedChainIdHex.toLowerCase()))){try{await this.evmProvider.request({method:"wallet_switchEthereumChain",params:[{chainId:this.expectedChainIdHex}]})}catch{try{await this.evmProvider.request({method:"wallet_addEthereumChain",params:[this.getExpectedChainParams()]})}catch{try{O.warning(this.$t&&this.$t("order.message.x402NetworkSwitchFailed")||"Your wallet does not support automatic network switching. Please switch to the required network in the wallet and try again.")}catch{}}}await this.refreshChainId()}},async onSwitchNetwork(){await this.ensureNetwork()},getExpectedChainParams(){const e={base:{chainId:"0x2105",chainName:"Base",nativeCurrency:{name:"ETH",symbol:"ETH",decimals:18},rpcUrls:["https://mainnet.base.org"],blockExplorerUrls:["https://basescan.org"]},"base-sepolia":{chainId:"0x14A34",chainName:"Base Sepolia",nativeCurrency:{name:"ETH",symbol:"ETH",decimals:18},rpcUrls:["https://sepolia.base.org"],blockExplorerUrls:["https://sepolia.basescan.org"]}},t=(this.expectedNetwork||"").toLowerCase();return e[t]||{chainId:this.expectedChainIdHex}},buildTypedData(e,t){const o=e?.extra||{};return{types:{EIP712Domain:[{name:"name",type:"string"},{name:"version",type:"string"},{name:"chainId",type:"uint256"},{name:"verifyingContract",type:"address"}],TransferWithAuthorization:[{name:"from",type:"address"},{name:"to",type:"address"},{name:"value",type:"uint256"},{name:"validAfter",type:"uint256"},{name:"validBefore",type:"uint256"},{name:"nonce",type:"bytes32"}]},primaryType:"TransferWithAuthorization",domain:{name:o?.name||"USD Coin",version:o?.version||"2",chainId:parseInt(this.expectedChainIdHex||"0x0",16),verifyingContract:e.asset},message:t}},randomNonce32(){const e=new Uint8Array(32);return crypto.getRandomValues(e),"0x"+Array.from(e).map(t=>t.toString(16).padStart(2,"0")).join("")},pickRequirements(){return this.paymentRequirements||this.primaryAccept},async onPayWithWallet(){if(!this.modelValue?.id||!this.evmProvider||!this.evmAddress){const e=this.$t&&this.$t("order.message.x402PaymentFailed")||"X402 wallet payment is not available right now. Please try again later.";O.error(e);return}this.signing=!0;try{let e=await this.getFreshRequirements();if(e||(e=this.pickRequirements()),!e){const x=this.$t&&this.$t("order.message.x402PaymentFailed")||"X402 wallet payment failed. Please try again later.";O.error(x);return}await this.ensureNetwork();const t=Math.floor(Date.now()/1e3),o=Number(e?.maxTimeoutSeconds||e?.max_timeout_seconds||120),c=BigInt(e?.maxAmountRequired||e?.max_amount_required||0).toString(),y={from:this.evmAddress,to:e.payTo||e.pay_to,value:c,validAfter:t,validBefore:t+o,nonce:this.randomNonce32()},k=this.buildTypedData(e,y),h=await this.evmProvider.request({method:"eth_signTypedData_v4",params:[this.evmAddress,JSON.stringify(k)]}),f={from:y.from,to:y.to,value:y.value,validAfter:String(y.validAfter),validBefore:String(y.validBefore),nonce:y.nonce},_={x402Version:1,scheme:e.scheme||"exact",network:e.network||this.expectedNetwork||"base",payload:{authorization:f,signature:h}},b=btoa(JSON.stringify(_));this.paying=!0;const{data:w}=await S.payX402WithHeader(this.modelValue.id,{pay_way:"X402"},b);this.$emit("update:modelValue",w),this.$emit("hide")}catch(e){let t;const o=e?.response?.data;if(o){const c=o?.error||o?.detail;typeof c=="string"&&(t=c)}t||(t=this.$t&&this.$t("order.message.x402PaymentFailed")||"X402 wallet payment failed. Please try again later.");try{O.error(t)}catch{}}finally{this.signing=!1,this.paying=!1}},onInstallGuideConfirm(){this.installGuideVisible=!1,this.reloadPage()},onNetworkGuideConfirm(){this.reloadPage()},reloadPage(){window.location.reload()}}}),_e={class:"flex flex-col gap-[16px]"},xe={class:"flex items-start gap-[12px]"},Ae={class:"m-0 text-[14px] leading-[1.6]"},Se={class:"flex flex-col gap-[10px]"},We={class:"flex items-center gap-[10px]"},Ce={class:"text-[14px] font-semibold text-[var(--el-text-color-primary)]"},Ie={class:"flex flex-col items-center gap-3 sm:grid-cols-2"},De=["onClick"],Re=["src","alt"],Te={class:"text-[14px] text-[var(--el-text-color-primary)]"},Ve={class:"ml-auto flex items-center gap-2"},Ne={key:3,class:"text-center text-[var(--el-text-color-secondary)] text-sm"},Ee={class:"flex items-center justify-center gap-[12px] flex-wrap mt-[8px]"},Oe={class:"mt-[6px]"},qe={class:"m-0 mb-[6px] text-[14px] font-semibold text-[var(--el-text-color-primary)]"},Xe={class:"m-0 pl-[18px] text-[var(--el-text-color-regular)] text-[13px] leading-[1.6] list-disc"},Ge={key:0,class:"flex flex-col gap-[12px]"},Me={class:"inline-flex items-center gap-[8px] break-all min-h-[24px]"},Be=["href"],Fe={key:1,class:"font-mono text-[var(--el-text-color-regular)]"},Le={class:"inline-flex items-center gap-[8px] break-all min-h-[24px]"},He={class:"font-mono text-[var(--el-text-color-regular)]"},Ue={key:1,class:"my-[12px] px-[16px] py-[14px] rounded-[10px] bg-[var(--el-color-primary-light-9)] text-[var(--el-text-color-regular)] text-[13px] leading-[1.6] text-center"},je={class:"mt-[12px] flex flex-col items-center gap-[8px] text-center"},ze={class:"flex flex-col gap-[12px]"},Ye={class:"m-0 text-[14px] leading-[1.6] text-[var(--el-text-color-regular)]"},Je={class:"m-0 pl-[18px] text-[13px] leading-[1.6] text-[var(--el-text-color-primary)] list-decimal"},Qe={class:"w-full flex justify-center"},Ke={class:"flex flex-col gap-[12px]"},Ze={class:"m-0 text-[14px] leading-[1.6] text-[var(--el-text-color-regular)]"},et={class:"m-0 pl-[18px] text-[13px] leading-[1.6] text-[var(--el-text-color-primary)] list-decimal"},tt={class:"w-full flex justify-center"};function st(e,t,o,c,y,k){const h=l("credit-card"),f=l("el-icon"),_=l("el-tag"),b=l("el-button"),w=l("el-alert"),x=l("el-tab-pane"),P=l("copy-to-clipboard"),A=l("el-descriptions-item"),I=l("el-descriptions"),E=l("document"),X=l("el-tabs"),D=l("el-dialog");return r(),p(C,null,[n(D,{"model-value":e.visible,title:e.$t("order.title.x402"),width:e.dialogWidth,top:"8vh",class:"x402-dialog"},{default:s(()=>[i("section",_e,[i("header",xe,[n(f,{size:22,class:"inline-flex items-center justify-center w-[38px] h-[38px] rounded-[12px] bg-[var(--el-color-primary-light-9)] text-[var(--el-color-primary)]"},{default:s(()=>[n(h)]),_:1}),i("div",null,[i("p",Ae,a(e.$t("order.message.x402IntroShort")),1)])]),n(X,{modelValue:e.activeTab,"onUpdate:modelValue":t[0]||(t[0]=g=>e.activeTab=g),type:"border-card",class:"mt-[8px]"},{default:s(()=>[n(x,{label:e.$t("order.message.x402TabWallet"),name:"wallet"},{default:s(()=>[i("section",Se,[i("div",We,[i("span",Ce,a(e.$t("order.message.x402WalletTitle")),1)]),i("div",Ie,[(r(!0),p(C,null,T(e.walletOptions,g=>(r(),p("div",{key:g.key,class:R(["flex w-[300px] items-center gap-3 rounded-[10px] border-2 px-4 py-3 min-h-[56px] transition-colors",e.walletStates[g.key].connected&&e.activeWallet===g.key?"border-[color:var(--el-color-primary)] bg-[color:var(--el-color-primary-light-9)] cursor-pointer":e.walletStates[g.key].connected?"border-[var(--el-border-color)] bg-[var(--el-fill-color-blank)] cursor-pointer":"border-[var(--el-border-color)] bg-[var(--el-fill-color-blank)] opacity-90 cursor-default"]),onClick:W=>e.selectWallet(g.key)},[i("img",{src:g.icon,alt:g.label,class:"w-[20px] h-[20px] rounded-[6px]"},null,8,Re),i("span",Te,a(g.label),1),i("div",Ve,[e.walletStates[g.key].connected?(r(),d(_,{key:0,class:"text-[12px] text-[var(--el-color-success)] whitespace-nowrap"},{default:s(()=>[v(a(e.$t("order.message.x402WalletConnected")),1)]),_:1})):(r(),d(b,{key:1,size:"small",type:"primary",onClick:le(W=>e.connectWallet(g.key),["stop"])},{default:s(()=>[v(a(e.$t("order.message.x402ConnectWallet")),1)]),_:2},1032,["onClick"]))])],10,De))),128))]),e.hasEvmProvider?e.networkMismatch?(r(),d(w,{key:1,type:"warning",closable:!1,"show-icon":"",class:"mt-[8px]",title:e.$t("order.message.x402SwitchNetwork",{network:e.displayNetwork||e.expectedNetwork})},null,8,["title"])):e.hasEvmAccount?u("",!0):(r(),d(w,{key:2,type:"info",closable:!1,"show-icon":"",title:e.$t("order.message.x402NeedConnectAccount")},null,8,["title"])):(r(),d(w,{key:0,type:"info",closable:!1,class:"mt-[8px]",description:e.$t("order.message.x402NoWalletDesc")},null,8,["description"])),e.evmAddress?(r(),p("div",Ne,[i("p",null,a(e.evmAddress?.substring(0,12))+"..."+a(e.evmAddress?.substring(e.evmAddress.length-12)),1)])):u("",!0),i("div",Ee,[e.hasEvmProvider?(r(),d(b,{key:0,type:"primary",disabled:!e.evmAddress||!e.requirementsAvailable||e.networkMismatch||!e.hasEvmAccount,loading:e.signing||e.paying,onClick:e.onPayWithWallet},{default:s(()=>[v(a(e.$t("order.message.x402WalletPayCta")),1)]),_:1},8,["disabled","loading","onClick"])):u("",!0)]),i("div",Oe,[i("p",qe,a(e.$t("order.message.x402StepsTitle")),1),i("ul",Xe,[i("li",null,a(e.$t("order.message.x402Step1")),1),i("li",null,a(e.$t("order.message.x402Step2",{network:e.displayNetwork||e.expectedNetwork})),1),i("li",null,a(e.$t("order.message.x402Step3")),1),i("li",null,a(e.$t("order.message.x402Step4")),1)])])])]),_:1},8,["label"]),n(x,{label:e.$t("order.message.x402TabApi"),name:"api"},{default:s(()=>[e.hasDetails?(r(),p("section",Ge,[n(I,{column:1,size:"small",class:"x402-descriptions"},{default:s(()=>[e.displayResource?(r(),d(A,{key:0},{label:s(()=>[v(a(e.$t("order.message.x402IntegrationResourceLabel")),1)]),default:s(()=>[i("div",Me,[e.isUrl(e.displayResource)?(r(),p("a",{key:0,href:e.displayResource,target:"_blank",rel:"noopener",class:"text-[var(--el-color-primary)] break-all"},a(e.displayResource),9,Be)):(r(),p("span",Fe,a(e.displayResource),1)),n(P,{content:e.displayResource,class:"inline-flex"},null,8,["content"])])]),_:1})):u("",!0),e.displayPayTo?(r(),d(A,{key:1},{label:s(()=>[v(a(e.$t("order.message.x402IntegrationPayToLabel")),1)]),default:s(()=>[i("div",Le,[i("span",He,a(e.displayPayTo),1),n(P,{content:e.displayPayTo,class:"inline-flex"},null,8,["content"])])]),_:1})):u("",!0),e.displayNetwork?(r(),d(A,{key:2},{label:s(()=>[v(a(e.$t("order.message.x402IntegrationNetworkLabel")),1)]),default:s(()=>[i("span",null,a(e.displayNetwork),1)]),_:1})):u("",!0),e.displayAsset?(r(),d(A,{key:3},{label:s(()=>[v(a(e.$t("order.message.x402IntegrationAssetLabel")),1)]),default:s(()=>[i("span",null,a(e.displayAsset),1)]),_:1})):u("",!0)]),_:1})])):(r(),p("section",Ue,[i("p",null,a(e.$t("order.message.x402IntegrationFallback")),1)])),i("div",je,[n(b,{type:"primary",class:"inline-flex items-center gap-[6px]",onClick:e.onOpenDocs},{default:s(()=>[n(f,null,{default:s(()=>[n(E)]),_:1}),i("span",null,a(e.$t("order.message.x402IntegrationDocsCta")),1)]),_:1},8,["onClick"])])]),_:1},8,["label"])]),_:1},8,["modelValue"])])]),_:1},8,["model-value","title","width"]),n(D,{"model-value":e.installGuideVisible,class:"x402-dialog x402-guide-dialog",width:"520px",top:"15vh",title:e.$t("order.message.x402InstallGuideTitle"),onClose:t[1]||(t[1]=g=>e.installGuideVisible=!1)},{footer:s(()=>[i("div",Qe,[n(b,{type:"primary",round:"",onClick:e.onInstallGuideConfirm},{default:s(()=>[v(a(e.$t("order.message.x402InstallGuideConfirm")),1)]),_:1},8,["onClick"])])]),default:s(()=>[i("div",ze,[i("p",Ye,a(e.$t("order.message.x402InstallGuideDesc",{wallet:e.installGuideWalletLabel})),1),i("ol",Je,[(r(!0),p(C,null,T(e.installGuideSteps,(g,W)=>(r(),p("li",{key:W},a(g),1))),128))])])]),_:1},8,["model-value","title"]),n(D,{"model-value":e.networkGuideVisible,class:"x402-dialog x402-guide-dialog",width:"520px",top:"15vh",title:e.$t("order.message.x402NetworkGuideTitle"),onClose:t[2]||(t[2]=g=>e.networkGuideVisible=!1)},{footer:s(()=>[i("div",tt,[n(b,{type:"primary",round:"",onClick:e.onNetworkGuideConfirm},{default:s(()=>[v(a(e.$t("order.message.x402NetworkGuideConfirm")),1)]),_:1},8,["onClick"])])]),default:s(()=>[i("div",Ke,[i("p",Ze,a(e.$t("order.message.x402NetworkGuideDesc",{network:e.displayNetwork||e.expectedNetwork})),1),i("ol",et,[(r(!0),p(C,null,T(e.networkGuideSteps,(g,W)=>(r(),p("li",{key:W},a(g),1))),128))])])]),_:1},8,["model-value","title"])],64)}const it=V($e,[["render",st],["__scopeId","data-v-c7a3ec9c"]]),rt=7e3,M=2e3;var J=(e=>(e.WechatPay="WechatPay",e.Stripe="Stripe",e.AliPay="AliPay",e.X402="X402",e))(J||{});const at=N({name:"ConsoleOrderDetail",components:{ElButton:z,CopyToClipboard:Y,ElRow:F,ElCard:ne,ElCol:B,ElSkeleton:oe,ElDivider:ae,ElAlert:j,ElDescriptions:U,ElDescriptionsItem:L,ElTag:H,WechatPayOrder:me,StripePayOrder:ve,AlipayPayOrder:Pe,X402PayOrder:it},data(){return{PayWay:J,payWay:"WechatPay",OrderState:$,order:void 0,x402Session:void 0,showPayWays:!0,loading:!1,paying:!1,prepaying:!1}},computed:{id(){return this.$route.params?.id?.toString()},redirect(){return this.$route.query?.redirect},pricingInfo(){const e=this.order?.metadata?.pricing||{},t=P=>typeof P=="number"&&Number.isFinite(P)?P:void 0,o=t(e?.original_price),c=t(e?.discounted_price),y=t(e?.discount_rate),k=t(e?.discount_rate_vip),h=t(e?.discount_rate_x402),f=t(this.order?.price),_=o??f??0,b=c??f??_,w=t(this.order?.discount)??y??0,x=Array.isArray(e?.discounted_methods)?e.discounted_methods.filter(P=>typeof P=="string"&&P.length>0):[];return{original:_,discounted:b,discountRate:w,discountedMethods:x,discountRateVip:k,discountRateX402:h}},appliedDiscountMethods(){return this.pricingInfo.discountedMethods||[]},hasVipApplied(){return this.appliedDiscountMethods.includes("vip")},hasX402Applied(){return this.appliedDiscountMethods.includes("x402")},pendingX402Preview(){return this.payWay==="X402"&&this.order?.pay_way!=="X402"&&this.x402DiscountRate>0},finalOriginalPrice(){return this.pricingInfo.original||0},baseEffectivePrice(){const e=this.order?.price;return typeof e=="number"&&Number.isFinite(e)?e:this.pricingInfo.discounted},previewX402Price(){const e=this.baseEffectivePrice||0,t=this.x402DiscountRate;return!t||t<=0?e:e*(1-t)},finalDiscountedPrice(){return this.pendingX402Preview?this.previewX402Price:this.baseEffectivePrice},showOriginalPrice(){return this.finalOriginalPrice<=0?!1:this.finalOriginalPrice>this.finalDiscountedPrice},totalDiscountRate(){const e=this.pricingInfo.discountRate??0;return this.pendingX402Preview?1-(1-e)*(1-this.x402DiscountRate):e},hasAnyDiscount(){return this.totalDiscountRate>0},discountBadges(){const e=[];return this.hasVipApplied&&this.vipDiscountPercent&&e.push({key:"vip",text:this.$t("order.message.discountTag",{percent:this.vipDiscountPercent}).toString(),type:"success"}),this.shouldDisplayX402Badge&&this.x402BadgePercent&&e.push({key:"x402",text:this.$t("order.message.x402DiscountTag",{percent:this.x402BadgePercent}).toString(),type:"success"}),e},discountHints(){const e=[];return this.hasVipApplied&&this.vipDiscountPercent&&e.push(this.$t("order.message.discountHint",{percent:this.vipDiscountPercent}).toString()),this.hasX402Applied&&this.x402AppliedPercent?e.push(this.$t("order.message.x402DiscountApplied",{percent:this.x402AppliedPercent}).toString()):this.pendingX402Preview&&this.x402BadgePercent&&e.push(this.$t("order.message.x402DiscountHint",{percent:this.x402BadgePercent}).toString()),e},x402DiscountRate(){const e=this.pricingInfo.discountRateX402;return typeof e=="number"&&Number.isFinite(e)&&e>0?e:0},vipDiscountPercent(){const e=(this.pricingInfo.discountRateVip??0)*100;return!Number.isFinite(e)||e<=0?"":Number.isInteger(e)?e.toFixed(0):e.toFixed(1)},x402AppliedPercent(){const t=(this.pricingInfo.discountRateX402??0)*100;return!Number.isFinite(t)||t<=0?"":Number.isInteger(t)?t.toFixed(0):t.toFixed(1)},x402BadgePercent(){const t=(this.hasX402Applied?this.pricingInfo.discountRateX402??this.x402DiscountRate:this.x402DiscountRate)*100;return!Number.isFinite(t)||t<=0?"":Number.isInteger(t)?t.toFixed(0):t.toFixed(1)},shouldDisplayX402Badge(){return this.hasX402Applied||this.pendingX402Preview},shouldShowPriceBlock(){return this.finalOriginalPrice>0||this.finalDiscountedPrice>0||this.hasAnyDiscount||this.pendingX402Preview},orderFailedReason(){if(!this.order||this.order.state!==$.FAILED)return;const t=(this.order.metadata||{})?.x402?.last_error||{};return(typeof t.reason=="string"?t.reason.trim():"")||void 0}},watch:{paying(e){e?this.startOrderPolling():this.stopOrderPolling()},order:{handler(e){if(e?.state===$.PAID){this.x402Session=void 0,setTimeout(()=>{this.redirect&&window.location.replace(this.redirect?.toString())},2e3);return}e?.state&&e.state!==$.PENDING&&e.state!==$.FAILED&&(this.x402Session=void 0)},deep:!0},payWay(e){e!=="X402"&&(this.x402Session=void 0)}},created(){this._orderRefreshTimer=void 0},mounted(){this.onFetchData()},beforeUnmount(){this.stopOrderPolling()},methods:{getPriceString:de,startOrderPolling(e=0){this.stopOrderPolling();const t=async()=>{try{const{data:o}=await S.refresh(this.id);if(this.order=o,o?.state===$.PAID||o?.state===$.FAILED||o?.state===$.EXPIRED){this.paying=!1,this.stopOrderPolling();return}}catch{}this.paying&&(this._orderRefreshTimer=window.setTimeout(t,rt))};this._orderRefreshTimer=window.setTimeout(t,e)},stopOrderPolling(){const e=this._orderRefreshTimer;e&&(clearTimeout(e),this._orderRefreshTimer=void 0)},onFetchData(){this.loading=!0,S.refresh(this.id).then(({data:e})=>{this.order=e,e.pay_way&&(this.payWay=e.pay_way),this.loading=!1}).catch(()=>{this.loading=!1})},onRepay(){this.payWay==="X402"&&(this.x402Session=void 0),this.paying=!0,this.startOrderPolling()},onPay(){this.prepaying=!0,this.payWay==="X402"&&(this.x402Session=void 0),S.pay(this.id,{pay_way:this.payWay}).then(({data:e})=>{if(this.prepaying=!1,e?.id&&(this.order=e),this.payWay==="X402"&&e){const t=e;t.accepts&&(this.x402Session=t)}(this.order&&this.order.price&&this.order.price>0||this.payWay==="X402")&&(this.paying=!0,this.startOrderPolling(M))}).catch(e=>{this.prepaying=!1;const t=e?.response?.data;if(this.payWay==="X402"&&t){this.x402Session=t,this.paying=!0,this.startOrderPolling(M);return}})}}}),ot={class:"title"},nt={key:0,class:"pt-5"},lt={key:1,class:"order"},dt={key:0},pt={key:1},ct={key:2},ut={key:3},ht={key:0,class:"price-block"},mt={class:"price-line"},yt={key:0,class:"price original"},ft={class:"price current unfree"},gt={key:1,class:"price free"},vt={key:0,class:"payways mb-6"},wt={class:"payname"},bt={class:"payname"},kt={class:"payname"},Pt={class:"payname"},$t={key:1},_t={key:2};function xt(e,t,o,c,y,k){const h=l("el-col"),f=l("el-row"),_=l("el-skeleton"),b=l("copy-to-clipboard"),w=l("el-descriptions-item"),x=l("el-tag"),P=l("el-descriptions"),A=l("el-divider"),I=l("el-alert"),E=l("el-button"),X=l("el-card"),D=l("wechat-pay-order"),g=l("stripe-pay-order"),W=l("alipay-pay-order"),Q=l("x402-pay-order");return r(),d(f,{class:"panel"},{default:s(()=>[n(h,{span:24},{default:s(()=>[n(f,null,{default:s(()=>[n(h,{span:24},{default:s(()=>[i("h2",ot,a(e.$t("order.title.info")),1)]),_:1})]),_:1}),n(f,null,{default:s(()=>[n(h,{span:24},{default:s(()=>[n(X,{shadow:"hover"},{default:s(()=>[n(f,null,{default:s(()=>[n(h,{span:16,offset:4},{default:s(()=>[e.loading?(r(),p("div",nt,[n(_,{animated:""})])):(r(),p("div",lt,[n(P,{column:1},{default:s(()=>[n(w,{label:e.$t("order.field.id")},{default:s(()=>[i("span",null,a(e.order?.id),1),e.order?.id?(r(),d(b,{key:0,content:e.order?.id,class:"inline-block"},null,8,["content"])):u("",!0)]),_:1},8,["label"]),n(w,{label:e.$t("order.field.description")},{default:s(()=>[v(a(e.order?.description),1)]),_:1},8,["label"]),e.order?.application?.service?(r(),d(w,{key:0,label:e.$t("order.field.api")},{default:s(()=>[v(a(e.order?.application?.service?.title),1)]),_:1},8,["label"])):u("",!0),e.order?.pay_way?(r(),d(w,{key:1,label:e.$t("order.field.payWay")},{default:s(()=>[e.order?.pay_way===e.PayWay.WechatPay?(r(),p("span",dt,a(e.$t("order.title.wechatPay")),1)):e.order?.pay_way===e.PayWay.Stripe?(r(),p("span",pt,a(e.$t("order.title.stripe")),1)):e.order?.pay_way===e.PayWay.AliPay?(r(),p("span",ct,a(e.$t("order.title.aliPay")),1)):e.order?.pay_way===e.PayWay.X402?(r(),p("span",ut,a(e.$t("order.title.x402")),1)):u("",!0)]),_:1},8,["label"])):u("",!0),n(w,{label:e.$t("order.field.createdAt")},{default:s(()=>[v(a(e.$dayjs.format(e.order?.created_at)),1)]),_:1},8,["label"]),n(w,{label:e.$t("order.field.price")},{default:s(()=>[e.shouldShowPriceBlock?(r(),p("div",ht,[i("div",mt,[e.showOriginalPrice?(r(),p("span",yt,a(e.getPriceString({value:e.finalOriginalPrice})),1)):u("",!0),i("span",ft,a(e.getPriceString({value:e.finalDiscountedPrice})),1),(r(!0),p(C,null,T(e.discountBadges,m=>(r(),d(x,{key:m.key,class:"discount-tag",effect:"light",size:"small",type:m.type},{default:s(()=>[v(a(m.text),1)]),_:2},1032,["type"]))),128))]),(r(!0),p(C,null,T(e.discountHints,(m,K)=>(r(),p("p",{key:K,class:"discount-hint"},a(m),1))),128))])):(r(),p("span",gt,a(e.$t("order.message.free")),1))]),_:1},8,["label"])]),_:1})]))]),_:1})]),_:1}),e.order?.state===e.OrderState.PAID||e.order?.state===e.OrderState.FINISHED?(r(),d(f,{key:0,class:"mb-5"},{default:s(()=>[n(h,{span:16,offset:4},{default:s(()=>[n(A,{"border-style":"dashed"}),n(I,{title:e.$t("order.message.paidSuccessfully"),type:"success","show-icon":"",closable:!1},null,8,["title"])]),_:1})]),_:1})):u("",!0),e.order?.state===e.OrderState.EXPIRED?(r(),d(f,{key:1,class:"mb-5"},{default:s(()=>[n(h,{span:16,offset:4},{default:s(()=>[n(A,{"border-style":"dashed"}),n(I,{title:e.$t("order.message.orderExpired"),type:"error","show-icon":"",closable:!1},null,8,["title"])]),_:1})]),_:1})):u("",!0),e.order?.state===e.OrderState.FAILED?(r(),d(f,{key:2,class:"mb-5"},{default:s(()=>[n(h,{span:16,offset:4},{default:s(()=>[n(A,{"border-style":"dashed"}),n(I,{title:e.$t("order.state.failed"),description:e.orderFailedReason,type:"error","show-icon":"",closable:!1},null,8,["title","description"])]),_:1})]),_:1})):u("",!0),e.order?.state===e.OrderState.PENDING?(r(),d(f,{key:3},{default:s(()=>[n(h,{span:16,offset:4},{default:s(()=>[n(A,{"border-style":"dashed"}),e.showPayWays&&e.order.price&&e.order.price>0&&!e.order.pay_way?(r(),p("div",vt,[i("div",{class:R({payway:!0,wechatpay:!0,active:e.payWay===e.PayWay.WechatPay}),onClick:t[0]||(t[0]=m=>e.payWay=e.PayWay.WechatPay)},[t[12]||(t[12]=i("span",{class:"payicon wechatpay"},null,-1)),i("span",wt,a(e.$t("order.title.wechatPay")),1)],2),i("div",{class:R({payway:!0,alipay:!0,active:e.payWay===e.PayWay.AliPay}),onClick:t[1]||(t[1]=m=>e.payWay=e.PayWay.AliPay)},[t[13]||(t[13]=i("span",{class:"payicon alipay"},null,-1)),i("span",bt,a(e.$t("order.title.aliPay")),1)],2),i("div",{class:R({payway:!0,stripe:!0,active:e.payWay===e.PayWay.Stripe}),onClick:t[2]||(t[2]=m=>e.payWay=e.PayWay.Stripe)},[t[14]||(t[14]=i("span",{class:"payicon stripe"},null,-1)),i("span",kt,a(e.$t("order.title.stripe")),1)],2),i("div",{class:R({payway:!0,x402:!0,relative:!0,active:e.payWay===e.PayWay.X402}),onClick:t[3]||(t[3]=m=>e.payWay=e.PayWay.X402)},[t[15]||(t[15]=i("span",{class:"payicon x402"},null,-1)),i("span",Pt,a(e.$t("order.title.x402")),1),e.x402DiscountRate>0?(r(),d(x,{key:0,class:"absolute -top-2 right-0",effect:"light",size:"small",type:"success"},{default:s(()=>[v(a(e.$t("order.message.x402DiscountTag",{percent:e.x402BadgePercent})),1)]),_:1})):u("",!0)],2)])):u("",!0),e.order?.pay_way?(r(),p("div",_t,[n(E,{type:"primary",round:"",size:"large",class:"btn-repay",onClick:e.onRepay},{default:s(()=>[v(a(e.$t("common.button.repay")),1)]),_:1},8,["onClick"])])):(r(),p("div",$t,[n(E,{loading:e.prepaying,round:"",type:"primary",size:"large",class:"btn-pay",onClick:e.onPay},{default:s(()=>[v(a(e.$t("common.button.pay")),1)]),_:1},8,["loading","onClick"])]))]),_:1})]),_:1})):u("",!0)]),_:1})]),_:1})]),_:1}),n(f,null,{default:s(()=>[n(h,{span:24},{default:s(()=>[e.order&&e.payWay===e.PayWay.WechatPay?(r(),d(D,{key:0,modelValue:e.order,"onUpdate:modelValue":t[4]||(t[4]=m=>e.order=m),visible:e.paying,onHide:t[5]||(t[5]=m=>e.paying=!1)},null,8,["modelValue","visible"])):u("",!0),e.order&&e.payWay===e.PayWay.Stripe?(r(),d(g,{key:1,modelValue:e.order,"onUpdate:modelValue":t[6]||(t[6]=m=>e.order=m),visible:e.paying,onHide:t[7]||(t[7]=m=>e.paying=!1)},null,8,["modelValue","visible"])):u("",!0),e.order&&e.payWay===e.PayWay.AliPay?(r(),d(W,{key:2,modelValue:e.order,"onUpdate:modelValue":t[8]||(t[8]=m=>e.order=m),visible:e.paying,onHide:t[9]||(t[9]=m=>e.paying=!1)},null,8,["modelValue","visible"])):u("",!0),e.order&&e.payWay===e.PayWay.X402?(r(),d(Q,{key:3,modelValue:e.order,"onUpdate:modelValue":t[10]||(t[10]=m=>e.order=m),session:e.x402Session,visible:e.paying,onHide:t[11]||(t[11]=m=>e.paying=!1)},null,8,["modelValue","session","visible"])):u("",!0)]),_:1})]),_:1})]),_:1})]),_:1})}const qt=V(at,[["render",xt],["__scopeId","data-v-ca4b1e4b"]]);export{qt as default};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{bS as y,bN as N}from"./vendor-CdFdgkAf.js";import{e as V,o as b,p as U,E as k,q as L,r as C,a as T}from"./vendor-element-plus-BFf0lqAh.js";import{f as v,h,t as n,i as s,R as o,ak as i,X as r,Y as a,F as _,j as m,Q as $,ah as A,ai as z}from"./vendor-vue-xzGp4vaJ.js";import{_ as E,S as F}from"./index-B9SFMWwY.js";const K=v({name:"EditText",components:{ElDialog:k,ElInput:U,ElButton:b,ElIcon:V,Edit:y},props:{modelValue:{type:String,required:!0},title:{type:String,required:!0},placeholder:{type:String,required:!0}},emits:["confirm","cancel"],data(){return{editing:!1,value:this.modelValue}},methods:{onCancel(){this.editing=!1},onConfirm(){this.$emit("confirm",this.value),this.editing=!1}}}),M={class:"edit-body"},O={class:"dialog-footer"};function D(e,t,S,I,w,q){const c=i("el-input"),d=i("el-button"),p=i("el-dialog"),f=i("edit"),g=i("el-icon");return m(),h(_,null,[n(p,{modelValue:e.editing,"onUpdate:modelValue":t[1]||(t[1]=u=>e.editing=u),title:e.title,width:"400px",class:"edit-dialog"},{footer:o(()=>[s("span",O,[n(d,{round:"",onClick:e.onCancel},{default:o(()=>[r(a(e.$t("common.button.cancel")),1)]),_:1},8,["onClick"]),n(d,{round:"",type:"primary",onClick:e.onConfirm},{default:o(()=>[r(a(e.$t("common.button.confirm")),1)]),_:1},8,["onClick"])])]),default:o(()=>[s("div",M,[n(c,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=u=>e.value=u),placeholder:e.placeholder},null,8,["modelValue","placeholder"])])]),_:1},8,["modelValue","title"]),s("span",{class:"edit",onClick:t[2]||(t[2]=u=>e.editing=!0)},[n(g,{class:"icon"},{default:o(()=>[n(f)]),_:1})])],64)}const ie=E(K,[["render",D]]),J=v({name:"EditImage",components:{ElDialog:k,ElButton:b,FontAwesomeIcon:N,ElIcon:V,Edit:y,ElUpload:L},props:{modelValue:{type:String,required:!0},title:{type:String,required:!0},tip:{type:String,required:!0}},emits:["confirm","cancel"],data(){return{editing:!1,value:this.modelValue,fileList:[],uploadUrl:F()+"/api/v1/files/"}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e?.response?.file_url)}},methods:{onCancel(){this.editing=!1},onConfirm(){this.$emit("confirm",this.urls?.[0]),this.editing=!1},onExceed(){C.warning(this.$t("site.message.uploadImageExceed"))},onError(){C.error(this.$t("site.message.uploadImageError"))}}}),j={class:"edit-body"},P={class:"el-upload__tip"},Q={class:"dialog-footer"};function R(e,t,S,I,w,q){const c=i("font-awesome-icon"),d=i("el-button"),p=i("el-upload"),f=i("el-dialog"),g=i("edit"),u=i("el-icon");return m(),h(_,null,[n(f,{modelValue:e.editing,"onUpdate:modelValue":t[1]||(t[1]=l=>e.editing=l),title:e.title,width:"400px",class:"edit-dialog"},{footer:o(()=>[s("span",Q,[n(d,{round:"",onClick:e.onCancel},{default:o(()=>[r(a(e.$t("common.button.cancel")),1)]),_:1},8,["onClick"]),n(d,{round:"",type:"primary",onClick:e.onConfirm},{default:o(()=>[r(a(e.$t("common.button.confirm")),1)]),_:1},8,["onClick"])])]),default:o(()=>[s("div",j,[n(p,{"file-list":e.fileList,"onUpdate:fileList":t[0]||(t[0]=l=>e.fileList=l),name:"file",limit:5,multiple:!0,action:e.uploadUrl,"list-type":"picture","on-exceed":e.onExceed,"on-error":e.onError,headers:e.headers},{tip:o(()=>[s("div",P,a(e.tip),1)]),default:o(()=>[n(d,{round:"",type:"primary",class:"btn btn-upload"},{default:o(()=>[n(c,{icon:"fa-solid fa-upload",class:"icon mr-2"}),r(" "+a(e.$t("site.button.upload")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","headers"])])]),_:1},8,["modelValue","title"]),s("span",{class:"edit",onClick:t[2]||(t[2]=l=>e.editing=!0)},[n(u,{class:"icon"},{default:o(()=>[n(g)]),_:1})])],64)}const le=E(J,[["render",R]]),X=v({name:"EditText",components:{ElDialog:k,ElInput:U,ElButton:b,ElIcon:V,ElTag:T,Edit:y},props:{modelValue:{type:Array,required:!0},title:{type:String,required:!0},placeholder:{type:String,required:!0},tip:{type:String,default:void 0},min:{type:Number,default:void 0},minErrorMessage:{type:String,default:void 0}},emits:["confirm","cancel"],data(){return{inputVisible:!1,inputValue:"",editing:!1,value:JSON.parse(JSON.stringify(this.modelValue))}},methods:{onCancel(){this.editing=!1},onConfirm(){if(this.min!==void 0&&this.value.length<this.min){C.error(this.minErrorMessage);return}this.$emit("confirm",this.value),this.editing=!1},onClose(e){this.value.splice(this.value.indexOf(e),1)},onInputConfirm(){const e=this.inputValue;e&&this.value.push(e),this.inputVisible=!1,this.inputValue=""},onNewItem(){this.inputVisible=!0,this.$nextTick(()=>{this.$refs.input.focus()})}}}),Y={class:"edit-body"},G={class:"tags"},H={class:"block tip"},W={class:"dialog-footer"};function Z(e,t,S,I,w,q){const c=i("el-tag"),d=i("el-input"),p=i("el-button"),f=i("el-dialog"),g=i("edit"),u=i("el-icon");return m(),h(_,null,[n(f,{modelValue:e.editing,"onUpdate:modelValue":t[1]||(t[1]=l=>e.editing=l),title:e.title,width:"400px",class:"edit-dialog"},{footer:o(()=>[s("span",W,[n(p,{round:"",onClick:e.onCancel},{default:o(()=>[r(a(e.$t("common.button.cancel")),1)]),_:1},8,["onClick"]),n(p,{round:"",type:"primary",onClick:e.onConfirm},{default:o(()=>[r(a(e.$t("common.button.confirm")),1)]),_:1},8,["onClick"])])]),default:o(()=>[s("div",Y,[s("div",G,[(m(!0),h(_,null,A(e.value,(l,B)=>(m(),$(c,{key:B,closable:"",round:"",class:"mr-2 mb-2","disable-transitions":!1,onClose:x=>e.onClose(l)},{default:o(()=>[r(a(l),1)]),_:2},1032,["onClose"]))),128))]),e.inputVisible?(m(),$(d,{key:0,ref:"input",modelValue:e.inputValue,"onUpdate:modelValue":t[0]||(t[0]=l=>e.inputValue=l),class:"block",size:"small",onKeyup:z(e.onInputConfirm,["enter"]),onBlur:e.onInputConfirm},null,8,["modelValue","onKeyup","onBlur"])):(m(),$(p,{key:1,round:"",class:"block",size:"small",onClick:e.onNewItem},{default:o(()=>t[3]||(t[3]=[r(" + ",-1)])),_:1,__:[3]},8,["onClick"])),s("span",H,a(e.tip),1)])]),_:1},8,["modelValue","title"]),s("span",{class:"edit",onClick:t[2]||(t[2]=l=>e.editing=!0)},[n(u,{class:"icon"},{default:o(()=>[n(g)]),_:1})])],64)}const se=E(X,[["render",Z]]);export{se as E,le as a,ie as b};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{I as w}from"./api-Ch0ZHArw.js";import{_ as y,$ as q,a0 as A,X as L}from"./index-B9SFMWwY.js";import"./vendor-CdFdgkAf.js";import{g as E}from"./price-Cw72dIAB.js";import{f as S,h as s,Y as t,j as a,F as $,ah as _,V as n,X as f,Q as d,R as i,t as r,ak as o,i as b,S as N,U as T,Z as R}from"./vendor-vue-xzGp4vaJ.js";import{o as z}from"./order-CwymXjrK.js";import{G,H as j,m as W,o as X,I as H,J,s as Q,w as Y,x as Z,F as K,r as x}from"./vendor-element-plus-BFf0lqAh.js";import"./vendor-axios-NIGUFBhG.js";import"./vendor-vue-router-BTuxvTV5.js";import"./vendor-dayjs-DbiJaq7z.js";import"./vendor-katex-DHBGsivc.js";const ee=S({name:"ApiPrice",props:{price:{type:Number,required:!1,default:0},unit:{type:String,required:!1,default:void 0},start:{type:Boolean,required:!1,default:!1}},methods:{getPriceString:E}}),ae={class:"price-text"},te={key:0,class:"unfree"},ie={key:1,class:"free"};function se(e,l,k,C,I,O){return a(),s("div",ae,[e.price>0?(a(),s("span",te,t(e.getPriceString({value:e.price}))+" "+t(e.unit?` / ${e.unit}`:"")+t(e.start?e.$t("common.message.startPrice"):""),1)):(a(),s("span",ie,t(e.$t("common.message.free")),1))])}const re=y(ee,[["render",se],["__scopeId","data-v-bb068181"]]),oe=S({name:"ServiceEstimation",components:{},props:{service:{type:Object,required:!0},package:{type:Object,required:!0}},methods:{getPriceString:E}}),ne={class:"estimation"},le={key:0,class:"item"},pe={key:0},ce={key:1},ue={key:2},de={key:0},me={key:1};function he(e,l,k,C,I,O){return a(),s("div",ne,[(a(!0),s($,null,_(e.service?.apis,(h,g)=>(a(),s("div",{key:g},[(a(!0),s($,null,_(h?.estimation,(p,c)=>(a(),s("div",{key:c,class:"items"},[e.package?.amount&&p?.cost?(a(),s("p",le,[f(" ≈ "+t(p.name)+" "+t(Math.round(e.package.amount/p.cost))+" "+t(e.$t("api.unit.count"))+" ",1),e.package.price>0?(a(),s("span",pe," - "+t(e.getPriceString({value:e.package.price/(e.package.amount/p.cost),fractionDigits:3})+" / "+e.$t("api.unit.count")),1)):n("",!0),p.remark?(a(),s("span",ce," ("+t(p.remark)+") ",1)):n("",!0),p?.comparisons?.length>0?(a(),s("span",ue," - ")):n("",!0),(a(!0),s($,null,_(p?.comparisons,(m,v)=>(a(),s("span",{key:v,class:"comparison"},[m?.value<0?(a(),s("i",de,t(e.$t("api.message.cheaperThan").replace("$[[value]]",m?.target?.toString()))+" "+t(Math.abs(m?.value)*100)+"% ",1)):n("",!0),m?.value>0?(a(),s("i",me,t(e.$t("api.message.moreExpensiveThan").replace("$[[value]]",m?.target?.toString()))+" "+t(Math.abs(m?.value)*100)+"% ",1)):n("",!0)]))),128))])):n("",!0)]))),128))]))),128))])}const ge=y(oe,[["render",he],["__scopeId","data-v-370bc975"]]),fe=S({name:"ConsoleApplicationBuy",components:{ElSkeleton:K,ElRow:Z,ElCol:Y,ElCard:Q,ElForm:J,ElFormItem:H,ElButton:X,ElDivider:W,ElRadioGroup:j,ElRadioButton:G,Price:re,ServiceEstimation:ge},data(){return{lang:this.$i18n.locale,application:void 0,loading:!1,type:w.USAGE,form:{packageId:void 0,amount:void 0},creating:!1}},computed:{applicationId(){return this.$route.params?.id?.toString()},id(){return this.$route.params?.id?.toString()},price(){return this.application?.service?.price&&this.form.amount?this.form.amount*this.application.service?.price:0},packages(){return this.application?.packages?.filter(e=>e.type===w.USAGE).sort((e,l)=>e.amount-l.amount)||[]},package(){if(this.packages&&this.form.packageId){const e=this.packages.filter(l=>l.id===this.form.packageId);if(e.length>0)return e[0]}}},mounted(){this.onFetchApplication()},methods:{getDiscount(e){return this.packages&&this.packages.length>0?this.lang?.startsWith("zh")?(10*e?.price/e?.amount/(this.packages[0].price/this.packages[0]?.amount)).toFixed(1)+"折":Math.round(100-100*e?.price/e?.amount/(this.packages[0].price/this.packages[0]?.amount))+"% OFF":""},onSubscribe(){this.$router.push({name:A,params:this.$route.params})},getPriceString:E,onFetchApplication(){this.loading=!0,L.get(this.id).then(({data:e})=>{this.application=e,this.loading=!1,this.form.packageId=this.packages?.[0]?.id}).catch(()=>{this.loading=!1})},onChangeType(){this.$router.push({name:A,params:this.$route.params})},onCreateOrder(){if(!this.application?.id)return;this.creating=!0;const e=this.$t(`service.unit.${this.application?.service?.unit}s`);z.create({application_id:this.application?.id,amount:this.package?.amount,...this.form.packageId!=="custom"&&this.package?{package_id:this.package.id}:{},description:this.application?.service?`${this.application?.service?.title} x ${this.package?.amount} ${e}`:this.$t("application.title.globalBuy")+" - "+this.package?.amount+" "+this.$t("service.unit.credits")}).then(({data:l})=>{this.creating=!1;const k=l;this.$router.push({name:q,params:{id:k.id}})}).catch(()=>{x.error(this.$t("order.message.createFailed")),this.creating=!1})}}}),ke={class:"title"},$e={key:0,class:"ml-2"},_e={key:1,class:T({price:!0,free:!0})};function ve(e,l,k,C,I,O){const h=o("el-col"),g=o("el-row"),p=o("el-skeleton"),c=o("el-form-item"),m=o("el-radio-button"),v=o("el-radio-group"),D=o("service-estimation"),V=o("price"),P=o("el-divider"),B=o("el-button"),U=o("el-form"),M=o("el-card");return a(),d(g,{class:"panel"},{default:i(()=>[r(h,{span:24},{default:i(()=>[r(g,null,{default:i(()=>[r(h,{span:24},{default:i(()=>[b("h2",ke,t(e.$t("common.title.buyMore")),1)]),_:1})]),_:1}),r(g,null,{default:i(()=>[r(h,{span:24},{default:i(()=>[r(M,{shadow:"hover"},{default:i(()=>[r(g,null,{default:i(()=>[r(h,{span:16,offset:4},{default:i(()=>[e.loading?(a(),d(p,{key:0})):e.application?(a(),d(U,{key:1,"label-width":"100px"},{default:i(()=>[e.application?.service?(a(),d(c,{key:0,label:e.$t("application.field.service")},{default:i(()=>[f(t(e.application?.service?.title),1)]),_:1},8,["label"])):(a(),d(c,{key:1,label:e.$t("application.field.scope")},{default:i(()=>[f(t(e.$t("application.title.globalBuy")),1)]),_:1},8,["label"])),r(c,{label:e.$t("application.field.package"),class:"mb-0"},{default:i(()=>[e.packages?(a(),d(v,{key:0,modelValue:e.form.packageId,"onUpdate:modelValue":l[0]||(l[0]=u=>e.form.packageId=u)},{default:i(()=>[(a(!0),s($,null,_(e.packages,(u,F)=>(a(),d(m,{key:F,label:u.id,class:"mb-2"},{default:i(()=>[N(b("span",{class:"corner"},t(e.getDiscount(u)),513),[[R,F!==0]]),f(" "+t(u.amount)+" "+t(e.$t(`service.unit.${e.application?.service?.unit||"credit"}s`)),1)]),_:2},1032,["label"]))),128))]),_:1},8,["modelValue"])):n("",!0)]),_:1},8,["label"]),e.application?.service?.apis&&e.application?.service?.apis?.map(u=>u?.estimation).filter(u=>!!u)?.length>0?(a(),d(c,{key:2},{default:i(()=>[e.application?.service?(a(),d(D,{key:0,service:e.application.service,package:e.package},null,8,["service","package"])):n("",!0)]),_:1})):n("",!0),r(c,{label:e.$t("service.field.price")},{default:i(()=>[r(V,{price:e.package?.price},null,8,["price"]),e.package?(a(),s("span",$e,"("+t(e.getPriceString({value:e.package?.price/e.package?.amount})+" / "+e.$t(`service.unit.${e.application?.service?.unit||"credits"}`))+") ",1)):n("",!0)]),_:1},8,["label"]),r(P,{"border-style":"dashed"}),r(c,{label:e.$t("application.field.shouldPayPrice")},{default:i(()=>[e.package?(a(),s("span",{key:0,class:T({price:!0,unfree:e.package?.price>0,free:e.package?.price===0})},t(e.getPriceString({value:e.package?.price})),3)):(a(),s("span",_e," $ 0 "))]),_:1},8,["label"]),r(c,null,{default:i(()=>[r(B,{type:"primary",size:"large",class:"btn-create",loading:e.creating,round:"",onClick:e.onCreateOrder},{default:i(()=>[f(t(e.$t("application.button.createOrder")),1)]),_:1},8,["loading","onClick"])]),_:1}),r(P,{"border-style":"dashed"}),N(r(c,{label:""},{default:i(()=>[b("span",null,t(e.$t("console.message.doNotWantExtra")),1),r(B,{type:"primary",class:"btn btn-subscribe",round:"",size:"small",onClick:e.onSubscribe},{default:i(()=>[f(t(e.$t("console.message.subscribe")),1)]),_:1},8,["onClick"])]),_:1},512),[[R,!1]])]),_:1})):n("",!0)]),_:1})]),_:1})]),_:1})]),_:1})]),_:1})]),_:1})]),_:1})}const Ae=y(fe,[["render",ve],["__scopeId","data-v-ee0069fd"]]);export{Ae as default};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{bN as c}from"./vendor-CdFdgkAf.js";import{ah as p,_ as f}from"./index-B9SFMWwY.js";import{P as m}from"./vendor-element-plus-BFf0lqAh.js";import{f as d,h as a,i as t,V as x,t as o,S as u,ak as n,Z as h,Y as g,j as i}from"./vendor-vue-xzGp4vaJ.js";const _=d({name:"FilePreview",components:{FontAwesomeIcon:c,ElProgress:m},props:{name:{type:String,required:!0},percentage:{type:Number,required:!1,default:void 0},closable:{type:Boolean,required:!1,default:!0}},emits:["remove"],methods:{isImageUrl:p}}),v={class:"file cursor-pointer relative rounded-[10px] h-[50px] w-[250px] flex flex-row items-center justify-start bg-[var(--el-bg-color)]"},w={class:"left h-[50px] w-[50px] flex items-center justify-center"},y={class:"wrapper relative w-[35px] h-[35px] flex items-center justify-center rounded-[10px] text-white bg-[#10a37f] m-auto"},b={class:"right flex-1 h-[50px] flex items-center justify-start pl-[2px] text-[14px] text-[var(--el-text-color-primary)] truncate"},k={class:"text-xs font-bold truncate"},j={key:0,class:"close absolute cursor-pointer top-[5px] right-[5px] bg-[rgba(0,0,0,0.7)] text-white w-[15px] rounded-full h-[15px] flex text-[10px] text-center items-center justify-center"};function $(e,s,N,B,C,F){const r=n("font-awesome-icon"),l=n("el-progress");return i(),a("div",v,[t("div",w,[t("div",y,[o(r,{icon:"fa-regular fa-file-alt"}),u(o(l,{type:"circle","stroke-width":3,percentage:e.percentage,width:25,class:"absolute top-1/2 left-1/2 -translate-x-1/2 -translate-y-1/2 w-[25px] h-[25px] z-[10] m-auto"},null,8,["percentage"]),[[h,e.percentage&&e.percentage<100]])])]),t("div",b,[t("span",k,g(e.name),1)]),e.closable?(i(),a("div",j,[o(r,{icon:"fa-solid fa-xmark",class:"icon icon-close",onClick:s[0]||(s[0]=P=>e.$emit("remove"))})])):x("",!0)])}const E=f(_,[["render",$]]);export{E as F};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{P as g}from"./Pagination-B7408PXm.js";import{C as b}from"./CopyToClipboard-ZLH7uqrY.js";import{b as w}from"./distribution-BpIng5_3.js";import{_ as y}from"./index-B9SFMWwY.js";import"./vendor-CdFdgkAf.js";import{g as $}from"./price-Cw72dIAB.js";import{s as C,t as v,u as D,w as H,x as P}from"./vendor-element-plus-BFf0lqAh.js";import{f as S,Q as p,R as o,t as e,ak as s,i as a,Y as n,S as k,ar as E,j as u}from"./vendor-vue-xzGp4vaJ.js";import"./vendor-axios-NIGUFBhG.js";import"./vendor-vue-router-BTuxvTV5.js";import"./vendor-dayjs-DbiJaq7z.js";import"./vendor-katex-DHBGsivc.js";const F=S({name:"ConsoleDistributionList",components:{Pagination:g,CopyToClipboard:b,ElRow:P,ElCol:H,ElTable:D,ElTableColumn:v,ElCard:C},data(){return{distributionHistories:[],distributionStatus:void 0,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:{getPriceString:$,onPageChange(t){this.$router.push({name:this.$route.name?.toString(),query:{page:t}})},onFetchData(){this.loading=!0,Promise.all([this.onFetchDistributionHistory()]).finally(()=>{this.loading=!1})},async onFetchDistributionHistory(){const{data:t}=await w.getAll({user_id:this.$store.getters.user.id,ordering:"-created_at",limit:this.limit,offset:(this.page-1)*this.limit});this.distributionHistories=t.items,this.total=t.count}}}),q={class:"title"},B={class:"key"},I={class:"copy"},T={class:"key"},j={class:"copy"},z={class:"price"},A={class:"description"},N={class:"description"},R={class:"created-at"},V={class:"pagination m-v-lg"};function L(t,O,Q,Y,G,J){const l=s("el-col"),d=s("el-row"),c=s("copy-to-clipboard"),r=s("el-table-column"),_=s("el-table"),m=s("el-card"),h=s("pagination"),f=E("loading");return u(),p(d,{class:"panel"},{default:o(()=>[e(l,{span:24},{default:o(()=>[e(d,null,{default:o(()=>[e(l,{span:24},{default:o(()=>[a("h2",q,n(t.$t("common.title.distributionHistory")),1)]),_:1})]),_:1}),e(d,null,{default:o(()=>[e(l,{span:24},{default:o(()=>[e(m,{shadow:"hover"},{default:o(()=>[k((u(),p(_,{data:t.distributionHistories,stripe:""},{default:o(()=>[e(r,{prop:"id",label:t.$t("distribution.field.id"),"class-name":"text-center",width:"350px"},{default:o(i=>[a("span",B,n(i.row.id),1),a("span",I,[e(c,{content:i.row.id},null,8,["content"])])]),_:1},8,["label"]),e(r,{prop:"id",label:t.$t("distribution.field.userId"),"class-name":"text-center",width:"350px"},{default:o(i=>[a("span",T,n(i.row.user_id),1),a("span",j,[e(c,{content:i.row.user_id},null,8,["content"])])]),_:1},8,["label"]),e(r,{label:t.$t("distribution.field.price"),width:"100px"},{default:o(i=>[a("span",z,n(t.getPriceString({value:i.row?.price})),1)]),_:1},8,["label"]),e(r,{label:t.$t("distribution.field.reward"),width:"100px"},{default:o(i=>[a("span",A,n(t.getPriceString({value:i.row?.reward})),1)]),_:1},8,["label"]),e(r,{label:t.$t("distribution.field.percentage"),width:"120px"},{default:o(i=>[a("span",N,n(i.row.percentage)+"%",1)]),_:1},8,["label"]),e(r,{label:t.$t("distribution.field.createdAt"),width:"200px"},{default:o(i=>[a("span",R,n(t.$dayjs.format(i.row.created_at)),1)]),_:1},8,["label"])]),_:1},8,["data"])),[[f,t.loading]])]),_:1})]),_:1})]),_:1}),e(d,null,{default:o(()=>[e(l,{span:10,offset:14},{default:o(()=>[a("div",V,[e(h,{"current-page":t.page,"page-size":t.limit,total:t.total,onChange:t.onPageChange},null,8,["current-page","page-size","total","onChange"])])]),_:1})]),_:1})]),_:1})]),_:1})}const st=y(F,[["render",L],["__scopeId","data-v-74b9e778"]]);export{st as default};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{bN as d}from"./vendor-CdFdgkAf.js";import{P as m}from"./vendor-element-plus-BFf0lqAh.js";import{f as u,h as r,i as t,S as s,V as f,Z as a,t as n,ak as l,a0 as g,j as i}from"./vendor-vue-xzGp4vaJ.js";import{_ as b}from"./index-B9SFMWwY.js";const v=u({name:"ImagePreview",components:{FontAwesomeIcon:d,ElProgress:m},props:{url:{type:String,required:!0},name:{type:String,required:!0},percentage:{type:Number,required:!1,default:void 0},closable:{type:Boolean,required:!1,default:!0}},emits:["remove"]}),h={class:"image w-[50px] h-[50px] relative rounded-[var(--el-border-radius-base)] overflow-hidden border border-[var(--el-border-color)] bg-[var(--el-fill-color-lighter)]"},w=["src","alt"],_={class:"overlay absolute inset-0 bg-white/50 backdrop-blur-[1px]"},x={key:0,class:"close absolute cursor-pointer top-[4px] right-[4px] bg-[rgba(0,0,0,0.65)] text-white w-[16px] h-[16px] rounded-full flex text-[10px] text-center items-center justify-center hover:bg-[rgba(0,0,0,0.8)]"};function y(e,o,k,$,N,q){const c=l("el-progress"),p=l("font-awesome-icon");return i(),r("div",h,[t("img",{class:"w-full h-full object-cover",src:e.url,alt:e.name},null,8,w),s(t("div",_,null,512),[[a,e.percentage&&e.percentage<100]]),s(n(c,{type:"circle","stroke-width":4,percentage:e.percentage,width:34,class:"absolute top-1/2 left-1/2 -translate-x-1/2 -translate-y-1/2 w-[34px] h-[34px] z-[10] m-auto text-[12px]"},null,8,["percentage"]),[[a,e.percentage&&e.percentage<100]]),e.closable?(i(),r("div",x,[n(p,{icon:"fa-solid fa-xmark",class:"icon icon-close",onClick:o[0]||(o[0]=g(B=>e.$emit("remove"),["stop"]))})])):f("",!0)])}const V=b(v,[["render",y]]);export{V as I};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{o as i}from"./vendor-element-plus-BFf0lqAh.js";import{f as m,h as a,V as p,Q as l,R as d,X as u,Y as f,ak as g,j as s}from"./vendor-vue-xzGp4vaJ.js";import{_ as w}from"./index-B9SFMWwY.js";const y=m({name:"ImageWrapper",components:{ElButton:i},props:{src:{type:String,required:!0},rawSrc:{type:String,required:!1,default:void 0}},methods:{onOpenUrl(e){window.open(e,"_blank")},onReload(e){const r=e.target,t=new URL(r.src),o=t.searchParams.get("retry");if(!o)t.searchParams.set("retry","1");else if(parseInt(o)<2)t.searchParams.set("retry",(parseInt(o)+1).toString());else return;r.src=t.toString()}}}),_={class:"image-wrapper"},k=["src"];function S(e,r,t,o,I,b){const c=g("el-button");return s(),a("div",_,[e.src?(s(),a("img",{key:0,src:e.src,class:"image",onError:r[0]||(r[0]=n=>e.onReload(n))},null,40,k)):p("",!0),e.rawSrc?(s(),l(c,{key:1,type:"info",round:"",class:"btn-raw",onClick:r[1]||(r[1]=n=>e.onOpenUrl(e.rawSrc))},{default:d(()=>[u(f(e.$t("common.button.seeRawImage")),1)]),_:1})):p("",!0)])}const C=w(y,[["render",S],["__scopeId","data-v-012b4a9e"]]);export{C as I};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{bN as R}from"./vendor-CdFdgkAf.js";import{o as C,O,K as I,L,Q as B,R as F,q as N,r as x,p as z,n as X,D as Q,i as Y}from"./vendor-element-plus-BFf0lqAh.js";import{f as _,h as r,i as l,t as o,M as P,R as d,ak as s,j as a,Y as c,F as V,ah as S,Q as w,U as T,a1 as H,X as k,V as y}from"./vendor-vue-xzGp4vaJ.js";import{_ as h,bl as K,bm as J,bn as W,bo as Z,bp as ee,bq as te,S as se,br as oe,a6 as ne,a3 as D}from"./index-B9SFMWwY.js";import{I as A,S as ae}from"./ScrollList-CsMofi7R.js";import{I as le}from"./ImagePreview-DsZM4u3Y.js";import{C as ie,N as re}from"./NoTasks-C4GBAEFK.js";import{a as ce}from"./price-Cw72dIAB.js";import{C as pe}from"./CopyToClipboard-ZLH7uqrY.js";import{V as de}from"./VideoPlayer-CUqP_b1_.js";import{B as ue}from"./BotPlaceholder-CbNYjS1E.js";import{l as me}from"./pagination-DjyMgG1D.js";import"./vendor-katex-DHBGsivc.js";import"./vendor-dayjs-DbiJaq7z.js";import"./vendor-axios-NIGUFBhG.js";import"./vendor-vue-router-BTuxvTV5.js";const ve=_({name:"LayoutPixverse",components:{ElDrawer:O,ElButton:C,FontAwesomeIcon:R},data(){return{drawer:!1}}}),fe={class:"main flex flex-row flex-1"},_e={class:"config w-[300px] h-full overflow-y-scroll border-r border-[var(--el-border-color)]"},he={class:"result h-full p-[15px] flex-1 flex flex-col"};function $e(e,t,u,m,$,g){const i=s("font-awesome-icon"),p=s("el-button"),n=s("el-drawer");return a(),r("div",fe,[l("div",_e,[P(e.$slots,"config",{},void 0,!0)]),l("div",he,[P(e.$slots,"result",{},void 0,!0)]),o(p,{circle:"",class:"menu",onClick:t[0]||(t[0]=f=>e.drawer=!0)},{default:d(()=>[o(i,{icon:"fa-solid fa-magic"})]),_:1}),o(n,{modelValue:e.drawer,"onUpdate:modelValue":t[1]||(t[1]=f=>e.drawer=f),direction:"ltr","with-header":!1,size:"350px"},{default:d(()=>[P(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const ge=h(ve,[["render",$e],["__scopeId","data-v-0646853d"]]),be=_({name:"ModelSelector",components:{ElSelect:L,ElOption:I},props:{modelValue:{type:String,default:void 0}},emits:["update:modelValue"],data(){return{options:[{value:"v3.5",label:"v3.5"},{value:"v4",label:"v4"},{value:"v4.5",label:"v4.5"}]}},computed:{value:{get(){return this.$store.state.pixverse?.config?.model},set(e){this.$store.commit("pixverse/setConfig",{...this.$store.state.pixverse.config,model:e})}}},mounted(){this.value||(this.value=K)}}),ye={class:"field"},ke={class:"title font-bold"};function we(e,t,u,m,$,g){const i=s("el-option"),p=s("el-select");return a(),r("div",ye,[l("h2",ke,c(e.$t("pixverse.name.model")),1),o(p,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=n=>e.value=n),class:"value",placeholder:e.$t("pixverse.placeholder.select")},{default:d(()=>[(a(!0),r(V,null,S(e.options,n=>(a(),w(i,{key:n.value,label:n.label,value:n.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Ve=h(be,[["render",we],["__scopeId","data-v-e8f337ca"]]),Se=_({name:"QualitySelector",components:{ElSelect:L,ElOption:I},props:{modelValue:{type:String,default:void 0}},emits:["update:modelValue"],data(){return{options:[{value:"360p",label:"360p"},{value:"540p",label:"540p"},{value:"720p",label:"720p"},{value:"1080p",label:"1080p"}]}},computed:{value:{get(){return this.$store.state.pixverse?.config?.quality},set(e){this.$store.commit("pixverse/setConfig",{...this.$store.state.pixverse.config,quality:e})}}},mounted(){this.value||(this.value=J)}}),xe={class:"field"},Ee={class:"title font-bold"};function Te(e,t,u,m,$,g){const i=s("el-option"),p=s("el-select");return a(),r("div",xe,[l("h2",Ee,c(e.$t("pixverse.name.quality")),1),o(p,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=n=>e.value=n),class:"value",placeholder:e.$t("pixverse.placeholder.select")},{default:d(()=>[(a(!0),r(V,null,S(e.options,n=>(a(),w(i,{key:n.value,label:n.label,value:n.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Ie=h(Se,[["render",Te],["__scopeId","data-v-64aeaae9"]]),Le=_({name:"MotionSelector",components:{ElSelect:L,ElOption:I},props:{modelValue:{type:String,default:void 0}},emits:["update:modelValue"],data(){return{options:[{value:"normal",label:this.$t("pixverse.name.motion1")},{value:"fast",label:this.$t("pixverse.name.motion2")}]}},computed:{value:{get(){return this.$store.state.pixverse?.config?.motion},set(e){this.$store.commit("pixverse/setConfig",{...this.$store.state.pixverse.config,motion:e})}}},mounted(){this.value||(this.value=W)}}),Re={class:"field"},Ce={class:"title font-bold"};function Ue(e,t,u,m,$,g){const i=s("el-option"),p=s("el-select");return a(),r("div",Re,[l("h2",Ce,c(e.$t("pixverse.name.motion")),1),o(p,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=n=>e.value=n),class:"value",placeholder:e.$t("pixverse.placeholder.select")},{default:d(()=>[(a(!0),r(V,null,S(e.options,n=>(a(),w(i,{key:n.value,label:n.label,value:n.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Pe=h(Le,[["render",Ue],["__scopeId","data-v-94237408"]]),Ae=_({name:"StyleSelector",components:{ElSelect:L,ElOption:I},props:{modelValue:{type:String,default:void 0}},emits:["update:modelValue"],data(){return{options:[{value:"cyberpunk",label:this.$t("pixverse.name.style1")},{value:"anime",label:this.$t("pixverse.name.style2")},{value:"comic",label:this.$t("pixverse.name.style3")},{value:"clay",label:this.$t("pixverse.name.style4")},{value:"3d_animation",label:this.$t("pixverse.name.style5")},{value:"realistic",label:this.$t("pixverse.name.style6")}]}},computed:{value:{get(){return this.$store.state.pixverse?.config?.style},set(e){this.$store.commit("pixverse/setConfig",{...this.$store.state.pixverse.config,style:e})}}},mounted(){this.value||(this.value=Z)}}),De={class:"field"},Ge={class:"title font-bold"};function je(e,t,u,m,$,g){const i=s("el-option"),p=s("el-select");return a(),r("div",De,[l("h2",Ge,c(e.$t("pixverse.name.style")),1),o(p,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=n=>e.value=n),class:"value",placeholder:e.$t("pixverse.placeholder.select")},{default:d(()=>[(a(!0),r(V,null,S(e.options,n=>(a(),w(i,{key:n.value,label:n.label,value:n.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Me=h(Ae,[["render",je],["__scopeId","data-v-64e17b3c"]]),qe=_({name:"SeedSelector",components:{ElSlider:F,InfoIcon:A,ElInputNumber:B},computed:{value:{get(){return this.$store.state?.pixverse?.config?.seed},set(e){console.debug("set seed",e),this.$store.commit("pixverse/setConfig",{...this.$store.state?.pixverse?.config,seed:e})}}},mounted(){this.value||(this.value=void 0)}}),Oe={class:"flex justify-between"},Be={class:"flex justify-start items-center"},Fe={class:"text-sm font-bold"},Ne={class:"flex justify-end items-center"},ze={class:"w-full"};function Xe(e,t,u,m,$,g){const i=s("info-icon"),p=s("el-input-number"),n=s("el-slider");return a(),r("div",null,[l("div",Oe,[l("div",Be,[l("span",Fe,c(e.$t("pixverse.name.seed")),1),o(i,{content:e.$t("pixverse.description.seed")},null,8,["content"])]),l("div",Ne,[o(p,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=f=>e.value=f),"controls-position":"right"},null,8,["modelValue"])])]),l("div",ze,[o(n,{modelValue:e.value,"onUpdate:modelValue":t[1]||(t[1]=f=>e.value=f),min:0,max:1e3,step:1},null,8,["modelValue"])])])}const Qe=h(qe,[["render",Xe]]),Ye=_({name:"DurationSelector",components:{ElSelect:L,ElOption:I},props:{modelValue:{type:String,default:void 0}},emits:["update:modelValue"],data(){return{options:[{value:5,label:"5s"},{value:8,label:"8s"}]}},computed:{value:{get(){return this.$store.state.pixverse?.config?.duration},set(e){this.$store.commit("pixverse/setConfig",{...this.$store.state.pixverse.config,duration:e})}}},mounted(){this.value||(this.value=ee)}}),He={class:"field"},Ke={class:"title font-bold"};function Je(e,t,u,m,$,g){const i=s("el-option"),p=s("el-select");return a(),r("div",He,[l("h2",Ke,c(e.$t("pixverse.name.duration")),1),o(p,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=n=>e.value=n),class:"value",placeholder:e.$t("pixverse.placeholder.select")},{default:d(()=>[(a(!0),r(V,null,S(e.options,n=>(a(),w(i,{key:n.value,label:n.label,value:n.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const We=h(Ye,[["render",Je],["__scopeId","data-v-065c77ef"]]),Ze=_({name:"RatioSelector",data(){return{options:[{value:"1:1",label:"1:1",width:20,height:20},{value:"4:3",label:"4:3",width:20,height:15},{value:"3:4",label:"3:4",width:15,height:20},{value:"16:9",label:"16:9",width:25,height:13},{value:"9:16",label:"9:16",width:13,height:25}]}},computed:{active(){return this.options.findIndex(e=>e.value===this.value)||0},value:{get(){return this.$store.state.pixverse.config?.aspect_ratio},set(e){console.debug("set aspect_ratio",e),this.$store.commit("pixverse/setConfig",{...this.$store.state.pixverse.config,aspect_ratio:e})}}},mounted(){this.value||(this.value=te)}}),et={class:"text-sm font-bold mb-2 block"},tt={class:"items"},st=["onClick"],ot={class:"name"};function nt(e,t,u,m,$,g){return a(),r("div",null,[l("span",et,c(e.$t("pixverse.name.aspectRatio")),1),l("div",tt,[(a(!0),r(V,null,S(e.options,(i,p)=>(a(),r("div",{key:p,class:T({active:e.active===p,item:!0}),onClick:n=>e.value=i.value},[l("div",{class:T(["preview",i.label])},[l("div",{class:"rect",style:H({width:i.width+"px",height:i.height+"px"})},null,4)],2),l("p",ot,c(i.label),1)],10,st))),128))])])}const at=h(Ze,[["render",nt],["__scopeId","data-v-32a7677f"]]),lt=_({name:"StartImage",components:{ElUpload:N,ElButton:C,InfoIcon:A,FontAwesomeIcon:R,ImagePreview:le},emits:["change"],data(){return{fileList:[],uploadUrl:se()+"/api/v1/files/"}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e?.response?.file_url)},value:{get(){return this.$store.state?.pixverse?.config?.image_url},set(){}}},mounted(){this.value||(this.value=void 0),this.onSetStartImageUrl()},methods:{onExceed(){x.warning(this.$t("pixverse.message.uploadReferencesExceed"))},onError(){x.error(this.$t("pixverse.message.uploadReferencesError"))},onSetStartImageUrl(){const e=this.urls?.[0];this.$store.commit("pixverse/setConfig",{...this.$store.state?.pixverse?.config,image_url:e})},async onSuccess(){this.onSetStartImageUrl()}}}),it={class:"relative"},rt={class:"flex justify-between"},ct={class:"flex justify-start items-center"},pt={class:"text-sm font-bold"};function dt(e,t,u,m,$,g){const i=s("info-icon"),p=s("image-preview"),n=s("font-awesome-icon"),f=s("el-button"),b=s("el-upload");return a(),r("div",it,[l("div",rt,[l("div",ct,[l("span",pt,c(e.$t("pixverse.name.startImage")),1),o(i,{content:e.$t("pixverse.description.uploadStartImage")},null,8,["content"])])]),o(b,{"file-list":e.fileList,"onUpdate:fileList":t[0]||(t[0]=v=>e.fileList=v),name:"file",accept:".png,.jpg,.jpeg,.gif,.bmp,.webp",limit:5,class:"upload-wrapper",multiple:!1,action:e.uploadUrl,"list-type":"picture","on-exceed":e.onExceed,"on-error":e.onError,"on-success":e.onSuccess,headers:e.headers},{file:d(({file:v})=>[v.url&&v.percentage!==void 0?(a(),w(p,{key:0,url:v.url,name:v.name,percentage:v.percentage,onRemove:E=>e.fileList.splice(e.fileList.indexOf(v),1)},null,8,["url","name","percentage","onRemove"])):y("",!0)]),default:d(()=>[o(f,{round:"",type:"primary",size:"small",class:"btn btn-upload"},{default:d(()=>[o(n,{icon:"fa-solid fa-upload",class:"icon mr-1"}),k(" "+c(e.$t("pixverse.button.uploadReferences")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-success","headers"])])}const ut=h(lt,[["render",dt],["__scopeId","data-v-666104e4"]]),mt="",vt=_({name:"PromptInput",components:{ElInput:z,InfoIcon:A},computed:{prompt:{get(){return this.$store.state.pixverse?.config?.prompt},set(e){console.debug("set prompt",e),this.$store.commit("pixverse/setConfig",{...this.$store.state.pixverse?.config,prompt:e})}}},mounted(){this.prompt||(this.prompt=mt)}}),ft={class:"field"},_t={class:"box"},ht={class:"title font-bold"};function $t(e,t,u,m,$,g){const i=s("info-icon"),p=s("el-input");return a(),r("div",ft,[l("div",_t,[l("h2",ht,c(e.$t("pixverse.name.prompt")),1),o(i,{content:e.$t("pixverse.description.prompt"),class:"info"},null,8,["content"])]),o(p,{modelValue:e.prompt,"onUpdate:modelValue":t[0]||(t[0]=n=>e.prompt=n),rows:3,type:"textarea",class:"prompt",placeholder:e.$t("pixverse.placeholder.prompt"),maxlength:500,"show-word-limit":""},null,8,["modelValue","placeholder"])])}const gt=h(vt,[["render",$t],["__scopeId","data-v-b3dd608e"]]),bt=_({name:"ConfigPanel",components:{ElButton:C,FontAwesomeIcon:R,PromptInput:gt,ModelSelector:Ve,QualitySelector:Ie,MotionSelector:Pe,StyleSelector:Me,DurationSelector:We,StartImage:ut,SeedSelector:Qe,RatioSelector:at,Consumption:ie},emits:["generate"],computed:{config(){return this.$store.state.pixverse?.config},consumption(){return ce(this.config,this.service?.cost)},service(){return this.$store.state.pixverse?.service}},methods:{onGenerate(){this.$emit("generate")}}}),yt={class:"flex flex-col h-full"},kt={class:"flex-1 overflow-y-auto p-[15px]"},wt={class:"flex flex-col items-center justify-center px-[15px] pb-[15px]"};function Vt(e,t,u,m,$,g){const i=s("prompt-input"),p=s("model-selector"),n=s("style-selector"),f=s("ratio-selector"),b=s("motion-selector"),v=s("quality-selector"),E=s("start-image"),U=s("seed-selector"),G=s("duration-selector"),j=s("consumption"),M=s("font-awesome-icon"),q=s("el-button");return a(),r("div",yt,[l("div",kt,[o(i,{class:"mb-4"}),o(p,{class:"mb-4"}),o(n,{class:"mb-4"}),o(f,{class:"mb-4"}),o(b,{class:"mb-4"}),o(v,{class:"mb-4"}),o(E,{class:"mb-2"}),o(U,{class:"mb-4"}),o(G,{class:"mb-4"})]),l("div",wt,[o(j,{value:e.consumption,service:e.service},null,8,["value","service"]),o(q,{type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:d(()=>[o(M,{icon:"fa-solid fa-magic",class:"mr-2"}),k(" "+c(e.$t("pixverse.button.generate")),1)]),_:1},8,["onClick"])])])}const St=h(bt,[["render",Vt]]),xt=_({name:"TaskPreview",components:{ElImage:Y,CopyToClipboard:pe,FontAwesomeIcon:R,ElAlert:Q,VideoPlayer:de,ElTooltip:X,ElButton:C},props:{modelValue:{type:Object,required:!0}},data(){return{}},computed:{application(){return this.$store.state.pixverse?.application},config(){return this.$store.state.pixverse?.config}},methods:{onDownload(e,t){e.stopPropagation(),console.log("on download"),window.open(t,"_blank")},onOpenVideo(e){window.open(e,"_blank")}}}),Et={class:"preview"},Tt={class:"left"},It={class:"main"},Lt={class:"bot"},Rt={class:"datetime"},Ct={class:"info"},Ut={key:0,class:"prompt mt-2"},Pt={key:0},At={key:1},Dt={key:0,class:T({content:!0,failed:!0})},Gt={key:0,class:"mb-4"},jt={key:1,class:T({operations:!0,"mt-2":!0})},Mt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},qt={class:"text-[var(--el-text-color-regular)] text-xs mb-0"},Ot={key:1,class:T({content:!0})},Bt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Ft={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Nt={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-0"};function zt(e,t,u,m,$,g){const i=s("el-image"),p=s("video-player"),n=s("el-button"),f=s("el-tooltip"),b=s("font-awesome-icon"),v=s("copy-to-clipboard"),E=s("el-alert");return a(),r("div",Et,[l("div",Tt,[o(i,{src:"https://cdn.acedata.cloud/viy61r.jpg",class:"avatar"})]),l("div",It,[l("div",Lt,[k(c(e.$t("pixverse.name.pixverseBot"))+" ",1),l("span",Rt,c(e.$dayjs.format(""+new Date(parseFloat((e.modelValue?.created_at||"").toString())*1e3))),1)]),l("div",Ct,[e.modelValue?.request?.prompt?(a(),r("p",Ut,[k(c(e.modelValue?.request?.prompt)+" ",1),e.modelValue?.response?y("",!0):(a(),r("span",Pt," - ("+c(e.$t("pixverse.status.pending"))+") ",1)),e.modelValue?.response?.data&&(e.modelValue?.response?.data[0]?.state==="processing"||e.modelValue?.response?.data[0]?.state==="pending")?(a(),r("span",At," - ("+c(e.$t("pixverse.status.processing"))+") ",1)):y("",!0)])):y("",!0)]),e.modelValue?.response?.success===!0&&e.modelValue?.response?.data?(a(),r("div",Dt,[e.modelValue?.response?.data[0]?.video_url?(a(),r("div",Gt,[o(p,{src:e.modelValue?.response?.data[0]?.video_url},null,8,["src"])])):y("",!0),e.modelValue?.response.success?(a(),r("div",jt,[o(f,{class:"box-item",effect:"dark",content:e.$t("pixverse.message.downloadVideo"),placement:"top-start"},{default:d(()=>[e.modelValue?.response?.data[0]?.video_url?(a(),w(n,{key:0,type:"info",size:"small",class:"btn-action",onClick:t[0]||(t[0]=U=>e.onDownload(U,e.modelValue?.response?.data[0]?.video_url))},{default:d(()=>[k(c(e.$t("pixverse.button.download")),1)]),_:1})):y("",!0)]),_:1},8,["content"])])):y("",!0),o(E,{closable:!1,class:"mt-2 success"},{default:d(()=>[l("p",Mt,[o(b,{icon:"fa-solid fa-hashtag",class:"mr-1"}),k(" "+c(e.$t("pixverse.name.model"))+": "+c(e.modelValue?.request?.model),1)]),l("p",qt,[o(b,{icon:"fa-solid fa-magic",class:"mr-1"}),k(" "+c(e.$t("pixverse.name.taskId"))+": "+c(e.modelValue?.id)+" ",1),o(v,{content:e.modelValue?.id},null,8,["content"])])]),_:1})])):y("",!0),e.modelValue?.response?.success===!1?(a(),r("div",Ot,[o(E,{closable:!1,class:"info"},{template:d(()=>[o(b,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),k(" "+c(e.$t("pixverse.name.failure")),1)]),default:d(()=>[l("p",Bt,[o(b,{icon:"fa-solid fa-circle-info",class:"mr-1"}),k(" "+c(e.$t("pixverse.name.failureReason"))+": "+c(e.modelValue?.response?.error?.message)+" ",1),o(v,{content:e.modelValue?.response?.error?.message},null,8,["content"])]),l("p",Ft,[o(b,{icon:"fa-solid fa-magic",class:"mr-1"}),k(" "+c(e.$t("pixverse.name.taskId"))+": "+c(e.modelValue?.id)+" ",1),o(v,{content:e.modelValue?.id},null,8,["content"])]),e.modelValue?.response?.trace_id?(a(),r("p",Nt,[o(b,{icon:"fa-solid fa-hashtag",class:"mr-1"}),k(" "+c(e.$t("pixverse.name.traceId"))+": "+c(e.modelValue?.response?.trace_id)+" ",1),o(v,{content:e.modelValue?.response?.trace_id},null,8,["content"])])):y("",!0)]),_:1})])):y("",!0)])])}const Xt=h(xt,[["render",zt],["__scopeId","data-v-3f3bff8a"]]),Qt=_({name:"RecentPanel",components:{TaskPreview:Xt,NoTasks:re,BotPlaceholder:ue,ScrollList:ae},props:{loading:{type:Boolean,default:!1}},emits:["reach-top"],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.pixverse?.tasks,items:this.$store.state.pixverse?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),Yt={key:0},Ht={key:2,class:"w-full h-full flex items-center justify-center"};function Kt(e,t,u,m,$,g){const i=s("bot-placeholder"),p=s("task-preview"),n=s("scroll-list"),f=s("no-tasks");return a(),r(V,null,[e.tasks?.items===void 0?(a(),r("div",Yt,[o(i)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(a(),w(n,{key:1,ref:"scrollList",class:"h-full w-full overflow-y-auto tasks",loading:e.loading,onReachTop:t[0]||(t[0]=b=>e.$emit("reach-top"))},{default:d(()=>[(a(!0),r(V,null,S(e.tasks?.items,(b,v)=>(a(),w(p,{key:v,"model-value":b},null,8,["model-value"]))),128))]),_:1},8,["loading"])):y("",!0),e.tasks?.items?.length===0?(a(),r("div",Ht,[o(f)])):y("",!0)],64)}const Jt=h(Qt,[["render",Kt]]),Wt="https://webhook.acedata.cloud/pixverse",Zt=_({name:"PixverseIndex",components:{ConfigPanel:St,Layout:ge,RecentPanel:Jt},inject:["initialized"],data(){return{task:void 0,job:0,loadingMore:!1,fetchingTasks:!1}},computed:{applicationsLoading(){return this.$store.state.pixverse?.status?.getApplications===D.Request},tasksLoading(){return this.$store.state.pixverse?.status?.getTasks===D.Request||this.fetchingTasks},credential(){return this.$store.state.pixverse.credential},config(){return this.$store.state.pixverse.config},tasks(){return this.$store.state.pixverse.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=setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){clearInterval(this.job)},methods:{async onReachTop(){await me({tasks:this.tasks,getTasks:()=>this.tasks,loading:this.loadingMore,setLoading:e=>this.loadingMore=e,isBlocked:()=>this.tasksLoading||this.applicationsLoading,fetch:e=>this.onGetTasks({createdAtMax:e}),getScrollElement:()=>this.getTasksScrollElement()})},async onGetService(){console.debug("start onGetService"),await this.$store.dispatch("pixverse/getService"),console.debug("end onGetService")},async onGetApplication(){console.debug("start onGetApplication"),await this.$store.dispatch("pixverse/getApplications"),console.debug("end onGetApplication"),await this.onGetTasks()},async onScrollDown(){await this.$nextTick();const e=this.getTasksScrollElement();e&&(e.scrollTop=e.scrollHeight)},async onGetTasks(e){if(this.applicationsLoading||this.fetchingTasks){console.debug("loading");return}console.debug("start onGetTasks",e);const{limit:t=5,createdAtMin:u,createdAtMax:m}=e||{};console.debug("limit",t,"createdAtMin",u,"createdAtMax",m),this.fetchingTasks=!0;try{await this.$store.dispatch("pixverse/getTasks",{limit:t,createdAtMin:u,createdAtMax:m})}finally{this.fetchingTasks=!1}},async onGenerate(){const e={...this.config,callback_url:Wt},t=this.credential?.token;if(!t){console.error("no token specified");return}x.info(this.$t("pixverse.message.startingTask")),oe.generate(e,{token:t}).then(()=>{x.success(this.$t("pixverse.message.startTaskSuccess"))}).catch(u=>{u?.response?.data?.error?.code===ne?x.error(this.$t("pixverse.message.usedUp")):x.error(this.$t("pixverse.message.startTaskFailed"))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function es(e,t,u,m,$,g){const i=s("config-panel"),p=s("recent-panel"),n=s("layout");return a(),w(n,null,{config:d(()=>[o(i,{onGenerate:e.onGenerate},null,8,["onGenerate"])]),result:d(()=>[o(p,{ref:"recentPanel",loading:e.loadingMore,onReachTop:e.onReachTop},null,8,["loading","onReachTop"])]),_:1})}const hs=h(Zt,[["render",es]]);export{hs as default};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{bN as T}from"./vendor-CdFdgkAf.js";import{o as L,O as K,K as G,L as A,q as N,r as V,Q,R as H,p as O,n as X,D as Y,i as J}from"./vendor-element-plus-BFf0lqAh.js";import{f as v,h as c,i as a,t,M as P,R as p,ak as o,j as n,Y as i,F as I,ah as C,Q as y,U as E,a1 as W,X as h,V as $}from"./vendor-vue-xzGp4vaJ.js";import{_ as k,b0 as Z,b1 as x,b2 as ee,b3 as te,S as B,b4 as oe,b5 as se,a6 as ne,a3 as M}from"./index-B9SFMWwY.js";import{I as U,S as le}from"./ScrollList-CsMofi7R.js";import{I as F}from"./ImagePreview-DsZM4u3Y.js";import{C as ae,N as ie}from"./NoTasks-C4GBAEFK.js";import{a as re}from"./price-Cw72dIAB.js";import{C as ce}from"./CopyToClipboard-ZLH7uqrY.js";import{V as de}from"./VideoPlayer-CUqP_b1_.js";import{B as ue}from"./BotPlaceholder-CbNYjS1E.js";import{l as pe}from"./pagination-DjyMgG1D.js";import"./vendor-katex-DHBGsivc.js";import"./vendor-dayjs-DbiJaq7z.js";import"./vendor-axios-NIGUFBhG.js";import"./vendor-vue-router-BTuxvTV5.js";const me=v({name:"LayoutKling",components:{ElDrawer:K,ElButton:L,FontAwesomeIcon:T},data(){return{drawer:!1}}}),ge={class:"main flex flex-row flex-1"},fe={class:"config w-[300px] h-full overflow-y-scroll border-r border-[var(--el-border-color)]"},_e={class:"result h-full p-[15px] flex-1 flex flex-col"};function he(e,s,g,f,b,w){const r=o("font-awesome-icon"),d=o("el-button"),l=o("el-drawer");return n(),c("div",ge,[a("div",fe,[P(e.$slots,"config",{},void 0,!0)]),a("div",_e,[P(e.$slots,"result",{},void 0,!0)]),t(d,{circle:"",class:"menu",onClick:s[0]||(s[0]=_=>e.drawer=!0)},{default:p(()=>[t(r,{icon:"fa-solid fa-magic"})]),_:1}),t(l,{modelValue:e.drawer,"onUpdate:modelValue":s[1]||(s[1]=_=>e.drawer=_),direction:"ltr","with-header":!1,size:"350px"},{default:p(()=>[P(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const $e=k(me,[["render",he],["__scopeId","data-v-fae64b48"]]),ve=v({name:"ModelSelector",components:{ElSelect:A,ElOption:G},props:{modelValue:{type:String,default:void 0}},emits:["update:modelValue"],data(){return{options:[{value:"kling-v1",label:"v1"},{value:"kling-v1-6",label:"v1.6"},{value:"kling-v2-master",label:"v2-Master"},{value:"kling-v2-1-master",label:"v2.1-Master"},{value:"kling-v2-5-turbo",label:"v2.5-Turbo"}]}},computed:{value:{get(){return this.$store.state.kling?.config?.model},set(e){this.$store.commit("kling/setConfig",{...this.$store.state.kling.config,model:e})}}},mounted(){this.value||(this.value=Z)}}),ke={class:"field"},be={class:"title font-bold"};function we(e,s,g,f,b,w){const r=o("el-option"),d=o("el-select");return n(),c("div",ke,[a("h2",be,i(e.$t("pika.name.model")),1),t(d,{modelValue:e.value,"onUpdate:modelValue":s[0]||(s[0]=l=>e.value=l),class:"value",placeholder:e.$t("pika.placeholder.select")},{default:p(()=>[(n(!0),c(I,null,C(e.options,l=>(n(),y(r,{key:l.value,label:l.label,value:l.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const ye=k(ve,[["render",we],["__scopeId","data-v-e476bacf"]]),Ve=v({name:"ModeSelector",components:{ElSelect:A,ElOption:G},props:{modelValue:{type:String,default:void 0}},emits:["update:modelValue"],data(){return{options:[{value:"std",label:this.$t("kling.name.modeStd")},{value:"pro",label:this.$t("kling.name.modePro")}]}},computed:{value:{get(){return this.$store.state.kling?.config?.mode},set(e){this.$store.commit("kling/setConfig",{...this.$store.state.kling.config,mode:e})}}},mounted(){this.value||(this.value=x)}}),Se={class:"field"},Ie={class:"title font-bold"};function Ee(e,s,g,f,b,w){const r=o("el-option"),d=o("el-select");return n(),c("div",Se,[a("h2",Ie,i(e.$t("kling.name.mode")),1),t(d,{modelValue:e.value,"onUpdate:modelValue":s[0]||(s[0]=l=>e.value=l),class:"value",placeholder:e.$t("kling.placeholder.select"),clearable:!0},{default:p(()=>[(n(!0),c(I,null,C(e.options,l=>(n(),y(r,{key:l.value,label:l.label,value:l.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Te=k(Ve,[["render",Ee],["__scopeId","data-v-daa57765"]]),Le=v({name:"DurationSelector",components:{ElSelect:A,ElOption:G},props:{modelValue:{type:String,default:void 0}},emits:["update:modelValue"],data(){return{options:[{value:5,label:"5秒"},{value:10,label:"10秒"}]}},computed:{value:{get(){return this.$store.state.kling?.config?.duration},set(e){this.$store.commit("kling/setConfig",{...this.$store.state.kling.config,duration:e})}}},mounted(){this.value||(this.value=ee)}}),Ce={class:"field"},Ue={class:"title font-bold"};function Re(e,s,g,f,b,w){const r=o("el-option"),d=o("el-select");return n(),c("div",Ce,[a("h2",Ue,i(e.$t("kling.name.duration")),1),t(d,{modelValue:e.value,"onUpdate:modelValue":s[0]||(s[0]=l=>e.value=l),class:"value",placeholder:e.$t("kling.placeholder.select")},{default:p(()=>[(n(!0),c(I,null,C(e.options,l=>(n(),y(r,{key:l.value,label:l.label,value:l.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Pe=k(Le,[["render",Re],["__scopeId","data-v-02112e2c"]]),Ge=v({name:"RatioSelector",data(){return{options:[{value:"1:1",label:"1:1",width:20,height:20},{value:"16:9",label:"16:9",width:25,height:13},{value:"9:16",label:"9:16",width:13,height:25}]}},computed:{active(){return this.options.findIndex(e=>e.value===this.value)||0},value:{get(){return this.$store.state?.kling?.config?.aspect_ratio},set(e){console.debug("set ratio",e),this.$store.commit("kling/setConfig",{...this.$store.state?.kling?.config,aspect_ratio:e})}}},mounted(){this.value||(this.value=te)}}),Ae={class:"text-sm font-bold mb-2 block"},De={class:"items"},je=["onClick"],Me={class:"name"};function Ne(e,s,g,f,b,w){return n(),c("div",null,[a("span",Ae,i(e.$t("kling.name.ratio")),1),a("div",De,[(n(!0),c(I,null,C(e.options,(r,d)=>(n(),c("div",{key:d,class:E({active:e.active===d,item:!0}),onClick:l=>e.value=r.value},[a("div",{class:E(["preview",r.label])},[a("div",{class:"rect",style:W({width:r.width+"px",height:r.height+"px"})},null,4)],2),a("p",Me,i(r.label),1)],10,je))),128))])])}const Oe=k(Ge,[["render",Ne],["__scopeId","data-v-2601284f"]]),Be=v({name:"StartImage",components:{ElUpload:N,ElButton:L,InfoIcon:U,FontAwesomeIcon:T,ImagePreview:F},emits:["change"],data(){return{fileList:[],uploadUrl:B()+"/api/v1/files/"}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e?.response?.file_url)},value:{get(){return this.$store.state?.kling?.config?.start_image_url},set(){}}},mounted(){this.value||(this.value=void 0),this.onSetStartImageUrl()},methods:{onExceed(){V.warning(this.$t("kling.message.uploadReferencesExceed"))},onError(){V.error(this.$t("kling.message.uploadReferencesError"))},onSetStartImageUrl(){const e=this.urls?.[0];this.$store.commit("kling/setConfig",{...this.$store.state?.kling?.config,start_image_url:e})},async onSuccess(){this.onSetStartImageUrl()}}}),Fe={class:"relative"},ze={class:"flex justify-between"},qe={class:"flex justify-start items-center"},Ke={class:"text-sm font-bold"};function Qe(e,s,g,f,b,w){const r=o("info-icon"),d=o("image-preview"),l=o("font-awesome-icon"),_=o("el-button"),m=o("el-upload");return n(),c("div",Fe,[a("div",ze,[a("div",qe,[a("span",Ke,i(e.$t("kling.name.startImage")),1),t(r,{content:e.$t("kling.description.uploadStartImage")},null,8,["content"])])]),t(m,{"file-list":e.fileList,"onUpdate:fileList":s[0]||(s[0]=u=>e.fileList=u),name:"file",accept:".png,.jpg,.jpeg,.gif,.bmp,.webp",limit:5,class:"upload-wrapper",multiple:!1,action:e.uploadUrl,"list-type":"picture","on-exceed":e.onExceed,"on-error":e.onError,"on-success":e.onSuccess,headers:e.headers},{file:p(({file:u})=>[u.url&&u.percentage!==void 0?(n(),y(d,{key:0,url:u.url,name:u.name,percentage:u.percentage,onRemove:S=>e.fileList.splice(e.fileList.indexOf(u),1)},null,8,["url","name","percentage","onRemove"])):$("",!0)]),default:p(()=>[t(_,{round:"",type:"primary",size:"small",class:"btn btn-upload"},{default:p(()=>[t(l,{icon:"fa-solid fa-upload",class:"icon mr-1"}),h(" "+i(e.$t("kling.button.uploadReferences")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-success","headers"])])}const He=k(Be,[["render",Qe],["__scopeId","data-v-e2205d5b"]]),Xe=v({name:"EndImage",components:{ElUpload:N,ElButton:L,ImagePreview:F,InfoIcon:U,FontAwesomeIcon:T},data(){return{fileList:[],uploadUrl:B()+"/api/v1/files/"}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e?.response?.file_url)},value:{get(){return this.$store.state?.kling?.config?.start_image_url},set(){}}},mounted(){this.value||(this.value=void 0),this.onSetEndImageUrl()},methods:{onExceed(){V.warning(this.$t("kling.message.uploadReferencesExceed"))},onError(){V.error(this.$t("kling.message.uploadReferencesError"))},onSetEndImageUrl(){const e=this.urls?.[0];this.$store.commit("kling/setConfig",{...this.$store.state.kling?.config,end_image_url:e})},async onSuccess(){this.onSetEndImageUrl()}}}),Ye={class:"relative"},Je={class:"flex justify-between"},We={class:"flex justify-start items-center"},Ze={class:"text-sm font-bold"};function xe(e,s,g,f,b,w){const r=o("info-icon"),d=o("image-preview"),l=o("font-awesome-icon"),_=o("el-button"),m=o("el-upload");return n(),c("div",Ye,[a("div",Je,[a("div",We,[a("span",Ze,i(e.$t("kling.name.endImage")),1),t(r,{content:e.$t("kling.description.uploadEndImage")},null,8,["content"])])]),t(m,{"file-list":e.fileList,"onUpdate:fileList":s[0]||(s[0]=u=>e.fileList=u),name:"file",accept:".png,.jpg,.jpeg,.gif,.bmp,.webp",limit:5,class:"upload-wrapper",multiple:!1,action:e.uploadUrl,"list-type":"picture","on-exceed":e.onExceed,"on-error":e.onError,"on-success":e.onSuccess,headers:e.headers},{file:p(({file:u})=>[u.url&&u.percentage!==void 0?(n(),y(d,{key:0,url:u.url,name:u.name,percentage:u.percentage,onRemove:S=>e.fileList.splice(e.fileList.indexOf(u),1)},null,8,["url","name","percentage","onRemove"])):$("",!0)]),default:p(()=>[t(_,{round:"",type:"primary",size:"small",class:"btn btn-upload"},{default:p(()=>[t(l,{icon:"fa-solid fa-upload",class:"icon mr-1"}),h(" "+i(e.$t("kling.button.uploadReferences")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-success","headers"])])}const et=k(Xe,[["render",xe],["__scopeId","data-v-caf87d80"]]),tt=v({name:"CfgScaleSelector",components:{ElSlider:H,InfoIcon:U,ElInputNumber:Q},computed:{value:{get(){return this.$store.state?.kling?.config?.cfg_scale},set(e){console.debug("set cfg_scale",e),this.$store.commit("kling/setConfig",{...this.$store.state?.kling?.config,cfg_scale:e})}}},mounted(){this.value||(this.value=oe)}}),ot={class:"flex justify-between"},st={class:"flex justify-start items-center"},nt={class:"text-sm font-bold"},lt={class:"flex justify-end items-center"},at={class:"w-full"};function it(e,s,g,f,b,w){const r=o("info-icon"),d=o("el-input-number"),l=o("el-slider");return n(),c("div",null,[a("div",ot,[a("div",st,[a("span",nt,i(e.$t("kling.name.cfgScale")),1),t(r,{content:e.$t("kling.description.cfgScale")},null,8,["content"])]),a("div",lt,[t(d,{modelValue:e.value,"onUpdate:modelValue":s[0]||(s[0]=_=>e.value=_),"controls-position":"right"},null,8,["modelValue"])])]),a("div",at,[t(l,{modelValue:e.value,"onUpdate:modelValue":s[1]||(s[1]=_=>e.value=_),min:0,max:1,step:.1},null,8,["modelValue"])])])}const rt=k(tt,[["render",it]]),ct="",dt=v({name:"PromptInput",components:{ElInput:O,InfoIcon:U},computed:{prompt:{get(){return this.$store.state.kling?.config?.prompt},set(e){console.debug("set prompt",e),this.$store.commit("kling/setConfig",{...this.$store.state.kling?.config,prompt:e})}}},mounted(){this.prompt||(this.prompt=ct)}}),ut={class:"field"},pt={class:"box"},mt={class:"title font-bold"};function gt(e,s,g,f,b,w){const r=o("info-icon"),d=o("el-input");return n(),c("div",ut,[a("div",pt,[a("h2",mt,i(e.$t("kling.name.prompt")),1),t(r,{content:e.$t("kling.description.prompt"),class:"info"},null,8,["content"])]),t(d,{modelValue:e.prompt,"onUpdate:modelValue":s[0]||(s[0]=l=>e.prompt=l),rows:3,type:"textarea",class:"prompt",placeholder:e.$t("kling.placeholder.prompt"),maxlength:500,"show-word-limit":""},null,8,["modelValue","placeholder"])])}const ft=k(dt,[["render",gt],["__scopeId","data-v-0e95dea6"]]),_t="",ht=v({name:"NegativePromptInput",components:{ElInput:O,InfoIcon:U},computed:{prompt:{get(){return this.$store.state.kling?.config?.negative_prompt},set(e){console.debug("set prompt",e),this.$store.commit("kling/setConfig",{...this.$store.state.kling?.config,negative_prompt:e})}}},mounted(){this.prompt||(this.prompt=_t)}}),$t={class:"field"},vt={class:"box"},kt={class:"title font-bold"};function bt(e,s,g,f,b,w){const r=o("info-icon"),d=o("el-input");return n(),c("div",$t,[a("div",vt,[a("h2",kt,i(e.$t("kling.name.negativePrompt")),1),t(r,{content:e.$t("kling.description.negativePrompt"),class:"info"},null,8,["content"])]),t(d,{modelValue:e.prompt,"onUpdate:modelValue":s[0]||(s[0]=l=>e.prompt=l),rows:3,type:"textarea",class:"prompt",placeholder:e.$t("kling.placeholder.negativePrompt"),maxlength:200,"show-word-limit":""},null,8,["modelValue","placeholder"])])}const wt=k(ht,[["render",bt],["__scopeId","data-v-dfc5338b"]]),yt=v({name:"ConfigPanel",components:{ElButton:L,Consumption:ae,FontAwesomeIcon:T,PromptInput:ft,NegativePromptInput:wt,ModelSelector:ye,ModeSelector:Te,DurationSelector:Pe,RatioSelector:Oe,StartImage:He,CfgScaleSelector:rt,EndImage:et},emits:["generate"],computed:{config(){return this.$store.state.kling?.config},consumption(){return re(this.config,this.service?.cost)},service(){return this.$store.state.kling?.service}},methods:{onGenerate(){this.$emit("generate")}}}),Vt={class:"flex flex-col h-full"},St={class:"flex-1 overflow-y-auto p-[15px]"},It={class:"flex flex-col items-center justify-center px-[15px] pb-[15px]"};function Et(e,s,g,f,b,w){const r=o("prompt-input"),d=o("model-selector"),l=o("ratio-selector"),_=o("start-image"),m=o("end-image"),u=o("duration-selector"),S=o("mode-selector"),R=o("cfg-scale-selector"),z=o("negative-prompt-input"),q=o("consumption"),D=o("font-awesome-icon"),j=o("el-button");return n(),c("div",Vt,[a("div",St,[t(r,{class:"mb-4"}),t(d,{class:"mb-4"}),t(l,{class:"mb-4"}),t(_,{class:"mb-2"}),t(m,{class:"mb-2"}),t(u,{class:"mb-4"}),t(S,{class:"mb-4"}),t(R,{class:"mb-4"}),t(z,{class:"mb-4"})]),a("div",It,[t(q,{value:e.consumption,service:e.service},null,8,["value","service"]),e.config?.video_url!==void 0||e.config?.custom?(n(),y(j,{key:0,type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:p(()=>[t(D,{icon:"fa-solid fa-magic",class:"mr-2"}),h(" "+i(e.$t("kling.button.extend")),1)]),_:1},8,["onClick"])):(n(),y(j,{key:1,type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:p(()=>[t(D,{icon:"fa-solid fa-magic",class:"mr-2"}),h(" "+i(e.$t("kling.button.generate")),1)]),_:1},8,["onClick"]))])])}const Tt=k(yt,[["render",Et]]),Lt=v({name:"TaskPreview",components:{ElImage:J,CopyToClipboard:ce,FontAwesomeIcon:T,ElAlert:Y,VideoPlayer:de,ElTooltip:X,ElButton:L},props:{modelValue:{type:Object,required:!0}},data(){return{}},computed:{application(){return this.$store.state.kling?.application},config(){return this.$store.state.kling?.config}},methods:{onDownload(e,s){e.stopPropagation(),console.log("on download"),window.open(s,"_blank")},onOpenVideo(e){window.open(e,"_blank")}}}),Ct={class:"preview"},Ut={class:"left"},Rt={class:"main"},Pt={class:"bot"},Gt={class:"datetime"},At={class:"info"},Dt={key:0,class:"prompt mt-2"},jt={key:0},Mt={key:1},Nt={key:0,class:E({content:!0,failed:!0})},Ot={key:0,class:"mb-4"},Bt={key:1,class:E({operations:!0,"mt-2":!0})},Ft={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},zt={class:"text-[var(--el-text-color-regular)] text-xs mb-0"},qt={key:1,class:E({content:!0})},Kt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Qt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Ht={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-0"},Xt={key:2,class:E({content:!0})},Yt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Jt={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-0"};function Wt(e,s,g,f,b,w){const r=o("el-image"),d=o("video-player"),l=o("el-button"),_=o("el-tooltip"),m=o("font-awesome-icon"),u=o("copy-to-clipboard"),S=o("el-alert");return n(),c("div",Ct,[a("div",Ut,[t(r,{src:"https://cdn.acedata.cloud/qpbbbb.jpg",class:"avatar"})]),a("div",Rt,[a("div",Pt,[h(i(e.$t("kling.name.klingBot"))+" ",1),a("span",Gt,i(e.$dayjs.format(""+new Date(parseFloat((e.modelValue?.created_at||"").toString())*1e3))),1)]),a("div",At,[e.modelValue?.request?.prompt?(n(),c("p",Dt,[h(i(e.modelValue?.request?.prompt)+" ",1),e.modelValue?.response?$("",!0):(n(),c("span",jt," - ("+i(e.$t("kling.status.pending"))+") ",1)),e.modelValue?.response?.state==="submitted"||e.modelValue?.response?.state==="processing"||e.modelValue?.response?.state==="pending"||e.modelValue?.response?.state==="completed"?(n(),c("span",Mt," - ("+i(e.$t("kling.status.processing"))+") ",1)):$("",!0)])):$("",!0)]),e.modelValue?.response?.success===!0?(n(),c("div",Nt,[e.modelValue?.response.video_url?(n(),c("div",Ot,[t(d,{src:e.modelValue?.response.video_url},null,8,["src"])])):$("",!0),e.modelValue?.response.success?(n(),c("div",Bt,[t(_,{class:"box-item",effect:"dark",content:e.$t("kling.message.downloadVideo"),placement:"top-start"},{default:p(()=>[e.modelValue?.response.video_url?(n(),y(l,{key:0,type:"info",size:"small",class:"btn-action",onClick:s[0]||(s[0]=R=>e.onDownload(R,e.modelValue?.response.video_url))},{default:p(()=>[h(i(e.$t("kling.button.download")),1)]),_:1})):$("",!0)]),_:1},8,["content"])])):$("",!0),t(S,{closable:!1,class:"mt-2 success"},{default:p(()=>[a("p",Ft,[t(m,{icon:"fa-solid fa-hashtag",class:"mr-1"}),h(" "+i(e.$t("kling.name.model"))+": "+i(e.modelValue?.request?.model),1)]),a("p",zt,[t(m,{icon:"fa-solid fa-magic",class:"mr-1"}),h(" "+i(e.$t("kling.name.taskId"))+": "+i(e.modelValue?.id)+" ",1),t(u,{content:e.modelValue?.id},null,8,["content"])])]),_:1})])):$("",!0),e.modelValue?.response?.success===!1?(n(),c("div",qt,[t(S,{closable:!1,class:"failure"},{template:p(()=>[t(m,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),h(" "+i(e.$t("kling.name.failure")),1)]),default:p(()=>[a("p",Kt,[t(m,{icon:"fa-solid fa-magic",class:"mr-1"}),h(" "+i(e.$t("kling.name.taskId"))+": "+i(e.modelValue?.id)+" ",1),t(u,{content:e.modelValue?.id},null,8,["content"])]),a("p",Qt,[t(m,{icon:"fa-solid fa-circle-info",class:"mr-1"}),h(" "+i(e.$t("kling.name.failureReason"))+": "+i(e.modelValue?.response?.error?.message)+" ",1),t(u,{content:e.modelValue?.response?.error?.message},null,8,["content"])]),e.modelValue?.response?.trace_id?(n(),c("p",Ht,[t(m,{icon:"fa-solid fa-hashtag",class:"mr-1"}),h(" "+i(e.$t("kling.name.traceId"))+": "+i(e.modelValue?.response?.trace_id)+" ",1),t(u,{content:e.modelValue?.response?.trace_id},null,8,["content"])])):$("",!0)]),_:1})])):$("",!0),e.modelValue?.response?.success===void 0?(n(),c("div",Xt,[t(S,{closable:!1,class:"info"},{template:p(()=>[t(m,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),h(" "+i(e.$t("kling.name.failure")),1)]),default:p(()=>[a("p",Yt,[t(m,{icon:"fa-solid fa-magic",class:"mr-1"}),h(" "+i(e.$t("kling.name.taskId"))+": "+i(e.modelValue?.id)+" ",1),t(u,{content:e.modelValue?.id},null,8,["content"])]),e.modelValue?.response?.trace_id?(n(),c("p",Jt,[t(m,{icon:"fa-solid fa-hashtag",class:"mr-1"}),h(" "+i(e.$t("kling.name.traceId"))+": "+i(e.modelValue?.response?.trace_id)+" ",1),t(u,{content:e.modelValue?.response?.trace_id},null,8,["content"])])):$("",!0)]),_:1})])):$("",!0)])])}const Zt=k(Lt,[["render",Wt],["__scopeId","data-v-c0a171a2"]]),xt=v({name:"RecentPanel",components:{TaskPreview:Zt,NoTasks:ie,BotPlaceholder:ue,ScrollList:le},props:{loading:{type:Boolean,default:!1}},emits:["reach-top"],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.kling?.tasks,items:this.$store.state.kling?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),eo={key:0},to={key:2,class:"w-full h-full flex items-center justify-center"};function oo(e,s,g,f,b,w){const r=o("bot-placeholder"),d=o("task-preview"),l=o("scroll-list"),_=o("no-tasks");return n(),c(I,null,[e.tasks?.items===void 0?(n(),c("div",eo,[t(r)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(n(),y(l,{key:1,ref:"scrollList",class:"h-full w-full overflow-y-auto tasks",loading:e.loading,onReachTop:s[0]||(s[0]=m=>e.$emit("reach-top"))},{default:p(()=>[(n(!0),c(I,null,C(e.tasks?.items,m=>(n(),y(d,{key:m.id,"model-value":m},null,8,["model-value"]))),128))]),_:1},8,["loading"])):$("",!0),e.tasks?.items?.length===0?(n(),c("div",to,[t(_)])):$("",!0)],64)}const so=k(xt,[["render",oo]]),no="https://webhook.acedata.cloud/kling",lo=v({name:"KlingIndex",components:{ConfigPanel:Tt,Layout:$e,RecentPanel:so},inject:["initialized"],data(){return{task:void 0,job:0,loadingMore:!1,fetchingTasks:!1}},computed:{applicationsLoading(){return this.$store.state.kling?.status?.getApplications===M.Request},tasksLoading(){return this.$store.state.kling?.status?.getTasks===M.Request||this.fetchingTasks},credential(){return this.$store.state.kling.credential},config(){return this.$store.state.kling.config},tasks(){return this.$store.state.kling.tasks}},watch:{tasks:{handler(e,s){e?.items?.length>s?.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=setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){clearInterval(this.job)},methods:{async onReachTop(){await pe({tasks: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("kling/getService"),console.debug("end onGetService")},async onGetApplication(){console.debug("start onGetApplication"),await this.$store.dispatch("kling/getApplications"),console.debug("end onGetApplication"),await this.onGetTasks()},async onScrollDown(){await this.$nextTick();const e=this.getTasksScrollElement();e&&(e.scrollTop=e.scrollHeight)},async onGetTasks(e){if(this.applicationsLoading||this.fetchingTasks){console.debug("loading");return}console.debug("start onGetTasks",e);const{limit:s=5,createdAtMin:g,createdAtMax:f}=e||{};console.debug("limit",s,"createdAtMin",g,"createdAtMax",f),this.fetchingTasks=!0;try{await this.$store.dispatch("kling/getTasks",{limit:s,createdAtMin:g,createdAtMax:f})}finally{this.fetchingTasks=!1}},async onGenerate(){const e={...this.config,callback_url:no},s=this.credential?.token;if(!s){console.error("no token specified");return}V.info(this.$t("kling.message.startingTask")),se.generate(e,{token:s}).then(()=>{V.success(this.$t("kling.message.startTaskSuccess"))}).catch(g=>{g?.response?.data?.error?.code===ne?V.error(this.$t("kling.message.usedUp")):V.error(this.$t("kling.message.startTaskFailed"))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function ao(e,s,g,f,b,w){const r=o("config-panel"),d=o("recent-panel"),l=o("layout");return n(),y(l,null,{config:p(()=>[t(r,{onGenerate:e.onGenerate},null,8,["onGenerate"])]),result:p(()=>[t(d,{ref:"recentPanel",loading:e.loadingMore,onReachTop:e.onReachTop},null,8,["loading","onReachTop"])]),_:1})}const Vo=k(lo,[["render",ao]]);export{Vo as default};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{bN as L}from"./vendor-CdFdgkAf.js";import{o as D,O as N,K as C,L as R,q,r as T,p as Z,n as W,D as Y,i as H}from"./vendor-element-plus-BFf0lqAh.js";import{f as b,h as i,i as r,t as o,M as U,R as u,ak as s,j as n,Y as l,F as V,ah as A,Q as S,U as I,a1 as K,X as h,V as $,S as Q,Z as X}from"./vendor-vue-xzGp4vaJ.js";import{_ as k,bb as G,bc as z,bd as y,be as M,bf as J,bg as x,bh as ee,bi as te,S as oe,bj as se,bk as ae,a6 as ne,a3 as P}from"./index-B9SFMWwY.js";import{I as j,S as le}from"./ScrollList-CsMofi7R.js";import{I as re}from"./ImagePreview-DsZM4u3Y.js";import{C as ie,N as ce}from"./NoTasks-C4GBAEFK.js";import{a as de}from"./price-Cw72dIAB.js";import{C as ue}from"./CopyToClipboard-ZLH7uqrY.js";import{V as pe}from"./VideoPlayer-CUqP_b1_.js";import{B as me}from"./BotPlaceholder-CbNYjS1E.js";import{l as fe}from"./pagination-DjyMgG1D.js";import"./vendor-katex-DHBGsivc.js";import"./vendor-dayjs-DbiJaq7z.js";import"./vendor-axios-NIGUFBhG.js";import"./vendor-vue-router-BTuxvTV5.js";const _e=b({name:"LayoutSora",components:{ElDrawer:N,ElButton:D,FontAwesomeIcon:L},data(){return{drawer:!1}}}),he={class:"main flex flex-row flex-1"},$e={class:"config w-[300px] h-full overflow-y-scroll border-r border-[var(--el-border-color)]"},ge={class:"result h-full p-[15px] flex-1 flex flex-col"};function ve(e,t,p,m,g,v){const c=s("font-awesome-icon"),d=s("el-button"),a=s("el-drawer");return n(),i("div",he,[r("div",$e,[U(e.$slots,"config",{},void 0,!0)]),r("div",ge,[U(e.$slots,"result",{},void 0,!0)]),o(d,{circle:"",class:"menu",onClick:t[0]||(t[0]=w=>e.drawer=!0)},{default:u(()=>[o(c,{icon:"fa-solid fa-magic"})]),_:1}),o(a,{modelValue:e.drawer,"onUpdate:modelValue":t[1]||(t[1]=w=>e.drawer=w),direction:"ltr","with-header":!1,size:"350px"},{default:u(()=>[U(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const be=k(_e,[["render",ve],["__scopeId","data-v-966c9b2c"]]),ke=b({name:"ModelSelector",components:{ElSelect:R,ElOption:C},props:{modelValue:{type:String,default:void 0}},emits:["update:modelValue"],data(){return{options:[{value:J,label:"sora-2"},{value:x,label:"sora-2-pro"}]}},computed:{value:{get(){return this.$store.state.sora?.config?.model},set(e){const t=this.$store.state.sora?.config||{},p=z[e]||[y],m=t.duration,g=m&&p.includes(m)?m:p.includes(y)?y:p[0],v={...t,model:e,duration:g,size:t.size||M};this.$store.commit("sora/setConfig",v)}}},mounted(){this.value||(this.value=G)}}),we={class:"field"},Se={class:"title font-bold"};function ye(e,t,p,m,g,v){const c=s("el-option"),d=s("el-select");return n(),i("div",we,[r("h2",Se,l(e.$t("sora.name.model")),1),o(d,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=a=>e.value=a),class:"value",placeholder:e.$t("sora.placeholder.select")},{default:u(()=>[(n(!0),i(V,null,A(e.options,a=>(n(),S(c,{key:a.value,label:a.label,value:a.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Ve=k(ke,[["render",ye],["__scopeId","data-v-3a7abba8"]]),Ee=b({name:"ActionSelector",components:{ElSelect:R,ElOption:C},data(){return{}},computed:{options(){return[{value:"text2video",label:this.$t("sora.button.action1")},{value:"image2video",label:this.$t("sora.button.action2")}]},value:{get(){return this.$store.state.sora?.config?.action},set(e){this.$store.commit("sora/setConfig",{...this.$store.state.sora?.config,action:e})}}},mounted(){this.value||(this.value=ee)}}),Te={class:"field"},Ie={class:"title font-bold"},Ae={class:"float-left"};function Le(e,t,p,m,g,v){const c=s("el-option"),d=s("el-select");return n(),i("div",Te,[r("h2",Ie,l(e.$t("sora.name.action")),1),o(d,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=a=>e.value=a),class:"value",placeholder:e.$t("sora.placeholder.select"),clearable:""},{default:u(()=>[(n(!0),i(V,null,A(e.options,a=>(n(),S(c,{key:a.value,label:a.label,value:a.value},{default:u(()=>[r("span",Ae,l(a.label),1)]),_:2},1032,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const De=k(Ee,[["render",Le],["__scopeId","data-v-7b82fa7f"]]),Ce=b({name:"DurationSelector",components:{ElSelect:R,ElOption:C},computed:{model(){return this.$store.state.sora?.config?.model||G},allowedDurations(){return z[this.model]||[y]},optionsForModel(){return this.allowedDurations.map(e=>({value:e,label:`${e}s`}))},value:{get(){return this.$store.state.sora?.config?.duration},set(e){const t=this.$store.state.sora?.config||{};this.$store.commit("sora/setConfig",{...t,duration:e})}}},watch:{allowedDurations(){const e=this.allowedDurations;if(!e.includes(this.value)){const t=e.includes(y)?y:e[0];this.value=t}}},mounted(){this.value||(this.value=y)}}),Re={class:"field"},Oe={class:"control"},Ue={class:"title font-bold"};function Pe(e,t,p,m,g,v){const c=s("el-option"),d=s("el-select");return n(),i("div",Re,[r("div",Oe,[r("h2",Ue,l(e.$t("sora.name.duration")),1),o(d,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=a=>e.value=a),class:"value",placeholder:e.$t("sora.placeholder.select")},{default:u(()=>[(n(!0),i(V,null,A(e.optionsForModel,a=>(n(),S(c,{key:a.value,label:a.label,value:a.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])])}const Ge=k(Ce,[["render",Pe],["__scopeId","data-v-c2934598"]]),ze=b({name:"OrientationSelector",data(){return{options:[{value:"portrait",label:"竖屏",width:13,height:25},{value:"landscape",label:"横屏",width:25,height:13}]}},computed:{active(){return this.options.findIndex(e=>e.value===this.value)||0},value:{get(){return this.$store.state.sora?.config?.orientation},set(e){console.debug("set orientation",e),this.$store.commit("sora/setConfig",{...this.$store.state?.sora?.config,orientation:e})}}},mounted(){this.value||(this.value=te)}}),Me={class:"text-sm font-bold mb-2 block"},je={class:"items"},Be=["onClick"],Fe={class:"name"};function Ne(e,t,p,m,g,v){return n(),i("div",null,[r("span",Me,l(e.$t("sora.name.orientation")),1),r("div",je,[(n(!0),i(V,null,A(e.options,(c,d)=>(n(),i("div",{key:d,class:I({active:e.active===d,item:!0}),onClick:a=>e.value=c.value},[r("div",{class:I(["preview",c.value])},[r("div",{class:"rect",style:K({width:c.width+"px",height:c.height+"px"})},null,4)],2),r("p",Fe,l(c.label),1)],10,Be))),128))])])}const qe=k(ze,[["render",Ne],["__scopeId","data-v-d6940af8"]]),Ze=b({name:"StartEndImage",components:{ElUpload:q,ElButton:D,InfoIcon:j,FontAwesomeIcon:L,ImagePreview:re},emits:["change"],data(){return{fileList:[],uploadUrl:oe()+"/api/v1/files/"}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e?.response?.file_url)},value:{get(){return this.$store.state?.sora?.config?.image_urls},set(){}}},mounted(){this.value||(this.value=void 0),this.onSetStartEndImageUrl()},methods:{onExceed(){T.warning(this.$t("sora.message.uploadReferencesExceed"))},onError(){T.error(this.$t("sora.message.uploadReferencesError"))},onSetStartEndImageUrl(){const e=this.urls;this.$store.commit("sora/setConfig",{...this.$store.state?.sora?.config,image_urls:e})},async onSuccess(){this.onSetStartEndImageUrl()}}}),We={class:"relative"},Ye={class:"flex justify-between"},He={class:"flex justify-start items-center"},Ke={class:"text-sm font-bold"};function Qe(e,t,p,m,g,v){const c=s("info-icon"),d=s("image-preview"),a=s("font-awesome-icon"),w=s("el-button"),_=s("el-upload");return n(),i("div",We,[r("div",Ye,[r("div",He,[r("span",Ke,l(e.$t("sora.name.startEndImage")),1),o(c,{content:e.$t("sora.description.uploadStartEndImage")},null,8,["content"])])]),o(_,{"file-list":e.fileList,"onUpdate:fileList":t[0]||(t[0]=f=>e.fileList=f),name:"file",accept:".png,.jpg,.jpeg,.gif,.bmp,.webp",limit:2,class:"upload-wrapper",multiple:!1,action:e.uploadUrl,"list-type":"picture","on-exceed":e.onExceed,"on-error":e.onError,"on-success":e.onSuccess,headers:e.headers},{file:u(({file:f})=>[f.url&&f.percentage!==void 0?(n(),S(d,{key:0,url:f.url,name:f.name,percentage:f.percentage,onRemove:E=>e.fileList.splice(e.fileList.indexOf(f),1)},null,8,["url","name","percentage","onRemove"])):$("",!0)]),default:u(()=>[o(w,{round:"",type:"primary",size:"small",class:"btn btn-upload"},{default:u(()=>[o(a,{icon:"fa-solid fa-upload",class:"icon mr-1"}),h(" "+l(e.$t("sora.button.uploadReferences")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-success","headers"])])}const Xe=k(Ze,[["render",Qe],["__scopeId","data-v-fd6e5c97"]]),Je=e=>e&&e.charAt(0).toUpperCase()+e.slice(1),xe=b({name:"SizeSelector",components:{ElSelect:R,ElOption:C},data(){return{options:se.map(e=>({value:e,label:Je(e)}))}},computed:{value:{get(){return this.$store.state.sora?.config?.size},set(e){const t=this.$store.state.sora?.config||{};this.$store.commit("sora/setConfig",{...t,size:e})}}},mounted(){this.value||(this.value=M)}}),et={class:"field"},tt={class:"control"},ot={class:"title font-bold"};function st(e,t,p,m,g,v){const c=s("el-option"),d=s("el-select");return n(),i("div",et,[r("div",tt,[r("h2",ot,l(e.$t("sora.name.size")),1),o(d,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=a=>e.value=a),class:"value",placeholder:e.$t("sora.placeholder.select")},{default:u(()=>[(n(!0),i(V,null,A(e.options,a=>(n(),S(c,{key:a.value,label:a.label,value:a.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])])}const at=k(xe,[["render",st],["__scopeId","data-v-8c485f0f"]]),nt="",lt=b({name:"PromptInput",components:{ElInput:Z,InfoIcon:j},computed:{prompt:{get(){return this.$store.state.sora?.config?.prompt},set(e){console.debug("set prompt",e),this.$store.commit("sora/setConfig",{...this.$store.state.sora?.config,prompt:e})}}},mounted(){this.prompt||(this.prompt=nt)}}),rt={class:"field"},it={class:"box"},ct={class:"title font-bold"};function dt(e,t,p,m,g,v){const c=s("info-icon"),d=s("el-input");return n(),i("div",rt,[r("div",it,[r("h2",ct,l(e.$t("sora.name.prompt")),1),o(c,{content:e.$t("sora.description.prompt"),class:"info"},null,8,["content"])]),o(d,{modelValue:e.prompt,"onUpdate:modelValue":t[0]||(t[0]=a=>e.prompt=a),rows:3,type:"textarea",class:"prompt",placeholder:e.$t("sora.placeholder.prompt"),maxlength:500,"show-word-limit":""},null,8,["modelValue","placeholder"])])}const ut=k(lt,[["render",dt],["__scopeId","data-v-cf3a1497"]]),pt=b({name:"ConfigPanel",components:{ElButton:D,Consumption:ie,FontAwesomeIcon:L,PromptInput:ut,ModelSelector:Ve,StartEndImage:Xe,SizeSelector:at,ActionSelector:De,OrientationSelector:qe,DurationSelector:Ge},emits:["generate"],computed:{config(){return this.$store.state.sora?.config},consumption(){return de(this.config,this.service?.cost)},service(){return this.$store.state.sora?.service}},methods:{onGenerate(){this.$emit("generate")}}}),mt={class:"flex flex-col h-full"},ft={class:"flex-1 overflow-y-auto p-[15px]"},_t={class:"flex flex-col items-center justify-center px-[15px] pb-[15px]"};function ht(e,t,p,m,g,v){const c=s("model-selector"),d=s("action-selector"),a=s("duration-selector"),w=s("size-selector"),_=s("orientation-selector"),f=s("prompt-input"),E=s("start-end-image"),O=s("consumption"),B=s("font-awesome-icon"),F=s("el-button");return n(),i("div",mt,[r("div",ft,[o(c,{class:"mb-4"}),o(d,{class:"mb-4"}),o(a,{class:"mb-4"}),o(w,{class:"mb-4"}),o(_,{class:"mb-4"}),o(f,{class:"mb-4"}),Q(o(E,{class:"mb-2"},null,512),[[X,e.config?.action==="image2video"]])]),r("div",_t,[o(O,{value:e.consumption,service:e.service},null,8,["value","service"]),o(F,{type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:u(()=>[o(B,{icon:"fa-solid fa-magic",class:"mr-2"}),h(" "+l(e.$t("sora.button.generate")),1)]),_:1},8,["onClick"])])])}const $t=k(pt,[["render",ht]]),gt=b({name:"TaskPreview",components:{ElImage:H,CopyToClipboard:ue,FontAwesomeIcon:L,ElAlert:Y,VideoPlayer:pe,ElTooltip:W,ElButton:D},props:{modelValue:{type:Object,required:!0}},data(){return{}},computed:{application(){return this.$store.state.sora?.application},config(){return this.$store.state.sora?.config}},methods:{onDownload(e,t){e.stopPropagation(),console.log("on download"),window.open(t,"_blank")},onOpenVideo(e){window.open(e,"_blank")}}}),vt={class:"preview"},bt={class:"left"},kt={class:"main"},wt={class:"bot"},St={class:"datetime"},yt={class:"info"},Vt={key:0,class:"prompt mt-2"},Et={key:0},Tt={key:1},It={key:0,class:I({content:!0,failed:!0})},At={key:0,class:"mb-4"},Lt={key:1,class:I({operations:!0,"mt-2":!0})},Dt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Ct={class:"text-[var(--el-text-color-regular)] text-xs mb-0"},Rt={key:1,class:I({content:!0})},Ot={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Ut={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Pt={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-0"},Gt={key:2,class:I({content:!0})},zt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Mt={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-0"};function jt(e,t,p,m,g,v){const c=s("el-image"),d=s("video-player"),a=s("el-button"),w=s("el-tooltip"),_=s("font-awesome-icon"),f=s("copy-to-clipboard"),E=s("el-alert");return n(),i("div",vt,[r("div",bt,[o(c,{src:"https://cdn.acedata.cloud/z5id1u.png",class:"avatar"})]),r("div",kt,[r("div",wt,[h(l(e.$t("sora.name.soraBot"))+" ",1),r("span",St,l(e.$dayjs.format(""+new Date(parseFloat((e.modelValue?.created_at||"").toString())*1e3))),1)]),r("div",yt,[e.modelValue?.request?.prompt?(n(),i("p",Vt,[h(l(e.modelValue?.request?.prompt)+" ",1),e.modelValue?.response?$("",!0):(n(),i("span",Et," - ("+l(e.$t("sora.status.pending"))+") ",1)),Array.isArray(e.modelValue?.response?.data)&&e.modelValue?.response?.data[0]?.state==="pending"?(n(),i("span",Tt," - ("+l(e.$t("sora.status.processing"))+") ",1)):$("",!0)])):$("",!0)]),e.modelValue?.response?.success===!0&&e.modelValue?.response?.data?(n(),i("div",It,[e.modelValue?.response?.data[0]?.video_url?(n(),i("div",At,[o(d,{src:e.modelValue?.response?.data[0]?.video_url},null,8,["src"])])):$("",!0),e.modelValue?.response.success?(n(),i("div",Lt,[o(w,{class:"box-item",effect:"dark",content:e.$t("sora.message.downloadVideo"),placement:"top-start"},{default:u(()=>[e.modelValue?.response?.data[0]?.video_url?(n(),S(a,{key:0,type:"info",size:"small",class:"btn-action",onClick:t[0]||(t[0]=O=>e.onDownload(O,e.modelValue?.response?.data[0]?.video_url))},{default:u(()=>[h(l(e.$t("sora.button.download")),1)]),_:1})):$("",!0)]),_:1},8,["content"])])):$("",!0),o(E,{closable:!1,class:"mt-2 success"},{default:u(()=>[r("p",Dt,[o(_,{icon:"fa-solid fa-hashtag",class:"mr-1"}),h(" "+l(e.$t("sora.name.model"))+": "+l(e.modelValue?.request?.model),1)]),r("p",Ct,[o(_,{icon:"fa-solid fa-magic",class:"mr-1"}),h(" "+l(e.$t("sora.name.taskId"))+": "+l(e.modelValue?.id)+" ",1),o(f,{content:e.modelValue?.id},null,8,["content"])])]),_:1})])):$("",!0),e.modelValue?.response?.success===!1?(n(),i("div",Rt,[o(E,{closable:!1,class:"failure"},{template:u(()=>[o(_,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),h(" "+l(e.$t("sora.name.failure")),1)]),default:u(()=>[r("p",Ot,[o(_,{icon:"fa-solid fa-magic",class:"mr-1"}),h(" "+l(e.$t("sora.name.taskId"))+": "+l(e.modelValue?.id)+" ",1),o(f,{content:e.modelValue?.id},null,8,["content"])]),r("p",Ut,[o(_,{icon:"fa-solid fa-circle-info",class:"mr-1"}),h(" "+l(e.$t("sora.name.failureReason"))+": "+l(e.modelValue?.response?.error?.message)+" ",1),o(f,{content:e.modelValue?.response?.error?.message},null,8,["content"])]),e.modelValue?.response?.trace_id?(n(),i("p",Pt,[o(_,{icon:"fa-solid fa-hashtag",class:"mr-1"}),h(" "+l(e.$t("sora.name.traceId"))+": "+l(e.modelValue?.response?.trace_id)+" ",1),o(f,{content:e.modelValue?.response?.trace_id},null,8,["content"])])):$("",!0)]),_:1})])):$("",!0),e.modelValue?.response?.success===void 0?(n(),i("div",Gt,[o(E,{closable:!1,class:"info"},{template:u(()=>[o(_,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),h(" "+l(e.$t("sora.name.failure")),1)]),default:u(()=>[r("p",zt,[o(_,{icon:"fa-solid fa-magic",class:"mr-1"}),h(" "+l(e.$t("sora.name.taskId"))+": "+l(e.modelValue?.id)+" ",1),o(f,{content:e.modelValue?.id},null,8,["content"])]),e.modelValue?.response?.trace_id?(n(),i("p",Mt,[o(_,{icon:"fa-solid fa-hashtag",class:"mr-1"}),h(" "+l(e.$t("sora.name.traceId"))+": "+l(e.modelValue?.response?.trace_id)+" ",1),o(f,{content:e.modelValue?.response?.trace_id},null,8,["content"])])):$("",!0)]),_:1})])):$("",!0)])])}const Bt=k(gt,[["render",jt],["__scopeId","data-v-183a4d07"]]),Ft=b({name:"RecentPanel",components:{TaskPreview:Bt,NoTasks:ce,BotPlaceholder:me,ScrollList:le},props:{loading:{type:Boolean,default:!1}},emits:["reach-top"],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.sora?.tasks,items:this.$store.state.sora?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),Nt={key:0},qt={key:2,class:"w-full h-full flex items-center justify-center"};function Zt(e,t,p,m,g,v){const c=s("bot-placeholder"),d=s("task-preview"),a=s("scroll-list"),w=s("no-tasks");return n(),i(V,null,[e.tasks?.items===void 0?(n(),i("div",Nt,[o(c)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(n(),S(a,{key:1,ref:"scrollList",class:"tasks h-full w-full overflow-y-auto",loading:e.loading,onReachTop:t[0]||(t[0]=_=>e.$emit("reach-top"))},{default:u(()=>[(n(!0),i(V,null,A(e.tasks?.items,(_,f)=>(n(),S(d,{key:f,"model-value":_},null,8,["model-value"]))),128))]),_:1},8,["loading"])):$("",!0),e.tasks?.items?.length===0?(n(),i("div",qt,[o(w)])):$("",!0)],64)}const Wt=k(Ft,[["render",Zt]]),Yt="https://webhook.acedata.cloud/sora",Ht=b({name:"SoraIndex",components:{ConfigPanel:$t,Layout:be,RecentPanel:Wt},inject:["initialized"],data(){return{task:void 0,job:0,loadingMore:!1,fetchingTasks:!1}},computed:{applicationsLoading(){return this.$store.state.sora?.status?.getApplications===P.Request},tasksLoading(){return this.$store.state.sora?.status?.getTasks===P.Request||this.fetchingTasks},credential(){return this.$store.state.sora.credential},config(){return this.$store.state.sora.config},tasks(){return this.$store.state.sora.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=setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){clearInterval(this.job)},methods:{async onReachTop(){await fe({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("sora/getService"),console.debug("end onGetService")},async onGetApplication(){console.debug("start onGetApplication"),await this.$store.dispatch("sora/getApplications"),console.debug("end onGetApplication"),await this.onGetTasks()},async onScrollDown(){await this.$nextTick();const e=this.getTasksScrollElement();e&&(e.scrollTop=e.scrollHeight)},async onGetTasks(e){if(this.applicationsLoading||this.fetchingTasks){console.debug("loading");return}console.debug("start onGetTasks",e);const{limit:t=5,createdAtMin:p,createdAtMax:m}=e||{};console.debug("limit",t,"createdAtMin",p,"createdAtMax",m),this.fetchingTasks=!0;try{await this.$store.dispatch("sora/getTasks",{limit:t,createdAtMin:p,createdAtMax:m})}finally{this.fetchingTasks=!1}},async onGenerate(){const e={...this.config,callback_url:Yt},t=this.credential?.token;if(!t){console.error("no token specified");return}T.info(this.$t("sora.message.startingTask")),ae.generate(e,{token:t}).then(()=>{T.success(this.$t("sora.message.startTaskSuccess"))}).catch(p=>{p?.response?.data?.error?.code===ne?T.error(this.$t("sora.message.usedUp")):T.error(this.$t("sora.message.startTaskFailed"))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function Kt(e,t,p,m,g,v){const c=s("config-panel"),d=s("recent-panel"),a=s("layout");return n(),S(a,null,{config:u(()=>[o(c,{onGenerate:e.onGenerate},null,8,["onGenerate"])]),result:u(()=>[o(d,{ref:"recentPanel",loading:e.loadingMore,onReachTop:e.onReachTop},null,8,["loading","onReachTop"])]),_:1})}const mo=k(Ht,[["render",Kt]]);export{mo as default};
|