@acedatacloud/nexior 3.277.2 → 3.277.4
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/assets/{ApiCodeButton-_F8VGfz6.js → ApiCodeButton-DXN7iB8l.js} +1 -1
- package/dist/assets/{AskUserQuestionCard-C-rgZ50J.js → AskUserQuestionCard-CPQb26DU.js} +1 -1
- package/dist/assets/{Auth-D0HnMvmY.js → Auth-BkXFXHwC.js} +1 -1
- package/dist/assets/{Bare-COkwusIM.js → Bare-B5EPTD3k.js} +1 -1
- package/dist/assets/{BotPlaceholder-CsbmSleA.js → BotPlaceholder-R_nAAbft.js} +1 -1
- package/dist/assets/{BottomFooter-DMpMmqr4.js → BottomFooter-jepzQURF.js} +1 -1
- package/dist/assets/{Callback-Cllgoj6s.js → Callback-DH3ldyqo.js} +1 -1
- package/dist/assets/{Console-C5hCQvvI.js → Console-rsr21rbN.js} +1 -1
- package/dist/assets/{Consumption-sOdFzyTj.js → Consumption-CjrpUNmV.js} +1 -1
- package/dist/assets/{Conversation-D1MyUAvd.js → Conversation-PmXYPnF1.js} +1 -1
- package/dist/assets/{CopyToClipboard-BWst2iVb.js → CopyToClipboard-DXA4nHxo.js} +1 -1
- package/dist/assets/{Detail-B0UTP8zE.js → Detail-BtKYzcA7.js} +2 -2
- package/dist/assets/{Extra-BpK_QuV5.js → Extra-B9rCcwWj.js} +1 -1
- package/dist/assets/{FilePreview-DxBIesog.js → FilePreview-Dqk4WVEr.js} +1 -1
- package/dist/assets/{Hailuo-Vq487_jN.js → Hailuo-D_ir2qwk.js} +1 -1
- package/dist/assets/{History-PzaVn0Qb.js → History-g_mPJBRP.js} +1 -1
- package/dist/assets/{ImagePreview-BONFD01I.js → ImagePreview-Bkw_taCt.js} +1 -1
- package/dist/assets/{ImageWrapper-DG9AFRn0.js → ImageWrapper-BPvtDIMf.js} +1 -1
- package/dist/assets/{Index-B4gwMLQA.js → Index-B6G7B2I0.js} +1 -1
- package/dist/assets/{Index-C2AVojml.js → Index-BDGE5GsR.js} +1 -1
- package/dist/assets/{Index-BPP9LFNQ.js → Index-BHzERvOB.js} +1 -1
- package/dist/assets/{Index-BH3zKDxE.js → Index-BQWV4ACZ.js} +1 -1
- package/dist/assets/{Index-CMhi_OcN.js → Index-C2M1W6HA.js} +1 -1
- package/dist/assets/{Index-BZd9sGXt.js → Index-C2jzr33l.js} +1 -1
- package/dist/assets/{Index-sMX_ReQd.js → Index-C3yZt6r4.js} +1 -1
- package/dist/assets/{Index-BYd_1Igk.js → Index-C8zclc3l.js} +1 -1
- package/dist/assets/{Index-cKvDEGwi.js → Index-C9vdHrH1.js} +1 -1
- package/dist/assets/{Index-BbQZOOMp.js → Index-CEMmW0Xt.js} +1 -1
- package/dist/assets/{Index-DTbtiksg.js → Index-CGQPNGH6.js} +1 -1
- package/dist/assets/{Index-BSmwFdf3.js → Index-CJ_B5PUw.js} +1 -1
- package/dist/assets/{Index-jUy6hwT5.js → Index-CTuEMRMq.js} +1 -1
- package/dist/assets/Index-CaYlG9QS.js +1 -0
- package/dist/assets/{Index-lZYFamZu.js → Index-ComARfRw.js} +1 -1
- package/dist/assets/{Index-Bgw66bG_.js → Index-CqgNerQP.js} +1 -1
- package/dist/assets/{Index-vue5_YrA.js → Index-CycuKObu.js} +1 -1
- package/dist/assets/{Index-D82sk4fu.js → Index-D3Do9QG2.js} +1 -1
- package/dist/assets/{Index-Cq4bH0VX.js → Index-D9e-AGnZ.js} +1 -1
- package/dist/assets/{Index-BclEWzuC.js → Index-DQ6WJNd4.js} +1 -1
- package/dist/assets/{Index-Bi4jTDTC.js → Index-DSIgRXEN.js} +1 -1
- package/dist/assets/{Index-DcZ5T2r-.js → Index-Dsbx7mYp.js} +1 -1
- package/dist/assets/{Index-BC5RavEk.js → Index-JB4pTHsw.js} +1 -1
- package/dist/assets/{Index-C2JSQHAI.css → Index-M4C0FZly.css} +1 -1
- package/dist/assets/{Index-BS8xKJbS.js → Index-Wn4WhxSA.js} +1 -1
- package/dist/assets/{Index-BnbPU1_5.js → Index-ZXaIaAWW.js} +1 -1
- package/dist/assets/{Index-z7f9IBf3.js → Index-ke_plb_v.js} +1 -1
- package/dist/assets/{Invitees-DLafR3-P.js → Invitees-CtOjf0iy.js} +1 -1
- package/dist/assets/{List-6RiG5ZM_.js → List-CpB562Ry.js} +1 -1
- package/dist/assets/{List-DAHZF49n.js → List-DjAb-cmd.js} +1 -1
- package/dist/assets/{List-DFYZobGA.js → List-HnIA1E2e.js} +1 -1
- package/dist/assets/{Main-B3Nil7ov.js → Main-BI0k19m6.js} +1 -1
- package/dist/assets/{Model-BOm-GsCG.js → Model-wnwwcJwj.js} +1 -1
- package/dist/assets/{Navigator-Jxq0iAHr.js → Navigator-BknUSx4Z.js} +1 -1
- package/dist/assets/{NoTasks-DFKN-WpO.js → NoTasks-568fhAGt.js} +1 -1
- package/dist/assets/{NotFound-CnH4FiVv.js → NotFound-Co5GcLDE.js} +1 -1
- package/dist/assets/{Pagination-D-Qrewom.js → Pagination-C9VVozAy.js} +1 -1
- package/dist/assets/{Pay-2FI1nMLX.js → Pay-D0MlHd8L.js} +1 -1
- package/dist/assets/{Player-DEzAfNr3.js → Player--ctmekZs.js} +1 -1
- package/dist/assets/{Seedance-DcogSBwZ.js → Seedance-vljqSpVs.js} +1 -1
- package/dist/assets/{Status-mQt-bcni.js → Status-CvH_CBCZ.js} +1 -1
- package/dist/assets/{Subscribe-BFZrNxkZ.js → Subscribe-DCU6AfQa.js} +1 -1
- package/dist/assets/{TabSwitcher-DnOx9vbA.js → TabSwitcher-CHZ_ECnY.js} +1 -1
- package/dist/assets/{Tts-CGJWvjIh.js → Tts-DGZwUosH.js} +1 -1
- package/dist/assets/{VideoPlayer-BsOg3z0K.js → VideoPlayer-BjsbkQZc.js} +1 -1
- package/dist/assets/{avatar-eI_WspJB.js → avatar-CHgySyav.js} +1 -1
- package/dist/assets/{basic-Cy1YlYE1.js → basic-CjTT_oRU.js} +1 -1
- package/dist/assets/{chat-Cd7LGowG.js → chat-BOAbBwQI.js} +1 -1
- package/dist/assets/{codingBridge-B9OgVVtV.js → codingBridge-Dxupvrte.js} +1 -1
- package/dist/assets/{codingBridgeNotify-BgO1-q2c.js → codingBridgeNotify-nSBbOsRW.js} +2 -2
- package/dist/assets/{collapse-BF3bD3JQ.js → collapse-B99-bYjk.js} +1 -1
- package/dist/assets/{constants-BVtW3DRs.js → constants-B6_fTlam.js} +1 -1
- package/dist/assets/{createTaskActions-CJFLOWRL.js → createTaskActions-CClbGT-n.js} +1 -1
- package/dist/assets/{date-picker-CQUJSKmg.js → date-picker-BtukkZrG.js} +1 -1
- package/dist/assets/{dropdown-CmHI22Qk.js → dropdown-BzFwppmF.js} +1 -1
- package/dist/assets/{esm-D7t-y-u1.js → esm-BOBX4dhx.js} +1 -1
- package/dist/assets/{esm-DMJZShgQ.js → esm-CWZTkeBt.js} +3 -3
- package/dist/assets/{esm-CAmisYjo.js → esm-CyghH0i3.js} +2 -2
- package/dist/assets/{esm-B8UUARCy.js → esm-DFfWKlEX.js} +1 -1
- package/dist/assets/esm-LoPWTfn9.js +1 -0
- package/dist/assets/{esm-DngzeHVk.js → esm-kL8Pp6jZ.js} +2 -2
- package/dist/assets/{esm-9Hz_oU09.js → esm-l5ji9H4b.js} +1 -1
- package/dist/assets/{fish-DwUn-O3u.js → fish-BWtzHFqO.js} +1 -1
- package/dist/assets/{flux-Z9gWtdb-.js → flux-C-FqnDs4.js} +1 -1
- package/dist/assets/{grokvideo-DeheY06v.js → grokvideo-C9fmjCwH.js} +1 -1
- package/dist/assets/{hailuo-CxOeW5h-.js → hailuo-BrfV-8h8.js} +1 -1
- package/dist/assets/{headshots-DFzZRzeH.js → headshots-Mjvj0YDr.js} +1 -1
- package/dist/assets/{image-C6NwfMIr.js → image-tItcr5tZ.js} +1 -1
- package/dist/assets/{index-8HYiV8-4.css → index-DDM8TkaO.css} +1 -1
- package/dist/assets/{index-B2cLm6qN.js → index-DpREqzJQ.js} +5 -5
- package/dist/assets/{index.browser.esm-Xp9wSEpI.js → index.browser.esm-BVybW0ME.js} +1 -1
- package/dist/assets/{index.es-CtAdUuvy.js → index.es-DkXuZNXE.js} +1 -1
- package/dist/assets/{input-number-CGajKQ5c.js → input-number-BZClQnf5.js} +1 -1
- package/dist/assets/kling-DnnRrHSY.js +1 -0
- package/dist/assets/{kling-Bx6IczHr.js → kling-Rhjbl3yb.js} +1 -1
- package/dist/assets/{kling-aUagiKYM.js → kling-bCcngi_D.js} +1 -1
- package/dist/assets/{luma--3nfPKkw.js → luma-BfJ45Nrp.js} +1 -1
- package/dist/assets/{midjourney-BbyZ5iSG.js → midjourney-BhBFIcGa.js} +1 -1
- package/dist/assets/{nanobanana-B4zl7XWD.js → nanobanana-9yIPx-7N.js} +1 -1
- package/dist/assets/{openaiimage-BYU8bU-f.js → openaiimage-yBE3S9GR.js} +1 -1
- package/dist/assets/{pagination-lmE1fJNh.js → pagination-BQOE0Lce.js} +1 -1
- package/dist/assets/{pika-DnH_-ozE.js → pika-BwDH6RXc.js} +1 -1
- package/dist/assets/{pixverse-B2M8mGrc.js → pixverse-V1u83-NJ.js} +1 -1
- package/dist/assets/{popover-CE7suPFv.js → popover-BOyleW7G.js} +1 -1
- package/dist/assets/{producer-Z11VfxX7.js → producer-D5j29zwT.js} +1 -1
- package/dist/assets/{qrart-BZb2-4I8.js → qrart-BOGIYlCy.js} +1 -1
- package/dist/assets/{row-CPUbrqBF.js → row-D8loqAPL.js} +1 -1
- package/dist/assets/{seedance-bPnnoS8W.js → seedance-BFWs3OMD.js} +1 -1
- package/dist/assets/{seedream-CohGukzG.js → seedream-PMGj_GEr.js} +1 -1
- package/dist/assets/{select-DAa8odbM.js → select-CYdISXBV.js} +1 -1
- package/dist/assets/{serp-wL6frSWn.js → serp-BXsV4ruQ.js} +1 -1
- package/dist/assets/{slider-Cm1_uMMy.js → slider-heMG04zo.js} +1 -1
- package/dist/assets/{solana-wallets-7rbqiX2h.js → solana-wallets-DpEYEH8X.js} +2 -2
- package/dist/assets/{solana-wallets-vue-DXB0bcIf.js → solana-wallets-vue-DwDUK9GJ.js} +1 -1
- package/dist/assets/{sora-D7Hs_5OF.js → sora-BPluLKCF.js} +1 -1
- package/dist/assets/{suno-CNnBIzRH.js → suno-B3FfSfsu.js} +1 -1
- package/dist/assets/{switch-OayEB1u5.js → switch-DT8swXGq.js} +1 -1
- package/dist/assets/{tabs-CczvvHUm.js → tabs-DbqhD0Ri.js} +1 -1
- package/dist/assets/{upload-C1A-s7Yk.js → upload-CHAO8dYa.js} +1 -1
- package/dist/assets/{veo-C_9ZZPgC.js → veo--ebyIQZO.js} +1 -1
- package/dist/assets/{wan-CzgADhR-.js → wan-QNzJ6Wsl.js} +1 -1
- package/dist/assets/{web-BnS1ZvGW.js → web-B3c_92-W.js} +1 -1
- package/dist/assets/{web-3p8KfgK2.js → web-BhPhz6gK.js} +1 -1
- package/dist/assets/{web-Bo0J-aov.js → web-CggzH-kj.js} +1 -1
- package/dist/assets/{web-BGojYlRE.js → web-DaBpN21i.js} +1 -1
- package/dist/assets/{web-CCI8ummo.js → web-Dslc1DMt.js} +1 -1
- package/dist/assets/{webextrator-DmkTce7c.js → webextrator-BVPmDKBS.js} +1 -1
- package/dist/index.html +3 -3
- package/package.json +1 -1
- package/dist/assets/Index-CTEt5y7l.js +0 -1
- package/dist/assets/esm-BqhS-60O.js +0 -1
- package/dist/assets/kling-DmQ_HZxb.js +0 -1
|
@@ -1 +1 @@
|
|
|
1
|
-
import"./rolldown-runtime--c01j_DQ.js";import{$ as e,Bt as t,D as n,E as r,M as i,N as a,O as o,P as s,Q as c,T as l,Ut as u,X as d,et as f,k as p,lt as m,x as h}from"./vendor-chart-mdwpew_o.js";import{t as g}from"./button-DWzbdjZV.js";import{n as _,t as v}from"./tabs-CczvvHUm.js";import{t as y}from"./upload-C1A-s7Yk.js";import{t as b}from"./image-C6NwfMIr.js";import{t as x}from"./alert-BJj7gY4q.js";import{n as S,r as C}from"./radio-IJQsW93X.js";import{t as w}from"./drawer-BvYPSxXh.js";import{n as ee,t as te}from"./skeleton-Cn4UY-T8.js";import{hi as T}from"./constants-BVtW3DRs.js";import{An as E,At as D,E as O,Fn as k,Ot as A,Sr as j,jt as M,kr as N,kt as P,sn as F,yr as I}from"./index-B2cLm6qN.js";import{t as L}from"./index.es-CtAdUuvy.js";import{t as R}from"./CopyToClipboard-BWst2iVb.js";import{t as z}from"./Status-mQt-bcni.js";import{t as B}from"./ImagePreview-BONFD01I.js";import{i as V,n as H,t as U}from"./pagination-lmE1fJNh.js";import{t as W}from"./ApiCodeButton-_F8VGfz6.js";var G=s({name:`LayoutHeadshots`,components:{ElDrawer:w,ElButton:g,FontAwesomeIcon:L},data(){return{drawer:!1}}}),K={class:`main flex flex-row flex-1`},q={class:`config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]`},J={class:`result h-full p-6 flex-1 flex flex-col min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]`};function Y(t,n,i,o,s,c){let l=f(`font-awesome-icon`),u=f(`el-button`),h=f(`el-drawer`);return d(),p(`div`,K,[r(`div`,q,[e(t.$slots,`config`,{},void 0,!0)]),r(`div`,J,[e(t.$slots,`result`,{},void 0,!0)]),a(u,{circle:``,class:`menu`,onClick:n[0]||=e=>t.drawer=!0},{default:m(()=>[a(l,{icon:`fa-solid fa-gear`})]),_:1}),a(h,{modelValue:t.drawer,"onUpdate:modelValue":n[1]||=e=>t.drawer=e,"with-header":!1,size:`340px`,class:`drawer`},{default:m(()=>[e(t.$slots,`config`,{},void 0,!0)]),_:3},8,[`modelValue`])])}var X=O(G,[[`render`,Y],[`__scopeId`,`data-v-ada6b2d1`]]),Z=s({name:`ImageUrlsInput`,components:{ElUpload:y,ElButton:g,InfoIcon:V,ImagePreview:B,FontAwesomeIcon:L},mixins:[M,P],data(){return{fileList:[],uploadUrl:j()+`/api/v1/files/`}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e?.response?.file_url)},value:{get(){return this.$store.state.headshots?.config?.image_urls},set(){let e=this.urls;this.$store.commit(`headshots/setConfig`,{...this.$store.state.headshots?.config,image_urls:e})}}},mounted(){this.value||=void 0,this.onSetImageUrls()},methods:{onExceed(){N.warning(this.$t(`headshots.message.uploadImageExceed`))},onError(){N.error(this.$t(`headshots.message.uploadImageError`))},onSetImageUrls(){let e=this.urls;this.$store.commit(`headshots/setConfig`,{...this.$store.state.headshots?.config,image_urls:e})},async onSuccess(){this.onSetImageUrls()}}}),Q={class:`field`},ne={class:`title font-bold`},re={class:`upload-wrapper`};function ie(e,t,n,o,s,c){let l=f(`image-preview`),h=f(`font-awesome-icon`),g=f(`el-button`),_=f(`el-upload`),v=f(`info-icon`);return d(),p(`div`,Q,[r(`h2`,ne,u(e.$t(`headshots.name.endImageUrls`)),1),r(`div`,re,[a(_,{ref:`uploader`,"file-list":e.fileList,"onUpdate:fileList":t[0]||=t=>e.fileList=t,accept:`.png,.jpg,.jpeg,.gif,.bmp,.webp`,name:`file`,class:`value upload-wrapper`,limit:2,multiple:!0,"list-type":`picture`,action:e.uploadUrl,"on-exceed":e.onExceed,"on-error":e.onError,"on-success":e.onSuccess,headers:e.headers},{file:m(({file:t})=>[a(l,{url:t.url||t.response?.file_url,name:t.name,percentage:t.percentage,onRemove:n=>e.fileList.splice(e.fileList.indexOf(t),1)},null,8,[`url`,`name`,`percentage`,`onRemove`])]),default:m(()=>[a(g,{size:`small`,type:`primary`,round:``},{default:m(()=>[a(h,{icon:`fa-solid fa-upload`,class:`mr-1`}),i(` `+u(e.$t(`headshots.button.uploadImageUrls`)),1)]),_:1})]),_:1},8,[`file-list`,`action`,`on-exceed`,`on-error`,`on-success`,`headers`])]),a(v,{content:e.$t(`headshots.description.endImageUrls`),class:`info`},null,8,[`content`])])}var ae=O(Z,[[`render`,ie],[`__scopeId`,`data-v-d468812a`]]),oe=`fast`,se=s({name:`ModeSelector`,components:{ElRadioButton:S,ElRadioGroup:C},data(){return{options:[{label:this.$t(`headshots.button.fast`),value:`fast`},{label:this.$t(`headshots.button.relax`),value:`relax`}]}},computed:{value:{get(){return this.$store.state.headshots.config?.mode},set(e){console.debug(`set mode`,e),this.$store.commit(`headshots/setConfig`,{...this.$store.state.headshots.config,mode:e})}}},mounted(){this.value||=oe}}),ce={class:`field`},le={class:`title font-bold`};function ue(e,t,o,s,l,g){let _=f(`el-radio-button`),v=f(`el-radio-group`);return d(),p(`div`,ce,[r(`h2`,le,u(e.$t(`headshots.name.mode`)),1),a(v,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,class:`mode`},{default:m(()=>[(d(!0),p(h,null,c(e.options,e=>(d(),n(_,{key:e.value,label:e.value},{default:m(()=>[i(u(e.label),1)]),_:2},1032,[`label`]))),128))]),_:1},8,[`modelValue`])])}var de=O(se,[[`render`,ue],[`__scopeId`,`data-v-e7702494`]]),fe=s({name:`StylizeSelector`,components:{ElTabs:_,ElTabPane:v,ElImage:b},data(){return{tab:`styles`,value:``,elements:{styles:{displayName:this.$t(`headshots.styleCategory.styles`),items:[{image:`https://static.aipedias.com/aicamera/common/20241008/20241008202314260779439.png`,label:this.$t(`headshots.styleTag.malePportrait`),value:`male_portrait`},{image:`https://static.aipedias.com/aicamera/common/20241008/202410082022241e9755548.png`,label:this.$t(`headshots.styleTag.malePportrait2`),value:`male_portrait2`},{image:`https://static.aipedias.com/aicamera/common/20241101/20241101170130d78f66521.png`,label:this.$t(`headshots.styleTag.kindergarten`),value:`kindergarten`},{image:`https://static.aipedias.com/aicamera/common/20240923/20240923123233accf60398.webp`,label:this.$t(`headshots.styleTag.logoTshirt`),value:`logo_tshirt`},{image:`https://static.aipedias.com/aicamera/common/20241025/202410252012329472d0656.jpg`,label:this.$t(`headshots.styleTag.wedding`),value:`wedding`},{image:`https://static.aipedias.com/aicamera/common/20240915/20240915145045254931400.webp`,label:this.$t(`headshots.styleTag.businessPphoto`),value:`business_photo`},{image:`https://static.aipedias.com/aicamera/common/20240810/20240810194526040341795.jpg`,label:this.$t(`headshots.styleTag.bobSuit`),value:`bob_suit`},{image:`https://static.aipedias.com/aicamera/common/20240717/20240717152654e0b348173.webp`,label:this.$t(`headshots.styleTag.femalePortrait`),value:`female_portrait`}]}}}},watch:{value(e){console.debug(`set template`,e),this.$store.commit(`headshots/setConfig`,{...this.$store.state.headshots?.config,template:e})}},mounted(){this.value||=``,console.debug(`set template`,this.value),this.$store.commit(`headshots/setConfig`,{...this.$store.state.headshots?.config,template:this.value})},methods:{onToggle(e){this.value===e?this.value=``:this.value=e,console.debug(`set template`,this.value),this.$store.commit(`headshots/setConfig`,{...this.$store.state.headshots?.config,template:this.value})}}}),pe={class:`field`},me=[`onClick`],he={class:`name`};function ge(e,i,o,s,l,g){let _=f(`el-image`),v=f(`el-tab-pane`),y=f(`el-tabs`);return d(),p(`div`,pe,[a(y,{modelValue:e.tab,"onUpdate:modelValue":i[0]||=t=>e.tab=t},{default:m(()=>[(d(!0),p(h,null,c(e.elements,(i,o)=>(d(),n(v,{key:o,label:i.displayName,name:o,class:`pane`},{default:m(()=>[(d(!0),p(h,null,c(i.items,(n,i)=>(d(),p(`div`,{key:i,class:t({item:!0,active:e.value===n.value}),onClick:t=>e.onToggle(n.value)},[a(_,{src:n.image,fit:`fill`,class:`preview`},null,8,[`src`]),r(`span`,he,u(n.label),1)],10,me))),128))]),_:2},1032,[`label`,`name`]))),128))]),_:1},8,[`modelValue`])])}var _e=s({name:`PresetPanel`,components:{ModeSelector:de,ImageUrlsInput:ae,ElButton:g,FontAwesomeIcon:L,ElementsSelector:O(fe,[[`render`,ge],[`__scopeId`,`data-v-be4bd25d`]])},emits:[`generate`],computed:{config(){return this.$store.state.headshots?.config}},methods:{onGenerate(){this.$emit(`generate`)}}}),ve={class:`panel`},ye={class:`config`},be={class:`actions`};function xe(e,t,n,o,s,c){let l=f(`elements-selector`),h=f(`mode-selector`),g=f(`image-urls-input`),_=f(`font-awesome-icon`),v=f(`el-button`);return d(),p(`div`,ve,[r(`div`,ye,[a(l,{class:`mb-4`}),a(h,{class:`mb-4`}),a(g,{class:`mb-4`}),r(`div`,be,[a(v,{type:`primary`,class:`btn w-full`,round:``,onClick:e.onGenerate},{default:m(()=>[a(_,{icon:`fa-solid fa-magic`,class:`mr-2`}),i(` `+u(e.$t(`headshots.button.generate`)),1)]),_:1},8,[`onClick`])])])])}var Se=O(_e,[[`render`,xe],[`__scopeId`,`data-v-848739f6`]]),Ce=s({name:`ImageGallery`,props:{modelValue:{type:Object,required:!0}},setup(e){return{images:l(()=>e.modelValue?.response?.data?.slice(0,2)||[]),viewImage:e=>{window.open(e,`_blank`)}}}}),we={class:`image-gallery`},Te=[`src`],Ee=[`onClick`];function De(e,t,n,i,a,s){return d(),p(`div`,we,[(d(!0),p(h,null,c(e.images,(t,n)=>(d(),p(`div`,{key:n,class:`image-container`},[r(`img`,{src:t.image_url,alt:`Image`},null,8,Te),t.image_url?(d(),p(`button`,{key:0,class:`view-button`,onClick:n=>e.viewImage(t.image_url)},u(e.$t(`headshots.button.viewImage`)),9,Ee)):o(``,!0)]))),128))])}var Oe=s({name:`TaskPreview`,components:{ElImage:b,CopyToClipboard:R,FontAwesomeIcon:L,ElAlert:x,ImageGallery:O(Ce,[[`render`,De],[`__scopeId`,`data-v-42f0a7be`]]),ApiCodeButton:W},props:{modelValue:{type:Object,required:!0}},data(){return{}},computed:{application(){return this.$store.state.headshots?.application},config(){return this.$store.state.headshots?.config}},methods:{onDownload(e,t){e?.stopPropagation(),console.log(`on download`),window.open(t,`_blank`)},onReload(e){let t=e.target,n=new URL(t.src),r=n.searchParams.get(`retry`);if(!r)n.searchParams.set(`retry`,`1`);else if(parseInt(r)<2)n.searchParams.set(`retry`,(parseInt(r)+1).toString());else return;t.src=n.toString()},onOpenVideo(e){window.open(e,`_blank`)}}}),ke={class:`preview`},Ae={class:`left`},je={class:`main`},Me={class:`bot`},Ne={class:`datetime`},Pe={class:`info`},Fe={key:0,class:`prompt mt-2`},Ie={key:0},Le={key:1},Re={key:0,class:t({content:!0,failed:!0})},ze={class:`image-wrapper`},Be={class:t({operations:!0,"mt-2":!0,"mb-2":!0})},Ve={class:`description`},He={key:0,class:`description`},Ue={key:1,class:t({content:!0})},We={class:`description`},Ge={class:`description`},Ke={key:0,class:`description`},qe={class:`description`},Je={key:2,class:t({content:!0})},$={class:`description`},Ye={key:3,class:t({content:!0})},Xe={class:`description`};function Ze(e,t,n,s,c,l){let h=f(`el-image`),g=f(`image-gallery`),_=f(`api-code-button`),v=f(`font-awesome-icon`),y=f(`copy-to-clipboard`),b=f(`el-alert`);return d(),p(`div`,ke,[r(`div`,Ae,[a(h,{src:`https://cdn.acedata.cloud/isxyfw.png`,class:`avatar`})]),r(`div`,je,[r(`div`,Me,[i(u(e.$t(`headshots.name.headshotsBot`))+` `,1),r(`span`,Ne,u(e.$dayjs.format(``+new Date(parseFloat((e.modelValue?.created_at||``).toString())*1e3))),1)]),r(`div`,Pe,[e.modelValue?.request?.template?(d(),p(`p`,Fe,[i(u(e.modelValue?.request?.template)+` `,1),e.modelValue?.response?o(``,!0):(d(),p(`span`,Ie,` - (`+u(e.$t(`headshots.status.pending`))+`) `,1)),e.modelValue?.response?.status===`unknown`?(d(),p(`span`,Le,` - (`+u(e.$t(`headshots.status.processing`))+`) `,1)):o(``,!0)])):o(``,!0)]),e.modelValue?.response?.success===!0?(d(),p(`div`,Re,[r(`div`,ze,[a(g,{"model-value":e.modelValue},null,8,[`model-value`])]),r(`div`,Be,[a(_,{path:`/headshots/images`,body:e.modelValue?.request},null,8,[`body`])]),a(b,{closable:!1,class:`mt-2 success`},{default:m(()=>[r(`p`,Ve,[a(v,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+u(e.$t(`headshots.name.taskId`))+`: `+u(e.modelValue?.id)+` `,1),a(y,{content:e.modelValue?.id,class:`btn-copy`},null,8,[`content`])]),e.modelValue?.elapsed?(d(),p(`p`,He,[a(v,{icon:`fa-solid fa-clock`,class:`mr-1`}),i(` `+u(e.$t(`headshots.name.elapsed`))+`: `+u(e.modelValue?.elapsed?.toFixed(2))+`s `,1)])):o(``,!0)]),_:1})])):o(``,!0),e.modelValue?.response?.success===!1?(d(),p(`div`,Ue,[a(b,{closable:!1,class:`failure`},{template:m(()=>[a(v,{icon:`fa-solid fa-exclamation-triangle`,class:`mr-1`}),i(` `+u(e.$t(`headshots.name.failure`)),1)]),default:m(()=>[r(`p`,We,[a(v,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+u(e.$t(`headshots.name.taskId`))+`: `+u(e.modelValue?.id)+` `,1),a(y,{content:e.modelValue?.id,class:`btn-copy`},null,8,[`content`])]),r(`p`,Ge,[a(v,{icon:`fa-solid fa-circle-info`,class:`mr-1`}),i(` `+u(e.$t(`headshots.name.failureReason`))+`: `+u(e.modelValue?.response?.error?.message)+` `,1),a(y,{content:e.modelValue?.response?.error?.message,class:`btn-copy`},null,8,[`content`])]),e.modelValue?.elapsed?(d(),p(`p`,Ke,[a(v,{icon:`fa-solid fa-clock`,class:`mr-1`}),i(` `+u(e.$t(`headshots.name.elapsed`))+`: `+u(e.modelValue?.elapsed?.toFixed(2))+`s `,1)])):o(``,!0),r(`p`,qe,[a(v,{icon:`fa-solid fa-hashtag`,class:`mr-1`}),i(` `+u(e.$t(`headshots.name.traceId`))+`: `+u(e.modelValue?.response?.trace_id)+` `,1),a(y,{content:e.modelValue?.response?.trace_id,class:`btn-copy`},null,8,[`content`])])]),_:1})])):o(``,!0),e.modelValue?.response?o(``,!0):(d(),p(`div`,Je,[a(b,{closable:!1,class:`info`},{template:m(()=>[a(v,{icon:`fa-solid fa-exclamation-triangle`,class:`mr-1`}),i(` `+u(e.$t(`headshots.name.failure`)),1)]),default:m(()=>[r(`p`,$,[a(v,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+u(e.$t(`headshots.name.taskId`))+`: `+u(e.modelValue?.id)+` `,1),a(y,{content:e.modelValue?.id,class:`btn-copy`},null,8,[`content`])])]),_:1})])),e.modelValue?.response?.status===`unknown`?(d(),p(`div`,Ye,[a(b,{closable:!1,class:`info`},{template:m(()=>[a(v,{icon:`fa-solid fa-exclamation-triangle`,class:`mr-1`}),i(` `+u(e.$t(`headshots.name.failure`)),1)]),default:m(()=>[r(`p`,Xe,[a(v,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+u(e.$t(`headshots.name.taskId`))+`: `+u(e.modelValue?.id)+` `,1),a(y,{content:e.modelValue?.id,class:`btn-copy`},null,8,[`content`])])]),_:1})])):o(``,!0)])])}var Qe=s({name:`RecentPanel`,components:{TaskPreview:O(Oe,[[`render`,Ze],[`__scopeId`,`data-v-0e921c0c`]]),ElSkeleton:te,ElSkeletonItem:ee,ScrollList:H},props:{loading:{type:Boolean,default:!1}},emits:[`reach-top`],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.headshots?.tasks,items:this.$store.state.headshots?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),$e={key:0,class:`tasks`},et={class:`left`},tt={class:`main`},nt={key:1,class:`tasks`},rt={key:2,class:`description`};function it(e,t,i,s,l,g){let _=f(`el-skeleton-item`),v=f(`el-skeleton`),y=f(`task-preview`),b=f(`scroll-list`);return d(),n(b,{ref:`scrollList`,class:`panel recent`,loading:e.loading,onReachTop:t[0]||=t=>e.$emit(`reach-top`)},{default:m(()=>[e.tasks?.items===void 0?(d(),p(`div`,$e,[(d(),p(h,null,c(3,e=>r(`div`,{key:e,class:`task placeholder`},[r(`div`,et,[a(v,{animated:``},{template:m(()=>[a(_,{variant:`image`,class:`avatar`})]),_:1})]),r(`div`,tt,[a(v,{animated:``},{template:m(()=>[a(_,{variant:`p`,class:`title`}),a(_,{variant:`image`,class:`icon`})]),_:1})])])),64))])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(d(),p(`div`,nt,[(d(!0),p(h,null,c(e.tasks?.items,(e,t)=>(d(),n(y,{key:t,"model-value":e,class:`preview`},null,8,[`model-value`]))),128))])):o(``,!0),e.tasks?.items?.length===0?(d(),p(`p`,rt,u(e.$t(`headshots.message.noTasks`)),1)):o(``,!0)]),_:1},8,[`loading`])}var at=O(Qe,[[`render`,it],[`__scopeId`,`data-v-ffd55c16`]]),ot=T(`headshots`),st=s({name:`HeadshotsIndex`,components:{ConfigPanel:Se,Layout:X,ApplicationStatus:z,RecentPanel:at},mixins:[D],inject:[`initialized`],data(){return{task:void 0,job:0,loadingMore:!1,fetchingTasks:!1}},computed:{applicationsLoading(){return this.$store.state.headshots?.status?.getApplications===I.Request},tasksLoading(){return this.$store.state.headshots?.status?.getTasks===I.Request||this.fetchingTasks},service(){return this.$store.state.headshots.service},credential(){return this.$store.state.headshots.credential},config(){return this.$store.state.headshots.config},initializing(){return this.$store.state.headshots.status.getApplications===I.Request},needApply(){return this.$store.state.headshots.status.getApplications===I.Success&&!this.application},application(){return this.$store.state.headshots.application},applications(){return this.$store.state.headshots.applications},tasks(){return this.$store.state.headshots.tasks}},watch:{tasks:{handler(e,t){e?.items?.length>t?.items?.length&&console.debug(`new tasks detected`)},deep:!0},initialized:{async handler(e){e&&(console.debug(`layout initialized`),await this.onGetTasks(),await this.onScrollDown(),this.job=window.setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){window.clearInterval(this.job)},methods:{async onReachTop(){await U({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(`headshots/getService`),console.debug(`end onGetService`)},async onGetApplication(){console.debug(`start onGetApplication`),await this.$store.dispatch(`headshots/getApplications`),console.debug(`end onGetApplication`),await this.onGetTasks()},onApply(){E.create({application:this.application}).then(({data:e})=>{this.application=e,N.success(this.$t(`application.message.applySuccessfully`))}).catch(e=>{e?.response?.data?.code===`duplication`&&N.error(this.$t(`application.message.alreadyApplied`))})},async onScrollDown(){await this.$nextTick();let e=this.getTasksScrollElement();e&&(e.scrollTop=e.scrollHeight)},async onGetTasks(e){if(this.applicationsLoading||this.fetchingTasks){console.debug(`loading`);return}console.debug(`start onGetTasks`,e);let{limit:t=5,createdAtMin:n,createdAtMax:r}=e||{};console.debug(`limit`,t,`createdAtMin`,n,`createdAtMax`,r),this.fetchingTasks=!0;try{await this.$store.dispatch(`headshots/getTasks`,{limit:t,createdAtMin:n,createdAtMax:r})}finally{this.fetchingTasks=!1}},async onGeneratePicture(){if(!A(this.uploadTracker,e=>this.$t(e),e=>N.warning(e)))return;let e={...this.config,callback_url:ot},t=this.credential?.token;if(!t){console.error(`no token specified`);return}N.info(this.$t(`headshots.message.startingTask`)),k(`headshots`,F.generate(e,{token:t})).then(()=>{N.success(this.$t(`headshots.message.startTaskSuccess`)),this.$store.commit(`headshots/setConfig`,{config:void 0})}).catch(e=>{(e?.response?.data)?.error?.code===`used_up`?N.error(this.$t(`headshots.message.usedUp`)):N.error(this.$t(`headshots.message.startTaskFailed`))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function ct(e,t,r,i,o,s){let c=f(`config-panel`),l=f(`application-status`),u=f(`recent-panel`),p=f(`layout`);return d(),n(p,null,{config:m(()=>[a(c,{onGenerate:e.onGeneratePicture},null,8,[`onGenerate`])]),result:m(()=>[a(l,{initializing:e.initializing,application:e.application,applications:e.applications,service:e.service,"need-apply":e.needApply,class:`mb-4`,onRefresh:e.onGetApplication,onSelect:t[0]||=t=>e.$store.dispatch(`headshots/setApplication`,t)},null,8,[`initializing`,`application`,`applications`,`service`,`need-apply`,`onRefresh`]),a(u,{ref:`recentPanel`,class:`panel recent`,loading:e.loadingMore,onReachTop:e.onReachTop},null,8,[`loading`,`onReachTop`])]),_:1})}var lt=O(st,[[`render`,ct],[`__scopeId`,`data-v-c707e859`]]);export{lt as default};
|
|
1
|
+
import"./rolldown-runtime--c01j_DQ.js";import{$ as e,Bt as t,D as n,E as r,M as i,N as a,O as o,P as s,Q as c,T as l,Ut as u,X as d,et as f,k as p,lt as m,x as h}from"./vendor-chart-mdwpew_o.js";import{t as g}from"./button-DWzbdjZV.js";import{n as _,t as v}from"./tabs-DbqhD0Ri.js";import{t as y}from"./upload-CHAO8dYa.js";import{t as b}from"./image-tItcr5tZ.js";import{t as x}from"./alert-BJj7gY4q.js";import{n as S,r as C}from"./radio-IJQsW93X.js";import{t as w}from"./drawer-BvYPSxXh.js";import{n as ee,t as te}from"./skeleton-Cn4UY-T8.js";import{hi as T}from"./constants-B6_fTlam.js";import{An as E,At as D,E as O,Fn as k,Ot as A,Sr as j,jt as M,kr as N,kt as P,sn as F,yr as I}from"./index-DpREqzJQ.js";import{t as L}from"./index.es-DkXuZNXE.js";import{t as R}from"./CopyToClipboard-DXA4nHxo.js";import{t as z}from"./Status-CvH_CBCZ.js";import{t as B}from"./ImagePreview-Bkw_taCt.js";import{i as V,n as H,t as U}from"./pagination-BQOE0Lce.js";import{t as W}from"./ApiCodeButton-DXN7iB8l.js";var G=s({name:`LayoutHeadshots`,components:{ElDrawer:w,ElButton:g,FontAwesomeIcon:L},data(){return{drawer:!1}}}),K={class:`main flex flex-row flex-1`},q={class:`config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]`},J={class:`result h-full p-6 flex-1 flex flex-col min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]`};function Y(t,n,i,o,s,c){let l=f(`font-awesome-icon`),u=f(`el-button`),h=f(`el-drawer`);return d(),p(`div`,K,[r(`div`,q,[e(t.$slots,`config`,{},void 0,!0)]),r(`div`,J,[e(t.$slots,`result`,{},void 0,!0)]),a(u,{circle:``,class:`menu`,onClick:n[0]||=e=>t.drawer=!0},{default:m(()=>[a(l,{icon:`fa-solid fa-gear`})]),_:1}),a(h,{modelValue:t.drawer,"onUpdate:modelValue":n[1]||=e=>t.drawer=e,"with-header":!1,size:`340px`,class:`drawer`},{default:m(()=>[e(t.$slots,`config`,{},void 0,!0)]),_:3},8,[`modelValue`])])}var X=O(G,[[`render`,Y],[`__scopeId`,`data-v-ada6b2d1`]]),Z=s({name:`ImageUrlsInput`,components:{ElUpload:y,ElButton:g,InfoIcon:V,ImagePreview:B,FontAwesomeIcon:L},mixins:[M,P],data(){return{fileList:[],uploadUrl:j()+`/api/v1/files/`}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e?.response?.file_url)},value:{get(){return this.$store.state.headshots?.config?.image_urls},set(){let e=this.urls;this.$store.commit(`headshots/setConfig`,{...this.$store.state.headshots?.config,image_urls:e})}}},mounted(){this.value||=void 0,this.onSetImageUrls()},methods:{onExceed(){N.warning(this.$t(`headshots.message.uploadImageExceed`))},onError(){N.error(this.$t(`headshots.message.uploadImageError`))},onSetImageUrls(){let e=this.urls;this.$store.commit(`headshots/setConfig`,{...this.$store.state.headshots?.config,image_urls:e})},async onSuccess(){this.onSetImageUrls()}}}),Q={class:`field`},ne={class:`title font-bold`},re={class:`upload-wrapper`};function ie(e,t,n,o,s,c){let l=f(`image-preview`),h=f(`font-awesome-icon`),g=f(`el-button`),_=f(`el-upload`),v=f(`info-icon`);return d(),p(`div`,Q,[r(`h2`,ne,u(e.$t(`headshots.name.endImageUrls`)),1),r(`div`,re,[a(_,{ref:`uploader`,"file-list":e.fileList,"onUpdate:fileList":t[0]||=t=>e.fileList=t,accept:`.png,.jpg,.jpeg,.gif,.bmp,.webp`,name:`file`,class:`value upload-wrapper`,limit:2,multiple:!0,"list-type":`picture`,action:e.uploadUrl,"on-exceed":e.onExceed,"on-error":e.onError,"on-success":e.onSuccess,headers:e.headers},{file:m(({file:t})=>[a(l,{url:t.url||t.response?.file_url,name:t.name,percentage:t.percentage,onRemove:n=>e.fileList.splice(e.fileList.indexOf(t),1)},null,8,[`url`,`name`,`percentage`,`onRemove`])]),default:m(()=>[a(g,{size:`small`,type:`primary`,round:``},{default:m(()=>[a(h,{icon:`fa-solid fa-upload`,class:`mr-1`}),i(` `+u(e.$t(`headshots.button.uploadImageUrls`)),1)]),_:1})]),_:1},8,[`file-list`,`action`,`on-exceed`,`on-error`,`on-success`,`headers`])]),a(v,{content:e.$t(`headshots.description.endImageUrls`),class:`info`},null,8,[`content`])])}var ae=O(Z,[[`render`,ie],[`__scopeId`,`data-v-d468812a`]]),oe=`fast`,se=s({name:`ModeSelector`,components:{ElRadioButton:S,ElRadioGroup:C},data(){return{options:[{label:this.$t(`headshots.button.fast`),value:`fast`},{label:this.$t(`headshots.button.relax`),value:`relax`}]}},computed:{value:{get(){return this.$store.state.headshots.config?.mode},set(e){console.debug(`set mode`,e),this.$store.commit(`headshots/setConfig`,{...this.$store.state.headshots.config,mode:e})}}},mounted(){this.value||=oe}}),ce={class:`field`},le={class:`title font-bold`};function ue(e,t,o,s,l,g){let _=f(`el-radio-button`),v=f(`el-radio-group`);return d(),p(`div`,ce,[r(`h2`,le,u(e.$t(`headshots.name.mode`)),1),a(v,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,class:`mode`},{default:m(()=>[(d(!0),p(h,null,c(e.options,e=>(d(),n(_,{key:e.value,label:e.value},{default:m(()=>[i(u(e.label),1)]),_:2},1032,[`label`]))),128))]),_:1},8,[`modelValue`])])}var de=O(se,[[`render`,ue],[`__scopeId`,`data-v-e7702494`]]),fe=s({name:`StylizeSelector`,components:{ElTabs:_,ElTabPane:v,ElImage:b},data(){return{tab:`styles`,value:``,elements:{styles:{displayName:this.$t(`headshots.styleCategory.styles`),items:[{image:`https://static.aipedias.com/aicamera/common/20241008/20241008202314260779439.png`,label:this.$t(`headshots.styleTag.malePportrait`),value:`male_portrait`},{image:`https://static.aipedias.com/aicamera/common/20241008/202410082022241e9755548.png`,label:this.$t(`headshots.styleTag.malePportrait2`),value:`male_portrait2`},{image:`https://static.aipedias.com/aicamera/common/20241101/20241101170130d78f66521.png`,label:this.$t(`headshots.styleTag.kindergarten`),value:`kindergarten`},{image:`https://static.aipedias.com/aicamera/common/20240923/20240923123233accf60398.webp`,label:this.$t(`headshots.styleTag.logoTshirt`),value:`logo_tshirt`},{image:`https://static.aipedias.com/aicamera/common/20241025/202410252012329472d0656.jpg`,label:this.$t(`headshots.styleTag.wedding`),value:`wedding`},{image:`https://static.aipedias.com/aicamera/common/20240915/20240915145045254931400.webp`,label:this.$t(`headshots.styleTag.businessPphoto`),value:`business_photo`},{image:`https://static.aipedias.com/aicamera/common/20240810/20240810194526040341795.jpg`,label:this.$t(`headshots.styleTag.bobSuit`),value:`bob_suit`},{image:`https://static.aipedias.com/aicamera/common/20240717/20240717152654e0b348173.webp`,label:this.$t(`headshots.styleTag.femalePortrait`),value:`female_portrait`}]}}}},watch:{value(e){console.debug(`set template`,e),this.$store.commit(`headshots/setConfig`,{...this.$store.state.headshots?.config,template:e})}},mounted(){this.value||=``,console.debug(`set template`,this.value),this.$store.commit(`headshots/setConfig`,{...this.$store.state.headshots?.config,template:this.value})},methods:{onToggle(e){this.value===e?this.value=``:this.value=e,console.debug(`set template`,this.value),this.$store.commit(`headshots/setConfig`,{...this.$store.state.headshots?.config,template:this.value})}}}),pe={class:`field`},me=[`onClick`],he={class:`name`};function ge(e,i,o,s,l,g){let _=f(`el-image`),v=f(`el-tab-pane`),y=f(`el-tabs`);return d(),p(`div`,pe,[a(y,{modelValue:e.tab,"onUpdate:modelValue":i[0]||=t=>e.tab=t},{default:m(()=>[(d(!0),p(h,null,c(e.elements,(i,o)=>(d(),n(v,{key:o,label:i.displayName,name:o,class:`pane`},{default:m(()=>[(d(!0),p(h,null,c(i.items,(n,i)=>(d(),p(`div`,{key:i,class:t({item:!0,active:e.value===n.value}),onClick:t=>e.onToggle(n.value)},[a(_,{src:n.image,fit:`fill`,class:`preview`},null,8,[`src`]),r(`span`,he,u(n.label),1)],10,me))),128))]),_:2},1032,[`label`,`name`]))),128))]),_:1},8,[`modelValue`])])}var _e=s({name:`PresetPanel`,components:{ModeSelector:de,ImageUrlsInput:ae,ElButton:g,FontAwesomeIcon:L,ElementsSelector:O(fe,[[`render`,ge],[`__scopeId`,`data-v-be4bd25d`]])},emits:[`generate`],computed:{config(){return this.$store.state.headshots?.config}},methods:{onGenerate(){this.$emit(`generate`)}}}),ve={class:`panel`},ye={class:`config`},be={class:`actions`};function xe(e,t,n,o,s,c){let l=f(`elements-selector`),h=f(`mode-selector`),g=f(`image-urls-input`),_=f(`font-awesome-icon`),v=f(`el-button`);return d(),p(`div`,ve,[r(`div`,ye,[a(l,{class:`mb-4`}),a(h,{class:`mb-4`}),a(g,{class:`mb-4`}),r(`div`,be,[a(v,{type:`primary`,class:`btn w-full`,round:``,onClick:e.onGenerate},{default:m(()=>[a(_,{icon:`fa-solid fa-magic`,class:`mr-2`}),i(` `+u(e.$t(`headshots.button.generate`)),1)]),_:1},8,[`onClick`])])])])}var Se=O(_e,[[`render`,xe],[`__scopeId`,`data-v-848739f6`]]),Ce=s({name:`ImageGallery`,props:{modelValue:{type:Object,required:!0}},setup(e){return{images:l(()=>e.modelValue?.response?.data?.slice(0,2)||[]),viewImage:e=>{window.open(e,`_blank`)}}}}),we={class:`image-gallery`},Te=[`src`],Ee=[`onClick`];function De(e,t,n,i,a,s){return d(),p(`div`,we,[(d(!0),p(h,null,c(e.images,(t,n)=>(d(),p(`div`,{key:n,class:`image-container`},[r(`img`,{src:t.image_url,alt:`Image`},null,8,Te),t.image_url?(d(),p(`button`,{key:0,class:`view-button`,onClick:n=>e.viewImage(t.image_url)},u(e.$t(`headshots.button.viewImage`)),9,Ee)):o(``,!0)]))),128))])}var Oe=s({name:`TaskPreview`,components:{ElImage:b,CopyToClipboard:R,FontAwesomeIcon:L,ElAlert:x,ImageGallery:O(Ce,[[`render`,De],[`__scopeId`,`data-v-42f0a7be`]]),ApiCodeButton:W},props:{modelValue:{type:Object,required:!0}},data(){return{}},computed:{application(){return this.$store.state.headshots?.application},config(){return this.$store.state.headshots?.config}},methods:{onDownload(e,t){e?.stopPropagation(),console.log(`on download`),window.open(t,`_blank`)},onReload(e){let t=e.target,n=new URL(t.src),r=n.searchParams.get(`retry`);if(!r)n.searchParams.set(`retry`,`1`);else if(parseInt(r)<2)n.searchParams.set(`retry`,(parseInt(r)+1).toString());else return;t.src=n.toString()},onOpenVideo(e){window.open(e,`_blank`)}}}),ke={class:`preview`},Ae={class:`left`},je={class:`main`},Me={class:`bot`},Ne={class:`datetime`},Pe={class:`info`},Fe={key:0,class:`prompt mt-2`},Ie={key:0},Le={key:1},Re={key:0,class:t({content:!0,failed:!0})},ze={class:`image-wrapper`},Be={class:t({operations:!0,"mt-2":!0,"mb-2":!0})},Ve={class:`description`},He={key:0,class:`description`},Ue={key:1,class:t({content:!0})},We={class:`description`},Ge={class:`description`},Ke={key:0,class:`description`},qe={class:`description`},Je={key:2,class:t({content:!0})},$={class:`description`},Ye={key:3,class:t({content:!0})},Xe={class:`description`};function Ze(e,t,n,s,c,l){let h=f(`el-image`),g=f(`image-gallery`),_=f(`api-code-button`),v=f(`font-awesome-icon`),y=f(`copy-to-clipboard`),b=f(`el-alert`);return d(),p(`div`,ke,[r(`div`,Ae,[a(h,{src:`https://cdn.acedata.cloud/isxyfw.png`,class:`avatar`})]),r(`div`,je,[r(`div`,Me,[i(u(e.$t(`headshots.name.headshotsBot`))+` `,1),r(`span`,Ne,u(e.$dayjs.format(``+new Date(parseFloat((e.modelValue?.created_at||``).toString())*1e3))),1)]),r(`div`,Pe,[e.modelValue?.request?.template?(d(),p(`p`,Fe,[i(u(e.modelValue?.request?.template)+` `,1),e.modelValue?.response?o(``,!0):(d(),p(`span`,Ie,` - (`+u(e.$t(`headshots.status.pending`))+`) `,1)),e.modelValue?.response?.status===`unknown`?(d(),p(`span`,Le,` - (`+u(e.$t(`headshots.status.processing`))+`) `,1)):o(``,!0)])):o(``,!0)]),e.modelValue?.response?.success===!0?(d(),p(`div`,Re,[r(`div`,ze,[a(g,{"model-value":e.modelValue},null,8,[`model-value`])]),r(`div`,Be,[a(_,{path:`/headshots/images`,body:e.modelValue?.request},null,8,[`body`])]),a(b,{closable:!1,class:`mt-2 success`},{default:m(()=>[r(`p`,Ve,[a(v,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+u(e.$t(`headshots.name.taskId`))+`: `+u(e.modelValue?.id)+` `,1),a(y,{content:e.modelValue?.id,class:`btn-copy`},null,8,[`content`])]),e.modelValue?.elapsed?(d(),p(`p`,He,[a(v,{icon:`fa-solid fa-clock`,class:`mr-1`}),i(` `+u(e.$t(`headshots.name.elapsed`))+`: `+u(e.modelValue?.elapsed?.toFixed(2))+`s `,1)])):o(``,!0)]),_:1})])):o(``,!0),e.modelValue?.response?.success===!1?(d(),p(`div`,Ue,[a(b,{closable:!1,class:`failure`},{template:m(()=>[a(v,{icon:`fa-solid fa-exclamation-triangle`,class:`mr-1`}),i(` `+u(e.$t(`headshots.name.failure`)),1)]),default:m(()=>[r(`p`,We,[a(v,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+u(e.$t(`headshots.name.taskId`))+`: `+u(e.modelValue?.id)+` `,1),a(y,{content:e.modelValue?.id,class:`btn-copy`},null,8,[`content`])]),r(`p`,Ge,[a(v,{icon:`fa-solid fa-circle-info`,class:`mr-1`}),i(` `+u(e.$t(`headshots.name.failureReason`))+`: `+u(e.modelValue?.response?.error?.message)+` `,1),a(y,{content:e.modelValue?.response?.error?.message,class:`btn-copy`},null,8,[`content`])]),e.modelValue?.elapsed?(d(),p(`p`,Ke,[a(v,{icon:`fa-solid fa-clock`,class:`mr-1`}),i(` `+u(e.$t(`headshots.name.elapsed`))+`: `+u(e.modelValue?.elapsed?.toFixed(2))+`s `,1)])):o(``,!0),r(`p`,qe,[a(v,{icon:`fa-solid fa-hashtag`,class:`mr-1`}),i(` `+u(e.$t(`headshots.name.traceId`))+`: `+u(e.modelValue?.response?.trace_id)+` `,1),a(y,{content:e.modelValue?.response?.trace_id,class:`btn-copy`},null,8,[`content`])])]),_:1})])):o(``,!0),e.modelValue?.response?o(``,!0):(d(),p(`div`,Je,[a(b,{closable:!1,class:`info`},{template:m(()=>[a(v,{icon:`fa-solid fa-exclamation-triangle`,class:`mr-1`}),i(` `+u(e.$t(`headshots.name.failure`)),1)]),default:m(()=>[r(`p`,$,[a(v,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+u(e.$t(`headshots.name.taskId`))+`: `+u(e.modelValue?.id)+` `,1),a(y,{content:e.modelValue?.id,class:`btn-copy`},null,8,[`content`])])]),_:1})])),e.modelValue?.response?.status===`unknown`?(d(),p(`div`,Ye,[a(b,{closable:!1,class:`info`},{template:m(()=>[a(v,{icon:`fa-solid fa-exclamation-triangle`,class:`mr-1`}),i(` `+u(e.$t(`headshots.name.failure`)),1)]),default:m(()=>[r(`p`,Xe,[a(v,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+u(e.$t(`headshots.name.taskId`))+`: `+u(e.modelValue?.id)+` `,1),a(y,{content:e.modelValue?.id,class:`btn-copy`},null,8,[`content`])])]),_:1})])):o(``,!0)])])}var Qe=s({name:`RecentPanel`,components:{TaskPreview:O(Oe,[[`render`,Ze],[`__scopeId`,`data-v-0e921c0c`]]),ElSkeleton:te,ElSkeletonItem:ee,ScrollList:H},props:{loading:{type:Boolean,default:!1}},emits:[`reach-top`],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.headshots?.tasks,items:this.$store.state.headshots?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),$e={key:0,class:`tasks`},et={class:`left`},tt={class:`main`},nt={key:1,class:`tasks`},rt={key:2,class:`description`};function it(e,t,i,s,l,g){let _=f(`el-skeleton-item`),v=f(`el-skeleton`),y=f(`task-preview`),b=f(`scroll-list`);return d(),n(b,{ref:`scrollList`,class:`panel recent`,loading:e.loading,onReachTop:t[0]||=t=>e.$emit(`reach-top`)},{default:m(()=>[e.tasks?.items===void 0?(d(),p(`div`,$e,[(d(),p(h,null,c(3,e=>r(`div`,{key:e,class:`task placeholder`},[r(`div`,et,[a(v,{animated:``},{template:m(()=>[a(_,{variant:`image`,class:`avatar`})]),_:1})]),r(`div`,tt,[a(v,{animated:``},{template:m(()=>[a(_,{variant:`p`,class:`title`}),a(_,{variant:`image`,class:`icon`})]),_:1})])])),64))])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(d(),p(`div`,nt,[(d(!0),p(h,null,c(e.tasks?.items,(e,t)=>(d(),n(y,{key:t,"model-value":e,class:`preview`},null,8,[`model-value`]))),128))])):o(``,!0),e.tasks?.items?.length===0?(d(),p(`p`,rt,u(e.$t(`headshots.message.noTasks`)),1)):o(``,!0)]),_:1},8,[`loading`])}var at=O(Qe,[[`render`,it],[`__scopeId`,`data-v-ffd55c16`]]),ot=T(`headshots`),st=s({name:`HeadshotsIndex`,components:{ConfigPanel:Se,Layout:X,ApplicationStatus:z,RecentPanel:at},mixins:[D],inject:[`initialized`],data(){return{task:void 0,job:0,loadingMore:!1,fetchingTasks:!1}},computed:{applicationsLoading(){return this.$store.state.headshots?.status?.getApplications===I.Request},tasksLoading(){return this.$store.state.headshots?.status?.getTasks===I.Request||this.fetchingTasks},service(){return this.$store.state.headshots.service},credential(){return this.$store.state.headshots.credential},config(){return this.$store.state.headshots.config},initializing(){return this.$store.state.headshots.status.getApplications===I.Request},needApply(){return this.$store.state.headshots.status.getApplications===I.Success&&!this.application},application(){return this.$store.state.headshots.application},applications(){return this.$store.state.headshots.applications},tasks(){return this.$store.state.headshots.tasks}},watch:{tasks:{handler(e,t){e?.items?.length>t?.items?.length&&console.debug(`new tasks detected`)},deep:!0},initialized:{async handler(e){e&&(console.debug(`layout initialized`),await this.onGetTasks(),await this.onScrollDown(),this.job=window.setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){window.clearInterval(this.job)},methods:{async onReachTop(){await U({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(`headshots/getService`),console.debug(`end onGetService`)},async onGetApplication(){console.debug(`start onGetApplication`),await this.$store.dispatch(`headshots/getApplications`),console.debug(`end onGetApplication`),await this.onGetTasks()},onApply(){E.create({application:this.application}).then(({data:e})=>{this.application=e,N.success(this.$t(`application.message.applySuccessfully`))}).catch(e=>{e?.response?.data?.code===`duplication`&&N.error(this.$t(`application.message.alreadyApplied`))})},async onScrollDown(){await this.$nextTick();let e=this.getTasksScrollElement();e&&(e.scrollTop=e.scrollHeight)},async onGetTasks(e){if(this.applicationsLoading||this.fetchingTasks){console.debug(`loading`);return}console.debug(`start onGetTasks`,e);let{limit:t=5,createdAtMin:n,createdAtMax:r}=e||{};console.debug(`limit`,t,`createdAtMin`,n,`createdAtMax`,r),this.fetchingTasks=!0;try{await this.$store.dispatch(`headshots/getTasks`,{limit:t,createdAtMin:n,createdAtMax:r})}finally{this.fetchingTasks=!1}},async onGeneratePicture(){if(!A(this.uploadTracker,e=>this.$t(e),e=>N.warning(e)))return;let e={...this.config,callback_url:ot},t=this.credential?.token;if(!t){console.error(`no token specified`);return}N.info(this.$t(`headshots.message.startingTask`)),k(`headshots`,F.generate(e,{token:t})).then(()=>{N.success(this.$t(`headshots.message.startTaskSuccess`)),this.$store.commit(`headshots/setConfig`,{config:void 0})}).catch(e=>{(e?.response?.data)?.error?.code===`used_up`?N.error(this.$t(`headshots.message.usedUp`)):N.error(this.$t(`headshots.message.startTaskFailed`))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function ct(e,t,r,i,o,s){let c=f(`config-panel`),l=f(`application-status`),u=f(`recent-panel`),p=f(`layout`);return d(),n(p,null,{config:m(()=>[a(c,{onGenerate:e.onGeneratePicture},null,8,[`onGenerate`])]),result:m(()=>[a(l,{initializing:e.initializing,application:e.application,applications:e.applications,service:e.service,"need-apply":e.needApply,class:`mb-4`,onRefresh:e.onGetApplication,onSelect:t[0]||=t=>e.$store.dispatch(`headshots/setApplication`,t)},null,8,[`initializing`,`application`,`applications`,`service`,`need-apply`,`onRefresh`]),a(u,{ref:`recentPanel`,class:`panel recent`,loading:e.loadingMore,onReachTop:e.onReachTop},null,8,[`loading`,`onReachTop`])]),_:1})}var lt=O(st,[[`render`,ct],[`__scopeId`,`data-v-c707e859`]]);export{lt as default};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import"./rolldown-runtime--c01j_DQ.js";import{$ as e,Bt as t,D as n,E as r,Ht as i,M as a,N as o,O as s,P as c,Q as l,Ut as u,X as d,_ as f,et as p,k as m,lt as h,ut as g,x as _,y as v}from"./vendor-chart-mdwpew_o.js";import{t as y}from"./button-DWzbdjZV.js";import{E as b}from"./use-deprecated-CPfQu7wa.js";import{r as x,t as S}from"./select-CYdISXBV.js";import{n as C,t as w}from"./tabs-DbqhD0Ri.js";import{t as T}from"./upload-CHAO8dYa.js";import{t as E}from"./tooltip-C3PYfh8V.js";import{t as D}from"./image-tItcr5tZ.js";import{t as O}from"./alert-BJj7gY4q.js";import{n as k,r as ee}from"./radio-IJQsW93X.js";import{t as te}from"./drawer-BvYPSxXh.js";import{t as ne}from"./input-number-BZClQnf5.js";import{t as A}from"./slider-heMG04zo.js";import{t as j}from"./switch-DT8swXGq.js";import{Sr as M,hi as re,yr as ie}from"./constants-B6_fTlam.js";import{At as ae,E as N,Fn as P,Ir as F,Nt as I,Or as L,Ot as R,Pr as oe,Sr as z,jt as B,kr as V,kt as H,pn as U,yr as se}from"./index-DpREqzJQ.js";import{t as W}from"./index.es-DkXuZNXE.js";import{t as ce}from"./CopyToClipboard-DXA4nHxo.js";import{t as le}from"./FilePreview-Dqk4WVEr.js";import{t as G}from"./ImagePreview-Bkw_taCt.js";import{n as ue}from"./taskDrawerMixin-Cr17Yxqk.js";import{t as de}from"./BotPlaceholder-R_nAAbft.js";import{i as K,n as fe,t as pe}from"./pagination-BQOE0Lce.js";import{n as me,t as he}from"./NoTasks-568fhAGt.js";import{t as q}from"./Consumption-CjrpUNmV.js";import{t as ge}from"./ApiCodeButton-DXN7iB8l.js";import{t as _e}from"./VideoPlayer-BjsbkQZc.js";var ve=c({name:`LayoutKling`,components:{ElDrawer:te,ElButton:y,FontAwesomeIcon:W},mixins:[ue]}),ye={class:`main flex flex-row flex-1 min-h-0`},be={class:`config w-[320px] flex-none h-full flex flex-col bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]`},xe={class:`result h-full p-6 flex-1 flex flex-col min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]`};function Se(t,n,i,a,s,c){let l=p(`font-awesome-icon`),u=p(`el-button`),_=p(`el-drawer`);return d(),m(`div`,ye,[r(`div`,be,[e(t.$slots,`config`,{},void 0,!0)]),r(`div`,xe,[e(t.$slots,`result`,{},void 0,!0)]),g(o(u,{circle:``,class:`menu`,onClick:n[0]||=e=>t.drawer=!0},{default:h(()=>[o(l,{icon:`fa-solid fa-magic`})]),_:1},512),[[f,!t.tasksEmpty]]),o(_,{modelValue:t.drawer,"onUpdate:modelValue":n[1]||=e=>t.drawer=e,direction:`ltr`,"with-header":!1,size:`350px`},{default:h(()=>[e(t.$slots,`config`,{},void 0,!0)]),_:3},8,[`modelValue`])])}var Ce=N(ve,[[`render`,Se],[`__scopeId`,`data-v-b87958dc`]]),we={text2video:!0,image2video:!0,endImage:!1,audio:!1,motionControl:!1};function J(e,t,n){let r=t||`std`,i=n??5;switch(e){case`kling-v1`:return{text2video:!0,image2video:!0,endImage:i===5,audio:!1,motionControl:i===5};case`kling-v1-6`:case`kling-v2-5-turbo`:return{text2video:!0,image2video:!0,endImage:r===`pro`,audio:!1,motionControl:!1};case`kling-v2-6`:return{text2video:!0,image2video:!0,endImage:r===`pro`,audio:r===`pro`,motionControl:!1};case`kling-v2-master`:case`kling-v2-1-master`:return{text2video:!0,image2video:!0,endImage:!1,audio:!1,motionControl:!1};case`kling-v3`:return{text2video:!0,image2video:!0,endImage:!0,audio:!0,motionControl:r!==`4k`};case`kling-v3-omni`:return{text2video:!0,image2video:!0,endImage:!0,audio:!0,motionControl:!1};case`kling-video-o1`:return{text2video:!0,image2video:!0,endImage:!0,audio:!1,motionControl:!1};default:return we}}function Y(e,t){if(!e)return[];let n=t.model??e.model,r=t.mode??e.mode,i=t.duration??e.duration;if(!n)return[];let a=J(n,r,i),o=[];return e.end_image_url&&!a.endImage&&o.push({field:`end_image_url`,i18nLabel:`kling.name.endImage`}),e.generate_audio&&!a.audio&&o.push({field:`generate_audio`,i18nLabel:`kling.name.generateAudio`}),e.camera_control?.type&&(!a.motionControl||e.start_image_url)&&o.push({field:`camera_control`,i18nLabel:`kling.name.cameraControl`}),o}function X(e,t){let n={...e};for(let e of t)e.field===`end_image_url`&&(n.end_image_url=void 0),e.field===`generate_audio`&&(n.generate_audio=!1),e.field===`camera_control`&&(n.camera_control=void 0);return n}var Te=c({name:`ModelSelector`,components:{ElSelect:x,ElOption:S},props:{modelValue:{type:String,default:void 0}},emits:[`update:modelValue`],data(){return{revertKey:0,options:[{value:`kling-v3`,label:`v3`},{value:`kling-v3-omni`,label:`v3-Omni`},{value:`kling-v2-6`,label:`v2.6`},{value:`kling-v2-5-turbo`,label:`v2.5-Turbo`},{value:`kling-v2-1-master`,label:`v2.1-Master`},{value:`kling-v2-master`,label:`v2-Master`},{value:`kling-v1-6`,label:`v1.6`},{value:`kling-v1`,label:`v1`},{value:`kling-video-o1`,label:`Video-o1`}]}},computed:{value(){return this.$store.state.kling?.config?.model}},mounted(){this.value||this.applyModel(ie)},methods:{async onChange(e){let t=this.$store.state.kling?.config||{},n=Y(t,{model:e});if(n.length===0){this.applyModel(e);return}let r=n.map(e=>this.$t(e.i18nLabel)).join(`、`);try{await L.confirm(this.$t(`kling.message.featureNotSupportedBody`,{fields:r}),this.$t(`kling.message.featureNotSupportedTitle`),{confirmButtonText:this.$t(`kling.button.confirmContinue`),cancelButtonText:this.$t(`kling.button.cancelSwitch`),type:`warning`});let i=X({...t,model:e},n);this.$store.commit(`kling/setConfig`,i),V.success(this.$t(`kling.message.featureRemovedNotice`,{fields:r}))}catch{this.revertKey+=1}},applyModel(e){this.$store.commit(`kling/setConfig`,{...this.$store.state.kling.config,model:e})}}}),Ee={class:`field`},De={class:`title font-bold`};function Oe(e,t,i,a,o,s){let c=p(`el-option`),f=p(`el-select`);return d(),m(`div`,Ee,[r(`h2`,De,u(e.$t(`pika.name.model`)),1),(d(),n(f,{key:e.revertKey,"model-value":e.value,class:`value`,placeholder:e.$t(`pika.placeholder.select`),onChange:e.onChange},{default:h(()=>[(d(!0),m(_,null,l(e.options,e=>(d(),n(c,{key:e.value,label:e.label,value:e.value},null,8,[`label`,`value`]))),128))]),_:1},8,[`model-value`,`placeholder`,`onChange`]))])}var ke=N(Te,[[`render`,Oe],[`__scopeId`,`data-v-04059875`]]),Ae=c({name:`ModeSelector`,components:{ElSelect:x,ElOption:S,InfoIcon:K},props:{modelValue:{type:String,default:void 0}},emits:[`update:modelValue`],data(){return{revertKey:0}},computed:{selectedModel(){return this.$store.state.kling?.config?.model||``},cameraControlSet(){return!!this.$store.state.kling?.config?.camera_control?.type},fourKReason(){return M.includes(this.selectedModel)?this.cameraControlSet?this.$t(`kling.description.mode4kIncompatibleCamera`):``:this.$t(`kling.description.mode4kRequiresV3`)},options(){return[{value:`std`,label:this.$t(`kling.name.modeStd`),disabled:!1,disabledReason:``},{value:`pro`,label:this.$t(`kling.name.modePro`),disabled:!1,disabledReason:``},{value:`4k`,label:this.$t(`kling.name.mode4k`),disabled:!!this.fourKReason,disabledReason:this.fourKReason}]},value(){return this.$store.state.kling?.config?.mode}},watch:{fourKReason(e){e&&this.value===`4k`&&this.applyMode(`std`)}},mounted(){this.value||this.applyMode(`std`)},methods:{async onChange(e){let t=this.$store.state.kling?.config||{},n=Y(t,{mode:e});if(n.length===0){this.applyMode(e);return}let r=n.map(e=>this.$t(e.i18nLabel)).join(`、`);try{await L.confirm(this.$t(`kling.message.featureNotSupportedBody`,{fields:r}),this.$t(`kling.message.featureNotSupportedTitle`),{confirmButtonText:this.$t(`kling.button.confirmContinue`),cancelButtonText:this.$t(`kling.button.cancelSwitch`),type:`warning`});let i=X({...t,mode:e},n);this.$store.commit(`kling/setConfig`,i),V.success(this.$t(`kling.message.featureRemovedNotice`,{fields:r}))}catch{this.revertKey+=1}},applyMode(e){this.$store.commit(`kling/setConfig`,{...this.$store.state.kling.config,mode:e})}}}),je={class:`field`},Me={class:`header`},Ne={class:`title font-bold`},Pe={key:0,class:`opt-tip`};function Fe(e,i,a,c,f,g){let v=p(`info-icon`),y=p(`el-option`),b=p(`el-select`);return d(),m(`div`,je,[r(`div`,Me,[r(`h2`,Ne,u(e.$t(`kling.name.mode`)),1),o(v,{content:e.$t(`kling.description.mode`),class:`info-icon`},null,8,[`content`])]),(d(),n(b,{key:e.revertKey,"model-value":e.value,class:`value`,placeholder:e.$t(`kling.placeholder.select`),clearable:!0,onChange:e.onChange},{default:h(()=>[(d(!0),m(_,null,l(e.options,e=>(d(),n(y,{key:e.value,label:e.label,value:e.value,disabled:e.disabled},{default:h(()=>[r(`span`,{class:t({"opt-disabled":e.disabled})},u(e.label),3),e.disabled&&e.disabledReason?(d(),m(`span`,Pe,u(e.disabledReason),1)):s(``,!0)]),_:2},1032,[`label`,`value`,`disabled`]))),128))]),_:1},8,[`model-value`,`placeholder`,`onChange`]))])}var Ie=N(Ae,[[`render`,Fe],[`__scopeId`,`data-v-9a8fa3c5`]]),Le=[3,5,8,10,12,15],Re=[5,10],ze=c({name:`DurationSelector`,components:{ElSelect:x,ElOption:S,InfoIcon:K},data(){return{revertKey:0}},computed:{selectedModel(){return this.$store.state.kling?.config?.model||``},isV3Model(){return M.includes(this.selectedModel)},allowedDurations(){return this.isV3Model?Le:Re},value(){return this.$store.state.kling?.config?.duration??5},selectValue(){let e=this.allowedDurations;return e.includes(this.value)?this.value:e.includes(5)?5:e[0]}},watch:{isV3Model(){this.allowedDurations.includes(this.value)||this.applyDuration(5)}},mounted(){this.$store.state.kling?.config?.duration||this.applyDuration(5)},methods:{async onChange(e){let t=this.$store.state.kling?.config||{},n=Y(t,{duration:e});if(n.length===0){this.applyDuration(e);return}let r=n.map(e=>this.$t(e.i18nLabel)).join(`、`);try{await L.confirm(this.$t(`kling.message.featureNotSupportedBody`,{fields:r}),this.$t(`kling.message.featureNotSupportedTitle`),{confirmButtonText:this.$t(`kling.button.confirmContinue`),cancelButtonText:this.$t(`kling.button.cancelSwitch`),type:`warning`});let i=X({...t,duration:e},n);this.$store.commit(`kling/setConfig`,i),V.success(this.$t(`kling.message.featureRemovedNotice`,{fields:r}))}catch{this.revertKey+=1}},applyDuration(e){this.$store.commit(`kling/setConfig`,{...this.$store.state.kling.config,duration:e})}}}),Be={class:`field`},Ve={class:`control`},He={class:`label`},Ue={class:`title font-bold`};function We(e,t,i,a,s,c){let f=p(`info-icon`),g=p(`el-option`),v=p(`el-select`);return d(),m(`div`,Be,[r(`div`,Ve,[r(`div`,He,[r(`h2`,Ue,u(e.$t(`kling.name.duration`)),1),o(f,{content:e.$t(`kling.description.duration`),class:`info-icon ml-1`},null,8,[`content`])]),(d(),n(v,{key:e.revertKey,"model-value":e.selectValue,class:`value`,placeholder:e.$t(`kling.placeholder.select`),onChange:e.onChange},{default:h(()=>[(d(!0),m(_,null,l(e.allowedDurations,e=>(d(),n(g,{key:e,label:`${e}s`,value:e},null,8,[`label`,`value`]))),128))]),_:1},8,[`model-value`,`placeholder`,`onChange`]))])])}var Ge=N(ze,[[`render`,We],[`__scopeId`,`data-v-5ae55e28`]]),Ke=c({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||=`1:1`}}),qe={class:`text-sm font-bold mb-2 block`},Je={class:`items`},Ye=[`onClick`],Xe={class:`name`};function Ze(e,n,a,o,s,c){return d(),m(`div`,null,[r(`span`,qe,u(e.$t(`kling.name.ratio`)),1),r(`div`,Je,[(d(!0),m(_,null,l(e.options,(n,a)=>(d(),m(`div`,{key:a,class:t({active:e.active===a,item:!0}),onClick:t=>e.value=n.value},[r(`div`,{class:t([`preview`,n.label])},[r(`div`,{class:`rect`,style:i({width:n.width+`px`,height:n.height+`px`})},null,4)],2),r(`p`,Xe,u(n.label),1)],10,Ye))),128))])])}var Qe=N(Ke,[[`render`,Ze],[`__scopeId`,`data-v-cdb14b2f`]]),$e=c({name:`StartImage`,components:{ElUpload:T,ElButton:y,ElTooltip:E,InfoIcon:K,FontAwesomeIcon:W,ImagePreview:G},mixins:[B,H],emits:[`change`],data(){return{fileList:[],uploadUrl:z()+`/api/v1/files/`}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e?.response?.file_url)},reachedLimit(){return(this.fileList?.length||0)>=1},value:{get(){return this.$store.state?.kling?.config?.start_image_url},set(){}}},mounted(){this.value||=void 0,this.onSetStartImageUrl()},methods:{onExceed(){V.warning(this.$t(`kling.message.uploadReferencesExceed`))},onError(){V.error(this.$t(`kling.message.uploadReferencesError`))},onSetStartImageUrl(){let e=this.urls?.[0];this.$store.commit(`kling/setConfig`,{...this.$store.state?.kling?.config,start_image_url:e})},async onSuccess(){this.onSetStartImageUrl()}}}),et={class:`relative`},tt={class:`flex justify-between`},nt={class:`flex justify-start items-center`},rt={class:`text-sm font-bold`};function it(e,t,i,c,l,f){let g=p(`info-icon`),_=p(`image-preview`),v=p(`font-awesome-icon`),y=p(`el-button`),b=p(`el-tooltip`),x=p(`el-upload`);return d(),m(`div`,et,[r(`div`,tt,[r(`div`,nt,[r(`span`,rt,u(e.$t(`kling.name.startImage`)),1),o(g,{content:e.$t(`kling.description.uploadStartImage`)},null,8,[`content`])])]),o(x,{ref:`uploader`,"file-list":e.fileList,"onUpdate:fileList":t[0]||=t=>e.fileList=t,name:`file`,accept:`.png,.jpg,.jpeg,.gif,.bmp,.webp`,limit:1,disabled:e.reachedLimit,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:h(({file:t})=>[t.url&&t.percentage!==void 0?(d(),n(_,{key:0,url:t.url,name:t.name,percentage:t.percentage,onRemove:n=>e.fileList.splice(e.fileList.indexOf(t),1)},null,8,[`url`,`name`,`percentage`,`onRemove`])):s(``,!0)]),default:h(()=>[o(b,{content:e.$t(`kling.message.uploadReferencesExceed`),disabled:!e.reachedLimit,placement:`top`},{default:h(()=>[r(`span`,null,[o(y,{round:``,type:`primary`,size:`small`,class:`btn btn-upload`,disabled:e.reachedLimit},{default:h(()=>[o(v,{icon:`fa-solid fa-upload`,class:`icon mr-1`}),a(` `+u(e.$t(`kling.button.uploadReferences`)),1)]),_:1},8,[`disabled`])])]),_:1},8,[`content`,`disabled`])]),_:1},8,[`file-list`,`disabled`,`action`,`on-exceed`,`on-error`,`on-success`,`headers`])])}var at=N($e,[[`render`,it],[`__scopeId`,`data-v-756dc269`]]),ot=c({name:`EndImage`,components:{ElUpload:T,ElButton:y,ElTooltip:E,ImagePreview:G,InfoIcon:K,FontAwesomeIcon:W},mixins:[B,H],data(){return{fileList:[],uploadUrl:z()+`/api/v1/files/`}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e?.response?.file_url)},reachedLimit(){return(this.fileList?.length||0)>=1},klingConfig(){return this.$store.state?.kling?.config||{}},endImageSupported(){return J(this.klingConfig.model,this.klingConfig.mode,this.klingConfig.duration).endImage},hasStartImage(){return!!this.klingConfig.start_image_url},uploadDisabled(){return this.reachedLimit||!this.endImageSupported||!this.hasStartImage},uploadTooltip(){return this.endImageSupported?this.hasStartImage?this.reachedLimit?this.$t(`kling.message.uploadReferencesExceed`):``:this.$t(`kling.message.endImageRequiresStart`):this.$t(`kling.message.endImageNotSupported`)},storeValue(){return this.klingConfig.end_image_url},value:{get(){return this.storeValue},set(){}}},watch:{storeValue(e){!e&&this.fileList.length>0&&(this.fileList=[])},hasStartImage(e){!e&&this.storeValue&&(this.fileList=[],this.$store.commit(`kling/setConfig`,{...this.$store.state.kling?.config,end_image_url:void 0}))}},mounted(){this.value||=void 0,this.onSetEndImageUrl()},methods:{onBeforeUpload(){return this.endImageSupported?this.hasStartImage?!0:(V.warning(this.$t(`kling.message.endImageRequiresStart`)),!1):(V.warning(this.$t(`kling.message.endImageNotSupported`)),!1)},onExceed(){V.warning(this.$t(`kling.message.uploadReferencesExceed`))},onError(){V.error(this.$t(`kling.message.uploadReferencesError`))},onSetEndImageUrl(){let e=this.urls?.[0];this.$store.commit(`kling/setConfig`,{...this.$store.state.kling?.config,end_image_url:e})},async onSuccess(){this.onSetEndImageUrl()}}}),st={class:`relative`},ct={class:`flex justify-between`},lt={class:`flex justify-start items-center`},ut={class:`text-sm font-bold`};function dt(e,t,i,c,l,f){let g=p(`info-icon`),_=p(`image-preview`),v=p(`font-awesome-icon`),y=p(`el-button`),b=p(`el-tooltip`),x=p(`el-upload`);return d(),m(`div`,st,[r(`div`,ct,[r(`div`,lt,[r(`span`,ut,u(e.$t(`kling.name.endImage`)),1),o(g,{content:e.$t(`kling.description.uploadEndImage`)},null,8,[`content`])])]),o(x,{ref:`uploader`,"file-list":e.fileList,"onUpdate:fileList":t[0]||=t=>e.fileList=t,name:`file`,accept:`.png,.jpg,.jpeg,.gif,.bmp,.webp`,limit:1,disabled:e.uploadDisabled,class:`upload-wrapper`,multiple:!1,action:e.uploadUrl,"list-type":`picture`,"before-upload":e.onBeforeUpload,"on-exceed":e.onExceed,"on-error":e.onError,"on-success":e.onSuccess,headers:e.headers},{file:h(({file:t})=>[t.url&&t.percentage!==void 0?(d(),n(_,{key:0,url:t.url,name:t.name,percentage:t.percentage,onRemove:n=>e.fileList.splice(e.fileList.indexOf(t),1)},null,8,[`url`,`name`,`percentage`,`onRemove`])):s(``,!0)]),default:h(()=>[o(b,{content:e.uploadTooltip,disabled:!e.uploadDisabled,placement:`top`},{default:h(()=>[r(`span`,null,[o(y,{round:``,type:`primary`,size:`small`,class:`btn btn-upload`,disabled:e.uploadDisabled},{default:h(()=>[o(v,{icon:`fa-solid fa-upload`,class:`icon mr-1`}),a(` `+u(e.$t(`kling.button.uploadReferences`)),1)]),_:1},8,[`disabled`])])]),_:1},8,[`content`,`disabled`])]),_:1},8,[`file-list`,`disabled`,`action`,`before-upload`,`on-exceed`,`on-error`,`on-success`,`headers`])])}var ft=N(ot,[[`render`,dt],[`__scopeId`,`data-v-c1b257e5`]]),pt=c({name:`CfgScaleSelector`,components:{ElSlider:A,InfoIcon:K,ElInputNumber:ne},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||=0}}),mt={class:`flex justify-between`},ht={class:`flex justify-start items-center`},gt={class:`text-sm font-bold`},_t={class:`flex justify-end items-center`},vt={class:`w-full`};function yt(e,t,n,i,a,s){let c=p(`info-icon`),l=p(`el-input-number`),f=p(`el-slider`);return d(),m(`div`,null,[r(`div`,mt,[r(`div`,ht,[r(`span`,gt,u(e.$t(`kling.name.cfgScale`)),1),o(c,{content:e.$t(`kling.description.cfgScale`)},null,8,[`content`])]),r(`div`,_t,[o(l,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,"controls-position":`right`},null,8,[`modelValue`])])]),r(`div`,vt,[o(f,{modelValue:e.value,"onUpdate:modelValue":t[1]||=t=>e.value=t,min:0,max:1,step:.1},null,8,[`modelValue`])])])}var bt=N(pt,[[`render`,yt]]),xt=c({name:`GenerateAudioSelector`,components:{ElSwitch:j,InfoIcon:K},computed:{selectedModel(){return this.$store.state.kling?.config?.model||``},selectedMode(){return this.$store.state.kling?.config?.mode||``},supported(){return!!(M.includes(this.selectedModel)||this.selectedModel===`kling-v2-6`&&this.selectedMode===`pro`)},tooltipContent(){return this.supported?this.$t(`kling.description.generateAudio`):this.$t(`kling.description.generateAudioUnsupported`)},value:{get(){return this.supported?this.$store.state.kling?.config?.generate_audio??!1:!1},set(e){this.$store.commit(`kling/setConfig`,{...this.$store.state.kling?.config,generate_audio:e})}}},watch:{supported(e){!e&&this.$store.state.kling?.config?.generate_audio&&this.$store.commit(`kling/setConfig`,{...this.$store.state.kling?.config,generate_audio:!1})}}}),St={class:`relative`},Ct={class:`flex justify-between items-center`},wt={class:`flex justify-start items-center`},Tt={class:`text-sm font-bold`};function Et(e,t,n,i,a,s){let c=p(`info-icon`),l=p(`el-switch`);return d(),m(`div`,St,[r(`div`,Ct,[r(`div`,wt,[r(`span`,Tt,u(e.$t(`kling.name.generateAudio`)),1),o(c,{content:e.tooltipContent},null,8,[`content`])]),o(l,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,class:`value`,disabled:!e.supported},null,8,[`modelValue`,`disabled`])])])}var Dt=N(xt,[[`render`,Et]]),Ot=[`horizontal`,`vertical`,`pan`,`tilt`,`roll`,`zoom`],kt=c({name:`CameraControlSelector`,components:{ElSelect:x,ElOption:S,ElSlider:A,ElInputNumber:ne,InfoIcon:K},data(){return{configKeys:Ot}},computed:{typeOptions(){return[{value:``,label:this.$t(`kling.name.cameraTypeNone`)},{value:`simple`,label:this.$t(`kling.name.cameraTypeSimple`)},{value:`down_back`,label:this.$t(`kling.name.cameraTypeDownBack`)},{value:`forward_up`,label:this.$t(`kling.name.cameraTypeForwardUp`)},{value:`left_turn_forward`,label:this.$t(`kling.name.cameraTypeLeftTurnForward`)},{value:`right_turn_forward`,label:this.$t(`kling.name.cameraTypeRightTurnForward`)}]},selectedMode(){return this.$store.state.kling?.config?.mode||``},selectedModel(){return this.$store.state.kling?.config?.model||``},selectedDuration(){return this.$store.state.kling?.config?.duration},motionControlSupported(){return J(this.selectedModel,this.selectedMode,this.selectedDuration).motionControl},hasStartImage(){return!!this.$store.state.kling?.config?.start_image_url},disabled(){return!this.motionControlSupported||this.hasStartImage},tooltipContent(){return this.motionControlSupported?this.hasStartImage?this.$t(`kling.description.cameraControlDisabledImage2Video`):this.$t(`kling.description.cameraControl`):this.$t(`kling.description.cameraControlNotSupported`)},selectedType(){return this.$store.state.kling?.config?.camera_control?.type},selectedTypeRaw:{get(){return this.selectedType??``},set(e){let t=this.$store.state.kling?.config||{};if(!e){let e={...t};delete e.camera_control,this.$store.commit(`kling/setConfig`,e);return}let n=e;this.$store.commit(`kling/setConfig`,{...t,camera_control:{type:n,config:n===`simple`?t.camera_control?.config||{}:void 0}})}},configValues(){return this.$store.state.kling?.config?.camera_control?.config||{}}},watch:{disabled(e){e&&this.selectedType!==void 0&&(this.selectedTypeRaw=``)}},methods:{writeConfig(e,t){let n=this.$store.state.kling?.config||{},r=n.camera_control||{type:`simple`},i={...r.config||{}};t==null?delete i[e]:i[e]=t,this.$store.commit(`kling/setConfig`,{...n,camera_control:{...r,type:`simple`,config:i}})},onSliderChange(e,t){this.writeConfig(e,t)},onNumberChange(e,t){this.writeConfig(e,t)}}}),At={class:`field`},jt={class:`header`},Mt={class:`text-sm font-bold`},Nt={key:0,class:`config-grid`},Pt={class:`cfg-row-head`},Ft={class:`cfg-name`};function It(e,t,i,a,c,f){let g=p(`info-icon`),v=p(`el-option`),y=p(`el-select`),b=p(`el-input-number`),x=p(`el-slider`);return d(),m(`div`,At,[r(`div`,jt,[r(`span`,Mt,u(e.$t(`kling.name.cameraControl`)),1),o(g,{content:e.tooltipContent},null,8,[`content`])]),o(y,{modelValue:e.selectedTypeRaw,"onUpdate:modelValue":t[0]||=t=>e.selectedTypeRaw=t,class:`value`,placeholder:e.$t(`kling.placeholder.cameraType`),clearable:!0,disabled:e.disabled},{default:h(()=>[(d(!0),m(_,null,l(e.typeOptions,e=>(d(),n(v,{key:e.value,label:e.label,value:e.value},null,8,[`label`,`value`]))),128))]),_:1},8,[`modelValue`,`placeholder`,`disabled`]),e.selectedType===`simple`&&!e.disabled?(d(),m(`div`,Nt,[(d(!0),m(_,null,l(e.configKeys,t=>(d(),m(`div`,{key:t,class:`cfg-row`},[r(`div`,Pt,[r(`span`,Ft,u(e.$t(`kling.name.cc_${t}`)),1),o(b,{modelValue:e.configValues[t],"onUpdate:modelValue":n=>e.configValues[t]=n,min:-1,max:1,step:.1,precision:1,"controls-position":`right`,size:`small`,class:`cfg-num`,onChange:n=>e.onNumberChange(t,n)},null,8,[`modelValue`,`onUpdate:modelValue`,`onChange`])]),o(x,{"model-value":e.configValues[t]??0,min:-1,max:1,step:.1,onInput:n=>e.onSliderChange(t,n)},null,8,[`model-value`,`onInput`])]))),128))])):s(``,!0)])}var Lt=N(kt,[[`render`,It],[`__scopeId`,`data-v-cd896060`]]),Rt=[{groupKey:`cameraMovements`,chipKeys:[`rotateAround`,`stationary`,`handheld`,`zoomOut`,`zoomIn`,`follow`,`panRight`,`tiltUp`,`tiltDown`,`orbit`]},{groupKey:`cameraSpeed`,chipKeys:[`speedSlow`,`speedMedium`,`speedFast`]},{groupKey:`shotType`,chipKeys:[`shotClose`,`shotMedium`,`shotLong`,`shotLowAngle`,`shotHighAngle`,`shotShallowDof`,`shotFront`,`shotProfile`,`shotCloseUp`,`shotDrone`]},{groupKey:`light`,chipKeys:[`lightSunlight`,`lightSoft`,`lightNeon`,`lightWarm`,`lightNature`,`lightCandle`,`lightCityNight`]},{groupKey:`frame`,chipKeys:[`frameRichDetails`,`frameSimpleBg`]},{groupKey:`atmosphere`,chipKeys:[`atmosphereMysterious`,`atmospherePeaceful`,`atmosphereHeartwarming`,`atmosphereVivid`,`atmosphereColorful`]}],Z=`, `;function zt(e,t){let n=(e||``).trim();return n?n.includes(t)?n:`${n}${Z}${t}`:t}function Q(e,t){if(!e||!t)return e||``;let n=[`${t}${Z}`,`${Z}${t}`,t],r=e;for(let e of n)if(r.includes(e)){r=r.replace(e,``);break}return r.replace(/(?:,\s*)+$/,``).replace(/^(?:,\s*)+/,``)}var Bt=c({name:`InspirationPills`,components:{FontAwesomeIcon:W},computed:{prompt(){return this.$store.state.kling?.config?.prompt||``},allChipTexts(){return Rt.flatMap(e=>e.chipKeys.map(e=>this.$t(`kling.inspiration.chip.${e}`)))},selected(){let e=this.prompt;if(!e)return[];let t=[];for(let n of this.allChipTexts){let r=e.indexOf(n);r!==-1&&t.push({text:n,idx:r})}return t.sort((e,t)=>e.idx-t.idx).map(e=>e.text)}},methods:{onRemove(e){let t=Q(this.prompt,e);this.$store.commit(`kling/setConfig`,{...this.$store.state.kling?.config,prompt:t})}}}),Vt={key:0,class:`pills`,role:`list`},Ht={class:`pill-text`},Ut=[`aria-label`,`onClick`];function Wt(e,t,n,i,a,c){let f=p(`font-awesome-icon`);return e.selected.length>0?(d(),m(`div`,Vt,[(d(!0),m(_,null,l(e.selected,t=>(d(),m(`div`,{key:t,class:`pill`,role:`listitem`},[r(`span`,Ht,u(t),1),r(`button`,{type:`button`,class:`pill-remove`,"aria-label":e.$t(`kling.inspiration.removeChip`),onClick:v(n=>e.onRemove(t),[`stop`])},[o(f,{icon:`fa-solid fa-xmark`})],8,Ut)]))),128))])):s(``,!0)}var Gt=c({name:`PromptInput`,components:{ElButton:y,FontAwesomeIcon:W,PromptTextarea:me,InspirationPills:N(Bt,[[`render`,Wt],[`__scopeId`,`data-v-5fc4fa65`]])},emits:[`open-inspiration`],computed:{prompt:{get(){return this.$store.state.kling?.config?.prompt},set(e){this.$store.commit(`kling/setConfig`,{...this.$store.state.kling?.config,prompt:e})}}},mounted(){this.prompt||=``}});function Kt(e,t,r,i,s,c){let l=p(`font-awesome-icon`),f=p(`el-button`),m=p(`inspiration-pills`),g=p(`prompt-textarea`);return d(),n(g,{modelValue:e.prompt,"onUpdate:modelValue":t[1]||=t=>e.prompt=t,title:e.$t(`kling.name.prompt`),info:e.$t(`kling.description.prompt`),placeholder:e.$t(`kling.placeholder.prompt`)},{actions:h(()=>[o(f,{text:``,size:`small`,class:`inspiration-btn`,onClick:t[0]||=t=>e.$emit(`open-inspiration`)},{default:h(()=>[o(l,{icon:`fa-regular fa-lightbulb`,class:`mr-1`}),a(` `+u(e.$t(`kling.inspiration.openButton`)),1)]),_:1})]),before:h(()=>[o(m)]),_:1},8,[`modelValue`,`title`,`info`,`placeholder`])}var qt=N(Gt,[[`render`,Kt],[`__scopeId`,`data-v-c01fc1a6`]]),Jt=c({name:`NegativePromptInput`,components:{ElInput:F,InfoIcon:K},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||=``}}),Yt={class:`field`},Xt={class:`box`},Zt={class:`title font-bold`};function Qt(e,t,n,i,a,s){let c=p(`info-icon`),l=p(`el-input`);return d(),m(`div`,Yt,[r(`div`,Xt,[r(`h2`,Zt,u(e.$t(`kling.name.negativePrompt`)),1),o(c,{content:e.$t(`kling.description.negativePrompt`),class:`info`},null,8,[`content`])]),o(l,{modelValue:e.prompt,"onUpdate:modelValue":t[0]||=t=>e.prompt=t,rows:3,type:`textarea`,class:`prompt`,placeholder:e.$t(`kling.placeholder.negativePrompt`)},null,8,[`modelValue`,`placeholder`])])}var $t=N(Jt,[[`render`,Qt],[`__scopeId`,`data-v-de98cf01`]]),en=c({name:`InspirationDrawer`,components:{ElDrawer:te,ElButton:y,FontAwesomeIcon:W},props:{modelValue:{type:Boolean,default:!1}},emits:[`update:modelValue`],data(){return{groups:Rt,Close:b}},computed:{visible:{get(){return this.modelValue},set(e){this.$emit(`update:modelValue`,e)}},drawerSize(){return window.innerWidth<768?`100%`:`380px`},prompt(){return this.$store.state.kling?.config?.prompt||``},allChipTexts(){return this.groups.flatMap(e=>e.chipKeys.map(e=>this.$t(`kling.inspiration.chip.${e}`)))},selectedCount(){return this.allChipTexts.filter(e=>this.isSelected(e)).length}},methods:{chipText(e){return this.$t(`kling.inspiration.chip.${e}`)},isSelected(e){return e?this.prompt.includes(e):!1},setPrompt(e){this.$store.commit(`kling/setConfig`,{...this.$store.state.kling?.config,prompt:e})},onToggle(e){e&&(this.isSelected(e)?this.setPrompt(Q(this.prompt,e)):this.setPrompt(zt(this.prompt,e)))},onClearSelected(){let e=this.prompt;for(let t of this.allChipTexts)for(;e.includes(t);)e=Q(e,t);this.setPrompt(e)}}}),tn={class:`drawer-content`},nn={class:`drawer-header`},rn={class:`title-row`},an={class:`title`},on={class:`hint`},sn={key:0,class:`selected-bar`},cn={class:`selected-text`},ln={class:`groups`},un={class:`group-title`},dn={class:`chip-grid`},fn=[`onClick`];function pn(e,i,c,f,g,v){let y=p(`font-awesome-icon`),b=p(`el-button`),x=p(`el-drawer`);return d(),n(x,{modelValue:e.visible,"onUpdate:modelValue":i[1]||=t=>e.visible=t,direction:`rtl`,"with-header":!1,size:e.drawerSize,"custom-class":`kling-inspiration-drawer`,"destroy-on-close":!1},{default:h(()=>[r(`div`,tn,[r(`div`,nn,[r(`div`,rn,[o(y,{icon:`fa-regular fa-lightbulb`,class:`mr-2`}),r(`span`,an,u(e.$t(`kling.inspiration.title`)),1)]),o(b,{text:``,icon:e.Close,class:`close-btn`,onClick:i[0]||=t=>e.visible=!1},null,8,[`icon`])]),r(`div`,on,u(e.$t(`kling.inspiration.hint`)),1),e.selectedCount>0?(d(),m(`div`,sn,[r(`span`,cn,u(e.$t(`kling.inspiration.selectedSummary`,{count:e.selectedCount})),1),o(b,{text:``,size:`small`,class:`clear-btn`,onClick:e.onClearSelected},{default:h(()=>[a(u(e.$t(`kling.inspiration.clearSelected`)),1)]),_:1},8,[`onClick`])])):s(``,!0),r(`div`,ln,[(d(!0),m(_,null,l(e.groups,n=>(d(),m(`div`,{key:n.groupKey,class:`group`},[r(`div`,un,u(e.$t(`kling.inspiration.group.${n.groupKey}`)),1),r(`div`,dn,[(d(!0),m(_,null,l(n.chipKeys,n=>(d(),m(`button`,{key:n,type:`button`,class:t({chip:!0,active:e.isSelected(e.chipText(n))}),onClick:t=>e.onToggle(e.chipText(n))},u(e.chipText(n)),11,fn))),128))])]))),128))])])]),_:1},8,[`modelValue`,`size`])}var mn=N(en,[[`render`,pn],[`__scopeId`,`data-v-7d457a69`]]),hn={"kling-v3":`v3`,"kling-v3-omni":`v3-Omni`,"kling-v2-6":`v2.6`,"kling-v2-5-turbo":`v2.5-Turbo`,"kling-v2-1-master":`v2.1-Master`,"kling-v2-master":`v2-Master`,"kling-v1-6":`v1.6`,"kling-v1":`v1`,"kling-video-o1":`Video-o1`},gn={std:`720p`,pro:`1080p`,"4k":`4K`},_n=c({name:`SummaryChip`,components:{FontAwesomeIcon:W},computed:{config(){return this.$store.state.kling?.config||{}},modelLabel(){let e=this.config?.model||`kling-v2-5-turbo`;return hn[e]||e},durationLabel(){return`${this.config?.duration??5}s`},aspectRatio(){return this.config?.aspect_ratio||``},modeLabel(){let e=this.config?.mode||`std`;return gn[e]||e},generateAudio(){return!!this.config?.generate_audio}}}),vn={class:`summary-chip`},yn=[`title`],bn=[`title`],xn=[`title`],Sn=[`title`],Cn=[`title`];function wn(e,t,n,i,a,c){let l=p(`font-awesome-icon`);return d(),m(`div`,vn,[r(`span`,{class:`part`,title:e.$t(`kling.name.model`)},u(e.modelLabel),9,yn),t[0]||=r(`span`,{class:`dot`},`·`,-1),r(`span`,{class:`part`,title:e.$t(`kling.name.duration`)},u(e.durationLabel),9,bn),t[1]||=r(`span`,{class:`dot`},`·`,-1),r(`span`,{class:`part`,title:e.$t(`kling.name.ratio`)},u(e.aspectRatio||`16:9`),9,xn),t[2]||=r(`span`,{class:`dot`},`·`,-1),r(`span`,{class:`part`,title:e.$t(`kling.name.mode`)},u(e.modeLabel),9,Sn),e.generateAudio?(d(),m(`span`,{key:0,class:`audio`,title:e.$t(`kling.name.generateAudio`)},[o(l,{icon:`fa-solid fa-headphones`})],8,Cn)):s(``,!0)])}var Tn=c({name:`ConfigPanel`,components:{ElButton:y,Consumption:q,FontAwesomeIcon:W,PromptInput:qt,NegativePromptInput:$t,ModelSelector:ke,ModeSelector:Ie,DurationSelector:Ge,RatioSelector:Qe,StartImage:at,CfgScaleSelector:bt,GenerateAudioSelector:Dt,CameraControlSelector:Lt,InspirationDrawer:mn,SummaryChip:N(_n,[[`render`,wn],[`__scopeId`,`data-v-418a6733`]]),EndImage:ft},emits:[`generate`],data(){return{inspirationOpen:!1}},computed:{config(){return this.$store.state.kling?.config},consumption(){return I(this.config,this.service?.cost)},service(){return this.$store.state.kling?.service}},methods:{onGenerate(){this.$emit(`generate`)}}}),En={class:`flex flex-col h-full`},Dn={class:`flex-1 overflow-y-auto p-5`},On={class:`flex flex-col items-center justify-center px-5 pb-5`};function kn(e,t,i,s,c,l){let f=p(`prompt-input`),g=p(`model-selector`),_=p(`ratio-selector`),v=p(`start-image`),y=p(`end-image`),b=p(`duration-selector`),x=p(`mode-selector`),S=p(`generate-audio-selector`),C=p(`camera-control-selector`),w=p(`cfg-scale-selector`),T=p(`negative-prompt-input`),E=p(`summary-chip`),D=p(`consumption`),O=p(`font-awesome-icon`),k=p(`el-button`),ee=p(`inspiration-drawer`);return d(),m(`div`,En,[r(`div`,Dn,[o(f,{class:`mb-4`,onOpenInspiration:t[0]||=t=>e.inspirationOpen=!0}),o(g,{class:`mb-4`}),o(_,{class:`mb-4`}),o(v,{class:`mb-2`}),o(y,{class:`mb-2`}),o(b,{class:`mb-4`}),o(x,{class:`mb-4`}),o(S,{class:`mb-4`}),o(C,{class:`mb-4`}),o(w,{class:`mb-4`}),o(T,{class:`mb-4`})]),r(`div`,On,[o(E),o(D,{value:e.consumption,service:e.service},null,8,[`value`,`service`]),e.config?.video_url!==void 0||e.config?.custom?(d(),n(k,{key:0,type:`primary`,class:`btn w-full`,round:``,onClick:e.onGenerate},{default:h(()=>[o(O,{icon:`fa-solid fa-magic`,class:`mr-2`}),a(` `+u(e.$t(`kling.button.extend`)),1)]),_:1},8,[`onClick`])):(d(),n(k,{key:1,type:`primary`,class:`btn w-full`,round:``,onClick:e.onGenerate},{default:h(()=>[o(O,{icon:`fa-solid fa-magic`,class:`mr-2`}),a(` `+u(e.$t(`kling.button.generate`)),1)]),_:1},8,[`onClick`]))]),o(ee,{modelValue:e.inspirationOpen,"onUpdate:modelValue":t[1]||=t=>e.inspirationOpen=t},null,8,[`modelValue`])])}var An=N(Tn,[[`render`,kn]]),jn=c({name:`MotionImage`,components:{ElUpload:T,ElButton:y,InfoIcon:K,FontAwesomeIcon:W,ImagePreview:G},mixins:[B,H],data(){return{fileList:[],uploadUrl:z()+`/api/v1/files/`}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e?.response?.file_url)}},mounted(){this.onSetImageUrl()},methods:{onExceed(){V.warning(this.$t(`kling.message.uploadReferencesExceed`))},onError(){V.error(this.$t(`kling.message.uploadReferencesError`))},onRemove(e){this.fileList.splice(this.fileList.indexOf(e),1),this.$store.commit(`kling/setMotionConfig`,{...this.$store.state.kling?.motionConfig,image_url:void 0})},onSetImageUrl(){let e=this.urls?.[0];this.$store.commit(`kling/setMotionConfig`,{...this.$store.state.kling?.motionConfig,image_url:e})},async onSuccess(){this.onSetImageUrl()}}}),Mn={class:`relative`},Nn={class:`flex justify-between`},Pn={class:`flex justify-start items-center`},Fn={class:`text-sm font-bold`};function In(e,t,i,c,l,f){let g=p(`info-icon`),_=p(`image-preview`),v=p(`font-awesome-icon`),y=p(`el-button`),b=p(`el-upload`);return d(),m(`div`,Mn,[r(`div`,Nn,[r(`div`,Pn,[r(`span`,Fn,u(e.$t(`kling.name.motionImage`)),1),o(g,{content:e.$t(`kling.description.motionImage`)},null,8,[`content`])])]),o(b,{ref:`uploader`,"file-list":e.fileList,"onUpdate:fileList":t[0]||=t=>e.fileList=t,name:`file`,accept:`.png,.jpg,.jpeg,.gif,.bmp,.webp`,limit:1,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:h(({file:t})=>[t.url&&t.percentage!==void 0?(d(),n(_,{key:0,url:t.url,name:t.name,percentage:t.percentage,onRemove:n=>e.onRemove(t)},null,8,[`url`,`name`,`percentage`,`onRemove`])):s(``,!0)]),default:h(()=>[o(y,{round:``,type:`primary`,size:`small`,class:`btn btn-upload`},{default:h(()=>[o(v,{icon:`fa-solid fa-upload`,class:`icon mr-1`}),a(` `+u(e.$t(`kling.button.uploadReferences`)),1)]),_:1})]),_:1},8,[`file-list`,`action`,`on-exceed`,`on-error`,`on-success`,`headers`])])}var Ln=N(jn,[[`render`,In],[`__scopeId`,`data-v-e52eaf2f`]]),Rn=c({name:`MotionVideo`,components:{ElUpload:T,ElButton:y,InfoIcon:K,FilePreview:le,FontAwesomeIcon:W},mixins:[H],data(){return{fileList:[],uploadUrl:z()+`/api/v1/files/`}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e?.response?.file_url)}},mounted(){this.onSetVideoUrl()},methods:{onExceed(){V.warning(this.$t(`kling.message.uploadVideoExceed`))},onError(){V.error(this.$t(`kling.message.uploadVideoError`))},onRemove(e){this.fileList.splice(this.fileList.indexOf(e),1),this.$store.commit(`kling/setMotionConfig`,{...this.$store.state.kling?.motionConfig,video_url:void 0})},beforeUpload(e){let t=e.type===`video/mp4`||e.type===`video/quicktime`,n=e.size/1024/1024<100;return t?n?!0:(V.error(this.$t(`kling.message.uploadVideoSizeExceed`)),!1):(V.error(this.$t(`kling.message.uploadVideoTypeFailed`)),!1)},onSetVideoUrl(){let e=this.urls?.[0];this.$store.commit(`kling/setMotionConfig`,{...this.$store.state.kling?.motionConfig,video_url:e})},async onSuccess(){this.onSetVideoUrl()}}}),zn={class:`relative`},Bn={class:`flex justify-between`},Vn={class:`flex justify-start items-center`},Hn={class:`text-sm font-bold`};function Un(e,t,i,c,l,f){let g=p(`info-icon`),_=p(`file-preview`),v=p(`font-awesome-icon`),y=p(`el-button`),b=p(`el-upload`);return d(),m(`div`,zn,[r(`div`,Bn,[r(`div`,Vn,[r(`span`,Hn,u(e.$t(`kling.name.motionVideo`)),1),o(g,{content:e.$t(`kling.description.motionVideo`)},null,8,[`content`])])]),o(b,{"file-list":e.fileList,"onUpdate:fileList":t[0]||=t=>e.fileList=t,accept:`.mp4,.mov`,name:`file`,class:`value`,"show-file-list":!0,limit:1,multiple:!1,action:e.uploadUrl,"before-upload":e.beforeUpload,"on-exceed":e.onExceed,"on-error":e.onError,"on-success":e.onSuccess,headers:e.headers},{file:h(({file:t})=>[t.percentage===void 0?s(``,!0):(d(),n(_,{key:0,url:t.url||t.response?.file_url,name:t.name,percentage:t.percentage,onRemove:n=>e.onRemove(t)},null,8,[`url`,`name`,`percentage`,`onRemove`]))]),default:h(()=>[o(y,{round:``,type:`primary`,size:`small`,class:`btn btn-upload`},{default:h(()=>[o(v,{icon:`fa-solid fa-upload`,class:`icon mr-1`}),a(` `+u(e.$t(`kling.button.uploadVideoUrl`)),1)]),_:1})]),_:1},8,[`file-list`,`action`,`before-upload`,`on-exceed`,`on-error`,`on-success`,`headers`])])}var Wn=N(Rn,[[`render`,Un],[`__scopeId`,`data-v-7019a8d2`]]),Gn=c({name:`MotionPromptInput`,components:{ElInput:F,InfoIcon:K},computed:{prompt:{get(){return this.$store.state.kling?.motionConfig?.prompt||``},set(e){this.$store.commit(`kling/setMotionConfig`,{...this.$store.state.kling?.motionConfig,prompt:e})}}}}),Kn={class:`field`},qn={class:`box`},Jn={class:`title font-bold`};function Yn(e,t,n,i,a,s){let c=p(`info-icon`),l=p(`el-input`);return d(),m(`div`,Kn,[r(`div`,qn,[r(`h2`,Jn,u(e.$t(`kling.name.motionPrompt`)),1),o(c,{content:e.$t(`kling.description.motionPrompt`),class:`info`},null,8,[`content`])]),o(l,{modelValue:e.prompt,"onUpdate:modelValue":t[0]||=t=>e.prompt=t,rows:3,type:`textarea`,class:`prompt`,placeholder:e.$t(`kling.placeholder.motionPrompt`)},null,8,[`modelValue`,`placeholder`])])}var Xn=N(Gn,[[`render`,Yn],[`__scopeId`,`data-v-ca9fdbe5`]]),Zn=`video`,Qn=c({name:`CharacterOrientationSelector`,components:{ElRadioGroup:ee,ElRadioButton:k,InfoIcon:K},computed:{value:{get(){return this.$store.state.kling?.motionConfig?.character_orientation||Zn},set(e){this.$store.commit(`kling/setMotionConfig`,{...this.$store.state.kling?.motionConfig,character_orientation:e})}}},mounted(){this.$store.state.kling?.motionConfig?.character_orientation||(this.value=Zn)}}),$n={class:`field`},er={class:`header`},tr={class:`text-sm font-bold`};function nr(e,t,n,i,s,c){let l=p(`info-icon`),f=p(`el-radio-button`),g=p(`el-radio-group`);return d(),m(`div`,$n,[r(`div`,er,[r(`span`,tr,u(e.$t(`kling.name.characterOrientation`)),1),o(l,{content:e.$t(`kling.description.characterOrientation`)},null,8,[`content`])]),o(g,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,size:`small`,class:`value`},{default:h(()=>[o(f,{label:`image`},{default:h(()=>[a(u(e.$t(`kling.name.orientationImage`)),1)]),_:1}),o(f,{label:`video`},{default:h(()=>[a(u(e.$t(`kling.name.orientationVideo`)),1)]),_:1})]),_:1},8,[`modelValue`])])}var rr=N(Qn,[[`render`,nr],[`__scopeId`,`data-v-7a91195b`]]),ir=`std`,ar=c({name:`MotionModeSelector`,components:{ElSelect:x,ElOption:S,InfoIcon:K},computed:{options(){return[{value:`std`,label:this.$t(`kling.name.modeStd`)},{value:`pro`,label:this.$t(`kling.name.modePro`)}]},value:{get(){return this.$store.state.kling?.motionConfig?.mode||ir},set(e){this.$store.commit(`kling/setMotionConfig`,{...this.$store.state.kling?.motionConfig,mode:e})}}},mounted(){this.$store.state.kling?.motionConfig?.mode||(this.value=ir)}}),or={class:`field`},sr={class:`header`},cr={class:`title font-bold`};function lr(e,t,i,a,s,c){let f=p(`info-icon`),g=p(`el-option`),v=p(`el-select`);return d(),m(`div`,or,[r(`div`,sr,[r(`h2`,cr,u(e.$t(`kling.name.mode`)),1),o(f,{content:e.$t(`kling.description.motionMode`)},null,8,[`content`])]),o(v,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,class:`value`,placeholder:e.$t(`kling.placeholder.select`)},{default:h(()=>[(d(!0),m(_,null,l(e.options,e=>(d(),n(g,{key:e.value,label:e.label,value:e.value},null,8,[`label`,`value`]))),128))]),_:1},8,[`modelValue`,`placeholder`])])}var ur=N(ar,[[`render`,lr],[`__scopeId`,`data-v-1295688c`]]),dr=c({name:`KeepOriginalSoundSelector`,components:{ElSwitch:j,InfoIcon:K},computed:{value:{get(){return(this.$store.state.kling?.motionConfig?.keep_original_sound??`yes`)===`yes`},set(e){this.$store.commit(`kling/setMotionConfig`,{...this.$store.state.kling?.motionConfig,keep_original_sound:e?`yes`:`no`})}}}}),fr={class:`relative`},pr={class:`flex justify-between items-center`},mr={class:`flex justify-start items-center`},hr={class:`text-sm font-bold`};function gr(e,t,n,i,a,s){let c=p(`info-icon`),l=p(`el-switch`);return d(),m(`div`,fr,[r(`div`,pr,[r(`div`,mr,[r(`span`,hr,u(e.$t(`kling.name.keepOriginalSound`)),1),o(c,{content:e.$t(`kling.description.keepOriginalSound`)},null,8,[`content`])]),o(l,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t},null,8,[`modelValue`])])])}var _r=c({name:`MotionPanel`,components:{ElButton:y,FontAwesomeIcon:W,Consumption:q,MotionImage:Ln,MotionVideo:Wn,MotionPromptInput:Xn,CharacterOrientationSelector:rr,MotionModeSelector:ur,KeepOriginalSoundSelector:N(dr,[[`render`,gr]])},emits:[`generate`],computed:{motionConfig(){return this.$store.state.kling?.motionConfig},consumption(){return I(this.motionConfig,this.service?.cost)},service(){return this.$store.state.kling?.service},canGenerate(){let e=this.motionConfig;return!!(e?.image_url&&e?.video_url)}},methods:{onGenerate(){this.$emit(`generate`)}}}),vr={class:`flex flex-col h-full`},yr={class:`flex-1 overflow-y-auto p-5`},br={class:`flex flex-col items-center justify-center px-5 pb-5`};function xr(e,t,n,i,s,c){let l=p(`motion-image`),f=p(`motion-video`),g=p(`motion-prompt-input`),_=p(`character-orientation-selector`),v=p(`motion-mode-selector`),y=p(`keep-original-sound-selector`),b=p(`consumption`),x=p(`font-awesome-icon`),S=p(`el-button`);return d(),m(`div`,vr,[r(`div`,yr,[o(l,{class:`mb-3`}),o(f,{class:`mb-3`}),o(g,{class:`mb-4`}),o(_,{class:`mb-4`}),o(v,{class:`mb-4`}),o(y,{class:`mb-4`})]),r(`div`,br,[o(b,{value:e.consumption,service:e.service},null,8,[`value`,`service`]),o(S,{type:`primary`,class:`btn w-full`,round:``,disabled:!e.canGenerate,onClick:e.onGenerate},{default:h(()=>[o(x,{icon:`fa-solid fa-magic`,class:`mr-2`}),a(` `+u(e.$t(`kling.button.generateMotion`)),1)]),_:1},8,[`disabled`,`onClick`])])])}var Sr=N(_r,[[`render`,xr]]),Cr=c({name:`KlingTabSwitcher`,components:{ElTabs:C,ElTabPane:w,ElTag:oe},props:{modelValue:{type:String,default:`videos`}},emits:[`update:modelValue`],computed:{tabs(){return[{value:`videos`,label:this.$t(`kling.tab.videoGeneration`)},{value:`motion`,label:this.$t(`kling.tab.motionControl`)},{value:`talking-photo`,label:this.$t(`kling.tab.talkingPhoto`)}]}},methods:{onUpdate(e){this.$emit(`update:modelValue`,e)}}}),wr=[`title`],Tr={class:`text`};function Er(e,t,i,o,c,f){let g=p(`el-tag`),v=p(`el-tab-pane`),y=p(`el-tabs`);return d(),n(y,{"model-value":e.modelValue,class:`kling-tabs`,stretch:``,"onUpdate:modelValue":e.onUpdate},{default:h(()=>[(d(!0),m(_,null,l(e.tabs,e=>(d(),n(v,{key:e.value,name:e.value,disabled:e.disabled},{label:h(()=>[r(`span`,{class:`tab-label`,title:e.disabled?e.disabledReason:void 0},[r(`span`,Tr,u(e.label),1),e.badge?(d(),n(g,{key:0,size:`small`,type:`warning`,class:`badge`},{default:h(()=>[a(u(e.badge),1)]),_:2},1024)):s(``,!0)],8,wr)]),_:2},1032,[`name`,`disabled`]))),128))]),_:1},8,[`model-value`,`onUpdate:modelValue`])}var Dr=N(Cr,[[`render`,Er],[`__scopeId`,`data-v-fda33e4c`]]),Or=c({name:`TalkingPhotoPanel`,components:{ElUpload:T,ElButton:y,ElInput:F,FontAwesomeIcon:W,Consumption:q,InfoIcon:K,ImagePreview:G},mixins:[H],emits:[`generate`],data(){return{imageFiles:[],audioFiles:[],uploadUrl:z()+`/api/v1/files/`}},computed:{config(){return this.$store.state.kling?.talkingPhotoConfig||{}},audioUrl(){return this.config.audio_url},headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},service(){return this.$store.state.kling?.service},consumption(){return I({...this.config,action:`talking-photo`},this.service?.cost)},canGenerate(){return!!(this.config.image_url&&this.config.audio_url)}},methods:{commit(e){this.$store.commit(`kling/setTalkingPhotoConfig`,{...this.config,...e})},onPromptChange(e){this.commit({prompt:e})},onImageExceed(){V.warning(this.$t(`kling.message.uploadReferencesExceed`))},onImageError(){V.error(this.$t(`kling.message.uploadReferencesError`))},onImageSuccess(e){this.commit({image_url:e?.file_url})},onImageRemove(e){this.imageFiles.splice(this.imageFiles.indexOf(e),1),this.commit({image_url:void 0})},onAudioExceed(){V.warning(this.$t(`kling.message.uploadAudioExceed`))},onAudioError(){V.error(this.$t(`kling.message.uploadAudioError`))},onAudioSuccess(e){this.commit({audio_url:e?.file_url})},onAudioRemove(){this.commit({audio_url:void 0})},onGenerate(){this.$emit(`generate`)}}}),kr={class:`flex flex-col h-full`},Ar={class:`flex-1 overflow-y-auto p-5`},jr={class:`relative mb-4`},Mr={class:`flex justify-start items-center`},Nr={class:`text-sm font-bold`},Pr={class:`relative mb-4`},Fr={class:`flex justify-start items-center`},Ir={class:`text-sm font-bold`},Lr=[`src`],Rr={class:`mb-4`},zr={class:`flex justify-start items-center`},Br={class:`text-sm font-bold`},Vr={class:`flex flex-col items-center justify-center px-5 pb-5`};function Hr(e,t,i,c,l,f){let g=p(`info-icon`),_=p(`image-preview`),v=p(`font-awesome-icon`),y=p(`el-button`),b=p(`el-upload`),x=p(`el-input`),S=p(`consumption`);return d(),m(`div`,kr,[r(`div`,Ar,[r(`div`,jr,[r(`div`,Mr,[r(`span`,Nr,u(e.$t(`kling.name.talkingPhotoImage`)),1),o(g,{content:e.$t(`kling.description.talkingPhotoImage`)},null,8,[`content`])]),o(b,{ref:`imageUploader`,"file-list":e.imageFiles,"onUpdate:fileList":t[0]||=t=>e.imageFiles=t,name:`file`,accept:`.png,.jpg,.jpeg,.webp,.bmp`,limit:1,class:`upload-wrapper`,multiple:!1,action:e.uploadUrl,"list-type":`picture`,headers:e.headers,"on-exceed":e.onImageExceed,"on-error":e.onImageError,"on-success":e.onImageSuccess},{file:h(({file:t})=>[t.url&&t.percentage!==void 0?(d(),n(_,{key:0,url:t.url,name:t.name,percentage:t.percentage,onRemove:n=>e.onImageRemove(t)},null,8,[`url`,`name`,`percentage`,`onRemove`])):s(``,!0)]),default:h(()=>[o(y,{round:``,type:`primary`,size:`small`,class:`btn btn-upload`},{default:h(()=>[o(v,{icon:`fa-solid fa-upload`,class:`icon mr-1`}),a(` `+u(e.$t(`kling.button.uploadReferences`)),1)]),_:1})]),_:1},8,[`file-list`,`action`,`headers`,`on-exceed`,`on-error`,`on-success`])]),r(`div`,Pr,[r(`div`,Fr,[r(`span`,Ir,u(e.$t(`kling.name.talkingPhotoAudio`)),1),o(g,{content:e.$t(`kling.description.talkingPhotoAudio`)},null,8,[`content`])]),o(b,{ref:`audioUploader`,"file-list":e.audioFiles,"onUpdate:fileList":t[1]||=t=>e.audioFiles=t,name:`file`,accept:`.mp3,.wav,.m4a,.aac`,limit:1,class:`upload-wrapper`,multiple:!1,action:e.uploadUrl,headers:e.headers,"on-exceed":e.onAudioExceed,"on-error":e.onAudioError,"on-success":e.onAudioSuccess,"on-remove":e.onAudioRemove},{default:h(()=>[o(y,{round:``,type:`primary`,size:`small`,class:`btn`},{default:h(()=>[o(v,{icon:`fa-solid fa-upload`,class:`icon mr-1`}),a(` `+u(e.$t(`kling.button.uploadAudio`)),1)]),_:1})]),_:1},8,[`file-list`,`action`,`headers`,`on-exceed`,`on-error`,`on-success`,`on-remove`]),e.audioUrl?(d(),m(`audio`,{key:0,src:e.audioUrl,controls:``,class:`w-full mt-2`},null,8,Lr)):s(``,!0)]),r(`div`,Rr,[r(`div`,zr,[r(`span`,Br,u(e.$t(`kling.name.talkingPhotoPrompt`)),1),o(g,{content:e.$t(`kling.description.talkingPhotoPrompt`)},null,8,[`content`])]),o(x,{"model-value":e.config.prompt,type:`textarea`,rows:2,placeholder:e.$t(`kling.placeholder.talkingPhotoPrompt`),class:`mt-1`,"onUpdate:modelValue":e.onPromptChange},null,8,[`model-value`,`placeholder`,`onUpdate:modelValue`])])]),r(`div`,Vr,[o(S,{value:e.consumption,service:e.service},null,8,[`value`,`service`]),o(y,{type:`primary`,class:`btn w-full`,round:``,disabled:!e.canGenerate,onClick:e.onGenerate},{default:h(()=>[o(v,{icon:`fa-solid fa-magic`,class:`mr-2`}),a(` `+u(e.$t(`kling.button.generateTalkingPhoto`)),1)]),_:1},8,[`disabled`,`onClick`])])])}var Ur=N(Or,[[`render`,Hr],[`__scopeId`,`data-v-a3aa5a3a`]]),Wr=c({name:`TaskPreview`,components:{ElImage:D,CopyToClipboard:ce,FontAwesomeIcon:W,ElAlert:O,VideoPlayer:_e,ElTooltip:E,ElButton:y,ImagePreview:G,ApiCodeButton:ge},props:{modelValue:{type:Object,required:!0}},data(){return{}},computed:{application(){return this.$store.state.kling?.application},config(){return this.$store.state.kling?.config},referenceImages(){let e=[],t=this.modelValue?.request?.start_image_url,n=this.modelValue?.request?.end_image_url;return t&&e.push({url:t,name:`start-image`}),n&&e.push({url:n,name:`end-image`}),e}},methods:{onDownload(e,t){e?.stopPropagation(),console.log(`on download`),window.open(t,`_blank`)},onOpenVideo(e){window.open(e,`_blank`)}}}),Gr={class:`preview`},Kr={class:`left`},qr={class:`main`},Jr={class:`bot`},Yr={class:`datetime`},Xr={class:`info`},Zr={key:0,class:`flex justify-start items-center gap-2 mt-2 w-full overflow-x-auto`},Qr={key:1,class:`prompt mt-2`},$r={key:0},ei={key:1},ti={key:0,class:t({content:!0,failed:!0})},ni={key:0,class:`mb-4`},ri={key:1,class:t({operations:!0,"mt-2":!0})},ii={class:`text-[var(--el-text-color-regular)] text-xs mb-2`},ai={class:`text-[var(--el-text-color-regular)] text-xs mb-2`},oi={key:0,class:`text-[var(--el-text-color-regular)] text-xs mb-0`},si={key:1,class:t({content:!0})},ci={class:`text-[var(--el-text-color-regular)] text-xs mb-2`},li={class:`text-[var(--el-text-color-regular)] text-xs mb-2`},ui={key:0,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},di={key:1,class:`text-[var(--el-text-color-regular)] text-xs mb-0`},fi={key:2,class:t({content:!0})},pi={class:`text-[var(--el-text-color-regular)] text-xs mb-2`},mi={key:0,class:`text-[var(--el-text-color-regular)] text-xs mb-0`};function hi(e,t,i,c,f,g){let v=p(`el-image`),y=p(`image-preview`),b=p(`video-player`),x=p(`el-button`),S=p(`el-tooltip`),C=p(`api-code-button`),w=p(`font-awesome-icon`),T=p(`copy-to-clipboard`),E=p(`el-alert`);return d(),m(`div`,Gr,[r(`div`,Kr,[o(v,{src:`https://cdn.acedata.cloud/qpbbbb.jpg`,class:`avatar`})]),r(`div`,qr,[r(`div`,Jr,[a(u(e.$t(`kling.name.klingBot`))+` `,1),r(`span`,Yr,u(e.$dayjs.format(``+new Date(parseFloat((e.modelValue?.created_at||``).toString())*1e3))),1)]),r(`div`,Xr,[e.referenceImages.length>0?(d(),m(`div`,Zr,[(d(!0),m(_,null,l(e.referenceImages,(e,t)=>(d(),n(y,{key:t,url:e.url,name:e.name,closable:!1},null,8,[`url`,`name`]))),128))])):s(``,!0),e.modelValue?.request?.prompt?(d(),m(`p`,Qr,[a(u(e.modelValue?.request?.prompt)+` `,1),e.modelValue?.response?s(``,!0):(d(),m(`span`,$r,` - (`+u(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`?(d(),m(`span`,ei,` - (`+u(e.$t(`kling.status.processing`))+`) `,1)):s(``,!0)])):s(``,!0)]),e.modelValue?.response?.success===!0?(d(),m(`div`,ti,[e.modelValue?.response.video_url?(d(),m(`div`,ni,[o(b,{src:e.modelValue?.response.video_url},null,8,[`src`])])):s(``,!0),e.modelValue?.response.success?(d(),m(`div`,ri,[o(S,{class:`box-item`,effect:`dark`,content:e.$t(`kling.message.downloadVideo`),placement:`top-start`},{default:h(()=>[e.modelValue?.response.video_url?(d(),n(x,{key:0,type:`info`,size:`small`,class:`btn-action`,onClick:t[0]||=t=>e.onDownload(t,e.modelValue?.response.video_url)},{default:h(()=>[a(u(e.$t(`kling.button.download`)),1)]),_:1})):s(``,!0)]),_:1},8,[`content`]),o(C,{path:`/kling/videos`,body:e.modelValue?.request},null,8,[`body`])])):s(``,!0),o(E,{closable:!1,class:`mt-2 success`},{default:h(()=>[r(`p`,ii,[o(w,{icon:`fa-solid fa-hashtag`,class:`mr-1`}),a(` `+u(e.$t(`kling.name.model`))+`: `+u(e.modelValue?.request?.model),1)]),r(`p`,ai,[o(w,{icon:`fa-solid fa-magic`,class:`mr-1`}),a(` `+u(e.$t(`kling.name.taskId`))+`: `+u(e.modelValue?.id)+` `,1),o(T,{content:e.modelValue?.id},null,8,[`content`])]),e.modelValue?.elapsed?(d(),m(`p`,oi,[o(w,{icon:`fa-solid fa-clock`,class:`mr-1`}),a(` `+u(e.$t(`kling.name.elapsed`))+`: `+u(e.modelValue?.elapsed?.toFixed(2))+`s `,1)])):s(``,!0)]),_:1})])):s(``,!0),e.modelValue?.response?.success===!1?(d(),m(`div`,si,[o(E,{closable:!1,class:`failure`},{template:h(()=>[o(w,{icon:`fa-solid fa-exclamation-triangle`,class:`mr-1`}),a(` `+u(e.$t(`kling.name.failure`)),1)]),default:h(()=>[r(`p`,ci,[o(w,{icon:`fa-solid fa-magic`,class:`mr-1`}),a(` `+u(e.$t(`kling.name.taskId`))+`: `+u(e.modelValue?.id)+` `,1),o(T,{content:e.modelValue?.id},null,8,[`content`])]),r(`p`,li,[o(w,{icon:`fa-solid fa-circle-info`,class:`mr-1`}),a(` `+u(e.$t(`kling.name.failureReason`))+`: `+u(e.modelValue?.response?.error?.message)+` `,1),o(T,{content:e.modelValue?.response?.error?.message},null,8,[`content`])]),e.modelValue?.elapsed?(d(),m(`p`,ui,[o(w,{icon:`fa-solid fa-clock`,class:`mr-1`}),a(` `+u(e.$t(`kling.name.elapsed`))+`: `+u(e.modelValue?.elapsed?.toFixed(2))+`s `,1)])):s(``,!0),e.modelValue?.response?.trace_id?(d(),m(`p`,di,[o(w,{icon:`fa-solid fa-hashtag`,class:`mr-1`}),a(` `+u(e.$t(`kling.name.traceId`))+`: `+u(e.modelValue?.response?.trace_id)+` `,1),o(T,{content:e.modelValue?.response?.trace_id},null,8,[`content`])])):s(``,!0)]),_:1})])):s(``,!0),e.modelValue?.response?.success===void 0?(d(),m(`div`,fi,[o(E,{closable:!1,class:`info`},{template:h(()=>[o(w,{icon:`fa-solid fa-exclamation-triangle`,class:`mr-1`}),a(` `+u(e.$t(`kling.name.failure`)),1)]),default:h(()=>[r(`p`,pi,[o(w,{icon:`fa-solid fa-magic`,class:`mr-1`}),a(` `+u(e.$t(`kling.name.taskId`))+`: `+u(e.modelValue?.id)+` `,1),o(T,{content:e.modelValue?.id},null,8,[`content`])]),e.modelValue?.response?.trace_id?(d(),m(`p`,mi,[o(w,{icon:`fa-solid fa-hashtag`,class:`mr-1`}),a(` `+u(e.$t(`kling.name.traceId`))+`: `+u(e.modelValue?.response?.trace_id)+` `,1),o(T,{content:e.modelValue?.response?.trace_id},null,8,[`content`])])):s(``,!0)]),_:1})])):s(``,!0)])])}var gi=c({name:`RecentPanel`,components:{TaskPreview:N(Wr,[[`render`,hi],[`__scopeId`,`data-v-c36bfd7f`]]),NoTasks:he,BotPlaceholder:de,ScrollList:fe},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?.()}}}),_i={key:0},vi={key:2,class:`w-full h-full flex items-center justify-center`};function yi(e,t,r,i,a,c){let u=p(`bot-placeholder`),f=p(`task-preview`),g=p(`scroll-list`),v=p(`no-tasks`);return d(),m(_,null,[e.tasks?.items===void 0?(d(),m(`div`,_i,[o(u)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(d(),n(g,{key:1,ref:`scrollList`,class:`h-full w-full overflow-y-auto tasks`,loading:e.loading,onReachTop:t[0]||=t=>e.$emit(`reach-top`)},{default:h(()=>[(d(!0),m(_,null,l(e.tasks?.items,e=>(d(),n(f,{key:e.id,"model-value":e},null,8,[`model-value`]))),128))]),_:1},8,[`loading`])):s(``,!0),e.tasks?.items?.length===0?(d(),m(`div`,vi,[o(v)])):s(``,!0)],64)}var bi=N(gi,[[`render`,yi]]),$=re(`kling`),xi=c({name:`KlingIndex`,components:{ConfigPanel:An,MotionPanel:Sr,TalkingPhotoPanel:Ur,TabSwitcher:Dr,Layout:Ce,RecentPanel:bi},mixins:[ae],inject:[`initialized`],data(){return{task:void 0,job:0,loadingMore:!1,fetchingTasks:!1}},computed:{applicationsLoading(){return this.$store.state.kling?.status?.getApplications===se.Request},tasksLoading(){return this.$store.state.kling?.status?.getTasks===se.Request||this.fetchingTasks},credential(){return this.$store.state.kling.credential},config(){return this.$store.state.kling.config},motionConfig(){return this.$store.state.kling.motionConfig},talkingPhotoConfig(){return this.$store.state.kling.talkingPhotoConfig},taskType(){return this.$store.state.kling.taskType||`videos`},tasks(){return this.$store.state.kling.tasks}},watch:{tasks:{handler(e,t){e?.items?.length>t?.items?.length&&console.debug(`new tasks detected`)},deep:!0},initialized:{async handler(e){e&&(console.debug(`layout initialized`),await this.onGetTasks(),await this.onScrollDown(),this.job=window.setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){window.clearInterval(this.job)},methods:{async onReachTop(){await 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();let e=this.getTasksScrollElement();e&&(e.scrollTop=e.scrollHeight)},async onGetTasks(e){if(this.applicationsLoading||this.fetchingTasks){console.debug(`loading`);return}console.debug(`start onGetTasks`,e);let{limit:t=5,createdAtMin:n,createdAtMax:r}=e||{};console.debug(`limit`,t,`createdAtMin`,n,`createdAtMax`,r),this.fetchingTasks=!0;try{await this.$store.dispatch(`kling/getTasks`,{limit:t,createdAtMin:n,createdAtMax:r})}finally{this.fetchingTasks=!1}},async onGenerate(){if(!R(this.uploadTracker,e=>this.$t(e),e=>V.warning(e)))return;let{camera_control:e,...t}=this.config||{},n={...t,callback_url:$};if(!n.video_id&&!t.video_url&&!n.start_image_url&&n.end_image_url){V.warning(this.$t(`kling.message.endImageRequiresStart`));return}n.action||(n.video_id||t.video_url?n.action=`extend`:n.start_image_url?n.action=`image2video`:n.action=`text2video`),n.action===`text2video`&&n.end_image_url&&delete n.end_image_url,e?.type&&(n.camera_control={type:e.type,...e.type===`simple`&&e.config?{config:Object.fromEntries(Object.entries(e.config).filter(([,e])=>e!=null))}:{}});let r=this.credential?.token;if(!r){console.error(`no token specified`);return}V.info(this.$t(`kling.message.startingTask`)),P(`kling`,U.generate(n,{token:r})).then(()=>{V.success(this.$t(`kling.message.startTaskSuccess`))}).catch(e=>{(e?.response?.data)?.error?.code===`used_up`?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?.()},async onTabChange(e){e!==this.taskType&&(await this.$store.dispatch(`kling/setTaskType`,e),await this.onGetTasks(),await this.onScrollDown())},async onGenerateMotion(){if(!R(this.uploadTracker,e=>this.$t(e),e=>V.warning(e)))return;let e=this.motionConfig||{};if(!e.image_url||!e.video_url){V.warning(this.$t(`kling.message.motionMissingInputs`));return}let t={image_url:e.image_url,video_url:e.video_url,character_orientation:e.character_orientation||`video`,mode:e.mode||`std`,keep_original_sound:e.keep_original_sound??`yes`,...e.prompt?{prompt:e.prompt}:{},callback_url:$},n=this.credential?.token;if(!n){console.error(`no token specified`);return}V.info(this.$t(`kling.message.startingTask`)),P(`kling`,U.motion(t,{token:n})).then(()=>{V.success(this.$t(`kling.message.startTaskSuccess`))}).catch(e=>{(e?.response?.data)?.error?.code===`used_up`?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)})},async onGenerateTalkingPhoto(){if(!R(this.uploadTracker,e=>this.$t(e),e=>V.warning(e)))return;let e=this.talkingPhotoConfig||{};if(!e.image_url||!e.audio_url){V.warning(this.$t(`kling.message.talkingPhotoMissingInputs`));return}let t={image_url:e.image_url,audio_url:e.audio_url,...e.prompt?{prompt:e.prompt}:{},...e.model?{model:e.model}:{},...e.duration?{duration:e.duration}:{},...e.mode?{mode:e.mode}:{},callback_url:$},n=this.credential?.token;if(!n){console.error(`no token specified`);return}V.info(this.$t(`kling.message.startingTask`)),P(`kling`,U.talkingPhoto(t,{token:n})).then(()=>{V.success(this.$t(`kling.message.startTaskSuccess`))}).catch(e=>{(e?.response?.data)?.error?.code===`used_up`?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)})}}}),Si={class:`flex flex-col h-full`},Ci={class:`flex-1 min-h-0`};function wi(e,t,i,a,c,l){let u=p(`tab-switcher`),f=p(`config-panel`),m=p(`motion-panel`),g=p(`talking-photo-panel`),_=p(`recent-panel`),v=p(`layout`);return d(),n(v,null,{config:h(()=>[r(`div`,Si,[o(u,{"model-value":e.taskType,"onUpdate:modelValue":e.onTabChange},null,8,[`model-value`,`onUpdate:modelValue`]),r(`div`,Ci,[e.taskType===`videos`?(d(),n(f,{key:0,onGenerate:e.onGenerate},null,8,[`onGenerate`])):e.taskType===`motion`?(d(),n(m,{key:1,onGenerate:e.onGenerateMotion},null,8,[`onGenerate`])):e.taskType===`talking-photo`?(d(),n(g,{key:2,onGenerate:e.onGenerateTalkingPhoto},null,8,[`onGenerate`])):s(``,!0)])])]),result:h(()=>[o(_,{ref:`recentPanel`,loading:e.loadingMore,onReachTop:e.onReachTop},null,8,[`loading`,`onReachTop`])]),_:1})}var Ti=N(xi,[[`render`,wi]]);export{Ti as default};
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import"./rolldown-runtime--c01j_DQ.js";import{$ as e,D as t,E as n,M as r,N as i,O as a,P as o,Q as s,Ut as c,X as l,et as u,j as d,k as f,lt as p,v as m,x as h,y as g}from"./vendor-chart-mdwpew_o.js";import{t as _}from"./button-DWzbdjZV.js";import{r as v,t as y}from"./select-DAa8odbM.js";import{n as b,t as x}from"./tabs-CczvvHUm.js";import{t as S}from"./tooltip-C3PYfh8V.js";import{t as C}from"./image-C6NwfMIr.js";import{t as w}from"./alert-BJj7gY4q.js";import{n as T,r as E}from"./radio-IJQsW93X.js";import{n as D,t as O}from"./collapse-BF3bD3JQ.js";import{t as k}from"./drawer-BvYPSxXh.js";import{t as ee}from"./input-number-CGajKQ5c.js";import{t as te}from"./switch-OayEB1u5.js";import"./constants-BVtW3DRs.js";import{E as A,Ir as j,Nt as M,kr as N,yr as P}from"./index-B2cLm6qN.js";import{t as F}from"./index.es-CtAdUuvy.js";import{t as I}from"./CopyToClipboard-BWst2iVb.js";import{t as L}from"./Consumption-sOdFzyTj.js";var R=o({name:`LayoutWebextrator`,components:{ElDrawer:k,ElButton:_,FontAwesomeIcon:F},data(){return{drawer:!1}}}),z={class:`main flex flex-row flex-1`},B={class:`config w-[340px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]`},V={class:`result h-full flex-1 flex flex-col min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]`};function H(t,r,a,o,s,c){let d=u(`font-awesome-icon`),m=u(`el-button`),h=u(`el-drawer`);return l(),f(`div`,z,[n(`div`,B,[e(t.$slots,`config`,{},void 0,!0)]),n(`div`,V,[e(t.$slots,`result`,{},void 0,!0)]),i(m,{circle:``,class:`menu`,onClick:r[0]||=e=>t.drawer=!0},{default:p(()=>[i(d,{icon:`fa-solid fa-sliders`})]),_:1}),i(h,{modelValue:t.drawer,"onUpdate:modelValue":r[1]||=e=>t.drawer=e,direction:`ltr`,"with-header":!1,size:`340px`,class:`drawer`},{default:p(()=>[e(t.$slots,`config`,{},void 0,!0)]),_:3},8,[`modelValue`])])}var U=A(R,[[`render`,H],[`__scopeId`,`data-v-f9e97e78`]]),W=o({name:`ModeSelector`,components:{ElRadioGroup:E,ElRadioButton:T,FontAwesomeIcon:F},computed:{value:{get(){return this.$store.state.webextrator?.config?.mode},set(e){this.$store.commit(`webextrator/setConfig`,{...this.$store.state.webextrator?.config,mode:e})}}}}),G={class:`field`},K={class:`title font-bold`};function q(e,t,a,o,s,d){let m=u(`font-awesome-icon`),h=u(`el-radio-button`),g=u(`el-radio-group`);return l(),f(`div`,G,[n(`h2`,K,c(e.$t(`webextrator.name.mode`)),1),i(g,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,class:`value w-full`},{default:p(()=>[i(h,{label:`extract`,value:`extract`},{default:p(()=>[i(m,{icon:`fa-solid fa-wand-magic-sparkles`,class:`mr-1`}),r(` `+c(e.$t(`webextrator.mode.extract`)),1)]),_:1}),i(h,{label:`render`,value:`render`},{default:p(()=>[i(m,{icon:`fa-solid fa-globe`,class:`mr-1`}),r(` `+c(e.$t(`webextrator.mode.render`)),1)]),_:1})]),_:1},8,[`modelValue`])])}var J=A(W,[[`render`,q],[`__scopeId`,`data-v-31e6c11d`]]),Y=o({name:`UrlInput`,components:{ElInput:j},emits:[`submit`],computed:{url:{get(){return this.$store.state.webextrator?.config?.url||``},set(e){this.$store.commit(`webextrator/setConfig`,{...this.$store.state.webextrator?.config,url:e})}}},methods:{onEnter(){this.$emit(`submit`)}}}),X={class:`field`},Z={class:`title font-bold`};function Q(e,t,r,a,o,s){let d=u(`el-input`);return l(),f(`div`,X,[n(`h2`,Z,c(e.$t(`webextrator.name.url`)),1),i(d,{modelValue:e.url,"onUpdate:modelValue":t[0]||=t=>e.url=t,type:`textarea`,rows:2,class:`prompt`,placeholder:e.$t(`webextrator.placeholder.url`),onKeydown:m(g(e.onEnter,[`exact`,`prevent`]),[`enter`])},null,8,[`modelValue`,`placeholder`,`onKeydown`])])}var ne=A(Y,[[`render`,Q],[`__scopeId`,`data-v-18488009`]]),re=o({name:`ExpectedTypeSelector`,components:{ElSelect:v,ElOption:y},computed:{value:{get(){return this.$store.state.webextrator?.config?.expected_type},set(e){this.$store.commit(`webextrator/setConfig`,{...this.$store.state.webextrator?.config,expected_type:e})}}},mounted(){this.value||=`general`}}),ie={class:`field`},ae={class:`title font-bold`};function oe(e,t,r,a,o,s){let d=u(`el-option`),m=u(`el-select`);return l(),f(`div`,ie,[n(`h2`,ae,c(e.$t(`webextrator.name.expectedType`)),1),i(m,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,class:`value`},{default:p(()=>[i(d,{value:`general`,label:e.$t(`webextrator.expectedType.general`)},null,8,[`label`]),i(d,{value:`article`,label:e.$t(`webextrator.expectedType.article`)},null,8,[`label`]),i(d,{value:`product`,label:e.$t(`webextrator.expectedType.product`)},null,8,[`label`])]),_:1},8,[`modelValue`])])}var se=A(re,[[`render`,oe],[`__scopeId`,`data-v-3b572c49`]]),ce=o({name:`LlmToggle`,components:{ElSwitch:te,ElTooltip:S,FontAwesomeIcon:F},computed:{value:{get(){return!!this.$store.state.webextrator?.config?.enable_llm},set(e){this.$store.commit(`webextrator/setConfig`,{...this.$store.state.webextrator?.config,enable_llm:e})}}}}),le={class:`field`},ue={class:`title font-bold`};function de(e,t,a,o,s,d){let m=u(`font-awesome-icon`),h=u(`el-tooltip`),g=u(`el-switch`);return l(),f(`div`,le,[n(`h2`,ue,[r(c(e.$t(`webextrator.name.enableLlm`))+` `,1),i(h,{effect:`dark`,content:e.$t(`webextrator.description.enableLlm`),placement:`top`},{default:p(()=>[i(m,{icon:`fa-solid fa-circle-info`,class:`ml-1 text-[var(--el-text-color-secondary)] text-xs`})]),_:1},8,[`content`])]),i(g,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,class:`value`},null,8,[`modelValue`])])}var fe=A(ce,[[`render`,de],[`__scopeId`,`data-v-32fa7c89`]]),pe=[`image`,`font`,`media`,`stylesheet`,`xhr`,`fetch`],me=o({name:`AdvancedOptions`,components:{ElCollapse:O,ElCollapseItem:D,ElInput:j,ElInputNumber:ee,ElSelect:v,ElOption:y},data(){return{active:[]}},computed:{resourceKinds(){return pe},waitUntil:{get(){return this.$store.state.webextrator?.config?.wait_until||`networkidle`},set(e){this.commit({wait_until:e})}},waitForSelector:{get(){return this.$store.state.webextrator?.config?.wait_for_selector||``},set(e){this.commit({wait_for_selector:e})}},timeout:{get(){return this.$store.state.webextrator?.config?.timeout??30},set(e){this.commit({timeout:e})}},delay:{get(){return this.$store.state.webextrator?.config?.delay??0},set(e){this.commit({delay:e})}},blockResources:{get(){return this.$store.state.webextrator?.config?.block_resources||[]},set(e){this.commit({block_resources:e})}}},methods:{commit(e){this.$store.commit(`webextrator/setConfig`,{...this.$store.state.webextrator?.config,...e})}}}),he={class:`field`},ge={class:`sub-title`},_e={class:`field`},ve={class:`sub-title`},ye={class:`field`},be={class:`sub-title`},xe={class:`field`},Se={class:`sub-title`},Ce={class:`field`},we={class:`sub-title`};function Te(e,r,a,o,d,m){let g=u(`el-option`),_=u(`el-select`),v=u(`el-input`),y=u(`el-input-number`),b=u(`el-collapse-item`),x=u(`el-collapse`);return l(),t(x,{modelValue:e.active,"onUpdate:modelValue":r[5]||=t=>e.active=t,class:`advanced`},{default:p(()=>[i(b,{title:e.$t(`webextrator.name.advanced`),name:`advanced`},{default:p(()=>[n(`div`,he,[n(`h2`,ge,c(e.$t(`webextrator.name.waitUntil`)),1),i(_,{modelValue:e.waitUntil,"onUpdate:modelValue":r[0]||=t=>e.waitUntil=t,class:`value`},{default:p(()=>[i(g,{value:`networkidle`,label:e.$t(`webextrator.waitUntil.networkidle`)},null,8,[`label`]),i(g,{value:`load`,label:e.$t(`webextrator.waitUntil.load`)},null,8,[`label`]),i(g,{value:`domcontentloaded`,label:e.$t(`webextrator.waitUntil.domcontentloaded`)},null,8,[`label`]),i(g,{value:`commit`,label:e.$t(`webextrator.waitUntil.commit`)},null,8,[`label`])]),_:1},8,[`modelValue`])]),n(`div`,_e,[n(`h2`,ve,c(e.$t(`webextrator.name.waitForSelector`)),1),i(v,{modelValue:e.waitForSelector,"onUpdate:modelValue":r[1]||=t=>e.waitForSelector=t,placeholder:e.$t(`webextrator.placeholder.waitForSelector`)},null,8,[`modelValue`,`placeholder`])]),n(`div`,ye,[n(`h2`,be,c(e.$t(`webextrator.name.timeout`)),1),i(y,{modelValue:e.timeout,"onUpdate:modelValue":r[2]||=t=>e.timeout=t,min:1,max:120,step:5,"controls-position":`right`,class:`w-full`},null,8,[`modelValue`])]),n(`div`,xe,[n(`h2`,Se,c(e.$t(`webextrator.name.delay`)),1),i(y,{modelValue:e.delay,"onUpdate:modelValue":r[3]||=t=>e.delay=t,min:0,max:30,step:1,"controls-position":`right`,class:`w-full`},null,8,[`modelValue`])]),n(`div`,Ce,[n(`h2`,we,c(e.$t(`webextrator.name.blockResources`)),1),i(_,{modelValue:e.blockResources,"onUpdate:modelValue":r[4]||=t=>e.blockResources=t,multiple:``,"collapse-tags":``,placeholder:e.$t(`webextrator.placeholder.blockResources`),class:`w-full`},{default:p(()=>[(l(!0),f(h,null,s(e.resourceKinds,n=>(l(),t(g,{key:n,label:e.$t(`webextrator.blockResource.${n}`),value:n},null,8,[`label`,`value`]))),128))]),_:1},8,[`modelValue`,`placeholder`])])]),_:1},8,[`title`])]),_:1},8,[`modelValue`])}var Ee=o({name:`WebextratorConfigPanel`,components:{ElButton:_,FontAwesomeIcon:F,ModeSelector:J,UrlInput:ne,ExpectedTypeSelector:se,LlmToggle:fe,AdvancedOptions:A(me,[[`render`,Te],[`__scopeId`,`data-v-8f36d2df`]]),Consumption:L},emits:[`run`],computed:{config(){return this.$store.state.webextrator?.config},service(){return this.$store.state.webextrator?.service},consumption(){return M(this.config||{},this.service?.cost)},running(){return this.$store.state.webextrator?.status?.run===P.Request},isExtract(){return(this.config?.mode||`extract`)===`extract`},canRun(){let e=(this.config?.url||``).trim();return/^https?:\/\//i.test(e)}},methods:{onRun(){this.canRun&&this.$emit(`run`)}}}),De={class:`flex flex-col h-full`},Oe={class:`flex-1 overflow-y-auto p-5`},ke={class:`flex flex-col items-center justify-center px-5 pb-5`};function Ae(e,t,o,s,d,m){let g=u(`mode-selector`),_=u(`url-input`),v=u(`expected-type-selector`),y=u(`llm-toggle`),b=u(`advanced-options`),x=u(`consumption`),S=u(`font-awesome-icon`),C=u(`el-button`);return l(),f(`div`,De,[n(`div`,Oe,[i(g,{class:`mb-4`}),i(_,{class:`mb-4`,onSubmit:e.onRun},null,8,[`onSubmit`]),e.isExtract?(l(),f(h,{key:0},[i(v,{class:`mb-4`}),i(y,{class:`mb-4`})],64)):a(``,!0),i(b,{class:`mb-4`})]),n(`div`,ke,[i(x,{value:e.consumption,service:e.service},null,8,[`value`,`service`]),i(C,{type:`primary`,class:`w-full`,round:``,loading:e.running,disabled:!e.canRun,onClick:e.onRun},{default:p(()=>[i(S,{icon:`fa-solid fa-bolt`,class:`mr-2`}),r(` `+c(e.$t(e.isExtract?`webextrator.button.extract`:`webextrator.button.render`)),1)]),_:1},8,[`loading`,`disabled`,`onClick`])])])}var je=A(Ee,[[`render`,Ae]]),Me=e=>!!e&&e.kind!==`render`,Ne=o({name:`WebextratorResultPanel`,components:{ElAlert:w,ElImage:C,ElTabs:b,ElTabPane:x,FontAwesomeIcon:F,CopyToClipboard:I},data(){return{activeTab:`markdown`}},computed:{response(){return this.$store.state.webextrator?.response},running(){return this.$store.state.webextrator?.status?.run===P.Request},data(){return this.response?.data},renderData(){return this.data&&this.data.kind===`render`?this.data:void 0},extractData(){return Me(this.data)?this.data:void 0},finalUrl(){let e=this.data;return e?.finalUrl||e?.final_url||e?.url},contentTypeLabel(){let e=this.data;return e?.contentType||e?.content_type||e?.expected_type},screenshotSrc(){let e=this.data?.screenshot;if(e)return e.startsWith(`data:`)||e.startsWith(`http`)?e:`data:image/png;base64,${e}`},markdown(){let e=this.data;return e?.markdown||e?.content||``},plainText(){return this.data?.text||``},html(){return this.data?.html||``},links(){return Array.isArray(this.data?.links)?this.data.links:[]},linksPlain(){return this.links.join(`
|
|
1
|
+
import"./rolldown-runtime--c01j_DQ.js";import{$ as e,D as t,E as n,M as r,N as i,O as a,P as o,Q as s,Ut as c,X as l,et as u,j as d,k as f,lt as p,v as m,x as h,y as g}from"./vendor-chart-mdwpew_o.js";import{t as _}from"./button-DWzbdjZV.js";import{r as v,t as y}from"./select-CYdISXBV.js";import{n as b,t as x}from"./tabs-DbqhD0Ri.js";import{t as S}from"./tooltip-C3PYfh8V.js";import{t as C}from"./image-tItcr5tZ.js";import{t as w}from"./alert-BJj7gY4q.js";import{n as T,r as E}from"./radio-IJQsW93X.js";import{n as D,t as O}from"./collapse-B99-bYjk.js";import{t as k}from"./drawer-BvYPSxXh.js";import{t as ee}from"./input-number-BZClQnf5.js";import{t as te}from"./switch-DT8swXGq.js";import"./constants-B6_fTlam.js";import{E as A,Ir as j,Nt as M,kr as N,yr as P}from"./index-DpREqzJQ.js";import{t as F}from"./index.es-DkXuZNXE.js";import{t as I}from"./CopyToClipboard-DXA4nHxo.js";import{t as L}from"./Consumption-CjrpUNmV.js";var R=o({name:`LayoutWebextrator`,components:{ElDrawer:k,ElButton:_,FontAwesomeIcon:F},data(){return{drawer:!1}}}),z={class:`main flex flex-row flex-1`},B={class:`config w-[340px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]`},V={class:`result h-full flex-1 flex flex-col min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]`};function H(t,r,a,o,s,c){let d=u(`font-awesome-icon`),m=u(`el-button`),h=u(`el-drawer`);return l(),f(`div`,z,[n(`div`,B,[e(t.$slots,`config`,{},void 0,!0)]),n(`div`,V,[e(t.$slots,`result`,{},void 0,!0)]),i(m,{circle:``,class:`menu`,onClick:r[0]||=e=>t.drawer=!0},{default:p(()=>[i(d,{icon:`fa-solid fa-sliders`})]),_:1}),i(h,{modelValue:t.drawer,"onUpdate:modelValue":r[1]||=e=>t.drawer=e,direction:`ltr`,"with-header":!1,size:`340px`,class:`drawer`},{default:p(()=>[e(t.$slots,`config`,{},void 0,!0)]),_:3},8,[`modelValue`])])}var U=A(R,[[`render`,H],[`__scopeId`,`data-v-f9e97e78`]]),W=o({name:`ModeSelector`,components:{ElRadioGroup:E,ElRadioButton:T,FontAwesomeIcon:F},computed:{value:{get(){return this.$store.state.webextrator?.config?.mode},set(e){this.$store.commit(`webextrator/setConfig`,{...this.$store.state.webextrator?.config,mode:e})}}}}),G={class:`field`},K={class:`title font-bold`};function q(e,t,a,o,s,d){let m=u(`font-awesome-icon`),h=u(`el-radio-button`),g=u(`el-radio-group`);return l(),f(`div`,G,[n(`h2`,K,c(e.$t(`webextrator.name.mode`)),1),i(g,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,class:`value w-full`},{default:p(()=>[i(h,{label:`extract`,value:`extract`},{default:p(()=>[i(m,{icon:`fa-solid fa-wand-magic-sparkles`,class:`mr-1`}),r(` `+c(e.$t(`webextrator.mode.extract`)),1)]),_:1}),i(h,{label:`render`,value:`render`},{default:p(()=>[i(m,{icon:`fa-solid fa-globe`,class:`mr-1`}),r(` `+c(e.$t(`webextrator.mode.render`)),1)]),_:1})]),_:1},8,[`modelValue`])])}var J=A(W,[[`render`,q],[`__scopeId`,`data-v-31e6c11d`]]),Y=o({name:`UrlInput`,components:{ElInput:j},emits:[`submit`],computed:{url:{get(){return this.$store.state.webextrator?.config?.url||``},set(e){this.$store.commit(`webextrator/setConfig`,{...this.$store.state.webextrator?.config,url:e})}}},methods:{onEnter(){this.$emit(`submit`)}}}),X={class:`field`},Z={class:`title font-bold`};function Q(e,t,r,a,o,s){let d=u(`el-input`);return l(),f(`div`,X,[n(`h2`,Z,c(e.$t(`webextrator.name.url`)),1),i(d,{modelValue:e.url,"onUpdate:modelValue":t[0]||=t=>e.url=t,type:`textarea`,rows:2,class:`prompt`,placeholder:e.$t(`webextrator.placeholder.url`),onKeydown:m(g(e.onEnter,[`exact`,`prevent`]),[`enter`])},null,8,[`modelValue`,`placeholder`,`onKeydown`])])}var ne=A(Y,[[`render`,Q],[`__scopeId`,`data-v-18488009`]]),re=o({name:`ExpectedTypeSelector`,components:{ElSelect:v,ElOption:y},computed:{value:{get(){return this.$store.state.webextrator?.config?.expected_type},set(e){this.$store.commit(`webextrator/setConfig`,{...this.$store.state.webextrator?.config,expected_type:e})}}},mounted(){this.value||=`general`}}),ie={class:`field`},ae={class:`title font-bold`};function oe(e,t,r,a,o,s){let d=u(`el-option`),m=u(`el-select`);return l(),f(`div`,ie,[n(`h2`,ae,c(e.$t(`webextrator.name.expectedType`)),1),i(m,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,class:`value`},{default:p(()=>[i(d,{value:`general`,label:e.$t(`webextrator.expectedType.general`)},null,8,[`label`]),i(d,{value:`article`,label:e.$t(`webextrator.expectedType.article`)},null,8,[`label`]),i(d,{value:`product`,label:e.$t(`webextrator.expectedType.product`)},null,8,[`label`])]),_:1},8,[`modelValue`])])}var se=A(re,[[`render`,oe],[`__scopeId`,`data-v-3b572c49`]]),ce=o({name:`LlmToggle`,components:{ElSwitch:te,ElTooltip:S,FontAwesomeIcon:F},computed:{value:{get(){return!!this.$store.state.webextrator?.config?.enable_llm},set(e){this.$store.commit(`webextrator/setConfig`,{...this.$store.state.webextrator?.config,enable_llm:e})}}}}),le={class:`field`},ue={class:`title font-bold`};function de(e,t,a,o,s,d){let m=u(`font-awesome-icon`),h=u(`el-tooltip`),g=u(`el-switch`);return l(),f(`div`,le,[n(`h2`,ue,[r(c(e.$t(`webextrator.name.enableLlm`))+` `,1),i(h,{effect:`dark`,content:e.$t(`webextrator.description.enableLlm`),placement:`top`},{default:p(()=>[i(m,{icon:`fa-solid fa-circle-info`,class:`ml-1 text-[var(--el-text-color-secondary)] text-xs`})]),_:1},8,[`content`])]),i(g,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,class:`value`},null,8,[`modelValue`])])}var fe=A(ce,[[`render`,de],[`__scopeId`,`data-v-32fa7c89`]]),pe=[`image`,`font`,`media`,`stylesheet`,`xhr`,`fetch`],me=o({name:`AdvancedOptions`,components:{ElCollapse:O,ElCollapseItem:D,ElInput:j,ElInputNumber:ee,ElSelect:v,ElOption:y},data(){return{active:[]}},computed:{resourceKinds(){return pe},waitUntil:{get(){return this.$store.state.webextrator?.config?.wait_until||`networkidle`},set(e){this.commit({wait_until:e})}},waitForSelector:{get(){return this.$store.state.webextrator?.config?.wait_for_selector||``},set(e){this.commit({wait_for_selector:e})}},timeout:{get(){return this.$store.state.webextrator?.config?.timeout??30},set(e){this.commit({timeout:e})}},delay:{get(){return this.$store.state.webextrator?.config?.delay??0},set(e){this.commit({delay:e})}},blockResources:{get(){return this.$store.state.webextrator?.config?.block_resources||[]},set(e){this.commit({block_resources:e})}}},methods:{commit(e){this.$store.commit(`webextrator/setConfig`,{...this.$store.state.webextrator?.config,...e})}}}),he={class:`field`},ge={class:`sub-title`},_e={class:`field`},ve={class:`sub-title`},ye={class:`field`},be={class:`sub-title`},xe={class:`field`},Se={class:`sub-title`},Ce={class:`field`},we={class:`sub-title`};function Te(e,r,a,o,d,m){let g=u(`el-option`),_=u(`el-select`),v=u(`el-input`),y=u(`el-input-number`),b=u(`el-collapse-item`),x=u(`el-collapse`);return l(),t(x,{modelValue:e.active,"onUpdate:modelValue":r[5]||=t=>e.active=t,class:`advanced`},{default:p(()=>[i(b,{title:e.$t(`webextrator.name.advanced`),name:`advanced`},{default:p(()=>[n(`div`,he,[n(`h2`,ge,c(e.$t(`webextrator.name.waitUntil`)),1),i(_,{modelValue:e.waitUntil,"onUpdate:modelValue":r[0]||=t=>e.waitUntil=t,class:`value`},{default:p(()=>[i(g,{value:`networkidle`,label:e.$t(`webextrator.waitUntil.networkidle`)},null,8,[`label`]),i(g,{value:`load`,label:e.$t(`webextrator.waitUntil.load`)},null,8,[`label`]),i(g,{value:`domcontentloaded`,label:e.$t(`webextrator.waitUntil.domcontentloaded`)},null,8,[`label`]),i(g,{value:`commit`,label:e.$t(`webextrator.waitUntil.commit`)},null,8,[`label`])]),_:1},8,[`modelValue`])]),n(`div`,_e,[n(`h2`,ve,c(e.$t(`webextrator.name.waitForSelector`)),1),i(v,{modelValue:e.waitForSelector,"onUpdate:modelValue":r[1]||=t=>e.waitForSelector=t,placeholder:e.$t(`webextrator.placeholder.waitForSelector`)},null,8,[`modelValue`,`placeholder`])]),n(`div`,ye,[n(`h2`,be,c(e.$t(`webextrator.name.timeout`)),1),i(y,{modelValue:e.timeout,"onUpdate:modelValue":r[2]||=t=>e.timeout=t,min:1,max:120,step:5,"controls-position":`right`,class:`w-full`},null,8,[`modelValue`])]),n(`div`,xe,[n(`h2`,Se,c(e.$t(`webextrator.name.delay`)),1),i(y,{modelValue:e.delay,"onUpdate:modelValue":r[3]||=t=>e.delay=t,min:0,max:30,step:1,"controls-position":`right`,class:`w-full`},null,8,[`modelValue`])]),n(`div`,Ce,[n(`h2`,we,c(e.$t(`webextrator.name.blockResources`)),1),i(_,{modelValue:e.blockResources,"onUpdate:modelValue":r[4]||=t=>e.blockResources=t,multiple:``,"collapse-tags":``,placeholder:e.$t(`webextrator.placeholder.blockResources`),class:`w-full`},{default:p(()=>[(l(!0),f(h,null,s(e.resourceKinds,n=>(l(),t(g,{key:n,label:e.$t(`webextrator.blockResource.${n}`),value:n},null,8,[`label`,`value`]))),128))]),_:1},8,[`modelValue`,`placeholder`])])]),_:1},8,[`title`])]),_:1},8,[`modelValue`])}var Ee=o({name:`WebextratorConfigPanel`,components:{ElButton:_,FontAwesomeIcon:F,ModeSelector:J,UrlInput:ne,ExpectedTypeSelector:se,LlmToggle:fe,AdvancedOptions:A(me,[[`render`,Te],[`__scopeId`,`data-v-8f36d2df`]]),Consumption:L},emits:[`run`],computed:{config(){return this.$store.state.webextrator?.config},service(){return this.$store.state.webextrator?.service},consumption(){return M(this.config||{},this.service?.cost)},running(){return this.$store.state.webextrator?.status?.run===P.Request},isExtract(){return(this.config?.mode||`extract`)===`extract`},canRun(){let e=(this.config?.url||``).trim();return/^https?:\/\//i.test(e)}},methods:{onRun(){this.canRun&&this.$emit(`run`)}}}),De={class:`flex flex-col h-full`},Oe={class:`flex-1 overflow-y-auto p-5`},ke={class:`flex flex-col items-center justify-center px-5 pb-5`};function Ae(e,t,o,s,d,m){let g=u(`mode-selector`),_=u(`url-input`),v=u(`expected-type-selector`),y=u(`llm-toggle`),b=u(`advanced-options`),x=u(`consumption`),S=u(`font-awesome-icon`),C=u(`el-button`);return l(),f(`div`,De,[n(`div`,Oe,[i(g,{class:`mb-4`}),i(_,{class:`mb-4`,onSubmit:e.onRun},null,8,[`onSubmit`]),e.isExtract?(l(),f(h,{key:0},[i(v,{class:`mb-4`}),i(y,{class:`mb-4`})],64)):a(``,!0),i(b,{class:`mb-4`})]),n(`div`,ke,[i(x,{value:e.consumption,service:e.service},null,8,[`value`,`service`]),i(C,{type:`primary`,class:`w-full`,round:``,loading:e.running,disabled:!e.canRun,onClick:e.onRun},{default:p(()=>[i(S,{icon:`fa-solid fa-bolt`,class:`mr-2`}),r(` `+c(e.$t(e.isExtract?`webextrator.button.extract`:`webextrator.button.render`)),1)]),_:1},8,[`loading`,`disabled`,`onClick`])])])}var je=A(Ee,[[`render`,Ae]]),Me=e=>!!e&&e.kind!==`render`,Ne=o({name:`WebextratorResultPanel`,components:{ElAlert:w,ElImage:C,ElTabs:b,ElTabPane:x,FontAwesomeIcon:F,CopyToClipboard:I},data(){return{activeTab:`markdown`}},computed:{response(){return this.$store.state.webextrator?.response},running(){return this.$store.state.webextrator?.status?.run===P.Request},data(){return this.response?.data},renderData(){return this.data&&this.data.kind===`render`?this.data:void 0},extractData(){return Me(this.data)?this.data:void 0},finalUrl(){let e=this.data;return e?.finalUrl||e?.final_url||e?.url},contentTypeLabel(){let e=this.data;return e?.contentType||e?.content_type||e?.expected_type},screenshotSrc(){let e=this.data?.screenshot;if(e)return e.startsWith(`data:`)||e.startsWith(`http`)?e:`data:image/png;base64,${e}`},markdown(){let e=this.data;return e?.markdown||e?.content||``},plainText(){return this.data?.text||``},html(){return this.data?.html||``},links(){return Array.isArray(this.data?.links)?this.data.links:[]},linksPlain(){return this.links.join(`
|
|
2
2
|
`)},images(){return Array.isArray(this.data?.images)?this.data.images:[]},structuredPretty(){return this.extractData?.structured?JSON.stringify(this.extractData.structured,null,2):``},rawPretty(){return this.response?JSON.stringify(this.response,null,2):``},errorMessage(){if(this.response?.success===!1){let e=this.response?.error;return e?.message||e?.code||this.$t(`webextrator.message.failed`)}}},watch:{response:{handler(){this.resetTab()},immediate:!0}},methods:{resetTab(){this.markdown?this.activeTab=`markdown`:this.extractData?.structured?this.activeTab=`structured`:this.plainText?this.activeTab=`text`:this.html?this.activeTab=`html`:this.activeTab=`raw`}}}),Pe={class:`h-full overflow-y-auto p-6`},Fe={key:0,class:`max-w-4xl mx-auto py-4`},Ie={class:`flex items-center gap-2 mb-3 text-[var(--el-color-primary)] text-sm`},Le={key:1,class:`flex flex-col items-center justify-center py-24 text-[var(--el-text-color-disabled)]`},Re={class:`text-base mb-1`},ze={class:`text-xs opacity-70`},Be={key:2,class:`max-w-4xl mx-auto py-4`},Ve={class:`text-xs whitespace-pre-wrap break-words`},He={key:3,class:`max-w-4xl mx-auto`},Ue={class:`mb-4`},We={class:`text-xl font-semibold leading-snug mb-1 break-words text-[var(--el-text-color-primary)]`},Ge={class:`flex flex-wrap items-center gap-x-3 gap-y-1 text-xs text-[var(--el-text-color-secondary)]`},Ke=[`href`],qe={key:1},Je={key:2},Ye={key:3},Xe={key:0,class:`mt-2 text-sm text-[var(--el-text-color-regular)] leading-relaxed line-clamp-3`},Ze={key:0,class:`mb-5`},Qe={class:`tab-toolbar`},$e={class:`content-block`},et={class:`tab-toolbar`},tt={class:`content-block`},$={class:`tab-toolbar`},nt={class:`content-block code`},rt={class:`tab-toolbar`},it={class:`links-list`},at=[`href`],ot={class:`grid grid-cols-2 md:grid-cols-3 lg:grid-cols-4 gap-2`},st={class:`tab-toolbar`},ct={class:`content-block code`},lt={class:`tab-toolbar`},ut={class:`content-block code`};function dt(e,o,m,g,_,v){let y=u(`font-awesome-icon`),b=u(`el-alert`),x=u(`el-image`),S=u(`copy-to-clipboard`),C=u(`el-tab-pane`),w=u(`el-tabs`);return l(),f(`div`,Pe,[e.running?(l(),f(`div`,Fe,[n(`div`,Ie,[i(y,{icon:`fa-solid fa-circle-notch`,spin:``}),n(`span`,null,c(e.$t(`webextrator.message.running`)),1)]),o[1]||=d(`<div class="mb-6 animate-pulse" data-v-b05b4db0><div class="h-5 w-3/5 rounded bg-[var(--el-fill-color-dark)] mb-2" data-v-b05b4db0></div><div class="h-3 w-2/5 rounded bg-[var(--el-fill-color)] mb-4" data-v-b05b4db0></div><div class="h-64 w-full rounded bg-[var(--el-fill-color)] mb-3" data-v-b05b4db0></div><div class="h-3 w-full rounded bg-[var(--el-fill-color)] mb-1" data-v-b05b4db0></div><div class="h-3 w-5/6 rounded bg-[var(--el-fill-color)] mb-1" data-v-b05b4db0></div><div class="h-3 w-4/6 rounded bg-[var(--el-fill-color)]" data-v-b05b4db0></div></div>`,1)])):!e.response&&!e.errorMessage?(l(),f(`div`,Le,[i(y,{icon:`fa-solid fa-globe`,class:`text-6xl mb-4 opacity-30`}),n(`p`,Re,c(e.$t(`webextrator.description.intro`)),1),n(`p`,ze,c(e.$t(`webextrator.description.introHint`)),1)])):e.errorMessage?(l(),f(`div`,Be,[i(b,{type:`error`,closable:!1,"show-icon":``,title:e.$t(`webextrator.message.failed`)},{default:p(()=>[n(`pre`,Ve,c(e.errorMessage),1)]),_:1},8,[`title`])])):e.data?(l(),f(`div`,He,[n(`header`,Ue,[n(`h1`,We,c(e.data.title||e.$t(`webextrator.message.untitled`)),1),n(`div`,Ge,[e.finalUrl?(l(),f(`a`,{key:0,href:e.finalUrl,target:`_blank`,rel:`noopener`,class:`hover:underline truncate max-w-[60%]`},[i(y,{icon:`fa-solid fa-up-right-from-square`,class:`mr-1`}),r(c(e.finalUrl),1)],8,Ke)):a(``,!0),e.renderData?.status?(l(),f(`span`,qe,[i(y,{icon:`fa-solid fa-signal`,class:`mr-1`}),r(c(e.renderData.status),1)])):a(``,!0),e.response?.elapsed?(l(),f(`span`,Je,[i(y,{icon:`fa-solid fa-clock`,class:`mr-1`}),r(c(e.response.elapsed.toFixed(2))+`s `,1)])):a(``,!0),e.contentTypeLabel?(l(),f(`span`,Ye,[i(y,{icon:`fa-solid fa-tag`,class:`mr-1`}),r(c(e.contentTypeLabel),1)])):a(``,!0)]),e.extractData?.description?(l(),f(`p`,Xe,c(e.extractData.description),1)):a(``,!0)]),e.screenshotSrc?(l(),f(`figure`,Ze,[i(x,{src:e.screenshotSrc,fit:`contain`,"preview-src-list":[e.screenshotSrc],"preview-teleported":``,"hide-on-click-modal":``,class:`w-full max-h-[480px] rounded border border-[var(--app-border-subtle)] bg-[var(--el-fill-color-light)]`},null,8,[`src`,`preview-src-list`])])):a(``,!0),i(w,{modelValue:e.activeTab,"onUpdate:modelValue":o[0]||=t=>e.activeTab=t,class:`result-tabs`},{default:p(()=>[e.markdown?(l(),t(C,{key:0,label:e.$t(`webextrator.tab.markdown`),name:`markdown`},{default:p(()=>[n(`div`,Qe,[i(S,{content:e.markdown},null,8,[`content`])]),n(`pre`,$e,c(e.markdown),1)]),_:1},8,[`label`])):a(``,!0),e.plainText?(l(),t(C,{key:1,label:e.$t(`webextrator.tab.text`),name:`text`},{default:p(()=>[n(`div`,et,[i(S,{content:e.plainText},null,8,[`content`])]),n(`pre`,tt,c(e.plainText),1)]),_:1},8,[`label`])):a(``,!0),e.extractData?.structured?(l(),t(C,{key:2,label:e.$t(`webextrator.tab.structured`),name:`structured`},{default:p(()=>[n(`div`,$,[i(S,{content:e.structuredPretty},null,8,[`content`])]),n(`pre`,nt,c(e.structuredPretty),1)]),_:1},8,[`label`])):a(``,!0),e.links.length?(l(),t(C,{key:3,label:`${e.$t(`webextrator.tab.links`)} (${e.links.length})`,name:`links`},{default:p(()=>[n(`div`,rt,[i(S,{content:e.linksPlain},null,8,[`content`])]),n(`ul`,it,[(l(!0),f(h,null,s(e.links,(e,t)=>(l(),f(`li`,{key:t,class:`truncate`},[n(`a`,{href:e,target:`_blank`,rel:`noopener`},c(e),9,at)]))),128))])]),_:1},8,[`label`])):a(``,!0),e.images.length?(l(),t(C,{key:4,label:`${e.$t(`webextrator.tab.images`)} (${e.images.length})`,name:`images`},{default:p(()=>[n(`div`,ot,[(l(!0),f(h,null,s(e.images,(n,r)=>(l(),t(x,{key:r,src:n,fit:`cover`,loading:`lazy`,"preview-src-list":e.images,"initial-index":r,"preview-teleported":``,"hide-on-click-modal":``,class:`aspect-square w-full rounded bg-[var(--el-fill-color-light)]`},null,8,[`src`,`preview-src-list`,`initial-index`]))),128))])]),_:1},8,[`label`])):a(``,!0),e.html?(l(),t(C,{key:5,label:e.$t(`webextrator.tab.html`),name:`html`},{default:p(()=>[n(`div`,st,[i(S,{content:e.html},null,8,[`content`])]),n(`pre`,ct,c(e.html),1)]),_:1},8,[`label`])):a(``,!0),i(C,{label:e.$t(`webextrator.tab.raw`),name:`raw`},{default:p(()=>[n(`div`,lt,[i(S,{content:e.rawPretty},null,8,[`content`])]),n(`pre`,ut,c(e.rawPretty),1)]),_:1},8,[`label`])]),_:1},8,[`modelValue`])])):a(``,!0)])}var ft=o({name:`WebextratorIndex`,components:{Layout:U,ConfigPanel:je,ResultPanel:A(Ne,[[`render`,dt],[`__scopeId`,`data-v-b05b4db0`]])},inject:[`initialized`],async mounted(){await this.$store.dispatch(`webextrator/getService`)},methods:{async onRun(){let e=this.$store.state.webextrator?.config;if(!e?.url)return;let t=(e.mode||`extract`)===`extract`;N.info(this.$t(t?`webextrator.message.extracting`:`webextrator.message.rendering`));try{await this.$store.dispatch(`webextrator/run`),N.success(this.$t(`webextrator.message.success`))}catch(e){let t=e?.response?.data?.error?.code||e?.response?.data?.code;t===`used_up`?N.error(this.$t(`webextrator.message.usedUp`)):t===`too_many_requests`?N.error(this.$t(`webextrator.message.busy`)):t===`timeout`?N.error(this.$t(`webextrator.message.timeout`)):N.error(this.$t(`webextrator.message.failed`))}}}});function pt(e,n,r,a,o,s){let c=u(`config-panel`),d=u(`result-panel`),f=u(`layout`);return l(),t(f,null,{config:p(()=>[i(c,{onRun:e.onRun},null,8,[`onRun`])]),result:p(()=>[i(d)]),_:1})}var mt=A(ft,[[`render`,pt]]);export{mt as default};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import"./rolldown-runtime--c01j_DQ.js";import{$ as e,Bt as t,D as n,E as r,M as i,N as a,O as o,P as s,Q as c,Ut as l,X as u,_ as d,et as f,k as p,lt as m,ut as h,x as g,y as _}from"./vendor-chart-mdwpew_o.js";import{t as v}from"./button-DWzbdjZV.js";import{r as y,t as b}from"./select-DAa8odbM.js";import{t as x}from"./upload-C1A-s7Yk.js";import{t as S}from"./tooltip-C3PYfh8V.js";import{t as C}from"./image-C6NwfMIr.js";import{t as w}from"./alert-BJj7gY4q.js";import{t as T}from"./drawer-BvYPSxXh.js";import{dt as E,ft as D,hi as ee}from"./constants-BVtW3DRs.js";import{At as te,E as O,Fn as k,Nt as A,Ot as j,Sr as M,Yt as N,jt as P,kr as F,kt as I,yr as L}from"./index-B2cLm6qN.js";import{t as R}from"./index.es-CtAdUuvy.js";import{t as z}from"./CopyToClipboard-BWst2iVb.js";import{t as B}from"./ImagePreview-BONFD01I.js";import{n as V}from"./taskDrawerMixin-Cr17Yxqk.js";import{t as H}from"./BotPlaceholder-CsbmSleA.js";import{i as U,n as W,t as G}from"./pagination-lmE1fJNh.js";import{n as K,t as q}from"./NoTasks-DFKN-WpO.js";import{t as J}from"./Consumption-sOdFzyTj.js";import{t as Y}from"./ApiCodeButton-_F8VGfz6.js";import{t as X}from"./VideoPlayer-BsOg3z0K.js";var Z=s({name:`LayoutWan`,components:{ElDrawer:T,ElButton:v,FontAwesomeIcon:R},mixins:[V]}),Q={class:`main flex flex-row flex-1`},ne={class:`config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]`},re={class:`result h-full p-6 flex-1 flex flex-col min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]`};function ie(t,n,i,o,s,c){let l=f(`font-awesome-icon`),g=f(`el-button`),_=f(`el-drawer`);return u(),p(`div`,Q,[r(`div`,ne,[e(t.$slots,`config`,{},void 0,!0)]),r(`div`,re,[e(t.$slots,`result`,{},void 0,!0)]),h(a(g,{circle:``,class:`menu`,onClick:n[0]||=e=>t.drawer=!0},{default:m(()=>[a(l,{icon:`fa-solid fa-magic`})]),_:1},512),[[d,!t.tasksEmpty]]),a(_,{modelValue:t.drawer,"onUpdate:modelValue":n[1]||=e=>t.drawer=e,direction:`ltr`,"with-header":!1,size:`340px`},{default:m(()=>[e(t.$slots,`config`,{},void 0,!0)]),_:3},8,[`modelValue`])])}var ae=O(Z,[[`render`,ie],[`__scopeId`,`data-v-1ffeb6b4`]]),oe=s({name:`ModelSelector`,components:{ElSelect:y,ElOption:b},data(){return{}},computed:{options(){return[{value:`wan2.6-t2v`,label:this.$t(`wan.button.modelT2v`)},{value:`wan2.6-i2v`,label:this.$t(`wan.button.modelI2v`)},{value:`wan2.6-i2v-flash`,label:this.$t(`wan.button.modelI2vFlash`)},{value:`wan2.6-r2v`,label:this.$t(`wan.button.modelR2v`)}]},value:{get(){return this.$store.state.wan?.config?.model},set(e){this.$store.commit(`wan/setConfig`,{...this.$store.state.wan?.config,model:e})}}},mounted(){this.value||=E}}),se={class:`field`},ce={class:`title font-bold`},le={class:`float-left`};function ue(e,t,i,o,s,d){let h=f(`el-option`),_=f(`el-select`);return u(),p(`div`,se,[r(`h2`,ce,l(e.$t(`wan.name.model`)),1),a(_,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,class:`value`,placeholder:e.$t(`wan.placeholder.select`),clearable:``},{default:m(()=>[(u(!0),p(g,null,c(e.options,e=>(u(),n(h,{key:e.value,label:e.label,value:e.value},{default:m(()=>[r(`span`,le,l(e.label),1)]),_:2},1032,[`label`,`value`]))),128))]),_:1},8,[`modelValue`,`placeholder`])])}var de=O(oe,[[`render`,ue],[`__scopeId`,`data-v-eb090beb`]]),fe=`720p`,pe=s({name:`ResolutionSelector`,components:{ElSelect:y,ElOption:b},computed:{options(){return[{value:`480p`,label:this.$t(`wan.name.resolution480p`)},{value:`720p`,label:this.$t(`wan.name.resolution720p`)},{value:`1080p`,label:this.$t(`wan.name.resolution1080p`)}]},value:{get(){return this.$store.state.wan?.config?.resolution},set(e){this.$store.commit(`wan/setConfig`,{...this.$store.state.wan?.config,resolution:e})}}},mounted(){this.value||=fe}}),me={class:`field`},he={class:`title font-bold`},ge={class:`float-left`};function _e(e,t,i,o,s,d){let h=f(`el-option`),_=f(`el-select`);return u(),p(`div`,me,[r(`h2`,he,l(e.$t(`wan.name.resolution`)),1),a(_,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,class:`value`,placeholder:e.$t(`wan.placeholder.select`),clearable:``},{default:m(()=>[(u(!0),p(g,null,c(e.options,e=>(u(),n(h,{key:e.value,label:e.label,value:e.value},{default:m(()=>[r(`span`,ge,l(e.label),1)]),_:2},1032,[`label`,`value`]))),128))]),_:1},8,[`modelValue`,`placeholder`])])}var ve=O(pe,[[`render`,_e],[`__scopeId`,`data-v-3e39f44e`]]),ye=5,be=s({name:`DurationSelector`,components:{ElSelect:y,ElOption:b},computed:{options(){return[{value:5,label:this.$t(`wan.name.duration5s`)},{value:10,label:this.$t(`wan.name.duration10s`)},{value:15,label:this.$t(`wan.name.duration15s`)}]},value:{get(){return this.$store.state.wan?.config?.duration},set(e){this.$store.commit(`wan/setConfig`,{...this.$store.state.wan?.config,duration:e})}}},mounted(){this.value||=ye}}),xe={class:`field`},Se={class:`title font-bold`},Ce={class:`float-left`};function we(e,t,i,o,s,d){let h=f(`el-option`),_=f(`el-select`);return u(),p(`div`,xe,[r(`h2`,Se,l(e.$t(`wan.name.duration`)),1),a(_,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,class:`value`,placeholder:e.$t(`wan.placeholder.select`),clearable:``},{default:m(()=>[(u(!0),p(g,null,c(e.options,e=>(u(),n(h,{key:e.value,label:e.label,value:e.value},{default:m(()=>[r(`span`,Ce,l(e.label),1)]),_:2},1032,[`label`,`value`]))),128))]),_:1},8,[`modelValue`,`placeholder`])])}var Te=O(be,[[`render`,we],[`__scopeId`,`data-v-5f35a2cf`]]),Ee=s({name:`ImageUrlInput`,components:{ElUpload:x,ElButton:v,InfoIcon:U,ImagePreview:B},mixins:[P,I],data(){return{fileList:[],uploadUrl:M()+`/api/v1/files/`}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e.url).filter(e=>e!==void 0)},value:{get(){return this.$store.state.wan?.config?.image_url},set(){let e=this.urls?.[0];this.$store.commit(`wan/setConfig`,{...this.$store.state.wan?.config,image_url:e})}}},mounted(){this.value||=void 0,this.onSetImageUrl()},methods:{onExceed(){F.warning(this.$t(`wan.message.uploadImageExceed`))},onError(){F.error(this.$t(`wan.message.uploadImageError`))},async onRemove(){F.error(this.$t(`wan.message.uploadImageError`))},onSetImageUrl(){let e=this.urls?.[0];this.$store.commit(`wan/setConfig`,{...this.$store.state.wan?.config,image_url:e})},async onSuccess(){this.onSetImageUrl()}}}),De={class:`relative`},Oe={class:`flex justify-between`},ke={class:`flex justify-start items-center`},Ae={class:`text-sm font-bold`};function je(e,t,s,c,d,h){let g=f(`info-icon`),_=f(`image-preview`),v=f(`el-button`),y=f(`el-upload`);return u(),p(`div`,De,[r(`div`,Oe,[r(`div`,ke,[r(`span`,Ae,l(e.$t(`wan.name.imageUrl`)),1),a(g,{content:e.$t(`wan.description.imageUrl`),class:`info`},null,8,[`content`])])]),a(y,{"file-list":e.fileList,"onUpdate:fileList":t[0]||=t=>e.fileList=t,accept:`.png,.jpg,.jpeg,.gif,.bmp,.webp`,name:`file`,"show-file-list":!0,limit:1,multiple:!1,"list-type":`picture`,action:e.uploadUrl,"on-exceed":e.onExceed,"on-error":e.onError,"on-remove":e.onRemove,"on-success":e.onSuccess,headers:e.headers},{file:m(({file:t})=>[t.url&&t.percentage!==void 0?(u(),n(_,{key:0,url:t.url,name:t.name,percentage:t.percentage,onRemove:n=>e.fileList.splice(e.fileList.indexOf(t),1)},null,8,[`url`,`name`,`percentage`,`onRemove`])):o(``,!0)]),default:m(()=>[a(v,{size:`small`,type:`primary`,class:`btn btn-upload`,round:``},{default:m(()=>[i(l(e.$t(`wan.button.uploadImageUrl`)),1)]),_:1})]),_:1},8,[`file-list`,`action`,`on-exceed`,`on-error`,`on-remove`,`on-success`,`headers`])])}var Me=O(Ee,[[`render`,je],[`__scopeId`,`data-v-41a69004`]]),Ne=s({name:`PromptInput`,components:{PromptTextarea:K},computed:{prompt:{get(){return this.$store.state.wan?.config?.prompt},set(e){this.$store.commit(`wan/setConfig`,{...this.$store.state.wan?.config,prompt:e})}}},mounted(){this.prompt||=``}});function Pe(e,t,r,i,a,o){let s=f(`prompt-textarea`);return u(),n(s,{modelValue:e.prompt,"onUpdate:modelValue":t[0]||=t=>e.prompt=t,title:e.$t(`wan.name.prompt`),info:e.$t(`wan.description.prompt`),placeholder:e.$t(`wan.placeholder.prompt`)},null,8,[`modelValue`,`title`,`info`,`placeholder`])}var Fe=s({name:`PresetPanel`,components:{ElButton:v,FontAwesomeIcon:R,PromptInput:O(Ne,[[`render`,Pe]]),ImageUrlInput:Me,ModelSelector:de,ResolutionSelector:ve,DurationSelector:Te,Consumption:J},emits:[`generate`],computed:{config(){return this.$store.state.wan?.config},consumption(){return A(this.config,this.service?.cost)},service(){return this.$store.state.wan?.service},supportsResolution(){let e=this.config?.model;return e===`wan2.6-t2v`||e===`wan2.6-i2v`||e===`wan2.6-i2v-flash`},supportsDuration(){return this.config?.model===`wan2.6-t2v`},supportsImageUrl(){let e=this.config?.model;return e===`wan2.6-i2v`||e===`wan2.6-i2v-flash`}},methods:{onGenerate(){this.$emit(`generate`)}}}),Ie={class:`flex flex-col h-full`},Le={class:`flex-1 overflow-y-auto p-5`},Re={class:`flex flex-col items-center justify-center px-5 pb-5`};function ze(e,t,s,c,d,h){let g=f(`prompt-input`),_=f(`model-selector`),v=f(`resolution-selector`),y=f(`duration-selector`),b=f(`image-url-input`),x=f(`consumption`),S=f(`font-awesome-icon`),C=f(`el-button`);return u(),p(`div`,Ie,[r(`div`,Le,[a(g,{class:`mb-4`}),a(_,{class:`mb-4`}),e.supportsResolution?(u(),n(v,{key:0,class:`mb-4`})):o(``,!0),e.supportsDuration?(u(),n(y,{key:1,class:`mb-4`})):o(``,!0),e.supportsImageUrl?(u(),n(b,{key:2,class:`mb-2`})):o(``,!0)]),r(`div`,Re,[a(x,{value:e.consumption,service:e.service},null,8,[`value`,`service`]),a(C,{type:`primary`,class:`btn w-full`,round:``,onClick:e.onGenerate},{default:m(()=>[a(S,{icon:`fa-solid fa-magic`,class:`mr-2`}),i(` `+l(e.$t(`wan.button.generate`)),1)]),_:1},8,[`onClick`])])])}var Be=O(Fe,[[`render`,ze]]),Ve=s({name:`TaskPreview`,components:{ElImage:C,CopyToClipboard:z,FontAwesomeIcon:R,ElAlert:w,VideoPlayer:X,ElTooltip:S,ElButton:v,ApiCodeButton:Y},props:{modelValue:{type:Object,required:!0}},setup(){return{WAN_LOGO:D}},computed:{application(){return this.$store.state.wan?.application},config(){return this.$store.state.wan?.config}},methods:{onDownload(e){console.debug(`on download wan video`,e),window.open(e,`_blank`)}}}),He={class:`preview`},Ue={class:`left`},We={class:`main`},Ge={class:`bot`},Ke={class:`datetime`},qe={class:`info`},Je={key:0,class:`prompt mt-2`},Ye={key:0},Xe={key:1},Ze={key:0,class:t({content:!0,failed:!0})},Qe={key:0,class:`mb-4`},$e={key:1,class:t({operations:!0,"mt-2":!0})},et={key:0,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},tt={class:`text-[var(--el-text-color-regular)] text-xs mb-2`},$={key:1,class:`text-[var(--el-text-color-regular)] text-xs mb-0`},nt={key:1,class:t({content:!0})},rt={class:`text-[var(--el-text-color-regular)] text-xs mb-2`},it={class:`text-[var(--el-text-color-regular)] text-xs mb-2`},at={key:0,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},ot={class:`text-[var(--el-text-color-regular)] text-xs mb-0`},st={key:2,class:t({content:!0})},ct={class:`text-[var(--el-text-color-regular)] text-xs mb-0`};function lt(e,t,n,s,c,d){let h=f(`el-image`),g=f(`video-player`),v=f(`el-button`),y=f(`el-tooltip`),b=f(`api-code-button`),x=f(`font-awesome-icon`),S=f(`copy-to-clipboard`),C=f(`el-alert`);return u(),p(`div`,He,[r(`div`,Ue,[a(h,{src:e.WAN_LOGO,class:`avatar`},null,8,[`src`])]),r(`div`,We,[r(`div`,Ge,[i(l(e.$t(`wan.name.wanBot`))+` `,1),r(`span`,Ke,l(e.$dayjs.format(``+new Date(parseFloat((e.modelValue?.created_at||``).toString())*1e3))),1)]),r(`div`,qe,[e.modelValue?.request?.prompt?(u(),p(`p`,Je,[i(l(e.modelValue?.request?.prompt)+` `,1),e.modelValue?.response?o(``,!0):(u(),p(`span`,Ye,` - (`+l(e.$t(`wan.status.pending`))+`) `,1)),e.modelValue?.response?.state===`processing`||e.modelValue?.response?.state===`pending`||e.modelValue?.response?.state===`running`?(u(),p(`span`,Xe,` - (`+l(e.$t(`wan.status.processing`))+`) `,1)):o(``,!0)])):o(``,!0)]),e.modelValue?.response?.success===!0?(u(),p(`div`,Ze,[e.modelValue?.response?.video_url?(u(),p(`div`,Qe,[a(g,{src:e.modelValue?.response?.video_url},null,8,[`src`])])):o(``,!0),e.modelValue?.response?.video_url?(u(),p(`div`,$e,[a(y,{class:`box-item`,effect:`dark`,content:e.$t(`wan.message.downloadVideo`),placement:`top-start`},{default:m(()=>[a(v,{type:`info`,size:`small`,class:`mb-2`,onClick:t[0]||=_(t=>e.onDownload(e.modelValue?.response?.video_url),[`stop`])},{default:m(()=>[i(l(e.$t(`wan.button.download`)),1)]),_:1})]),_:1},8,[`content`]),a(b,{path:`/wan/videos`,body:e.modelValue?.request},null,8,[`body`])])):o(``,!0),a(C,{closable:!1,class:`mt-2 success`},{default:m(()=>[e.modelValue?.request?.model?(u(),p(`p`,et,[a(x,{icon:`fa-solid fa-hashtag`,class:`mr-1`}),i(` `+l(e.$t(`wan.name.model`))+`: `+l(e.modelValue?.request?.model)+` `,1),a(S,{content:e.modelValue?.id},null,8,[`content`])])):o(``,!0),r(`p`,tt,[a(x,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+l(e.$t(`wan.name.taskId`))+`: `+l(e.modelValue?.id)+` `,1),a(S,{content:e.modelValue?.id},null,8,[`content`])]),e.modelValue?.elapsed?(u(),p(`p`,$,[a(x,{icon:`fa-solid fa-clock`,class:`mr-1`}),i(` `+l(e.$t(`wan.name.elapsed`))+`: `+l(e.modelValue?.elapsed?.toFixed(2))+`s `,1)])):o(``,!0)]),_:1})])):o(``,!0),e.modelValue?.response?.success===!1?(u(),p(`div`,nt,[a(C,{closable:!1,class:`failure`},{template:m(()=>[a(x,{icon:`fa-solid fa-exclamation-triangle`,class:`mr-1`}),i(` `+l(e.$t(`wan.name.failure`)),1)]),default:m(()=>[r(`p`,rt,[a(x,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+l(e.$t(`wan.name.taskId`))+`: `+l(e.modelValue?.id)+` `,1),a(S,{content:e.modelValue?.id},null,8,[`content`])]),r(`p`,it,[a(x,{icon:`fa-solid fa-circle-info`,class:`mr-1`}),i(` `+l(e.$t(`wan.name.failureReason`))+`: `+l(e.modelValue?.response?.error?.message)+` `,1),a(S,{content:e.modelValue?.response?.error?.message},null,8,[`content`])]),e.modelValue?.elapsed?(u(),p(`p`,at,[a(x,{icon:`fa-solid fa-clock`,class:`mr-1`}),i(` `+l(e.$t(`wan.name.elapsed`))+`: `+l(e.modelValue?.elapsed?.toFixed(2))+`s `,1)])):o(``,!0),r(`p`,ot,[a(x,{icon:`fa-solid fa-hashtag`,class:`mr-1`}),i(` `+l(e.$t(`wan.name.traceId`))+`: `+l(e.modelValue?.response?.trace_id)+` `,1),a(S,{content:e.modelValue?.response?.trace_id},null,8,[`content`])])]),_:1})])):o(``,!0),e.modelValue?.response?.success===void 0?(u(),p(`div`,st,[a(C,{closable:!1,class:`info`},{template:m(()=>[a(x,{icon:`fa-solid fa-exclamation-triangle`,class:`mr-1`}),i(` `+l(e.$t(`wan.name.failure`)),1)]),default:m(()=>[r(`p`,ct,[a(x,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+l(e.$t(`wan.name.taskId`))+`: `+l(e.modelValue?.id)+` `,1),a(S,{content:e.modelValue?.id},null,8,[`content`])])]),_:1})])):o(``,!0)])])}var ut=s({name:`RecentPanel`,components:{TaskPreview:O(Ve,[[`render`,lt],[`__scopeId`,`data-v-916b8970`]]),BotPlaceholder:H,NoTasks:q,ScrollList:W},props:{loading:{type:Boolean,default:!1}},emits:[`reach-top`],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.wan?.tasks,items:this.$store.state.wan?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),dt={key:0},ft={key:2,class:`w-full h-full flex items-center justify-center`};function pt(e,t,r,i,s,l){let d=f(`bot-placeholder`),h=f(`task-preview`),_=f(`scroll-list`),v=f(`no-tasks`);return u(),p(g,null,[e.tasks?.items===void 0?(u(),p(`div`,dt,[a(d)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(u(),n(_,{key:1,ref:`scrollList`,class:`tasks w-full h-full overflow-y-auto`,loading:e.loading,onReachTop:t[0]||=t=>e.$emit(`reach-top`)},{default:m(()=>[(u(!0),p(g,null,c(e.tasks?.items,e=>(u(),n(h,{key:e.id,"model-value":e},null,8,[`model-value`]))),128))]),_:1},8,[`loading`])):o(``,!0),e.tasks?.items?.length===0?(u(),p(`div`,ft,[a(v)])):o(``,!0)],64)}var mt=O(ut,[[`render`,pt]]),ht=ee(`wan`),gt=s({name:`WanIndex`,components:{ConfigPanel:Be,Layout:ae,RecentPanel:mt},mixins:[te],inject:[`initialized`],data(){return{task:void 0,job:0,timer:void 0,loadingMore:!1,fetchingTasks:!1}},computed:{applicationsLoading(){return this.$store.state.wan?.status?.getApplications===L.Request},tasksLoading(){return this.$store.state.wan?.status?.getTasks===L.Request||this.fetchingTasks},credential(){return this.$store.state.wan.credential},config(){return this.$store.state.wan.config},application(){return this.$store.state.wan.application},tasks(){return this.$store.state.wan.tasks}},watch:{tasks:{handler(e,t){e?.items?.length>t?.items?.length&&console.debug(`new tasks detected`)},deep:!0},initialized:{async handler(e){e&&(console.debug(`layout initialized`),await this.onGetTasks(),await this.onScrollDown(),this.job=window.setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){window.clearInterval(this.job)},methods:{async onReachTop(){await G({tasks:this.tasks,getTasks:()=>this.tasks,loading:this.loadingMore,setLoading:e=>this.loadingMore=e,isBlocked:()=>this.tasksLoading||this.applicationsLoading,fetch:e=>this.onGetTasks({createdAtMax:e}),getScrollElement:()=>this.getTasksScrollElement()})},async onGetService(){console.debug(`start onGetService`),await this.$store.dispatch(`wan/getService`),console.debug(`end onGetService`)},async onGetApplication(){console.debug(`start onGetApplication`),await this.$store.dispatch(`wan/getApplications`),console.debug(`end onGetApplication`),await this.onGetTasks()},async onScrollDown(){await this.$nextTick();let e=this.getTasksScrollElement();e&&(e.scrollTop=e.scrollHeight)},async onGetTasks(e){if(this.applicationsLoading||this.fetchingTasks){console.debug(`loading`);return}console.debug(`start onGetTasks`,e);let{limit:t=5,createdAtMin:n,createdAtMax:r}=e||{};console.debug(`limit`,t,`createdAtMin`,n,`createdAtMax`,r),this.fetchingTasks=!0;try{await this.$store.dispatch(`wan/getTasks`,{limit:t,createdAtMin:n,createdAtMax:r})}finally{this.fetchingTasks=!1}},async onGenerate(){if(!j(this.uploadTracker,e=>this.$t(e),e=>F.warning(e)))return;let e={...this.config,callback_url:ht},t=this.credential?.token;if(!t){console.error(`no token specified`);return}F.info(this.$t(`wan.message.startingTask`)),k(`wan`,N.generate(e,{token:t})).then(()=>{F.success(this.$t(`wan.message.startTaskSuccess`))}).catch(e=>{(e?.response?.data)?.error?.code===`used_up`?F.error(this.$t(`wan.message.usedUp`)):F.error(this.$t(`wan.message.startTaskFailed`))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function _t(e,t,r,i,o,s){let c=f(`config-panel`),l=f(`recent-panel`),d=f(`layout`);return u(),n(d,null,{config:m(()=>[a(c,{onGenerate:e.onGenerate},null,8,[`onGenerate`])]),result:m(()=>[a(l,{ref:`recentPanel`,loading:e.loadingMore,onReachTop:e.onReachTop},null,8,[`loading`,`onReachTop`])]),_:1})}var vt=O(gt,[[`render`,_t]]);export{vt as default};
|
|
1
|
+
import"./rolldown-runtime--c01j_DQ.js";import{$ as e,Bt as t,D as n,E as r,M as i,N as a,O as o,P as s,Q as c,Ut as l,X as u,_ as d,et as f,k as p,lt as m,ut as h,x as g,y as _}from"./vendor-chart-mdwpew_o.js";import{t as v}from"./button-DWzbdjZV.js";import{r as y,t as b}from"./select-CYdISXBV.js";import{t as x}from"./upload-CHAO8dYa.js";import{t as S}from"./tooltip-C3PYfh8V.js";import{t as C}from"./image-tItcr5tZ.js";import{t as w}from"./alert-BJj7gY4q.js";import{t as T}from"./drawer-BvYPSxXh.js";import{dt as E,ft as D,hi as ee}from"./constants-B6_fTlam.js";import{At as te,E as O,Fn as k,Nt as A,Ot as j,Sr as M,Yt as N,jt as P,kr as F,kt as I,yr as L}from"./index-DpREqzJQ.js";import{t as R}from"./index.es-DkXuZNXE.js";import{t as z}from"./CopyToClipboard-DXA4nHxo.js";import{t as B}from"./ImagePreview-Bkw_taCt.js";import{n as V}from"./taskDrawerMixin-Cr17Yxqk.js";import{t as H}from"./BotPlaceholder-R_nAAbft.js";import{i as U,n as W,t as G}from"./pagination-BQOE0Lce.js";import{n as K,t as q}from"./NoTasks-568fhAGt.js";import{t as J}from"./Consumption-CjrpUNmV.js";import{t as Y}from"./ApiCodeButton-DXN7iB8l.js";import{t as X}from"./VideoPlayer-BjsbkQZc.js";var Z=s({name:`LayoutWan`,components:{ElDrawer:T,ElButton:v,FontAwesomeIcon:R},mixins:[V]}),Q={class:`main flex flex-row flex-1`},ne={class:`config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]`},re={class:`result h-full p-6 flex-1 flex flex-col min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]`};function ie(t,n,i,o,s,c){let l=f(`font-awesome-icon`),g=f(`el-button`),_=f(`el-drawer`);return u(),p(`div`,Q,[r(`div`,ne,[e(t.$slots,`config`,{},void 0,!0)]),r(`div`,re,[e(t.$slots,`result`,{},void 0,!0)]),h(a(g,{circle:``,class:`menu`,onClick:n[0]||=e=>t.drawer=!0},{default:m(()=>[a(l,{icon:`fa-solid fa-magic`})]),_:1},512),[[d,!t.tasksEmpty]]),a(_,{modelValue:t.drawer,"onUpdate:modelValue":n[1]||=e=>t.drawer=e,direction:`ltr`,"with-header":!1,size:`340px`},{default:m(()=>[e(t.$slots,`config`,{},void 0,!0)]),_:3},8,[`modelValue`])])}var ae=O(Z,[[`render`,ie],[`__scopeId`,`data-v-1ffeb6b4`]]),oe=s({name:`ModelSelector`,components:{ElSelect:y,ElOption:b},data(){return{}},computed:{options(){return[{value:`wan2.6-t2v`,label:this.$t(`wan.button.modelT2v`)},{value:`wan2.6-i2v`,label:this.$t(`wan.button.modelI2v`)},{value:`wan2.6-i2v-flash`,label:this.$t(`wan.button.modelI2vFlash`)},{value:`wan2.6-r2v`,label:this.$t(`wan.button.modelR2v`)}]},value:{get(){return this.$store.state.wan?.config?.model},set(e){this.$store.commit(`wan/setConfig`,{...this.$store.state.wan?.config,model:e})}}},mounted(){this.value||=E}}),se={class:`field`},ce={class:`title font-bold`},le={class:`float-left`};function ue(e,t,i,o,s,d){let h=f(`el-option`),_=f(`el-select`);return u(),p(`div`,se,[r(`h2`,ce,l(e.$t(`wan.name.model`)),1),a(_,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,class:`value`,placeholder:e.$t(`wan.placeholder.select`),clearable:``},{default:m(()=>[(u(!0),p(g,null,c(e.options,e=>(u(),n(h,{key:e.value,label:e.label,value:e.value},{default:m(()=>[r(`span`,le,l(e.label),1)]),_:2},1032,[`label`,`value`]))),128))]),_:1},8,[`modelValue`,`placeholder`])])}var de=O(oe,[[`render`,ue],[`__scopeId`,`data-v-eb090beb`]]),fe=`720p`,pe=s({name:`ResolutionSelector`,components:{ElSelect:y,ElOption:b},computed:{options(){return[{value:`480p`,label:this.$t(`wan.name.resolution480p`)},{value:`720p`,label:this.$t(`wan.name.resolution720p`)},{value:`1080p`,label:this.$t(`wan.name.resolution1080p`)}]},value:{get(){return this.$store.state.wan?.config?.resolution},set(e){this.$store.commit(`wan/setConfig`,{...this.$store.state.wan?.config,resolution:e})}}},mounted(){this.value||=fe}}),me={class:`field`},he={class:`title font-bold`},ge={class:`float-left`};function _e(e,t,i,o,s,d){let h=f(`el-option`),_=f(`el-select`);return u(),p(`div`,me,[r(`h2`,he,l(e.$t(`wan.name.resolution`)),1),a(_,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,class:`value`,placeholder:e.$t(`wan.placeholder.select`),clearable:``},{default:m(()=>[(u(!0),p(g,null,c(e.options,e=>(u(),n(h,{key:e.value,label:e.label,value:e.value},{default:m(()=>[r(`span`,ge,l(e.label),1)]),_:2},1032,[`label`,`value`]))),128))]),_:1},8,[`modelValue`,`placeholder`])])}var ve=O(pe,[[`render`,_e],[`__scopeId`,`data-v-3e39f44e`]]),ye=5,be=s({name:`DurationSelector`,components:{ElSelect:y,ElOption:b},computed:{options(){return[{value:5,label:this.$t(`wan.name.duration5s`)},{value:10,label:this.$t(`wan.name.duration10s`)},{value:15,label:this.$t(`wan.name.duration15s`)}]},value:{get(){return this.$store.state.wan?.config?.duration},set(e){this.$store.commit(`wan/setConfig`,{...this.$store.state.wan?.config,duration:e})}}},mounted(){this.value||=ye}}),xe={class:`field`},Se={class:`title font-bold`},Ce={class:`float-left`};function we(e,t,i,o,s,d){let h=f(`el-option`),_=f(`el-select`);return u(),p(`div`,xe,[r(`h2`,Se,l(e.$t(`wan.name.duration`)),1),a(_,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,class:`value`,placeholder:e.$t(`wan.placeholder.select`),clearable:``},{default:m(()=>[(u(!0),p(g,null,c(e.options,e=>(u(),n(h,{key:e.value,label:e.label,value:e.value},{default:m(()=>[r(`span`,Ce,l(e.label),1)]),_:2},1032,[`label`,`value`]))),128))]),_:1},8,[`modelValue`,`placeholder`])])}var Te=O(be,[[`render`,we],[`__scopeId`,`data-v-5f35a2cf`]]),Ee=s({name:`ImageUrlInput`,components:{ElUpload:x,ElButton:v,InfoIcon:U,ImagePreview:B},mixins:[P,I],data(){return{fileList:[],uploadUrl:M()+`/api/v1/files/`}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e.url).filter(e=>e!==void 0)},value:{get(){return this.$store.state.wan?.config?.image_url},set(){let e=this.urls?.[0];this.$store.commit(`wan/setConfig`,{...this.$store.state.wan?.config,image_url:e})}}},mounted(){this.value||=void 0,this.onSetImageUrl()},methods:{onExceed(){F.warning(this.$t(`wan.message.uploadImageExceed`))},onError(){F.error(this.$t(`wan.message.uploadImageError`))},async onRemove(){F.error(this.$t(`wan.message.uploadImageError`))},onSetImageUrl(){let e=this.urls?.[0];this.$store.commit(`wan/setConfig`,{...this.$store.state.wan?.config,image_url:e})},async onSuccess(){this.onSetImageUrl()}}}),De={class:`relative`},Oe={class:`flex justify-between`},ke={class:`flex justify-start items-center`},Ae={class:`text-sm font-bold`};function je(e,t,s,c,d,h){let g=f(`info-icon`),_=f(`image-preview`),v=f(`el-button`),y=f(`el-upload`);return u(),p(`div`,De,[r(`div`,Oe,[r(`div`,ke,[r(`span`,Ae,l(e.$t(`wan.name.imageUrl`)),1),a(g,{content:e.$t(`wan.description.imageUrl`),class:`info`},null,8,[`content`])])]),a(y,{"file-list":e.fileList,"onUpdate:fileList":t[0]||=t=>e.fileList=t,accept:`.png,.jpg,.jpeg,.gif,.bmp,.webp`,name:`file`,"show-file-list":!0,limit:1,multiple:!1,"list-type":`picture`,action:e.uploadUrl,"on-exceed":e.onExceed,"on-error":e.onError,"on-remove":e.onRemove,"on-success":e.onSuccess,headers:e.headers},{file:m(({file:t})=>[t.url&&t.percentage!==void 0?(u(),n(_,{key:0,url:t.url,name:t.name,percentage:t.percentage,onRemove:n=>e.fileList.splice(e.fileList.indexOf(t),1)},null,8,[`url`,`name`,`percentage`,`onRemove`])):o(``,!0)]),default:m(()=>[a(v,{size:`small`,type:`primary`,class:`btn btn-upload`,round:``},{default:m(()=>[i(l(e.$t(`wan.button.uploadImageUrl`)),1)]),_:1})]),_:1},8,[`file-list`,`action`,`on-exceed`,`on-error`,`on-remove`,`on-success`,`headers`])])}var Me=O(Ee,[[`render`,je],[`__scopeId`,`data-v-41a69004`]]),Ne=s({name:`PromptInput`,components:{PromptTextarea:K},computed:{prompt:{get(){return this.$store.state.wan?.config?.prompt},set(e){this.$store.commit(`wan/setConfig`,{...this.$store.state.wan?.config,prompt:e})}}},mounted(){this.prompt||=``}});function Pe(e,t,r,i,a,o){let s=f(`prompt-textarea`);return u(),n(s,{modelValue:e.prompt,"onUpdate:modelValue":t[0]||=t=>e.prompt=t,title:e.$t(`wan.name.prompt`),info:e.$t(`wan.description.prompt`),placeholder:e.$t(`wan.placeholder.prompt`)},null,8,[`modelValue`,`title`,`info`,`placeholder`])}var Fe=s({name:`PresetPanel`,components:{ElButton:v,FontAwesomeIcon:R,PromptInput:O(Ne,[[`render`,Pe]]),ImageUrlInput:Me,ModelSelector:de,ResolutionSelector:ve,DurationSelector:Te,Consumption:J},emits:[`generate`],computed:{config(){return this.$store.state.wan?.config},consumption(){return A(this.config,this.service?.cost)},service(){return this.$store.state.wan?.service},supportsResolution(){let e=this.config?.model;return e===`wan2.6-t2v`||e===`wan2.6-i2v`||e===`wan2.6-i2v-flash`},supportsDuration(){return this.config?.model===`wan2.6-t2v`},supportsImageUrl(){let e=this.config?.model;return e===`wan2.6-i2v`||e===`wan2.6-i2v-flash`}},methods:{onGenerate(){this.$emit(`generate`)}}}),Ie={class:`flex flex-col h-full`},Le={class:`flex-1 overflow-y-auto p-5`},Re={class:`flex flex-col items-center justify-center px-5 pb-5`};function ze(e,t,s,c,d,h){let g=f(`prompt-input`),_=f(`model-selector`),v=f(`resolution-selector`),y=f(`duration-selector`),b=f(`image-url-input`),x=f(`consumption`),S=f(`font-awesome-icon`),C=f(`el-button`);return u(),p(`div`,Ie,[r(`div`,Le,[a(g,{class:`mb-4`}),a(_,{class:`mb-4`}),e.supportsResolution?(u(),n(v,{key:0,class:`mb-4`})):o(``,!0),e.supportsDuration?(u(),n(y,{key:1,class:`mb-4`})):o(``,!0),e.supportsImageUrl?(u(),n(b,{key:2,class:`mb-2`})):o(``,!0)]),r(`div`,Re,[a(x,{value:e.consumption,service:e.service},null,8,[`value`,`service`]),a(C,{type:`primary`,class:`btn w-full`,round:``,onClick:e.onGenerate},{default:m(()=>[a(S,{icon:`fa-solid fa-magic`,class:`mr-2`}),i(` `+l(e.$t(`wan.button.generate`)),1)]),_:1},8,[`onClick`])])])}var Be=O(Fe,[[`render`,ze]]),Ve=s({name:`TaskPreview`,components:{ElImage:C,CopyToClipboard:z,FontAwesomeIcon:R,ElAlert:w,VideoPlayer:X,ElTooltip:S,ElButton:v,ApiCodeButton:Y},props:{modelValue:{type:Object,required:!0}},setup(){return{WAN_LOGO:D}},computed:{application(){return this.$store.state.wan?.application},config(){return this.$store.state.wan?.config}},methods:{onDownload(e){console.debug(`on download wan video`,e),window.open(e,`_blank`)}}}),He={class:`preview`},Ue={class:`left`},We={class:`main`},Ge={class:`bot`},Ke={class:`datetime`},qe={class:`info`},Je={key:0,class:`prompt mt-2`},Ye={key:0},Xe={key:1},Ze={key:0,class:t({content:!0,failed:!0})},Qe={key:0,class:`mb-4`},$e={key:1,class:t({operations:!0,"mt-2":!0})},et={key:0,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},tt={class:`text-[var(--el-text-color-regular)] text-xs mb-2`},$={key:1,class:`text-[var(--el-text-color-regular)] text-xs mb-0`},nt={key:1,class:t({content:!0})},rt={class:`text-[var(--el-text-color-regular)] text-xs mb-2`},it={class:`text-[var(--el-text-color-regular)] text-xs mb-2`},at={key:0,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},ot={class:`text-[var(--el-text-color-regular)] text-xs mb-0`},st={key:2,class:t({content:!0})},ct={class:`text-[var(--el-text-color-regular)] text-xs mb-0`};function lt(e,t,n,s,c,d){let h=f(`el-image`),g=f(`video-player`),v=f(`el-button`),y=f(`el-tooltip`),b=f(`api-code-button`),x=f(`font-awesome-icon`),S=f(`copy-to-clipboard`),C=f(`el-alert`);return u(),p(`div`,He,[r(`div`,Ue,[a(h,{src:e.WAN_LOGO,class:`avatar`},null,8,[`src`])]),r(`div`,We,[r(`div`,Ge,[i(l(e.$t(`wan.name.wanBot`))+` `,1),r(`span`,Ke,l(e.$dayjs.format(``+new Date(parseFloat((e.modelValue?.created_at||``).toString())*1e3))),1)]),r(`div`,qe,[e.modelValue?.request?.prompt?(u(),p(`p`,Je,[i(l(e.modelValue?.request?.prompt)+` `,1),e.modelValue?.response?o(``,!0):(u(),p(`span`,Ye,` - (`+l(e.$t(`wan.status.pending`))+`) `,1)),e.modelValue?.response?.state===`processing`||e.modelValue?.response?.state===`pending`||e.modelValue?.response?.state===`running`?(u(),p(`span`,Xe,` - (`+l(e.$t(`wan.status.processing`))+`) `,1)):o(``,!0)])):o(``,!0)]),e.modelValue?.response?.success===!0?(u(),p(`div`,Ze,[e.modelValue?.response?.video_url?(u(),p(`div`,Qe,[a(g,{src:e.modelValue?.response?.video_url},null,8,[`src`])])):o(``,!0),e.modelValue?.response?.video_url?(u(),p(`div`,$e,[a(y,{class:`box-item`,effect:`dark`,content:e.$t(`wan.message.downloadVideo`),placement:`top-start`},{default:m(()=>[a(v,{type:`info`,size:`small`,class:`mb-2`,onClick:t[0]||=_(t=>e.onDownload(e.modelValue?.response?.video_url),[`stop`])},{default:m(()=>[i(l(e.$t(`wan.button.download`)),1)]),_:1})]),_:1},8,[`content`]),a(b,{path:`/wan/videos`,body:e.modelValue?.request},null,8,[`body`])])):o(``,!0),a(C,{closable:!1,class:`mt-2 success`},{default:m(()=>[e.modelValue?.request?.model?(u(),p(`p`,et,[a(x,{icon:`fa-solid fa-hashtag`,class:`mr-1`}),i(` `+l(e.$t(`wan.name.model`))+`: `+l(e.modelValue?.request?.model)+` `,1),a(S,{content:e.modelValue?.id},null,8,[`content`])])):o(``,!0),r(`p`,tt,[a(x,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+l(e.$t(`wan.name.taskId`))+`: `+l(e.modelValue?.id)+` `,1),a(S,{content:e.modelValue?.id},null,8,[`content`])]),e.modelValue?.elapsed?(u(),p(`p`,$,[a(x,{icon:`fa-solid fa-clock`,class:`mr-1`}),i(` `+l(e.$t(`wan.name.elapsed`))+`: `+l(e.modelValue?.elapsed?.toFixed(2))+`s `,1)])):o(``,!0)]),_:1})])):o(``,!0),e.modelValue?.response?.success===!1?(u(),p(`div`,nt,[a(C,{closable:!1,class:`failure`},{template:m(()=>[a(x,{icon:`fa-solid fa-exclamation-triangle`,class:`mr-1`}),i(` `+l(e.$t(`wan.name.failure`)),1)]),default:m(()=>[r(`p`,rt,[a(x,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+l(e.$t(`wan.name.taskId`))+`: `+l(e.modelValue?.id)+` `,1),a(S,{content:e.modelValue?.id},null,8,[`content`])]),r(`p`,it,[a(x,{icon:`fa-solid fa-circle-info`,class:`mr-1`}),i(` `+l(e.$t(`wan.name.failureReason`))+`: `+l(e.modelValue?.response?.error?.message)+` `,1),a(S,{content:e.modelValue?.response?.error?.message},null,8,[`content`])]),e.modelValue?.elapsed?(u(),p(`p`,at,[a(x,{icon:`fa-solid fa-clock`,class:`mr-1`}),i(` `+l(e.$t(`wan.name.elapsed`))+`: `+l(e.modelValue?.elapsed?.toFixed(2))+`s `,1)])):o(``,!0),r(`p`,ot,[a(x,{icon:`fa-solid fa-hashtag`,class:`mr-1`}),i(` `+l(e.$t(`wan.name.traceId`))+`: `+l(e.modelValue?.response?.trace_id)+` `,1),a(S,{content:e.modelValue?.response?.trace_id},null,8,[`content`])])]),_:1})])):o(``,!0),e.modelValue?.response?.success===void 0?(u(),p(`div`,st,[a(C,{closable:!1,class:`info`},{template:m(()=>[a(x,{icon:`fa-solid fa-exclamation-triangle`,class:`mr-1`}),i(` `+l(e.$t(`wan.name.failure`)),1)]),default:m(()=>[r(`p`,ct,[a(x,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+l(e.$t(`wan.name.taskId`))+`: `+l(e.modelValue?.id)+` `,1),a(S,{content:e.modelValue?.id},null,8,[`content`])])]),_:1})])):o(``,!0)])])}var ut=s({name:`RecentPanel`,components:{TaskPreview:O(Ve,[[`render`,lt],[`__scopeId`,`data-v-916b8970`]]),BotPlaceholder:H,NoTasks:q,ScrollList:W},props:{loading:{type:Boolean,default:!1}},emits:[`reach-top`],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.wan?.tasks,items:this.$store.state.wan?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),dt={key:0},ft={key:2,class:`w-full h-full flex items-center justify-center`};function pt(e,t,r,i,s,l){let d=f(`bot-placeholder`),h=f(`task-preview`),_=f(`scroll-list`),v=f(`no-tasks`);return u(),p(g,null,[e.tasks?.items===void 0?(u(),p(`div`,dt,[a(d)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(u(),n(_,{key:1,ref:`scrollList`,class:`tasks w-full h-full overflow-y-auto`,loading:e.loading,onReachTop:t[0]||=t=>e.$emit(`reach-top`)},{default:m(()=>[(u(!0),p(g,null,c(e.tasks?.items,e=>(u(),n(h,{key:e.id,"model-value":e},null,8,[`model-value`]))),128))]),_:1},8,[`loading`])):o(``,!0),e.tasks?.items?.length===0?(u(),p(`div`,ft,[a(v)])):o(``,!0)],64)}var mt=O(ut,[[`render`,pt]]),ht=ee(`wan`),gt=s({name:`WanIndex`,components:{ConfigPanel:Be,Layout:ae,RecentPanel:mt},mixins:[te],inject:[`initialized`],data(){return{task:void 0,job:0,timer:void 0,loadingMore:!1,fetchingTasks:!1}},computed:{applicationsLoading(){return this.$store.state.wan?.status?.getApplications===L.Request},tasksLoading(){return this.$store.state.wan?.status?.getTasks===L.Request||this.fetchingTasks},credential(){return this.$store.state.wan.credential},config(){return this.$store.state.wan.config},application(){return this.$store.state.wan.application},tasks(){return this.$store.state.wan.tasks}},watch:{tasks:{handler(e,t){e?.items?.length>t?.items?.length&&console.debug(`new tasks detected`)},deep:!0},initialized:{async handler(e){e&&(console.debug(`layout initialized`),await this.onGetTasks(),await this.onScrollDown(),this.job=window.setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){window.clearInterval(this.job)},methods:{async onReachTop(){await G({tasks:this.tasks,getTasks:()=>this.tasks,loading:this.loadingMore,setLoading:e=>this.loadingMore=e,isBlocked:()=>this.tasksLoading||this.applicationsLoading,fetch:e=>this.onGetTasks({createdAtMax:e}),getScrollElement:()=>this.getTasksScrollElement()})},async onGetService(){console.debug(`start onGetService`),await this.$store.dispatch(`wan/getService`),console.debug(`end onGetService`)},async onGetApplication(){console.debug(`start onGetApplication`),await this.$store.dispatch(`wan/getApplications`),console.debug(`end onGetApplication`),await this.onGetTasks()},async onScrollDown(){await this.$nextTick();let e=this.getTasksScrollElement();e&&(e.scrollTop=e.scrollHeight)},async onGetTasks(e){if(this.applicationsLoading||this.fetchingTasks){console.debug(`loading`);return}console.debug(`start onGetTasks`,e);let{limit:t=5,createdAtMin:n,createdAtMax:r}=e||{};console.debug(`limit`,t,`createdAtMin`,n,`createdAtMax`,r),this.fetchingTasks=!0;try{await this.$store.dispatch(`wan/getTasks`,{limit:t,createdAtMin:n,createdAtMax:r})}finally{this.fetchingTasks=!1}},async onGenerate(){if(!j(this.uploadTracker,e=>this.$t(e),e=>F.warning(e)))return;let e={...this.config,callback_url:ht},t=this.credential?.token;if(!t){console.error(`no token specified`);return}F.info(this.$t(`wan.message.startingTask`)),k(`wan`,N.generate(e,{token:t})).then(()=>{F.success(this.$t(`wan.message.startTaskSuccess`))}).catch(e=>{(e?.response?.data)?.error?.code===`used_up`?F.error(this.$t(`wan.message.usedUp`)):F.error(this.$t(`wan.message.startTaskFailed`))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function _t(e,t,r,i,o,s){let c=f(`config-panel`),l=f(`recent-panel`),d=f(`layout`);return u(),n(d,null,{config:m(()=>[a(c,{onGenerate:e.onGenerate},null,8,[`onGenerate`])]),result:m(()=>[a(l,{ref:`recentPanel`,loading:e.loadingMore,onReachTop:e.onReachTop},null,8,[`loading`,`onReachTop`])]),_:1})}var vt=O(gt,[[`render`,_t]]);export{vt as default};
|