mastracode 0.9.2-alpha.2 → 0.9.2-alpha.4

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.
Files changed (47) hide show
  1. package/CHANGELOG.md +24 -0
  2. package/README.md +1 -1
  3. package/dist/{chunk-UUS7G74S.js → chunk-7I6PTSCL.js} +10 -10
  4. package/dist/chunk-7I6PTSCL.js.map +1 -0
  5. package/dist/{chunk-REEH5DEO.js → chunk-HFH7M2ET.js} +6 -119
  6. package/dist/chunk-HFH7M2ET.js.map +1 -0
  7. package/dist/{chunk-SDEWWLAM.cjs → chunk-PXPRSHIZ.cjs} +712 -825
  8. package/dist/chunk-PXPRSHIZ.cjs.map +1 -0
  9. package/dist/{chunk-HYI5VCPJ.cjs → chunk-RGS2DVIJ.cjs} +36 -36
  10. package/dist/{chunk-HYI5VCPJ.cjs.map → chunk-RGS2DVIJ.cjs.map} +1 -1
  11. package/dist/{chunk-45H2FFSL.cjs → chunk-SCGR45LE.cjs} +3 -3
  12. package/dist/{chunk-45H2FFSL.cjs.map → chunk-SCGR45LE.cjs.map} +1 -1
  13. package/dist/{chunk-PSPCUMGV.js → chunk-WISS4SS3.js} +4 -4
  14. package/dist/{chunk-PSPCUMGV.js.map → chunk-WISS4SS3.js.map} +1 -1
  15. package/dist/{chunk-C7K52PPG.cjs → chunk-XBA6CB7T.cjs} +13 -13
  16. package/dist/chunk-XBA6CB7T.cjs.map +1 -0
  17. package/dist/{chunk-GTRZ4DPO.js → chunk-YIBXRSXL.js} +3 -3
  18. package/dist/{chunk-GTRZ4DPO.js.map → chunk-YIBXRSXL.js.map} +1 -1
  19. package/dist/cli.cjs +17 -17
  20. package/dist/cli.js +4 -4
  21. package/dist/index.cjs +3 -3
  22. package/dist/index.js +1 -1
  23. package/dist/onboarding/onboarding-inline.d.ts +0 -1
  24. package/dist/onboarding/onboarding-inline.d.ts.map +1 -1
  25. package/dist/onboarding/packs.d.ts.map +1 -1
  26. package/dist/onboarding/settings.d.ts +0 -2
  27. package/dist/onboarding/settings.d.ts.map +1 -1
  28. package/dist/storage-6BUW7JXT.cjs +24 -0
  29. package/dist/{storage-HJALULMH.cjs.map → storage-6BUW7JXT.cjs.map} +1 -1
  30. package/dist/storage-T6AFSPIY.js +3 -0
  31. package/dist/{storage-R76IXKUI.js.map → storage-T6AFSPIY.js.map} +1 -1
  32. package/dist/tui/commands/login.d.ts.map +1 -1
  33. package/dist/tui/mastra-tui.d.ts +0 -5
  34. package/dist/tui/mastra-tui.d.ts.map +1 -1
  35. package/dist/tui.cjs +19 -19
  36. package/dist/tui.js +2 -2
  37. package/package.json +7 -7
  38. package/dist/auth/claude-max-warning.d.ts +0 -9
  39. package/dist/auth/claude-max-warning.d.ts.map +0 -1
  40. package/dist/chunk-C7K52PPG.cjs.map +0 -1
  41. package/dist/chunk-REEH5DEO.js.map +0 -1
  42. package/dist/chunk-SDEWWLAM.cjs.map +0 -1
  43. package/dist/chunk-UUS7G74S.js.map +0 -1
  44. package/dist/storage-HJALULMH.cjs +0 -24
  45. package/dist/storage-R76IXKUI.js +0 -3
  46. package/dist/tui/claude-max-warning.d.ts +0 -18
  47. package/dist/tui/claude-max-warning.d.ts.map +0 -1
package/CHANGELOG.md CHANGED
@@ -1,5 +1,29 @@
1
1
  # mastracode
2
2
 
