feat: auto-detect default provider + yellow highlight
This commit is contained in:
@@ -43,8 +43,22 @@ if cfg and os.path.exists(cfg):
|
||||
try:
|
||||
c = json.load(open(cfg))
|
||||
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','')
|
||||
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
|
||||
for n,p in m.get('providers',{}).items():
|
||||
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}
|
||||
.pv{display:flex;justify-content:space-between;padding:3px 0;font-size:.78em}
|
||||
.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}
|
||||
.ok{color:var(--green)}.er{color:var(--err)}
|
||||
.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="hb">${hbBars}</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">
|
||||
${[['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>
|
||||
|
||||
Reference in New Issue
Block a user