clay-server 2.36.2-beta.1 → 2.36.2-beta.2

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.
@@ -330,10 +330,11 @@ function attachSessions(ctx) {
330
330
  var targetVendor = switchTargetSess.vendor || sm.defaultVendor || null;
331
331
  var tvModels = (targetVendor && sm.modelsByVendor && sm.modelsByVendor[targetVendor]) || [];
332
332
  var found = false;
333
+ var _curLc = sm.currentModel.toLowerCase();
333
334
  for (var tvi = 0; tvi < tvModels.length; tvi++) {
334
335
  var tvEntry = tvModels[tvi];
335
336
  var tvVal = typeof tvEntry === "string" ? tvEntry : (tvEntry && (tvEntry.value || tvEntry.id)) || "";
336
- if (tvVal === sm.currentModel) { found = true; break; }
337
+ if (tvVal === sm.currentModel || (tvVal && (tvVal.toLowerCase().indexOf(_curLc) !== -1 || _curLc.indexOf(tvVal.toLowerCase()) !== -1))) { found = true; break; }
337
338
  }
338
339
  if (tvModels.length > 0 && !found) {
339
340
  sm.currentModel = "";
@@ -749,8 +749,9 @@ export function toggleStatusPanel() {
749
749
  // --- Context panel ---
750
750
 
751
751
  export function resolveContextWindow(model, sdkValue) {
752
- if (sdkValue) return sdkValue;
753
752
  var lc = (model || "").toLowerCase();
753
+ if (lc.includes("[1m]")) return 1000000;
754
+ if (sdkValue) return sdkValue;
754
755
  for (var key in KNOWN_CONTEXT_WINDOWS) {
755
756
  if (lc.includes(key)) return KNOWN_CONTEXT_WINDOWS[key];
756
757
  }
@@ -851,8 +852,11 @@ export function accumulateContext(cost, usage, modelUsage, lastStreamInputTokens
851
852
  if (models.length > 0) {
852
853
  var m = models[0];
853
854
  var mu = modelUsage[m];
854
- contextData.model = m;
855
- contextData.contextWindow = resolveContextWindow(m, mu.contextWindow);
855
+ // Prefer the user-configured model name over the API-reported one
856
+ // (e.g. CLI reports "claude-sonnet-4-6" even when running as opus[1m])
857
+ var displayModel = store.get('currentModel') || m;
858
+ contextData.model = displayModel;
859
+ contextData.contextWindow = resolveContextWindow(displayModel, mu.contextWindow);
856
860
  if (mu.maxOutputTokens) contextData.maxOutputTokens = mu.maxOutputTokens;
857
861
  }
858
862
  }
package/lib/sdk-bridge.js CHANGED
@@ -198,6 +198,24 @@ function createSDKBridge(opts) {
198
198
  return false;
199
199
  }
200
200
 
201
+ // Resolve a shorthand model name (e.g. "opus[1m]") to its full ID
202
+ // in the vendor model list (e.g. "claude-opus-4.6[1m]").
203
+ function resolveModelInList(list, modelId) {
204
+ if (!list || !modelId) return null;
205
+ var lc = modelId.toLowerCase();
206
+ for (var mi = 0; mi < list.length; mi++) {
207
+ var val = modelEntryValue(list[mi]);
208
+ if (val === modelId) return val;
209
+ }
210
+ for (var mi = 0; mi < list.length; mi++) {
211
+ var val = modelEntryValue(list[mi]);
212
+ if (!val || val === "default") continue;
213
+ var vlc = val.toLowerCase();
214
+ if (vlc.indexOf(lc) !== -1 || lc.indexOf(vlc) !== -1) return val;
215
+ }
216
+ return null;
217
+ }
218
+
201
219
  function sendModelInfoForVendor(vendor, model) {
202
220
  send({
203
221
  type: "model_info",
@@ -1234,12 +1252,13 @@ function createSDKBridge(opts) {
1234
1252
  // Claude would reject the unknown model. We validate against the
1235
1253
  // session vendor's model list regardless of which vendor happens to be
1236
1254
  // the project's default adapter.
1237
- var queryModel = ls.model || sm.currentModel || undefined;
1255
+ var queryModel = (ls.model && ls.model !== "default" ? ls.model : null) || sm.currentModel || undefined;
1238
1256
  var sessionVendor = session.vendor || (adapter && adapter.vendor) || null;
1239
1257
  if (sessionVendor) {
1240
1258
  var vendorModels = (sm.modelsByVendor && sm.modelsByVendor[sessionVendor]) || [];
1241
1259
  if (vendorModels.length > 0 && queryModel && !modelListContains(vendorModels, queryModel)) {
1242
- queryModel = modelEntryValue(vendorModels[0]);
1260
+ var resolved = resolveModelInList(vendorModels, queryModel);
1261
+ queryModel = resolved || modelEntryValue(vendorModels[0]);
1243
1262
  }
1244
1263
  }
1245
1264
  // Guard against anything upstream having set queryModel to an object
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "clay-server",
3
- "version": "2.36.2-beta.1",
3
+ "version": "2.36.2-beta.2",
4
4
  "description": "Self-hosted team workspace for Claude Code and Codex. Multi-user, browser-based, with persistent AI mates.",
5
5
  "bin": {
6
6
  "clay-server": "./bin/cli.js",