@wendongfly/myhi 1.0.77 → 1.0.79

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/chat.html CHANGED
@@ -374,8 +374,9 @@
374
374
  if (t.modelUsage) { for (const [m, u] of Object.entries(t.modelUsage)) { if (u.outputTokens > 0) html += `<div style="font-size:0.75rem;color:#8b949e;margin-top:0.3rem">${m.replace(/claude-/,'').replace(/-\d{8}$/,'')} 输入 ${(u.inputTokens/1000).toFixed(0)}K 输出 ${(u.outputTokens/1000).toFixed(0)}K</div>`; } }
375
375
  html += '</div>';
376
376
  }
377
- html += '<button onclick="this.parentElement.parentElement.remove()" style="margin-top:0.8rem;width:100%;padding:0.7rem;background:#7c3aed;color:#fff;border:none;border-radius:10px;cursor:pointer;font-size:0.9rem;font-weight:600">关闭</button></div>';
377
+ html += '<button onclick="this.closest(\'[data-usage-overlay]\').remove()" style="margin-top:0.8rem;width:100%;padding:0.7rem;background:#7c3aed;color:#fff;border:none;border-radius:10px;cursor:pointer;font-size:0.9rem;font-weight:600">关闭</button></div>';
378
378
  const overlay = document.createElement('div');
379
+ overlay.setAttribute('data-usage-overlay', '');
379
380
  overlay.style.cssText = 'position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,0.6);z-index:999;display:flex;align-items:center;justify-content:center;backdrop-filter:blur(4px)';
380
381
  overlay.onclick = (e) => { if (e.target === overlay) overlay.remove(); };
381
382
  const box = document.createElement('div');
@@ -976,8 +977,9 @@
976
977
  }
977
978
  }
978
979
 
979
- socket.on('connect', () => { showOverlay('正在加入会话...'); socket.emit('join', SESSION_ID); });
980
- socket.on('connect_error', (err) => { showOverlay('连接失败: ' + err.message, true); });
980
+ let _reconnectFails = 0;
981
+ socket.on('connect', () => { _reconnectFails = 0; showOverlay('正在加入会话...'); socket.emit('join', SESSION_ID); });
982
+ socket.on('connect_error', () => { _reconnectFails++; showOverlay(_reconnectFails >= 5 ? '连接失败,请检查网络' : `正在重连... (${_reconnectFails})`, _reconnectFails >= 10); });
981
983
  socket.on('disconnect', () => { showOverlay('已断开连接,正在重连...'); });
982
984
 
983
985
  socket.on('joined', (session) => {
package/dist/index.html CHANGED
@@ -570,8 +570,9 @@
570
570
  if (t.modelUsage) { for (const [m, u] of Object.entries(t.modelUsage)) { if (u.outputTokens > 0) html += `<div style="font-size:0.75rem;color:#8b949e;margin-top:0.3rem">${m.replace(/claude-/,'').replace(/-\d{8}$/,'')} 输入 ${(u.inputTokens/1000).toFixed(0)}K 输出 ${(u.outputTokens/1000).toFixed(0)}K</div>`; } }
571
571
  html += '</div>';
572
572
  }
573
- html += '<button onclick="this.parentElement.parentElement.remove()" style="margin-top:0.8rem;width:100%;padding:0.7rem;background:#7c3aed;color:#fff;border:none;border-radius:10px;cursor:pointer;font-size:0.9rem;font-weight:600">关闭</button></div>';
573
+ html += '<button onclick="this.closest(\'[data-usage-overlay]\').remove()" style="margin-top:0.8rem;width:100%;padding:0.7rem;background:#7c3aed;color:#fff;border:none;border-radius:10px;cursor:pointer;font-size:0.9rem;font-weight:600">关闭</button></div>';
574
574
  const overlay = document.createElement('div');
575
+ overlay.setAttribute('data-usage-overlay', '');
575
576
  overlay.style.cssText = 'position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,0.6);z-index:999;display:flex;align-items:center;justify-content:center;backdrop-filter:blur(4px)';
576
577
  overlay.onclick = (e) => { if (e.target === overlay) overlay.remove(); };
577
578
  const box = document.createElement('div');
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@wendongfly/myhi",
3
- "version": "1.0.77",
3
+ "version": "1.0.79",
4
4
  "description": "Web-based terminal sharing with chat UI — control your terminal from phone via LAN/Tailscale",
5
5
  "type": "module",
6
6
  "main": "dist/index.js",