Update index.html via Sune

This commit is contained in:
2025-09-02 22:04:12 -07:00
parent 309ea0b141
commit cc083ae92a

View File

@@ -162,7 +162,7 @@ const SUNE=window.SUNE=new Proxy({get list(){return sunes},get id(){return su.ge
if(!sunes.length){const def=SUNE.create({name:'Default'});SUNE.setActive(def.id)}
const state={messages:[],busy:false,controller:null,currentThreadId:null,abortRequested:false,attachments:[],stream:{rid:null,bubble:null,meta:null,text:'',done:false}}
const getModelShort=m=>{const mm=m||SUNE.model||'';return mm.includes('/')?mm.split('/').pop():mm}
const renderSuneHTML=async()=>{const c=[SUNE.html,SUNE.extension_html].map(x=>(x||'').trim()).join('\n'),m=el.suneHtml;m.classList.toggle('hidden',!c);if(!c){m.innerHTML='';return}const doc=new DOMParser().parseFromString(`<body>${c}</body>`,'text/html');for(const t of[...doc.querySelectorAll('sune[src]')]){try{const d=await(await fetch(t.getAttribute('src'))).json(),s=(Array.isArray(d)?d[0]:d?.sunes?.[0]||d)||{},h=[s?.settings?.html||'',s?.settings?.extension_html||''].join('\n').trim();if(h)t.replaceWith(doc.createRange().createContextualFragment(h));else t.remove()}catch{t.remove()}}m.innerHTML=doc.body.innerHTML;m.querySelectorAll('script').forEach(s=>{const n=document.createElement('script');[...s.attributes].forEach(a=>n.setAttribute(a.name,a.value));n.text=s.text;s.replaceWith(n)})}
const renderSuneHTML=async()=>{const m=el.suneHtml;let finalHtml=[SUNE.html,SUNE.extension_html].map(x=>(x||'').trim()).join('\n');m.classList.toggle('hidden',!finalHtml);if(!finalHtml){m.innerHTML='';return}const tempDoc=new DOMParser().parseFromString(finalHtml,'text/html');const suneTags=[...tempDoc.querySelectorAll('sune[src]')];for(const tag of suneTags){const src=tag.getAttribute('src');const outerHTML=tag.outerHTML;try{const res=await fetch(src);const data=await res.json();const suneData=(Array.isArray(data)?data[0]:data?.sunes?.[0]||data)||{};const replacementHtml=[suneData?.settings?.html||'',suneData?.settings?.extension_html||''].join('\n').trim();finalHtml=finalHtml.replace(outerHTML,replacementHtml||'')}catch{finalHtml=finalHtml.replace(outerHTML,'')}}m.innerHTML=finalHtml;m.querySelectorAll('script').forEach(s=>{const n=document.createElement('script');[...s.attributes].forEach(a=>n.setAttribute(a.name,a.value));n.text=s.text;s.replaceWith(n)})}
const reflectActiveSune=async()=>{const a=SUNE.active;el.suneBtnTop.title=`Settings — ${a.name}`;el.suneBtnTop.innerHTML=a.avatar?`<img src="${esc(a.avatar)}" alt="" class="h-8 w-8 rounded-full object-cover"/>`:'✺';icons();await renderSuneHTML()}
const suneRow=a=>`<div class="relative flex items-center gap-2 px-3 py-2 ${a.pinned?'bg-yellow-50':''}"><button data-sune-id="${a.id}" class="flex-1 text-left flex items-center gap-2 ${a.id===SUNE.id?'font-medium':''}">${a.avatar?`<img src="${esc(a.avatar)}" alt="" class="h-6 w-6 rounded-full object-cover"/>`:`<span class="h-6 w-6 rounded-full bg-gray-200 flex items-center justify-center">✺</span>`}<span class="truncate">${a.pinned?'📌 ':''}${esc(a.name)}</span></button><button data-sune-menu="${a.id}" class="h-8 w-8 rounded hover:bg-gray-100 flex items-center justify-center" title="More"><i data-lucide="more-horizontal" class="h-4 w-4"></i></button></div>`
const renderSidebar=()=>{const list=[...SUNE.list].sort((a,b)=>(b.pinned-a.pinned));el.suneList.innerHTML=list.map(suneRow).join('');icons()}