@acedatacloud/nexior 3.278.4 → 3.278.6
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-C1XeBPd6.js → ApiCodeButton-jFmqbRiH.js} +1 -1
- package/dist/assets/{AskUserQuestionCard-oOnoGoYC.js → AskUserQuestionCard-CwbaPqdB.js} +1 -1
- package/dist/assets/{Auth-C3GZzsqu.js → Auth-Ci47S6DL.js} +1 -1
- package/dist/assets/{Bare-ilkcpOfn.js → Bare-oRvY9SO_.js} +1 -1
- package/dist/assets/{BotPlaceholder-C1UVVId0.js → BotPlaceholder-68XVM5HA.js} +1 -1
- package/dist/assets/{BottomFooter-OYMNLKXj.js → BottomFooter-CDh9tDrk.js} +1 -1
- package/dist/assets/{Callback-DZWDH2Jd.js → Callback-FWrgM33B.js} +1 -1
- package/dist/assets/{Console-eAvlamaN.js → Console-Cmrg8HLQ.js} +1 -1
- package/dist/assets/{Consumption-DTpXXWzm.js → Consumption-CtCh2-Du.js} +1 -1
- package/dist/assets/{Conversation-CrkfOD7B.js → Conversation-Dxoe-G0V.js} +1 -1
- package/dist/assets/{CopyToClipboard-CRnka5tK.js → CopyToClipboard-Sk5Grp1_.js} +1 -1
- package/dist/assets/Detail-BmywvZyh.js +2 -0
- package/dist/assets/{Extra-Ca4VzqGk.js → Extra-DCGSw9u8.js} +1 -1
- package/dist/assets/{FilePreview-B-30mO9d.js → FilePreview-D7-o4T0W.js} +1 -1
- package/dist/assets/{Hailuo-BgqAqO-q.js → Hailuo-oSRio97B.js} +1 -1
- package/dist/assets/{History-BTV8BkyG.js → History-CyaFQE2b.js} +1 -1
- package/dist/assets/{ImagePreview-DhCeZxCj.js → ImagePreview-BX6eL7DE.js} +1 -1
- package/dist/assets/{ImageWrapper-D2btRRAT.js → ImageWrapper-CFm9ms8f.js} +1 -1
- package/dist/assets/{Index-DQ65PFeh.js → Index-32O39bTZ.js} +1 -1
- package/dist/assets/{Index-BCDRu724.js → Index-5Z2L7kQ_.js} +1 -1
- package/dist/assets/{Index-DSk0Kd_P.js → Index-AM32Jsd_.js} +1 -1
- package/dist/assets/{Index-83IdsREA.js → Index-B6bsVKGb.js} +1 -1
- package/dist/assets/{Index-Bsro-2ns.js → Index-BLmdYbTP.js} +1 -1
- package/dist/assets/{Index-CVDt8ZY-.js → Index-BNm9dHZk.js} +1 -1
- package/dist/assets/{Index-C-OYMJTV.js → Index-BOv75dyC.js} +1 -1
- package/dist/assets/{Index-W-S932Hw.js → Index-BZkQ4nNA.js} +1 -1
- package/dist/assets/{Index-DBM5oVyB.js → Index-C0VYiD6o.js} +1 -1
- package/dist/assets/{Index-CfdAudvE.js → Index-C531JD6R.js} +1 -1
- package/dist/assets/{Index-N2wA_CDH.js → Index-C82HzKj6.js} +1 -1
- package/dist/assets/{Index-BA46FpHB.js → Index-CCY3ktN7.js} +1 -1
- package/dist/assets/{Index-CaFkCgHI.js → Index-CTUCTP8_.js} +1 -1
- package/dist/assets/{Index-CEMGKfmo.js → Index-CYPPLW67.js} +1 -1
- package/dist/assets/{Index-MeX7MVcf.js → Index-CcEqzpOj.js} +1 -1
- package/dist/assets/{Index-ZUvgUU8o.js → Index-CtXDNdat.js} +1 -1
- package/dist/assets/{Index-C0dMgZnO.js → Index-CvmBXYeH.js} +1 -1
- package/dist/assets/{Index-B-7PZA3P.js → Index-CywKdPI7.js} +1 -1
- package/dist/assets/{Index-DncgncPd.js → Index-DSCqcfuS.js} +1 -1
- package/dist/assets/{Index-BnVtmvSF.js → Index-DtS-es34.js} +1 -1
- package/dist/assets/{Index-DjDTSJh9.js → Index-HGoGUEkP.js} +1 -1
- package/dist/assets/{Index-D9wgOGcc.js → Index-QRPbjXrJ.js} +1 -1
- package/dist/assets/{Index-nGxC_UL9.js → Index-_Bo2-RW1.js} +1 -1
- package/dist/assets/{Index-DzXFliY0.js → Index-fwDg0fqX.js} +1 -1
- package/dist/assets/{Index-DDbrH674.js → Index-offzr0fy.js} +1 -1
- package/dist/assets/{Index-B0rY6XyR.js → Index-z56RdUUb.js} +1 -1
- package/dist/assets/{Invitees-B2dp_P8M.js → Invitees-BgvGRbPh.js} +1 -1
- package/dist/assets/{List-Bpj9MQXe.js → List-BckXjcW9.js} +1 -1
- package/dist/assets/{List-C7cCl6VZ.js → List-ByZV-dj9.js} +1 -1
- package/dist/assets/{List-DthXcxsV.js → List-BzNZPXTG.js} +1 -1
- package/dist/assets/{Main-Dzcz3CQQ.js → Main-wyylddOl.js} +1 -1
- package/dist/assets/{Model-DTA7WYUi.js → Model-DceuLS4F.js} +1 -1
- package/dist/assets/{Navigator-DKSj2Vas.js → Navigator-D3NzM01r.js} +1 -1
- package/dist/assets/{NoTasks-C1jixEiN.js → NoTasks-BiV0deXP.js} +1 -1
- package/dist/assets/{NotFound-D5YnmbEB.js → NotFound-CVkbvO_1.js} +1 -1
- package/dist/assets/{Pagination-BB0rDmAw.js → Pagination-ZOWQKDT0.js} +1 -1
- package/dist/assets/{Pay-DKBMI1b6.js → Pay-BNZJs2EM.js} +1 -1
- package/dist/assets/{Player-BImId-TA.js → Player-BVmBsucF.js} +1 -1
- package/dist/assets/{Seedance-LsGJ233H.js → Seedance-Bm03MMxP.js} +1 -1
- package/dist/assets/{Status-BgvktlpB.js → Status-CrsbP6TF.js} +1 -1
- package/dist/assets/{Subscribe-DYGeuJIU.js → Subscribe-CpBUJDlW.js} +1 -1
- package/dist/assets/{TabSwitcher-DuAqLxUz.js → TabSwitcher-9HZQkVgj.js} +1 -1
- package/dist/assets/{Tts-2qcW53B7.js → Tts-HCcDpqMH.js} +1 -1
- package/dist/assets/{VideoPlayer-gT-2rF-j.js → VideoPlayer-v8gnvaTw.js} +1 -1
- package/dist/assets/{avatar-DLL1117G.js → avatar-BmPQ8jQh.js} +1 -1
- package/dist/assets/{basic-DBGdmFzO.js → basic-Dqxph20p.js} +1 -1
- package/dist/assets/{chat-Famr5Dh3.js → chat-DSYlplVB.js} +1 -1
- package/dist/assets/{codingBridge-C6-bnlhU.js → codingBridge-FP8WVxB9.js} +1 -1
- package/dist/assets/{codingBridgeNotify-CzOJWd-L.js → codingBridgeNotify-CZO6SwJI.js} +2 -2
- package/dist/assets/{collapse-Cdnq-zf7.js → collapse-CAMPyzPR.js} +1 -1
- package/dist/assets/{createTaskActions-BUWJErGu.js → createTaskActions-wg0ye13X.js} +1 -1
- package/dist/assets/{date-picker-DNzuis04.js → date-picker-KV86ypd9.js} +1 -1
- package/dist/assets/{dropdown-5vgk-RLq.js → dropdown-CmezA_CG.js} +1 -1
- package/dist/assets/{esm-DFhLU1h5.js → esm-Bbsdh5Bd.js} +2 -2
- package/dist/assets/{esm-yabqu3BG.js → esm-BwW5YxMW.js} +1 -1
- package/dist/assets/esm-BzWpsj82.js +1 -0
- package/dist/assets/{esm-DNm0jlst.js → esm-CQmtp9Z4.js} +3 -3
- package/dist/assets/{esm-BDz3-BhM.js → esm-Cc69-h7M.js} +1 -1
- package/dist/assets/{esm-CRsYuFpi.js → esm-DSmQmgGd.js} +1 -1
- package/dist/assets/{esm-BmxknlM2.js → esm-Dh-dlIcy.js} +2 -2
- package/dist/assets/{fish-dbdLrzWy.js → fish-C-FtRXfp.js} +1 -1
- package/dist/assets/{flux-DyviWvjE.js → flux-DMiy4O4j.js} +1 -1
- package/dist/assets/{grokvideo-qrd6p2o2.js → grokvideo-Bje6zguo.js} +1 -1
- package/dist/assets/{hailuo-DpxIOlpn.js → hailuo-DsndlA1r.js} +1 -1
- package/dist/assets/{headshots-DJRZcUpJ.js → headshots-_ezlyjK-.js} +1 -1
- package/dist/assets/{image-OB0St7Yu.js → image-C7UiYpMr.js} +1 -1
- package/dist/assets/{index-CTMytxLX.js → index-BSaC0vue.js} +3 -3
- package/dist/assets/{index.browser.esm-C3bG2KzK.js → index.browser.esm-BwOdN9cT.js} +1 -1
- package/dist/assets/{index.es-DsMKNIuW.js → index.es-NL3Dn982.js} +1 -1
- package/dist/assets/{input-number-kZVB4fzD.js → input-number-BqK5b3Jr.js} +1 -1
- package/dist/assets/{kling-Bf1AxoJM.js → kling-eN28pw11.js} +1 -1
- package/dist/assets/{luma-CsV4LQYT.js → luma-DYO_UuS-.js} +1 -1
- package/dist/assets/{midjourney-CMW7Ux6b.js → midjourney-DEYQrtQ7.js} +1 -1
- package/dist/assets/{nanobanana-DnTNTtkq.js → nanobanana-PnTQafGO.js} +1 -1
- package/dist/assets/{openaiimage-CQN4Wul-.js → openaiimage-C2OiAGKp.js} +1 -1
- package/dist/assets/{pagination-CMIlkvfz.js → pagination-D5c7xkGS.js} +1 -1
- package/dist/assets/{pika-Bd75sd5k.js → pika-DM8s8cup.js} +1 -1
- package/dist/assets/{pixverse-BpSWuW92.js → pixverse-C-KDMNR8.js} +1 -1
- package/dist/assets/{popover-CeSAG69n.js → popover-C0rRvXZ8.js} +1 -1
- package/dist/assets/{producer-ITL9iATN.js → producer-DDva0DSK.js} +1 -1
- package/dist/assets/{qrart-CfFMTejm.js → qrart-BrITmJtc.js} +1 -1
- package/dist/assets/{row-Cq8mMRkw.js → row-B4cK4Xdf.js} +1 -1
- package/dist/assets/{seedance-CcheKNrL.js → seedance-WcmHM1hi.js} +1 -1
- package/dist/assets/{seedream-B55ZlbhM.js → seedream-srprw_2Z.js} +1 -1
- package/dist/assets/{select-CTfF5Pq0.js → select-DyEe0uU4.js} +1 -1
- package/dist/assets/{serp-DySJaJQH.js → serp-kCuxrxmG.js} +1 -1
- package/dist/assets/{slider-B5LGYuTq.js → slider-D3OY3HJh.js} +1 -1
- package/dist/assets/{solana-wallets-CtntUGPc.js → solana-wallets-CBcITIOk.js} +2 -2
- package/dist/assets/{solana-wallets-vue-Cy-TvgK3.js → solana-wallets-vue-BL_979pn.js} +1 -1
- package/dist/assets/{sora--H2jRucL.js → sora-CEZ_N-Hq.js} +1 -1
- package/dist/assets/{suno-CgkMICe_.js → suno-D5QYXvID.js} +1 -1
- package/dist/assets/{switch-B2HtIflI.js → switch-CycowGlP.js} +1 -1
- package/dist/assets/{tabs-D-lB-wXk.js → tabs-QBrRiwM9.js} +1 -1
- package/dist/assets/{upload-PztQKfjm.js → upload-2ooOKJyT.js} +1 -1
- package/dist/assets/{veo-rkeTUbPb.js → veo-DU5XwINf.js} +1 -1
- package/dist/assets/{wan-xIj-uREq.js → wan-Ulz6Ib59.js} +1 -1
- package/dist/assets/{web-Cn1Ev3Rd.js → web-BcTVGaLQ.js} +1 -1
- package/dist/assets/{web-BbKwlQEJ.js → web-BtLO8jH4.js} +1 -1
- package/dist/assets/{web-DE99siCh.js → web-CCXvHLrL.js} +1 -1
- package/dist/assets/{web-0yhFotq-.js → web-DkNYQC6W.js} +1 -1
- package/dist/assets/{web-BwhUYrDl.js → web-wAGBwbo5.js} +1 -1
- package/dist/assets/{webextrator-BCG-VK2I.js → webextrator-BLVZOlZc.js} +1 -1
- package/dist/index.html +1 -1
- package/package.json +1 -1
- package/dist/assets/Detail-FaCDRqcy.js +0 -2
- package/dist/assets/esm-DimqjTJx.js +0 -1
|
@@ -1 +1 @@
|
|
|
1
|
-
import"./rolldown-runtime--c01j_DQ.js";import{$ as e,A as t,D as n,F as r,N as i,O as a,P as o,S as s,Vt as c,Wt as l,Z as u,b as d,dt as f,et as p,k as m,tt as h,ut as g,v as _}from"./vendor-chart-BJCvKk8-.js";import{t as v}from"./button-DfsQodL-.js";import{n as y,r as b,t as x}from"./select-CTfF5Pq0.js";import{t as S}from"./upload-PztQKfjm.js";import{t as C}from"./tooltip-BLwTovWL.js";import{t as w}from"./image-OB0St7Yu.js";import{t as T}from"./alert-OvnfgMB-.js";import{t as E}from"./drawer-Dpuj2uIl.js";import{t as D}from"./input-number-kZVB4fzD.js";import{t as ee}from"./switch-B2HtIflI.js";import{_i as te,an as O,cn as k,dn as A,en as ne,fn as j,in as M,ln as N,on as P,rn as F,sn as I,tn as L}from"./constants-CwLEZ_AF.js";import{$t as re,At as ie,E as R,Fn as z,Nt as B,Or as V,Ot as H,Sr as U,jt as W,kr as G,kt as K,yr as q}from"./index-CTMytxLX.js";import{t as J}from"./index.es-DsMKNIuW.js";import{t as Y}from"./CopyToClipboard-CRnka5tK.js";import{t as X}from"./ImagePreview-DhCeZxCj.js";import{n as ae}from"./taskDrawerMixin-DEgO_R5H.js";import{t as oe}from"./BotPlaceholder-C1UVVId0.js";import{i as Z,n as se,t as ce}from"./pagination-CMIlkvfz.js";import{n as le,t as ue}from"./NoTasks-C1jixEiN.js";import{t as de}from"./Consumption-DTpXXWzm.js";import{t as fe}from"./ApiCodeButton-C1XeBPd6.js";import{t as pe}from"./ImageWrapper-D2btRRAT.js";var me=r({name:`LayoutSeedream`,components:{ElDrawer:E,ElButton:v,FontAwesomeIcon:J},mixins:[ae]}),he={class:`main flex flex-row flex-1`},ge={class:`config w-[320px] h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]`},_e={class:`result h-full p-6 flex-1 flex flex-col bg-[var(--app-content-bg)]`};function ve(e,r,i,a,s,c){let l=h(`font-awesome-icon`),d=h(`el-button`),m=h(`el-drawer`);return u(),t(`div`,he,[n(`div`,ge,[p(e.$slots,`config`,{},void 0,!0)]),n(`div`,_e,[p(e.$slots,`result`,{},void 0,!0)]),f(o(d,{circle:``,class:`menu`,onClick:r[0]||=t=>e.drawer=!0},{default:g(()=>[o(l,{icon:`fa-solid fa-magic`})]),_:1},512),[[_,!e.tasksEmpty]]),o(m,{modelValue:e.drawer,"onUpdate:modelValue":r[1]||=t=>e.drawer=t,direction:`ltr`,"with-header":!1,size:`340px`,class:`drawer`},{default:g(()=>[p(e.$slots,`config`,{},void 0,!0)]),_:3},8,[`modelValue`])])}var ye=R(me,[[`render`,ve],[`__scopeId`,`data-v-2a1715d6`]]),be=r({name:`SeedreamPromptInput`,components:{PromptTextarea:le},computed:{prompt:{get(){return this.$store.state.seedream?.config?.prompt},set(e){this.$store.commit(`seedream/setConfig`,{...this.$store.state.seedream?.config,prompt:e})}}},mounted(){this.prompt||=``}});function xe(e,t,n,r,i,o){let s=h(`prompt-textarea`);return u(),a(s,{modelValue:e.prompt,"onUpdate:modelValue":t[0]||=t=>e.prompt=t,title:e.$t(`seedream.name.prompt`),info:e.$t(`seedream.description.prompt`),placeholder:e.$t(`seedream.placeholder.prompt`)},null,8,[`modelValue`,`title`,`info`,`placeholder`])}var Se=R(be,[[`render`,xe]]),Ce={image:!0,imageRequired:!1,sizeTiers:[`1K`,`2K`,`3K`,`4K`],sizeAdaptive:!0,sizePixel:!0,sizePixelDefault:void 0,groupGeneration:!1,seed:!1,guidanceScale:!1,outputFormat:!1,tools:!1};function Q(e){switch(e){case P:return{image:!0,imageRequired:!1,sizeTiers:[`2K`,`3K`,`4K`],sizeAdaptive:!0,sizePixel:!0,groupGeneration:!0,seed:!1,guidanceScale:!1,outputFormat:!0,tools:!0};case O:return{image:!0,imageRequired:!1,sizeTiers:[`2K`,`4K`],sizeAdaptive:!0,sizePixel:!0,groupGeneration:!0,seed:!1,guidanceScale:!1,outputFormat:!1,tools:!1};case M:return{image:!0,imageRequired:!1,sizeTiers:[`1K`,`2K`,`4K`],sizeAdaptive:!0,sizePixel:!0,groupGeneration:!0,seed:!1,guidanceScale:!1,outputFormat:!1,tools:!1};case F:return{image:!1,imageRequired:!1,sizeTiers:[],sizeAdaptive:!1,sizePixel:!0,sizePixelDefault:`1024x1024`,groupGeneration:!1,seed:!0,guidanceScale:!0,guidanceScaleDefault:L[F],outputFormat:!1,tools:!1};case I:return{image:!0,imageRequired:!0,sizeTiers:[],sizeAdaptive:!1,sizePixel:!0,sizePixelDefault:`1024x1024`,groupGeneration:!1,seed:!1,guidanceScale:!0,guidanceScaleDefault:L[I],outputFormat:!1,tools:!1};default:return Ce}}var we=[`1K`,`2K`,`3K`,`4K`];function Te(e,t){if(!e)return[];let n=t.model??e.model;if(!n)return[];let r=Q(n),i=[];Array.isArray(e.image)&&e.image.length>0&&!r.image&&i.push({field:`image`,i18nLabel:`seedream.name.imageUrls`});let a=typeof e.size==`string`?e.size:void 0;if(a){let e=a.toUpperCase();(we.includes(e)&&!r.sizeTiers.includes(e)||a===`adaptive`&&!r.sizeAdaptive)&&i.push({field:`size`,i18nLabel:`seedream.name.size`})}return e.sequential_image_generation===`auto`&&!r.groupGeneration&&i.push({field:`sequential_image_generation`,i18nLabel:`seedream.name.maxImages`}),e.seed!==void 0&&e.seed!==null&&!r.seed&&i.push({field:`seed`,i18nLabel:`seedream.name.seed`}),e.guidance_scale!==void 0&&e.guidance_scale!==null&&!r.guidanceScale&&i.push({field:`guidance_scale`,i18nLabel:`seedream.name.guidanceScale`}),e.output_format&&!r.outputFormat&&i.push({field:`output_format`,i18nLabel:`seedream.name.outputFormat`}),Array.isArray(e.tools)&&e.tools.length>0&&!r.tools&&i.push({field:`tools`,i18nLabel:`seedream.name.tools`}),i}function Ee(e,t,n){let r={...e},i=Q(n.model??e.model);for(let e of t)switch(e.field){case`image`:delete r.image;break;case`size`:i.sizePixelDefault?r.size=i.sizePixelDefault:delete r.size;break;case`sequential_image_generation`:r.sequential_image_generation=`disabled`,delete r.sequential_image_generation_options;break;case`seed`:delete r.seed;break;case`guidance_scale`:delete r.guidance_scale;break;case`output_format`:delete r.output_format;break;case`tools`:delete r.tools;break}return r}var De=r({name:`SeedreamImageInput`,components:{ElUpload:S,ElButton:v,InfoIcon:Z,ImagePreview:X,FontAwesomeIcon:J},mixins:[W,K],data(){return{fileList:[],uploadUrl:U()+`/api/v1/files/`,suppressWatch:!1}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e?.response?.file_url).filter(e=>!!e)},value(){return this.$store.state.seedream?.config?.image},model(){return this.$store.state.seedream?.config?.model},supported(){return Q(this.model).image}},watch:{value:{immediate:!0,handler(e){if(this.suppressWatch)return;if(!e||e.length===0){let e=(this.fileList||[]).filter(e=>!e?.response?.file_url);this.fileList=e.length?e:[];return}let t=[];e.forEach(e=>{let n=this.fileList.find(t=>t?.response?.file_url===e||t?.url===e);n?t.push(n):t.push({name:e.split(`/`).pop()||e,url:e,status:`success`,percentage:100,response:{file_url:e}})}),(this.fileList||[]).filter(e=>!e?.response?.file_url).forEach(e=>{t.some(t=>t===e||t?.url===e?.url||t?.response?.file_url===e?.response?.file_url)||t.push(e)}),this.fileList=t}}},methods:{onChange(e){if(!e?.url&&e?.raw)try{e.url=URL.createObjectURL(e.raw)}catch{}},onRemove(e){if(e?.url&&typeof e.url==`string`&&e.url.startsWith(`blob:`))try{URL.revokeObjectURL(e.url)}catch{}this.onSetImages()},onExceed(){G.warning(this.$t(`seedream.message.uploadImageExceed`))},onError(){G.error(this.$t(`seedream.message.uploadImageError`))},onSetImages(){let e=this.urls;this.suppressWatch=!0,this.$store.commit(`seedream/setConfig`,{...this.$store.state.seedream?.config,image:e}),this.$nextTick(()=>{this.suppressWatch=!1})},async onSuccess(e,t){e?.file_url&&(t.url=e.file_url,t.response=e),this.onSetImages()},onRemovePreview(e,t){if(this.fileList.splice(e,1),t?.url&&typeof t.url==`string`&&t.url.startsWith(`blob:`))try{URL.revokeObjectURL(t.url)}catch{}this.onSetImages()}}}),Oe={key:0},ke={class:`field`},Ae={class:`label`},je={class:`box`},Me={class:`title font-bold`},Ne={class:`value`},Pe={class:`file-list mt-2 flex flex-wrap gap-[10px]`};function Fe(r,c,d,f,p,_){let v=h(`info-icon`),y=h(`font-awesome-icon`),b=h(`el-button`),x=h(`el-upload`),S=h(`image-preview`);return r.supported?(u(),t(`div`,Oe,[n(`div`,ke,[n(`div`,Ae,[n(`div`,je,[n(`h2`,Me,l(r.$t(`seedream.name.imageUrls`)),1),o(v,{content:r.$t(`seedream.description.imageUrls`),class:`info`},null,8,[`content`])])]),n(`div`,Ne,[o(x,{ref:`uploader`,"file-list":r.fileList,"onUpdate:fileList":c[0]||=e=>r.fileList=e,accept:`.png,.jpg,.jpeg,.gif,.bmp,.webp`,name:`file`,limit:14,multiple:!0,"show-file-list":!1,action:r.uploadUrl,"on-exceed":r.onExceed,"on-error":r.onError,"on-success":r.onSuccess,"on-change":r.onChange,"on-remove":r.onRemove,headers:r.headers},{default:g(()=>[o(b,{size:`small`,type:`primary`,round:``},{default:g(()=>[o(y,{icon:`fa-solid fa-upload`,class:`mr-1`}),i(` `+l(r.$t(`seedream.button.uploadImageUrls`)),1)]),_:1})]),_:1},8,[`file-list`,`action`,`on-exceed`,`on-error`,`on-success`,`on-change`,`on-remove`,`headers`])])]),n(`div`,Pe,[(u(!0),t(s,null,e(r.fileList,(e,t)=>(u(),a(S,{key:e.uid||e?.response?.file_url||e.url||t,url:e.url||e?.response?.file_url,name:e.name,percentage:e.percentage,onRemove:n=>r.onRemovePreview(t,e)},null,8,[`url`,`name`,`percentage`,`onRemove`]))),128))])])):m(``,!0)}var Ie=R(De,[[`render`,Fe],[`__scopeId`,`data-v-6ef4c2e4`]]),Le=r({name:`SeedreamModelSelector`,components:{ElSelect:b,ElOption:x,InfoIcon:Z},data(){return{revertKey:0,options:[{value:P,label:this.$t(`seedream.model.seedream50`)},{value:O,label:this.$t(`seedream.model.seedream45`)},{value:M,label:this.$t(`seedream.model.seedream40`)},{value:F,label:this.$t(`seedream.model.seedream30t2i`)},{value:I,label:this.$t(`seedream.model.seededit30i2i`)}]}},computed:{value(){return this.$store.state.seedream?.config?.model}},mounted(){this.value||this.applyModel(ne)},methods:{async onChange(e){let t=this.$store.state.seedream?.config||{},n=Te(t,{model:e});if(n.length===0){this.applyModel(e);return}let r=n.map(e=>this.$t(e.i18nLabel)).join(`、`);try{await V.confirm(this.$t(`seedream.message.featureNotSupportedBody`,{fields:r}),this.$t(`seedream.message.featureNotSupportedTitle`),{confirmButtonText:this.$t(`seedream.button.confirmContinue`),cancelButtonText:this.$t(`seedream.button.cancelSwitch`),type:`warning`});let i=Ee({...t,model:e},n,{model:e});this.$store.commit(`seedream/setConfig`,i),G.success(this.$t(`seedream.message.featureRemovedNotice`,{fields:r}))}catch{this.revertKey+=1}},applyModel(e){this.$store.commit(`seedream/setConfig`,{...this.$store.state.seedream?.config,model:e})}}}),Re={class:`field`},ze={class:`label`},Be={class:`box`},Ve={class:`title font-bold`};function He(r,i,c,d,f,p){let m=h(`info-icon`),_=h(`el-option`),v=h(`el-select`);return u(),t(`div`,Re,[n(`div`,ze,[n(`div`,Be,[n(`h2`,Ve,l(r.$t(`seedream.name.model`)),1),o(m,{content:r.$t(`seedream.description.model`),class:`info`},null,8,[`content`])])]),(u(),a(v,{key:r.revertKey,"model-value":r.value,class:`value`,placeholder:r.$t(`seedream.placeholder.select`),onChange:r.onChange},{default:g(()=>[(u(!0),t(s,null,e(r.options,e=>(u(),a(_,{key:e.value,label:e.label,value:e.value},null,8,[`label`,`value`]))),128))]),_:1},8,[`model-value`,`placeholder`,`onChange`]))])}var Ue=R(Le,[[`render`,He],[`__scopeId`,`data-v-8892a12c`]]),We=r({name:`SeedreamSizeSelector`,components:{ElSelect:b,ElOption:x,ElOptionGroup:y,InfoIcon:Z},data(){return{SEEDREAM_SIZE_ADAPTIVE:A,pixelOptions:N}},computed:{model(){return this.$store.state.seedream?.config?.model},capabilities(){return Q(this.model)},value:{get(){return this.$store.state.seedream?.config?.size},set(e){this.$store.commit(`seedream/setConfig`,{...this.$store.state.seedream?.config,size:e})}}},watch:{model:{immediate:!0,handler(){if(this.value)return;let e=this.capabilities;e.sizeTiers.length?this.value=e.sizeTiers.includes(`2K`)?`2K`:e.sizeTiers[0]:e.sizePixelDefault&&(this.value=e.sizePixelDefault)}}}}),Ge={class:`field`},Ke={class:`label`},qe={class:`box`},Je={class:`title font-bold`};function Ye(r,i,c,d,f,p){let _=h(`info-icon`),v=h(`el-option`),y=h(`el-option-group`),b=h(`el-select`);return u(),t(`div`,Ge,[n(`div`,Ke,[n(`div`,qe,[n(`h2`,Je,l(r.$t(`seedream.name.size`)),1),o(_,{content:r.$t(`seedream.description.size`),class:`info`},null,8,[`content`])])]),o(b,{modelValue:r.value,"onUpdate:modelValue":i[0]||=e=>r.value=e,class:`value`,placeholder:r.$t(`seedream.placeholder.size`),filterable:``,"allow-create":``,"default-first-option":``},{default:g(()=>[r.capabilities.sizeTiers.length?(u(),a(y,{key:0,label:r.$t(`seedream.size.group.tier`)},{default:g(()=>[(u(!0),t(s,null,e(r.capabilities.sizeTiers,e=>(u(),a(v,{key:e,label:e,value:e},null,8,[`label`,`value`]))),128))]),_:1},8,[`label`])):m(``,!0),r.capabilities.sizeAdaptive?(u(),a(y,{key:1,label:r.$t(`seedream.size.group.adaptive`)},{default:g(()=>[(u(),a(v,{key:r.SEEDREAM_SIZE_ADAPTIVE,label:r.$t(`seedream.size.adaptive`),value:r.SEEDREAM_SIZE_ADAPTIVE},null,8,[`label`,`value`]))]),_:1},8,[`label`])):m(``,!0),o(y,{label:r.$t(`seedream.size.group.pixel`)},{default:g(()=>[(u(!0),t(s,null,e(r.pixelOptions,e=>(u(),a(v,{key:e.value,label:`${e.value} (${e.ratio})`,value:e.value},null,8,[`label`,`value`]))),128))]),_:1},8,[`label`])]),_:1},8,[`modelValue`,`placeholder`])])}var Xe=R(We,[[`render`,Ye],[`__scopeId`,`data-v-dd7bd021`]]),Ze=r({name:`SeedreamMaxImagesSelector`,components:{ElInputNumber:D,InfoIcon:Z},computed:{config(){return this.$store.state.seedream?.config||{}},supported(){return Q(this.config?.model).groupGeneration},referenceImageCount(){let e=this.config?.image;return Array.isArray(e)?e.length:0},effectiveMax(){let e=15-this.referenceImageCount;return Math.max(1,Math.min(15,e))},value:{get(){let e=this.config?.sequential_image_generation_options?.max_images;return typeof e==`number`&&e>=1?e:1},set(e){let t={...this.config||{}},n=Math.max(1,Math.min(this.effectiveMax,Math.floor(e||1)));n>1?(t.sequential_image_generation=`auto`,t.sequential_image_generation_options={...t.sequential_image_generation_options||{},max_images:n}):(t.sequential_image_generation=`disabled`,t.sequential_image_generation_options&&delete t.sequential_image_generation_options),this.$store.commit(`seedream/setConfig`,t)}}},watch:{effectiveMax(e){this.value>e&&(this.value=e)}}}),Qe={key:0,class:`field`},$e={class:`label`},et={class:`box`},tt={class:`title font-bold`},nt={class:`value`};function rt(e,r,i,a,s,c){let d=h(`info-icon`),f=h(`el-input-number`);return e.supported?(u(),t(`div`,Qe,[n(`div`,$e,[n(`div`,et,[n(`h2`,tt,l(e.$t(`seedream.name.maxImages`)),1),o(d,{content:e.$t(`seedream.description.maxImages`),class:`info`},null,8,[`content`])])]),n(`div`,nt,[o(f,{modelValue:e.value,"onUpdate:modelValue":r[0]||=t=>e.value=t,min:1,max:e.effectiveMax,step:1,size:`default`,"controls-position":`right`,class:`counter`},null,8,[`modelValue`,`max`])])])):m(``,!0)}var it=R(Ze,[[`render`,rt],[`__scopeId`,`data-v-f079fd20`]]),at=r({name:`SeedreamOutputFormatSelector`,components:{ElSelect:b,ElOption:x,InfoIcon:Z},data(){return{options:[...k]}},computed:{config(){return this.$store.state.seedream?.config||{}},supported(){return Q(this.config?.model).outputFormat},value:{get(){return this.config?.output_format},set(e){let t={...this.config||{}};t.output_format=e,this.$store.commit(`seedream/setConfig`,t)}}}}),ot={key:0,class:`field`},st={class:`label`},ct={class:`box`},lt={class:`title font-bold`};function ut(r,i,c,d,f,p){let _=h(`info-icon`),v=h(`el-option`),y=h(`el-select`);return r.supported?(u(),t(`div`,ot,[n(`div`,st,[n(`div`,ct,[n(`h2`,lt,l(r.$t(`seedream.name.outputFormat`)),1),o(_,{content:r.$t(`seedream.description.outputFormat`),class:`info`},null,8,[`content`])])]),o(y,{modelValue:r.value,"onUpdate:modelValue":i[0]||=e=>r.value=e,class:`value`,placeholder:r.$t(`seedream.placeholder.select`)},{default:g(()=>[(u(!0),t(s,null,e(r.options,e=>(u(),a(v,{key:e,label:e.toUpperCase(),value:e},null,8,[`label`,`value`]))),128))]),_:1},8,[`modelValue`,`placeholder`])])):m(``,!0)}var dt=R(at,[[`render`,ut],[`__scopeId`,`data-v-69ea4c07`]]),ft=r({name:`SeedreamSeedInput`,components:{ElInputNumber:D,InfoIcon:Z},computed:{config(){return this.$store.state.seedream?.config||{}},supported(){return Q(this.config?.model).seed},value:{get(){let e=this.config?.seed;return typeof e==`number`?e:-1},set(e){let t={...this.config||{}};t.seed=typeof e==`number`&&Number.isInteger(e)?e:-1,this.$store.commit(`seedream/setConfig`,t)}}}}),pt={key:0,class:`field`},mt={class:`label`},ht={class:`box`},gt={class:`title font-bold`},_t={class:`value`};function vt(e,r,i,a,s,c){let d=h(`info-icon`),f=h(`el-input-number`);return e.supported?(u(),t(`div`,pt,[n(`div`,mt,[n(`div`,ht,[n(`h2`,gt,l(e.$t(`seedream.name.seed`)),1),o(d,{content:e.$t(`seedream.description.seed`),class:`info`},null,8,[`content`])])]),n(`div`,_t,[o(f,{modelValue:e.value,"onUpdate:modelValue":r[0]||=t=>e.value=t,min:-1,max:2147483647,step:1,size:`default`,"controls-position":`right`,class:`counter`},null,8,[`modelValue`])])])):m(``,!0)}var yt=R(ft,[[`render`,vt],[`__scopeId`,`data-v-10cdc1e0`]]),bt=r({name:`SeedreamGuidanceScaleInput`,components:{ElInputNumber:D,InfoIcon:Z},computed:{config(){return this.$store.state.seedream?.config||{}},supported(){return Q(this.config?.model).guidanceScale},defaultValue(){return Q(this.config?.model).guidanceScaleDefault??2.5},value:{get(){let e=this.config?.guidance_scale;return typeof e==`number`?e:this.defaultValue},set(e){let t={...this.config||{}};t.guidance_scale=typeof e==`number`&&e>=1&&e<=10?e:this.defaultValue,this.$store.commit(`seedream/setConfig`,t)}}}}),xt={key:0,class:`field`},St={class:`label`},Ct={class:`box`},wt={class:`title font-bold`},Tt={class:`value`};function Et(e,r,i,a,s,c){let d=h(`info-icon`),f=h(`el-input-number`);return e.supported?(u(),t(`div`,xt,[n(`div`,St,[n(`div`,Ct,[n(`h2`,wt,l(e.$t(`seedream.name.guidanceScale`)),1),o(d,{content:e.$t(`seedream.description.guidanceScale`),class:`info`},null,8,[`content`])])]),n(`div`,Tt,[o(f,{modelValue:e.value,"onUpdate:modelValue":r[0]||=t=>e.value=t,min:1,max:10,step:.1,precision:1,size:`default`,"controls-position":`right`,class:`counter`},null,8,[`modelValue`])])])):m(``,!0)}var Dt=R(bt,[[`render`,Et],[`__scopeId`,`data-v-7386f064`]]),Ot=r({name:`SeedreamWatermarkSwitch`,components:{ElSwitch:ee,InfoIcon:Z},computed:{value:{get(){let e=this.$store.state.seedream?.config?.watermark;return e===void 0?!1:!!e},set(e){this.$store.commit(`seedream/setConfig`,{...this.$store.state.seedream?.config,watermark:e})}}}}),kt={class:`field`},At={class:`label`},jt={class:`box`},Mt={class:`title font-bold`},Nt={class:`value`};function Pt(e,r,i,a,s,c){let d=h(`info-icon`),f=h(`el-switch`);return u(),t(`div`,kt,[n(`div`,At,[n(`div`,jt,[n(`h2`,Mt,l(e.$t(`seedream.name.watermark`)),1),o(d,{content:e.$t(`seedream.description.watermark`),class:`info`},null,8,[`content`])])]),n(`div`,Nt,[o(f,{modelValue:e.value,"onUpdate:modelValue":r[0]||=t=>e.value=t},null,8,[`modelValue`])])])}var Ft=r({name:`SeedreamConfigPanel`,components:{ElButton:v,FontAwesomeIcon:J,PromptInput:Se,Consumption:de,ImageInput:Ie,ModelSelector:Ue,SizeSelector:Xe,MaxImagesSelector:it,OutputFormatSelector:dt,SeedInput:yt,GuidanceScaleInput:Dt,WatermarkSwitch:R(Ot,[[`render`,Pt],[`__scopeId`,`data-v-9e2abf0f`]])},emits:[`generate`],computed:{config(){return this.$store.state.seedream?.config},consumption(){let e={...this.config||{}},t=Array.isArray(e?.image)&&e.image.length>0,n=e?.sequential_image_generation===`auto`?Math.max(1,Math.floor(e?.sequential_image_generation_options?.max_images||1)):1;return B({...e,action:t?`edit`:`generate`,model:j(e?.model),count:n},this.service?.cost)},service(){return this.$store.state.seedream?.service}},methods:{onGenerate(){this.$emit(`generate`)}}}),It={class:`flex flex-col h-full`},Lt={class:`flex-1 overflow-y-auto p-5`},Rt={class:`flex flex-col items-center justify-center px-5 pb-5`};function zt(e,r,a,s,c,d){let f=h(`model-selector`),p=h(`size-selector`),m=h(`max-images-selector`),_=h(`output-format-selector`),v=h(`seed-input`),y=h(`guidance-scale-input`),b=h(`watermark-switch`),x=h(`prompt-input`),S=h(`image-input`),C=h(`consumption`),w=h(`font-awesome-icon`),T=h(`el-button`);return u(),t(`div`,It,[n(`div`,Lt,[o(f,{class:`mb-4`}),o(p,{class:`mb-4`}),o(m,{class:`mb-4`}),o(_,{class:`mb-4`}),o(v,{class:`mb-4`}),o(y,{class:`mb-4`}),o(b,{class:`mb-4`}),o(x,{class:`mb-4`}),o(S,{class:`mb-4`})]),n(`div`,Rt,[o(C,{value:e.consumption,service:e.service},null,8,[`value`,`service`]),o(T,{type:`primary`,class:`btn w-full`,round:``,onClick:e.onGenerate},{default:g(()=>[o(w,{icon:`fa-solid fa-magic`,class:`mr-2`}),i(` `+l(e.$t(`seedream.button.generate`)),1)]),_:1},8,[`onClick`])])])}var Bt=R(Ft,[[`render`,zt]]),Vt=r({name:`SeedreamTaskPreview`,components:{ElImage:w,CopyToClipboard:Y,FontAwesomeIcon:J,ElAlert:T,ImageWrapper:pe,ElButton:v,ElTooltip:C,ImagePreview:X,ApiCodeButton:fe},props:{modelValue:{type:Object,required:!0}},computed:{isEdit(){return Array.isArray(this.modelValue?.request?.image)&&(this.modelValue?.request?.image?.length||0)>0},images(){let e=[];return Array.isArray(this.modelValue?.response?.data)&&this.modelValue?.response?.data?.forEach(t=>{e.push(t)}),e}},methods:{shortModel(e){return j(e)||e},onEdit(e){if(!e)return;console.debug(`Edit image:`,e);let t={...this.$store.state.seedream?.config||{}};t.image=[e],this.$store.commit(`seedream/setConfig`,t)}}}),Ht={class:`preview`},Ut={class:`left`},Wt={class:`main`},Gt={class:`bot`},Kt={class:`datetime`},qt={class:`info`},Jt={key:0,class:`flex justify-start items-center gap-2 mt-2 w-full overflow-x-auto`},Yt={key:1,class:`prompt mt-2`},Xt={key:0},Zt={key:0,class:c({content:!0})},Qt={class:`text-[var(--el-text-color-regular)] text-xs mb-0`},$t={key:1,class:c({content:!0,failed:!0})},en={class:`flex justify-start items-center gap-4 w-full overflow-x-auto`},tn={class:c({operations:!0,"mt-2":!0,"mb-2":!0})},nn={key:0,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},rn={key:1,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},an={class:`text-[var(--el-text-color-regular)] text-xs mb-2`},on={class:`text-[var(--el-text-color-regular)] text-xs mb-2`},sn={key:2,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},cn={key:3,class:`text-[var(--el-text-color-regular)] text-xs mb-0`},$={key:2,class:c({content:!0})},ln={key:0,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},un={key:1,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},dn={class:`text-[var(--el-text-color-regular)] text-xs mb-2`},fn={class:`text-[var(--el-text-color-regular)] text-xs mb-2`},pn={key:2,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},mn={key:3,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},hn={key:4,class:`text-[var(--el-text-color-regular)] text-xs mb-0`},gn={key:3,class:c({content:!0})},_n={class:`text-[var(--el-text-color-regular)] text-xs mb-2`},vn={key:0,class:`text-[var(--el-text-color-regular)] text-xs mb-0`};function yn(r,c,f,p,_,v){let y=h(`el-image`),b=h(`image-preview`),x=h(`font-awesome-icon`),S=h(`copy-to-clipboard`),C=h(`el-alert`),w=h(`image-wrapper`),T=h(`el-button`),E=h(`el-tooltip`),D=h(`api-code-button`);return u(),t(`div`,Ht,[n(`div`,Ut,[o(y,{src:`https://cdn.acedata.cloud/9egrbn.png`,class:`avatar`})]),n(`div`,Wt,[n(`div`,Gt,[i(l(r.$t(`seedream.name.seedreamBot`))+` `,1),n(`span`,Kt,l(r.$dayjs.format(``+new Date(parseFloat((r.modelValue?.created_at||``).toString())*1e3))),1)]),n(`div`,qt,[Array.isArray(r.modelValue?.request?.image)&&r.modelValue?.request?.image.length>0?(u(),t(`div`,Jt,[(u(!0),t(s,null,e(r.modelValue?.request?.image,(e,t)=>(u(),a(b,{key:t,url:e,name:`image-${t+1}`,closable:!1},null,8,[`url`,`name`]))),128))])):m(``,!0),r.modelValue?.request?.prompt?(u(),t(`p`,Yt,[i(l(r.modelValue?.request?.prompt)+` `,1),r.modelValue?.response?m(``,!0):(u(),t(`span`,Xt,` - (`+l(r.$t(`seedream.status.pending`))+`) `,1))])):m(``,!0)]),r.modelValue?.response?r.modelValue?.response?.success===!0?(u(),t(`div`,$t,[n(`div`,en,[(u(!0),t(s,null,e(r.images,(e,t)=>(u(),a(w,{key:t,src:e?.image_url,"raw-src":e?.image_url},null,8,[`src`,`raw-src`]))),128))]),n(`div`,tn,[o(E,{class:`box-item`,effect:`dark`,content:r.$t(`common.button.edit`),placement:`top-start`},{default:g(()=>[o(T,{type:`info`,size:`small`,class:`btn-action`,onClick:c[0]||=d(e=>r.onEdit(r.images?.[0]?.image_url),[`stop`])},{default:g(()=>[i(l(r.$t(`common.button.edit`)),1)]),_:1})]),_:1},8,[`content`]),o(D,{path:`/seedream/images`,body:r.modelValue?.request},null,8,[`body`])]),o(C,{closable:!1,class:`mt-2 success`},{default:g(()=>[r.modelValue?.request?.model?(u(),t(`p`,nn,[o(x,{icon:`fa-solid fa-cube`,class:`mr-1`}),i(` `+l(r.$t(`seedream.name.model`))+`: `+l(r.shortModel(r.modelValue?.request?.model)),1)])):m(``,!0),r.modelValue?.request?.size?(u(),t(`p`,rn,[o(x,{icon:`fa-solid fa-image`,class:`mr-1`}),i(` `+l(r.$t(`seedream.name.size`))+`: `+l(r.modelValue?.request?.size),1)])):m(``,!0),n(`p`,an,[o(x,{icon:`fa-solid fa-bolt`,class:`mr-1`}),i(` `+l(r.$t(`seedream.name.task`))+`: `+l(r.isEdit?r.$t(`seedream.name.edits`):r.$t(`seedream.name.generate`)),1)]),n(`p`,on,[o(x,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+l(r.$t(`seedream.name.taskId`))+`: `+l(r.modelValue?.id)+` `,1),o(S,{content:r.modelValue?.id,class:`btn-copy inline-block`},null,8,[`content`])]),r.modelValue?.elapsed?(u(),t(`p`,sn,[o(x,{icon:`fa-solid fa-clock`,class:`mr-1`}),i(` `+l(r.$t(`seedream.name.elapsed`))+`: `+l(r.modelValue?.elapsed?.toFixed(2))+`s `,1)])):m(``,!0),r.modelValue?.response?.trace_id?(u(),t(`p`,cn,[o(x,{icon:`fa-solid fa-hashtag`,class:`mr-1`}),i(` `+l(r.$t(`seedream.name.traceId`))+`: `+l(r.modelValue?.response?.trace_id)+` `,1),o(S,{content:r.modelValue?.response?.trace_id,class:`btn-copy inline-block`},null,8,[`content`])])):m(``,!0)]),_:1})])):r.modelValue?.response?.success===!1?(u(),t(`div`,$,[o(C,{closable:!1,class:`failure`},{template:g(()=>[o(x,{icon:`fa-solid fa-exclamation-triangle`,class:`mr-1`}),i(` `+l(r.$t(`seedream.name.failure`)),1)]),default:g(()=>[r.modelValue?.request?.model?(u(),t(`p`,ln,[o(x,{icon:`fa-solid fa-cube`,class:`mr-1`}),i(` `+l(r.$t(`seedream.name.model`))+`: `+l(r.shortModel(r.modelValue?.request?.model)),1)])):m(``,!0),r.modelValue?.request?.size?(u(),t(`p`,un,[o(x,{icon:`fa-solid fa-image`,class:`mr-1`}),i(` `+l(r.$t(`seedream.name.size`))+`: `+l(r.modelValue?.request?.size),1)])):m(``,!0),n(`p`,dn,[o(x,{icon:`fa-solid fa-bolt`,class:`mr-1`}),i(` `+l(r.$t(`seedream.name.task`))+`: `+l(r.isEdit?r.$t(`seedream.name.edits`):r.$t(`seedream.name.generate`)),1)]),n(`p`,fn,[o(x,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+l(r.$t(`seedream.name.taskId`))+`: `+l(r.modelValue?.id)+` `,1),o(S,{content:r.modelValue?.id,class:`btn-copy`},null,8,[`content`])]),r.modelValue?.response?.error?.message?(u(),t(`p`,pn,[o(x,{icon:`fa-solid fa-circle-info`,class:`mr-1`}),i(` `+l(r.$t(`seedream.name.failureReason`))+`: `+l(r.modelValue?.response?.error?.message)+` `,1),o(S,{content:r.modelValue?.response?.error?.message,class:`btn-copy`},null,8,[`content`])])):m(``,!0),r.modelValue?.elapsed?(u(),t(`p`,mn,[o(x,{icon:`fa-solid fa-clock`,class:`mr-1`}),i(` `+l(r.$t(`seedream.name.elapsed`))+`: `+l(r.modelValue?.elapsed?.toFixed(2))+`s `,1)])):m(``,!0),r.modelValue?.response?.trace_id?(u(),t(`p`,hn,[o(x,{icon:`fa-solid fa-hashtag`,class:`mr-1`}),i(` `+l(r.$t(`seedream.name.traceId`))+`: `+l(r.modelValue?.response?.trace_id)+` `,1),o(S,{content:r.modelValue?.response?.trace_id,class:`btn-copy`},null,8,[`content`])])):m(``,!0)]),_:1})])):(u(),t(`div`,gn,[o(C,{closable:!1,class:`info`},{template:g(()=>[o(x,{icon:`fa-solid fa-circle-info`,class:`mr-1`}),i(` `+l(r.$t(`seedream.name.status`)),1)]),default:g(()=>[n(`p`,_n,[o(x,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+l(r.$t(`seedream.name.taskId`))+`: `+l(r.modelValue?.id)+` `,1),o(S,{content:r.modelValue?.id,class:`btn-copy`},null,8,[`content`])]),r.modelValue?.response?.trace_id?(u(),t(`p`,vn,[o(x,{icon:`fa-solid fa-hashtag`,class:`mr-1`}),i(` `+l(r.$t(`seedream.name.traceId`))+`: `+l(r.modelValue?.response?.trace_id)+` `,1),o(S,{content:r.modelValue?.response?.trace_id,class:`btn-copy`},null,8,[`content`])])):m(``,!0)]),_:1})])):(u(),t(`div`,Zt,[o(C,{closable:!1,class:`info`},{template:g(()=>[o(x,{icon:`fa-regular fa-clock`,class:`mr-1`}),i(` `+l(r.$t(`seedream.status.pending`)),1)]),default:g(()=>[n(`p`,Qt,[o(x,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+l(r.$t(`seedream.name.taskId`))+`: `+l(r.modelValue?.id)+` `,1),o(S,{content:r.modelValue?.id,class:`btn-copy inline-block`},null,8,[`content`])])]),_:1})]))])])}var bn=r({name:`SeedreamRecentPanel`,components:{TaskPreview:R(Vt,[[`render`,yn],[`__scopeId`,`data-v-1b4654bc`]]),BotPlaceholder:oe,NoTasks:ue,ScrollList:se},props:{loading:{type:Boolean,default:!1}},emits:[`reach-top`],computed:{tasks(){return{...this.$store.state.seedream?.tasks,items:this.$store.state.seedream?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),xn={key:0},Sn={key:2,class:`w-full h-full flex items-center justify-center`};function Cn(n,r,i,c,l,d){let f=h(`bot-placeholder`),p=h(`task-preview`),_=h(`scroll-list`),v=h(`no-tasks`);return u(),t(s,null,[n.tasks?.items===void 0?(u(),t(`div`,xn,[o(f)])):n.tasks?.items?.length&&n.tasks?.items?.length>0?(u(),a(_,{key:1,ref:`scrollList`,class:`tasks h-full w-full overflow-y-auto`,loading:n.loading,onReachTop:r[0]||=e=>n.$emit(`reach-top`)},{default:g(()=>[(u(!0),t(s,null,e(n.tasks?.items,e=>(u(),a(p,{key:e.id,"model-value":e},null,8,[`model-value`]))),128))]),_:1},8,[`loading`])):m(``,!0),n.tasks?.items?.length===0?(u(),t(`div`,Sn,[o(v)])):m(``,!0)],64)}var wn=R(bn,[[`render`,Cn]]),Tn=te(`seedream`),En=r({name:`SeedreamIndex`,components:{ConfigPanel:Bt,Layout:ye,RecentPanel:wn},mixins:[ie],inject:[`initialized`],data(){return{task:void 0,job:0,loading:!1}},computed:{applicationsLoading(){return this.$store.state.seedream?.status?.getApplications===q.Request},tasksLoading(){return this.$store.state.seedream?.status?.getTasks===q.Request},credential(){return this.$store.state.seedream?.credential},config(){return this.$store.state.seedream?.config},application(){return this.$store.state.seedream?.application},tasks(){return this.$store.state.seedream?.tasks}},watch:{tasks:{handler(e,t){e?.items?.length>t?.items?.length&&console.debug(`new tasks detected`)},deep:!0},initialized:{async handler(e){e&&(console.debug(`layout initialized`),await this.onGetTasks(),await this.onScrollDown(),this.job=window.setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){window.clearInterval(this.job)},methods:{async onReachTop(){await ce({tasks:this.tasks,getTasks:()=>this.tasks,loading:this.loading,setLoading:e=>this.loading=e,isBlocked:()=>this.tasksLoading,fetch:e=>this.onGetTasks({createdAtMax:e}),getScrollElement:()=>this.getTasksScrollElement()})},async onGetService(){console.debug(`start onGetService`),await this.$store.dispatch(`seedream/getService`),console.debug(`end onGetService`)},async onGetApplication(){console.debug(`start onGetApplication`),await this.$store.dispatch(`seedream/getApplications`),console.debug(`end onGetApplication`),await this.onGetTasks()},async onScrollDown(){await this.$nextTick();let e=this.getTasksScrollElement();e&&(e.scrollTop=e.scrollHeight)},async onGetTasks(e){if(this.applicationsLoading||this.tasksLoading){console.debug(`loading`);return}console.debug(`start onGetTasks`,e);let{limit:t=20,createdAtMin:n,createdAtMax:r}=e||{};console.debug(`limit`,t,`createdAtMin`,n,`createdAtMax`,r),await this.$store.dispatch(`seedream/getTasks`,{limit:t,createdAtMin:n,createdAtMax:r})},async onGenerate(){if(!H(this.uploadTracker,e=>this.$t(e),e=>G.warning(e)))return;let e={...this.config||{}};!(Array.isArray(e?.image)&&e.image.length>0)&&`image`in e&&delete e.image,e?.size||delete e.size;let t={...e,callback_url:Tn},n=this.credential?.token;if(!n){console.error(`no token specified`);return}G.info(this.$t(`seedream.message.startingTask`)),z(`seedream`,re.generate(t,{token:n})).then(()=>{G.success(this.$t(`seedream.message.startTaskSuccess`))}).catch(e=>{let t=e?.response?.data;t?.error?.code===`used_up`?G.error(this.$t(`seedream.message.usedUp`)):G.error(this.$t(`seedream.message.startTaskFailed`)+(t?.error?.message||``))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function Dn(e,t,n,r,i,s){let c=h(`config-panel`),l=h(`recent-panel`),d=h(`layout`);return u(),a(d,null,{config:g(()=>[o(c,{onGenerate:e.onGenerate},null,8,[`onGenerate`])]),result:g(()=>[o(l,{ref:`recentPanel`,loading:e.loading,onReachTop:e.onReachTop},null,8,[`loading`,`onReachTop`])]),_:1})}var On=R(En,[[`render`,Dn]]);export{On as default};
|
|
1
|
+
import"./rolldown-runtime--c01j_DQ.js";import{$ as e,A as t,D as n,F as r,N as i,O as a,P as o,S as s,Vt as c,Wt as l,Z as u,b as d,dt as f,et as p,k as m,tt as h,ut as g,v as _}from"./vendor-chart-BJCvKk8-.js";import{t as v}from"./button-DfsQodL-.js";import{n as y,r as b,t as x}from"./select-DyEe0uU4.js";import{t as S}from"./upload-2ooOKJyT.js";import{t as C}from"./tooltip-BLwTovWL.js";import{t as w}from"./image-C7UiYpMr.js";import{t as T}from"./alert-OvnfgMB-.js";import{t as E}from"./drawer-Dpuj2uIl.js";import{t as D}from"./input-number-BqK5b3Jr.js";import{t as ee}from"./switch-CycowGlP.js";import{_i as te,an as O,cn as k,dn as A,en as ne,fn as j,in as M,ln as N,on as P,rn as F,sn as I,tn as L}from"./constants-CwLEZ_AF.js";import{$t as re,At as ie,E as R,Fn as z,Nt as B,Or as V,Ot as H,Sr as U,jt as W,kr as G,kt as K,yr as q}from"./index-BSaC0vue.js";import{t as J}from"./index.es-NL3Dn982.js";import{t as Y}from"./CopyToClipboard-Sk5Grp1_.js";import{t as X}from"./ImagePreview-BX6eL7DE.js";import{n as ae}from"./taskDrawerMixin-DEgO_R5H.js";import{t as oe}from"./BotPlaceholder-68XVM5HA.js";import{i as Z,n as se,t as ce}from"./pagination-D5c7xkGS.js";import{n as le,t as ue}from"./NoTasks-BiV0deXP.js";import{t as de}from"./Consumption-CtCh2-Du.js";import{t as fe}from"./ApiCodeButton-jFmqbRiH.js";import{t as pe}from"./ImageWrapper-CFm9ms8f.js";var me=r({name:`LayoutSeedream`,components:{ElDrawer:E,ElButton:v,FontAwesomeIcon:J},mixins:[ae]}),he={class:`main flex flex-row flex-1`},ge={class:`config w-[320px] h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]`},_e={class:`result h-full p-6 flex-1 flex flex-col bg-[var(--app-content-bg)]`};function ve(e,r,i,a,s,c){let l=h(`font-awesome-icon`),d=h(`el-button`),m=h(`el-drawer`);return u(),t(`div`,he,[n(`div`,ge,[p(e.$slots,`config`,{},void 0,!0)]),n(`div`,_e,[p(e.$slots,`result`,{},void 0,!0)]),f(o(d,{circle:``,class:`menu`,onClick:r[0]||=t=>e.drawer=!0},{default:g(()=>[o(l,{icon:`fa-solid fa-magic`})]),_:1},512),[[_,!e.tasksEmpty]]),o(m,{modelValue:e.drawer,"onUpdate:modelValue":r[1]||=t=>e.drawer=t,direction:`ltr`,"with-header":!1,size:`340px`,class:`drawer`},{default:g(()=>[p(e.$slots,`config`,{},void 0,!0)]),_:3},8,[`modelValue`])])}var ye=R(me,[[`render`,ve],[`__scopeId`,`data-v-2a1715d6`]]),be=r({name:`SeedreamPromptInput`,components:{PromptTextarea:le},computed:{prompt:{get(){return this.$store.state.seedream?.config?.prompt},set(e){this.$store.commit(`seedream/setConfig`,{...this.$store.state.seedream?.config,prompt:e})}}},mounted(){this.prompt||=``}});function xe(e,t,n,r,i,o){let s=h(`prompt-textarea`);return u(),a(s,{modelValue:e.prompt,"onUpdate:modelValue":t[0]||=t=>e.prompt=t,title:e.$t(`seedream.name.prompt`),info:e.$t(`seedream.description.prompt`),placeholder:e.$t(`seedream.placeholder.prompt`)},null,8,[`modelValue`,`title`,`info`,`placeholder`])}var Se=R(be,[[`render`,xe]]),Ce={image:!0,imageRequired:!1,sizeTiers:[`1K`,`2K`,`3K`,`4K`],sizeAdaptive:!0,sizePixel:!0,sizePixelDefault:void 0,groupGeneration:!1,seed:!1,guidanceScale:!1,outputFormat:!1,tools:!1};function Q(e){switch(e){case P:return{image:!0,imageRequired:!1,sizeTiers:[`2K`,`3K`,`4K`],sizeAdaptive:!0,sizePixel:!0,groupGeneration:!0,seed:!1,guidanceScale:!1,outputFormat:!0,tools:!0};case O:return{image:!0,imageRequired:!1,sizeTiers:[`2K`,`4K`],sizeAdaptive:!0,sizePixel:!0,groupGeneration:!0,seed:!1,guidanceScale:!1,outputFormat:!1,tools:!1};case M:return{image:!0,imageRequired:!1,sizeTiers:[`1K`,`2K`,`4K`],sizeAdaptive:!0,sizePixel:!0,groupGeneration:!0,seed:!1,guidanceScale:!1,outputFormat:!1,tools:!1};case F:return{image:!1,imageRequired:!1,sizeTiers:[],sizeAdaptive:!1,sizePixel:!0,sizePixelDefault:`1024x1024`,groupGeneration:!1,seed:!0,guidanceScale:!0,guidanceScaleDefault:L[F],outputFormat:!1,tools:!1};case I:return{image:!0,imageRequired:!0,sizeTiers:[],sizeAdaptive:!1,sizePixel:!0,sizePixelDefault:`1024x1024`,groupGeneration:!1,seed:!1,guidanceScale:!0,guidanceScaleDefault:L[I],outputFormat:!1,tools:!1};default:return Ce}}var we=[`1K`,`2K`,`3K`,`4K`];function Te(e,t){if(!e)return[];let n=t.model??e.model;if(!n)return[];let r=Q(n),i=[];Array.isArray(e.image)&&e.image.length>0&&!r.image&&i.push({field:`image`,i18nLabel:`seedream.name.imageUrls`});let a=typeof e.size==`string`?e.size:void 0;if(a){let e=a.toUpperCase();(we.includes(e)&&!r.sizeTiers.includes(e)||a===`adaptive`&&!r.sizeAdaptive)&&i.push({field:`size`,i18nLabel:`seedream.name.size`})}return e.sequential_image_generation===`auto`&&!r.groupGeneration&&i.push({field:`sequential_image_generation`,i18nLabel:`seedream.name.maxImages`}),e.seed!==void 0&&e.seed!==null&&!r.seed&&i.push({field:`seed`,i18nLabel:`seedream.name.seed`}),e.guidance_scale!==void 0&&e.guidance_scale!==null&&!r.guidanceScale&&i.push({field:`guidance_scale`,i18nLabel:`seedream.name.guidanceScale`}),e.output_format&&!r.outputFormat&&i.push({field:`output_format`,i18nLabel:`seedream.name.outputFormat`}),Array.isArray(e.tools)&&e.tools.length>0&&!r.tools&&i.push({field:`tools`,i18nLabel:`seedream.name.tools`}),i}function Ee(e,t,n){let r={...e},i=Q(n.model??e.model);for(let e of t)switch(e.field){case`image`:delete r.image;break;case`size`:i.sizePixelDefault?r.size=i.sizePixelDefault:delete r.size;break;case`sequential_image_generation`:r.sequential_image_generation=`disabled`,delete r.sequential_image_generation_options;break;case`seed`:delete r.seed;break;case`guidance_scale`:delete r.guidance_scale;break;case`output_format`:delete r.output_format;break;case`tools`:delete r.tools;break}return r}var De=r({name:`SeedreamImageInput`,components:{ElUpload:S,ElButton:v,InfoIcon:Z,ImagePreview:X,FontAwesomeIcon:J},mixins:[W,K],data(){return{fileList:[],uploadUrl:U()+`/api/v1/files/`,suppressWatch:!1}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e?.response?.file_url).filter(e=>!!e)},value(){return this.$store.state.seedream?.config?.image},model(){return this.$store.state.seedream?.config?.model},supported(){return Q(this.model).image}},watch:{value:{immediate:!0,handler(e){if(this.suppressWatch)return;if(!e||e.length===0){let e=(this.fileList||[]).filter(e=>!e?.response?.file_url);this.fileList=e.length?e:[];return}let t=[];e.forEach(e=>{let n=this.fileList.find(t=>t?.response?.file_url===e||t?.url===e);n?t.push(n):t.push({name:e.split(`/`).pop()||e,url:e,status:`success`,percentage:100,response:{file_url:e}})}),(this.fileList||[]).filter(e=>!e?.response?.file_url).forEach(e=>{t.some(t=>t===e||t?.url===e?.url||t?.response?.file_url===e?.response?.file_url)||t.push(e)}),this.fileList=t}}},methods:{onChange(e){if(!e?.url&&e?.raw)try{e.url=URL.createObjectURL(e.raw)}catch{}},onRemove(e){if(e?.url&&typeof e.url==`string`&&e.url.startsWith(`blob:`))try{URL.revokeObjectURL(e.url)}catch{}this.onSetImages()},onExceed(){G.warning(this.$t(`seedream.message.uploadImageExceed`))},onError(){G.error(this.$t(`seedream.message.uploadImageError`))},onSetImages(){let e=this.urls;this.suppressWatch=!0,this.$store.commit(`seedream/setConfig`,{...this.$store.state.seedream?.config,image:e}),this.$nextTick(()=>{this.suppressWatch=!1})},async onSuccess(e,t){e?.file_url&&(t.url=e.file_url,t.response=e),this.onSetImages()},onRemovePreview(e,t){if(this.fileList.splice(e,1),t?.url&&typeof t.url==`string`&&t.url.startsWith(`blob:`))try{URL.revokeObjectURL(t.url)}catch{}this.onSetImages()}}}),Oe={key:0},ke={class:`field`},Ae={class:`label`},je={class:`box`},Me={class:`title font-bold`},Ne={class:`value`},Pe={class:`file-list mt-2 flex flex-wrap gap-[10px]`};function Fe(r,c,d,f,p,_){let v=h(`info-icon`),y=h(`font-awesome-icon`),b=h(`el-button`),x=h(`el-upload`),S=h(`image-preview`);return r.supported?(u(),t(`div`,Oe,[n(`div`,ke,[n(`div`,Ae,[n(`div`,je,[n(`h2`,Me,l(r.$t(`seedream.name.imageUrls`)),1),o(v,{content:r.$t(`seedream.description.imageUrls`),class:`info`},null,8,[`content`])])]),n(`div`,Ne,[o(x,{ref:`uploader`,"file-list":r.fileList,"onUpdate:fileList":c[0]||=e=>r.fileList=e,accept:`.png,.jpg,.jpeg,.gif,.bmp,.webp`,name:`file`,limit:14,multiple:!0,"show-file-list":!1,action:r.uploadUrl,"on-exceed":r.onExceed,"on-error":r.onError,"on-success":r.onSuccess,"on-change":r.onChange,"on-remove":r.onRemove,headers:r.headers},{default:g(()=>[o(b,{size:`small`,type:`primary`,round:``},{default:g(()=>[o(y,{icon:`fa-solid fa-upload`,class:`mr-1`}),i(` `+l(r.$t(`seedream.button.uploadImageUrls`)),1)]),_:1})]),_:1},8,[`file-list`,`action`,`on-exceed`,`on-error`,`on-success`,`on-change`,`on-remove`,`headers`])])]),n(`div`,Pe,[(u(!0),t(s,null,e(r.fileList,(e,t)=>(u(),a(S,{key:e.uid||e?.response?.file_url||e.url||t,url:e.url||e?.response?.file_url,name:e.name,percentage:e.percentage,onRemove:n=>r.onRemovePreview(t,e)},null,8,[`url`,`name`,`percentage`,`onRemove`]))),128))])])):m(``,!0)}var Ie=R(De,[[`render`,Fe],[`__scopeId`,`data-v-6ef4c2e4`]]),Le=r({name:`SeedreamModelSelector`,components:{ElSelect:b,ElOption:x,InfoIcon:Z},data(){return{revertKey:0,options:[{value:P,label:this.$t(`seedream.model.seedream50`)},{value:O,label:this.$t(`seedream.model.seedream45`)},{value:M,label:this.$t(`seedream.model.seedream40`)},{value:F,label:this.$t(`seedream.model.seedream30t2i`)},{value:I,label:this.$t(`seedream.model.seededit30i2i`)}]}},computed:{value(){return this.$store.state.seedream?.config?.model}},mounted(){this.value||this.applyModel(ne)},methods:{async onChange(e){let t=this.$store.state.seedream?.config||{},n=Te(t,{model:e});if(n.length===0){this.applyModel(e);return}let r=n.map(e=>this.$t(e.i18nLabel)).join(`、`);try{await V.confirm(this.$t(`seedream.message.featureNotSupportedBody`,{fields:r}),this.$t(`seedream.message.featureNotSupportedTitle`),{confirmButtonText:this.$t(`seedream.button.confirmContinue`),cancelButtonText:this.$t(`seedream.button.cancelSwitch`),type:`warning`});let i=Ee({...t,model:e},n,{model:e});this.$store.commit(`seedream/setConfig`,i),G.success(this.$t(`seedream.message.featureRemovedNotice`,{fields:r}))}catch{this.revertKey+=1}},applyModel(e){this.$store.commit(`seedream/setConfig`,{...this.$store.state.seedream?.config,model:e})}}}),Re={class:`field`},ze={class:`label`},Be={class:`box`},Ve={class:`title font-bold`};function He(r,i,c,d,f,p){let m=h(`info-icon`),_=h(`el-option`),v=h(`el-select`);return u(),t(`div`,Re,[n(`div`,ze,[n(`div`,Be,[n(`h2`,Ve,l(r.$t(`seedream.name.model`)),1),o(m,{content:r.$t(`seedream.description.model`),class:`info`},null,8,[`content`])])]),(u(),a(v,{key:r.revertKey,"model-value":r.value,class:`value`,placeholder:r.$t(`seedream.placeholder.select`),onChange:r.onChange},{default:g(()=>[(u(!0),t(s,null,e(r.options,e=>(u(),a(_,{key:e.value,label:e.label,value:e.value},null,8,[`label`,`value`]))),128))]),_:1},8,[`model-value`,`placeholder`,`onChange`]))])}var Ue=R(Le,[[`render`,He],[`__scopeId`,`data-v-8892a12c`]]),We=r({name:`SeedreamSizeSelector`,components:{ElSelect:b,ElOption:x,ElOptionGroup:y,InfoIcon:Z},data(){return{SEEDREAM_SIZE_ADAPTIVE:A,pixelOptions:N}},computed:{model(){return this.$store.state.seedream?.config?.model},capabilities(){return Q(this.model)},value:{get(){return this.$store.state.seedream?.config?.size},set(e){this.$store.commit(`seedream/setConfig`,{...this.$store.state.seedream?.config,size:e})}}},watch:{model:{immediate:!0,handler(){if(this.value)return;let e=this.capabilities;e.sizeTiers.length?this.value=e.sizeTiers.includes(`2K`)?`2K`:e.sizeTiers[0]:e.sizePixelDefault&&(this.value=e.sizePixelDefault)}}}}),Ge={class:`field`},Ke={class:`label`},qe={class:`box`},Je={class:`title font-bold`};function Ye(r,i,c,d,f,p){let _=h(`info-icon`),v=h(`el-option`),y=h(`el-option-group`),b=h(`el-select`);return u(),t(`div`,Ge,[n(`div`,Ke,[n(`div`,qe,[n(`h2`,Je,l(r.$t(`seedream.name.size`)),1),o(_,{content:r.$t(`seedream.description.size`),class:`info`},null,8,[`content`])])]),o(b,{modelValue:r.value,"onUpdate:modelValue":i[0]||=e=>r.value=e,class:`value`,placeholder:r.$t(`seedream.placeholder.size`),filterable:``,"allow-create":``,"default-first-option":``},{default:g(()=>[r.capabilities.sizeTiers.length?(u(),a(y,{key:0,label:r.$t(`seedream.size.group.tier`)},{default:g(()=>[(u(!0),t(s,null,e(r.capabilities.sizeTiers,e=>(u(),a(v,{key:e,label:e,value:e},null,8,[`label`,`value`]))),128))]),_:1},8,[`label`])):m(``,!0),r.capabilities.sizeAdaptive?(u(),a(y,{key:1,label:r.$t(`seedream.size.group.adaptive`)},{default:g(()=>[(u(),a(v,{key:r.SEEDREAM_SIZE_ADAPTIVE,label:r.$t(`seedream.size.adaptive`),value:r.SEEDREAM_SIZE_ADAPTIVE},null,8,[`label`,`value`]))]),_:1},8,[`label`])):m(``,!0),o(y,{label:r.$t(`seedream.size.group.pixel`)},{default:g(()=>[(u(!0),t(s,null,e(r.pixelOptions,e=>(u(),a(v,{key:e.value,label:`${e.value} (${e.ratio})`,value:e.value},null,8,[`label`,`value`]))),128))]),_:1},8,[`label`])]),_:1},8,[`modelValue`,`placeholder`])])}var Xe=R(We,[[`render`,Ye],[`__scopeId`,`data-v-dd7bd021`]]),Ze=r({name:`SeedreamMaxImagesSelector`,components:{ElInputNumber:D,InfoIcon:Z},computed:{config(){return this.$store.state.seedream?.config||{}},supported(){return Q(this.config?.model).groupGeneration},referenceImageCount(){let e=this.config?.image;return Array.isArray(e)?e.length:0},effectiveMax(){let e=15-this.referenceImageCount;return Math.max(1,Math.min(15,e))},value:{get(){let e=this.config?.sequential_image_generation_options?.max_images;return typeof e==`number`&&e>=1?e:1},set(e){let t={...this.config||{}},n=Math.max(1,Math.min(this.effectiveMax,Math.floor(e||1)));n>1?(t.sequential_image_generation=`auto`,t.sequential_image_generation_options={...t.sequential_image_generation_options||{},max_images:n}):(t.sequential_image_generation=`disabled`,t.sequential_image_generation_options&&delete t.sequential_image_generation_options),this.$store.commit(`seedream/setConfig`,t)}}},watch:{effectiveMax(e){this.value>e&&(this.value=e)}}}),Qe={key:0,class:`field`},$e={class:`label`},et={class:`box`},tt={class:`title font-bold`},nt={class:`value`};function rt(e,r,i,a,s,c){let d=h(`info-icon`),f=h(`el-input-number`);return e.supported?(u(),t(`div`,Qe,[n(`div`,$e,[n(`div`,et,[n(`h2`,tt,l(e.$t(`seedream.name.maxImages`)),1),o(d,{content:e.$t(`seedream.description.maxImages`),class:`info`},null,8,[`content`])])]),n(`div`,nt,[o(f,{modelValue:e.value,"onUpdate:modelValue":r[0]||=t=>e.value=t,min:1,max:e.effectiveMax,step:1,size:`default`,"controls-position":`right`,class:`counter`},null,8,[`modelValue`,`max`])])])):m(``,!0)}var it=R(Ze,[[`render`,rt],[`__scopeId`,`data-v-f079fd20`]]),at=r({name:`SeedreamOutputFormatSelector`,components:{ElSelect:b,ElOption:x,InfoIcon:Z},data(){return{options:[...k]}},computed:{config(){return this.$store.state.seedream?.config||{}},supported(){return Q(this.config?.model).outputFormat},value:{get(){return this.config?.output_format},set(e){let t={...this.config||{}};t.output_format=e,this.$store.commit(`seedream/setConfig`,t)}}}}),ot={key:0,class:`field`},st={class:`label`},ct={class:`box`},lt={class:`title font-bold`};function ut(r,i,c,d,f,p){let _=h(`info-icon`),v=h(`el-option`),y=h(`el-select`);return r.supported?(u(),t(`div`,ot,[n(`div`,st,[n(`div`,ct,[n(`h2`,lt,l(r.$t(`seedream.name.outputFormat`)),1),o(_,{content:r.$t(`seedream.description.outputFormat`),class:`info`},null,8,[`content`])])]),o(y,{modelValue:r.value,"onUpdate:modelValue":i[0]||=e=>r.value=e,class:`value`,placeholder:r.$t(`seedream.placeholder.select`)},{default:g(()=>[(u(!0),t(s,null,e(r.options,e=>(u(),a(v,{key:e,label:e.toUpperCase(),value:e},null,8,[`label`,`value`]))),128))]),_:1},8,[`modelValue`,`placeholder`])])):m(``,!0)}var dt=R(at,[[`render`,ut],[`__scopeId`,`data-v-69ea4c07`]]),ft=r({name:`SeedreamSeedInput`,components:{ElInputNumber:D,InfoIcon:Z},computed:{config(){return this.$store.state.seedream?.config||{}},supported(){return Q(this.config?.model).seed},value:{get(){let e=this.config?.seed;return typeof e==`number`?e:-1},set(e){let t={...this.config||{}};t.seed=typeof e==`number`&&Number.isInteger(e)?e:-1,this.$store.commit(`seedream/setConfig`,t)}}}}),pt={key:0,class:`field`},mt={class:`label`},ht={class:`box`},gt={class:`title font-bold`},_t={class:`value`};function vt(e,r,i,a,s,c){let d=h(`info-icon`),f=h(`el-input-number`);return e.supported?(u(),t(`div`,pt,[n(`div`,mt,[n(`div`,ht,[n(`h2`,gt,l(e.$t(`seedream.name.seed`)),1),o(d,{content:e.$t(`seedream.description.seed`),class:`info`},null,8,[`content`])])]),n(`div`,_t,[o(f,{modelValue:e.value,"onUpdate:modelValue":r[0]||=t=>e.value=t,min:-1,max:2147483647,step:1,size:`default`,"controls-position":`right`,class:`counter`},null,8,[`modelValue`])])])):m(``,!0)}var yt=R(ft,[[`render`,vt],[`__scopeId`,`data-v-10cdc1e0`]]),bt=r({name:`SeedreamGuidanceScaleInput`,components:{ElInputNumber:D,InfoIcon:Z},computed:{config(){return this.$store.state.seedream?.config||{}},supported(){return Q(this.config?.model).guidanceScale},defaultValue(){return Q(this.config?.model).guidanceScaleDefault??2.5},value:{get(){let e=this.config?.guidance_scale;return typeof e==`number`?e:this.defaultValue},set(e){let t={...this.config||{}};t.guidance_scale=typeof e==`number`&&e>=1&&e<=10?e:this.defaultValue,this.$store.commit(`seedream/setConfig`,t)}}}}),xt={key:0,class:`field`},St={class:`label`},Ct={class:`box`},wt={class:`title font-bold`},Tt={class:`value`};function Et(e,r,i,a,s,c){let d=h(`info-icon`),f=h(`el-input-number`);return e.supported?(u(),t(`div`,xt,[n(`div`,St,[n(`div`,Ct,[n(`h2`,wt,l(e.$t(`seedream.name.guidanceScale`)),1),o(d,{content:e.$t(`seedream.description.guidanceScale`),class:`info`},null,8,[`content`])])]),n(`div`,Tt,[o(f,{modelValue:e.value,"onUpdate:modelValue":r[0]||=t=>e.value=t,min:1,max:10,step:.1,precision:1,size:`default`,"controls-position":`right`,class:`counter`},null,8,[`modelValue`])])])):m(``,!0)}var Dt=R(bt,[[`render`,Et],[`__scopeId`,`data-v-7386f064`]]),Ot=r({name:`SeedreamWatermarkSwitch`,components:{ElSwitch:ee,InfoIcon:Z},computed:{value:{get(){let e=this.$store.state.seedream?.config?.watermark;return e===void 0?!1:!!e},set(e){this.$store.commit(`seedream/setConfig`,{...this.$store.state.seedream?.config,watermark:e})}}}}),kt={class:`field`},At={class:`label`},jt={class:`box`},Mt={class:`title font-bold`},Nt={class:`value`};function Pt(e,r,i,a,s,c){let d=h(`info-icon`),f=h(`el-switch`);return u(),t(`div`,kt,[n(`div`,At,[n(`div`,jt,[n(`h2`,Mt,l(e.$t(`seedream.name.watermark`)),1),o(d,{content:e.$t(`seedream.description.watermark`),class:`info`},null,8,[`content`])])]),n(`div`,Nt,[o(f,{modelValue:e.value,"onUpdate:modelValue":r[0]||=t=>e.value=t},null,8,[`modelValue`])])])}var Ft=r({name:`SeedreamConfigPanel`,components:{ElButton:v,FontAwesomeIcon:J,PromptInput:Se,Consumption:de,ImageInput:Ie,ModelSelector:Ue,SizeSelector:Xe,MaxImagesSelector:it,OutputFormatSelector:dt,SeedInput:yt,GuidanceScaleInput:Dt,WatermarkSwitch:R(Ot,[[`render`,Pt],[`__scopeId`,`data-v-9e2abf0f`]])},emits:[`generate`],computed:{config(){return this.$store.state.seedream?.config},consumption(){let e={...this.config||{}},t=Array.isArray(e?.image)&&e.image.length>0,n=e?.sequential_image_generation===`auto`?Math.max(1,Math.floor(e?.sequential_image_generation_options?.max_images||1)):1;return B({...e,action:t?`edit`:`generate`,model:j(e?.model),count:n},this.service?.cost)},service(){return this.$store.state.seedream?.service}},methods:{onGenerate(){this.$emit(`generate`)}}}),It={class:`flex flex-col h-full`},Lt={class:`flex-1 overflow-y-auto p-5`},Rt={class:`flex flex-col items-center justify-center px-5 pb-5`};function zt(e,r,a,s,c,d){let f=h(`model-selector`),p=h(`size-selector`),m=h(`max-images-selector`),_=h(`output-format-selector`),v=h(`seed-input`),y=h(`guidance-scale-input`),b=h(`watermark-switch`),x=h(`prompt-input`),S=h(`image-input`),C=h(`consumption`),w=h(`font-awesome-icon`),T=h(`el-button`);return u(),t(`div`,It,[n(`div`,Lt,[o(f,{class:`mb-4`}),o(p,{class:`mb-4`}),o(m,{class:`mb-4`}),o(_,{class:`mb-4`}),o(v,{class:`mb-4`}),o(y,{class:`mb-4`}),o(b,{class:`mb-4`}),o(x,{class:`mb-4`}),o(S,{class:`mb-4`})]),n(`div`,Rt,[o(C,{value:e.consumption,service:e.service},null,8,[`value`,`service`]),o(T,{type:`primary`,class:`btn w-full`,round:``,onClick:e.onGenerate},{default:g(()=>[o(w,{icon:`fa-solid fa-magic`,class:`mr-2`}),i(` `+l(e.$t(`seedream.button.generate`)),1)]),_:1},8,[`onClick`])])])}var Bt=R(Ft,[[`render`,zt]]),Vt=r({name:`SeedreamTaskPreview`,components:{ElImage:w,CopyToClipboard:Y,FontAwesomeIcon:J,ElAlert:T,ImageWrapper:pe,ElButton:v,ElTooltip:C,ImagePreview:X,ApiCodeButton:fe},props:{modelValue:{type:Object,required:!0}},computed:{isEdit(){return Array.isArray(this.modelValue?.request?.image)&&(this.modelValue?.request?.image?.length||0)>0},images(){let e=[];return Array.isArray(this.modelValue?.response?.data)&&this.modelValue?.response?.data?.forEach(t=>{e.push(t)}),e}},methods:{shortModel(e){return j(e)||e},onEdit(e){if(!e)return;console.debug(`Edit image:`,e);let t={...this.$store.state.seedream?.config||{}};t.image=[e],this.$store.commit(`seedream/setConfig`,t)}}}),Ht={class:`preview`},Ut={class:`left`},Wt={class:`main`},Gt={class:`bot`},Kt={class:`datetime`},qt={class:`info`},Jt={key:0,class:`flex justify-start items-center gap-2 mt-2 w-full overflow-x-auto`},Yt={key:1,class:`prompt mt-2`},Xt={key:0},Zt={key:0,class:c({content:!0})},Qt={class:`text-[var(--el-text-color-regular)] text-xs mb-0`},$t={key:1,class:c({content:!0,failed:!0})},en={class:`flex justify-start items-center gap-4 w-full overflow-x-auto`},tn={class:c({operations:!0,"mt-2":!0,"mb-2":!0})},nn={key:0,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},rn={key:1,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},an={class:`text-[var(--el-text-color-regular)] text-xs mb-2`},on={class:`text-[var(--el-text-color-regular)] text-xs mb-2`},sn={key:2,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},cn={key:3,class:`text-[var(--el-text-color-regular)] text-xs mb-0`},$={key:2,class:c({content:!0})},ln={key:0,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},un={key:1,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},dn={class:`text-[var(--el-text-color-regular)] text-xs mb-2`},fn={class:`text-[var(--el-text-color-regular)] text-xs mb-2`},pn={key:2,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},mn={key:3,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},hn={key:4,class:`text-[var(--el-text-color-regular)] text-xs mb-0`},gn={key:3,class:c({content:!0})},_n={class:`text-[var(--el-text-color-regular)] text-xs mb-2`},vn={key:0,class:`text-[var(--el-text-color-regular)] text-xs mb-0`};function yn(r,c,f,p,_,v){let y=h(`el-image`),b=h(`image-preview`),x=h(`font-awesome-icon`),S=h(`copy-to-clipboard`),C=h(`el-alert`),w=h(`image-wrapper`),T=h(`el-button`),E=h(`el-tooltip`),D=h(`api-code-button`);return u(),t(`div`,Ht,[n(`div`,Ut,[o(y,{src:`https://cdn.acedata.cloud/9egrbn.png`,class:`avatar`})]),n(`div`,Wt,[n(`div`,Gt,[i(l(r.$t(`seedream.name.seedreamBot`))+` `,1),n(`span`,Kt,l(r.$dayjs.format(``+new Date(parseFloat((r.modelValue?.created_at||``).toString())*1e3))),1)]),n(`div`,qt,[Array.isArray(r.modelValue?.request?.image)&&r.modelValue?.request?.image.length>0?(u(),t(`div`,Jt,[(u(!0),t(s,null,e(r.modelValue?.request?.image,(e,t)=>(u(),a(b,{key:t,url:e,name:`image-${t+1}`,closable:!1},null,8,[`url`,`name`]))),128))])):m(``,!0),r.modelValue?.request?.prompt?(u(),t(`p`,Yt,[i(l(r.modelValue?.request?.prompt)+` `,1),r.modelValue?.response?m(``,!0):(u(),t(`span`,Xt,` - (`+l(r.$t(`seedream.status.pending`))+`) `,1))])):m(``,!0)]),r.modelValue?.response?r.modelValue?.response?.success===!0?(u(),t(`div`,$t,[n(`div`,en,[(u(!0),t(s,null,e(r.images,(e,t)=>(u(),a(w,{key:t,src:e?.image_url,"raw-src":e?.image_url},null,8,[`src`,`raw-src`]))),128))]),n(`div`,tn,[o(E,{class:`box-item`,effect:`dark`,content:r.$t(`common.button.edit`),placement:`top-start`},{default:g(()=>[o(T,{type:`info`,size:`small`,class:`btn-action`,onClick:c[0]||=d(e=>r.onEdit(r.images?.[0]?.image_url),[`stop`])},{default:g(()=>[i(l(r.$t(`common.button.edit`)),1)]),_:1})]),_:1},8,[`content`]),o(D,{path:`/seedream/images`,body:r.modelValue?.request},null,8,[`body`])]),o(C,{closable:!1,class:`mt-2 success`},{default:g(()=>[r.modelValue?.request?.model?(u(),t(`p`,nn,[o(x,{icon:`fa-solid fa-cube`,class:`mr-1`}),i(` `+l(r.$t(`seedream.name.model`))+`: `+l(r.shortModel(r.modelValue?.request?.model)),1)])):m(``,!0),r.modelValue?.request?.size?(u(),t(`p`,rn,[o(x,{icon:`fa-solid fa-image`,class:`mr-1`}),i(` `+l(r.$t(`seedream.name.size`))+`: `+l(r.modelValue?.request?.size),1)])):m(``,!0),n(`p`,an,[o(x,{icon:`fa-solid fa-bolt`,class:`mr-1`}),i(` `+l(r.$t(`seedream.name.task`))+`: `+l(r.isEdit?r.$t(`seedream.name.edits`):r.$t(`seedream.name.generate`)),1)]),n(`p`,on,[o(x,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+l(r.$t(`seedream.name.taskId`))+`: `+l(r.modelValue?.id)+` `,1),o(S,{content:r.modelValue?.id,class:`btn-copy inline-block`},null,8,[`content`])]),r.modelValue?.elapsed?(u(),t(`p`,sn,[o(x,{icon:`fa-solid fa-clock`,class:`mr-1`}),i(` `+l(r.$t(`seedream.name.elapsed`))+`: `+l(r.modelValue?.elapsed?.toFixed(2))+`s `,1)])):m(``,!0),r.modelValue?.response?.trace_id?(u(),t(`p`,cn,[o(x,{icon:`fa-solid fa-hashtag`,class:`mr-1`}),i(` `+l(r.$t(`seedream.name.traceId`))+`: `+l(r.modelValue?.response?.trace_id)+` `,1),o(S,{content:r.modelValue?.response?.trace_id,class:`btn-copy inline-block`},null,8,[`content`])])):m(``,!0)]),_:1})])):r.modelValue?.response?.success===!1?(u(),t(`div`,$,[o(C,{closable:!1,class:`failure`},{template:g(()=>[o(x,{icon:`fa-solid fa-exclamation-triangle`,class:`mr-1`}),i(` `+l(r.$t(`seedream.name.failure`)),1)]),default:g(()=>[r.modelValue?.request?.model?(u(),t(`p`,ln,[o(x,{icon:`fa-solid fa-cube`,class:`mr-1`}),i(` `+l(r.$t(`seedream.name.model`))+`: `+l(r.shortModel(r.modelValue?.request?.model)),1)])):m(``,!0),r.modelValue?.request?.size?(u(),t(`p`,un,[o(x,{icon:`fa-solid fa-image`,class:`mr-1`}),i(` `+l(r.$t(`seedream.name.size`))+`: `+l(r.modelValue?.request?.size),1)])):m(``,!0),n(`p`,dn,[o(x,{icon:`fa-solid fa-bolt`,class:`mr-1`}),i(` `+l(r.$t(`seedream.name.task`))+`: `+l(r.isEdit?r.$t(`seedream.name.edits`):r.$t(`seedream.name.generate`)),1)]),n(`p`,fn,[o(x,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+l(r.$t(`seedream.name.taskId`))+`: `+l(r.modelValue?.id)+` `,1),o(S,{content:r.modelValue?.id,class:`btn-copy`},null,8,[`content`])]),r.modelValue?.response?.error?.message?(u(),t(`p`,pn,[o(x,{icon:`fa-solid fa-circle-info`,class:`mr-1`}),i(` `+l(r.$t(`seedream.name.failureReason`))+`: `+l(r.modelValue?.response?.error?.message)+` `,1),o(S,{content:r.modelValue?.response?.error?.message,class:`btn-copy`},null,8,[`content`])])):m(``,!0),r.modelValue?.elapsed?(u(),t(`p`,mn,[o(x,{icon:`fa-solid fa-clock`,class:`mr-1`}),i(` `+l(r.$t(`seedream.name.elapsed`))+`: `+l(r.modelValue?.elapsed?.toFixed(2))+`s `,1)])):m(``,!0),r.modelValue?.response?.trace_id?(u(),t(`p`,hn,[o(x,{icon:`fa-solid fa-hashtag`,class:`mr-1`}),i(` `+l(r.$t(`seedream.name.traceId`))+`: `+l(r.modelValue?.response?.trace_id)+` `,1),o(S,{content:r.modelValue?.response?.trace_id,class:`btn-copy`},null,8,[`content`])])):m(``,!0)]),_:1})])):(u(),t(`div`,gn,[o(C,{closable:!1,class:`info`},{template:g(()=>[o(x,{icon:`fa-solid fa-circle-info`,class:`mr-1`}),i(` `+l(r.$t(`seedream.name.status`)),1)]),default:g(()=>[n(`p`,_n,[o(x,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+l(r.$t(`seedream.name.taskId`))+`: `+l(r.modelValue?.id)+` `,1),o(S,{content:r.modelValue?.id,class:`btn-copy`},null,8,[`content`])]),r.modelValue?.response?.trace_id?(u(),t(`p`,vn,[o(x,{icon:`fa-solid fa-hashtag`,class:`mr-1`}),i(` `+l(r.$t(`seedream.name.traceId`))+`: `+l(r.modelValue?.response?.trace_id)+` `,1),o(S,{content:r.modelValue?.response?.trace_id,class:`btn-copy`},null,8,[`content`])])):m(``,!0)]),_:1})])):(u(),t(`div`,Zt,[o(C,{closable:!1,class:`info`},{template:g(()=>[o(x,{icon:`fa-regular fa-clock`,class:`mr-1`}),i(` `+l(r.$t(`seedream.status.pending`)),1)]),default:g(()=>[n(`p`,Qt,[o(x,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+l(r.$t(`seedream.name.taskId`))+`: `+l(r.modelValue?.id)+` `,1),o(S,{content:r.modelValue?.id,class:`btn-copy inline-block`},null,8,[`content`])])]),_:1})]))])])}var bn=r({name:`SeedreamRecentPanel`,components:{TaskPreview:R(Vt,[[`render`,yn],[`__scopeId`,`data-v-1b4654bc`]]),BotPlaceholder:oe,NoTasks:ue,ScrollList:se},props:{loading:{type:Boolean,default:!1}},emits:[`reach-top`],computed:{tasks(){return{...this.$store.state.seedream?.tasks,items:this.$store.state.seedream?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),xn={key:0},Sn={key:2,class:`w-full h-full flex items-center justify-center`};function Cn(n,r,i,c,l,d){let f=h(`bot-placeholder`),p=h(`task-preview`),_=h(`scroll-list`),v=h(`no-tasks`);return u(),t(s,null,[n.tasks?.items===void 0?(u(),t(`div`,xn,[o(f)])):n.tasks?.items?.length&&n.tasks?.items?.length>0?(u(),a(_,{key:1,ref:`scrollList`,class:`tasks h-full w-full overflow-y-auto`,loading:n.loading,onReachTop:r[0]||=e=>n.$emit(`reach-top`)},{default:g(()=>[(u(!0),t(s,null,e(n.tasks?.items,e=>(u(),a(p,{key:e.id,"model-value":e},null,8,[`model-value`]))),128))]),_:1},8,[`loading`])):m(``,!0),n.tasks?.items?.length===0?(u(),t(`div`,Sn,[o(v)])):m(``,!0)],64)}var wn=R(bn,[[`render`,Cn]]),Tn=te(`seedream`),En=r({name:`SeedreamIndex`,components:{ConfigPanel:Bt,Layout:ye,RecentPanel:wn},mixins:[ie],inject:[`initialized`],data(){return{task:void 0,job:0,loading:!1}},computed:{applicationsLoading(){return this.$store.state.seedream?.status?.getApplications===q.Request},tasksLoading(){return this.$store.state.seedream?.status?.getTasks===q.Request},credential(){return this.$store.state.seedream?.credential},config(){return this.$store.state.seedream?.config},application(){return this.$store.state.seedream?.application},tasks(){return this.$store.state.seedream?.tasks}},watch:{tasks:{handler(e,t){e?.items?.length>t?.items?.length&&console.debug(`new tasks detected`)},deep:!0},initialized:{async handler(e){e&&(console.debug(`layout initialized`),await this.onGetTasks(),await this.onScrollDown(),this.job=window.setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){window.clearInterval(this.job)},methods:{async onReachTop(){await ce({tasks:this.tasks,getTasks:()=>this.tasks,loading:this.loading,setLoading:e=>this.loading=e,isBlocked:()=>this.tasksLoading,fetch:e=>this.onGetTasks({createdAtMax:e}),getScrollElement:()=>this.getTasksScrollElement()})},async onGetService(){console.debug(`start onGetService`),await this.$store.dispatch(`seedream/getService`),console.debug(`end onGetService`)},async onGetApplication(){console.debug(`start onGetApplication`),await this.$store.dispatch(`seedream/getApplications`),console.debug(`end onGetApplication`),await this.onGetTasks()},async onScrollDown(){await this.$nextTick();let e=this.getTasksScrollElement();e&&(e.scrollTop=e.scrollHeight)},async onGetTasks(e){if(this.applicationsLoading||this.tasksLoading){console.debug(`loading`);return}console.debug(`start onGetTasks`,e);let{limit:t=20,createdAtMin:n,createdAtMax:r}=e||{};console.debug(`limit`,t,`createdAtMin`,n,`createdAtMax`,r),await this.$store.dispatch(`seedream/getTasks`,{limit:t,createdAtMin:n,createdAtMax:r})},async onGenerate(){if(!H(this.uploadTracker,e=>this.$t(e),e=>G.warning(e)))return;let e={...this.config||{}};!(Array.isArray(e?.image)&&e.image.length>0)&&`image`in e&&delete e.image,e?.size||delete e.size;let t={...e,callback_url:Tn},n=this.credential?.token;if(!n){console.error(`no token specified`);return}G.info(this.$t(`seedream.message.startingTask`)),z(`seedream`,re.generate(t,{token:n})).then(()=>{G.success(this.$t(`seedream.message.startTaskSuccess`))}).catch(e=>{let t=e?.response?.data;t?.error?.code===`used_up`?G.error(this.$t(`seedream.message.usedUp`)):G.error(this.$t(`seedream.message.startTaskFailed`)+(t?.error?.message||``))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function Dn(e,t,n,r,i,s){let c=h(`config-panel`),l=h(`recent-panel`),d=h(`layout`);return u(),a(d,null,{config:g(()=>[o(c,{onGenerate:e.onGenerate},null,8,[`onGenerate`])]),result:g(()=>[o(l,{ref:`recentPanel`,loading:e.loading,onReachTop:e.onReachTop},null,8,[`loading`,`onReachTop`])]),_:1})}var On=R(En,[[`render`,Dn]]);export{On as default};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import"./rolldown-runtime--c01j_DQ.js";import{$ as e,A as t,D as n,F as r,N as i,O as a,P as o,S as s,Ut as c,Vt as l,Wt as u,Z as d,b as f,k as p,tt as m,ut as h}from"./vendor-chart-BJCvKk8-.js";import{t as g}from"./button-DfsQodL-.js";import{r as _,t as v}from"./select-CTfF5Pq0.js";import{t as y}from"./upload-PztQKfjm.js";import{t as b}from"./tooltip-BLwTovWL.js";import{t as x}from"./image-OB0St7Yu.js";import{t as S}from"./alert-OvnfgMB-.js";import{Ct as C,Et as w,Ot as T,St as E,Tt as D,_i as O,_t as k,bt as A,vt as j,wt as ee,xt as te,yt as M}from"./constants-CwLEZ_AF.js";import{At as N,E as P,Fn as F,Nt as I,Ot as L,Sr as R,Zt as z,jt as B,kr as V,kt as H,yr as U}from"./index-CTMytxLX.js";import{t as W}from"./index.es-DsMKNIuW.js";import{t as G}from"./CopyToClipboard-CRnka5tK.js";import{t as K}from"./ImagePreview-DhCeZxCj.js";import{t as q}from"./BotPlaceholder-C1UVVId0.js";import{i as J,n as Y,t as X}from"./pagination-CMIlkvfz.js";import{n as Z,t as Q}from"./NoTasks-C1jixEiN.js";import{t as ne}from"./Consumption-DTpXXWzm.js";import{t as re}from"./ApiCodeButton-C1XeBPd6.js";import{t as ie}from"./Seedance-LsGJ233H.js";import{t as ae}from"./VideoPlayer-gT-2rF-j.js";var oe=r({name:`GrokVideoPromptInput`,components:{PromptTextarea:Z},computed:{prompt:{get(){return this.$store.state.grokvideo?.config?.prompt},set(e){this.$store.commit(`grokvideo/setConfig`,{...this.$store.state.grokvideo?.config,prompt:e})}}},mounted(){this.prompt||=``}});function se(e,t,n,r,i,o){let s=m(`prompt-textarea`);return d(),a(s,{modelValue:e.prompt,"onUpdate:modelValue":t[0]||=t=>e.prompt=t,title:e.$t(`grokvideo.name.prompt`),info:e.$t(`grokvideo.description.prompt`),placeholder:e.$t(`grokvideo.placeholder.prompt`),"min-rows":5},null,8,[`modelValue`,`title`,`info`,`placeholder`])}var ce=P(oe,[[`render`,se]]),le=r({name:`GrokVideoModelSelector`,components:{ElSelect:_,ElOption:v,InfoIcon:J},data(){return{options:[{value:E,label:this.$t(`grokvideo.model.default`)},{value:te,label:this.$t(`grokvideo.model.preview15`)}]}},computed:{value:{get(){return this.$store.state.grokvideo?.config?.model},set(e){this.$store.commit(`grokvideo/setConfig`,{...this.$store.state.grokvideo?.config,model:e})}}},mounted(){this.value||=k}}),ue={class:`field`},de={class:`label`},fe={class:`box`},pe={class:`title font-bold`};function me(r,i,c,l,f,p){let g=m(`info-icon`),_=m(`el-option`),v=m(`el-select`);return d(),t(`div`,ue,[n(`div`,de,[n(`div`,fe,[n(`h2`,pe,u(r.$t(`grokvideo.name.model`)),1),o(g,{content:r.$t(`grokvideo.description.model`),class:`info`},null,8,[`content`])])]),o(v,{modelValue:r.value,"onUpdate:modelValue":i[0]||=e=>r.value=e,class:`value`,placeholder:r.$t(`grokvideo.placeholder.select`)},{default:h(()=>[(d(!0),t(s,null,e(r.options,e=>(d(),a(_,{key:e.value,label:e.label,value:e.value},null,8,[`label`,`value`]))),128))]),_:1},8,[`modelValue`,`placeholder`])])}var he=P(le,[[`render`,me],[`__scopeId`,`data-v-291d93fb`]]),ge=r({name:`GrokVideoDurationSelector`,components:{ElSelect:_,ElOption:v,InfoIcon:J},data(){return{options:[{value:3,label:`3s`},{value:5,label:`5s`},{value:6,label:`6s`},{value:8,label:`8s`},{value:10,label:`10s`},{value:12,label:`12s`},{value:15,label:`15s`}]}},computed:{value:{get(){return this.$store.state.grokvideo?.config?.duration},set(e){this.$store.commit(`grokvideo/setConfig`,{...this.$store.state.grokvideo?.config,duration:e})}}},mounted(){this.value||=8}}),_e={class:`field`},ve={class:`label`},ye={class:`box`},be={class:`title font-bold`};function xe(r,i,c,l,f,p){let g=m(`info-icon`),_=m(`el-option`),v=m(`el-select`);return d(),t(`div`,_e,[n(`div`,ve,[n(`div`,ye,[n(`h2`,be,u(r.$t(`grokvideo.name.duration`)),1),o(g,{content:r.$t(`grokvideo.description.duration`),class:`info`},null,8,[`content`])])]),o(v,{modelValue:r.value,"onUpdate:modelValue":i[0]||=e=>r.value=e,class:`value`,placeholder:r.$t(`grokvideo.placeholder.select`)},{default:h(()=>[(d(!0),t(s,null,e(r.options,e=>(d(),a(_,{key:e.value,label:e.label,value:e.value},null,8,[`label`,`value`]))),128))]),_:1},8,[`modelValue`,`placeholder`])])}var Se=P(ge,[[`render`,xe],[`__scopeId`,`data-v-8b8ef5e7`]]),Ce=r({name:`GrokVideoResolutionSelector`,components:{InfoIcon:J},data(){return{options:[{value:D,label:`480p`},{value:w,label:`720p`}]}},computed:{value:{get(){return this.$store.state.grokvideo?.config?.resolution},set(e){this.$store.commit(`grokvideo/setConfig`,{...this.$store.state.grokvideo?.config,resolution:e})}}},mounted(){this.value||=M}}),we={class:`resolution`},Te={class:`header`},Ee={class:`title font-bold`},De={class:`items`},Oe=[`onClick`];function ke(r,i,a,c,f,p){let h=m(`info-icon`);return d(),t(`div`,we,[n(`div`,Te,[n(`h2`,Ee,u(r.$t(`grokvideo.name.resolution`)),1),o(h,{content:r.$t(`grokvideo.description.resolution`),class:`info`},null,8,[`content`])]),n(`div`,De,[(d(!0),t(s,null,e(r.options,e=>(d(),t(`div`,{key:e.value,class:l([`item`,{active:r.value===e.value}]),onClick:t=>r.value=e.value},u(e.label),11,Oe))),128))])])}var Ae=P(Ce,[[`render`,ke],[`__scopeId`,`data-v-f1ebb899`]]),je=r({name:`GrokVideoRatioSelector`,components:{InfoIcon:J},computed:{options(){return[{value:C,label:`16:9`,w:32,h:18},{value:ee,label:`9:16`,w:18,h:32},{value:`1:1`,label:`1:1`,w:24,h:24},{value:`4:3`,label:`4:3`,w:28,h:21},{value:`3:4`,label:`3:4`,w:21,h:28},{value:`3:2`,label:`3:2`,w:30,h:20},{value:`2:3`,label:`2:3`,w:20,h:30}]},value:{get(){return this.$store.state.grokvideo?.config?.aspect_ratio},set(e){this.$store.commit(`grokvideo/setConfig`,{...this.$store.state.grokvideo?.config,aspect_ratio:e})}}},mounted(){this.value||=j}}),Me={class:`ratio`},Ne={class:`header`},Pe={class:`title font-bold`},Fe={class:`items`},Ie=[`onClick`],Le={class:`preview`},Re={class:`name`};function ze(r,i,a,f,p,h){let g=m(`info-icon`);return d(),t(`div`,Me,[n(`div`,Ne,[n(`h2`,Pe,u(r.$t(`grokvideo.name.ratio`)),1),o(g,{content:r.$t(`grokvideo.description.ratio`),class:`info`},null,8,[`content`])]),n(`div`,Fe,[(d(!0),t(s,null,e(r.options,e=>(d(),t(`div`,{key:e.value,class:l([`item`,{active:r.value===e.value}]),onClick:t=>r.value=e.value},[n(`div`,Le,[n(`div`,{class:`rect`,style:c({width:e.w+`px`,height:e.h+`px`})},null,4)]),n(`div`,Re,u(e.label),1)],10,Ie))),128))])])}var Be=P(je,[[`render`,ze],[`__scopeId`,`data-v-70115284`]]),Ve=r({name:`GrokVideoImageInput`,components:{ElUpload:y,ElButton:g,InfoIcon:J,FontAwesomeIcon:W,ImagePreview:K},mixins:[B,H],data(){return{fileList:[],uploadUrl:R()+`/api/v1/files/`}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},required(){return T(this.$store.state.grokvideo?.config?.model)},urls(){return this.fileList.map(e=>e?.response?.file_url)}},methods:{onExceed(){V.warning(this.$t(`grokvideo.message.uploadExceed`))},onError(){V.error(this.$t(`grokvideo.message.uploadError`))},onSetImageUrl(){let e=this.urls?.[0];this.$store.commit(`grokvideo/setConfig`,{...this.$store.state.grokvideo?.config,image_url:e||void 0})},async onSuccess(){this.onSetImageUrl()},async onRemove(){this.onSetImageUrl()}}}),He={class:`relative`},Ue={class:`flex justify-between`},We={class:`flex justify-start items-center`},Ge={class:`text-sm font-bold`},Ke={key:0,class:`required-badge`};function qe(e,r,s,c,l,f){let g=m(`info-icon`),_=m(`image-preview`),v=m(`font-awesome-icon`),y=m(`el-button`),b=m(`el-upload`);return d(),t(`div`,He,[n(`div`,Ue,[n(`div`,We,[n(`span`,Ge,u(e.$t(`grokvideo.name.image`)),1),e.required?(d(),t(`span`,Ke,u(e.$t(`grokvideo.name.required`)),1)):p(``,!0),o(g,{content:e.$t(`grokvideo.description.image`)},null,8,[`content`])])]),o(b,{ref:`uploader`,"file-list":e.fileList,"onUpdate:fileList":r[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,"on-remove":e.onRemove,headers:e.headers},{file:h(({file:t})=>[t.url&&t.percentage!==void 0?(d(),a(_,{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`])):p(``,!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`}),i(` `+u(e.$t(`grokvideo.button.upload`)),1)]),_:1})]),_:1},8,[`file-list`,`action`,`on-exceed`,`on-error`,`on-success`,`on-remove`,`headers`])])}var Je=r({name:`GrokVideoConfigPanel`,components:{ElButton:g,FontAwesomeIcon:W,PromptInput:ce,ModelSelector:he,DurationSelector:Se,ResolutionSelector:Ae,RatioSelector:Be,ImageInput:P(Ve,[[`render`,qe],[`__scopeId`,`data-v-164e5a1d`]]),Consumption:ne},emits:[`generate`],computed:{config(){return this.$store.state.grokvideo?.config},consumption(){return I(this.config,this.service?.cost)},service(){return this.$store.state.grokvideo?.service}},methods:{onGenerate(){this.$emit(`generate`)}}}),Ye={class:`flex flex-col h-full`},Xe={class:`flex-1 overflow-y-auto p-5`},Ze={class:`flex flex-col items-center justify-center px-5 pb-5`};function Qe(e,r,a,s,c,l){let f=m(`prompt-input`),p=m(`model-selector`),g=m(`ratio-selector`),_=m(`resolution-selector`),v=m(`duration-selector`),y=m(`image-input`),b=m(`consumption`),x=m(`font-awesome-icon`),S=m(`el-button`);return d(),t(`div`,Ye,[n(`div`,Xe,[o(f,{class:`mb-4`}),o(p,{class:`mb-4`}),o(g,{class:`mb-4`}),o(_,{class:`mb-4`}),o(v,{class:`mb-4`}),o(y,{class:`mb-2`})]),n(`div`,Ze,[o(b,{value:e.consumption,service:e.service},null,8,[`value`,`service`]),o(S,{type:`primary`,class:`btn w-full`,round:``,onClick:e.onGenerate},{default:h(()=>[o(x,{icon:`fa-solid fa-magic`,class:`mr-2`}),i(` `+u(e.$t(`grokvideo.button.generate`)),1)]),_:1},8,[`onClick`])])])}var $e=P(Je,[[`render`,Qe]]),et=r({name:`GrokVideoTaskPreview`,components:{ElImage:x,CopyToClipboard:G,FontAwesomeIcon:W,ElAlert:S,VideoPlayer:ae,ElTooltip:b,ElButton:g,ImagePreview:K,ApiCodeButton:re},props:{modelValue:{type:Object,required:!0}},data(){return{grokVideoLogo:A}},computed:{video(){return this.modelValue?.response?.data?.[0]},inputImage(){return this.modelValue?.request?.image_url}},methods:{onDownload(e){window.open(e,`_blank`)}}}),tt={class:`preview`},nt={class:`left`},rt={class:`main`},it={class:`bot`},at={class:`datetime`},ot={class:`info`},st={key:0,class:`flex justify-start items-center gap-2 mt-2 w-full overflow-x-auto`},ct={key:1,class:`prompt mt-2`},lt={key:0},ut={key:1},dt={key:0,class:l({content:!0})},ft={class:`text-[var(--el-text-color-regular)] text-xs mb-0`},pt={key:1,class:l({content:!0})},mt={key:0,class:`mb-4`},ht={key:1,class:l({operations:!0,"mt-2":!0,"mb-2":!0})},gt={key:0,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},_t={key:1,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},vt={key:2,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},yt={key:0},bt={class:`text-[var(--el-text-color-regular)] text-xs mb-2`},xt={key:3,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},St={key:4,class:`text-[var(--el-text-color-regular)] text-xs mb-0`},Ct={key:2,class:l({content:!0})},wt={class:`text-[var(--el-text-color-regular)] text-xs mb-2`},Tt={key:0,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},Et={key:1,class:`text-[var(--el-text-color-regular)] text-xs mb-0`},$={key:3,class:l({content:!0})},Dt={class:`text-[var(--el-text-color-regular)] text-xs mb-0`};function Ot(e,r,a,s,c,l){let g=m(`el-image`),_=m(`image-preview`),v=m(`font-awesome-icon`),y=m(`copy-to-clipboard`),b=m(`el-alert`),x=m(`video-player`),S=m(`el-button`),C=m(`el-tooltip`),w=m(`api-code-button`);return d(),t(`div`,tt,[n(`div`,nt,[o(g,{src:e.grokVideoLogo,class:`avatar`},null,8,[`src`])]),n(`div`,rt,[n(`div`,it,[i(u(e.$t(`grokvideo.name.bot`))+` `,1),n(`span`,at,u(e.$dayjs.format(``+new Date(parseFloat((e.modelValue?.created_at||``).toString())*1e3))),1)]),n(`div`,ot,[e.inputImage?(d(),t(`div`,st,[o(_,{url:e.inputImage,name:`image`,closable:!1},null,8,[`url`])])):p(``,!0),e.modelValue?.request?.prompt?(d(),t(`p`,ct,[i(u(e.modelValue?.request?.prompt)+` `,1),e.modelValue?.response?e.video?.state===`processing`||e.video?.state===`pending`?(d(),t(`span`,ut,` - (`+u(e.$t(`grokvideo.status.processing`))+`) `,1)):p(``,!0):(d(),t(`span`,lt,` - (`+u(e.$t(`grokvideo.status.pending`))+`) `,1))])):p(``,!0)]),e.modelValue?.response?e.modelValue?.response?.success===!0?(d(),t(`div`,pt,[e.video?.video_url?(d(),t(`div`,mt,[o(x,{src:e.video?.video_url},null,8,[`src`])])):p(``,!0),e.video?.video_url?(d(),t(`div`,ht,[o(C,{class:`box-item`,effect:`dark`,content:e.$t(`grokvideo.message.downloadVideo`),placement:`top-start`},{default:h(()=>[o(S,{type:`info`,size:`small`,class:`btn-action`,onClick:r[0]||=f(t=>e.onDownload(e.video?.video_url),[`stop`])},{default:h(()=>[i(u(e.$t(`grokvideo.button.download`)),1)]),_:1})]),_:1},8,[`content`]),o(w,{path:`/grok/videos`,body:e.modelValue?.request},null,8,[`body`])])):p(``,!0),o(b,{closable:!1,class:`mt-2 success`},{default:h(()=>[e.modelValue?.request?.model?(d(),t(`p`,gt,[o(v,{icon:`fa-solid fa-cube`,class:`mr-1`}),i(` `+u(e.$t(`grokvideo.name.model`))+`: `+u(e.modelValue?.request?.model),1)])):p(``,!0),e.video?.duration?(d(),t(`p`,_t,[o(v,{icon:`fa-solid fa-clock`,class:`mr-1`}),i(` `+u(e.$t(`grokvideo.name.duration`))+`: `+u(e.video?.duration)+`s `,1)])):p(``,!0),e.modelValue?.request?.resolution?(d(),t(`p`,vt,[o(v,{icon:`fa-solid fa-expand`,class:`mr-1`}),i(` `+u(e.$t(`grokvideo.name.resolution`))+`: `+u(e.modelValue?.request?.resolution)+` `,1),e.modelValue?.request?.aspect_ratio?(d(),t(`span`,yt,` · `+u(e.modelValue?.request?.aspect_ratio),1)):p(``,!0)])):p(``,!0),n(`p`,bt,[o(v,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+u(e.$t(`grokvideo.name.taskId`))+`: `+u(e.modelValue?.id)+` `,1),o(y,{content:e.modelValue?.id,class:`btn-copy inline-block`},null,8,[`content`])]),e.modelValue?.elapsed?(d(),t(`p`,xt,[o(v,{icon:`fa-solid fa-clock`,class:`mr-1`}),i(` `+u(e.$t(`grokvideo.name.elapsed`))+`: `+u(e.modelValue?.elapsed?.toFixed(2))+`s `,1)])):p(``,!0),e.modelValue?.response?.trace_id?(d(),t(`p`,St,[o(v,{icon:`fa-solid fa-hashtag`,class:`mr-1`}),i(` `+u(e.$t(`grokvideo.name.traceId`))+`: `+u(e.modelValue?.response?.trace_id)+` `,1),o(y,{content:e.modelValue?.response?.trace_id,class:`btn-copy inline-block`},null,8,[`content`])])):p(``,!0)]),_:1})])):e.modelValue?.response?.success===!1?(d(),t(`div`,Ct,[o(b,{closable:!1,class:`failure`},{template:h(()=>[o(v,{icon:`fa-solid fa-exclamation-triangle`,class:`mr-1`}),i(` `+u(e.$t(`grokvideo.name.failure`)),1)]),default:h(()=>[n(`p`,wt,[o(v,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+u(e.$t(`grokvideo.name.taskId`))+`: `+u(e.modelValue?.id)+` `,1),o(y,{content:e.modelValue?.id,class:`btn-copy inline-block`},null,8,[`content`])]),e.modelValue?.response?.error?.message?(d(),t(`p`,Tt,[o(v,{icon:`fa-solid fa-circle-info`,class:`mr-1`}),i(` `+u(e.$t(`grokvideo.name.failureReason`))+`: `+u(e.modelValue?.response?.error?.message)+` `,1),o(y,{content:e.modelValue?.response?.error?.message,class:`btn-copy inline-block`},null,8,[`content`])])):p(``,!0),e.modelValue?.response?.trace_id?(d(),t(`p`,Et,[o(v,{icon:`fa-solid fa-hashtag`,class:`mr-1`}),i(` `+u(e.$t(`grokvideo.name.traceId`))+`: `+u(e.modelValue?.response?.trace_id)+` `,1),o(y,{content:e.modelValue?.response?.trace_id,class:`btn-copy inline-block`},null,8,[`content`])])):p(``,!0)]),_:1})])):(d(),t(`div`,$,[o(b,{closable:!1,class:`info`},{template:h(()=>[o(v,{icon:`fa-solid fa-circle-info`,class:`mr-1`}),i(` `+u(e.$t(`grokvideo.name.status`)),1)]),default:h(()=>[n(`p`,Dt,[o(v,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+u(e.$t(`grokvideo.name.taskId`))+`: `+u(e.modelValue?.id)+` `,1),o(y,{content:e.modelValue?.id,class:`btn-copy inline-block`},null,8,[`content`])])]),_:1})])):(d(),t(`div`,dt,[o(b,{closable:!1,class:`info`},{template:h(()=>[o(v,{icon:`fa-regular fa-clock`,class:`mr-1`}),i(` `+u(e.$t(`grokvideo.status.pending`)),1)]),default:h(()=>[n(`p`,ft,[o(v,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+u(e.$t(`grokvideo.name.taskId`))+`: `+u(e.modelValue?.id)+` `,1),o(y,{content:e.modelValue?.id,class:`btn-copy inline-block`},null,8,[`content`])])]),_:1})]))])])}var kt=r({name:`GrokVideoRecentPanel`,components:{TaskPreview:P(et,[[`render`,Ot],[`__scopeId`,`data-v-cb4cd43a`]]),BotPlaceholder:q,NoTasks:Q,ScrollList:Y},props:{loading:{type:Boolean,default:!1}},emits:[`reach-top`],computed:{tasks(){return{...this.$store.state.grokvideo?.tasks,items:this.$store.state.grokvideo?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),At={key:0},jt={key:2,class:`w-full h-full flex items-center justify-center`};function Mt(n,r,i,c,l,u){let f=m(`bot-placeholder`),g=m(`task-preview`),_=m(`scroll-list`),v=m(`no-tasks`);return d(),t(s,null,[n.tasks?.items===void 0?(d(),t(`div`,At,[o(f)])):n.tasks?.items?.length&&n.tasks?.items?.length>0?(d(),a(_,{key:1,ref:`scrollList`,class:`tasks w-full h-full overflow-y-auto`,loading:n.loading,onReachTop:r[0]||=e=>n.$emit(`reach-top`)},{default:h(()=>[(d(!0),t(s,null,e(n.tasks?.items,e=>(d(),a(g,{key:e.id,"model-value":e},null,8,[`model-value`]))),128))]),_:1},8,[`loading`])):p(``,!0),n.tasks?.items?.length===0?(d(),t(`div`,jt,[o(v)])):p(``,!0)],64)}var Nt=P(kt,[[`render`,Mt]]),Pt=O(`grok`),Ft=r({name:`GrokVideoIndex`,components:{ConfigPanel:$e,Layout:ie,RecentPanel:Nt},mixins:[N],inject:[`initialized`],data(){return{task:void 0,job:0,loadingMore:!1,fetchingTasks:!1}},computed:{applicationsLoading(){return this.$store.state.grokvideo?.status?.getApplications===U.Request},tasksLoading(){return this.$store.state.grokvideo?.status?.getTasks===U.Request||this.fetchingTasks},credential(){return this.$store.state.grokvideo?.credential},config(){return this.$store.state.grokvideo?.config},tasks(){return this.$store.state.grokvideo?.tasks}},watch:{initialized:{async handler(e){e&&(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 X({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(){await this.$store.dispatch(`grokvideo/getService`)},async onScrollDown(){await this.$nextTick();let e=this.getTasksScrollElement();e&&(e.scrollTop=e.scrollHeight)},async onGetTasks(e){if(this.applicationsLoading||this.fetchingTasks)return;let{limit:t=5,createdAtMin:n,createdAtMax:r}=e||{};this.fetchingTasks=!0;try{await this.$store.dispatch(`grokvideo/getTasks`,{limit:t,createdAtMin:n,createdAtMax:r})}finally{this.fetchingTasks=!1}},async onGenerate(){if(!L(this.uploadTracker,e=>this.$t(e),e=>V.warning(e)))return;let e={...this.config||{}};typeof e?.prompt==`string`&&(e.prompt=e.prompt.trim(),e.prompt||delete e.prompt),typeof e?.image_url==`string`&&!e.image_url.trim()&&delete e.image_url;let t=!!e?.image_url;if(T(e?.model)&&!t){V.warning(this.$t(`grokvideo.message.modelRequiresImage`));return}if(!t&&!e?.prompt){V.warning(this.$t(`grokvideo.message.promptOrImageRequired`));return}let n={...e,callback_url:Pt},r=this.credential?.token;if(!r){console.error(`no token specified`);return}V.info(this.$t(`grokvideo.message.startingTask`)),F(`grokvideo`,z.generate(n,{token:r})).then(()=>{V.success(this.$t(`grokvideo.message.startTaskSuccess`))}).catch(e=>{let t=e?.response?.data;t?.error?.code===`used_up`?V.error(this.$t(`grokvideo.message.usedUp`)):V.error(this.$t(`grokvideo.message.startTaskFailed`)+(t?.error?.message||``))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function It(e,t,n,r,i,s){let c=m(`config-panel`),l=m(`recent-panel`),u=m(`layout`);return d(),a(u,null,{config:h(()=>[o(c,{onGenerate:e.onGenerate},null,8,[`onGenerate`])]),result:h(()=>[o(l,{ref:`recentPanel`,loading:e.loadingMore,onReachTop:e.onReachTop},null,8,[`loading`,`onReachTop`])]),_:1})}var Lt=P(Ft,[[`render`,It]]);export{Lt as default};
|
|
1
|
+
import"./rolldown-runtime--c01j_DQ.js";import{$ as e,A as t,D as n,F as r,N as i,O as a,P as o,S as s,Ut as c,Vt as l,Wt as u,Z as d,b as f,k as p,tt as m,ut as h}from"./vendor-chart-BJCvKk8-.js";import{t as g}from"./button-DfsQodL-.js";import{r as _,t as v}from"./select-DyEe0uU4.js";import{t as y}from"./upload-2ooOKJyT.js";import{t as b}from"./tooltip-BLwTovWL.js";import{t as x}from"./image-C7UiYpMr.js";import{t as S}from"./alert-OvnfgMB-.js";import{Ct as C,Et as w,Ot as T,St as E,Tt as D,_i as O,_t as k,bt as A,vt as j,wt as ee,xt as te,yt as M}from"./constants-CwLEZ_AF.js";import{At as N,E as P,Fn as F,Nt as I,Ot as L,Sr as R,Zt as z,jt as B,kr as V,kt as H,yr as U}from"./index-BSaC0vue.js";import{t as W}from"./index.es-NL3Dn982.js";import{t as G}from"./CopyToClipboard-Sk5Grp1_.js";import{t as K}from"./ImagePreview-BX6eL7DE.js";import{t as q}from"./BotPlaceholder-68XVM5HA.js";import{i as J,n as Y,t as X}from"./pagination-D5c7xkGS.js";import{n as Z,t as Q}from"./NoTasks-BiV0deXP.js";import{t as ne}from"./Consumption-CtCh2-Du.js";import{t as re}from"./ApiCodeButton-jFmqbRiH.js";import{t as ie}from"./Seedance-Bm03MMxP.js";import{t as ae}from"./VideoPlayer-v8gnvaTw.js";var oe=r({name:`GrokVideoPromptInput`,components:{PromptTextarea:Z},computed:{prompt:{get(){return this.$store.state.grokvideo?.config?.prompt},set(e){this.$store.commit(`grokvideo/setConfig`,{...this.$store.state.grokvideo?.config,prompt:e})}}},mounted(){this.prompt||=``}});function se(e,t,n,r,i,o){let s=m(`prompt-textarea`);return d(),a(s,{modelValue:e.prompt,"onUpdate:modelValue":t[0]||=t=>e.prompt=t,title:e.$t(`grokvideo.name.prompt`),info:e.$t(`grokvideo.description.prompt`),placeholder:e.$t(`grokvideo.placeholder.prompt`),"min-rows":5},null,8,[`modelValue`,`title`,`info`,`placeholder`])}var ce=P(oe,[[`render`,se]]),le=r({name:`GrokVideoModelSelector`,components:{ElSelect:_,ElOption:v,InfoIcon:J},data(){return{options:[{value:E,label:this.$t(`grokvideo.model.default`)},{value:te,label:this.$t(`grokvideo.model.preview15`)}]}},computed:{value:{get(){return this.$store.state.grokvideo?.config?.model},set(e){this.$store.commit(`grokvideo/setConfig`,{...this.$store.state.grokvideo?.config,model:e})}}},mounted(){this.value||=k}}),ue={class:`field`},de={class:`label`},fe={class:`box`},pe={class:`title font-bold`};function me(r,i,c,l,f,p){let g=m(`info-icon`),_=m(`el-option`),v=m(`el-select`);return d(),t(`div`,ue,[n(`div`,de,[n(`div`,fe,[n(`h2`,pe,u(r.$t(`grokvideo.name.model`)),1),o(g,{content:r.$t(`grokvideo.description.model`),class:`info`},null,8,[`content`])])]),o(v,{modelValue:r.value,"onUpdate:modelValue":i[0]||=e=>r.value=e,class:`value`,placeholder:r.$t(`grokvideo.placeholder.select`)},{default:h(()=>[(d(!0),t(s,null,e(r.options,e=>(d(),a(_,{key:e.value,label:e.label,value:e.value},null,8,[`label`,`value`]))),128))]),_:1},8,[`modelValue`,`placeholder`])])}var he=P(le,[[`render`,me],[`__scopeId`,`data-v-291d93fb`]]),ge=r({name:`GrokVideoDurationSelector`,components:{ElSelect:_,ElOption:v,InfoIcon:J},data(){return{options:[{value:3,label:`3s`},{value:5,label:`5s`},{value:6,label:`6s`},{value:8,label:`8s`},{value:10,label:`10s`},{value:12,label:`12s`},{value:15,label:`15s`}]}},computed:{value:{get(){return this.$store.state.grokvideo?.config?.duration},set(e){this.$store.commit(`grokvideo/setConfig`,{...this.$store.state.grokvideo?.config,duration:e})}}},mounted(){this.value||=8}}),_e={class:`field`},ve={class:`label`},ye={class:`box`},be={class:`title font-bold`};function xe(r,i,c,l,f,p){let g=m(`info-icon`),_=m(`el-option`),v=m(`el-select`);return d(),t(`div`,_e,[n(`div`,ve,[n(`div`,ye,[n(`h2`,be,u(r.$t(`grokvideo.name.duration`)),1),o(g,{content:r.$t(`grokvideo.description.duration`),class:`info`},null,8,[`content`])])]),o(v,{modelValue:r.value,"onUpdate:modelValue":i[0]||=e=>r.value=e,class:`value`,placeholder:r.$t(`grokvideo.placeholder.select`)},{default:h(()=>[(d(!0),t(s,null,e(r.options,e=>(d(),a(_,{key:e.value,label:e.label,value:e.value},null,8,[`label`,`value`]))),128))]),_:1},8,[`modelValue`,`placeholder`])])}var Se=P(ge,[[`render`,xe],[`__scopeId`,`data-v-8b8ef5e7`]]),Ce=r({name:`GrokVideoResolutionSelector`,components:{InfoIcon:J},data(){return{options:[{value:D,label:`480p`},{value:w,label:`720p`}]}},computed:{value:{get(){return this.$store.state.grokvideo?.config?.resolution},set(e){this.$store.commit(`grokvideo/setConfig`,{...this.$store.state.grokvideo?.config,resolution:e})}}},mounted(){this.value||=M}}),we={class:`resolution`},Te={class:`header`},Ee={class:`title font-bold`},De={class:`items`},Oe=[`onClick`];function ke(r,i,a,c,f,p){let h=m(`info-icon`);return d(),t(`div`,we,[n(`div`,Te,[n(`h2`,Ee,u(r.$t(`grokvideo.name.resolution`)),1),o(h,{content:r.$t(`grokvideo.description.resolution`),class:`info`},null,8,[`content`])]),n(`div`,De,[(d(!0),t(s,null,e(r.options,e=>(d(),t(`div`,{key:e.value,class:l([`item`,{active:r.value===e.value}]),onClick:t=>r.value=e.value},u(e.label),11,Oe))),128))])])}var Ae=P(Ce,[[`render`,ke],[`__scopeId`,`data-v-f1ebb899`]]),je=r({name:`GrokVideoRatioSelector`,components:{InfoIcon:J},computed:{options(){return[{value:C,label:`16:9`,w:32,h:18},{value:ee,label:`9:16`,w:18,h:32},{value:`1:1`,label:`1:1`,w:24,h:24},{value:`4:3`,label:`4:3`,w:28,h:21},{value:`3:4`,label:`3:4`,w:21,h:28},{value:`3:2`,label:`3:2`,w:30,h:20},{value:`2:3`,label:`2:3`,w:20,h:30}]},value:{get(){return this.$store.state.grokvideo?.config?.aspect_ratio},set(e){this.$store.commit(`grokvideo/setConfig`,{...this.$store.state.grokvideo?.config,aspect_ratio:e})}}},mounted(){this.value||=j}}),Me={class:`ratio`},Ne={class:`header`},Pe={class:`title font-bold`},Fe={class:`items`},Ie=[`onClick`],Le={class:`preview`},Re={class:`name`};function ze(r,i,a,f,p,h){let g=m(`info-icon`);return d(),t(`div`,Me,[n(`div`,Ne,[n(`h2`,Pe,u(r.$t(`grokvideo.name.ratio`)),1),o(g,{content:r.$t(`grokvideo.description.ratio`),class:`info`},null,8,[`content`])]),n(`div`,Fe,[(d(!0),t(s,null,e(r.options,e=>(d(),t(`div`,{key:e.value,class:l([`item`,{active:r.value===e.value}]),onClick:t=>r.value=e.value},[n(`div`,Le,[n(`div`,{class:`rect`,style:c({width:e.w+`px`,height:e.h+`px`})},null,4)]),n(`div`,Re,u(e.label),1)],10,Ie))),128))])])}var Be=P(je,[[`render`,ze],[`__scopeId`,`data-v-70115284`]]),Ve=r({name:`GrokVideoImageInput`,components:{ElUpload:y,ElButton:g,InfoIcon:J,FontAwesomeIcon:W,ImagePreview:K},mixins:[B,H],data(){return{fileList:[],uploadUrl:R()+`/api/v1/files/`}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},required(){return T(this.$store.state.grokvideo?.config?.model)},urls(){return this.fileList.map(e=>e?.response?.file_url)}},methods:{onExceed(){V.warning(this.$t(`grokvideo.message.uploadExceed`))},onError(){V.error(this.$t(`grokvideo.message.uploadError`))},onSetImageUrl(){let e=this.urls?.[0];this.$store.commit(`grokvideo/setConfig`,{...this.$store.state.grokvideo?.config,image_url:e||void 0})},async onSuccess(){this.onSetImageUrl()},async onRemove(){this.onSetImageUrl()}}}),He={class:`relative`},Ue={class:`flex justify-between`},We={class:`flex justify-start items-center`},Ge={class:`text-sm font-bold`},Ke={key:0,class:`required-badge`};function qe(e,r,s,c,l,f){let g=m(`info-icon`),_=m(`image-preview`),v=m(`font-awesome-icon`),y=m(`el-button`),b=m(`el-upload`);return d(),t(`div`,He,[n(`div`,Ue,[n(`div`,We,[n(`span`,Ge,u(e.$t(`grokvideo.name.image`)),1),e.required?(d(),t(`span`,Ke,u(e.$t(`grokvideo.name.required`)),1)):p(``,!0),o(g,{content:e.$t(`grokvideo.description.image`)},null,8,[`content`])])]),o(b,{ref:`uploader`,"file-list":e.fileList,"onUpdate:fileList":r[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,"on-remove":e.onRemove,headers:e.headers},{file:h(({file:t})=>[t.url&&t.percentage!==void 0?(d(),a(_,{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`])):p(``,!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`}),i(` `+u(e.$t(`grokvideo.button.upload`)),1)]),_:1})]),_:1},8,[`file-list`,`action`,`on-exceed`,`on-error`,`on-success`,`on-remove`,`headers`])])}var Je=r({name:`GrokVideoConfigPanel`,components:{ElButton:g,FontAwesomeIcon:W,PromptInput:ce,ModelSelector:he,DurationSelector:Se,ResolutionSelector:Ae,RatioSelector:Be,ImageInput:P(Ve,[[`render`,qe],[`__scopeId`,`data-v-164e5a1d`]]),Consumption:ne},emits:[`generate`],computed:{config(){return this.$store.state.grokvideo?.config},consumption(){return I(this.config,this.service?.cost)},service(){return this.$store.state.grokvideo?.service}},methods:{onGenerate(){this.$emit(`generate`)}}}),Ye={class:`flex flex-col h-full`},Xe={class:`flex-1 overflow-y-auto p-5`},Ze={class:`flex flex-col items-center justify-center px-5 pb-5`};function Qe(e,r,a,s,c,l){let f=m(`prompt-input`),p=m(`model-selector`),g=m(`ratio-selector`),_=m(`resolution-selector`),v=m(`duration-selector`),y=m(`image-input`),b=m(`consumption`),x=m(`font-awesome-icon`),S=m(`el-button`);return d(),t(`div`,Ye,[n(`div`,Xe,[o(f,{class:`mb-4`}),o(p,{class:`mb-4`}),o(g,{class:`mb-4`}),o(_,{class:`mb-4`}),o(v,{class:`mb-4`}),o(y,{class:`mb-2`})]),n(`div`,Ze,[o(b,{value:e.consumption,service:e.service},null,8,[`value`,`service`]),o(S,{type:`primary`,class:`btn w-full`,round:``,onClick:e.onGenerate},{default:h(()=>[o(x,{icon:`fa-solid fa-magic`,class:`mr-2`}),i(` `+u(e.$t(`grokvideo.button.generate`)),1)]),_:1},8,[`onClick`])])])}var $e=P(Je,[[`render`,Qe]]),et=r({name:`GrokVideoTaskPreview`,components:{ElImage:x,CopyToClipboard:G,FontAwesomeIcon:W,ElAlert:S,VideoPlayer:ae,ElTooltip:b,ElButton:g,ImagePreview:K,ApiCodeButton:re},props:{modelValue:{type:Object,required:!0}},data(){return{grokVideoLogo:A}},computed:{video(){return this.modelValue?.response?.data?.[0]},inputImage(){return this.modelValue?.request?.image_url}},methods:{onDownload(e){window.open(e,`_blank`)}}}),tt={class:`preview`},nt={class:`left`},rt={class:`main`},it={class:`bot`},at={class:`datetime`},ot={class:`info`},st={key:0,class:`flex justify-start items-center gap-2 mt-2 w-full overflow-x-auto`},ct={key:1,class:`prompt mt-2`},lt={key:0},ut={key:1},dt={key:0,class:l({content:!0})},ft={class:`text-[var(--el-text-color-regular)] text-xs mb-0`},pt={key:1,class:l({content:!0})},mt={key:0,class:`mb-4`},ht={key:1,class:l({operations:!0,"mt-2":!0,"mb-2":!0})},gt={key:0,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},_t={key:1,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},vt={key:2,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},yt={key:0},bt={class:`text-[var(--el-text-color-regular)] text-xs mb-2`},xt={key:3,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},St={key:4,class:`text-[var(--el-text-color-regular)] text-xs mb-0`},Ct={key:2,class:l({content:!0})},wt={class:`text-[var(--el-text-color-regular)] text-xs mb-2`},Tt={key:0,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},Et={key:1,class:`text-[var(--el-text-color-regular)] text-xs mb-0`},$={key:3,class:l({content:!0})},Dt={class:`text-[var(--el-text-color-regular)] text-xs mb-0`};function Ot(e,r,a,s,c,l){let g=m(`el-image`),_=m(`image-preview`),v=m(`font-awesome-icon`),y=m(`copy-to-clipboard`),b=m(`el-alert`),x=m(`video-player`),S=m(`el-button`),C=m(`el-tooltip`),w=m(`api-code-button`);return d(),t(`div`,tt,[n(`div`,nt,[o(g,{src:e.grokVideoLogo,class:`avatar`},null,8,[`src`])]),n(`div`,rt,[n(`div`,it,[i(u(e.$t(`grokvideo.name.bot`))+` `,1),n(`span`,at,u(e.$dayjs.format(``+new Date(parseFloat((e.modelValue?.created_at||``).toString())*1e3))),1)]),n(`div`,ot,[e.inputImage?(d(),t(`div`,st,[o(_,{url:e.inputImage,name:`image`,closable:!1},null,8,[`url`])])):p(``,!0),e.modelValue?.request?.prompt?(d(),t(`p`,ct,[i(u(e.modelValue?.request?.prompt)+` `,1),e.modelValue?.response?e.video?.state===`processing`||e.video?.state===`pending`?(d(),t(`span`,ut,` - (`+u(e.$t(`grokvideo.status.processing`))+`) `,1)):p(``,!0):(d(),t(`span`,lt,` - (`+u(e.$t(`grokvideo.status.pending`))+`) `,1))])):p(``,!0)]),e.modelValue?.response?e.modelValue?.response?.success===!0?(d(),t(`div`,pt,[e.video?.video_url?(d(),t(`div`,mt,[o(x,{src:e.video?.video_url},null,8,[`src`])])):p(``,!0),e.video?.video_url?(d(),t(`div`,ht,[o(C,{class:`box-item`,effect:`dark`,content:e.$t(`grokvideo.message.downloadVideo`),placement:`top-start`},{default:h(()=>[o(S,{type:`info`,size:`small`,class:`btn-action`,onClick:r[0]||=f(t=>e.onDownload(e.video?.video_url),[`stop`])},{default:h(()=>[i(u(e.$t(`grokvideo.button.download`)),1)]),_:1})]),_:1},8,[`content`]),o(w,{path:`/grok/videos`,body:e.modelValue?.request},null,8,[`body`])])):p(``,!0),o(b,{closable:!1,class:`mt-2 success`},{default:h(()=>[e.modelValue?.request?.model?(d(),t(`p`,gt,[o(v,{icon:`fa-solid fa-cube`,class:`mr-1`}),i(` `+u(e.$t(`grokvideo.name.model`))+`: `+u(e.modelValue?.request?.model),1)])):p(``,!0),e.video?.duration?(d(),t(`p`,_t,[o(v,{icon:`fa-solid fa-clock`,class:`mr-1`}),i(` `+u(e.$t(`grokvideo.name.duration`))+`: `+u(e.video?.duration)+`s `,1)])):p(``,!0),e.modelValue?.request?.resolution?(d(),t(`p`,vt,[o(v,{icon:`fa-solid fa-expand`,class:`mr-1`}),i(` `+u(e.$t(`grokvideo.name.resolution`))+`: `+u(e.modelValue?.request?.resolution)+` `,1),e.modelValue?.request?.aspect_ratio?(d(),t(`span`,yt,` · `+u(e.modelValue?.request?.aspect_ratio),1)):p(``,!0)])):p(``,!0),n(`p`,bt,[o(v,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+u(e.$t(`grokvideo.name.taskId`))+`: `+u(e.modelValue?.id)+` `,1),o(y,{content:e.modelValue?.id,class:`btn-copy inline-block`},null,8,[`content`])]),e.modelValue?.elapsed?(d(),t(`p`,xt,[o(v,{icon:`fa-solid fa-clock`,class:`mr-1`}),i(` `+u(e.$t(`grokvideo.name.elapsed`))+`: `+u(e.modelValue?.elapsed?.toFixed(2))+`s `,1)])):p(``,!0),e.modelValue?.response?.trace_id?(d(),t(`p`,St,[o(v,{icon:`fa-solid fa-hashtag`,class:`mr-1`}),i(` `+u(e.$t(`grokvideo.name.traceId`))+`: `+u(e.modelValue?.response?.trace_id)+` `,1),o(y,{content:e.modelValue?.response?.trace_id,class:`btn-copy inline-block`},null,8,[`content`])])):p(``,!0)]),_:1})])):e.modelValue?.response?.success===!1?(d(),t(`div`,Ct,[o(b,{closable:!1,class:`failure`},{template:h(()=>[o(v,{icon:`fa-solid fa-exclamation-triangle`,class:`mr-1`}),i(` `+u(e.$t(`grokvideo.name.failure`)),1)]),default:h(()=>[n(`p`,wt,[o(v,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+u(e.$t(`grokvideo.name.taskId`))+`: `+u(e.modelValue?.id)+` `,1),o(y,{content:e.modelValue?.id,class:`btn-copy inline-block`},null,8,[`content`])]),e.modelValue?.response?.error?.message?(d(),t(`p`,Tt,[o(v,{icon:`fa-solid fa-circle-info`,class:`mr-1`}),i(` `+u(e.$t(`grokvideo.name.failureReason`))+`: `+u(e.modelValue?.response?.error?.message)+` `,1),o(y,{content:e.modelValue?.response?.error?.message,class:`btn-copy inline-block`},null,8,[`content`])])):p(``,!0),e.modelValue?.response?.trace_id?(d(),t(`p`,Et,[o(v,{icon:`fa-solid fa-hashtag`,class:`mr-1`}),i(` `+u(e.$t(`grokvideo.name.traceId`))+`: `+u(e.modelValue?.response?.trace_id)+` `,1),o(y,{content:e.modelValue?.response?.trace_id,class:`btn-copy inline-block`},null,8,[`content`])])):p(``,!0)]),_:1})])):(d(),t(`div`,$,[o(b,{closable:!1,class:`info`},{template:h(()=>[o(v,{icon:`fa-solid fa-circle-info`,class:`mr-1`}),i(` `+u(e.$t(`grokvideo.name.status`)),1)]),default:h(()=>[n(`p`,Dt,[o(v,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+u(e.$t(`grokvideo.name.taskId`))+`: `+u(e.modelValue?.id)+` `,1),o(y,{content:e.modelValue?.id,class:`btn-copy inline-block`},null,8,[`content`])])]),_:1})])):(d(),t(`div`,dt,[o(b,{closable:!1,class:`info`},{template:h(()=>[o(v,{icon:`fa-regular fa-clock`,class:`mr-1`}),i(` `+u(e.$t(`grokvideo.status.pending`)),1)]),default:h(()=>[n(`p`,ft,[o(v,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+u(e.$t(`grokvideo.name.taskId`))+`: `+u(e.modelValue?.id)+` `,1),o(y,{content:e.modelValue?.id,class:`btn-copy inline-block`},null,8,[`content`])])]),_:1})]))])])}var kt=r({name:`GrokVideoRecentPanel`,components:{TaskPreview:P(et,[[`render`,Ot],[`__scopeId`,`data-v-cb4cd43a`]]),BotPlaceholder:q,NoTasks:Q,ScrollList:Y},props:{loading:{type:Boolean,default:!1}},emits:[`reach-top`],computed:{tasks(){return{...this.$store.state.grokvideo?.tasks,items:this.$store.state.grokvideo?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),At={key:0},jt={key:2,class:`w-full h-full flex items-center justify-center`};function Mt(n,r,i,c,l,u){let f=m(`bot-placeholder`),g=m(`task-preview`),_=m(`scroll-list`),v=m(`no-tasks`);return d(),t(s,null,[n.tasks?.items===void 0?(d(),t(`div`,At,[o(f)])):n.tasks?.items?.length&&n.tasks?.items?.length>0?(d(),a(_,{key:1,ref:`scrollList`,class:`tasks w-full h-full overflow-y-auto`,loading:n.loading,onReachTop:r[0]||=e=>n.$emit(`reach-top`)},{default:h(()=>[(d(!0),t(s,null,e(n.tasks?.items,e=>(d(),a(g,{key:e.id,"model-value":e},null,8,[`model-value`]))),128))]),_:1},8,[`loading`])):p(``,!0),n.tasks?.items?.length===0?(d(),t(`div`,jt,[o(v)])):p(``,!0)],64)}var Nt=P(kt,[[`render`,Mt]]),Pt=O(`grok`),Ft=r({name:`GrokVideoIndex`,components:{ConfigPanel:$e,Layout:ie,RecentPanel:Nt},mixins:[N],inject:[`initialized`],data(){return{task:void 0,job:0,loadingMore:!1,fetchingTasks:!1}},computed:{applicationsLoading(){return this.$store.state.grokvideo?.status?.getApplications===U.Request},tasksLoading(){return this.$store.state.grokvideo?.status?.getTasks===U.Request||this.fetchingTasks},credential(){return this.$store.state.grokvideo?.credential},config(){return this.$store.state.grokvideo?.config},tasks(){return this.$store.state.grokvideo?.tasks}},watch:{initialized:{async handler(e){e&&(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 X({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(){await this.$store.dispatch(`grokvideo/getService`)},async onScrollDown(){await this.$nextTick();let e=this.getTasksScrollElement();e&&(e.scrollTop=e.scrollHeight)},async onGetTasks(e){if(this.applicationsLoading||this.fetchingTasks)return;let{limit:t=5,createdAtMin:n,createdAtMax:r}=e||{};this.fetchingTasks=!0;try{await this.$store.dispatch(`grokvideo/getTasks`,{limit:t,createdAtMin:n,createdAtMax:r})}finally{this.fetchingTasks=!1}},async onGenerate(){if(!L(this.uploadTracker,e=>this.$t(e),e=>V.warning(e)))return;let e={...this.config||{}};typeof e?.prompt==`string`&&(e.prompt=e.prompt.trim(),e.prompt||delete e.prompt),typeof e?.image_url==`string`&&!e.image_url.trim()&&delete e.image_url;let t=!!e?.image_url;if(T(e?.model)&&!t){V.warning(this.$t(`grokvideo.message.modelRequiresImage`));return}if(!t&&!e?.prompt){V.warning(this.$t(`grokvideo.message.promptOrImageRequired`));return}let n={...e,callback_url:Pt},r=this.credential?.token;if(!r){console.error(`no token specified`);return}V.info(this.$t(`grokvideo.message.startingTask`)),F(`grokvideo`,z.generate(n,{token:r})).then(()=>{V.success(this.$t(`grokvideo.message.startTaskSuccess`))}).catch(e=>{let t=e?.response?.data;t?.error?.code===`used_up`?V.error(this.$t(`grokvideo.message.usedUp`)):V.error(this.$t(`grokvideo.message.startTaskFailed`)+(t?.error?.message||``))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function It(e,t,n,r,i,s){let c=m(`config-panel`),l=m(`recent-panel`),u=m(`layout`);return d(),a(u,null,{config:h(()=>[o(c,{onGenerate:e.onGenerate},null,8,[`onGenerate`])]),result:h(()=>[o(l,{ref:`recentPanel`,loading:e.loadingMore,onReachTop:e.onReachTop},null,8,[`loading`,`onReachTop`])]),_:1})}var Lt=P(Ft,[[`render`,It]]);export{Lt as default};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import"./rolldown-runtime--c01j_DQ.js";import{A as e,D as t,F as n,N as r,O as i,P as a,Wt as o,Z as s,dt as c,k as l,nt as u,tt as d,ut as f}from"./vendor-chart-BJCvKk8-.js";import{t as p}from"./button-DfsQodL-.js";import{n as m,t as h}from"./row-
|
|
1
|
+
import"./rolldown-runtime--c01j_DQ.js";import{A as e,D as t,F as n,N as r,O as i,P as a,Wt as o,Z as s,dt as c,k as l,nt as u,tt as d,ut as f}from"./vendor-chart-BJCvKk8-.js";import{t as p}from"./button-DfsQodL-.js";import{n as m,t as h}from"./row-B4cK4Xdf.js";import{i as g,n as _,r as v,t as y}from"./container-BgEH5azS.js";import{n as b,t as x}from"./dropdown-CmezA_CG.js";import{a as S,i as C,n as w,r as T,t as E}from"./avatar-BmPQ8jQh.js";import{Bt as D,D as O,Dr as k,E as A,K as j,O as M,rt as N,xr as P,z as F}from"./index-BSaC0vue.js";import{t as I}from"./BottomFooter-CDh9tDrk.js";var L=n({name:`TopHeader`,components:{ElCol:m,Logo:w,ElRow:h,ElDropdown:x,ElMenu:T,ElMenuItem:C,ElDropdownItem:b,ElButton:p,ElSubMenu:S},data(){return{defaultAvatar:E,products:`chat`}},computed:{site(){return this.$store.state?.site},dark(){return this.$store.getters?.dark},active(){return this.$route.matched?.[0]?.path},user(){return this.$store.getters?.user},authenticated(){return this.$store.getters?.authenticated}},methods:{openTab(e){if(k()){O.open({url:e}).catch(t=>{console.warn(`Browser.open failed, falling back to window.open`,t),window.open(e,`_blank`)});return}window.open(e,`_blank`)},onSelect(e){e&&this.$router.push(e)},onHome(){this.$router.push({name:N})},onLogin(){this.$router.push({name:M})},onDownload(){this.$router.push({name:j})},onProfile(){let e=P();this.openTab(D(`${e}/user/profile`))},onVerify(){let e=P();this.openTab(D(`${e}/user/verify`))},onConsole(){this.$router.push({name:F})},async onLogout(){this.$store.dispatch(`logout`)}}}),R={key:0,class:`mt-4 pr-10`},z={key:1,class:`float-right`},B=[`src`];function V(n,p,m,h,g,_){let v=d(`logo`),y=d(`el-col`),b=d(`el-menu-item`),x=d(`el-sub-menu`),S=d(`el-menu`),C=d(`el-button`),w=d(`language-selector`),T=d(`dark-selector`),E=d(`el-dropdown-item`),D=d(`el-dropdown-menu`),O=d(`el-dropdown`),k=d(`el-row`),A=u(`t`);return s(),i(k,{class:`header`},{default:f(()=>[a(y,{md:4,xs:24,class:`brand-col`},{default:f(()=>[a(v,{onClick:n.onHome},null,8,[`onClick`])]),_:1}),a(y,{md:16,xs:13},{default:f(()=>[a(S,{"default-active":n.active,mode:`horizontal`,class:`menu`,ellipsis:!0,onSelect:n.onSelect},{default:f(()=>[a(x,{index:n.products},{title:f(()=>[r(o(n.$t(`common.nav.products`)),1)]),default:f(()=>[n.site?.features?.chatgpt?.enabled?c((s(),i(b,{key:0,index:`/chat`},null,512)),[[A,`index.title.chat`]]):l(``,!0),n.site?.features?.midjourney?.enabled?c((s(),i(b,{key:1,index:`/midjourney`},null,512)),[[A,`index.title.midjourney`]]):l(``,!0),n.site?.features?.qrart?.enabled?c((s(),i(b,{key:2,index:`/qrart`},null,512)),[[A,`index.title.qrart`]]):l(``,!0),n.site?.features?.suno?.enabled?c((s(),i(b,{key:3,index:`/suno`},null,512)),[[A,`index.title.suno`]]):l(``,!0),n.site?.features?.luma?.enabled?c((s(),i(b,{key:4,index:`/luma`},null,512)),[[A,`index.title.luma`]]):l(``,!0),n.site?.features?.headshots?.enabled?c((s(),i(b,{key:5,index:`/headshots`},null,512)),[[A,`index.title.headshots`]]):l(``,!0)]),_:1},8,[`index`]),c(a(b,{onRoute:e=>void 0,onClick:n.onDownload},null,8,[`onClick`]),[[A,`common.nav.mobileApp`]]),c(a(b,{onRoute:e=>void 0,onClick:p[0]||=e=>n.openTab(`https://platform.acedata.cloud`)},null,512),[[A,`common.nav.apiPlatform`]]),c(a(b,{onRoute:e=>void 0,onClick:p[1]||=e=>n.openTab(`https://platform.acedata.cloud/support`)},null,512),[[A,`common.nav.support`]]),c(a(b,{onRoute:e=>void 0,onClick:p[2]||=e=>n.openTab(`https://platform.acedata.cloud/earning`)},null,512),[[A,`common.nav.referral`]])]),_:1},8,[`default-active`,`onSelect`])]),_:1}),a(y,{md:4,xs:11},{default:f(()=>[n.authenticated?(s(),e(`div`,z,[t(`div`,{class:`console`,onClick:p[3]||=(...e)=>n.onConsole&&n.onConsole(...e)},o(n.$t(`common.button.console`)),1),a(O,{trigger:`click`},{dropdown:f(()=>[a(D,null,{default:f(()=>[a(E,{onClick:n.onProfile},{default:f(()=>[r(o(n.$t(`common.button.profile`)),1)]),_:1},8,[`onClick`]),a(E,{onClick:n.onLogout},{default:f(()=>[r(o(n.$t(`common.button.logout`)),1)]),_:1},8,[`onClick`])]),_:1})]),default:f(()=>[t(`img`,{src:n.user?.avatar||n.defaultAvatar,class:`avatar`},null,8,B)]),_:1})])):(s(),e(`div`,R,[a(C,{type:`primary`,class:`float-right`,size:`small`,round:``,onClick:n.onLogin},{default:f(()=>[r(o(n.$t(`common.button.login`)),1)]),_:1},8,[`onClick`]),a(w,{class:`locale float-right mr-4`}),a(T,{class:`float-right mr-4`})]))]),_:1})]),_:1})}var H=n({name:`LayoutIndex`,components:{TopHeader:A(L,[[`render`,V]]),BottomFooter:I,ElContainer:y,ElMain:g,ElFooter:_,ElHeader:v}});function U(e,t,n,r,o,c){let l=d(`top-header`),u=d(`el-header`),p=d(`router-view`),m=d(`el-main`),h=d(`bottom-footer`),g=d(`el-footer`),_=d(`el-container`);return s(),i(_,{class:`wrapper min-h-[100vh]`},{default:f(()=>[a(u,{class:`header p-0 h-auto`},{default:f(()=>[a(l)]),_:1}),a(m,{class:`main`},{default:f(()=>[a(p)]),_:1}),a(g,{class:`footer p-0 h-auto`},{default:f(()=>[a(h)]),_:1})]),_:1})}var W=A(H,[[`render`,U]]);export{W as default};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import"./rolldown-runtime--c01j_DQ.js";import{$ as e,A as t,D as n,F as r,N as i,O as a,P as o,S as s,Vt as c,Wt as l,Z as u,b as d,dt as f,et as p,k as m,tt as h,ut as g,v as _}from"./vendor-chart-BJCvKk8-.js";import{t as v}from"./button-DfsQodL-.js";import{r as y,t as b}from"./select-CTfF5Pq0.js";import{t as x}from"./upload-PztQKfjm.js";import{t as S}from"./tooltip-BLwTovWL.js";import{t as C}from"./image-OB0St7Yu.js";import{t as w}from"./alert-OvnfgMB-.js";import{t as T}from"./drawer-Dpuj2uIl.js";import{An as E,En as D,On as O,_i as k,kn as A}from"./constants-CwLEZ_AF.js";import{At as j,E as M,Fn as N,Nt as P,Ot as ee,Sr as te,jt as F,kr as I,kt as L,tn as R,yr as z}from"./index-CTMytxLX.js";import{t as B}from"./index.es-DsMKNIuW.js";import{t as V}from"./CopyToClipboard-CRnka5tK.js";import{t as H}from"./ImagePreview-DhCeZxCj.js";import{n as U}from"./taskDrawerMixin-DEgO_R5H.js";import{t as W}from"./BotPlaceholder-C1UVVId0.js";import{i as G,n as K,t as q}from"./pagination-CMIlkvfz.js";import{n as J,t as Y}from"./NoTasks-C1jixEiN.js";import{t as X}from"./Consumption-DTpXXWzm.js";import{t as Z}from"./ApiCodeButton-C1XeBPd6.js";import{t as Q}from"./ImageWrapper-D2btRRAT.js";var ne=r({name:`LayoutNanobanana`,components:{ElDrawer:T,ElButton:v,FontAwesomeIcon:B},mixins:[U]}),re={class:`main flex flex-row flex-1`},ie={class:`config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]`},ae={class:`result h-full p-6 flex-1 flex flex-col min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]`};function oe(e,r,i,a,s,c){let l=h(`font-awesome-icon`),d=h(`el-button`),m=h(`el-drawer`);return u(),t(`div`,re,[n(`div`,ie,[p(e.$slots,`config`,{},void 0,!0)]),n(`div`,ae,[p(e.$slots,`result`,{},void 0,!0)]),f(o(d,{circle:``,class:`menu`,onClick:r[0]||=t=>e.drawer=!0},{default:g(()=>[o(l,{icon:`fa-solid fa-magic`})]),_:1},512),[[_,!e.tasksEmpty]]),o(m,{modelValue:e.drawer,"onUpdate:modelValue":r[1]||=t=>e.drawer=t,direction:`ltr`,"with-header":!1,size:`340px`,class:`drawer`},{default:g(()=>[p(e.$slots,`config`,{},void 0,!0)]),_:3},8,[`modelValue`])])}var se=M(ne,[[`render`,oe],[`__scopeId`,`data-v-d7e69eb2`]]),ce=r({name:`PromptInput`,components:{PromptTextarea:J},computed:{prompt:{get(){return this.$store.state.nanobanana?.config?.prompt},set(e){this.$store.commit(`nanobanana/setConfig`,{...this.$store.state.nanobanana?.config,prompt:e})}}},mounted(){this.prompt||=``}});function le(e,t,n,r,i,o){let s=h(`prompt-textarea`);return u(),a(s,{modelValue:e.prompt,"onUpdate:modelValue":t[0]||=t=>e.prompt=t,title:e.$t(`nanobanana.name.prompt`),info:e.$t(`nanobanana.description.prompt`),placeholder:e.$t(`nanobanana.placeholder.prompt`)},null,8,[`modelValue`,`title`,`info`,`placeholder`])}var ue=M(ce,[[`render`,le]]),de=r({name:`ImageUrlsInput`,components:{ElUpload:x,ElButton:v,InfoIcon:G,ImagePreview:H,FontAwesomeIcon:B},mixins:[F,L],data(){return{fileList:[],uploadUrl:te()+`/api/v1/files/`,suppressWatch:!1}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e?.response?.file_url).filter(e=>!!e)},value(){return this.$store.state.nanobanana?.config?.image_urls}},watch:{value:{immediate:!0,handler(e){if(this.suppressWatch)return;if(!e||e.length===0){let e=(this.fileList||[]).filter(e=>!e?.response?.file_url);this.fileList=e.length?e:[];return}let t=[];e.forEach(e=>{let n=this.fileList.find(t=>t?.response?.file_url===e||t?.url===e);n?t.push(n):t.push({name:e.split(`/`).pop()||e,url:e,status:`success`,percentage:100,response:{file_url:e}})}),(this.fileList||[]).filter(e=>!e?.response?.file_url).forEach(e=>{t.some(t=>t===e||t?.url===e?.url||t?.response?.file_url===e?.response?.file_url)||t.push(e)}),this.fileList=t}}},mounted(){},methods:{onChange(e){if(!e?.url&&e?.raw)try{e.url=URL.createObjectURL(e.raw)}catch{}},onRemove(e){if(e?.url&&typeof e.url==`string`&&e.url.startsWith(`blob:`))try{URL.revokeObjectURL(e.url)}catch{}this.onSetImageUrls()},onExceed(){I.warning(this.$t(`nanobanana.message.uploadImageExceed`))},onError(){I.error(this.$t(`nanobanana.message.uploadImageError`))},onSetImageUrls(){let e=this.urls;this.suppressWatch=!0,this.$store.commit(`nanobanana/setConfig`,{...this.$store.state.nanobanana?.config,image_urls:e}),this.$nextTick(()=>{this.suppressWatch=!1})},async onSuccess(e,t){e?.file_url&&(t.url=e.file_url,t.response=e),this.onSetImageUrls()},onRemovePreview(e,t){if(this.fileList.splice(e,1),t?.url&&typeof t.url==`string`&&t.url.startsWith(`blob:`))try{URL.revokeObjectURL(t.url)}catch{}this.onSetImageUrls()}}}),fe={class:`field flex items-center justify-between`},pe={class:`title font-bold text-[14px] mb-[10px]`},me={class:`upload-wrapper flex flex-col items-start gap-[8px]`},he={class:`controls flex items-center`},ge={class:`file-list flex flex-wrap gap-[10px]`};function _e(r,c,d,f,p,m){let _=h(`font-awesome-icon`),v=h(`el-button`),y=h(`el-upload`),b=h(`info-icon`),x=h(`image-preview`);return u(),t(s,null,[n(`div`,fe,[n(`h2`,pe,l(r.$t(`nanobanana.name.imageUrls`)),1),n(`div`,me,[n(`div`,he,[o(y,{ref:`uploader`,"file-list":r.fileList,"onUpdate:fileList":c[0]||=e=>r.fileList=e,accept:`.png,.jpg,.jpeg,.gif,.bmp,.webp`,name:`file`,class:`value`,limit:5,multiple:!0,"show-file-list":!1,action:r.uploadUrl,"on-exceed":r.onExceed,"on-error":r.onError,"on-success":r.onSuccess,"on-change":r.onChange,"on-remove":r.onRemove,headers:r.headers},{default:g(()=>[o(v,{size:`small`,type:`primary`,round:``},{default:g(()=>[o(_,{icon:`fa-solid fa-upload`,class:`mr-1`}),i(` `+l(r.$t(`nanobanana.button.uploadImageUrls`)),1)]),_:1})]),_:1},8,[`file-list`,`action`,`on-exceed`,`on-error`,`on-success`,`on-change`,`on-remove`,`headers`]),o(b,{content:r.$t(`nanobanana.description.imageUrls`),class:`ml-2`},null,8,[`content`])])])]),n(`div`,ge,[(u(!0),t(s,null,e(r.fileList,(e,t)=>(u(),a(x,{key:e.uid||e?.response?.file_url||e.url||t,url:e.url||e?.response?.file_url,name:e.name,percentage:e.percentage,onRemove:n=>r.onRemovePreview(t,e)},null,8,[`url`,`name`,`percentage`,`onRemove`]))),128))])],64)}var ve=M(de,[[`render`,_e]]),ye=r({name:`AspectRatioSelector`,components:{ElSelect:y,ElOption:b},data(){return{options:[`1:1`,`3:2`,`2:3`,`16:9`,`9:16`,`4:3`,`3:4`]}},computed:{value:{get(){return this.$store.state.nanobanana?.config?.aspect_ratio},set(e){console.debug(`set aspect_ratio`,e);let t={...this.$store.state.nanobanana?.config||{}};e?t.aspect_ratio=e:delete t.aspect_ratio,this.$store.commit(`nanobanana/setConfig`,t)}}}}),be={class:`field`},xe={class:`title font-bold`};function Se(r,i,c,d,f,p){let m=h(`el-option`),_=h(`el-select`);return u(),t(`div`,be,[n(`h2`,xe,l(r.$t(`nanobanana.name.aspectRatio`)),1),o(_,{modelValue:r.value,"onUpdate:modelValue":i[0]||=e=>r.value=e,class:`value`,clearable:``,placeholder:r.$t(`nanobanana.placeholder.select`)},{default:g(()=>[(u(!0),t(s,null,e(r.options,e=>(u(),a(m,{key:e,label:e,value:e},null,8,[`label`,`value`]))),128))]),_:1},8,[`modelValue`,`placeholder`])])}var Ce=M(ye,[[`render`,Se],[`__scopeId`,`data-v-67f08a08`]]),we=r({name:`NanobananaModelSelector`,components:{ElSelect:y,ElOption:b,InfoIcon:G},data(){return{options:[{value:O,label:this.$t(`nanobanana.model.nanoBanana`)},{value:E,label:this.$t(`nanobanana.model.nanoBananaPro`)},{value:A,label:this.$t(`nanobanana.model.nanoBanana2`)}]}},computed:{value:{get(){return this.$store.state.nanobanana?.config?.model},set(e){this.$store.commit(`nanobanana/setConfig`,{...this.$store.state.nanobanana?.config,model:e})}},modelDescription(){return this.$t(`nanobanana.description.model`)}},mounted(){this.value||=D}}),Te={class:`field`},Ee={class:`label`},De={class:`box`},Oe={class:`title font-bold`};function ke(r,i,c,d,f,p){let m=h(`info-icon`),_=h(`el-option`),v=h(`el-select`);return u(),t(`div`,Te,[n(`div`,Ee,[n(`div`,De,[n(`h2`,Oe,l(r.$t(`nanobanana.name.model`)),1),o(m,{content:r.modelDescription,class:`info`},null,8,[`content`])])]),o(v,{modelValue:r.value,"onUpdate:modelValue":i[0]||=e=>r.value=e,class:`value`,placeholder:r.$t(`nanobanana.placeholder.select`)},{default:g(()=>[(u(!0),t(s,null,e(r.options,e=>(u(),a(_,{key:e.value,label:e.label,value:e.value},null,8,[`label`,`value`]))),128))]),_:1},8,[`modelValue`,`placeholder`])])}var Ae=M(we,[[`render`,ke],[`__scopeId`,`data-v-94304d73`]]),je=r({name:`NanobananaResolutionSelector`,components:{ElSelect:y,ElOption:b,InfoIcon:G},data(){return{cachedResolution:`1K`,options:[{value:`1K`,label:`1K`},{value:`2K`,label:`2K`},{value:`4K`,label:`4K`}]}},computed:{value:{get(){return this.$store.state.nanobanana?.config?.resolution},set(e){this.$store.commit(`nanobanana/setConfig`,{...this.$store.state.nanobanana?.config,resolution:e})}},isProModel(){return this.$store.state.nanobanana?.config?.model!==O}},watch:{value(e){this.isProModel&&e&&(this.cachedResolution=e)},isProModel(e){e?this.value||=this.cachedResolution||`1K`:(this.value&&(this.cachedResolution=this.value),this.$store.commit(`nanobanana/setConfig`,{...this.$store.state.nanobanana?.config,resolution:void 0}))}},mounted(){this.isProModel&&!this.value&&(this.value=`1K`),!this.isProModel&&this.value&&(this.cachedResolution=this.value,this.$store.commit(`nanobanana/setConfig`,{...this.$store.state.nanobanana?.config,resolution:void 0}))}}),Me={class:`field`},Ne={class:`label`},Pe={class:`box`},Fe={class:`title font-bold`};function Ie(r,i,c,d,f,p){let m=h(`info-icon`),_=h(`el-option`),v=h(`el-select`);return u(),t(`div`,Me,[n(`div`,Ne,[n(`div`,Pe,[n(`h2`,Fe,l(r.$t(`nanobanana.name.resolution`)),1),o(m,{content:r.$t(`nanobanana.description.resolutionProOnly`),class:`info`},null,8,[`content`])])]),o(v,{modelValue:r.value,"onUpdate:modelValue":i[0]||=e=>r.value=e,class:`value`,placeholder:r.$t(`nanobanana.placeholder.select`),disabled:!r.isProModel},{default:g(()=>[(u(!0),t(s,null,e(r.options,e=>(u(),a(_,{key:e.value,label:e.label,value:e.value},null,8,[`label`,`value`]))),128))]),_:1},8,[`modelValue`,`placeholder`,`disabled`])])}var Le=r({name:`ConfigPanel`,components:{ElButton:v,FontAwesomeIcon:B,PromptInput:ue,Consumption:X,ImageUrlsInput:ve,AspectRatioSelector:Ce,ModelSelector:Ae,ResolutionSelector:M(je,[[`render`,Ie],[`__scopeId`,`data-v-fd5ab393`]])},emits:[`generate`],computed:{config(){return this.$store.state.nanobanana?.config},consumption(){let e={...this.config||{}},t=Array.isArray(e?.image_urls)&&e.image_urls.length>0;return P({...e,action:t?`edit`:`generate`},this.service?.cost)},service(){return this.$store.state.nanobanana?.service}},methods:{onGenerate(){this.$emit(`generate`)}}}),Re={class:`flex flex-col h-full`},ze={class:`flex-1 overflow-y-auto p-5`},Be={class:`flex flex-col items-center justify-center px-5 pb-5`};function Ve(e,r,a,s,c,d){let f=h(`model-selector`),p=h(`resolution-selector`),m=h(`prompt-input`),_=h(`aspect-ratio-selector`),v=h(`image-urls-input`),y=h(`consumption`),b=h(`font-awesome-icon`),x=h(`el-button`);return u(),t(`div`,Re,[n(`div`,ze,[o(f,{class:`mb-4`}),o(p,{class:`mb-4`}),o(m,{class:`mb-4`}),o(_,{class:`mb-4`}),o(v,{class:`mb-4`})]),n(`div`,Be,[o(y,{value:e.consumption,service:e.service},null,8,[`value`,`service`]),o(x,{type:`primary`,class:`btn w-full`,round:``,onClick:e.onGenerate},{default:g(()=>[o(b,{icon:`fa-solid fa-magic`,class:`mr-2`}),i(` `+l(e.$t(`nanobanana.button.generate`)),1)]),_:1},8,[`onClick`])])])}var He=M(Le,[[`render`,Ve]]),Ue=r({name:`TaskPreview`,components:{ElImage:C,CopyToClipboard:V,FontAwesomeIcon:B,ElAlert:w,ImageWrapper:Q,ElButton:v,ElTooltip:S,ImagePreview:H,ApiCodeButton:Z},props:{modelValue:{type:Object,required:!0}},computed:{images(){let e=[];return Array.isArray(this.modelValue?.response?.data)&&this.modelValue?.response?.data?.forEach(t=>{e.push(t)}),e}},methods:{onEdit(e){if(!e)return;console.debug(`Edit image:`,e);let t={...this.$store.state.nanobanana?.config||{}};delete t.action,t.image_urls=[e],this.$store.commit(`nanobanana/setConfig`,t)}}}),We={class:`preview`},Ge={class:`left`},Ke={class:`main`},qe={class:`bot`},Je={class:`datetime`},Ye={class:`info`},Xe={key:0,class:`flex justify-start items-center gap-2 mt-2 w-full overflow-x-auto`},Ze={key:1,class:`prompt mt-2`},Qe={key:0},$e={key:0,class:c({content:!0,failed:!0})},et={class:`flex justify-start items-center gap-4 w-full overflow-x-auto`},tt={class:c({operations:!0,"mt-2":!0,"mb-2":!0})},nt={key:0,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},rt={key:1,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},it={key:2,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},at={key:3,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},ot={class:`text-[var(--el-text-color-regular)] text-xs mb-2`},st={key:4,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},ct={key:5,class:`text-[var(--el-text-color-regular)] text-xs mb-0`},lt={key:1,class:c({content:!0})},ut={key:0,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},dt={key:1,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},ft={key:2,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},pt={key:3,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},mt={class:`text-[var(--el-text-color-regular)] text-xs mb-2`},ht={class:`text-[var(--el-text-color-regular)] text-xs mb-2`},gt={key:4,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},_t={key:5,class:`text-[var(--el-text-color-regular)] text-xs mb-0`},vt={key:2,class:c({content:!0})},yt={key:0,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},$={key:1,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},bt={key:2,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},xt={key:3,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},St={class:`text-[var(--el-text-color-regular)] text-xs mb-2`};function Ct(r,c,f,p,_,v){let y=h(`el-image`),b=h(`image-preview`),x=h(`image-wrapper`),S=h(`el-button`),C=h(`el-tooltip`),w=h(`api-code-button`),T=h(`font-awesome-icon`),E=h(`copy-to-clipboard`),D=h(`el-alert`);return u(),t(`div`,We,[n(`div`,Ge,[o(y,{src:`https://cdn.acedata.cloud/859plc.jpg`,class:`avatar`})]),n(`div`,Ke,[n(`div`,qe,[i(l(r.$t(`nanobanana.name.nanobananaBot`))+` `,1),n(`span`,Je,l(r.$dayjs.format(``+new Date(parseFloat((r.modelValue?.created_at||``).toString())*1e3))),1)]),n(`div`,Ye,[r.modelValue?.request?.image_urls&&r.modelValue?.request?.image_urls.length>0?(u(),t(`div`,Xe,[(u(!0),t(s,null,e(r.modelValue?.request?.image_urls,(e,t)=>(u(),a(b,{key:t,url:e,name:`image-${t+1}`,closable:!1},null,8,[`url`,`name`]))),128))])):m(``,!0),r.modelValue?.request?.prompt?(u(),t(`p`,Ze,[i(l(r.modelValue?.request?.prompt)+` `,1),r.modelValue?.response?m(``,!0):(u(),t(`span`,Qe,` - (`+l(r.$t(`nanobanana.status.pending`))+`) `,1))])):m(``,!0)]),r.modelValue?.response?.success===!0?(u(),t(`div`,$e,[n(`div`,et,[(u(!0),t(s,null,e(r.images,(e,t)=>(u(),a(x,{key:t,src:e?.image_url,"raw-src":e?.image_url},null,8,[`src`,`raw-src`]))),128))]),n(`div`,tt,[o(C,{class:`box-item`,effect:`dark`,content:r.$t(`common.button.edit`),placement:`top-start`},{default:g(()=>[o(S,{type:`info`,size:`small`,class:`btn-action`,onClick:c[0]||=d(e=>r.onEdit(r.images?.[0]?.image_url),[`stop`])},{default:g(()=>[i(l(r.$t(`common.button.edit`)),1)]),_:1})]),_:1},8,[`content`]),o(w,{path:`/nano-banana/images`,body:r.modelValue?.request},null,8,[`body`])]),o(D,{closable:!1,class:`mt-2 success`},{default:g(()=>[r.modelValue?.request?.model?(u(),t(`p`,nt,[o(T,{icon:`fa-solid fa-cube`,class:`mr-1`}),i(` `+l(r.$t(`nanobanana.name.model`))+`: `+l(r.modelValue?.request?.model),1)])):m(``,!0),r.modelValue?.request?.resolution?(u(),t(`p`,rt,[o(T,{icon:`fa-solid fa-image`,class:`mr-1`}),i(` `+l(r.$t(`nanobanana.name.resolution`))+`: `+l(r.modelValue?.request?.resolution),1)])):m(``,!0),r.modelValue?.request?.aspect_ratio?(u(),t(`p`,it,[o(T,{icon:`fa-solid fa-up-right-from-square`,class:`mr-1`}),i(` `+l(r.$t(`nanobanana.name.aspectRatio`))+`: `+l(r.modelValue?.request?.aspect_ratio),1)])):m(``,!0),r.modelValue?.request?.action?(u(),t(`p`,at,[o(T,{icon:`fa-solid fa-bolt`,class:`mr-1`}),i(` `+l(r.$t(`nanobanana.name.task`))+`: `+l(r.modelValue?.request?.action===`generate`?r.$t(`nanobanana.name.generate`):r.$t(`nanobanana.name.edits`)),1)])):m(``,!0),n(`p`,ot,[o(T,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+l(r.$t(`nanobanana.name.taskId`))+`: `+l(r.modelValue?.id)+` `,1),o(E,{content:r.modelValue?.id,class:`btn-copy inline-block`},null,8,[`content`])]),r.modelValue?.elapsed?(u(),t(`p`,st,[o(T,{icon:`fa-solid fa-clock`,class:`mr-1`}),i(` `+l(r.$t(`nanobanana.name.elapsed`))+`: `+l(r.modelValue?.elapsed?.toFixed(2))+`s `,1)])):m(``,!0),r.modelValue?.response?.trace_id?(u(),t(`p`,ct,[o(T,{icon:`fa-solid fa-hashtag`,class:`mr-1`}),i(` `+l(r.$t(`nanobanana.name.traceId`))+`: `+l(r.modelValue?.response?.trace_id)+` `,1),o(E,{content:r.modelValue?.response?.trace_id,class:`btn-copy inline-block`},null,8,[`content`])])):m(``,!0)]),_:1})])):r.modelValue?.response?.success===!1?(u(),t(`div`,lt,[o(D,{closable:!1,class:`failure`},{template:g(()=>[o(T,{icon:`fa-solid fa-exclamation-triangle`,class:`mr-1`}),i(` `+l(r.$t(`nanobanana.name.failure`)),1)]),default:g(()=>[r.modelValue?.request?.model?(u(),t(`p`,ut,[o(T,{icon:`fa-solid fa-cube`,class:`mr-1`}),i(` `+l(r.$t(`nanobanana.name.model`))+`: `+l(r.modelValue?.request?.model),1)])):m(``,!0),r.modelValue?.request?.resolution?(u(),t(`p`,dt,[o(T,{icon:`fa-solid fa-image`,class:`mr-1`}),i(` `+l(r.$t(`nanobanana.name.resolution`))+`: `+l(r.modelValue?.request?.resolution),1)])):m(``,!0),r.modelValue?.request?.aspect_ratio?(u(),t(`p`,ft,[o(T,{icon:`fa-solid fa-up-right-from-square`,class:`mr-1`}),i(` `+l(r.$t(`nanobanana.name.aspectRatio`))+`: `+l(r.modelValue?.request?.aspect_ratio),1)])):m(``,!0),r.modelValue?.request?.action?(u(),t(`p`,pt,[o(T,{icon:`fa-solid fa-bolt`,class:`mr-1`}),i(` `+l(r.$t(`nanobanana.name.task`))+`: `+l(r.modelValue?.request?.action===`generate`?r.$t(`nanobanana.name.generate`):r.$t(`nanobanana.name.edits`)),1)])):m(``,!0),n(`p`,mt,[o(T,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+l(r.$t(`nanobanana.name.taskId`))+`: `+l(r.modelValue?.id)+` `,1),o(E,{content:r.modelValue?.id,class:`btn-copy`},null,8,[`content`])]),n(`p`,ht,[o(T,{icon:`fa-solid fa-circle-info`,class:`mr-1`}),i(` `+l(r.$t(`nanobanana.name.failureReason`))+`: `+l(r.modelValue?.response?.error?.message)+` `,1),o(E,{content:r.modelValue?.response?.error?.message,class:`btn-copy`},null,8,[`content`])]),r.modelValue?.elapsed?(u(),t(`p`,gt,[o(T,{icon:`fa-solid fa-clock`,class:`mr-1`}),i(` `+l(r.$t(`nanobanana.name.elapsed`))+`: `+l(r.modelValue?.elapsed?.toFixed(2))+`s `,1)])):m(``,!0),r.modelValue?.response?.trace_id?(u(),t(`p`,_t,[o(T,{icon:`fa-solid fa-hashtag`,class:`mr-1`}),i(` `+l(r.$t(`nanobanana.name.traceId`))+`: `+l(r.modelValue?.response?.trace_id)+` `,1),o(E,{content:r.modelValue?.response?.trace_id,class:`btn-copy`},null,8,[`content`])])):m(``,!0)]),_:1})])):(u(),t(`div`,vt,[o(D,{closable:!1,class:`info`},{template:g(()=>[o(T,{icon:`fa-solid fa-exclamation-triangle`,class:`mr-1`}),i(` `+l(r.$t(`nanobanana.name.failure`)),1)]),default:g(()=>[r.modelValue?.request?.model?(u(),t(`p`,yt,[o(T,{icon:`fa-solid fa-cube`,class:`mr-1`}),i(` `+l(r.$t(`nanobanana.name.model`))+`: `+l(r.modelValue?.request?.model),1)])):m(``,!0),r.modelValue?.request?.resolution?(u(),t(`p`,$,[o(T,{icon:`fa-solid fa-image`,class:`mr-1`}),i(` `+l(r.$t(`nanobanana.name.resolution`))+`: `+l(r.modelValue?.request?.resolution),1)])):m(``,!0),r.modelValue?.request?.aspect_ratio?(u(),t(`p`,bt,[o(T,{icon:`fa-solid fa-up-right-from-square`,class:`mr-1`}),i(` `+l(r.$t(`nanobanana.name.aspectRatio`))+`: `+l(r.modelValue?.request?.aspect_ratio),1)])):m(``,!0),r.modelValue?.request?.action?(u(),t(`p`,xt,[o(T,{icon:`fa-solid fa-bolt`,class:`mr-1`}),i(` `+l(r.$t(`nanobanana.name.task`))+`: `+l(r.modelValue?.request?.action===`generate`?r.$t(`nanobanana.name.generate`):r.$t(`nanobanana.name.edits`)),1)])):m(``,!0),n(`p`,St,[o(T,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+l(r.$t(`nanobanana.name.taskId`))+`: `+l(r.modelValue?.id)+` `,1),o(E,{content:r.modelValue?.id,class:`btn-copy`},null,8,[`content`])])]),_:1})]))])])}var wt=r({name:`RecentPanel`,components:{TaskPreview:M(Ue,[[`render`,Ct],[`__scopeId`,`data-v-63f58569`]]),BotPlaceholder:W,NoTasks:Y,ScrollList:K},props:{loading:{type:Boolean,default:!1}},emits:[`reach-top`],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.nanobanana?.tasks,items:this.$store.state.nanobanana?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),Tt={key:0},Et={key:2,class:`w-full h-full flex items-center justify-center`};function Dt(n,r,i,c,l,d){let f=h(`bot-placeholder`),p=h(`task-preview`),_=h(`scroll-list`),v=h(`no-tasks`);return u(),t(s,null,[n.tasks?.items===void 0?(u(),t(`div`,Tt,[o(f)])):n.tasks?.items?.length&&n.tasks?.items?.length>0?(u(),a(_,{key:1,ref:`scrollList`,class:`tasks h-full w-full overflow-y-auto`,loading:n.loading,onReachTop:r[0]||=e=>n.$emit(`reach-top`)},{default:g(()=>[(u(!0),t(s,null,e(n.tasks?.items,e=>(u(),a(p,{key:e.id,"model-value":e},null,8,[`model-value`]))),128))]),_:1},8,[`loading`])):m(``,!0),n.tasks?.items?.length===0?(u(),t(`div`,Et,[o(v)])):m(``,!0)],64)}var Ot=M(wt,[[`render`,Dt]]),kt=k(`nanobanana`),At=r({name:`NanobananaIndex`,components:{ConfigPanel:He,Layout:se,RecentPanel:Ot},mixins:[j],inject:[`initialized`],data(){return{task:void 0,job:0,loading:!1}},computed:{applicationsLoading(){return this.$store.state.nanobanana?.status?.getApplications===z.Request},tasksLoading(){return this.$store.state.nanobanana?.status?.getTasks===z.Request},credential(){return this.$store.state.nanobanana?.credential},config(){return this.$store.state.nanobanana?.config},application(){return this.$store.state.nanobanana?.application},tasks(){return this.$store.state.nanobanana?.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 q({tasks:this.tasks,getTasks:()=>this.tasks,loading:this.loading,setLoading:e=>this.loading=e,isBlocked:()=>this.tasksLoading,fetch:e=>this.onGetTasks({createdAtMax:e}),getScrollElement:()=>this.getTasksScrollElement()})},async onGetService(){console.debug(`start onGetService`),await this.$store.dispatch(`nanobanana/getService`),console.debug(`end onGetService`)},async onGetApplication(){console.debug(`start onGetApplication`),await this.$store.dispatch(`nanobanana/getApplications`),console.debug(`end onGetApplication`),await this.onGetTasks()},async onScrollDown(){await this.$nextTick();let e=this.getTasksScrollElement();e&&(e.scrollTop=e.scrollHeight)},async onGetTasks(e){if(this.applicationsLoading||this.tasksLoading){console.debug(`loading`);return}console.debug(`start onGetTasks`,e);let{limit:t=20,createdAtMin:n,createdAtMax:r}=e||{};console.debug(`limit`,t,`createdAtMin`,n,`createdAtMax`,r),await this.$store.dispatch(`nanobanana/getTasks`,{limit:t,createdAtMin:n,createdAtMax:r})},async onGenerate(){if(!ee(this.uploadTracker,e=>this.$t(e),e=>I.warning(e)))return;let e={...this.config||{}},t=Array.isArray(e?.image_urls)&&e.image_urls.length>0;delete e.action,!t&&`image_urls`in e&&delete e.image_urls,e?.aspect_ratio||delete e.aspect_ratio,e?.model!==`nano-banana-pro`&&`resolution`in e&&delete e.resolution,e?.model===`nano-banana-pro`&&!e?.resolution&&(e.resolution=`1K`);let n={...e,action:t?`edit`:`generate`,callback_url:kt},r=this.credential?.token;if(!r){console.error(`no token specified`);return}I.info(this.$t(`nanobanana.message.startingTask`)),N(`nanobanana`,R.generate(n,{token:r})).then(()=>{I.success(this.$t(`nanobanana.message.startTaskSuccess`))}).catch(e=>{let t=e?.response?.data;t?.error?.code===`used_up`?I.error(this.$t(`nanobanana.message.usedUp`)):I.error(this.$t(`nanobanana.message.startTaskFailed`)+(t?.error?.message||``))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function jt(e,t,n,r,i,s){let c=h(`config-panel`),l=h(`recent-panel`),d=h(`layout`);return u(),a(d,null,{config:g(()=>[o(c,{onGenerate:e.onGenerate},null,8,[`onGenerate`])]),result:g(()=>[o(l,{ref:`recentPanel`,loading:e.loading,onReachTop:e.onReachTop},null,8,[`loading`,`onReachTop`])]),_:1})}var Mt=M(At,[[`render`,jt]]);export{Mt as default};
|
|
1
|
+
import"./rolldown-runtime--c01j_DQ.js";import{$ as e,A as t,D as n,F as r,N as i,O as a,P as o,S as s,Vt as c,Wt as l,Z as u,b as d,dt as f,et as p,k as m,tt as h,ut as g,v as _}from"./vendor-chart-BJCvKk8-.js";import{t as v}from"./button-DfsQodL-.js";import{r as y,t as b}from"./select-DyEe0uU4.js";import{t as x}from"./upload-2ooOKJyT.js";import{t as S}from"./tooltip-BLwTovWL.js";import{t as C}from"./image-C7UiYpMr.js";import{t as w}from"./alert-OvnfgMB-.js";import{t as T}from"./drawer-Dpuj2uIl.js";import{An as E,En as D,On as O,_i as k,kn as A}from"./constants-CwLEZ_AF.js";import{At as j,E as M,Fn as N,Nt as P,Ot as ee,Sr as te,jt as F,kr as I,kt as L,tn as R,yr as z}from"./index-BSaC0vue.js";import{t as B}from"./index.es-NL3Dn982.js";import{t as V}from"./CopyToClipboard-Sk5Grp1_.js";import{t as H}from"./ImagePreview-BX6eL7DE.js";import{n as U}from"./taskDrawerMixin-DEgO_R5H.js";import{t as W}from"./BotPlaceholder-68XVM5HA.js";import{i as G,n as K,t as q}from"./pagination-D5c7xkGS.js";import{n as J,t as Y}from"./NoTasks-BiV0deXP.js";import{t as X}from"./Consumption-CtCh2-Du.js";import{t as Z}from"./ApiCodeButton-jFmqbRiH.js";import{t as Q}from"./ImageWrapper-CFm9ms8f.js";var ne=r({name:`LayoutNanobanana`,components:{ElDrawer:T,ElButton:v,FontAwesomeIcon:B},mixins:[U]}),re={class:`main flex flex-row flex-1`},ie={class:`config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]`},ae={class:`result h-full p-6 flex-1 flex flex-col min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]`};function oe(e,r,i,a,s,c){let l=h(`font-awesome-icon`),d=h(`el-button`),m=h(`el-drawer`);return u(),t(`div`,re,[n(`div`,ie,[p(e.$slots,`config`,{},void 0,!0)]),n(`div`,ae,[p(e.$slots,`result`,{},void 0,!0)]),f(o(d,{circle:``,class:`menu`,onClick:r[0]||=t=>e.drawer=!0},{default:g(()=>[o(l,{icon:`fa-solid fa-magic`})]),_:1},512),[[_,!e.tasksEmpty]]),o(m,{modelValue:e.drawer,"onUpdate:modelValue":r[1]||=t=>e.drawer=t,direction:`ltr`,"with-header":!1,size:`340px`,class:`drawer`},{default:g(()=>[p(e.$slots,`config`,{},void 0,!0)]),_:3},8,[`modelValue`])])}var se=M(ne,[[`render`,oe],[`__scopeId`,`data-v-d7e69eb2`]]),ce=r({name:`PromptInput`,components:{PromptTextarea:J},computed:{prompt:{get(){return this.$store.state.nanobanana?.config?.prompt},set(e){this.$store.commit(`nanobanana/setConfig`,{...this.$store.state.nanobanana?.config,prompt:e})}}},mounted(){this.prompt||=``}});function le(e,t,n,r,i,o){let s=h(`prompt-textarea`);return u(),a(s,{modelValue:e.prompt,"onUpdate:modelValue":t[0]||=t=>e.prompt=t,title:e.$t(`nanobanana.name.prompt`),info:e.$t(`nanobanana.description.prompt`),placeholder:e.$t(`nanobanana.placeholder.prompt`)},null,8,[`modelValue`,`title`,`info`,`placeholder`])}var ue=M(ce,[[`render`,le]]),de=r({name:`ImageUrlsInput`,components:{ElUpload:x,ElButton:v,InfoIcon:G,ImagePreview:H,FontAwesomeIcon:B},mixins:[F,L],data(){return{fileList:[],uploadUrl:te()+`/api/v1/files/`,suppressWatch:!1}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e?.response?.file_url).filter(e=>!!e)},value(){return this.$store.state.nanobanana?.config?.image_urls}},watch:{value:{immediate:!0,handler(e){if(this.suppressWatch)return;if(!e||e.length===0){let e=(this.fileList||[]).filter(e=>!e?.response?.file_url);this.fileList=e.length?e:[];return}let t=[];e.forEach(e=>{let n=this.fileList.find(t=>t?.response?.file_url===e||t?.url===e);n?t.push(n):t.push({name:e.split(`/`).pop()||e,url:e,status:`success`,percentage:100,response:{file_url:e}})}),(this.fileList||[]).filter(e=>!e?.response?.file_url).forEach(e=>{t.some(t=>t===e||t?.url===e?.url||t?.response?.file_url===e?.response?.file_url)||t.push(e)}),this.fileList=t}}},mounted(){},methods:{onChange(e){if(!e?.url&&e?.raw)try{e.url=URL.createObjectURL(e.raw)}catch{}},onRemove(e){if(e?.url&&typeof e.url==`string`&&e.url.startsWith(`blob:`))try{URL.revokeObjectURL(e.url)}catch{}this.onSetImageUrls()},onExceed(){I.warning(this.$t(`nanobanana.message.uploadImageExceed`))},onError(){I.error(this.$t(`nanobanana.message.uploadImageError`))},onSetImageUrls(){let e=this.urls;this.suppressWatch=!0,this.$store.commit(`nanobanana/setConfig`,{...this.$store.state.nanobanana?.config,image_urls:e}),this.$nextTick(()=>{this.suppressWatch=!1})},async onSuccess(e,t){e?.file_url&&(t.url=e.file_url,t.response=e),this.onSetImageUrls()},onRemovePreview(e,t){if(this.fileList.splice(e,1),t?.url&&typeof t.url==`string`&&t.url.startsWith(`blob:`))try{URL.revokeObjectURL(t.url)}catch{}this.onSetImageUrls()}}}),fe={class:`field flex items-center justify-between`},pe={class:`title font-bold text-[14px] mb-[10px]`},me={class:`upload-wrapper flex flex-col items-start gap-[8px]`},he={class:`controls flex items-center`},ge={class:`file-list flex flex-wrap gap-[10px]`};function _e(r,c,d,f,p,m){let _=h(`font-awesome-icon`),v=h(`el-button`),y=h(`el-upload`),b=h(`info-icon`),x=h(`image-preview`);return u(),t(s,null,[n(`div`,fe,[n(`h2`,pe,l(r.$t(`nanobanana.name.imageUrls`)),1),n(`div`,me,[n(`div`,he,[o(y,{ref:`uploader`,"file-list":r.fileList,"onUpdate:fileList":c[0]||=e=>r.fileList=e,accept:`.png,.jpg,.jpeg,.gif,.bmp,.webp`,name:`file`,class:`value`,limit:5,multiple:!0,"show-file-list":!1,action:r.uploadUrl,"on-exceed":r.onExceed,"on-error":r.onError,"on-success":r.onSuccess,"on-change":r.onChange,"on-remove":r.onRemove,headers:r.headers},{default:g(()=>[o(v,{size:`small`,type:`primary`,round:``},{default:g(()=>[o(_,{icon:`fa-solid fa-upload`,class:`mr-1`}),i(` `+l(r.$t(`nanobanana.button.uploadImageUrls`)),1)]),_:1})]),_:1},8,[`file-list`,`action`,`on-exceed`,`on-error`,`on-success`,`on-change`,`on-remove`,`headers`]),o(b,{content:r.$t(`nanobanana.description.imageUrls`),class:`ml-2`},null,8,[`content`])])])]),n(`div`,ge,[(u(!0),t(s,null,e(r.fileList,(e,t)=>(u(),a(x,{key:e.uid||e?.response?.file_url||e.url||t,url:e.url||e?.response?.file_url,name:e.name,percentage:e.percentage,onRemove:n=>r.onRemovePreview(t,e)},null,8,[`url`,`name`,`percentage`,`onRemove`]))),128))])],64)}var ve=M(de,[[`render`,_e]]),ye=r({name:`AspectRatioSelector`,components:{ElSelect:y,ElOption:b},data(){return{options:[`1:1`,`3:2`,`2:3`,`16:9`,`9:16`,`4:3`,`3:4`]}},computed:{value:{get(){return this.$store.state.nanobanana?.config?.aspect_ratio},set(e){console.debug(`set aspect_ratio`,e);let t={...this.$store.state.nanobanana?.config||{}};e?t.aspect_ratio=e:delete t.aspect_ratio,this.$store.commit(`nanobanana/setConfig`,t)}}}}),be={class:`field`},xe={class:`title font-bold`};function Se(r,i,c,d,f,p){let m=h(`el-option`),_=h(`el-select`);return u(),t(`div`,be,[n(`h2`,xe,l(r.$t(`nanobanana.name.aspectRatio`)),1),o(_,{modelValue:r.value,"onUpdate:modelValue":i[0]||=e=>r.value=e,class:`value`,clearable:``,placeholder:r.$t(`nanobanana.placeholder.select`)},{default:g(()=>[(u(!0),t(s,null,e(r.options,e=>(u(),a(m,{key:e,label:e,value:e},null,8,[`label`,`value`]))),128))]),_:1},8,[`modelValue`,`placeholder`])])}var Ce=M(ye,[[`render`,Se],[`__scopeId`,`data-v-67f08a08`]]),we=r({name:`NanobananaModelSelector`,components:{ElSelect:y,ElOption:b,InfoIcon:G},data(){return{options:[{value:O,label:this.$t(`nanobanana.model.nanoBanana`)},{value:E,label:this.$t(`nanobanana.model.nanoBananaPro`)},{value:A,label:this.$t(`nanobanana.model.nanoBanana2`)}]}},computed:{value:{get(){return this.$store.state.nanobanana?.config?.model},set(e){this.$store.commit(`nanobanana/setConfig`,{...this.$store.state.nanobanana?.config,model:e})}},modelDescription(){return this.$t(`nanobanana.description.model`)}},mounted(){this.value||=D}}),Te={class:`field`},Ee={class:`label`},De={class:`box`},Oe={class:`title font-bold`};function ke(r,i,c,d,f,p){let m=h(`info-icon`),_=h(`el-option`),v=h(`el-select`);return u(),t(`div`,Te,[n(`div`,Ee,[n(`div`,De,[n(`h2`,Oe,l(r.$t(`nanobanana.name.model`)),1),o(m,{content:r.modelDescription,class:`info`},null,8,[`content`])])]),o(v,{modelValue:r.value,"onUpdate:modelValue":i[0]||=e=>r.value=e,class:`value`,placeholder:r.$t(`nanobanana.placeholder.select`)},{default:g(()=>[(u(!0),t(s,null,e(r.options,e=>(u(),a(_,{key:e.value,label:e.label,value:e.value},null,8,[`label`,`value`]))),128))]),_:1},8,[`modelValue`,`placeholder`])])}var Ae=M(we,[[`render`,ke],[`__scopeId`,`data-v-94304d73`]]),je=r({name:`NanobananaResolutionSelector`,components:{ElSelect:y,ElOption:b,InfoIcon:G},data(){return{cachedResolution:`1K`,options:[{value:`1K`,label:`1K`},{value:`2K`,label:`2K`},{value:`4K`,label:`4K`}]}},computed:{value:{get(){return this.$store.state.nanobanana?.config?.resolution},set(e){this.$store.commit(`nanobanana/setConfig`,{...this.$store.state.nanobanana?.config,resolution:e})}},isProModel(){return this.$store.state.nanobanana?.config?.model!==O}},watch:{value(e){this.isProModel&&e&&(this.cachedResolution=e)},isProModel(e){e?this.value||=this.cachedResolution||`1K`:(this.value&&(this.cachedResolution=this.value),this.$store.commit(`nanobanana/setConfig`,{...this.$store.state.nanobanana?.config,resolution:void 0}))}},mounted(){this.isProModel&&!this.value&&(this.value=`1K`),!this.isProModel&&this.value&&(this.cachedResolution=this.value,this.$store.commit(`nanobanana/setConfig`,{...this.$store.state.nanobanana?.config,resolution:void 0}))}}),Me={class:`field`},Ne={class:`label`},Pe={class:`box`},Fe={class:`title font-bold`};function Ie(r,i,c,d,f,p){let m=h(`info-icon`),_=h(`el-option`),v=h(`el-select`);return u(),t(`div`,Me,[n(`div`,Ne,[n(`div`,Pe,[n(`h2`,Fe,l(r.$t(`nanobanana.name.resolution`)),1),o(m,{content:r.$t(`nanobanana.description.resolutionProOnly`),class:`info`},null,8,[`content`])])]),o(v,{modelValue:r.value,"onUpdate:modelValue":i[0]||=e=>r.value=e,class:`value`,placeholder:r.$t(`nanobanana.placeholder.select`),disabled:!r.isProModel},{default:g(()=>[(u(!0),t(s,null,e(r.options,e=>(u(),a(_,{key:e.value,label:e.label,value:e.value},null,8,[`label`,`value`]))),128))]),_:1},8,[`modelValue`,`placeholder`,`disabled`])])}var Le=r({name:`ConfigPanel`,components:{ElButton:v,FontAwesomeIcon:B,PromptInput:ue,Consumption:X,ImageUrlsInput:ve,AspectRatioSelector:Ce,ModelSelector:Ae,ResolutionSelector:M(je,[[`render`,Ie],[`__scopeId`,`data-v-fd5ab393`]])},emits:[`generate`],computed:{config(){return this.$store.state.nanobanana?.config},consumption(){let e={...this.config||{}},t=Array.isArray(e?.image_urls)&&e.image_urls.length>0;return P({...e,action:t?`edit`:`generate`},this.service?.cost)},service(){return this.$store.state.nanobanana?.service}},methods:{onGenerate(){this.$emit(`generate`)}}}),Re={class:`flex flex-col h-full`},ze={class:`flex-1 overflow-y-auto p-5`},Be={class:`flex flex-col items-center justify-center px-5 pb-5`};function Ve(e,r,a,s,c,d){let f=h(`model-selector`),p=h(`resolution-selector`),m=h(`prompt-input`),_=h(`aspect-ratio-selector`),v=h(`image-urls-input`),y=h(`consumption`),b=h(`font-awesome-icon`),x=h(`el-button`);return u(),t(`div`,Re,[n(`div`,ze,[o(f,{class:`mb-4`}),o(p,{class:`mb-4`}),o(m,{class:`mb-4`}),o(_,{class:`mb-4`}),o(v,{class:`mb-4`})]),n(`div`,Be,[o(y,{value:e.consumption,service:e.service},null,8,[`value`,`service`]),o(x,{type:`primary`,class:`btn w-full`,round:``,onClick:e.onGenerate},{default:g(()=>[o(b,{icon:`fa-solid fa-magic`,class:`mr-2`}),i(` `+l(e.$t(`nanobanana.button.generate`)),1)]),_:1},8,[`onClick`])])])}var He=M(Le,[[`render`,Ve]]),Ue=r({name:`TaskPreview`,components:{ElImage:C,CopyToClipboard:V,FontAwesomeIcon:B,ElAlert:w,ImageWrapper:Q,ElButton:v,ElTooltip:S,ImagePreview:H,ApiCodeButton:Z},props:{modelValue:{type:Object,required:!0}},computed:{images(){let e=[];return Array.isArray(this.modelValue?.response?.data)&&this.modelValue?.response?.data?.forEach(t=>{e.push(t)}),e}},methods:{onEdit(e){if(!e)return;console.debug(`Edit image:`,e);let t={...this.$store.state.nanobanana?.config||{}};delete t.action,t.image_urls=[e],this.$store.commit(`nanobanana/setConfig`,t)}}}),We={class:`preview`},Ge={class:`left`},Ke={class:`main`},qe={class:`bot`},Je={class:`datetime`},Ye={class:`info`},Xe={key:0,class:`flex justify-start items-center gap-2 mt-2 w-full overflow-x-auto`},Ze={key:1,class:`prompt mt-2`},Qe={key:0},$e={key:0,class:c({content:!0,failed:!0})},et={class:`flex justify-start items-center gap-4 w-full overflow-x-auto`},tt={class:c({operations:!0,"mt-2":!0,"mb-2":!0})},nt={key:0,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},rt={key:1,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},it={key:2,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},at={key:3,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},ot={class:`text-[var(--el-text-color-regular)] text-xs mb-2`},st={key:4,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},ct={key:5,class:`text-[var(--el-text-color-regular)] text-xs mb-0`},lt={key:1,class:c({content:!0})},ut={key:0,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},dt={key:1,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},ft={key:2,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},pt={key:3,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},mt={class:`text-[var(--el-text-color-regular)] text-xs mb-2`},ht={class:`text-[var(--el-text-color-regular)] text-xs mb-2`},gt={key:4,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},_t={key:5,class:`text-[var(--el-text-color-regular)] text-xs mb-0`},vt={key:2,class:c({content:!0})},yt={key:0,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},$={key:1,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},bt={key:2,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},xt={key:3,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},St={class:`text-[var(--el-text-color-regular)] text-xs mb-2`};function Ct(r,c,f,p,_,v){let y=h(`el-image`),b=h(`image-preview`),x=h(`image-wrapper`),S=h(`el-button`),C=h(`el-tooltip`),w=h(`api-code-button`),T=h(`font-awesome-icon`),E=h(`copy-to-clipboard`),D=h(`el-alert`);return u(),t(`div`,We,[n(`div`,Ge,[o(y,{src:`https://cdn.acedata.cloud/859plc.jpg`,class:`avatar`})]),n(`div`,Ke,[n(`div`,qe,[i(l(r.$t(`nanobanana.name.nanobananaBot`))+` `,1),n(`span`,Je,l(r.$dayjs.format(``+new Date(parseFloat((r.modelValue?.created_at||``).toString())*1e3))),1)]),n(`div`,Ye,[r.modelValue?.request?.image_urls&&r.modelValue?.request?.image_urls.length>0?(u(),t(`div`,Xe,[(u(!0),t(s,null,e(r.modelValue?.request?.image_urls,(e,t)=>(u(),a(b,{key:t,url:e,name:`image-${t+1}`,closable:!1},null,8,[`url`,`name`]))),128))])):m(``,!0),r.modelValue?.request?.prompt?(u(),t(`p`,Ze,[i(l(r.modelValue?.request?.prompt)+` `,1),r.modelValue?.response?m(``,!0):(u(),t(`span`,Qe,` - (`+l(r.$t(`nanobanana.status.pending`))+`) `,1))])):m(``,!0)]),r.modelValue?.response?.success===!0?(u(),t(`div`,$e,[n(`div`,et,[(u(!0),t(s,null,e(r.images,(e,t)=>(u(),a(x,{key:t,src:e?.image_url,"raw-src":e?.image_url},null,8,[`src`,`raw-src`]))),128))]),n(`div`,tt,[o(C,{class:`box-item`,effect:`dark`,content:r.$t(`common.button.edit`),placement:`top-start`},{default:g(()=>[o(S,{type:`info`,size:`small`,class:`btn-action`,onClick:c[0]||=d(e=>r.onEdit(r.images?.[0]?.image_url),[`stop`])},{default:g(()=>[i(l(r.$t(`common.button.edit`)),1)]),_:1})]),_:1},8,[`content`]),o(w,{path:`/nano-banana/images`,body:r.modelValue?.request},null,8,[`body`])]),o(D,{closable:!1,class:`mt-2 success`},{default:g(()=>[r.modelValue?.request?.model?(u(),t(`p`,nt,[o(T,{icon:`fa-solid fa-cube`,class:`mr-1`}),i(` `+l(r.$t(`nanobanana.name.model`))+`: `+l(r.modelValue?.request?.model),1)])):m(``,!0),r.modelValue?.request?.resolution?(u(),t(`p`,rt,[o(T,{icon:`fa-solid fa-image`,class:`mr-1`}),i(` `+l(r.$t(`nanobanana.name.resolution`))+`: `+l(r.modelValue?.request?.resolution),1)])):m(``,!0),r.modelValue?.request?.aspect_ratio?(u(),t(`p`,it,[o(T,{icon:`fa-solid fa-up-right-from-square`,class:`mr-1`}),i(` `+l(r.$t(`nanobanana.name.aspectRatio`))+`: `+l(r.modelValue?.request?.aspect_ratio),1)])):m(``,!0),r.modelValue?.request?.action?(u(),t(`p`,at,[o(T,{icon:`fa-solid fa-bolt`,class:`mr-1`}),i(` `+l(r.$t(`nanobanana.name.task`))+`: `+l(r.modelValue?.request?.action===`generate`?r.$t(`nanobanana.name.generate`):r.$t(`nanobanana.name.edits`)),1)])):m(``,!0),n(`p`,ot,[o(T,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+l(r.$t(`nanobanana.name.taskId`))+`: `+l(r.modelValue?.id)+` `,1),o(E,{content:r.modelValue?.id,class:`btn-copy inline-block`},null,8,[`content`])]),r.modelValue?.elapsed?(u(),t(`p`,st,[o(T,{icon:`fa-solid fa-clock`,class:`mr-1`}),i(` `+l(r.$t(`nanobanana.name.elapsed`))+`: `+l(r.modelValue?.elapsed?.toFixed(2))+`s `,1)])):m(``,!0),r.modelValue?.response?.trace_id?(u(),t(`p`,ct,[o(T,{icon:`fa-solid fa-hashtag`,class:`mr-1`}),i(` `+l(r.$t(`nanobanana.name.traceId`))+`: `+l(r.modelValue?.response?.trace_id)+` `,1),o(E,{content:r.modelValue?.response?.trace_id,class:`btn-copy inline-block`},null,8,[`content`])])):m(``,!0)]),_:1})])):r.modelValue?.response?.success===!1?(u(),t(`div`,lt,[o(D,{closable:!1,class:`failure`},{template:g(()=>[o(T,{icon:`fa-solid fa-exclamation-triangle`,class:`mr-1`}),i(` `+l(r.$t(`nanobanana.name.failure`)),1)]),default:g(()=>[r.modelValue?.request?.model?(u(),t(`p`,ut,[o(T,{icon:`fa-solid fa-cube`,class:`mr-1`}),i(` `+l(r.$t(`nanobanana.name.model`))+`: `+l(r.modelValue?.request?.model),1)])):m(``,!0),r.modelValue?.request?.resolution?(u(),t(`p`,dt,[o(T,{icon:`fa-solid fa-image`,class:`mr-1`}),i(` `+l(r.$t(`nanobanana.name.resolution`))+`: `+l(r.modelValue?.request?.resolution),1)])):m(``,!0),r.modelValue?.request?.aspect_ratio?(u(),t(`p`,ft,[o(T,{icon:`fa-solid fa-up-right-from-square`,class:`mr-1`}),i(` `+l(r.$t(`nanobanana.name.aspectRatio`))+`: `+l(r.modelValue?.request?.aspect_ratio),1)])):m(``,!0),r.modelValue?.request?.action?(u(),t(`p`,pt,[o(T,{icon:`fa-solid fa-bolt`,class:`mr-1`}),i(` `+l(r.$t(`nanobanana.name.task`))+`: `+l(r.modelValue?.request?.action===`generate`?r.$t(`nanobanana.name.generate`):r.$t(`nanobanana.name.edits`)),1)])):m(``,!0),n(`p`,mt,[o(T,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+l(r.$t(`nanobanana.name.taskId`))+`: `+l(r.modelValue?.id)+` `,1),o(E,{content:r.modelValue?.id,class:`btn-copy`},null,8,[`content`])]),n(`p`,ht,[o(T,{icon:`fa-solid fa-circle-info`,class:`mr-1`}),i(` `+l(r.$t(`nanobanana.name.failureReason`))+`: `+l(r.modelValue?.response?.error?.message)+` `,1),o(E,{content:r.modelValue?.response?.error?.message,class:`btn-copy`},null,8,[`content`])]),r.modelValue?.elapsed?(u(),t(`p`,gt,[o(T,{icon:`fa-solid fa-clock`,class:`mr-1`}),i(` `+l(r.$t(`nanobanana.name.elapsed`))+`: `+l(r.modelValue?.elapsed?.toFixed(2))+`s `,1)])):m(``,!0),r.modelValue?.response?.trace_id?(u(),t(`p`,_t,[o(T,{icon:`fa-solid fa-hashtag`,class:`mr-1`}),i(` `+l(r.$t(`nanobanana.name.traceId`))+`: `+l(r.modelValue?.response?.trace_id)+` `,1),o(E,{content:r.modelValue?.response?.trace_id,class:`btn-copy`},null,8,[`content`])])):m(``,!0)]),_:1})])):(u(),t(`div`,vt,[o(D,{closable:!1,class:`info`},{template:g(()=>[o(T,{icon:`fa-solid fa-exclamation-triangle`,class:`mr-1`}),i(` `+l(r.$t(`nanobanana.name.failure`)),1)]),default:g(()=>[r.modelValue?.request?.model?(u(),t(`p`,yt,[o(T,{icon:`fa-solid fa-cube`,class:`mr-1`}),i(` `+l(r.$t(`nanobanana.name.model`))+`: `+l(r.modelValue?.request?.model),1)])):m(``,!0),r.modelValue?.request?.resolution?(u(),t(`p`,$,[o(T,{icon:`fa-solid fa-image`,class:`mr-1`}),i(` `+l(r.$t(`nanobanana.name.resolution`))+`: `+l(r.modelValue?.request?.resolution),1)])):m(``,!0),r.modelValue?.request?.aspect_ratio?(u(),t(`p`,bt,[o(T,{icon:`fa-solid fa-up-right-from-square`,class:`mr-1`}),i(` `+l(r.$t(`nanobanana.name.aspectRatio`))+`: `+l(r.modelValue?.request?.aspect_ratio),1)])):m(``,!0),r.modelValue?.request?.action?(u(),t(`p`,xt,[o(T,{icon:`fa-solid fa-bolt`,class:`mr-1`}),i(` `+l(r.$t(`nanobanana.name.task`))+`: `+l(r.modelValue?.request?.action===`generate`?r.$t(`nanobanana.name.generate`):r.$t(`nanobanana.name.edits`)),1)])):m(``,!0),n(`p`,St,[o(T,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+l(r.$t(`nanobanana.name.taskId`))+`: `+l(r.modelValue?.id)+` `,1),o(E,{content:r.modelValue?.id,class:`btn-copy`},null,8,[`content`])])]),_:1})]))])])}var wt=r({name:`RecentPanel`,components:{TaskPreview:M(Ue,[[`render`,Ct],[`__scopeId`,`data-v-63f58569`]]),BotPlaceholder:W,NoTasks:Y,ScrollList:K},props:{loading:{type:Boolean,default:!1}},emits:[`reach-top`],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.nanobanana?.tasks,items:this.$store.state.nanobanana?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),Tt={key:0},Et={key:2,class:`w-full h-full flex items-center justify-center`};function Dt(n,r,i,c,l,d){let f=h(`bot-placeholder`),p=h(`task-preview`),_=h(`scroll-list`),v=h(`no-tasks`);return u(),t(s,null,[n.tasks?.items===void 0?(u(),t(`div`,Tt,[o(f)])):n.tasks?.items?.length&&n.tasks?.items?.length>0?(u(),a(_,{key:1,ref:`scrollList`,class:`tasks h-full w-full overflow-y-auto`,loading:n.loading,onReachTop:r[0]||=e=>n.$emit(`reach-top`)},{default:g(()=>[(u(!0),t(s,null,e(n.tasks?.items,e=>(u(),a(p,{key:e.id,"model-value":e},null,8,[`model-value`]))),128))]),_:1},8,[`loading`])):m(``,!0),n.tasks?.items?.length===0?(u(),t(`div`,Et,[o(v)])):m(``,!0)],64)}var Ot=M(wt,[[`render`,Dt]]),kt=k(`nanobanana`),At=r({name:`NanobananaIndex`,components:{ConfigPanel:He,Layout:se,RecentPanel:Ot},mixins:[j],inject:[`initialized`],data(){return{task:void 0,job:0,loading:!1}},computed:{applicationsLoading(){return this.$store.state.nanobanana?.status?.getApplications===z.Request},tasksLoading(){return this.$store.state.nanobanana?.status?.getTasks===z.Request},credential(){return this.$store.state.nanobanana?.credential},config(){return this.$store.state.nanobanana?.config},application(){return this.$store.state.nanobanana?.application},tasks(){return this.$store.state.nanobanana?.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 q({tasks:this.tasks,getTasks:()=>this.tasks,loading:this.loading,setLoading:e=>this.loading=e,isBlocked:()=>this.tasksLoading,fetch:e=>this.onGetTasks({createdAtMax:e}),getScrollElement:()=>this.getTasksScrollElement()})},async onGetService(){console.debug(`start onGetService`),await this.$store.dispatch(`nanobanana/getService`),console.debug(`end onGetService`)},async onGetApplication(){console.debug(`start onGetApplication`),await this.$store.dispatch(`nanobanana/getApplications`),console.debug(`end onGetApplication`),await this.onGetTasks()},async onScrollDown(){await this.$nextTick();let e=this.getTasksScrollElement();e&&(e.scrollTop=e.scrollHeight)},async onGetTasks(e){if(this.applicationsLoading||this.tasksLoading){console.debug(`loading`);return}console.debug(`start onGetTasks`,e);let{limit:t=20,createdAtMin:n,createdAtMax:r}=e||{};console.debug(`limit`,t,`createdAtMin`,n,`createdAtMax`,r),await this.$store.dispatch(`nanobanana/getTasks`,{limit:t,createdAtMin:n,createdAtMax:r})},async onGenerate(){if(!ee(this.uploadTracker,e=>this.$t(e),e=>I.warning(e)))return;let e={...this.config||{}},t=Array.isArray(e?.image_urls)&&e.image_urls.length>0;delete e.action,!t&&`image_urls`in e&&delete e.image_urls,e?.aspect_ratio||delete e.aspect_ratio,e?.model!==`nano-banana-pro`&&`resolution`in e&&delete e.resolution,e?.model===`nano-banana-pro`&&!e?.resolution&&(e.resolution=`1K`);let n={...e,action:t?`edit`:`generate`,callback_url:kt},r=this.credential?.token;if(!r){console.error(`no token specified`);return}I.info(this.$t(`nanobanana.message.startingTask`)),N(`nanobanana`,R.generate(n,{token:r})).then(()=>{I.success(this.$t(`nanobanana.message.startTaskSuccess`))}).catch(e=>{let t=e?.response?.data;t?.error?.code===`used_up`?I.error(this.$t(`nanobanana.message.usedUp`)):I.error(this.$t(`nanobanana.message.startTaskFailed`)+(t?.error?.message||``))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function jt(e,t,n,r,i,s){let c=h(`config-panel`),l=h(`recent-panel`),d=h(`layout`);return u(),a(d,null,{config:g(()=>[o(c,{onGenerate:e.onGenerate},null,8,[`onGenerate`])]),result:g(()=>[o(l,{ref:`recentPanel`,loading:e.loading,onReachTop:e.onReachTop},null,8,[`loading`,`onReachTop`])]),_:1})}var Mt=M(At,[[`render`,jt]]);export{Mt as default};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import"./rolldown-runtime--c01j_DQ.js";import{A as e,D as t,F as n,N as r,O as i,P as a,Wt as o,Z as s,k as c,tt as l,ut as u}from"./vendor-chart-BJCvKk8-.js";import{t as d}from"./button-DfsQodL-.js";import{n as f,t as p}from"./table-lRQt4LGt.js";import{t as m}from"./tooltip-BLwTovWL.js";import{t as ee}from"./card-DjyfNde2.js";import{n as h,t as g}from"./row-
|
|
1
|
+
import"./rolldown-runtime--c01j_DQ.js";import{A as e,D as t,F as n,N as r,O as i,P as a,Wt as o,Z as s,k as c,tt as l,ut as u}from"./vendor-chart-BJCvKk8-.js";import{t as d}from"./button-DfsQodL-.js";import{n as f,t as p}from"./table-lRQt4LGt.js";import{t as m}from"./tooltip-BLwTovWL.js";import{t as ee}from"./card-DjyfNde2.js";import{n as h,t as g}from"./row-B4cK4Xdf.js";import{t as _}from"./divider-LA__Fty9.js";import{t as v}from"./progress-C3UHYIHi.js";import{t as y}from"./skeleton-C4sltx62.js";import{E as b,Et as x,G as S,Pt as C,Sn as w,U as T,bn as E,kn as D,xn as O}from"./index-BSaC0vue.js";import{t as k}from"./index.es-NL3Dn982.js";import{t as A}from"./CopyToClipboard-Sk5Grp1_.js";var j=n({name:`ConsoleDistributionList`,components:{CopyToClipboard:A,FontAwesomeIcon:k,QrCode:x,ElProgress:v,ElRow:g,ElCol:h,ElButton:d,ElDivider:_,ElCard:ee,ElTooltip:m,ElTable:p,ElTableColumn:f,ElSkeleton:y},data(){return{invitees:[],inviteesCount:void 0,distributionLevels:[],distributionLink:void 0,distributionStatus:void 0,loading:!1}},computed:{redirect(){return this.$route.query.redirect},page(){return parseInt(this.$route.query.page?.toString()||`1`)},qrColor(){let e=document.documentElement.classList.contains(`dark`);return{dark:e?`#ffffff`:`#000000`,light:e?`#1e1e1e`:`#ffffff`}},distributionLevelMap(){let e={};return this.distributionLevels.forEach(t=>{e[t.level]=t}),e}},watch:{page:{handler(){this.onFetchData()}}},async mounted(){this.onFetchData(),this.onGenerateDistributionLink()},methods:{getPriceString:C,goHistory(){this.$router.push({name:T})},goInvitees(){this.$router.push({name:S})},onPageChange(e){this.$router.push({name:this.$route.name?.toString(),query:{page:e}})},getPercentageForNextLevel(){let e=this.distributionLevelMap[this.distributionStatus?.level?.level]?.threshold,t=this.distributionLevelMap[this.distributionStatus?.level?.level+1]?.threshold;return Math.floor((this.distributionStatus?.price-e)/(t-e)*100)},getDeltaForNextLevel(){let e=this.distributionLevelMap[this.distributionStatus?.level?.level+1]?.threshold;return Math.floor(e-this.distributionStatus?.price)},async onFetchData(){this.loading=!0,await O.initialize(),Promise.all([this.onFetchDistributionStatus(),this.onFetchDistributionLevels(),this.onFetchInvitees()]).finally(()=>{this.loading=!1})},async onGenerateDistributionLink(){let e=`${window.location.origin}?inviter_id=${this.$store.getters.user.id}`;try{let t=(await w.create(e))?.data?.data?.url;this.distributionLink=(t||e).replace(`surl.id`,`share.acedata.cloud`)}catch{this.distributionLink=e}},async onFetchDistributionStatus(){let{data:e}=await O.getAll({user_id:this.$store.getters.user.id});e.items&&e.items.length>0&&(this.distributionStatus=e.items[0])},async onFetchDistributionLevels(){let{data:e}=await E.getAll({limit:20,user_id:this.$store.getters.user.id});this.distributionLevels=e.items},async onFetchInvitees(){let{data:e}=await D.getInvitees({});this.invitees=e.items,this.inviteesCount=e.count}}}),M={class:`title`},N={key:1},P={class:`icon-wrapper`},F={class:`text-left`},I={class:`description`},L={class:`value`},R={key:1},z={class:`icon-wrapper`},B={class:`text-left`},V={class:`description`},H={class:`value`},U={key:1},W={class:`icon-wrapper`},te={class:`text-left`},G={class:`description`},K={class:`value`},q={key:1},J={class:`icon-wrapper`},Y={class:`text-left`},X={class:`description`},Z={class:`value`},Q={key:1},ne={class:`title`},re={class:`clear-both overflow-hidden`},ie={class:`float-left description`},ae={class:`float-right description`},oe={class:`description`},se={class:`level`},ce={class:`level`},le={class:`level`},ue={key:1},de={class:`title`},fe={class:`link-wrapper text-center`},pe=[`href`],$={class:`qr-wrapper ml-auto mr-auto`},me={class:`mt-0`},he={class:`description`},ge={class:`more`};function _e(n,d,f,p,m,ee){let h=l(`el-col`),g=l(`el-row`),_=l(`el-skeleton`),v=l(`font-awesome-icon`),y=l(`el-button`),b=l(`el-card`),x=l(`el-tooltip`),S=l(`el-progress`),C=l(`el-divider`),w=l(`el-table-column`),T=l(`el-table`),E=l(`copy-to-clipboard`),D=l(`qr-code`);return s(),i(g,{class:`panel`},{default:u(()=>[a(h,{span:24},{default:u(()=>[a(g,null,{default:u(()=>[a(h,{span:24},{default:u(()=>[t(`h2`,M,o(n.$t(`common.title.distribution`)),1)]),_:1})]),_:1}),a(g,{gutter:15},{default:u(()=>[a(h,{md:6,xs:24},{default:u(()=>[a(b,{shadow:`hover`,class:`item-mini mb-4`},{default:u(()=>[n.loading?(s(),i(_,{key:0})):(s(),e(`div`,N,[t(`div`,P,[a(v,{icon:`fa-solid fa-wallet`,class:`icon`})]),t(`div`,F,[t(`p`,I,o(n.$t(`distribution.title.price`)),1),t(`p`,L,o(n.getPriceString({value:n.distributionStatus?.price})),1)]),a(y,{type:`primary`,round:``,size:`small`,class:`btn`,onClick:n.goHistory},{default:u(()=>[r(o(n.$t(`distribution.button.detail`)),1)]),_:1},8,[`onClick`])]))]),_:1})]),_:1}),a(h,{md:6,xs:24},{default:u(()=>[a(b,{shadow:`hover`,class:`item-mini mb-4`},{default:u(()=>[n.loading?(s(),i(_,{key:0})):(s(),e(`div`,R,[t(`div`,z,[a(v,{icon:`fa-solid fa-coins`,class:`icon`})]),t(`div`,B,[t(`p`,V,o(n.$t(`distribution.title.reward`)),1),t(`p`,H,o(n.getPriceString({value:n.distributionStatus?.reward})),1)]),a(x,{effect:`dark`,content:n.$t(`distribution.message.developingWithDrawal`),placement:`top`},{default:u(()=>[a(y,{type:`primary`,round:``,size:`small`,class:`btn`},{default:u(()=>[r(o(n.$t(`distribution.button.withdrawal`)),1)]),_:1})]),_:1},8,[`content`])]))]),_:1})]),_:1}),a(h,{md:6,xs:24},{default:u(()=>[a(b,{shadow:`hover`,class:`item-mini mb-4`},{default:u(()=>[n.loading?(s(),i(_,{key:0})):(s(),e(`div`,U,[t(`div`,W,[a(v,{icon:`fa-solid fa-percent`,class:`icon`})]),t(`div`,te,[t(`p`,G,o(n.$t(`distribution.title.percentage`)),1),t(`p`,K,o(n.distributionStatus?.level?.percentage)+`%`,1)])]))]),_:1})]),_:1}),a(h,{md:6,xs:24},{default:u(()=>[a(b,{shadow:`hover`,class:`item-mini mb-4`},{default:u(()=>[n.loading?(s(),i(_,{key:0})):(s(),e(`div`,q,[t(`div`,J,[a(v,{icon:`fa-regular fa-user`,class:`icon`})]),t(`div`,Y,[t(`p`,X,o(n.$t(`distribution.title.inviteesCount`)),1),t(`p`,Z,o(n.inviteesCount),1)]),a(y,{type:`primary`,round:``,size:`small`,class:`btn`,onClick:n.goInvitees},{default:u(()=>[r(o(n.$t(`distribution.button.detail`)),1)]),_:1},8,[`onClick`])]))]),_:1})]),_:1})]),_:1}),a(g,{gutter:15},{default:u(()=>[a(h,{md:12,xs:24},{default:u(()=>[a(b,{shadow:`hover`,class:`level-info mb-4`},{default:u(()=>[n.loading?(s(),i(_,{key:0})):(s(),e(`div`,Q,[t(`h4`,ne,o(n.$t(`distribution.title.levelInfo`)),1),t(`div`,re,[t(`div`,ie,[t(`p`,null,o(n.$t(`distribution.title.currentLevel`))+`: L`+o(n.distributionStatus?.level?.level),1),t(`p`,null,o(n.$t(`distribution.title.currentPercentage`))+`: `+o(n.distributionLevelMap[n.distributionStatus?.level?.level]?.percentage)+`% `,1)]),t(`div`,ae,[t(`p`,null,o(n.$t(`distribution.title.nextLevel`))+`: L`+o(n.distributionStatus?.level?.level+1),1),t(`p`,null,o(n.$t(`distribution.title.nextPercentage`))+`: `+o(n.distributionLevelMap[n.distributionStatus?.level?.level+1]?.percentage)+`% `,1)])]),a(S,{"text-inside":!0,"stroke-width":20,percentage:n.getPercentageForNextLevel(),class:`mb-2`},null,8,[`percentage`]),t(`p`,oe,o(n.$t(`distribution.message.deltaPriceForNextLevel`))+`: $`+o(n.getDeltaForNextLevel()),1),a(C),n.distributionLevels?(s(),i(T,{key:0,data:n.distributionLevels,stripe:``},{default:u(()=>[a(w,{label:n.$t(`distribution.field.level`)},{default:u(e=>[t(`span`,se,`L`+o(e.row?.level),1)]),_:1},8,[`label`]),a(w,{label:n.$t(`distribution.field.threshold`)},{default:u(e=>[t(`span`,ce,`$`+o(e.row?.threshold),1)]),_:1},8,[`label`]),a(w,{label:n.$t(`distribution.field.percentage`)},{default:u(e=>[t(`span`,le,o(e.row?.percentage)+`%`,1)]),_:1},8,[`label`])]),_:1},8,[`data`])):c(``,!0)]))]),_:1})]),_:1}),a(h,{md:12,xs:24},{default:u(()=>[a(b,{shadow:`hover`,class:`distribution-info mb-4`},{default:u(()=>[n.loading?(s(),i(_,{key:0})):(s(),e(`div`,ue,[t(`h4`,de,o(n.$t(`distribution.title.distributionLink`)),1),a(C),t(`div`,fe,[c(``,!0),t(`a`,{href:n.distributionLink,class:`link`},o(n.distributionLink),9,pe),a(E,{content:n.distributionLink},null,8,[`content`])]),t(`div`,$,[n.distributionLink?(s(),i(D,{key:0,value:n.distributionLink,size:180,margin:2,class:`block mb-2 ml-auto mr-auto`,type:`image/png`,color:n.qrColor},null,8,[`value`,`color`])):c(``,!0),t(`p`,me,o(n.$t(`distribution.message.distributionQrDescription`)),1)]),t(`p`,he,[r(o(n.$t(`distribution.message.distributionLinkDescription`))+` `,1),t(`span`,ge,[a(x,{effect:`dark`,content:n.$t(`distribution.message.distributionLinkDescription2`),placement:`top`},{default:u(()=>[r(o(n.$t(`distribution.message.technicalDetail`)),1)]),_:1},8,[`content`])])])]))]),_:1})]),_:1})]),_:1})]),_:1})]),_:1})}var ve=b(j,[[`render`,_e],[`__scopeId`,`data-v-1ca0740d`]]);export{ve as default};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{A as e,F as t,Z as n}from"./vendor-chart-BJCvKk8-.js";import{E as r}from"./index-
|
|
1
|
+
import{A as e,F as t,Z as n}from"./vendor-chart-BJCvKk8-.js";import{E as r}from"./index-BSaC0vue.js";var i=t({name:`SettingsIndex`,mounted(){let e=this.$route.query.tab||``;window.dispatchEvent(new CustomEvent(`open-user-settings`,{detail:{tab:e}}))}}),a={class:`settings-page`};function o(t,r,i,o,s,c){return n(),e(`div`,a)}var s=r(i,[[`render`,o]]);export{s as default};
|