feat: auto-detect default provider + yellow highlight
This commit is contained in:
@@ -43,8 +43,22 @@ if cfg and os.path.exists(cfg):
|
|||||||
try:
|
try:
|
||||||
c = json.load(open(cfg))
|
c = json.load(open(cfg))
|
||||||
m = c.get('models',{})
|
m = c.get('models',{})
|
||||||
# Extract default from config or -d param
|
# Auto-detect default: most used provider from recent sessions
|
||||||
dp = default_prov or m.get('default','')
|
dp = default_prov or m.get('default','')
|
||||||
|
if not dp:
|
||||||
|
from collections import Counter
|
||||||
|
prov_count = Counter()
|
||||||
|
for sd2 in glob.glob(os.path.join(os.path.expanduser('~/.openclaw'),'agents','*','sessions')):
|
||||||
|
for jf2 in glob.glob(os.path.join(sd2,'*.jsonl')):
|
||||||
|
if os.path.getmtime(jf2) < time.time()-7*86400: continue
|
||||||
|
try:
|
||||||
|
with open(jf2) as f2:
|
||||||
|
for ln in f2:
|
||||||
|
if '"provider"' in ln:
|
||||||
|
try: prov_count[json.loads(ln).get('message',{}).get('provider','')] += 1
|
||||||
|
except: pass
|
||||||
|
except: pass
|
||||||
|
if prov_count: dp = prov_count.most_common(1)[0][0]
|
||||||
default_name = dp.split('/')[0] if '/' in dp else dp
|
default_name = dp.split('/')[0] if '/' in dp else dp
|
||||||
for n,p in m.get('providers',{}).items():
|
for n,p in m.get('providers',{}).items():
|
||||||
if not isinstance(p,dict): continue
|
if not isinstance(p,dict): continue
|
||||||
|
|||||||
@@ -36,7 +36,7 @@ h1{font-size:1.3em;color:var(--neon);margin-bottom:4px}
|
|||||||
.sec{font-size:.72em;color:var(--dim);margin-bottom:4px}
|
.sec{font-size:.72em;color:var(--dim);margin-bottom:4px}
|
||||||
.pv{display:flex;justify-content:space-between;padding:3px 0;font-size:.78em}
|
.pv{display:flex;justify-content:space-between;padding:3px 0;font-size:.78em}
|
||||||
.pv-l{display:flex;gap:5px;align-items:center}
|
.pv-l{display:flex;gap:5px;align-items:center}
|
||||||
.star{color:var(--warn);font-size:.7em}
|
.pv-default{color:var(--warn)}
|
||||||
.pm{color:var(--dim);font-size:.85em}
|
.pm{color:var(--dim);font-size:.85em}
|
||||||
.ok{color:var(--green)}.er{color:var(--err)}
|
.ok{color:var(--green)}.er{color:var(--err)}
|
||||||
.gs{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin:8px 0}
|
.gs{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin:8px 0}
|
||||||
@@ -122,7 +122,7 @@ function renderNodes(){
|
|||||||
<div class="tg"><span class="${n.role==='master'?'ms':'wk'}">${n.role}</span><span>OC ${n.oc_version}</span><span>${n.os}</span></div>
|
<div class="tg"><span class="${n.role==='master'?'ms':'wk'}">${n.role}</span><span>OC ${n.oc_version}</span><span>${n.os}</span></div>
|
||||||
<div class="hb">${hbBars}</div>
|
<div class="hb">${hbBars}</div>
|
||||||
<div class="sec">供应商</div>
|
<div class="sec">供应商</div>
|
||||||
${provs.sort((a,b)=>b.default-a.default||(a.name>b.name?1:-1)).map(p=>`<div class="pv"><div class="pv-l">${p.default?'<span class="star">★</span>':''}${p.name} <span class="pm">${p.model}</span></div><div>${p.status==='ok'?'<span class="ok">✓</span> <span class="pm">'+p.ms+'ms</span>':'<span class="er">✗</span> <span class="pm">'+(p.err||'离线')+'</span>'}</div></div>`).join('')}
|
${provs.sort((a,b)=>b.default-a.default||(a.name>b.name?1:-1)).map(p=>`<div class="pv"><div class="pv-l">${p.default?'<span class="pv-default">★ </span>':''}<span${p.default?' class="pv-default"':''}>${p.name}</span> <span class="pm">${p.model}</span></div><div>${p.status==='ok'?'<span class="ok">✓</span> <span class="pm">'+p.ms+'ms</span>':'<span class="er">✗</span> <span class="pm">'+(p.err||'离线')+'</span>'}</div></div>`).join('')}
|
||||||
<div class="gs">
|
<div class="gs">
|
||||||
${[['cpu',n.cpu],['mem',n.mem],['disk',n.disk],['swap',n.swap]].map(([l,v])=>`<div class="g"><span class="g-l">${l}</span><div class="g-t"><div class="g-f ${gaugeColor(v)}" style="width:${v}%"></div></div><span class="g-n">${on?v+'%':'—'}</span></div>`).join('')}
|
${[['cpu',n.cpu],['mem',n.mem],['disk',n.disk],['swap',n.swap]].map(([l,v])=>`<div class="g"><span class="g-l">${l}</span><div class="g-t"><div class="g-f ${gaugeColor(v)}" style="width:${v}%"></div></div><span class="g-n">${on?v+'%':'—'}</span></div>`).join('')}
|
||||||
</div>
|
</div>
|
||||||
|
|||||||
Reference in New Issue
Block a user