diff --git a/dist/assets/index-DAL8-vqm.js b/dist/assets/index-Cv7JfxES.js similarity index 99% rename from dist/assets/index-DAL8-vqm.js rename to dist/assets/index-Cv7JfxES.js index 894a5a6..7fa72a0 100644 --- a/dist/assets/index-DAL8-vqm.js +++ b/dist/assets/index-Cv7JfxES.js @@ -1488,16 +1488,16 @@ async function syncActiveThread() { } const bubble = getBubbleById(id); if (!bubble) return false; - const prevText = bubble.textContent || ""; + const msgIdx = state.messages.findIndex((x) => x.id === id); + const localText = msgIdx >= 0 ? partsToText(state.messages[msgIdx]) : bubble.textContent || ""; const j = await fetch(HTTP_BASE + "?uid=" + encodeURIComponent(id)).then((r) => r.ok ? r.json() : null).catch(() => null); const finalise = (t, c, imgs) => { const tempMsg = { content: c, images: imgs }; renderMarkdown(bubble, partsToText(tempMsg), { enhance: false }); enhanceCodeBlocks(bubble, true); - const i = state.messages.findIndex((x) => x.id === id); - if (i >= 0) { - state.messages[i].content = c; - state.messages[i].images = imgs; + if (msgIdx >= 0) { + state.messages[msgIdx].content = c; + state.messages[msgIdx].images = imgs; } else state.messages.push({ id, role: "assistant", content: c, images: imgs, ...activeMeta() }); THREAD.persist(); setBtnSend(); @@ -1508,16 +1508,16 @@ async function syncActiveThread() { }; if (!j || j.rid !== id) { if (j && j.error) { - const t = prevText + "\n\n" + j.error; + const t = localText + "\n\n" + j.error; finalise(t, [{ type: "text", text: t }]); } return false; } - const text = j.text || "", isDone = j.error || j.done || j.phase === "done"; - const display = partsToText({ content: [{ type: "text", text }], images: j.images }); + const serverText = j.text || "", isDone = j.error || j.done || j.phase === "done"; + const finalText = serverText.length >= localText.length || isDone ? serverText : localText; + const display = partsToText({ content: [{ type: "text", text: finalText }], images: j.images }); if (display) renderMarkdown(bubble, display, { enhance: false }); if (isDone) { - const finalText = text || prevText; finalise(finalText, [{ type: "text", text: finalText }], j.images); return false; } diff --git a/dist/index.html b/dist/index.html index 5f3a310..3aa5ce5 100644 --- a/dist/index.html +++ b/dist/index.html @@ -12,7 +12,7 @@ - + diff --git a/dist/sw.js b/dist/sw.js index b4a8a07..2dcf2c9 100644 --- a/dist/sw.js +++ b/dist/sw.js @@ -1 +1 @@ -if(!self.define){let e,s={};const i=(i,n)=>(i=new URL(i+".js",n).href,s[i]||new Promise(s=>{if("document"in self){const e=document.createElement("script");e.src=i,e.onload=s,document.head.appendChild(e)}else e=i,importScripts(i),s()}).then(()=>{let e=s[i];if(!e)throw new Error(`Module ${i} didn’t register its module`);return e}));self.define=(n,r)=>{const t=e||("document"in self?document.currentScript.src:"")||location.href;if(s[t])return;let o={};const c=e=>i(e,t),l={module:{uri:t},exports:o,require:c};s[t]=Promise.all(n.map(e=>l[e]||c(e))).then(e=>(r(...e),o))}}define(["./workbox-8c29f6e4"],function(e){"use strict";self.skipWaiting(),e.clientsClaim(),e.precacheAndRoute([{url:"registerSW.js",revision:"1872c500de691dce40960bb85481de07"},{url:"index.html",revision:"50b9a8411eab7cb3f1b4dc4d86217ab4"},{url:"assets/index-DAL8-vqm.js",revision:null},{url:"assets/index-CZ8Js0gk.css",revision:null},{url:"manifest.webmanifest",revision:"7a6c5c6ab9cb5d3605d21df44c6b17a2"}],{}),e.cleanupOutdatedCaches(),e.registerRoute(new e.NavigationRoute(e.createHandlerBoundToURL("index.html")))}); +if(!self.define){let e,s={};const i=(i,n)=>(i=new URL(i+".js",n).href,s[i]||new Promise(s=>{if("document"in self){const e=document.createElement("script");e.src=i,e.onload=s,document.head.appendChild(e)}else e=i,importScripts(i),s()}).then(()=>{let e=s[i];if(!e)throw new Error(`Module ${i} didn’t register its module`);return e}));self.define=(n,r)=>{const t=e||("document"in self?document.currentScript.src:"")||location.href;if(s[t])return;let o={};const d=e=>i(e,t),c={module:{uri:t},exports:o,require:d};s[t]=Promise.all(n.map(e=>c[e]||d(e))).then(e=>(r(...e),o))}}define(["./workbox-8c29f6e4"],function(e){"use strict";self.skipWaiting(),e.clientsClaim(),e.precacheAndRoute([{url:"registerSW.js",revision:"1872c500de691dce40960bb85481de07"},{url:"index.html",revision:"8b290d06fdea7a854064c5dad25c9259"},{url:"assets/index-Cv7JfxES.js",revision:null},{url:"assets/index-CZ8Js0gk.css",revision:null},{url:"manifest.webmanifest",revision:"7a6c5c6ab9cb5d3605d21df44c6b17a2"}],{}),e.cleanupOutdatedCaches(),e.registerRoute(new e.NavigationRoute(e.createHandlerBoundToURL("index.html")))});