3
+ ## 0.9.2-alpha.4
4
+
5
+ ### Patch Changes
6
+
7
+ - Updated dependencies [[`423aa6f`](https://github.com/mastra-ai/mastra/commit/423aa6fd12406de6a1cc6b68e463d30af1d790fb), [`4bb5adc`](https://github.com/mastra-ai/mastra/commit/4bb5adc05c88e3a83fe1ea5ecb9eae6e17313124), [`4bb5adc`](https://github.com/mastra-ai/mastra/commit/4bb5adc05c88e3a83fe1ea5ecb9eae6e17313124)]:
8
+ - @mastra/core@1.16.0-alpha.3
9
+ - @mastra/mcp@1.3.1
10
+ - @mastra/memory@1.9.1-alpha.1
11
+
12
+ ## 0.9.2-alpha.3
13
+
14
+ ### Patch Changes
15
+
16
+ - Removed the Anthropic OAuth warning flow from Mastra Code. ([#14605](https://github.com/mastra-ai/mastra/pull/14605))
17
+
18
+ `/login`, startup, and the setup wizard no longer interrupt Anthropic OAuth with the Claude Max warning prompt, and the related onboarding setting has been removed. Anthropic has confirmed that users do not get banned for using Claude max oauth. https://x.com/trq212/status/2035076299774206228?s=20
19
+
20
+ - Mastra Code now defaults the OpenAI mode pack to use `openai/gpt-5.4` for build and plan, and `openai/gpt-5.4-mini` for fast mode. The OpenAI OM pack selected during setup now defaults to `openai/gpt-5.4-mini`. ([#14604](https://github.com/mastra-ai/mastra/pull/14604))
21
+
22
+ - Updated dependencies [[`be37de4`](https://github.com/mastra-ai/mastra/commit/be37de4391bd1d5486ce38efacbf00ca51637262), [`f3ce603`](https://github.com/mastra-ai/mastra/commit/f3ce603fd76180f4a5be90b6dc786d389b6b3e98), [`2871451`](https://github.com/mastra-ai/mastra/commit/2871451703829aefa06c4a5d6eca7fd3731222ef), [`d3930ea`](https://github.com/mastra-ai/mastra/commit/d3930eac51c30b0ecf7eaa54bb9430758b399777), [`23bd359`](https://github.com/mastra-ai/mastra/commit/23bd359c50898c3b28b9ee25ce47c12614da5a36)]:
23
+ - @mastra/core@1.16.0-alpha.2
24
+ - @mastra/memory@1.9.1-alpha.0
25
+ - @mastra/mcp@1.3.1
26
+
3
27
  ## 0.9.2-alpha.2
4
28
 
5
29
  ### Patch Changes
package/README.md CHANGED
@@ -140,7 +140,7 @@ The SQLite database is stored in your system's application data directory:
140
140
 
141
141
  For **Anthropic** models, mastracode supports two authentication methods:
142
142
 
143
- 1. **Claude Max OAuth (primary)** — Use `/login` to authenticate with a Claude Pro/Max subscription. This is the recommended approach.
143
+ 1. **Claude Max OAuth (primary)** — Use `/login` to authenticate with a Claude Pro/Max subscription.
144
144
  2. **API key (fallback)** — Set the `ANTHROPIC_API_KEY` environment variable for direct API access. This is used when not logged in via OAuth.
145
145
 
146
146
  When both are available, Claude Max OAuth takes priority.
@@ -1,4 +1,4 @@
1
- import { getAppDataDir } from './chunk-GTRZ4DPO.js';
1
+ import { getAppDataDir } from './chunk-YIBXRSXL.js';
2
2
  import * as fs from 'fs';
3
3
  import { existsSync, readFileSync, mkdirSync, writeFileSync } from 'fs';
4
4
  import * as path from 'path';
@@ -16,8 +16,7 @@ var DEFAULTS = {
16
16
  skippedAt: null,
17
17
  version: 0,
18
18
  modePackId: null,
19
- omPackId: null,
20
- claudeMaxOAuthWarningAcknowledgedAt: null
19
+ omPackId: null
21
20
  },
22
21
  models: {
23
22
  activeModelPackId: null,
@@ -164,7 +163,7 @@ function migrateFromAuth(settingsPath) {
164
163
  return true;
165
164
  }
166
165
  var LEGACY_VARIED_MODELS = {
167
- plan: "openai/gpt-5.3-codex",
166
+ plan: "openai/gpt-5.4",
168
167
  build: "anthropic/claude-sonnet-4-5",
169
168
  fast: "anthropic/claude-haiku-4-5"
170
169
  };
@@ -311,7 +310,8 @@ function saveSettings(settings, filePath = getSettingsPath()) {
311
310
  // src/onboarding/packs.ts
312
311
  function getAvailableModePacks(access, savedCustomPacks = []) {
313
312
  const packs = [];
314
- const openaiCodex = "openai/gpt-5.3-codex";
313
+ const openaiCodex = "openai/gpt-5.4";
314
+ const openaiFast = "openai/gpt-5.4-mini";
315
315
  const anthropicBuild = access.anthropic === "oauth" ? "anthropic/claude-opus-4-6" : "anthropic/claude-sonnet-4-5";
316
316
  if (access.anthropic) {
317
317
  packs.push({
@@ -333,7 +333,7 @@ function getAvailableModePacks(access, savedCustomPacks = []) {
333
333
  models: {
334
334
  build: openaiCodex,
335
335
  plan: openaiCodex,
336
- fast: "openai/gpt-5.1-codex-mini"
336
+ fast: openaiFast
337
337
  }
338
338
  });
339
339
  }
@@ -379,9 +379,9 @@ function getAvailableOmPacks(access) {
379
379
  if (access.openai) {
380
380
  packs.push({
381
381
  id: "openai",
382
- name: "Codex Mini",
382
+ name: "OpenAI Mini",
383
383
  description: access.openai === "oauth" ? "Via Codex subscription" : "Via OpenAI API key",
384
- modelId: "openai/gpt-5.1-codex-mini"
384
+ modelId: "openai/gpt-5.4-mini"
385
385
  });
386
386
  }
387
387
  if (access.deepseek) {
@@ -908,5 +908,5 @@ function releaseAllThreadLocks() {
908
908
  }
909
909
 
910
910
  export { BOX_INDENT, BOX_INDENT_STR, CHAT_INDENT, ONBOARDING_VERSION, TERM_WIDTH_BUFFER, THREAD_ACTIVE_MODEL_PACK_ID_KEY, ThreadLockError, acquireThreadLock, applyThemeMode, ensureContrast, getAvailableModePacks, getAvailableOmPacks, getCustomProviderId, getEditorTheme, getMarkdownTheme, getSelectListTheme, getSettingsListTheme, getTermWidth, getThemeMode, loadSettings, luminance, mastra, mastraBrand, releaseAllThreadLocks, releaseThreadLock, resolveModelDefaults, resolveOmModel, resolveThreadActiveModelPackId, restoreTerminalForeground, saveSettings, theme, tintHex, toCustomProviderModelId };
911
- //# sourceMappingURL=chunk-UUS7G74S.js.map
912
- //# sourceMappingURL=chunk-UUS7G74S.js.map
911
+ //# sourceMappingURL=chunk-7I6PTSCL.js.map
912
+ //# sourceMappingURL=chunk-7I6PTSCL.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/onboarding/settings.ts","../src/onboarding/packs.ts","../src/tui/theme.ts","../src/utils/thread-lock.ts"],"names":["bg","p","q"],"mappings":"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","file":"chunk-7I6PTSCL.js","sourcesContent":["/**\n * Persistent global settings stored in the app data directory as settings.json.\n * This file persists onboarding state AND user preferences (model choices, yolo, etc.)\n * so they carry across threads and restarts.\n */\n\nimport { existsSync, mkdirSync, readFileSync, writeFileSync } from 'node:fs';\nimport { dirname, join } from 'node:path';\nimport type { LSPConfig } from '@mastra/core/workspace';\nimport { getAppDataDir } from '../utils/project.js';\n\n/** A saved custom pack — user-defined model selections for each mode. */\nexport interface CustomPack {\n name: string;\n models: Record<string, string>;\n createdAt: string;\n}\n\n/** A saved custom provider for OpenAI-compatible endpoints. */\nexport interface CustomProviderSetting {\n name: string;\n url: string;\n apiKey?: string;\n models: string[];\n}\n\n/** Storage backend type. */\nexport type StorageBackend = 'libsql' | 'pg';\n\n/** LibSQL-specific storage settings. */\nexport interface LibSQLStorageSettings {\n url?: string;\n authToken?: string;\n}\n\n/** PostgreSQL-specific storage settings. */\nexport interface PgStorageSettings {\n connectionString?: string;\n host?: string;\n port?: number;\n database?: string;\n user?: string;\n password?: string;\n schemaName?: string;\n disableInit?: boolean;\n skipDefaultIndexes?: boolean;\n}\n\n/** Storage configuration persisted in global settings. */\nexport interface StorageSettings {\n /** Which backend to use. Default: 'libsql'. */\n backend: StorageBackend;\n /** LibSQL-specific config (used when backend is 'libsql'). */\n libsql: LibSQLStorageSettings;\n /** PostgreSQL-specific config (used when backend is 'pg'). */\n pg: PgStorageSettings;\n}\n\n/** Valid persisted thinking level values. */\nexport type ThinkingLevelSetting = 'off' | 'low' | 'medium' | 'high' | 'xhigh';\n\nexport interface GlobalSettings {\n // Onboarding tracking\n onboarding: {\n completedAt: string | null;\n skippedAt: string | null;\n version: number;\n modePackId: string | null;\n omPackId: string | null;\n };\n // Global model preferences (applied to new threads)\n models: {\n /**\n * Active model pack ID. Built-in packs use their id directly (\"anthropic\",\n * \"openai\"). Custom packs use \"custom:<name>\".\n * When set, models are resolved from the pack at startup so pack updates\n * (e.g. new model versions) apply automatically.\n * Cleared when the user manually overrides via /models (falls back to modeDefaults).\n */\n activeModelPackId: string | null;\n /** Explicit per-mode overrides — used when no activeModelPackId is set. */\n modeDefaults: Record<string, string>;\n /**\n * Active OM pack ID (e.g. \"gemini\", \"anthropic\", \"custom\").\n * When set, the OM model is resolved from the pack at startup so pack\n * updates (e.g. new model versions) apply automatically.\n * Cleared when the user manually overrides via /om (falls back to omModelOverride).\n */\n activeOmPackId: string | null;\n /** Explicit OM model override — used for custom OM pack or /om manual changes. */\n omModelOverride: string | null;\n /** Per-agent-type subagent model overrides (e.g. { explore: \"openai/gpt-5.1-codex-mini\" }) */\n subagentModels: Record<string, string>;\n };\n // Global behavior preferences\n preferences: {\n yolo: boolean | null;\n theme: 'auto' | 'dark' | 'light';\n /** Default reasoning effort level used for all threads/models unless overridden in-session. */\n thinkingLevel: ThinkingLevelSetting;\n /** When true, components like subagent output collapse to compact summaries on completion. */\n quietMode: boolean;\n };\n // Storage backend configuration\n storage: StorageSettings;\n // User-created custom model packs\n customModelPacks: CustomPack[];\n // User-created custom providers with custom models\n customProviders: CustomProviderSetting[];\n // Model usage counts for ranking in the selector\n modelUseCounts: Record<string, number>;\n // Version the user dismissed the update prompt for (skip until they manually update past this)\n updateDismissedVersion: string | null;\n // LSP configuration forwarded to the workspace\n lsp?: LSPConfig;\n}\n\nexport const STORAGE_DEFAULTS: StorageSettings = {\n backend: 'libsql',\n libsql: {},\n pg: {},\n};\n\nconst DEFAULTS: GlobalSettings = {\n onboarding: {\n completedAt: null,\n skippedAt: null,\n version: 0,\n modePackId: null,\n omPackId: null,\n },\n models: {\n activeModelPackId: null,\n modeDefaults: {},\n activeOmPackId: null,\n omModelOverride: null,\n subagentModels: {},\n },\n preferences: {\n yolo: null,\n theme: 'auto',\n thinkingLevel: 'off',\n quietMode: false,\n },\n storage: { ...STORAGE_DEFAULTS },\n customModelPacks: [],\n customProviders: [],\n modelUseCounts: {},\n updateDismissedVersion: null,\n lsp: {},\n};\n\nconst THINKING_LEVEL_VALUES: ThinkingLevelSetting[] = ['off', 'low', 'medium', 'high', 'xhigh'];\n\nfunction parseThinkingLevel(value: unknown): ThinkingLevelSetting {\n return typeof value === 'string' && THINKING_LEVEL_VALUES.includes(value as ThinkingLevelSetting)\n ? (value as ThinkingLevelSetting)\n : DEFAULTS.preferences.thinkingLevel;\n}\n\nfunction parsePreferences(rawPreferences: unknown): GlobalSettings['preferences'] {\n const raw = rawPreferences && typeof rawPreferences === 'object' ? (rawPreferences as Record<string, unknown>) : {};\n\n return {\n ...DEFAULTS.preferences,\n ...raw,\n thinkingLevel: parseThinkingLevel(raw.thinkingLevel),\n };\n}\n\nexport function getSettingsPath(): string {\n return join(getAppDataDir(), 'settings.json');\n}\n\nexport function getCustomProviderId(name: string): string {\n const slug = name\n .trim()\n .toLowerCase()\n .replace(/[^a-z0-9]+/g, '-')\n .replace(/^-+|-+$/g, '');\n return slug || 'provider';\n}\n\nexport function toCustomProviderModelId(providerName: string, modelName: string): string {\n const providerId = getCustomProviderId(providerName);\n const trimmedModelName = modelName.trim();\n const providerPrefix = `${providerId}/`;\n if (trimmedModelName.startsWith(providerPrefix)) {\n return trimmedModelName;\n }\n return `${providerId}/${trimmedModelName}`;\n}\n\nexport function parseCustomProviders(rawProviders: unknown): CustomProviderSetting[] {\n if (!Array.isArray(rawProviders)) return [];\n\n const parsedProviders: CustomProviderSetting[] = [];\n for (const rawProvider of rawProviders) {\n if (!rawProvider || typeof rawProvider !== 'object') continue;\n\n const candidate = rawProvider as Record<string, unknown>;\n const name = typeof candidate.name === 'string' ? candidate.name.trim() : '';\n const url = typeof candidate.url === 'string' ? candidate.url.trim() : '';\n if (!name || !url) continue;\n\n const providerId = getCustomProviderId(name);\n const models = Array.isArray(candidate.models)\n ? [\n ...new Set(\n candidate.models\n .filter((model): model is string => typeof model === 'string')\n .map(model => model.trim())\n .map(model => {\n const providerPrefix = `${providerId}/`;\n if (model.startsWith(providerPrefix)) {\n return model.slice(providerPrefix.length);\n }\n return model;\n }),\n ),\n ].filter(model => model.length > 0)\n : [];\n\n const apiKey =\n typeof candidate.apiKey === 'string' && candidate.apiKey.trim().length > 0 ? candidate.apiKey.trim() : undefined;\n\n parsedProviders.push({\n name,\n url,\n ...(apiKey ? { apiKey } : {}),\n models,\n });\n }\n\n return parsedProviders;\n}\n\n/**\n * One-time migration: move model-related data from auth.json to settings.json.\n * Reads `_modelRanks`, `_modeModelId_*`, `_subagentModelId*` from auth.json,\n * merges them into settings, removes them from auth.json, and writes both files.\n * No-ops if auth.json has no _ prefixed model data.\n */\nfunction migrateFromAuth(settingsPath: string): boolean {\n const authPath = join(getAppDataDir(), 'auth.json');\n if (!existsSync(authPath)) return false;\n\n let authData: Record<string, any>;\n try {\n authData = JSON.parse(readFileSync(authPath, 'utf-8'));\n } catch {\n return false;\n }\n\n const modelKeys = Object.keys(authData).filter(k => k.startsWith('_'));\n if (modelKeys.length === 0) return false;\n\n // Load existing settings (or defaults) and merge auth data into it\n let settings: GlobalSettings;\n if (existsSync(settingsPath)) {\n try {\n const raw = JSON.parse(readFileSync(settingsPath, 'utf-8'));\n settings = {\n onboarding: { ...DEFAULTS.onboarding, ...raw.onboarding },\n models: { ...DEFAULTS.models, ...raw.models },\n preferences: parsePreferences(raw.preferences),\n storage: {\n ...STORAGE_DEFAULTS,\n ...raw.storage,\n libsql: { ...STORAGE_DEFAULTS.libsql, ...raw.storage?.libsql },\n pg: { ...STORAGE_DEFAULTS.pg, ...raw.storage?.pg },\n },\n customModelPacks: Array.isArray(raw.customModelPacks) ? raw.customModelPacks : [],\n customProviders: parseCustomProviders(raw.customProviders),\n modelUseCounts: raw.modelUseCounts && typeof raw.modelUseCounts === 'object' ? raw.modelUseCounts : {},\n updateDismissedVersion: typeof raw.updateDismissedVersion === 'string' ? raw.updateDismissedVersion : null,\n lsp: raw.lsp && typeof raw.lsp === 'object' ? (raw.lsp as LSPConfig) : undefined,\n };\n } catch {\n settings = structuredClone(DEFAULTS);\n }\n } else {\n settings = structuredClone(DEFAULTS);\n }\n\n // Migrate model use counts (only if settings doesn't already have them)\n if (authData._modelRanks && typeof authData._modelRanks === 'object') {\n settings.modelUseCounts = { ...authData._modelRanks, ...settings.modelUseCounts };\n }\n\n // Migrate per-mode model defaults (don't overwrite existing settings)\n for (const key of modelKeys) {\n const modeMatch = key.match(/^_modeModelId_(.+)$/);\n if (modeMatch?.[1] && typeof authData[key] === 'string' && !settings.models.modeDefaults[modeMatch[1]]) {\n settings.models.modeDefaults[modeMatch[1]] = authData[key];\n }\n }\n\n // Migrate subagent models (don't overwrite existing settings)\n for (const key of modelKeys) {\n if (key === '_subagentModelId' && typeof authData[key] === 'string' && !settings.models.subagentModels['default']) {\n settings.models.subagentModels['default'] = authData[key];\n }\n const saMatch = key.match(/^_subagentModelId_(.+)$/);\n if (saMatch?.[1] && typeof authData[key] === 'string' && !settings.models.subagentModels[saMatch[1]]) {\n settings.models.subagentModels[saMatch[1]] = authData[key];\n }\n }\n\n // Write migrated settings\n saveSettings(settings, settingsPath);\n\n // Clean up auth.json — remove _ prefixed keys\n for (const key of modelKeys) {\n delete authData[key];\n }\n try {\n writeFileSync(authPath, JSON.stringify(authData, null, 2), 'utf-8');\n } catch {\n // Non-fatal — settings are saved, auth cleanup can fail\n }\n\n return true;\n}\n\nconst LEGACY_VARIED_MODELS: Record<string, string> = {\n plan: 'openai/gpt-5.4',\n build: 'anthropic/claude-sonnet-4-5',\n fast: 'anthropic/claude-haiku-4-5',\n};\n\nexport function migrateLegacyVariedPack(settings: GlobalSettings): boolean {\n const legacyPackId = 'varied';\n const customPackId = 'custom:varied';\n const hasLegacyReference =\n settings.models.activeModelPackId === legacyPackId || settings.onboarding.modePackId === legacyPackId;\n\n if (!hasLegacyReference) return false;\n\n const existingIdx = settings.customModelPacks.findIndex(p => p.name === 'varied');\n if (existingIdx >= 0) {\n const existing = settings.customModelPacks[existingIdx]!;\n const modelsMatch = Object.entries(LEGACY_VARIED_MODELS).every(([k, v]) => existing.models[k] === v);\n if (!modelsMatch) {\n existing.models = { ...LEGACY_VARIED_MODELS };\n }\n } else {\n settings.customModelPacks.push({\n name: 'varied',\n models: { ...LEGACY_VARIED_MODELS },\n createdAt: new Date().toISOString(),\n });\n }\n\n if (settings.models.activeModelPackId === legacyPackId) {\n settings.models.activeModelPackId = customPackId;\n if (Object.keys(settings.models.modeDefaults).length === 0) {\n settings.models.modeDefaults = { ...LEGACY_VARIED_MODELS };\n }\n }\n\n if (settings.onboarding.modePackId === legacyPackId) {\n settings.onboarding.modePackId = customPackId;\n }\n\n return true;\n}\n\nexport function loadSettings(filePath: string = getSettingsPath()): GlobalSettings {\n // One-time migration: move model data from auth.json into settings.json\n migrateFromAuth(filePath);\n\n if (!existsSync(filePath)) return structuredClone(DEFAULTS);\n try {\n const raw = JSON.parse(readFileSync(filePath, 'utf-8'));\n // Spread raw first to preserve unknown top-level keys (forward-compatibility),\n // then overlay with parsed/typed fields so known keys are always correct.\n const settings: GlobalSettings = {\n ...raw,\n onboarding: { ...DEFAULTS.onboarding, ...raw.onboarding },\n models: { ...DEFAULTS.models, ...raw.models },\n preferences: parsePreferences(raw.preferences),\n storage: {\n ...STORAGE_DEFAULTS,\n ...raw.storage,\n libsql: { ...STORAGE_DEFAULTS.libsql, ...raw.storage?.libsql },\n pg: { ...STORAGE_DEFAULTS.pg, ...raw.storage?.pg },\n },\n customModelPacks: Array.isArray(raw.customModelPacks) ? raw.customModelPacks : [],\n customProviders: parseCustomProviders(raw.customProviders),\n modelUseCounts: raw.modelUseCounts && typeof raw.modelUseCounts === 'object' ? raw.modelUseCounts : {},\n updateDismissedVersion: typeof raw.updateDismissedVersion === 'string' ? raw.updateDismissedVersion : null,\n lsp: raw.lsp && typeof raw.lsp === 'object' ? (raw.lsp as LSPConfig) : undefined,\n };\n\n // Migrate legacy omModelId → omModelOverride\n let settingsChanged = false;\n if (raw.models?.omModelId && !settings.models.omModelOverride) {\n settings.models.omModelOverride = raw.models.omModelId;\n settingsChanged = true;\n }\n\n if (migrateLegacyVariedPack(settings)) {\n settingsChanged = true;\n }\n\n if (settingsChanged) {\n saveSettings(settings, filePath);\n }\n\n return settings;\n } catch {\n return structuredClone(DEFAULTS);\n }\n}\n\nexport const THREAD_ACTIVE_MODEL_PACK_ID_KEY = 'activeModelPackId';\n\nexport interface ThreadSettings {\n activeModelPackId: string | null;\n modeModelIds: Record<string, string>;\n}\n\nexport function parseThreadSettings(metadata: Record<string, unknown> | undefined): ThreadSettings {\n const modeModelIds: Record<string, string> = {};\n for (const [key, value] of Object.entries(metadata ?? {})) {\n const modeMatch = key.match(/^modeModelId_(.+)$/);\n if (modeMatch?.[1] && typeof value === 'string' && value.length > 0) {\n modeModelIds[modeMatch[1]] = value;\n }\n }\n\n const rawPackId = metadata?.[THREAD_ACTIVE_MODEL_PACK_ID_KEY];\n const activeModelPackId = typeof rawPackId === 'string' && rawPackId.length > 0 ? rawPackId : null;\n\n return {\n activeModelPackId,\n modeModelIds,\n };\n}\n\n/**\n * Resolve active model pack id for the current thread.\n *\n * Priority:\n * 1) explicit thread metadata activeModelPackId\n * 2) inferred from thread modeModelId_* values\n * 3) global settings.models.activeModelPackId\n */\nexport function resolveThreadActiveModelPackId(\n settings: GlobalSettings,\n builtinPacks: Array<{ id: string; models: Record<string, string> }>,\n metadata: Record<string, unknown> | undefined,\n): string | null {\n const threadSettings = parseThreadSettings(metadata);\n\n const isKnownPack = (packId: string): boolean => {\n if (packId.startsWith('custom:')) {\n const name = packId.slice('custom:'.length);\n return settings.customModelPacks.some(p => p.name === name);\n }\n return builtinPacks.some(p => p.id === packId);\n };\n\n if (threadSettings.activeModelPackId && isKnownPack(threadSettings.activeModelPackId)) {\n return threadSettings.activeModelPackId;\n }\n\n const allPacks: Array<{ id: string; models: Record<string, string> }> = [\n ...builtinPacks,\n ...settings.customModelPacks.map(p => ({ id: `custom:${p.name}`, models: p.models })),\n ];\n\n for (const pack of allPacks) {\n const packEntries = Object.entries(pack.models);\n const threadEntries = Object.keys(threadSettings.modeModelIds);\n const matches =\n packEntries.length === threadEntries.length &&\n packEntries.every(([modeId, modelId]) => threadSettings.modeModelIds[modeId] === modelId);\n if (matches) return pack.id;\n }\n\n if (settings.models.activeModelPackId && isKnownPack(settings.models.activeModelPackId)) {\n return settings.models.activeModelPackId;\n }\n\n return null;\n}\n\n/**\n * Resolve effective per-mode model defaults.\n *\n * If `activeModelPackId` is set, looks up the pack (built-in or custom) and\n * returns its models. Falls back to the explicit `modeDefaults` map.\n *\n * @param settings The loaded global settings.\n * @param builtinPacks Built-in packs for the current provider access\n * (from `getAvailableModePacks`). Pass `[]` if unavailable.\n */\nexport function resolveModelDefaults(\n settings: GlobalSettings,\n builtinPacks: Array<{ id: string; models: Record<string, string> }>,\n): Record<string, string> {\n const { activeModelPackId, modeDefaults } = settings.models;\n if (!activeModelPackId) return modeDefaults;\n\n // Custom pack: \"custom:<name>\"\n if (activeModelPackId.startsWith('custom:')) {\n const name = activeModelPackId.slice('custom:'.length);\n const pack = settings.customModelPacks.find(p => p.name === name);\n if (pack) return pack.models;\n // Custom pack was deleted — fall through to modeDefaults\n return modeDefaults;\n }\n\n // Built-in pack\n const builtin = builtinPacks.find(p => p.id === activeModelPackId);\n if (builtin) return builtin.models;\n\n // Unknown pack id — fall through\n return modeDefaults;\n}\n\n/**\n * Resolve the effective OM model ID.\n *\n * If `activeOmPackId` is set, looks up the matching OM pack and returns its\n * model. Falls back to the explicit `omModelOverride`.\n *\n * @param settings The loaded global settings.\n * @param builtinOmPacks Built-in OM packs for the current provider access\n * (from `getAvailableOmPacks`). Pass `[]` if unavailable.\n */\nexport function resolveOmModel(\n settings: GlobalSettings,\n builtinOmPacks: Array<{ id: string; modelId: string }>,\n): string | null {\n const { activeOmPackId, omModelOverride } = settings.models;\n if (!activeOmPackId) return omModelOverride;\n\n if (activeOmPackId === 'custom') return omModelOverride;\n\n const pack = builtinOmPacks.find(p => p.id === activeOmPackId);\n if (pack) return pack.modelId;\n\n // Unknown pack — fall back to override\n return omModelOverride;\n}\n\nexport function saveSettings(settings: GlobalSettings, filePath: string = getSettingsPath()): void {\n const dir = dirname(filePath);\n if (!existsSync(dir)) {\n mkdirSync(dir, { recursive: true });\n }\n writeFileSync(filePath, JSON.stringify(settings, null, 2), 'utf-8');\n}\n","/**\n * Onboarding \"packs\" — predefined model configurations for each mode.\n *\n * Each pack assigns a default model to the build, plan, and fast modes,\n * plus an OM (observational memory) model.\n */\n\n// ---------------------------------------------------------------------------\n// Types\n// ---------------------------------------------------------------------------\n\nexport interface ModePack {\n id: string;\n name: string;\n description: string;\n models: {\n build: string;\n plan: string;\n fast: string;\n };\n}\n\nexport interface OMPack {\n id: string;\n name: string;\n description: string;\n modelId: string;\n}\n\n/** How a provider is accessed: OAuth subscription, API key, or not at all. */\nexport type ProviderAccessLevel = 'oauth' | 'apikey' | false;\n\n/** Which providers the user has access to and how. */\nexport interface ProviderAccess {\n anthropic: ProviderAccessLevel;\n openai: ProviderAccessLevel;\n cerebras: ProviderAccessLevel;\n google: ProviderAccessLevel;\n deepseek: ProviderAccessLevel;\n [provider: string]: ProviderAccessLevel;\n}\n\n// ---------------------------------------------------------------------------\n// Mode Packs\n// ---------------------------------------------------------------------------\n\n/**\n * Build the list of available mode packs based on which providers the user\n * can actually reach (API key or OAuth login).\n *\n * @param savedCustomPacks Previously saved custom packs from settings.json.\n * These are inserted before the \"New Custom\" option.\n */\nexport function getAvailableModePacks(\n access: ProviderAccess,\n savedCustomPacks: Array<{ name: string; models: Record<string, string> }> = [],\n): ModePack[] {\n const packs: ModePack[] = [];\n\n const openaiCodex = 'openai/gpt-5.4';\n const openaiFast = 'openai/gpt-5.4-mini';\n const anthropicBuild = access.anthropic === 'oauth' ? 'anthropic/claude-opus-4-6' : 'anthropic/claude-sonnet-4-5';\n\n if (access.anthropic) {\n packs.push({\n id: 'anthropic',\n name: 'Anthropic',\n description:\n access.anthropic === 'oauth' ? 'All Anthropic models via Max subscription' : 'All Anthropic models via API key',\n models: {\n build: anthropicBuild,\n plan: anthropicBuild,\n fast: 'anthropic/claude-haiku-4-5',\n },\n });\n }\n\n if (access.openai) {\n packs.push({\n id: 'openai',\n name: 'OpenAI',\n description:\n access.openai === 'oauth' ? 'All OpenAI models via Codex subscription' : 'All OpenAI models via API key',\n models: {\n build: openaiCodex,\n plan: openaiCodex,\n fast: openaiFast,\n },\n });\n }\n\n // Saved custom packs — inserted before the \"New Custom\" option\n for (const cp of savedCustomPacks) {\n packs.push({\n id: `custom:${cp.name}`,\n name: cp.name,\n description: 'Saved custom pack',\n models: {\n build: cp.models.build ?? '',\n plan: cp.models.plan ?? '',\n fast: cp.models.fast ?? '',\n },\n });\n }\n\n // New Custom — always available; user picks each model individually\n const hasCustom = savedCustomPacks.length > 0;\n packs.push({\n id: 'custom',\n name: hasCustom ? 'New Custom' : 'Custom',\n description: 'Choose a model for each mode',\n models: { build: '', plan: '', fast: '' },\n });\n\n return packs;\n}\n\n// ---------------------------------------------------------------------------\n// OM Packs\n// ---------------------------------------------------------------------------\n\nexport function getAvailableOmPacks(access: ProviderAccess): OMPack[] {\n const packs: OMPack[] = [];\n\n if (access.google) {\n packs.push({\n id: 'gemini',\n name: 'Gemini Flash',\n description: access.google === 'oauth' ? 'Via Google OAuth' : 'Via Google API key',\n modelId: 'google/gemini-2.5-flash',\n });\n }\n\n if (access.anthropic) {\n packs.push({\n id: 'anthropic',\n name: 'Claude Haiku',\n description: access.anthropic === 'oauth' ? 'Via Max subscription' : 'Via Anthropic API key',\n modelId: 'anthropic/claude-haiku-4-5',\n });\n }\n\n if (access.openai) {\n packs.push({\n id: 'openai',\n name: 'OpenAI Mini',\n description: access.openai === 'oauth' ? 'Via Codex subscription' : 'Via OpenAI API key',\n modelId: 'openai/gpt-5.4-mini',\n });\n }\n\n if (access.deepseek) {\n packs.push({\n id: 'deepseek',\n name: 'DeepSeek',\n description: 'Via DeepSeek API key',\n modelId: 'deepseek/deepseek-chat',\n });\n }\n\n // Custom — always available; user picks any model\n packs.push({\n id: 'custom',\n name: 'Custom',\n description: 'Choose any available model',\n modelId: '',\n });\n\n return packs;\n}\n\n// ---------------------------------------------------------------------------\n// Current onboarding version — bump when adding new steps\n// ---------------------------------------------------------------------------\n\nexport const ONBOARDING_VERSION = 1;\n","/**\n * Theme system for the Mastra Code TUI.\n * Simplified from pi-mono's theme system.\n */\n\nimport type { MarkdownTheme, EditorTheme, SettingsListTheme, SelectListTheme } from '@mariozechner/pi-tui';\nimport chalk from 'chalk';\n\n// =============================================================================\n// Theme Mode\n// =============================================================================\n\nexport type ThemeMode = 'dark' | 'light';\n\nlet currentThemeMode: ThemeMode = 'dark';\n\nexport function getThemeMode(): ThemeMode {\n return currentThemeMode;\n}\n\n// =============================================================================\n// Mastra Brand Palette (immutable — stays constant regardless of theme)\n// =============================================================================\n\nexport const mastraBrand = {\n purple: '#7f45e0', // #b588fe brand is too washed out for terminal\n green: '#16c858', // brand green (dark mode primary)\n orange: '#fdac53',\n pink: '#ff69cc',\n blue: '#2563eb', // #6ccdfb brand is to washed out\n red: '#DC5663', // #ff4758 too intense\n yellow: '#e7e67b',\n} as const;\n\n// =============================================================================\n// Extended Color Palette (additional colors for future use)\n// =============================================================================\n\nexport const extendedColors = {\n // Teals / Cyans\n teal: '#14b8a6',\n cyan: '#06b6d4',\n lightCyan: '#22d3ee',\n // Blues\n skyBlue: '#38bdf8',\n indigo: '#6366f1',\n // Purples / Violets\n violet: '#a855f7',\n lavender: '#c084fc',\n fuchsia: '#d946ef',\n // Pinks / Roses\n rose: '#f472b6',\n coral: '#fb7185',\n // Warm Tones\n amber: '#fb923c',\n lime: '#a3e635',\n gold: '#facc15',\n // Earthy / Muted\n stone: '#a8a29e',\n warmGray: '#78716c',\n copper: '#b45309',\n} as const;\n\nexport const greens = {\n // Bright / Vivid\n emerald: '#4ade80',\n seafoam: '#34d399',\n jade: '#10b981',\n springGreen: '#00ff7f',\n neonGreen: '#50fa7b',\n // Warm Greens\n chartreuse: '#84cc16',\n lightLime: '#bef264',\n electricLime: '#caff33',\n // Cool / Deep\n aquamarine: '#2dd4bf',\n mint: '#5eead4',\n pastelMint: '#6ee7b7',\n // Forest / Muted\n forest: '#16a34a',\n deepForest: '#15803d',\n sage: '#059669',\n pine: '#047857',\n evergreen: '#065f46',\n // Neon / Electric\n neonLime: '#39ff14',\n pureGreen: '#00ff00',\n hacker: '#00ff41',\n lawnGreen: '#66ff00',\n} as const;\n\n// =============================================================================\n// Mastra Surface Palette (theme-dependent)\n// =============================================================================\n\ninterface MastraSurface {\n bg: string;\n antiGrid: string;\n elevationSm: string;\n elevationLg: string;\n hover: string;\n white: string;\n specialGray: string;\n mainGray: string;\n darkGray: string;\n borderAntiGrid: string;\n borderElevation: string;\n}\n\nconst darkSurface: MastraSurface = {\n bg: '#020202',\n antiGrid: '#0d0d0d',\n elevationSm: '#1a1a1a',\n elevationLg: '#141414',\n hover: '#262626',\n white: '#f0f0f0',\n specialGray: '#cccccc',\n mainGray: '#939393',\n darkGray: '#848484',\n borderAntiGrid: '#141414',\n borderElevation: '#1a1a1a',\n};\n\nconst lightSurface: MastraSurface = {\n bg: '#ffffff',\n antiGrid: '#eaeaea',\n elevationSm: '#ebebeb',\n elevationLg: '#f0f0f0',\n hover: '#e0e0e0',\n white: '#1a1a1a',\n specialGray: '#444444',\n mainGray: '#636363',\n darkGray: '#666666',\n borderAntiGrid: '#e5e5e5',\n borderElevation: '#e0e0e0',\n};\n\ntype MastraPalette = typeof mastraBrand & MastraSurface;\n\nfunction getSurface(): MastraSurface {\n return currentThemeMode === 'dark' ? darkSurface : lightSurface;\n}\n\n// The actual terminal background color detected via OSC 11.\n// Falls back to the surface palette bg if not detected.\nlet detectedTerminalBg: string | undefined;\n\n/** The effective background color used for contrast calculations. */\nfunction getContrastBg(): string {\n return detectedTerminalBg ?? getSurface().bg;\n}\n\n// Theme-adapted brand colors — precomputed for contrast against the actual terminal bg.\nlet adaptedBrand: Record<string, string> = {};\n\n// Theme-adapted surface colors — precomputed for contrast against the actual terminal bg.\nlet adaptedSurface: Partial<Record<string, string>> = {};\n\n// Surface keys that represent text colors (not backgrounds/borders)\nconst textSurfaceKeys: (keyof MastraSurface)[] = ['white', 'specialGray', 'mainGray', 'darkGray'];\n\n// Theme keys that are used as foreground text colors (not backgrounds/borders)\nconst textThemeKeys: (keyof ThemeColors)[] = [\n 'accent',\n 'success',\n 'error',\n 'warning',\n 'muted',\n 'dim',\n 'text',\n 'thinkingText',\n 'userMessageText',\n 'toolTitle',\n 'toolOutput',\n 'textHighlight',\n 'path',\n 'number',\n 'function',\n];\n\n// Comfortable minimum contrast for TUI body text — above WCAG AA (4.5:1) for better readability\nexport const TUI_MIN_CONTRAST = 5.5;\n\n/** Terminal width buffer applied at the framework level to prevent wrapping in nested terminals */\nexport const TERM_WIDTH_BUFFER = 3;\n/** Get the effective terminal width (matching the framework's reduced width) */\nexport const getTermWidth = () => (process.stdout.columns || 80) - TERM_WIDTH_BUFFER;\n\n/** Left indent (in spaces) applied to assistant text (Markdown body) */\nexport const CHAT_INDENT = 2;\n/** Precomputed indent string for assistant text */\nexport const CHAT_INDENT_STR = ' '.repeat(2);\n/** Left indent (in spaces) applied to user messages and tool call boxes */\nexport const BOX_INDENT = 0;\n/** Precomputed indent string for boxes */\nexport const BOX_INDENT_STR = '';\n\n// Brand accent colors (purple, blue, etc.) use standard WCAG AA to preserve vibrancy\nconst BRAND_MIN_CONTRAST = 4.5;\n\nfunction computeAdaptedColors(): void {\n const bg = getContrastBg();\n\n adaptedBrand = {};\n for (const [key, value] of Object.entries(mastraBrand)) {\n adaptedBrand[key] = ensureContrast(value, bg, BRAND_MIN_CONTRAST);\n }\n adaptedSurface = {};\n const surface = getSurface();\n for (const key of textSurfaceKeys) {\n adaptedSurface[key] = ensureContrast(surface[key], bg, TUI_MIN_CONTRAST);\n }\n\n // Adapt theme foreground colors against actual terminal bg\n const baseTheme = currentThemeMode === 'light' ? lightTheme : darkTheme;\n const adapted = { ...baseTheme };\n for (const key of textThemeKeys) {\n adapted[key] = ensureContrast(baseTheme[key], bg, TUI_MIN_CONTRAST);\n }\n currentTheme = adapted;\n}\n\n// Note: computeAdaptedColors() is called after darkTheme/lightTheme are defined (see below)\n\n/** Mastra palette — brand + text surface colors are contrast-adapted, other surface colors adapt to theme mode. */\nexport const mastra: MastraPalette = new Proxy({} as MastraPalette, {\n get(_target, prop: string) {\n if (prop in mastraBrand) {\n return adaptedBrand[prop] ?? mastraBrand[prop as keyof typeof mastraBrand];\n }\n // For text surface colors, return the contrast-adapted version\n if (prop in adaptedSurface) {\n return adaptedSurface[prop];\n }\n const surface = getSurface();\n if (prop in surface) {\n return surface[prop as keyof MastraSurface];\n }\n return undefined;\n },\n});\n\n/** Tint a hex color by a brightness factor (0–1). e.g. tintHex(\"#ff8800\", 0.15) → near-black orange */\nexport function tintHex(hex: string, factor: number): string {\n const r = Math.floor(parseInt(hex.slice(1, 3), 16) * factor);\n const g = Math.floor(parseInt(hex.slice(3, 5), 16) * factor);\n const b = Math.floor(parseInt(hex.slice(5, 7), 16) * factor);\n return `#${r.toString(16).padStart(2, '0')}${g.toString(16).padStart(2, '0')}${b.toString(16).padStart(2, '0')}`;\n}\n\n// =============================================================================\n// Theme Colors\n// =============================================================================\n\nexport type ThemeColor =\n | 'accent'\n | 'border'\n | 'borderAccent'\n | 'borderMuted'\n | 'success'\n | 'error'\n | 'warning'\n | 'muted'\n | 'dim'\n | 'text'\n | 'thinkingText'\n | 'userMessageText'\n | 'toolTitle'\n | 'toolArgs'\n | 'toolOutput'\n | 'textHighlight'\n | 'toolBorderPending'\n | 'toolBorderSuccess'\n | 'toolBorderError'\n | 'function'\n | 'path'\n | 'number';\n\nexport type ThemeBg =\n | 'selectedBg'\n | 'userMessageBg'\n | 'systemReminderBg'\n | 'toolPendingBg'\n | 'toolSuccessBg'\n | 'toolErrorBg'\n | 'overlayBg'\n | 'errorBg';\n\nexport interface ThemeColors {\n // Core UI\n accent: string;\n border: string;\n borderAccent: string;\n borderMuted: string;\n success: string;\n error: string;\n warning: string;\n muted: string;\n dim: string;\n text: string;\n thinkingText: string;\n // User messages\n userMessageBg: string;\n userMessageText: string;\n // System reminders\n systemReminderBg: string;\n // Tool execution\n toolPendingBg: string;\n toolSuccessBg: string;\n toolErrorBg: string;\n toolBorderPending: string;\n toolBorderSuccess: string;\n toolBorderError: string;\n toolTitle: string;\n toolArgs: string;\n toolOutput: string;\n textHighlight: string;\n // Selection\n selectedBg: string;\n // Overlays\n overlayBg: string;\n // Error display\n errorBg: string;\n path: string;\n number: string;\n function: string;\n}\n\n// =============================================================================\n// Dark Theme\n// =============================================================================\n\nexport const darkTheme: ThemeColors = {\n // Core UI\n accent: '#16c858', // Brand green\n border: '#3f3f46',\n borderAccent: '#16c858',\n borderMuted: '#27272a',\n success: '#22c55e',\n error: '#ef4444',\n warning: '#f59e0b',\n muted: '#8c8c94',\n dim: '#84848c',\n text: '#fafafa',\n thinkingText: '#a1a1aa',\n // User messages\n userMessageBg: '#0f172a', // Slate blue\n userMessageText: '#fafafa',\n // System reminders\n systemReminderBg: '#1a1400', // Dark orange tint\n // Tool execution\n toolPendingBg: '#0a1a10', // Dark green tint (matches brand accent)\n toolSuccessBg: '#0a1a10', // Dark green tint (same as pending)\n toolErrorBg: '#1f0a0a', // Dark red tint\n toolBorderPending: '#52525b', // Zinc-600 dim grey for pending\n toolBorderSuccess: '#52525b', // Zinc-600 dim grey for success\n toolBorderError: '#ef4444', // Red for error\n toolTitle: '#fb923c', // Amber for tool names\n toolArgs: '#ffe4c4', // Bisque (warm cream) for tool arguments\n toolOutput: '#d4d4d8',\n textHighlight: '#c084fc', // Lavender for inline code, headings, links\n // Error display\n errorBg: '#291415', // Slightly lighter than toolErrorBg for contrast\n path: '#9ca3af', // Gray for file paths\n number: '#fbbf24', // Yellow for line numbers\n function: '#60a5fa', // Light blue for function names\n // Selection\n selectedBg: darkSurface.hover,\n // Overlays\n overlayBg: darkSurface.antiGrid,\n};\n\n// =============================================================================\n// Light Theme\n// =============================================================================\n\nexport const lightTheme: ThemeColors = {\n // Core UI\n accent: '#0d8020', // Brand green (light mode)\n border: '#d4d4d8',\n borderAccent: '#0d8020',\n borderMuted: '#e4e4e7',\n success: '#15803d',\n error: '#dc2626',\n warning: '#d97706',\n muted: '#595961',\n dim: '#67676f',\n text: '#18181b',\n thinkingText: '#595961',\n // User messages\n userMessageBg: '#f0fdf4', // Light green tint\n userMessageText: '#18181b',\n // System reminders\n systemReminderBg: '#fefce8', // Light yellow\n // Tool execution\n toolPendingBg: '#f0fdf4', // Light green tint (matches brand accent)\n toolSuccessBg: '#f0fdf4', // Light green tint (same as pending)\n toolErrorBg: '#fef2f2', // Light red\n toolBorderPending: '#a1a1aa', // Zinc-400 dim grey for pending\n toolBorderSuccess: '#a1a1aa', // Zinc-400 dim grey for success\n toolBorderError: '#dc2626', // Red for error\n toolTitle: '#c2410c', // Deep amber for light backgrounds\n toolArgs: '#92400e', // Deep amber-brown for light backgrounds\n toolOutput: '#3f3f46',\n textHighlight: '#7c3aed', // Deep violet for light backgrounds\n // Error display\n errorBg: '#fef2f2', // Light red\n path: '#6b7280', // Gray for file paths\n number: '#b45309', // Amber for line numbers\n function: '#2563eb', // Blue for function names\n // Selection\n selectedBg: lightSurface.hover,\n // Overlays\n overlayBg: lightSurface.antiGrid,\n};\n\n// =============================================================================\n// Theme Instance\n// =============================================================================\n\nlet currentTheme: ThemeColors = darkTheme;\n\n// Initialize adapted colors now that darkTheme/lightTheme are defined\ncomputeAdaptedColors();\n\n/**\n * Get the current theme colors.\n */\nfunction getTheme(): ThemeColors {\n return currentTheme;\n}\n\n/**\n * Set the current theme.\n */\nfunction setTheme(colors: ThemeColors): void {\n currentTheme = colors;\n}\n\n/**\n * Apply a theme mode, updating both the surface palette and the theme colors.\n */\nexport function applyThemeMode(mode: ThemeMode, terminalBgHex?: string): void {\n currentThemeMode = mode;\n currentTheme = mode === 'light' ? lightTheme : darkTheme;\n detectedTerminalBg = terminalBgHex;\n computeAdaptedColors();\n // Set terminal default foreground via OSC 10 so unstyled text (e.g. editor input)\n // adapts to the theme. Convert hex to rgb/ format for OSC.\n if (process.stdout.isTTY) {\n const textHex = currentTheme.text;\n const r = parseInt(textHex.slice(1, 3), 16);\n const g = parseInt(textHex.slice(3, 5), 16);\n const b = parseInt(textHex.slice(5, 7), 16);\n process.stdout.write(\n `\\x1b]10;rgb:${r.toString(16).padStart(2, '0')}/${g.toString(16).padStart(2, '0')}/${b.toString(16).padStart(2, '0')}\\x07`,\n );\n }\n}\n\n/**\n * Restore terminal foreground to default. Call on exit to undo OSC 10 changes.\n */\nexport function restoreTerminalForeground(): void {\n if (process.stdout.isTTY) {\n // OSC 110 resets the terminal's default foreground to its original value.\n process.stdout.write('\\x1b]110\\x07');\n }\n}\n\n// =============================================================================\n// Theme Helper Functions\n// =============================================================================\n\n/**\n * Apply foreground color from theme.\n */\nfunction fg(color: ThemeColor, text: string): string {\n const hex = currentTheme[color];\n if (!hex) return text;\n return chalk.hex(hex)(text);\n}\n\n/**\n * Apply background color from theme.\n */\nfunction bg(color: ThemeBg, text: string): string {\n const hex = currentTheme[color];\n if (!hex) return text;\n return chalk.bgHex(hex)(text);\n}\n\n/**\n * Apply bold styling.\n */\nfunction bold(text: string): string {\n return chalk.bold(text);\n}\n\n/**\n * Apply italic styling.\n */\nfunction italic(text: string): string {\n return chalk.italic(text);\n}\n\n/**\n * Apply dim styling.\n */\nfunction dim(text: string): string {\n return chalk.dim(text);\n}\n\n// =============================================================================\n// Contrast Utilities (WCAG 2.1)\n// =============================================================================\n\n/** Convert a single sRGB channel (0–1) to linear light. */\nfunction linearize(c: number): number {\n return c <= 0.03928 ? c / 12.92 : ((c + 0.055) / 1.055) ** 2.4;\n}\n\n/** Parse a hex color string into [r, g, b] in 0–1 range. */\nfunction parseHex(hex: string): [number, number, number] {\n const h = hex.replace('#', '');\n return [parseInt(h.slice(0, 2), 16) / 255, parseInt(h.slice(2, 4), 16) / 255, parseInt(h.slice(4, 6), 16) / 255];\n}\n\n/** Convert [r, g, b] (0–255) to a hex color string. */\nfunction toHex(r: number, g: number, b: number): string {\n const clamp = (v: number) => Math.max(0, Math.min(255, Math.round(v)));\n return `#${clamp(r).toString(16).padStart(2, '0')}${clamp(g).toString(16).padStart(2, '0')}${clamp(b).toString(16).padStart(2, '0')}`;\n}\n\n/** WCAG relative luminance of a hex color. Returns 0 (black) to 1 (white). */\nexport function luminance(hex: string): number {\n const [r, g, b] = parseHex(hex);\n return 0.2126 * linearize(r) + 0.7152 * linearize(g) + 0.0722 * linearize(b);\n}\n\n/** WCAG contrast ratio between two hex colors. Returns 1 (identical) to 21 (black/white). */\nexport function contrastRatio(hex1: string, hex2: string): number {\n const l1 = luminance(hex1);\n const l2 = luminance(hex2);\n const lighter = Math.max(l1, l2);\n const darker = Math.min(l1, l2);\n return (lighter + 0.05) / (darker + 0.05);\n}\n\n/** Convert RGB (0–1) to HSL. Returns [h (0–360), s (0–1), l (0–1)]. */\nfunction rgbToHsl(r: number, g: number, b: number): [number, number, number] {\n const max = Math.max(r, g, b);\n const min = Math.min(r, g, b);\n const l = (max + min) / 2;\n if (max === min) return [0, 0, l];\n const d = max - min;\n const s = l > 0.5 ? d / (2 - max - min) : d / (max + min);\n let h = 0;\n if (max === r) h = ((g - b) / d + (g < b ? 6 : 0)) / 6;\n else if (max === g) h = ((b - r) / d + 2) / 6;\n else h = ((r - g) / d + 4) / 6;\n return [h * 360, s, l];\n}\n\n/** Convert HSL to RGB (0–1). */\nfunction hslToRgb(h: number, s: number, l: number): [number, number, number] {\n h = h / 360;\n if (s === 0) return [l, l, l];\n const hue2rgb = (p: number, q: number, t: number) => {\n if (t < 0) t += 1;\n if (t > 1) t -= 1;\n if (t < 1 / 6) return p + (q - p) * 6 * t;\n if (t < 1 / 2) return q;\n if (t < 2 / 3) return p + (q - p) * (2 / 3 - t) * 6;\n return p;\n };\n const q = l < 0.5 ? l * (1 + s) : l + s - l * s;\n const p = 2 * l - q;\n return [hue2rgb(p, q, h + 1 / 3), hue2rgb(p, q, h), hue2rgb(p, q, h - 1 / 3)];\n}\n\n/**\n * Adjust a foreground color to ensure sufficient contrast against a background.\n * Adjusts lightness in HSL space to preserve hue and saturation.\n * Returns the original color if it already has sufficient contrast.\n */\nexport function ensureContrast(fgHex: string, bgHex: string, minRatio = 4.5): string {\n if (contrastRatio(fgHex, bgHex) >= minRatio) return fgHex;\n\n const [r, g, b] = parseHex(fgHex);\n const [h, s, origL] = rgbToHsl(r, g, b);\n const origCR = contrastRatio(fgHex, bgHex);\n\n function searchDirection(lighten: boolean): { hex: string; contrast: number } {\n const targetL = lighten ? 1 : 0;\n const extreme = lighten ? '#ffffff' : '#000000';\n const extremeCR = contrastRatio(extreme, bgHex);\n if (extremeCR <= origCR) return { hex: fgHex, contrast: origCR };\n\n let lo = 0;\n let hi = 1;\n let best = fgHex;\n let bestCR = origCR;\n\n for (let i = 0; i < 20; i++) {\n const mid = (lo + hi) / 2;\n const newL = origL + (targetL - origL) * mid;\n const [nr, ng, nb] = hslToRgb(h, s, newL);\n const candidate = toHex(nr * 255, ng * 255, nb * 255);\n const cr = contrastRatio(candidate, bgHex);\n if (cr >= minRatio) {\n best = candidate;\n bestCR = cr;\n hi = mid;\n } else {\n lo = mid;\n }\n }\n\n if (bestCR < minRatio && extremeCR > bestCR) {\n // If the best hue-preserving result is reasonably close to the target,\n // keep it to preserve color identity rather than collapsing to black/white.\n if (bestCR >= minRatio * 0.65) {\n return { hex: best, contrast: bestCR };\n }\n return { hex: extreme, contrast: extremeCR };\n }\n\n return { hex: best, contrast: bestCR };\n }\n\n const whiteContrast = contrastRatio('#ffffff', bgHex);\n const blackContrast = contrastRatio('#000000', bgHex);\n const primaryLighten = whiteContrast >= blackContrast;\n\n const primaryResult = searchDirection(primaryLighten);\n if (primaryResult.contrast >= minRatio) return primaryResult.hex;\n\n const altResult = searchDirection(!primaryLighten);\n if (altResult.contrast >= minRatio) return altResult.hex;\n\n return primaryResult.contrast >= altResult.contrast ? primaryResult.hex : altResult.hex;\n}\n\n/**\n * Returns \"#ffffff\" or \"#000000\" depending on which has better contrast\n * against the given hex background color (WCAG relative luminance).\n */\nexport function getContrastText(hexBg: string): string {\n return luminance(hexBg) > 0.179 ? '#000000' : '#ffffff';\n}\n\n// =============================================================================\n// Theme Object\n// =============================================================================\n\nexport const theme = {\n fg,\n bg,\n bold,\n italic,\n dim,\n getTheme,\n setTheme,\n};\n\n// =============================================================================\n// Markdown Theme (for pi-tui Markdown component)\n// =============================================================================\n\nexport function getMarkdownTheme(): MarkdownTheme {\n const t = getTheme();\n return {\n heading: (text: string) => chalk.hex(t.textHighlight).bold(text),\n link: (text: string) => chalk.hex(t.textHighlight)(text),\n linkUrl: (text: string) => chalk.hex(t.muted)(text),\n code: (text: string) => chalk.hex(t.textHighlight).bold(text),\n codeBlock: (text: string) => chalk.hex(t.text)(text),\n codeBlockBorder: (text: string) => chalk.hex(t.dim)(text),\n quote: (text: string) => chalk.hex(t.muted).italic(text),\n quoteBorder: (text: string) => chalk.hex(t.borderMuted)(text),\n hr: (text: string) => chalk.hex(t.borderMuted)(text),\n listBullet: (text: string) => chalk.hex(t.textHighlight)(text),\n // Required by MarkdownTheme interface\n bold: (text: string) => chalk.bold(text),\n italic: (text: string) => chalk.italic(text),\n strikethrough: (text: string) => chalk.strikethrough(text),\n underline: (text: string) => chalk.underline(text),\n };\n}\n\n// =============================================================================\n// Editor Theme (for pi-tui Editor component)\n// =============================================================================\n\nexport function getEditorTheme(): EditorTheme {\n const t = getTheme();\n return {\n borderColor: (text: string) => chalk.hex(getContrastBg())(text),\n selectList: {\n selectedPrefix: (text: string) => chalk.hex(t.accent)(text),\n selectedText: (text: string) => chalk.bgHex(t.selectedBg)(text),\n description: (text: string) => chalk.hex(t.muted)(text),\n scrollInfo: (text: string) => chalk.hex(t.dim)(text),\n noMatch: (text: string) => chalk.hex(t.muted)(text),\n },\n };\n}\n\n// =============================================================================\n// Settings List Theme (for pi-tui SettingsList component)\n// =============================================================================\n\nexport function getSettingsListTheme(): SettingsListTheme {\n const t = getTheme();\n return {\n label: (text: string, selected: boolean) => (selected ? chalk.hex(t.text).bold(text) : chalk.hex(t.muted)(text)),\n value: (text: string, selected: boolean) => (selected ? chalk.hex(t.accent)(text) : chalk.hex(t.dim)(text)),\n description: (text: string) => chalk.hex(t.muted).italic(text),\n cursor: chalk.hex(t.accent)('→ '),\n hint: (text: string) => chalk.hex(t.dim)(text),\n };\n}\n\nexport function getSelectListTheme(): SelectListTheme {\n const t = getTheme();\n return {\n selectedPrefix: (text: string) => chalk.hex(t.accent)(text),\n selectedText: (text: string) => chalk.bgHex(t.selectedBg)(text),\n description: (text: string) => chalk.hex(t.muted)(text),\n scrollInfo: (text: string) => chalk.hex(t.dim)(text),\n noMatch: (text: string) => chalk.hex(t.muted)(text),\n };\n}\n","/**\n * Thread lock — ensures only one process writes to a thread at a time.\n *\n * Uses filesystem lock files: <appDataDir>/locks/<threadId>.lock\n * Each lock file contains the PID of the owning process.\n * Stale locks (from crashed processes) are detected and reclaimed.\n */\nimport * as fs from 'node:fs';\nimport * as path from 'node:path';\nimport { getAppDataDir } from './project.js';\n\nexport class ThreadLockError extends Error {\n constructor(\n public readonly threadId: string,\n public readonly ownerPid: number,\n ) {\n super(`Thread ${threadId} is locked by another process (PID ${ownerPid})`);\n this.name = 'ThreadLockError';\n }\n}\n\nfunction getLocksDir(): string {\n const dir = path.join(getAppDataDir(), 'locks');\n if (!fs.existsSync(dir)) {\n fs.mkdirSync(dir, { recursive: true });\n }\n return dir;\n}\n\nfunction getLockPath(threadId: string): string {\n // Sanitize thread ID for filesystem safety\n const safeId = threadId.replace(/[^a-zA-Z0-9_-]/g, '_');\n return path.join(getLocksDir(), `${safeId}.lock`);\n}\n\nfunction isProcessAlive(pid: number): boolean {\n try {\n process.kill(pid, 0);\n return true;\n } catch {\n return false;\n }\n}\n\n/**\n * Attempt to acquire a lock for the given thread.\n * Throws ThreadLockError if another live process holds the lock.\n * Reclaims stale locks from dead processes.\n */\nexport function acquireThreadLock(threadId: string): void {\n const lockPath = getLockPath(threadId);\n const myPid = process.pid;\n\n // Check for existing lock\n if (fs.existsSync(lockPath)) {\n try {\n const content = fs.readFileSync(lockPath, 'utf-8').trim();\n const ownerPid = parseInt(content, 10);\n\n if (!isNaN(ownerPid) && ownerPid !== myPid && isProcessAlive(ownerPid)) {\n throw new ThreadLockError(threadId, ownerPid);\n }\n // Stale lock (dead process) or our own lock — reclaim it\n } catch (error) {\n if (error instanceof ThreadLockError) throw error;\n // File read error — try to overwrite\n }\n }\n\n // Write our PID to the lock file\n fs.writeFileSync(lockPath, String(myPid), { mode: 0o644 });\n}\n\n/**\n * Release the lock for the given thread (only if we own it).\n */\nexport function releaseThreadLock(threadId: string): void {\n const lockPath = getLockPath(threadId);\n const myPid = process.pid;\n\n try {\n if (!fs.existsSync(lockPath)) return;\n\n const content = fs.readFileSync(lockPath, 'utf-8').trim();\n const ownerPid = parseInt(content, 10);\n\n // Only remove if we own it\n if (ownerPid === myPid) {\n fs.unlinkSync(lockPath);\n }\n } catch {\n // Best-effort cleanup — ignore errors\n }\n}\n\n/**\n * Check if a thread is locked by another process.\n * Returns the PID of the owner if locked, null otherwise.\n */\nexport function getThreadLockOwner(threadId: string): number | null {\n const lockPath = getLockPath(threadId);\n\n try {\n if (!fs.existsSync(lockPath)) return null;\n\n const content = fs.readFileSync(lockPath, 'utf-8').trim();\n const ownerPid = parseInt(content, 10);\n\n if (isNaN(ownerPid)) return null;\n if (ownerPid === process.pid) return null; // Our own lock\n if (!isProcessAlive(ownerPid)) {\n // Stale lock — clean it up\n try {\n fs.unlinkSync(lockPath);\n } catch {}\n return null;\n }\n\n return ownerPid;\n } catch {\n return null;\n }\n}\n\n/**\n * Release all thread locks owned by this process.\n * Call this on process exit.\n */\nexport function releaseAllThreadLocks(): void {\n try {\n const locksDir = getLocksDir();\n const files = fs.readdirSync(locksDir);\n const myPid = String(process.pid);\n\n for (const file of files) {\n if (!file.endsWith('.lock')) continue;\n const lockPath = path.join(locksDir, file);\n try {\n const content = fs.readFileSync(lockPath, 'utf-8').trim();\n if (content === myPid) {\n fs.unlinkSync(lockPath);\n }\n } catch {\n // Best-effort\n }\n }\n } catch {\n // Best-effort\n }\n}\n"]}
@@ -1,5 +1,5 @@
1
- import { theme, mastra, getMarkdownTheme, CHAT_INDENT, BOX_INDENT, getTermWidth, TERM_WIDTH_BUFFER, getEditorTheme, loadSettings, getAvailableModePacks, resolveThreadActiveModelPackId, saveSettings, getAvailableOmPacks, ONBOARDING_VERSION, THREAD_ACTIVE_MODEL_PACK_ID_KEY, tintHex, BOX_INDENT_STR, ThreadLockError, getSelectListTheme, luminance, ensureContrast, getThemeMode, applyThemeMode, getCustomProviderId, getSettingsListTheme, toCustomProviderModelId } from './chunk-UUS7G74S.js';
2
- import { getOAuthProviders, detectProject, getUserId, getCurrentGitBranch, getAppDataDir, PROVIDER_DEFAULT_MODELS } from './chunk-GTRZ4DPO.js';
1
+ import { theme, mastra, getMarkdownTheme, CHAT_INDENT, BOX_INDENT, getTermWidth, TERM_WIDTH_BUFFER, getEditorTheme, loadSettings, getAvailableModePacks, resolveThreadActiveModelPackId, saveSettings, getAvailableOmPacks, ONBOARDING_VERSION, THREAD_ACTIVE_MODEL_PACK_ID_KEY, tintHex, BOX_INDENT_STR, ThreadLockError, getSelectListTheme, luminance, ensureContrast, getThemeMode, applyThemeMode, getCustomProviderId, getSettingsListTheme, toCustomProviderModelId } from './chunk-7I6PTSCL.js';
2
+ import { getOAuthProviders, detectProject, getUserId, getCurrentGitBranch, getAppDataDir, PROVIDER_DEFAULT_MODELS } from './chunk-YIBXRSXL.js';
3
3
  import { MC_TOOLS, getToolCategory, TOOL_CATEGORIES } from './chunk-MS5RYNRK.js';
4
4
  import { exec, spawn, execFile, execSync, execFileSync } from 'child_process';
5
5
  import { Box, Text, Spacer, Input, Container, fuzzyFilter, getEditorKeybindings, Markdown, ProcessTerminal, TUI, visibleWidth, Editor, matchesKey, CombinedAutocompleteProvider, SelectList, wrapTextWithAnsi, SettingsList, isKeyRelease } from '@mariozechner/pi-tui';
@@ -17,9 +17,6 @@ import { parse } from 'partial-json';
17
17
  import * as yaml from 'js-yaml';
18
18
  import stripAnsi2 from 'strip-ansi';
19
19
 
20
- // src/auth/claude-max-warning.ts
21
- var ANTHROPIC_OAUTH_PROVIDER_ID = "anthropic";
22
- var CLAUDE_MAX_OAUTH_WARNING_MESSAGE = "OAuth with a Claude Max plan is a grey area. Anthropic has reportedly banned users for using Claude max credentials outside of Claude Code, and it may violate Anthropic Terms of Service. Proceed at your own risk.";
23
20
  var AskQuestionBorderedBox = class {
24
21
  questionLines;
25
22
  selectList;
@@ -410,8 +407,6 @@ var OnboardingInlineComponent = class extends Container {
410
407
  return this.renderWelcome();
411
408
  case "auth":
412
409
  return this.renderAuth();
413
- case "claudeMaxWarning":
414
- return this.renderClaudeMaxWarning();
415
410
  case "modePack":
416
411
  return this.renderModePack();
417
412
  case "omPack":
@@ -493,8 +488,6 @@ var OnboardingInlineComponent = class extends Container {
493
488
  this.selectList.onSelect = (item) => {
494
489
  if (item.value === "__skip") {
495
490
  this.renderStep("modePack");
496
- } else if (item.value === ANTHROPIC_OAUTH_PROVIDER_ID) {
497
- this.renderStep("claudeMaxWarning");
498
491
  } else {
499
492
  this.loginRequested = true;
500
493
  this.loginProvider = item.value;
@@ -511,38 +504,6 @@ var OnboardingInlineComponent = class extends Container {
511
504
  box.addChild(new Text(theme.fg("dim", "\u2191\u2193 navigate \xB7 Enter select \xB7 Esc skip"), 0, 0));
512
505
  }
513
506
  // ---------------------------------------------------------------------------
514
- // Step: Claude Max OAuth Warning
515
- // ---------------------------------------------------------------------------
516
- renderClaudeMaxWarning() {
517
- const box = this.makeBox();
518
- box.addChild(new Text(theme.bold(theme.fg("warning", "\u26A0 Claude Max OAuth Warning")), 0, 0));
519
- box.addChild(new Spacer(1));
520
- box.addChild(new Text(theme.fg("text", CLAUDE_MAX_OAUTH_WARNING_MESSAGE), 0, 0));
521
- box.addChild(new Spacer(1));
522
- const items = [
523
- { value: "continue", label: ` ${theme.fg("success", "Continue")}` },
524
- { value: "cancel", label: ` ${theme.fg("dim", "Cancel")}` }
525
- ];
526
- this.selectList = new SelectList(items, items.length, getSelectListTheme());
527
- this.selectList.onSelect = (item) => {
528
- if (item.value === "continue") {
529
- this.loginRequested = true;
530
- this.loginProvider = ANTHROPIC_OAUTH_PROVIDER_ID;
531
- this.options.onLogin(ANTHROPIC_OAUTH_PROVIDER_ID, () => {
532
- this.renderStep("modePack");
533
- });
534
- } else {
535
- this.renderStep("auth");
536
- }
537
- };
538
- this.selectList.onCancel = () => {
539
- this.renderStep("auth");
540
- };
541
- box.addChild(this.selectList);
542
- box.addChild(new Spacer(1));
543
- box.addChild(new Text(theme.fg("dim", "\u2191\u2193 navigate \xB7 Enter select \xB7 Esc go back"), 0, 0));
544
- }
545
- // ---------------------------------------------------------------------------
546
507
  // Step: Mode pack
547
508
  // ---------------------------------------------------------------------------
548
509
  /** Text component showing details for the currently highlighted mode pack. */
@@ -899,7 +860,7 @@ function getInstallCommand(pm, version) {
899
860
  }
900
861
  function getCurrentVersion() {
901
862
  {
902
- return "0.9.2-alpha.2";
863
+ return "0.9.2-alpha.4";
903
864
  }
904
865
  }
905
866
  async function fetchLatestVersion() {
@@ -947,45 +908,6 @@ function buildInstallArgs(pm, version) {
947
908
  return ["install", "-g", pkg];
948
909
  }
949
910
  }
950
- function showClaudeMaxOAuthWarning(state, mode) {
951
- const options = mode === "login" ? [
952
- { label: "Continue", description: "Proceed with Anthropic OAuth" },
953
- { label: "Cancel", description: "Go back" }
954
- ] : [
955
- { label: "Continue", description: "Keep Anthropic OAuth credentials" },
956
- { label: "Remove OAuth", description: "Log out from Anthropic" }
957
- ];
958
- return new Promise((resolve3) => {
959
- const questionComponent = new AskQuestionInlineComponent(
960
- {
961
- question: CLAUDE_MAX_OAUTH_WARNING_MESSAGE,
962
- options,
963
- formatResult: (answer) => `Claude Max OAuth warning \u2192 ${answer}`,
964
- isNegativeAnswer: (answer) => answer !== "Continue",
965
- onSubmit: (answer) => {
966
- state.activeInlineQuestion = void 0;
967
- if (answer === "Continue") {
968
- resolve3("continue");
969
- } else if (answer === "Cancel") {
970
- resolve3("cancel");
971
- } else {
972
- resolve3("remove");
973
- }
974
- },
975
- onCancel: () => {
976
- state.activeInlineQuestion = void 0;
977
- resolve3("cancel");
978
- }
979
- },
980
- state.ui
981
- );
982
- state.activeInlineQuestion = questionComponent;
983
- state.chatContainer.addChild(questionComponent);
984
- state.chatContainer.addChild(new Spacer(1));
985
- state.ui.requestRender();
986
- state.chatContainer.invalidate();
987
- });
988
- }
989
911
  async function processSlashCommand(command, args, workingDir) {
990
912
  const { result: withArgs, shouldAppendRawArgs } = replaceArguments(command.template, args);
991
913
  let result = withArgs;
@@ -5639,15 +5561,6 @@ async function performLogin(ctx, providerId) {
5639
5561
  ctx.showError("Auth storage not configured");
5640
5562
  return;
5641
5563
  }
5642
- if (providerId === ANTHROPIC_OAUTH_PROVIDER_ID) {
5643
- const warningResult = await showClaudeMaxOAuthWarning(ctx.state, "login");
5644
- if (warningResult !== "continue") {
5645
- return;
5646
- }
5647
- const settings = loadSettings();
5648
- settings.onboarding.claudeMaxOAuthWarningAcknowledgedAt = (/* @__PURE__ */ new Date()).toISOString();
5649
- saveSettings(settings);
5650
- }
5651
5564
  return new Promise((resolve3) => {
5652
5565
  const dialog = new LoginDialogComponent(ctx.state.ui, providerId, (success, message) => {
5653
5566
  ctx.state.ui.hideOverlay();
@@ -11612,7 +11525,6 @@ var MastraTUI = class _MastraTUI {
11612
11525
  updateTerminalTitle(this.state);
11613
11526
  await renderExistingMessages(this.state);
11614
11527
  await renderExistingTasks(this.state);
11615
- await this.checkClaudeMaxOAuthWarning();
11616
11528
  if (this.shouldShowOnboarding()) {
11617
11529
  await this.showOnboarding();
11618
11530
  }
@@ -11805,26 +11717,6 @@ var MastraTUI = class _MastraTUI {
11805
11717
  };
11806
11718
  });
11807
11719
  }
11808
- /**
11809
- * One-time startup check: if the user has Anthropic OAuth credentials and
11810
- * hasn't yet acknowledged the Claude Max ToS warning, show it now.
11811
- */
11812
- async checkClaudeMaxOAuthWarning() {
11813
- const authStorage = this.state.authStorage;
11814
- if (!authStorage || !authStorage.isLoggedIn(ANTHROPIC_OAUTH_PROVIDER_ID)) return;
11815
- const settings = loadSettings();
11816
- if (settings.onboarding.claudeMaxOAuthWarningAcknowledgedAt) return;
11817
- const result = await showClaudeMaxOAuthWarning(this.state, "startup");
11818
- if (result === "continue") {
11819
- settings.onboarding.claudeMaxOAuthWarningAcknowledgedAt = (/* @__PURE__ */ new Date()).toISOString();
11820
- saveSettings(settings);
11821
- } else if (result === "remove") {
11822
- authStorage.logout(ANTHROPIC_OAUTH_PROVIDER_ID);
11823
- settings.onboarding.claudeMaxOAuthWarningAcknowledgedAt = (/* @__PURE__ */ new Date()).toISOString();
11824
- saveSettings(settings);
11825
- await this.refreshModelAuthStatus();
11826
- }
11827
- }
11828
11720
  /**
11829
11721
  * Get the workspace, preferring harness-owned workspace over the direct option.
11830
11722
  */
@@ -11919,7 +11811,7 @@ var MastraTUI = class _MastraTUI {
11919
11811
  signal: dialog.signal
11920
11812
  }).then(async () => {
11921
11813
  this.state.ui.hideOverlay();
11922
- const { PROVIDER_DEFAULT_MODELS: PROVIDER_DEFAULT_MODELS2 } = await import('./storage-R76IXKUI.js');
11814
+ const { PROVIDER_DEFAULT_MODELS: PROVIDER_DEFAULT_MODELS2 } = await import('./storage-T6AFSPIY.js');
11923
11815
  const defaultModel = PROVIDER_DEFAULT_MODELS2[providerId];
11924
11816
  if (defaultModel) {
11925
11817
  await this.state.harness.switchModel({ modelId: defaultModel });
@@ -11985,11 +11877,6 @@ var MastraTUI = class _MastraTUI {
11985
11877
  resolve3();
11986
11878
  },
11987
11879
  onLogin: (providerId, done) => {
11988
- if (providerId === ANTHROPIC_OAUTH_PROVIDER_ID) {
11989
- const s = loadSettings();
11990
- s.onboarding.claudeMaxOAuthWarningAcknowledgedAt = (/* @__PURE__ */ new Date()).toISOString();
11991
- saveSettings(s);
11992
- }
11993
11880
  this.performLogin(providerId).then(async () => {
11994
11881
  try {
11995
11882
  const updatedAccess = await this.buildProviderAccess();
@@ -12275,5 +12162,5 @@ var LoginSelectorComponent = class extends Box {
12275
12162
  };
12276
12163
 
12277
12164
  export { AssistantMessageComponent, LoginDialogComponent, LoginSelectorComponent, MastraTUI, ModelSelectorComponent, OMProgressComponent, ToolExecutionComponentEnhanced, UserMessageComponent, createTUIState, detectTerminalTheme, formatOMStatus, getCurrentVersion };
12278
- //# sourceMappingURL=chunk-REEH5DEO.js.map
12279
- //# sourceMappingURL=chunk-REEH5DEO.js.map
12165
+ //# sourceMappingURL=chunk-HFH7M2ET.js.map
12166
+ //# sourceMappingURL=chunk-HFH7M2ET.js.map