@aituber-onair/chat 0.36.0 → 0.37.0

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/README.ja.md CHANGED
@@ -534,9 +534,9 @@ const geminiService = ChatServiceFactory.createChatService('gemini', {
534
534
  `gemini-3.1-flash-lite` が推奨の安定版 Flash-Lite モデルです。
535
535
  現在の安定版 Flash モデルとして `gemini-3.5-flash` も利用できます。
536
536
  `gemini-3.1-flash-lite-preview`、`gemini-3-pro-preview`、
537
- `gemini-2.0-flash`、`gemini-2.0-flash-lite` などの preview /
538
- shutdown 予定モデルは後方互換のため明示的な model string では利用できますが、
539
- 本番用途では新しいモデルへ移行してください。
537
+ `gemini-2.5-flash-lite-preview-06-17` などの preview / deprecated
538
+ モデルは後方互換のため明示的な model string では利用できますが、本番用途では
539
+ 新しいモデルへ移行してください。
540
540
 
541
541
  チャット用途では、`gemini-3.5-flash` に対して Gemini の
542
542
  `thinkingConfig`(`thinkingLevel: 'MINIMAL'`、`includeThoughts: false`)を
@@ -1009,7 +1009,7 @@ console.log(modelLevel); // 'unknown'
1009
1009
 
1010
1010
  - **OpenAI**: GPT-5.5、GPT-5.4 Pro、GPT-5.4、GPT-5.4 Mini、GPT-5.4 Nano、GPT-5.1、GPT-5(Nano/Mini/Standard)、GPT-4.1(miniとnanoを含む), GPT-4, GPT-4o-mini, O3-mini, o1, o1-miniのモデルをサポート
1011
1011
  - **OpenAI-Compatible**: OpenAI互換 endpoint 経由で任意のローカル/セルフホスト model ID を利用できます。vision 対応可否は endpoint ごとに差があるため、原則 `unknown` 扱いです
1012
- - **Gemini**: Gemini 3.5 Flash、Gemini 3.1 Flash-Lite、Gemini 3.1 Pro Preview、Gemini 3 Flash Preview、Gemini 2.5 Pro、Gemini 2.5 Flash、Gemini 2.5 Flash Lite、Gemma 4 31B IT、Gemma 4 26B A4B IT などの推奨モデルをサポート。Gemini 3.5 Flash はチャット用途向けに minimal thinking を自動適用します。Gemini 3.1 Flash-Lite Preview、Gemini 3 Pro Preview、Gemini 2.0 Flash、Gemini 2.0 Flash-Lite などの lifecycle 上 deprecated なモデルは明示指定用に export を残していますが、shutdown 前に移行してください
1012
+ - **Gemini**: Gemini 3.5 Flash、Gemini 3.1 Flash-Lite、Gemini 3.1 Pro Preview、Gemini 3 Flash Preview、Gemini 2.5 Pro、Gemini 2.5 Flash、Gemini 2.5 Flash Lite、Gemma 4 31B IT、Gemma 4 26B A4B IT などの推奨モデルをサポート。Gemini 3.5 Flash はチャット用途向けに minimal thinking を自動適用します。Gemini 3.1 Flash-Lite Preview、Gemini 3 Pro Preview、Gemini 2.5 Flash Lite Preview などの lifecycle 上 deprecated なモデルは明示指定用に export を残しています
1013
1013
  - **Claude**: Claude Opus 4.8, Claude Opus 4.7, Claude Opus 4.6, Claude Opus 4.5, Claude Sonnet 4.6, Claude Sonnet 4.5, Claude Haiku 4.5 に加え、まだ利用可能だが非推奨の Claude 4 Opus, Claude 4 Sonnet, Claude 3 Haiku をサポート
1014
1014
  - **OpenRouter**: OpenRouterのキュレーション済みモデル一覧(OpenAI/Claude/Gemini/Z.ai/Kimi)をサポート。モデルIDはOpenRouter節を参照してください
1015
1015
  - **Z.ai**: GLM-5/GLM-5-Turbo(テキスト)、GLM-4.7/4.6(テキスト)、GLM-4.6V系(ビジョン)をサポート
package/README.md CHANGED
@@ -548,11 +548,10 @@ const geminiService = ChatServiceFactory.createChatService('gemini', {
548
548
 
549
549
  `gemini-3.1-flash-lite` is the recommended stable Flash-Lite model. Deprecated
550
550
  preview and shutdown-scheduled models such as `gemini-3.1-flash-lite-preview`,
551
- `gemini-3-pro-preview`, `gemini-2.0-flash`, and
552
- `gemini-2.0-flash-lite` remain usable by explicit model string for backward
553
- compatibility, but are no longer advertised in the standard supported-model
554
- list for production use. `gemini-3.5-flash` is also available as the current
555
- stable Flash model.
551
+ `gemini-3-pro-preview`, and `gemini-2.5-flash-lite-preview-06-17` remain usable
552
+ by explicit model string for backward compatibility, but are no longer
553
+ advertised in the standard supported-model list for production use.
554
+ `gemini-3.5-flash` is also available as the current stable Flash model.
556
555
 
557
556
  For chat-style usage, `gemini-3.5-flash` automatically sends Gemini
558
557
  `thinkingConfig` with `thinkingLevel: 'MINIMAL'` and `includeThoughts: false`.
@@ -1025,7 +1024,7 @@ Currently, the following AI providers are built-in:
1025
1024
 
1026
1025
  - **OpenAI**: Supports models like GPT-5.5, GPT-5.4 Pro, GPT-5.4, GPT-5.4 Mini, GPT-5.4 Nano, GPT-5.1, GPT-5 (Nano/Mini/Standard), GPT-4.1 (including mini and nano), GPT-4, GPT-4o-mini, O3-mini, o1, o1-mini
1027
1026
  - **OpenAI-Compatible**: Supports arbitrary local/self-hosted model IDs via OpenAI-compatible endpoints. Vision capability is treated as `unknown` unless your app knows the endpoint-specific model catalog.
1028
- - **Gemini**: Supports recommended models like Gemini 3.5 Flash, Gemini 3.1 Flash-Lite, Gemini 3.1 Pro Preview, Gemini 3 Flash Preview, Gemini 2.5 Pro, Gemini 2.5 Flash, Gemini 2.5 Flash Lite, Gemma 4 31B IT, and Gemma 4 26B A4B IT. Gemini 3.5 Flash automatically uses minimal thinking for chat-style responses. Deprecated lifecycle models such as Gemini 3.1 Flash-Lite Preview, Gemini 3 Pro Preview, Gemini 2.0 Flash, and Gemini 2.0 Flash-Lite remain exported for explicit use, but should be migrated before shutdown.
1027
+ - **Gemini**: Supports recommended models like Gemini 3.5 Flash, Gemini 3.1 Flash-Lite, Gemini 3.1 Pro Preview, Gemini 3 Flash Preview, Gemini 2.5 Pro, Gemini 2.5 Flash, Gemini 2.5 Flash Lite, Gemma 4 31B IT, and Gemma 4 26B A4B IT. Gemini 3.5 Flash automatically uses minimal thinking for chat-style responses. Deprecated lifecycle models such as Gemini 3.1 Flash-Lite Preview, Gemini 3 Pro Preview, and Gemini 2.5 Flash Lite Preview remain exported for explicit use.
1029
1028
  - **Claude**: Supports current Claude API model IDs including Claude Opus 4.8, Claude Opus 4.7, Claude Opus 4.6, Claude Opus 4.5, Claude Sonnet 4.6, Claude Sonnet 4.5, Claude Haiku 4.5, plus deprecated-but-still-available Claude 4 Opus, Claude 4 Sonnet, and Claude 3 Haiku
1030
1029
  - **OpenRouter**: Supports a curated OpenRouter model list (OpenAI/Claude/Gemini/Z.ai/Kimi). See the OpenRouter section for model IDs.
1031
1030
  - **Z.ai**: Supports GLM-5/GLM-5-Turbo (text), GLM-4.7/4.6 (text), and GLM-4.6V family (vision)
@@ -14,13 +14,6 @@ export declare const MODEL_GEMINI_2_5_FLASH = "gemini-2.5-flash";
14
14
  export declare const MODEL_GEMINI_2_5_FLASH_LITE = "gemini-2.5-flash-lite";
15
15
  /** @deprecated Use MODEL_GEMINI_3_1_FLASH_LITE instead. */
16
16
  export declare const MODEL_GEMINI_2_5_FLASH_LITE_PREVIEW_06_17 = "gemini-2.5-flash-lite-preview-06-17";
17
- /** @deprecated Use MODEL_GEMINI_2_5_FLASH instead. */
18
- export declare const MODEL_GEMINI_2_0_FLASH = "gemini-2.0-flash";
19
- /**
20
- * @deprecated Use MODEL_GEMINI_3_1_FLASH_LITE or
21
- * MODEL_GEMINI_2_5_FLASH_LITE instead.
22
- */
23
- export declare const MODEL_GEMINI_2_0_FLASH_LITE = "gemini-2.0-flash-lite";
24
17
  export declare const GEMINI_RECOMMENDED_MODELS: string[];
25
18
  export declare const GEMINI_DEPRECATED_MODELS: string[];
26
19
  export declare const GEMINI_VISION_SUPPORTED_MODELS: string[];
@@ -1 +1 @@
1
- {"version":3,"file":"gemini.d.ts","sourceRoot":"","sources":["../../../src/constants/gemini.ts"],"names":[],"mappings":"AACA,eAAO,MAAM,mBAAmB,8CAA8C,CAAC;AAG/E,eAAO,MAAM,oBAAoB,mBAAmB,CAAC;AACrD,eAAO,MAAM,wBAAwB,uBAAuB,CAAC;AAC7D,eAAO,MAAM,sBAAsB,qBAAqB,CAAC;AACzD,eAAO,MAAM,4BAA4B,2BAA2B,CAAC;AACrE,eAAO,MAAM,2BAA2B,0BAA0B,CAAC;AACnE,2DAA2D;AAC3D,eAAO,MAAM,mCAAmC,kCACf,CAAC;AAClC,4DAA4D;AAC5D,eAAO,MAAM,0BAA0B,yBAAyB,CAAC;AACjE,eAAO,MAAM,4BAA4B,2BAA2B,CAAC;AACrE,eAAO,MAAM,oBAAoB,mBAAmB,CAAC;AACrD,eAAO,MAAM,sBAAsB,qBAAqB,CAAC;AACzD,eAAO,MAAM,2BAA2B,0BAA0B,CAAC;AACnE,2DAA2D;AAC3D,eAAO,MAAM,yCAAyC,wCACf,CAAC;AACxC,sDAAsD;AACtD,eAAO,MAAM,sBAAsB,qBAAqB,CAAC;AACzD;;;GAGG;AACH,eAAO,MAAM,2BAA2B,0BAA0B,CAAC;AAEnE,eAAO,MAAM,yBAAyB,UAUrC,CAAC;AAEF,eAAO,MAAM,wBAAwB,UAMpC,CAAC;AAIF,eAAO,MAAM,8BAA8B,UAG1C,CAAC"}
1
+ {"version":3,"file":"gemini.d.ts","sourceRoot":"","sources":["../../../src/constants/gemini.ts"],"names":[],"mappings":"AACA,eAAO,MAAM,mBAAmB,8CAA8C,CAAC;AAG/E,eAAO,MAAM,oBAAoB,mBAAmB,CAAC;AACrD,eAAO,MAAM,wBAAwB,uBAAuB,CAAC;AAC7D,eAAO,MAAM,sBAAsB,qBAAqB,CAAC;AACzD,eAAO,MAAM,4BAA4B,2BAA2B,CAAC;AACrE,eAAO,MAAM,2BAA2B,0BAA0B,CAAC;AACnE,2DAA2D;AAC3D,eAAO,MAAM,mCAAmC,kCACf,CAAC;AAClC,4DAA4D;AAC5D,eAAO,MAAM,0BAA0B,yBAAyB,CAAC;AACjE,eAAO,MAAM,4BAA4B,2BAA2B,CAAC;AACrE,eAAO,MAAM,oBAAoB,mBAAmB,CAAC;AACrD,eAAO,MAAM,sBAAsB,qBAAqB,CAAC;AACzD,eAAO,MAAM,2BAA2B,0BAA0B,CAAC;AACnE,2DAA2D;AAC3D,eAAO,MAAM,yCAAyC,wCACf,CAAC;AAExC,eAAO,MAAM,yBAAyB,UAUrC,CAAC;AAEF,eAAO,MAAM,wBAAwB,UAIpC,CAAC;AAIF,eAAO,MAAM,8BAA8B,UAG1C,CAAC"}
@@ -1,6 +1,6 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.GEMINI_VISION_SUPPORTED_MODELS = exports.GEMINI_DEPRECATED_MODELS = exports.GEMINI_RECOMMENDED_MODELS = exports.MODEL_GEMINI_2_0_FLASH_LITE = exports.MODEL_GEMINI_2_0_FLASH = exports.MODEL_GEMINI_2_5_FLASH_LITE_PREVIEW_06_17 = exports.MODEL_GEMINI_2_5_FLASH_LITE = exports.MODEL_GEMINI_2_5_FLASH = exports.MODEL_GEMINI_2_5_PRO = exports.MODEL_GEMINI_3_FLASH_PREVIEW = exports.MODEL_GEMINI_3_PRO_PREVIEW = exports.MODEL_GEMINI_3_1_FLASH_LITE_PREVIEW = exports.MODEL_GEMINI_3_1_FLASH_LITE = exports.MODEL_GEMINI_3_1_PRO_PREVIEW = exports.MODEL_GEMINI_3_5_FLASH = exports.MODEL_GEMMA_4_26B_A4B_IT = exports.MODEL_GEMMA_4_31B_IT = exports.ENDPOINT_GEMINI_API = void 0;
3
+ exports.GEMINI_VISION_SUPPORTED_MODELS = exports.GEMINI_DEPRECATED_MODELS = exports.GEMINI_RECOMMENDED_MODELS = exports.MODEL_GEMINI_2_5_FLASH_LITE_PREVIEW_06_17 = exports.MODEL_GEMINI_2_5_FLASH_LITE = exports.MODEL_GEMINI_2_5_FLASH = exports.MODEL_GEMINI_2_5_PRO = exports.MODEL_GEMINI_3_FLASH_PREVIEW = exports.MODEL_GEMINI_3_PRO_PREVIEW = exports.MODEL_GEMINI_3_1_FLASH_LITE_PREVIEW = exports.MODEL_GEMINI_3_1_FLASH_LITE = exports.MODEL_GEMINI_3_1_PRO_PREVIEW = exports.MODEL_GEMINI_3_5_FLASH = exports.MODEL_GEMMA_4_26B_A4B_IT = exports.MODEL_GEMMA_4_31B_IT = exports.ENDPOINT_GEMINI_API = void 0;
4
4
  // API Endpoints
5
5
  exports.ENDPOINT_GEMINI_API = 'https://generativelanguage.googleapis.com';
6
6
  // Gemini / Gemma models
@@ -19,13 +19,6 @@ exports.MODEL_GEMINI_2_5_FLASH = 'gemini-2.5-flash';
19
19
  exports.MODEL_GEMINI_2_5_FLASH_LITE = 'gemini-2.5-flash-lite';
20
20
  /** @deprecated Use MODEL_GEMINI_3_1_FLASH_LITE instead. */
21
21
  exports.MODEL_GEMINI_2_5_FLASH_LITE_PREVIEW_06_17 = 'gemini-2.5-flash-lite-preview-06-17';
22
- /** @deprecated Use MODEL_GEMINI_2_5_FLASH instead. */
23
- exports.MODEL_GEMINI_2_0_FLASH = 'gemini-2.0-flash';
24
- /**
25
- * @deprecated Use MODEL_GEMINI_3_1_FLASH_LITE or
26
- * MODEL_GEMINI_2_5_FLASH_LITE instead.
27
- */
28
- exports.MODEL_GEMINI_2_0_FLASH_LITE = 'gemini-2.0-flash-lite';
29
22
  exports.GEMINI_RECOMMENDED_MODELS = [
30
23
  exports.MODEL_GEMINI_3_5_FLASH,
31
24
  exports.MODEL_GEMINI_3_1_FLASH_LITE,
@@ -41,8 +34,6 @@ exports.GEMINI_DEPRECATED_MODELS = [
41
34
  exports.MODEL_GEMINI_3_1_FLASH_LITE_PREVIEW,
42
35
  exports.MODEL_GEMINI_3_PRO_PREVIEW,
43
36
  exports.MODEL_GEMINI_2_5_FLASH_LITE_PREVIEW_06_17,
44
- exports.MODEL_GEMINI_2_0_FLASH,
45
- exports.MODEL_GEMINI_2_0_FLASH_LITE,
46
37
  ];
47
38
  // Vision support for Gemini models. Deprecated entries remain for explicit
48
39
  // model-string compatibility, but are omitted from recommended model lists.
@@ -1 +1 @@
1
- {"version":3,"file":"gemini.js","sourceRoot":"","sources":["../../../src/constants/gemini.ts"],"names":[],"mappings":";;;AAAA,gBAAgB;AACH,QAAA,mBAAmB,GAAG,2CAA2C,CAAC;AAE/E,wBAAwB;AACX,QAAA,oBAAoB,GAAG,gBAAgB,CAAC;AACxC,QAAA,wBAAwB,GAAG,oBAAoB,CAAC;AAChD,QAAA,sBAAsB,GAAG,kBAAkB,CAAC;AAC5C,QAAA,4BAA4B,GAAG,wBAAwB,CAAC;AACxD,QAAA,2BAA2B,GAAG,uBAAuB,CAAC;AACnE,2DAA2D;AAC9C,QAAA,mCAAmC,GAC9C,+BAA+B,CAAC;AAClC,4DAA4D;AAC/C,QAAA,0BAA0B,GAAG,sBAAsB,CAAC;AACpD,QAAA,4BAA4B,GAAG,wBAAwB,CAAC;AACxD,QAAA,oBAAoB,GAAG,gBAAgB,CAAC;AACxC,QAAA,sBAAsB,GAAG,kBAAkB,CAAC;AAC5C,QAAA,2BAA2B,GAAG,uBAAuB,CAAC;AACnE,2DAA2D;AAC9C,QAAA,yCAAyC,GACpD,qCAAqC,CAAC;AACxC,sDAAsD;AACzC,QAAA,sBAAsB,GAAG,kBAAkB,CAAC;AACzD;;;GAGG;AACU,QAAA,2BAA2B,GAAG,uBAAuB,CAAC;AAEtD,QAAA,yBAAyB,GAAG;IACvC,8BAAsB;IACtB,mCAA2B;IAC3B,oCAA4B;IAC5B,oCAA4B;IAC5B,4BAAoB;IACpB,8BAAsB;IACtB,mCAA2B;IAC3B,4BAAoB;IACpB,gCAAwB;CACzB,CAAC;AAEW,QAAA,wBAAwB,GAAG;IACtC,2CAAmC;IACnC,kCAA0B;IAC1B,iDAAyC;IACzC,8BAAsB;IACtB,mCAA2B;CAC5B,CAAC;AAEF,2EAA2E;AAC3E,4EAA4E;AAC/D,QAAA,8BAA8B,GAAG;IAC5C,GAAG,iCAAyB;IAC5B,GAAG,gCAAwB;CAC5B,CAAC"}
1
+ {"version":3,"file":"gemini.js","sourceRoot":"","sources":["../../../src/constants/gemini.ts"],"names":[],"mappings":";;;AAAA,gBAAgB;AACH,QAAA,mBAAmB,GAAG,2CAA2C,CAAC;AAE/E,wBAAwB;AACX,QAAA,oBAAoB,GAAG,gBAAgB,CAAC;AACxC,QAAA,wBAAwB,GAAG,oBAAoB,CAAC;AAChD,QAAA,sBAAsB,GAAG,kBAAkB,CAAC;AAC5C,QAAA,4BAA4B,GAAG,wBAAwB,CAAC;AACxD,QAAA,2BAA2B,GAAG,uBAAuB,CAAC;AACnE,2DAA2D;AAC9C,QAAA,mCAAmC,GAC9C,+BAA+B,CAAC;AAClC,4DAA4D;AAC/C,QAAA,0BAA0B,GAAG,sBAAsB,CAAC;AACpD,QAAA,4BAA4B,GAAG,wBAAwB,CAAC;AACxD,QAAA,oBAAoB,GAAG,gBAAgB,CAAC;AACxC,QAAA,sBAAsB,GAAG,kBAAkB,CAAC;AAC5C,QAAA,2BAA2B,GAAG,uBAAuB,CAAC;AACnE,2DAA2D;AAC9C,QAAA,yCAAyC,GACpD,qCAAqC,CAAC;AAE3B,QAAA,yBAAyB,GAAG;IACvC,8BAAsB;IACtB,mCAA2B;IAC3B,oCAA4B;IAC5B,oCAA4B;IAC5B,4BAAoB;IACpB,8BAAsB;IACtB,mCAA2B;IAC3B,4BAAoB;IACpB,gCAAwB;CACzB,CAAC;AAEW,QAAA,wBAAwB,GAAG;IACtC,2CAAmC;IACnC,kCAA0B;IAC1B,iDAAyC;CAC1C,CAAC;AAEF,2EAA2E;AAC3E,4EAA4E;AAC/D,QAAA,8BAA8B,GAAG;IAC5C,GAAG,iCAAyB;IAC5B,GAAG,gCAAwB;CAC5B,CAAC"}
@@ -14,13 +14,6 @@ export declare const MODEL_GEMINI_2_5_FLASH = "gemini-2.5-flash";
14
14
  export declare const MODEL_GEMINI_2_5_FLASH_LITE = "gemini-2.5-flash-lite";
15
15
  /** @deprecated Use MODEL_GEMINI_3_1_FLASH_LITE instead. */
16
16
  export declare const MODEL_GEMINI_2_5_FLASH_LITE_PREVIEW_06_17 = "gemini-2.5-flash-lite-preview-06-17";
17
- /** @deprecated Use MODEL_GEMINI_2_5_FLASH instead. */
18
- export declare const MODEL_GEMINI_2_0_FLASH = "gemini-2.0-flash";
19
- /**
20
- * @deprecated Use MODEL_GEMINI_3_1_FLASH_LITE or
21
- * MODEL_GEMINI_2_5_FLASH_LITE instead.
22
- */
23
- export declare const MODEL_GEMINI_2_0_FLASH_LITE = "gemini-2.0-flash-lite";
24
17
  export declare const GEMINI_RECOMMENDED_MODELS: string[];
25
18
  export declare const GEMINI_DEPRECATED_MODELS: string[];
26
19
  export declare const GEMINI_VISION_SUPPORTED_MODELS: string[];
@@ -1 +1 @@
1
- {"version":3,"file":"gemini.d.ts","sourceRoot":"","sources":["../../../src/constants/gemini.ts"],"names":[],"mappings":"AACA,eAAO,MAAM,mBAAmB,8CAA8C,CAAC;AAG/E,eAAO,MAAM,oBAAoB,mBAAmB,CAAC;AACrD,eAAO,MAAM,wBAAwB,uBAAuB,CAAC;AAC7D,eAAO,MAAM,sBAAsB,qBAAqB,CAAC;AACzD,eAAO,MAAM,4BAA4B,2BAA2B,CAAC;AACrE,eAAO,MAAM,2BAA2B,0BAA0B,CAAC;AACnE,2DAA2D;AAC3D,eAAO,MAAM,mCAAmC,kCACf,CAAC;AAClC,4DAA4D;AAC5D,eAAO,MAAM,0BAA0B,yBAAyB,CAAC;AACjE,eAAO,MAAM,4BAA4B,2BAA2B,CAAC;AACrE,eAAO,MAAM,oBAAoB,mBAAmB,CAAC;AACrD,eAAO,MAAM,sBAAsB,qBAAqB,CAAC;AACzD,eAAO,MAAM,2BAA2B,0BAA0B,CAAC;AACnE,2DAA2D;AAC3D,eAAO,MAAM,yCAAyC,wCACf,CAAC;AACxC,sDAAsD;AACtD,eAAO,MAAM,sBAAsB,qBAAqB,CAAC;AACzD;;;GAGG;AACH,eAAO,MAAM,2BAA2B,0BAA0B,CAAC;AAEnE,eAAO,MAAM,yBAAyB,UAUrC,CAAC;AAEF,eAAO,MAAM,wBAAwB,UAMpC,CAAC;AAIF,eAAO,MAAM,8BAA8B,UAG1C,CAAC"}
1
+ {"version":3,"file":"gemini.d.ts","sourceRoot":"","sources":["../../../src/constants/gemini.ts"],"names":[],"mappings":"AACA,eAAO,MAAM,mBAAmB,8CAA8C,CAAC;AAG/E,eAAO,MAAM,oBAAoB,mBAAmB,CAAC;AACrD,eAAO,MAAM,wBAAwB,uBAAuB,CAAC;AAC7D,eAAO,MAAM,sBAAsB,qBAAqB,CAAC;AACzD,eAAO,MAAM,4BAA4B,2BAA2B,CAAC;AACrE,eAAO,MAAM,2BAA2B,0BAA0B,CAAC;AACnE,2DAA2D;AAC3D,eAAO,MAAM,mCAAmC,kCACf,CAAC;AAClC,4DAA4D;AAC5D,eAAO,MAAM,0BAA0B,yBAAyB,CAAC;AACjE,eAAO,MAAM,4BAA4B,2BAA2B,CAAC;AACrE,eAAO,MAAM,oBAAoB,mBAAmB,CAAC;AACrD,eAAO,MAAM,sBAAsB,qBAAqB,CAAC;AACzD,eAAO,MAAM,2BAA2B,0BAA0B,CAAC;AACnE,2DAA2D;AAC3D,eAAO,MAAM,yCAAyC,wCACf,CAAC;AAExC,eAAO,MAAM,yBAAyB,UAUrC,CAAC;AAEF,eAAO,MAAM,wBAAwB,UAIpC,CAAC;AAIF,eAAO,MAAM,8BAA8B,UAG1C,CAAC"}
@@ -16,13 +16,6 @@ export const MODEL_GEMINI_2_5_FLASH = 'gemini-2.5-flash';
16
16
  export const MODEL_GEMINI_2_5_FLASH_LITE = 'gemini-2.5-flash-lite';
17
17
  /** @deprecated Use MODEL_GEMINI_3_1_FLASH_LITE instead. */
18
18
  export const MODEL_GEMINI_2_5_FLASH_LITE_PREVIEW_06_17 = 'gemini-2.5-flash-lite-preview-06-17';
19
- /** @deprecated Use MODEL_GEMINI_2_5_FLASH instead. */
20
- export const MODEL_GEMINI_2_0_FLASH = 'gemini-2.0-flash';
21
- /**
22
- * @deprecated Use MODEL_GEMINI_3_1_FLASH_LITE or
23
- * MODEL_GEMINI_2_5_FLASH_LITE instead.
24
- */
25
- export const MODEL_GEMINI_2_0_FLASH_LITE = 'gemini-2.0-flash-lite';
26
19
  export const GEMINI_RECOMMENDED_MODELS = [
27
20
  MODEL_GEMINI_3_5_FLASH,
28
21
  MODEL_GEMINI_3_1_FLASH_LITE,
@@ -38,8 +31,6 @@ export const GEMINI_DEPRECATED_MODELS = [
38
31
  MODEL_GEMINI_3_1_FLASH_LITE_PREVIEW,
39
32
  MODEL_GEMINI_3_PRO_PREVIEW,
40
33
  MODEL_GEMINI_2_5_FLASH_LITE_PREVIEW_06_17,
41
- MODEL_GEMINI_2_0_FLASH,
42
- MODEL_GEMINI_2_0_FLASH_LITE,
43
34
  ];
44
35
  // Vision support for Gemini models. Deprecated entries remain for explicit
45
36
  // model-string compatibility, but are omitted from recommended model lists.
@@ -1 +1 @@
1
- {"version":3,"file":"gemini.js","sourceRoot":"","sources":["../../../src/constants/gemini.ts"],"names":[],"mappings":"AAAA,gBAAgB;AAChB,MAAM,CAAC,MAAM,mBAAmB,GAAG,2CAA2C,CAAC;AAE/E,wBAAwB;AACxB,MAAM,CAAC,MAAM,oBAAoB,GAAG,gBAAgB,CAAC;AACrD,MAAM,CAAC,MAAM,wBAAwB,GAAG,oBAAoB,CAAC;AAC7D,MAAM,CAAC,MAAM,sBAAsB,GAAG,kBAAkB,CAAC;AACzD,MAAM,CAAC,MAAM,4BAA4B,GAAG,wBAAwB,CAAC;AACrE,MAAM,CAAC,MAAM,2BAA2B,GAAG,uBAAuB,CAAC;AACnE,2DAA2D;AAC3D,MAAM,CAAC,MAAM,mCAAmC,GAC9C,+BAA+B,CAAC;AAClC,4DAA4D;AAC5D,MAAM,CAAC,MAAM,0BAA0B,GAAG,sBAAsB,CAAC;AACjE,MAAM,CAAC,MAAM,4BAA4B,GAAG,wBAAwB,CAAC;AACrE,MAAM,CAAC,MAAM,oBAAoB,GAAG,gBAAgB,CAAC;AACrD,MAAM,CAAC,MAAM,sBAAsB,GAAG,kBAAkB,CAAC;AACzD,MAAM,CAAC,MAAM,2BAA2B,GAAG,uBAAuB,CAAC;AACnE,2DAA2D;AAC3D,MAAM,CAAC,MAAM,yCAAyC,GACpD,qCAAqC,CAAC;AACxC,sDAAsD;AACtD,MAAM,CAAC,MAAM,sBAAsB,GAAG,kBAAkB,CAAC;AACzD;;;GAGG;AACH,MAAM,CAAC,MAAM,2BAA2B,GAAG,uBAAuB,CAAC;AAEnE,MAAM,CAAC,MAAM,yBAAyB,GAAG;IACvC,sBAAsB;IACtB,2BAA2B;IAC3B,4BAA4B;IAC5B,4BAA4B;IAC5B,oBAAoB;IACpB,sBAAsB;IACtB,2BAA2B;IAC3B,oBAAoB;IACpB,wBAAwB;CACzB,CAAC;AAEF,MAAM,CAAC,MAAM,wBAAwB,GAAG;IACtC,mCAAmC;IACnC,0BAA0B;IAC1B,yCAAyC;IACzC,sBAAsB;IACtB,2BAA2B;CAC5B,CAAC;AAEF,2EAA2E;AAC3E,4EAA4E;AAC5E,MAAM,CAAC,MAAM,8BAA8B,GAAG;IAC5C,GAAG,yBAAyB;IAC5B,GAAG,wBAAwB;CAC5B,CAAC"}
1
+ {"version":3,"file":"gemini.js","sourceRoot":"","sources":["../../../src/constants/gemini.ts"],"names":[],"mappings":"AAAA,gBAAgB;AAChB,MAAM,CAAC,MAAM,mBAAmB,GAAG,2CAA2C,CAAC;AAE/E,wBAAwB;AACxB,MAAM,CAAC,MAAM,oBAAoB,GAAG,gBAAgB,CAAC;AACrD,MAAM,CAAC,MAAM,wBAAwB,GAAG,oBAAoB,CAAC;AAC7D,MAAM,CAAC,MAAM,sBAAsB,GAAG,kBAAkB,CAAC;AACzD,MAAM,CAAC,MAAM,4BAA4B,GAAG,wBAAwB,CAAC;AACrE,MAAM,CAAC,MAAM,2BAA2B,GAAG,uBAAuB,CAAC;AACnE,2DAA2D;AAC3D,MAAM,CAAC,MAAM,mCAAmC,GAC9C,+BAA+B,CAAC;AAClC,4DAA4D;AAC5D,MAAM,CAAC,MAAM,0BAA0B,GAAG,sBAAsB,CAAC;AACjE,MAAM,CAAC,MAAM,4BAA4B,GAAG,wBAAwB,CAAC;AACrE,MAAM,CAAC,MAAM,oBAAoB,GAAG,gBAAgB,CAAC;AACrD,MAAM,CAAC,MAAM,sBAAsB,GAAG,kBAAkB,CAAC;AACzD,MAAM,CAAC,MAAM,2BAA2B,GAAG,uBAAuB,CAAC;AACnE,2DAA2D;AAC3D,MAAM,CAAC,MAAM,yCAAyC,GACpD,qCAAqC,CAAC;AAExC,MAAM,CAAC,MAAM,yBAAyB,GAAG;IACvC,sBAAsB;IACtB,2BAA2B;IAC3B,4BAA4B;IAC5B,4BAA4B;IAC5B,oBAAoB;IACpB,sBAAsB;IACtB,2BAA2B;IAC3B,oBAAoB;IACpB,wBAAwB;CACzB,CAAC;AAEF,MAAM,CAAC,MAAM,wBAAwB,GAAG;IACtC,mCAAmC;IACnC,0BAA0B;IAC1B,yCAAyC;CAC1C,CAAC;AAEF,2EAA2E;AAC3E,4EAA4E;AAC5E,MAAM,CAAC,MAAM,8BAA8B,GAAG;IAC5C,GAAG,yBAAyB;IAC5B,GAAG,wBAAwB;CAC5B,CAAC"}
@@ -91,8 +91,6 @@ var AITuberOnAirChat = (() => {
91
91
  MODEL_DEEPSEEK_REASONER: () => MODEL_DEEPSEEK_REASONER,
92
92
  MODEL_DEEPSEEK_V4_FLASH: () => MODEL_DEEPSEEK_V4_FLASH,
93
93
  MODEL_DEEPSEEK_V4_PRO: () => MODEL_DEEPSEEK_V4_PRO,
94
- MODEL_GEMINI_2_0_FLASH: () => MODEL_GEMINI_2_0_FLASH,
95
- MODEL_GEMINI_2_0_FLASH_LITE: () => MODEL_GEMINI_2_0_FLASH_LITE,
96
94
  MODEL_GEMINI_2_5_FLASH: () => MODEL_GEMINI_2_5_FLASH,
97
95
  MODEL_GEMINI_2_5_FLASH_LITE: () => MODEL_GEMINI_2_5_FLASH_LITE,
98
96
  MODEL_GEMINI_2_5_FLASH_LITE_PREVIEW_06_17: () => MODEL_GEMINI_2_5_FLASH_LITE_PREVIEW_06_17,
@@ -308,8 +306,6 @@ var AITuberOnAirChat = (() => {
308
306
  var MODEL_GEMINI_2_5_FLASH = "gemini-2.5-flash";
309
307
  var MODEL_GEMINI_2_5_FLASH_LITE = "gemini-2.5-flash-lite";
310
308
  var MODEL_GEMINI_2_5_FLASH_LITE_PREVIEW_06_17 = "gemini-2.5-flash-lite-preview-06-17";
311
- var MODEL_GEMINI_2_0_FLASH = "gemini-2.0-flash";
312
- var MODEL_GEMINI_2_0_FLASH_LITE = "gemini-2.0-flash-lite";
313
309
  var GEMINI_RECOMMENDED_MODELS = [
314
310
  MODEL_GEMINI_3_5_FLASH,
315
311
  MODEL_GEMINI_3_1_FLASH_LITE,
@@ -324,9 +320,7 @@ var AITuberOnAirChat = (() => {
324
320
  var GEMINI_DEPRECATED_MODELS = [
325
321
  MODEL_GEMINI_3_1_FLASH_LITE_PREVIEW,
326
322
  MODEL_GEMINI_3_PRO_PREVIEW,
327
- MODEL_GEMINI_2_5_FLASH_LITE_PREVIEW_06_17,
328
- MODEL_GEMINI_2_0_FLASH,
329
- MODEL_GEMINI_2_0_FLASH_LITE
323
+ MODEL_GEMINI_2_5_FLASH_LITE_PREVIEW_06_17
330
324
  ];
331
325
  var GEMINI_VISION_SUPPORTED_MODELS = [
332
326
  ...GEMINI_RECOMMENDED_MODELS,
@@ -1,4 +1,4 @@
1
- "use strict";var AITuberOnAirChat=(()=>{var Ft=Object.defineProperty;var vi=Object.getOwnPropertyDescriptor;var Oi=Object.getOwnPropertyNames;var Ei=Object.prototype.hasOwnProperty;var Si=(r,e)=>{for(var t in e)Ft(r,t,{get:e[t],enumerable:!0})},Ci=(r,e,t,o)=>{if(e&&typeof e=="object"||typeof e=="function")for(let i of Oi(e))!Ei.call(r,i)&&i!==t&&Ft(r,i,{get:()=>e[i],enumerable:!(o=vi(e,i))||o.enumerable});return r};var Ti=r=>Ci(Ft({},"__esModule",{value:!0}),r);var ar={};Si(ar,{CHAT_RESPONSE_LENGTH:()=>C,CLAUDE_VISION_SUPPORTED_MODELS:()=>Re,ChatServiceFactory:()=>xe,ChatServiceHttpClient:()=>_,ClaudeChatService:()=>pe,ClaudeChatServiceProvider:()=>ce,DEEPSEEK_API_BASE_URL:()=>Ko,DEEPSEEK_DEPRECATED_MODELS:()=>Di,DEEPSEEK_SUPPORTED_MODELS:()=>lo,DEFAULT_MAX_TOKENS:()=>fo,DEFAULT_SUMMARY_PROMPT_TEMPLATE:()=>bi,DEFAULT_VISION_PROMPT:()=>Ri,DeepSeekChatService:()=>ue,DeepSeekChatServiceProvider:()=>he,EMOTION_TAG_CLEANUP_REGEX:()=>Oo,EMOTION_TAG_REGEX:()=>Xo,ENDPOINT_CLAUDE_API:()=>Xt,ENDPOINT_DEEPSEEK_CHAT_COMPLETIONS_API:()=>Ve,ENDPOINT_GEMINI_API:()=>zt,ENDPOINT_KIMI_CHAT_COMPLETIONS_API:()=>ne,ENDPOINT_MISTRAL_CHAT_COMPLETIONS_API:()=>Ge,ENDPOINT_OPENAI_CHAT_COMPLETIONS_API:()=>K,ENDPOINT_OPENAI_RESPONSES_API:()=>D,ENDPOINT_OPENROUTER_API:()=>be,ENDPOINT_XAI_CHAT_COMPLETIONS_API:()=>we,ENDPOINT_ZAI_CHAT_COMPLETIONS_API:()=>Ne,EmotionParser:()=>le,GEMINI_DEPRECATED_MODELS:()=>Go,GEMINI_NANO_MAX_CONTEXT_MESSAGES:()=>vo,GEMINI_RECOMMENDED_MODELS:()=>$e,GEMINI_VISION_SUPPORTED_MODELS:()=>De,GPT5_PRESETS:()=>Mo,GPT_5_MODELS:()=>To,GeminiChatService:()=>me,GeminiChatServiceProvider:()=>de,GeminiNanoChatService:()=>ge,GeminiNanoChatServiceProvider:()=>_e,HttpError:()=>H,KIMI_VISION_SUPPORTED_MODELS:()=>Ho,KimiChatService:()=>fe,KimiChatServiceProvider:()=>Me,MAX_TOKENS_BY_LENGTH:()=>Nt,MISTRAL_API_BASE_URL:()=>jo,MISTRAL_REASONING_EFFORT_SUPPORTED_MODELS:()=>qo,MISTRAL_SUPPORTED_MODELS:()=>mo,MISTRAL_VISION_SUPPORTED_MODELS:()=>zo,MODEL_ANTHROPIC_CLAUDE_3_5_SONNET:()=>Zt,MODEL_ANTHROPIC_CLAUDE_3_7_SONNET:()=>Mt,MODEL_ANTHROPIC_CLAUDE_4_5_HAIKU:()=>vt,MODEL_ANTHROPIC_CLAUDE_HAIKU_LATEST:()=>gt,MODEL_ANTHROPIC_CLAUDE_OPUS_4:()=>_t,MODEL_ANTHROPIC_CLAUDE_SONNET_4:()=>ft,MODEL_ANTHROPIC_CLAUDE_SONNET_LATEST:()=>dt,MODEL_CLAUDE_3_5_HAIKU:()=>yi,MODEL_CLAUDE_3_5_SONNET:()=>Li,MODEL_CLAUDE_3_7_SONNET:()=>Pi,MODEL_CLAUDE_3_HAIKU:()=>je,MODEL_CLAUDE_4_5_HAIKU:()=>R,MODEL_CLAUDE_4_5_OPUS:()=>Je,MODEL_CLAUDE_4_5_SONNET:()=>Xe,MODEL_CLAUDE_4_6_OPUS:()=>Ye,MODEL_CLAUDE_4_6_SONNET:()=>Ze,MODEL_CLAUDE_4_7_OPUS:()=>Qe,MODEL_CLAUDE_4_8_OPUS:()=>et,MODEL_CLAUDE_4_OPUS:()=>ze,MODEL_CLAUDE_4_SONNET:()=>qe,MODEL_DEEPSEEK_CHAT:()=>Wo,MODEL_DEEPSEEK_REASONER:()=>$o,MODEL_DEEPSEEK_V4_FLASH:()=>ae,MODEL_DEEPSEEK_V4_PRO:()=>Bo,MODEL_GEMINI_2_0_FLASH:()=>wo,MODEL_GEMINI_2_0_FLASH_LITE:()=>Vo,MODEL_GEMINI_2_5_FLASH:()=>Ro,MODEL_GEMINI_2_5_FLASH_LITE:()=>bo,MODEL_GEMINI_2_5_FLASH_LITE_PREVIEW_06_17:()=>No,MODEL_GEMINI_2_5_PRO:()=>Do,MODEL_GEMINI_3_1_FLASH_LITE:()=>X,MODEL_GEMINI_3_1_FLASH_LITE_PREVIEW:()=>Io,MODEL_GEMINI_3_1_PRO_PREVIEW:()=>Po,MODEL_GEMINI_3_5_FLASH:()=>We,MODEL_GEMINI_3_FLASH_PREVIEW:()=>Ao,MODEL_GEMINI_3_PRO_PREVIEW:()=>xo,MODEL_GEMINI_NANO:()=>Y,MODEL_GEMMA_4_26B_A4B_IT:()=>Lo,MODEL_GEMMA_4_31B_IT:()=>yo,MODEL_GLM_4_6:()=>so,MODEL_GLM_4_6V:()=>Lt,MODEL_GLM_4_6V_FLASH:()=>Z,MODEL_GLM_4_6V_FLASHX:()=>Pt,MODEL_GLM_4_7:()=>oe,MODEL_GLM_4_7_FLASH:()=>no,MODEL_GLM_4_7_FLASHX:()=>ro,MODEL_GLM_5:()=>oo,MODEL_GLM_5_TURBO:()=>io,MODEL_GOOGLE_GEMINI_2_5_FLASH:()=>Ct,MODEL_GOOGLE_GEMINI_2_5_FLASH_LITE_PREVIEW_09_2025:()=>Tt,MODEL_GOOGLE_GEMINI_2_5_PRO:()=>St,MODEL_GOOGLE_GEMINI_FLASH_LATEST:()=>Et,MODEL_GOOGLE_GEMINI_PRO_LATEST:()=>Ot,MODEL_GPT_4O:()=>Be,MODEL_GPT_4O_MINI:()=>q,MODEL_GPT_4_1:()=>Ue,MODEL_GPT_4_1_MINI:()=>He,MODEL_GPT_4_1_NANO:()=>Ke,MODEL_GPT_5:()=>ee,MODEL_GPT_5_1:()=>W,MODEL_GPT_5_4:()=>G,MODEL_GPT_5_4_MINI:()=>$,MODEL_GPT_5_4_NANO:()=>j,MODEL_GPT_5_4_PRO:()=>F,MODEL_GPT_5_5:()=>k,MODEL_GPT_5_MINI:()=>Q,MODEL_GPT_5_NANO:()=>B,MODEL_GPT_OSS_20B_FREE:()=>U,MODEL_GROK_4_1_FAST_NON_REASONING:()=>N,MODEL_GROK_4_1_FAST_REASONING:()=>Dt,MODEL_GROK_4_20_NON_REASONING:()=>At,MODEL_GROK_4_20_REASONING:()=>xt,MODEL_GROK_4_3:()=>It,MODEL_KIMI_K2_5:()=>Rt,MODEL_KIMI_K2_6:()=>w,MODEL_MISTRAL_LARGE_2512:()=>ho,MODEL_MISTRAL_LARGE_LATEST:()=>uo,MODEL_MISTRAL_MEDIUM_2508:()=>co,MODEL_MISTRAL_MEDIUM_3_5:()=>bt,MODEL_MISTRAL_SMALL_2603:()=>po,MODEL_MISTRAL_SMALL_LATEST:()=>V,MODEL_MOONSHOTAI_KIMI_K2_5:()=>tt,MODEL_MOONSHOTAI_KIMI_LATEST:()=>ot,MODEL_O1:()=>Kt,MODEL_O1_MINI:()=>Ht,MODEL_O3_MINI:()=>Ut,MODEL_OPENAI_GPT_4O:()=>ut,MODEL_OPENAI_GPT_4_1_MINI:()=>ht,MODEL_OPENAI_GPT_4_1_NANO:()=>mt,MODEL_OPENAI_GPT_5_1_CHAT:()=>at,MODEL_OPENAI_GPT_5_1_CODEX:()=>lt,MODEL_OPENAI_GPT_5_5:()=>st,MODEL_OPENAI_GPT_5_5_PRO:()=>nt,MODEL_OPENAI_GPT_5_MINI:()=>pt,MODEL_OPENAI_GPT_5_NANO:()=>ct,MODEL_OPENAI_GPT_LATEST:()=>it,MODEL_OPENAI_GPT_MINI_LATEST:()=>rt,MODEL_OPENROUTER_AUTO:()=>Jt,MODEL_ZAI_GLM_4_5_AIR:()=>Qt,MODEL_ZAI_GLM_4_5_AIR_FREE:()=>yt,MODEL_ZAI_GLM_4_7_FLASH:()=>Yt,MistralChatService:()=>ve,MistralChatServiceProvider:()=>Oe,OPENROUTER_CREDITS_THRESHOLD:()=>Ai,OPENROUTER_FREE_DAILY_LIMIT_HIGH_CREDITS:()=>xi,OPENROUTER_FREE_DAILY_LIMIT_LOW_CREDITS:()=>Ii,OPENROUTER_FREE_MODELS:()=>eo,OPENROUTER_FREE_RATE_LIMIT_PER_MINUTE:()=>to,OPENROUTER_VISION_SUPPORTED_MODELS:()=>ko,OpenAIChatService:()=>y,OpenAIChatServiceProvider:()=>Se,OpenAICompatibleChatServiceProvider:()=>Ee,OpenRouterChatService:()=>Ce,OpenRouterChatServiceProvider:()=>Te,StreamTextAccumulator:()=>M,VISION_SUPPORTED_MODELS:()=>Ae,XAIChatService:()=>ye,XAIChatServiceProvider:()=>Le,XAI_VISION_SUPPORTED_MODELS:()=>Uo,ZAIChatService:()=>Pe,ZAIChatServiceProvider:()=>Ie,ZAI_VISION_SUPPORTED_MODELS:()=>Fo,allowsReasoningLow:()=>qt,allowsReasoningMinimal:()=>jt,allowsReasoningNone:()=>$t,allowsReasoningXHigh:()=>Wt,buildOpenAICompatibleTools:()=>x,getDefaultReasoningEffortForGPT5Model:()=>b,getMaxTokensForResponseLength:()=>E,installGASFetch:()=>_i,isGPT5Model:()=>z,isKimiVisionModel:()=>se,isMistralReasoningEffort:()=>go,isMistralReasoningEffortModel:()=>ke,isMistralVisionModel:()=>_o,isOpenRouterFreeModel:()=>J,isOpenRouterVisionModel:()=>te,isResponsesOnlyGPT5Model:()=>Bt,isXaiVisionModel:()=>re,isZaiToolStreamModel:()=>ao,isZaiVisionModel:()=>ie,parseOpenAICompatibleOneShot:()=>I,parseOpenAICompatibleTextStream:()=>L,parseOpenAICompatibleToolStream:()=>P,processChatWithOptionalTools:()=>f,refreshOpenRouterFreeModels:()=>qi,resolveVisionModel:()=>O,runOnceText:()=>Gi,screenplayToText:()=>Vi,textToScreenplay:()=>Jo,textsToScreenplay:()=>wi});var K="https://api.openai.com/v1/chat/completions",D="https://api.openai.com/v1/responses",B="gpt-5-nano",Q="gpt-5-mini",ee="gpt-5",W="gpt-5.1",G="gpt-5.4",k="gpt-5.5",$="gpt-5.4-mini",j="gpt-5.4-nano",F="gpt-5.4-pro",Ue="gpt-4.1",He="gpt-4.1-mini",Ke="gpt-4.1-nano",q="gpt-4o-mini",Be="gpt-4o",Ut="o3-mini",Ht="o1-mini",Kt="o1",Ae=[B,Q,ee,W,G,k,$,j,F,Ue,He,Ke,q,Be,"o1"],To=[B,Q,ee,W,G,k,$,j,F];function z(r){return To.includes(r)}function Bt(r){return r===F}function Wt(r){return r===k||r===G||r===$||r===j||r===F}function $t(r){return r===W||r===G||r===k||r===$||r===j}function jt(r){return r===B||r===Q||r===ee}function qt(r){return r!==F}function b(r){return r===W||r===G||r===k?"none":"medium"}var zt="https://generativelanguage.googleapis.com",yo="gemma-4-31b-it",Lo="gemma-4-26b-a4b-it",We="gemini-3.5-flash",Po="gemini-3.1-pro-preview",X="gemini-3.1-flash-lite",Io="gemini-3.1-flash-lite-preview",xo="gemini-3-pro-preview",Ao="gemini-3-flash-preview",Do="gemini-2.5-pro",Ro="gemini-2.5-flash",bo="gemini-2.5-flash-lite",No="gemini-2.5-flash-lite-preview-06-17",wo="gemini-2.0-flash",Vo="gemini-2.0-flash-lite",$e=[We,X,Po,Ao,Do,Ro,bo,yo,Lo],Go=[Io,xo,No,wo,Vo],De=[...$e,...Go];var Xt="https://api.anthropic.com/v1/messages",je="claude-3-haiku-20240307",yi="claude-3-5-haiku-20241022",Li="claude-3-5-sonnet-20241022",Pi="claude-3-7-sonnet-20250219",qe="claude-sonnet-4-20250514",ze="claude-opus-4-20250514",Xe="claude-sonnet-4-5-20250929",R="claude-haiku-4-5-20251001",Je="claude-opus-4-5-20251101",Ze="claude-sonnet-4-6",Ye="claude-opus-4-6",Qe="claude-opus-4-7",et="claude-opus-4-8",Re=[je,qe,ze,Xe,R,Je,Ze,Ye,Qe,et];var be="https://openrouter.ai/api/v1/chat/completions",Jt="openrouter/auto",U="openai/gpt-oss-20b:free",tt="moonshotai/kimi-k2.5",ot="~moonshotai/kimi-latest",it="~openai/gpt-latest",rt="~openai/gpt-mini-latest",nt="openai/gpt-5.5-pro",st="openai/gpt-5.5",at="openai/gpt-5.1-chat",lt="openai/gpt-5.1-codex",pt="openai/gpt-5-mini",ct="openai/gpt-5-nano",ut="openai/gpt-4o",ht="openai/gpt-4.1-mini",mt="openai/gpt-4.1-nano",dt="~anthropic/claude-sonnet-latest",gt="~anthropic/claude-haiku-latest",_t="anthropic/claude-opus-4",ft="anthropic/claude-sonnet-4",Mt="anthropic/claude-3.7-sonnet",Zt="anthropic/claude-3.5-sonnet",vt="anthropic/claude-haiku-4.5",Ot="~google/gemini-pro-latest",Et="~google/gemini-flash-latest",St="google/gemini-2.5-pro",Ct="google/gemini-2.5-flash",Tt="google/gemini-2.5-flash-lite-preview-09-2025",Yt="z-ai/glm-4.7-flash",Qt="z-ai/glm-4.5-air",yt="z-ai/glm-4.5-air:free",eo=[U,yt],ko=[ot,it,rt,nt,st,at,lt,pt,ct,ut,ht,mt,dt,gt,_t,ft,Mt,vt,Ot,Et,St,Ct,Tt,tt],to=20,Ii=50,xi=1e3,Ai=10;function J(r){return r.trim().endsWith(":free")}function te(r){return ko.some(e=>r.includes(e))}var Ne="https://api.z.ai/api/paas/v4/chat/completions",oo="glm-5",io="glm-5-turbo",oe="glm-4.7",ro="glm-4.7-FlashX",no="glm-4.7-Flash",so="glm-4.6",Lt="glm-4.6V",Pt="glm-4.6V-FlashX",Z="glm-4.6V-Flash",Fo=[Lt,Pt,Z];function ie(r){return Fo.includes(r)}function ao(r){return r.toLowerCase().startsWith("glm-4.6")}var we="https://api.x.ai/v1/chat/completions",It="grok-4.3",xt="grok-4.20-0309-reasoning",At="grok-4.20-0309-non-reasoning",Dt="grok-4-1-fast-reasoning",N="grok-4-1-fast-non-reasoning",Uo=[It,xt,At,Dt,N];function re(r){return Uo.includes(r)}var ne="https://api.moonshot.ai/v1/chat/completions",w="kimi-k2.6",Rt="kimi-k2.5",Ho=[w,Rt];function se(r){return Ho.includes(r)}var Ko="https://api.deepseek.com",Ve=`${Ko}/chat/completions`,ae="deepseek-v4-flash",Bo="deepseek-v4-pro",Wo="deepseek-chat",$o="deepseek-reasoner",lo=[ae,Bo],Di=[Wo,$o];var jo="https://api.mistral.ai/v1",Ge=`${jo}/chat/completions`,V="mistral-small-latest",po="mistral-small-2603",bt="mistral-medium-3-5",co="mistral-medium-2508",uo="mistral-large-latest",ho="mistral-large-2512",mo=[V,bt,uo,ho,po,co],qo=[V,bt],zo=[V,po,bt,co,uo,ho];function ke(r){return qo.includes(r)}function go(r){return r==="none"||r==="high"}function _o(r){return zo.includes(r)}var C={VERY_SHORT:"veryShort",SHORT:"short",MEDIUM:"medium",LONG:"long",VERY_LONG:"veryLong",DEEP:"deep"},Nt={[C.VERY_SHORT]:40,[C.SHORT]:100,[C.MEDIUM]:200,[C.LONG]:300,[C.VERY_LONG]:1e3,[C.DEEP]:5e3},fo=5e3,Mo={casual:{reasoning_effort:"minimal",verbosity:"low",description:"Fast responses for casual chat, quick questions (GPT-4 like experience)"},balanced:{reasoning_effort:"medium",verbosity:"medium",description:"Balanced reasoning for business tasks, learning, general problem solving"},expert:{reasoning_effort:"high",verbosity:"high",description:"Deep reasoning for research, complex analysis, expert-level tasks"}};function E(r){return r?Nt[r]??fo:fo}var Ri="You are a friendly AI avatar. Comment on the situation based on the broadcast screen.",bi=`You are a skilled summarizing assistant.
1
+ "use strict";var AITuberOnAirChat=(()=>{var Ft=Object.defineProperty;var fi=Object.getOwnPropertyDescriptor;var Mi=Object.getOwnPropertyNames;var vi=Object.prototype.hasOwnProperty;var Oi=(r,e)=>{for(var t in e)Ft(r,t,{get:e[t],enumerable:!0})},Ei=(r,e,t,o)=>{if(e&&typeof e=="object"||typeof e=="function")for(let i of Mi(e))!vi.call(r,i)&&i!==t&&Ft(r,i,{get:()=>e[i],enumerable:!(o=fi(e,i))||o.enumerable});return r};var Si=r=>Ei(Ft({},"__esModule",{value:!0}),r);var nr={};Oi(nr,{CHAT_RESPONSE_LENGTH:()=>C,CLAUDE_VISION_SUPPORTED_MODELS:()=>Re,ChatServiceFactory:()=>Ie,ChatServiceHttpClient:()=>_,ClaudeChatService:()=>pe,ClaudeChatServiceProvider:()=>ce,DEEPSEEK_API_BASE_URL:()=>Uo,DEEPSEEK_DEPRECATED_MODELS:()=>Ii,DEEPSEEK_SUPPORTED_MODELS:()=>lo,DEFAULT_MAX_TOKENS:()=>fo,DEFAULT_SUMMARY_PROMPT_TEMPLATE:()=>Di,DEFAULT_VISION_PROMPT:()=>Ai,DeepSeekChatService:()=>ue,DeepSeekChatServiceProvider:()=>he,EMOTION_TAG_CLEANUP_REGEX:()=>Oo,EMOTION_TAG_REGEX:()=>qo,ENDPOINT_CLAUDE_API:()=>Xt,ENDPOINT_DEEPSEEK_CHAT_COMPLETIONS_API:()=>Ve,ENDPOINT_GEMINI_API:()=>zt,ENDPOINT_KIMI_CHAT_COMPLETIONS_API:()=>ne,ENDPOINT_MISTRAL_CHAT_COMPLETIONS_API:()=>ke,ENDPOINT_OPENAI_CHAT_COMPLETIONS_API:()=>K,ENDPOINT_OPENAI_RESPONSES_API:()=>D,ENDPOINT_OPENROUTER_API:()=>be,ENDPOINT_XAI_CHAT_COMPLETIONS_API:()=>we,ENDPOINT_ZAI_CHAT_COMPLETIONS_API:()=>Ne,EmotionParser:()=>le,GEMINI_DEPRECATED_MODELS:()=>wo,GEMINI_NANO_MAX_CONTEXT_MESSAGES:()=>vo,GEMINI_RECOMMENDED_MODELS:()=>$e,GEMINI_VISION_SUPPORTED_MODELS:()=>De,GPT5_PRESETS:()=>Mo,GPT_5_MODELS:()=>To,GeminiChatService:()=>me,GeminiChatServiceProvider:()=>de,GeminiNanoChatService:()=>ge,GeminiNanoChatServiceProvider:()=>_e,HttpError:()=>H,KIMI_VISION_SUPPORTED_MODELS:()=>Fo,KimiChatService:()=>fe,KimiChatServiceProvider:()=>Me,MAX_TOKENS_BY_LENGTH:()=>Nt,MISTRAL_API_BASE_URL:()=>Wo,MISTRAL_REASONING_EFFORT_SUPPORTED_MODELS:()=>$o,MISTRAL_SUPPORTED_MODELS:()=>mo,MISTRAL_VISION_SUPPORTED_MODELS:()=>jo,MODEL_ANTHROPIC_CLAUDE_3_5_SONNET:()=>Zt,MODEL_ANTHROPIC_CLAUDE_3_7_SONNET:()=>Mt,MODEL_ANTHROPIC_CLAUDE_4_5_HAIKU:()=>vt,MODEL_ANTHROPIC_CLAUDE_HAIKU_LATEST:()=>gt,MODEL_ANTHROPIC_CLAUDE_OPUS_4:()=>_t,MODEL_ANTHROPIC_CLAUDE_SONNET_4:()=>ft,MODEL_ANTHROPIC_CLAUDE_SONNET_LATEST:()=>dt,MODEL_CLAUDE_3_5_HAIKU:()=>Ci,MODEL_CLAUDE_3_5_SONNET:()=>Ti,MODEL_CLAUDE_3_7_SONNET:()=>yi,MODEL_CLAUDE_3_HAIKU:()=>je,MODEL_CLAUDE_4_5_HAIKU:()=>R,MODEL_CLAUDE_4_5_OPUS:()=>Je,MODEL_CLAUDE_4_5_SONNET:()=>Xe,MODEL_CLAUDE_4_6_OPUS:()=>Ye,MODEL_CLAUDE_4_6_SONNET:()=>Ze,MODEL_CLAUDE_4_7_OPUS:()=>Qe,MODEL_CLAUDE_4_8_OPUS:()=>et,MODEL_CLAUDE_4_OPUS:()=>ze,MODEL_CLAUDE_4_SONNET:()=>qe,MODEL_DEEPSEEK_CHAT:()=>Ko,MODEL_DEEPSEEK_REASONER:()=>Bo,MODEL_DEEPSEEK_V4_FLASH:()=>ae,MODEL_DEEPSEEK_V4_PRO:()=>Ho,MODEL_GEMINI_2_5_FLASH:()=>Ro,MODEL_GEMINI_2_5_FLASH_LITE:()=>bo,MODEL_GEMINI_2_5_FLASH_LITE_PREVIEW_06_17:()=>No,MODEL_GEMINI_2_5_PRO:()=>Do,MODEL_GEMINI_3_1_FLASH_LITE:()=>X,MODEL_GEMINI_3_1_FLASH_LITE_PREVIEW:()=>xo,MODEL_GEMINI_3_1_PRO_PREVIEW:()=>Po,MODEL_GEMINI_3_5_FLASH:()=>We,MODEL_GEMINI_3_FLASH_PREVIEW:()=>Ao,MODEL_GEMINI_3_PRO_PREVIEW:()=>Io,MODEL_GEMINI_NANO:()=>Y,MODEL_GEMMA_4_26B_A4B_IT:()=>Lo,MODEL_GEMMA_4_31B_IT:()=>yo,MODEL_GLM_4_6:()=>so,MODEL_GLM_4_6V:()=>Lt,MODEL_GLM_4_6V_FLASH:()=>Z,MODEL_GLM_4_6V_FLASHX:()=>Pt,MODEL_GLM_4_7:()=>oe,MODEL_GLM_4_7_FLASH:()=>no,MODEL_GLM_4_7_FLASHX:()=>ro,MODEL_GLM_5:()=>oo,MODEL_GLM_5_TURBO:()=>io,MODEL_GOOGLE_GEMINI_2_5_FLASH:()=>Ct,MODEL_GOOGLE_GEMINI_2_5_FLASH_LITE_PREVIEW_09_2025:()=>Tt,MODEL_GOOGLE_GEMINI_2_5_PRO:()=>St,MODEL_GOOGLE_GEMINI_FLASH_LATEST:()=>Et,MODEL_GOOGLE_GEMINI_PRO_LATEST:()=>Ot,MODEL_GPT_4O:()=>Be,MODEL_GPT_4O_MINI:()=>q,MODEL_GPT_4_1:()=>Ue,MODEL_GPT_4_1_MINI:()=>He,MODEL_GPT_4_1_NANO:()=>Ke,MODEL_GPT_5:()=>ee,MODEL_GPT_5_1:()=>W,MODEL_GPT_5_4:()=>k,MODEL_GPT_5_4_MINI:()=>$,MODEL_GPT_5_4_NANO:()=>j,MODEL_GPT_5_4_PRO:()=>F,MODEL_GPT_5_5:()=>G,MODEL_GPT_5_MINI:()=>Q,MODEL_GPT_5_NANO:()=>B,MODEL_GPT_OSS_20B_FREE:()=>U,MODEL_GROK_4_1_FAST_NON_REASONING:()=>N,MODEL_GROK_4_1_FAST_REASONING:()=>Dt,MODEL_GROK_4_20_NON_REASONING:()=>At,MODEL_GROK_4_20_REASONING:()=>It,MODEL_GROK_4_3:()=>xt,MODEL_KIMI_K2_5:()=>Rt,MODEL_KIMI_K2_6:()=>w,MODEL_MISTRAL_LARGE_2512:()=>ho,MODEL_MISTRAL_LARGE_LATEST:()=>uo,MODEL_MISTRAL_MEDIUM_2508:()=>co,MODEL_MISTRAL_MEDIUM_3_5:()=>bt,MODEL_MISTRAL_SMALL_2603:()=>po,MODEL_MISTRAL_SMALL_LATEST:()=>V,MODEL_MOONSHOTAI_KIMI_K2_5:()=>tt,MODEL_MOONSHOTAI_KIMI_LATEST:()=>ot,MODEL_O1:()=>Kt,MODEL_O1_MINI:()=>Ht,MODEL_O3_MINI:()=>Ut,MODEL_OPENAI_GPT_4O:()=>ut,MODEL_OPENAI_GPT_4_1_MINI:()=>ht,MODEL_OPENAI_GPT_4_1_NANO:()=>mt,MODEL_OPENAI_GPT_5_1_CHAT:()=>at,MODEL_OPENAI_GPT_5_1_CODEX:()=>lt,MODEL_OPENAI_GPT_5_5:()=>st,MODEL_OPENAI_GPT_5_5_PRO:()=>nt,MODEL_OPENAI_GPT_5_MINI:()=>pt,MODEL_OPENAI_GPT_5_NANO:()=>ct,MODEL_OPENAI_GPT_LATEST:()=>it,MODEL_OPENAI_GPT_MINI_LATEST:()=>rt,MODEL_OPENROUTER_AUTO:()=>Jt,MODEL_ZAI_GLM_4_5_AIR:()=>Qt,MODEL_ZAI_GLM_4_5_AIR_FREE:()=>yt,MODEL_ZAI_GLM_4_7_FLASH:()=>Yt,MistralChatService:()=>ve,MistralChatServiceProvider:()=>Oe,OPENROUTER_CREDITS_THRESHOLD:()=>xi,OPENROUTER_FREE_DAILY_LIMIT_HIGH_CREDITS:()=>Pi,OPENROUTER_FREE_DAILY_LIMIT_LOW_CREDITS:()=>Li,OPENROUTER_FREE_MODELS:()=>eo,OPENROUTER_FREE_RATE_LIMIT_PER_MINUTE:()=>to,OPENROUTER_VISION_SUPPORTED_MODELS:()=>Vo,OpenAIChatService:()=>y,OpenAIChatServiceProvider:()=>Se,OpenAICompatibleChatServiceProvider:()=>Ee,OpenRouterChatService:()=>Ce,OpenRouterChatServiceProvider:()=>Te,StreamTextAccumulator:()=>M,VISION_SUPPORTED_MODELS:()=>Ae,XAIChatService:()=>ye,XAIChatServiceProvider:()=>Le,XAI_VISION_SUPPORTED_MODELS:()=>Go,ZAIChatService:()=>Pe,ZAIChatServiceProvider:()=>xe,ZAI_VISION_SUPPORTED_MODELS:()=>ko,allowsReasoningLow:()=>qt,allowsReasoningMinimal:()=>jt,allowsReasoningNone:()=>$t,allowsReasoningXHigh:()=>Wt,buildOpenAICompatibleTools:()=>I,getDefaultReasoningEffortForGPT5Model:()=>b,getMaxTokensForResponseLength:()=>E,installGASFetch:()=>di,isGPT5Model:()=>z,isKimiVisionModel:()=>se,isMistralReasoningEffort:()=>go,isMistralReasoningEffortModel:()=>Ge,isMistralVisionModel:()=>_o,isOpenRouterFreeModel:()=>J,isOpenRouterVisionModel:()=>te,isResponsesOnlyGPT5Model:()=>Bt,isXaiVisionModel:()=>re,isZaiToolStreamModel:()=>ao,isZaiVisionModel:()=>ie,parseOpenAICompatibleOneShot:()=>x,parseOpenAICompatibleTextStream:()=>L,parseOpenAICompatibleToolStream:()=>P,processChatWithOptionalTools:()=>f,refreshOpenRouterFreeModels:()=>$i,resolveVisionModel:()=>O,runOnceText:()=>wi,screenplayToText:()=>Ni,textToScreenplay:()=>zo,textsToScreenplay:()=>bi});var K="https://api.openai.com/v1/chat/completions",D="https://api.openai.com/v1/responses",B="gpt-5-nano",Q="gpt-5-mini",ee="gpt-5",W="gpt-5.1",k="gpt-5.4",G="gpt-5.5",$="gpt-5.4-mini",j="gpt-5.4-nano",F="gpt-5.4-pro",Ue="gpt-4.1",He="gpt-4.1-mini",Ke="gpt-4.1-nano",q="gpt-4o-mini",Be="gpt-4o",Ut="o3-mini",Ht="o1-mini",Kt="o1",Ae=[B,Q,ee,W,k,G,$,j,F,Ue,He,Ke,q,Be,"o1"],To=[B,Q,ee,W,k,G,$,j,F];function z(r){return To.includes(r)}function Bt(r){return r===F}function Wt(r){return r===G||r===k||r===$||r===j||r===F}function $t(r){return r===W||r===k||r===G||r===$||r===j}function jt(r){return r===B||r===Q||r===ee}function qt(r){return r!==F}function b(r){return r===W||r===k||r===G?"none":"medium"}var zt="https://generativelanguage.googleapis.com",yo="gemma-4-31b-it",Lo="gemma-4-26b-a4b-it",We="gemini-3.5-flash",Po="gemini-3.1-pro-preview",X="gemini-3.1-flash-lite",xo="gemini-3.1-flash-lite-preview",Io="gemini-3-pro-preview",Ao="gemini-3-flash-preview",Do="gemini-2.5-pro",Ro="gemini-2.5-flash",bo="gemini-2.5-flash-lite",No="gemini-2.5-flash-lite-preview-06-17",$e=[We,X,Po,Ao,Do,Ro,bo,yo,Lo],wo=[xo,Io,No],De=[...$e,...wo];var Xt="https://api.anthropic.com/v1/messages",je="claude-3-haiku-20240307",Ci="claude-3-5-haiku-20241022",Ti="claude-3-5-sonnet-20241022",yi="claude-3-7-sonnet-20250219",qe="claude-sonnet-4-20250514",ze="claude-opus-4-20250514",Xe="claude-sonnet-4-5-20250929",R="claude-haiku-4-5-20251001",Je="claude-opus-4-5-20251101",Ze="claude-sonnet-4-6",Ye="claude-opus-4-6",Qe="claude-opus-4-7",et="claude-opus-4-8",Re=[je,qe,ze,Xe,R,Je,Ze,Ye,Qe,et];var be="https://openrouter.ai/api/v1/chat/completions",Jt="openrouter/auto",U="openai/gpt-oss-20b:free",tt="moonshotai/kimi-k2.5",ot="~moonshotai/kimi-latest",it="~openai/gpt-latest",rt="~openai/gpt-mini-latest",nt="openai/gpt-5.5-pro",st="openai/gpt-5.5",at="openai/gpt-5.1-chat",lt="openai/gpt-5.1-codex",pt="openai/gpt-5-mini",ct="openai/gpt-5-nano",ut="openai/gpt-4o",ht="openai/gpt-4.1-mini",mt="openai/gpt-4.1-nano",dt="~anthropic/claude-sonnet-latest",gt="~anthropic/claude-haiku-latest",_t="anthropic/claude-opus-4",ft="anthropic/claude-sonnet-4",Mt="anthropic/claude-3.7-sonnet",Zt="anthropic/claude-3.5-sonnet",vt="anthropic/claude-haiku-4.5",Ot="~google/gemini-pro-latest",Et="~google/gemini-flash-latest",St="google/gemini-2.5-pro",Ct="google/gemini-2.5-flash",Tt="google/gemini-2.5-flash-lite-preview-09-2025",Yt="z-ai/glm-4.7-flash",Qt="z-ai/glm-4.5-air",yt="z-ai/glm-4.5-air:free",eo=[U,yt],Vo=[ot,it,rt,nt,st,at,lt,pt,ct,ut,ht,mt,dt,gt,_t,ft,Mt,vt,Ot,Et,St,Ct,Tt,tt],to=20,Li=50,Pi=1e3,xi=10;function J(r){return r.trim().endsWith(":free")}function te(r){return Vo.some(e=>r.includes(e))}var Ne="https://api.z.ai/api/paas/v4/chat/completions",oo="glm-5",io="glm-5-turbo",oe="glm-4.7",ro="glm-4.7-FlashX",no="glm-4.7-Flash",so="glm-4.6",Lt="glm-4.6V",Pt="glm-4.6V-FlashX",Z="glm-4.6V-Flash",ko=[Lt,Pt,Z];function ie(r){return ko.includes(r)}function ao(r){return r.toLowerCase().startsWith("glm-4.6")}var we="https://api.x.ai/v1/chat/completions",xt="grok-4.3",It="grok-4.20-0309-reasoning",At="grok-4.20-0309-non-reasoning",Dt="grok-4-1-fast-reasoning",N="grok-4-1-fast-non-reasoning",Go=[xt,It,At,Dt,N];function re(r){return Go.includes(r)}var ne="https://api.moonshot.ai/v1/chat/completions",w="kimi-k2.6",Rt="kimi-k2.5",Fo=[w,Rt];function se(r){return Fo.includes(r)}var Uo="https://api.deepseek.com",Ve=`${Uo}/chat/completions`,ae="deepseek-v4-flash",Ho="deepseek-v4-pro",Ko="deepseek-chat",Bo="deepseek-reasoner",lo=[ae,Ho],Ii=[Ko,Bo];var Wo="https://api.mistral.ai/v1",ke=`${Wo}/chat/completions`,V="mistral-small-latest",po="mistral-small-2603",bt="mistral-medium-3-5",co="mistral-medium-2508",uo="mistral-large-latest",ho="mistral-large-2512",mo=[V,bt,uo,ho,po,co],$o=[V,bt],jo=[V,po,bt,co,uo,ho];function Ge(r){return $o.includes(r)}function go(r){return r==="none"||r==="high"}function _o(r){return jo.includes(r)}var C={VERY_SHORT:"veryShort",SHORT:"short",MEDIUM:"medium",LONG:"long",VERY_LONG:"veryLong",DEEP:"deep"},Nt={[C.VERY_SHORT]:40,[C.SHORT]:100,[C.MEDIUM]:200,[C.LONG]:300,[C.VERY_LONG]:1e3,[C.DEEP]:5e3},fo=5e3,Mo={casual:{reasoning_effort:"minimal",verbosity:"low",description:"Fast responses for casual chat, quick questions (GPT-4 like experience)"},balanced:{reasoning_effort:"medium",verbosity:"medium",description:"Balanced reasoning for business tasks, learning, general problem solving"},expert:{reasoning_effort:"high",verbosity:"high",description:"Deep reasoning for research, complex analysis, expert-level tasks"}};function E(r){return r?Nt[r]??fo:fo}var Ai="You are a friendly AI avatar. Comment on the situation based on the broadcast screen.",Di=`You are a skilled summarizing assistant.
2
2
  Analyze the following conversation and produce a summary in the **same language** as the majority of the conversation:
3
3
  - Summaries should highlight key points
4
4
  - Stay concise (around {maxLength} characters if possible)
@@ -7,15 +7,15 @@ Analyze the following conversation and produce a summary in the **same language*
7
7
  If the conversation is in Japanese, summarize in Japanese.
8
8
  If it's in English, summarize in English.
9
9
  If it's in another language, summarize in that language.
10
- `;var Y="gemini-nano",vo=20;var H=class extends Error{constructor(t,o,i){super(`HTTP ${t}: ${o}`);this.status=t;this.statusText=o;this.body=i;this.name="HttpError"}},Fe=class Fe{static setFetch(e){this.fetchImpl=e}static async post(e,t,o={},i={}){let{timeout:n=3e4,retries:s=0,retryDelay:a=1e3}=i,c={...{"Content-Type":"application/json"},...o},d=null;for(let u=0;u<=s;u++)try{let m=typeof AbortController<"u",p=m?new AbortController:void 0,h=m?setTimeout(()=>p.abort(),n):void 0,g=await Fe.fetchImpl(e,{method:"POST",headers:c,body:typeof t=="string"?t:JSON.stringify(t),...p?{signal:p.signal}:{}});if(h&&clearTimeout(h),!g.ok){let S=await g.text();throw new H(g.status,g.statusText,S)}return g}catch(m){if(d=m,m instanceof H&&m.status>=400&&m.status<500)throw m;if(m instanceof Error&&m.name==="AbortError")throw new Error(`Request timeout after ${n}ms`);u<s&&await new Promise(p=>setTimeout(p,a*(u+1)))}throw d||new Error("Request failed")}static async handleErrorResponse(e){let t=await e.text();throw new H(e.status,e.statusText,t)}static async get(e,t={},o={}){let{timeout:i=3e4,retries:n=0,retryDelay:s=1e3}=o,a=null;for(let l=0;l<=n;l++)try{let c=typeof AbortController<"u",d=c?new AbortController:void 0,u=c?setTimeout(()=>d.abort(),i):void 0,m=await Fe.fetchImpl(e,{method:"GET",headers:t,...d?{signal:d.signal}:{}});if(u&&clearTimeout(u),!m.ok){let p=await m.text();throw new H(m.status,m.statusText,p)}return m}catch(c){if(a=c,c instanceof H&&c.status>=400&&c.status<500)throw c;if(c instanceof Error&&c.name==="AbortError")throw new Error(`Request timeout after ${i}ms`);l<n&&await new Promise(d=>setTimeout(d,s*(l+1)))}throw a||new Error("Request failed")}};Fe.fetchImpl=(e,t)=>fetch(e,t);var _=Fe;var M=class{static append(e,t){if(!t)return;let o=e[e.length-1];o&&o.type==="text"?o.text+=t:e.push({type:"text",text:t})}static getFullText(e){return e.filter(t=>t.type==="text").map(t=>t.text).join("")}static addTextBlock(e,t){t&&e.push({type:"text",text:t})}};var Ni=["happy","sad","angry","surprised","neutral"],Xo=/\[([a-z]+)\]/i,Oo=/\[[a-z]+\]\s*/gi,le=class{static extractEmotion(e){let t=e.match(Xo);if(t){let o=t[1].toLowerCase(),i=e.replace(Oo,"").trim();return{emotion:o,cleanText:i}}return{cleanText:e}}static isValidEmotion(e){return Ni.includes(e)}static cleanEmotionTags(e){return e.replace(Oo,"").trim()}static addEmotionTag(e,t){return`[${e}] ${t}`}};function Jo(r){let{emotion:e,cleanText:t}=le.extractEmotion(r);return e?{emotion:e,text:t}:{text:t}}function wi(r){return r.map(e=>Jo(e))}function Vi(r){return r.emotion?le.addEmotionTag(r.emotion,r.text):r.text}async function Gi(r,e){let{blocks:t}=await r.chatOnce(e,!1,()=>{});return M.getFullText(t)}var Zo=(r,e)=>{try{return JSON.parse(r)}catch(t){if(e){e(r,t);return}throw t}},Eo=r=>typeof r=="string"?r:Array.isArray(r)?r.map(e=>typeof e=="string"?e:e&&typeof e=="object"&&e.type==="text"&&typeof e.text=="string"?e.text:"").join(""):"",Yo=async(r,e)=>{let t=r.body?.getReader();if(!t)throw new Error("Response body is null.");let o=new TextDecoder,i="",n=!1;for(;!n;){let{done:s,value:a}=await t.read();if(s)break;i+=o.decode(a,{stream:!0});let l=i.split(`
11
- `);i=l.pop()||"";for(let c of l){let d=c.trim();if(!d||d.startsWith(":")||!d.startsWith("data:"))continue;let u=d.slice(5).trim();if(u==="[DONE]"){n=!0;break}e(u)}}};async function L(r,e,t={}){let o="";return await Yo(r,i=>{let n=Zo(i,t.onJsonError);if(!n)return;let s=Eo(n.choices?.[0]?.delta?.content);s&&(e(s),o+=s)}),o}async function P(r,e,t={}){let o=[],i=new Map,n,s,a=t.appendTextBlock??M.append;await Yo(r,d=>{let u=Zo(d,t.onJsonError);if(!u)return;let m=u.choices?.[0];typeof m?.finish_reason=="string"&&(n=m.finish_reason),u.usage&&(s=u.usage);let p=m?.delta,h=Eo(p?.content);h&&(e(h),a(o,h)),p?.tool_calls&&p.tool_calls.forEach(g=>{let S=i.get(g.index)??{id:g.id,name:g.function?.name,args:""};S.args+=g.function?.arguments||"",i.set(g.index,S)})});let l=Array.from(i.entries()).sort((d,u)=>d[0]-u[0]).map(([d,u])=>({type:"tool_use",id:u.id,name:u.name,input:JSON.parse(u.args||"{}")}));return{blocks:[...o,...l],stop_reason:l.length?"tool_use":"end",truncated:n==="length",finish_reason:n,usage:s}}function I(r){let e=r?.choices?.[0],t=[];if(e?.message?.tool_calls?.length)e.message.tool_calls.forEach(o=>t.push({type:"tool_use",id:o.id,name:o.function?.name,input:JSON.parse(o.function?.arguments||"{}")}));else{let o=Eo(e?.message?.content);o&&t.push({type:"text",text:o})}return{blocks:t,stop_reason:e?.finish_reason==="tool_calls"||t.some(o=>o.type==="tool_use")?"tool_use":"end",truncated:e?.finish_reason==="length",finish_reason:e?.finish_reason,usage:r?.usage}}var x=(r,e="chat-completions")=>r.length===0?[]:e==="responses"?r.map(t=>({type:"function",name:t.name,description:t.description,parameters:t.parameters})):r.map(t=>({type:"function",function:{name:t.name,description:t.description,parameters:t.parameters}}));async function f(r){if(!r.hasTools){let t=await r.runWithoutTools();await r.onCompleteResponse(t);return}let e=await r.runWithTools();if(r.onToolBlocks&&r.onToolBlocks(e.blocks),e.stop_reason==="end"){let t=M.getFullText(e.blocks);await r.onCompleteResponse(t);return}throw new Error(r.toolErrorMessage)}var O=r=>{let e=r.model??r.defaultModel,t=r.visionModel??(r.supportsVisionForModel(e)?e:r.defaultVisionModel);if(r.validate==="explicit"&&r.visionModel&&!r.supportsVisionForModel(r.visionModel))throw new Error(`Model ${r.visionModel} does not support vision capabilities.`);if(r.validate==="resolved"&&!r.supportsVisionForModel(t))throw new Error(`Model ${t} does not support vision capabilities.`);return t};var ki="https://openrouter.ai/api/v1/models",Fi=2,Ui=12e3,Hi=1,Ki=10;function So(r){return r instanceof Error?r.message:String(r)}function wt(r,e){return typeof r!="number"||!Number.isFinite(r)?e:Math.max(1,Math.floor(r))}function Bi(r){let e=new Set,t=[];for(let o of r){let i=o.trim();!i||e.has(i)||(e.add(i),t.push(i))}return t}async function Qo(r,e,t){if(!(typeof AbortController<"u"))return fetch(r,e);let i=new AbortController,n=setTimeout(()=>i.abort(),t);try{return await fetch(r,{...e,signal:i.signal})}catch(s){throw s instanceof Error&&s.name==="AbortError"?new Error(`Timeout after ${t}ms`):s}finally{clearTimeout(n)}}async function ei(r){let e=`HTTP ${r.status} ${r.statusText}`.trim(),t="";try{t=await r.text()}catch{return e}let o=t.replace(/\s+/g," ").trim().slice(0,200);return o?`${e}: ${o}`:e}function Wi(r){if(!r||typeof r!="object")throw new Error("Invalid models response shape");let e=r,t=Array.isArray(e.data)?e.data:Array.isArray(e.models)?e.models:[];if(t.length===0)return[];let o=t.map(i=>i.id).filter(i=>typeof i=="string");return Bi(o)}async function $i({modelId:r,apiKey:e,endpoint:t,timeoutMs:o,appName:i,appUrl:n}){let s={Authorization:`Bearer ${e}`,"Content-Type":"application/json"};i&&(s["X-Title"]=i),n&&(s["HTTP-Referer"]=n);try{let a=await Qo(t,{method:"POST",headers:s,body:JSON.stringify({model:r,messages:[{role:"user",content:"Reply only with OK."}],stream:!1})},o);if(!a.ok)return{id:r,ok:!1,reason:await ei(a)};try{await a.json()}catch(l){return{id:r,ok:!1,reason:`JSON parse failed: ${So(l)}`}}return{id:r,ok:!0}}catch(a){return{id:r,ok:!1,reason:So(a)}}}async function ji(r,e,t){if(r.length===0)return[];let o=new Array(r.length),i=0,n=Math.min(e,r.length);return await Promise.all(Array.from({length:n},async()=>{for(;i<r.length;){let s=i;i+=1,o[s]=await t(r[s])}})),o}async function qi(r){let e=r.apiKey.trim();if(!e)throw new Error("OpenRouter API key is required.");let t=r.modelsEndpoint||ki,o=r.endpoint||be,i=wt(r.timeoutMs,Ui),n=wt(r.concurrency,Fi),s=wt(r.maxCandidates,Hi),a=wt(r.maxWorking,Ki),l=await Qo(t,{method:"GET"},i);if(!l.ok)throw new Error(await ei(l));let c;try{c=await l.json()}catch(h){throw new Error(`JSON parse failed: ${So(h)}`)}let d=Wi(c).filter(h=>J(h)).slice(0,s),u=await ji(d,n,h=>$i({modelId:h,apiKey:e,endpoint:o,timeoutMs:i,appName:r.appName,appUrl:r.appUrl})),m=u.filter(h=>h.ok).map(h=>h.id).slice(0,a),p=u.filter(h=>!h.ok).map(h=>({id:h.id,reason:h.reason||"Unknown error"}));return{working:m,failed:p,fetchedAt:Date.now()}}function ti(r){return r.map(e=>({role:Vt(e.role),content:e.content}))}function oi(r){return r.map(e=>{if(typeof e.content=="string")return{role:Vt(e.role),content:[{type:"text",text:e.content}]};if(Array.isArray(e.content)){let t=e.content.map(o=>{if(o.type==="image_url"){if(o.image_url.url.startsWith("data:")){let i=o.image_url.url.match(/^data:([^;]+);base64,(.+)$/);return i?{type:"image",source:{type:"base64",media_type:i[1],data:i[2]}}:null}return{type:"image",source:{type:"url",url:o.image_url.url,media_type:zi(o.image_url.url)}}}return o}).filter(o=>o);return{role:Vt(e.role),content:t}}return{role:Vt(e.role),content:[]}})}function Vt(r){switch(r){case"system":return"system";case"user":return"user";case"assistant":return"assistant";default:return"user"}}function zi(r){switch(r.split(".").pop()?.toLowerCase()){case"jpg":case"jpeg":return"image/jpeg";case"png":return"image/png";case"gif":return"image/gif";case"webp":return"image/webp";default:return"image/jpeg"}}var pe=class{constructor(e,t=R,o=R,i=[],n=[],s){this.provider="claude";if(this.apiKey=e,this.model=t||R,this.visionModel=o||R,this.tools=i,this.mcpServers=n,this.responseLength=s,!Re.includes(this.visionModel))throw new Error(`Model ${this.visionModel} does not support vision capabilities.`)}getModel(){return this.model}getVisionModel(){return this.visionModel}getMCPServers(){return this.mcpServers}addMCPServer(e){this.mcpServers.push(e)}removeMCPServer(e){this.mcpServers=this.mcpServers.filter(t=>t.name!==e)}hasMCPServers(){return this.mcpServers.length>0}async processChat(e,t,o){await f({hasTools:this.tools.length>0||this.mcpServers.length>0,runWithoutTools:async()=>{let i=await this.callClaude(e,this.model,!0);return this.parsePureStream(i,t)},runWithTools:()=>this.chatOnce(e,!0,t),onCompleteResponse:o,toolErrorMessage:"processChat received tool_calls. ChatProcessor must use chatOnce() loop when tools are enabled."})}async processVisionChat(e,t,o){await f({hasTools:this.tools.length>0||this.mcpServers.length>0,runWithoutTools:async()=>{let i=await this.callClaude(e,this.visionModel,!0);return this.parsePureStream(i,t)},runWithTools:()=>this.visionChatOnce(e),onCompleteResponse:o,toolErrorMessage:"processVisionChat received tool_calls. ChatProcessor must use chatOnce() loop when tools are enabled."})}async callClaude(e,t,o,i){let n=e.find(u=>u.role==="system")?.content??"",s=e.filter(u=>u.role!=="system"),a=s.some(u=>Array.isArray(u.content)&&u.content.some(m=>m.type==="image_url"||m.type==="image")),l={model:t,system:n,messages:a?oi(s):ti(s),stream:o,max_tokens:i!==void 0?i:E(this.responseLength)};this.tools.length&&(l.tools=this.tools.map(u=>({name:u.name,description:u.description,input_schema:u.parameters})),l.tool_choice={type:"auto"}),this.mcpServers.length>0&&(l.mcp_servers=this.mcpServers);let c={"Content-Type":"application/json","x-api-key":this.apiKey,"anthropic-version":"2023-06-01","anthropic-dangerous-direct-browser-access":"true"};return this.mcpServers.length>0&&(c["anthropic-beta"]="mcp-client-2025-04-04"),await _.post(Xt,l,c)}async parseStream(e,t){let o=e.body.getReader(),i=new TextDecoder,n=[],s=new Map,a="";for(;;){let{done:l,value:c}=await o.read();if(l)break;a+=i.decode(c,{stream:!0});let d;for(;(d=a.indexOf(`
12
- `))!==-1;){let u=a.slice(0,d).trim();if(a=a.slice(d+1),!u.startsWith("data:"))continue;let m=u.slice(5).trim();if(m==="[DONE]")break;let p=JSON.parse(m);if(p.type==="content_block_delta"&&p.delta?.text&&(t(p.delta.text),n.push({type:"text",text:p.delta.text})),p.type==="content_block_start"&&p.content_block?.type==="tool_use"?s.set(p.index,{id:p.content_block.id,name:p.content_block.name,args:""}):p.type==="content_block_start"&&p.content_block?.type==="mcp_tool_use"?s.set(p.index,{id:p.content_block.id,name:p.content_block.name,args:"",server_name:p.content_block.server_name}):p.type==="content_block_start"&&p.content_block?.type==="tool_result"?n.push({type:"tool_result",tool_use_id:p.content_block.tool_use_id,content:p.content_block.content??""}):p.type==="content_block_start"&&p.content_block?.type==="mcp_tool_result"&&n.push({type:"mcp_tool_result",tool_use_id:p.content_block.tool_use_id,is_error:p.content_block.is_error??!1,content:p.content_block.content??[]}),p.type==="content_block_delta"&&p.delta?.type==="input_json_delta"){let h=s.get(p.index);h&&(h.args+=p.delta.partial_json||"")}if(p.type==="content_block_stop"&&s.has(p.index)){let{id:h,name:g,args:S,server_name:A}=s.get(p.index);A?n.push({type:"mcp_tool_use",id:h,name:g,server_name:A,input:JSON.parse(S||"{}")}):n.push({type:"tool_use",id:h,name:g,input:JSON.parse(S||"{}")}),s.delete(p.index)}}}return{blocks:n,stop_reason:n.some(l=>l.type==="tool_use"||l.type==="mcp_tool_use")?"tool_use":"end"}}async parsePureStream(e,t){let{blocks:o}=await this.parseStream(e,t);return o.filter(i=>i.type==="text").map(i=>i.text).join("")}parseOneShot(e){let t=[];return(e.content??[]).forEach(o=>{o.type==="text"?t.push({type:"text",text:o.text}):o.type==="tool_use"?t.push({type:"tool_use",id:o.id,name:o.name,input:o.input??{}}):o.type==="mcp_tool_use"?t.push({type:"mcp_tool_use",id:o.id,name:o.name,server_name:o.server_name,input:o.input??{}}):o.type==="tool_result"?t.push({type:"tool_result",tool_use_id:o.tool_use_id,content:o.content??""}):o.type==="mcp_tool_result"&&t.push({type:"mcp_tool_result",tool_use_id:o.tool_use_id,is_error:o.is_error??!1,content:o.content??[]})}),{blocks:t,stop_reason:t.some(o=>o.type==="tool_use"||o.type==="mcp_tool_use")?"tool_use":"end"}}async chatOnce(e,t=!0,o=()=>{},i){let n=await this.callClaude(e,this.model,t,i),s=t?await this.parseStream(n,o):this.parseOneShot(await n.json());return this.convertToStandardCompletion(s)}async visionChatOnce(e,t=!1,o=()=>{},i){let n=await this.callClaude(e,this.visionModel,t,i),s=t?await this.parseStream(n,o):this.parseOneShot(await n.json());return this.convertToStandardCompletion(s)}convertToStandardCompletion(e){return{blocks:e.blocks.filter(o=>o.type==="text"||o.type==="tool_use"||o.type==="tool_result"),stop_reason:e.stop_reason}}};var ce=class{createChatService(e){let t=O({model:e.model,visionModel:e.visionModel,defaultModel:this.getDefaultModel(),defaultVisionModel:this.getDefaultModel(),supportsVisionForModel:o=>this.supportsVisionForModel(o),validate:"resolved"});return new pe(e.apiKey,e.model||this.getDefaultModel(),t,e.tools??[],e.mcpServers??[],e.responseLength)}getProviderName(){return"claude"}getSupportedModels(){return[qe,ze,Xe,R,Je,Ze,Ye,Qe,et,je]}getDefaultModel(){return R}supportsVision(){return this.getVisionSupportLevel()!=="unsupported"}getVisionSupportLevel(){return"supported"}supportsVisionForModel(e){return Re.includes(e)}getVisionSupportLevelForModel(e){return this.supportsVisionForModel(e)?"supported":"unsupported"}};async function Gt(r,e){let t=r.body.getReader(),o=new TextDecoder,i=[],n=new Map,s,a,l,c="";for(;;){let{done:u,value:m}=await t.read();if(u)break;c+=o.decode(m,{stream:!0});let p="",h="",g=c.split(`
13
- `);c=g.pop()||"";for(let S=0;S<g.length;S++){let A=g[S].trim();if(A.startsWith("event:"))p=A.slice(6).trim();else if(A.startsWith("data:"))h=A.slice(5).trim();else if(A===""&&p&&h){try{let v=JSON.parse(h);Xi(p,v,e,i,n,T=>{T.responseStatus!==void 0&&(s=T.responseStatus),T.incompleteDetails!==void 0&&(a=T.incompleteDetails),T.usage!==void 0&&(l=T.usage)})}catch{console.warn("Failed to parse SSE data:",h)}p="",h=""}}}let d=Array.from(n.values()).map(u=>({type:"tool_use",id:u.id,name:u.name,input:u.input||{}}));return{blocks:[...i,...d],stop_reason:d.length?"tool_use":"end",truncated:s==="incomplete",response_status:s,incomplete_details:a,usage:l}}function Xi(r,e,t,o,i,n){switch(r){case"response.output_item.added":e.item?.type==="message"&&Array.isArray(e.item.content)?e.item.content.forEach(s=>{s.type==="output_text"&&s.text&&(t(s.text),M.append(o,s.text))}):e.item?.type==="function_call"&&i.set(e.item.id,{id:e.item.id,name:e.item.name,input:e.item.arguments?JSON.parse(e.item.arguments):{}});break;case"response.content_part.added":e.part?.type==="output_text"&&typeof e.part.text=="string"&&(t(e.part.text),M.append(o,e.part.text));break;case"response.output_text.delta":case"response.content_part.delta":{let s=typeof e.delta=="string"?e.delta:e.delta?.text??"";s&&(t(s),M.append(o,s));break}case"response.output_text.done":case"response.content_part.done":case"response.reasoning.started":case"response.reasoning.delta":case"response.reasoning.done":break;case"response.completed":n(ii(e,"completed"));break;case"response.incomplete":n(ii(e,"incomplete"));break;default:break}}function ii(r,e){let t=r?.response??r;return{responseStatus:t?.status??e,incompleteDetails:t?.incomplete_details??null,usage:t?.usage}}function ri(r){let e=[];return r.output&&Array.isArray(r.output)&&r.output.forEach(t=>{t.type==="message"&&t.content&&t.content.forEach(o=>{o.type==="output_text"&&o.text&&e.push({type:"text",text:o.text})}),t.type==="function_call"&&e.push({type:"tool_use",id:t.id,name:t.name,input:t.arguments?JSON.parse(t.arguments):{}})}),{blocks:e,stop_reason:e.some(t=>t.type==="tool_use")?"tool_use":"end",truncated:r?.status==="incomplete",response_status:r?.status,incomplete_details:r?.incomplete_details??null,usage:r?.usage}}function ni({tools:r,mcpServers:e,isResponsesAPI:t}){let o=[];return r.length>0&&o.push(...x(r,t?"responses":"chat-completions")),e.length>0&&t&&o.push(...Ji(e)),o}function Ji(r){return r.map(e=>{let t={type:"mcp",server_label:e.name,server_url:e.url};return e.require_approval&&(t.require_approval=e.require_approval),e.tool_configuration?.allowed_tools&&(t.allowed_tools=e.tool_configuration.allowed_tools),e.authorization_token&&(t.headers={Authorization:`Bearer ${e.authorization_token}`}),t})}var Zi={[C.VERY_SHORT]:800,[C.SHORT]:1200,[C.MEDIUM]:2e3,[C.LONG]:3e3,[C.VERY_LONG]:8e3,[C.DEEP]:25e3},Yi={none:1200,minimal:1600,low:2500,medium:4e3,high:8e3,xhigh:12e3},Qi=new Set(["openai-compatible","deepseek","mistral"]);function si({provider:r,endpoint:e,messages:t,model:o,stream:i,tools:n,mcpServers:s,responseLength:a,verbosity:l,reasoning_effort:c,enableReasoningSummary:d,maxTokens:u}){let m=e===D;tr(e,s);let p={model:o,stream:i},h=er({provider:r,model:o,responseLength:a,reasoning_effort:c,maxTokens:u});m?h!==void 0&&(p.max_output_tokens=h):h!==void 0&&(ai(r)?p.max_tokens=h:p.max_completion_tokens=h),m?p.input=or(t):p.messages=r==="mistral"?ir(t):t,z(o)&&(m?(c&&(p.reasoning={...p.reasoning,effort:c},d&&(p.reasoning.summary="auto")),l&&(p.text={...p.text,format:{type:"text"},verbosity:l})):(c&&(p.reasoning_effort=c),l&&(p.verbosity=l))),r==="mistral"&&ke(o)&&c&&go(c)&&(p.reasoning_effort=c);let g=ni({tools:n,mcpServers:s,isResponsesAPI:m});return g.length>0&&(p.tools=g,m||(p.tool_choice="auto")),p}function er({provider:r,model:e,responseLength:t,reasoning_effort:o,maxTokens:i}){if(i!==void 0)return i;let n=ai(r)?t!==void 0?E(t):void 0:E(t);if(r!=="openai"||!z(e)||t===void 0)return n;let s=o??b(e);return Math.max(n??0,Zi[t],Yi[s])}function tr(r,e){if(e.length>0&&r===K)throw new Error(`MCP servers are not supported with Chat Completions API. Current endpoint: ${r}. Please use OpenAI Responses API endpoint: ${D}. MCP tools are only available in the Responses API endpoint.`)}function or(r){return r.map(e=>{let o={role:e.role==="tool"?"user":e.role};return typeof e.content=="string"?o.content=e.content:Array.isArray(e.content)?o.content=e.content.map(i=>i.type==="text"?{type:"input_text",text:i.text}:i.type==="image_url"?{type:"input_image",image_url:i.image_url.url}:i):o.content=e.content,o})}function ir(r){return r.map(e=>{let t={role:e.role};return Array.isArray(e.content)?(t.content=e.content.map(o=>o.type==="image_url"&&typeof o.image_url=="object"&&typeof o.image_url?.url=="string"?{type:"image_url",image_url:o.image_url.url}:o),t):(t.content=e.content,t)})}function ai(r){return Qi.has(r)}var y=class{constructor(e,t=q,o=q,i,n=K,s=[],a,l,c,d=!1,u="openai",m=!0){if(this.provider=u,this.apiKey=e,this.model=t,this.tools=i||[],this.endpoint=n,this.mcpServers=s,this.responseLength=a,this.verbosity=l,this.reasoning_effort=c,this.enableReasoningSummary=d,m&&!Ae.includes(o))throw new Error(`Model ${o} does not support vision capabilities.`);this.visionModel=o}getModel(){return this.model}getVisionModel(){return this.visionModel}async processChat(e,t,o){await f({hasTools:this.tools.length>0,runWithoutTools:async()=>{let i=await this.callOpenAI(e,this.model,!0),n=this.endpoint===D;try{if(n){let s=await Gt(i,t);return M.getFullText(s.blocks)}return this.handleStream(i,t)}catch(s){throw console.error("[processChat] Error in streaming/completion:",s),s}},runWithTools:()=>this.chatOnce(e,!0,t),onCompleteResponse:o,toolErrorMessage:"processChat received tool_calls. ChatProcessor must use chatOnce() loop when tools are enabled."})}async processVisionChat(e,t,o){try{await f({hasTools:this.tools.length>0,runWithoutTools:async()=>{let i=await this.callOpenAI(e,this.visionModel,!0),n=this.endpoint===D;try{if(n){let s=await Gt(i,t);return M.getFullText(s.blocks)}return this.handleStream(i,t)}catch(s){throw console.error("[processVisionChat] Error in streaming/completion:",s),s}},runWithTools:()=>this.visionChatOnce(e,!0,t),onCompleteResponse:o,toolErrorMessage:"processVisionChat received tool_calls. ChatProcessor must use visionChatOnce() loop when tools are enabled."})}catch(i){throw console.error("Error in processVisionChat:",i),i}}async chatOnce(e,t=!0,o=()=>{},i){let n=await this.callOpenAI(e,this.model,t,i);return this.parseResponse(n,t,o)}async visionChatOnce(e,t=!1,o=()=>{},i){let n=await this.callOpenAI(e,this.visionModel,t,i);return this.parseResponse(n,t,o)}async parseResponse(e,t,o){return this.endpoint===D?t?Gt(e,o):ri(await e.json()):t?this.parseStream(e,o):this.parseOneShot(await e.json())}async callOpenAI(e,t,o=!1,i){let n=si({provider:this.provider,endpoint:this.endpoint,messages:e,model:t,stream:o,tools:this.tools,mcpServers:this.mcpServers,responseLength:this.responseLength,verbosity:this.verbosity,reasoning_effort:this.reasoning_effort,enableReasoningSummary:this.enableReasoningSummary,maxTokens:i}),s={};return(this.provider!=="openai-compatible"||this.apiKey.trim()!=="")&&(s.Authorization=`Bearer ${this.apiKey}`),await _.post(this.endpoint,n,s)}async handleStream(e,t){return L(e,t)}async parseStream(e,t){return P(e,t,{appendTextBlock:M.addTextBlock})}parseOneShot(e){return I(e)}};var ue=class extends y{constructor(e,t=ae,o=t,i,n=Ve,s){super(e,t,o,i,n,[],s,void 0,void 0,!1,"deepseek",!1)}};var he=class{createChatService(e){this.validateRequiredOptions(e);let t=e.model||this.getDefaultModel(),o=e.tools;return new ue(e.apiKey,t,e.visionModel??t,o,this.resolveEndpoint(e),e.responseLength)}getProviderName(){return"deepseek"}getSupportedModels(){return[...lo]}getDefaultModel(){return ae}supportsVision(){return!1}getVisionSupportLevel(){return"unsupported"}supportsVisionForModel(e){return!1}getVisionSupportLevelForModel(e){return"unsupported"}validateRequiredOptions(e){if(!e.apiKey?.trim())throw new Error("deepseek provider requires apiKey.")}resolveEndpoint(e){if(e.endpoint)return this.normalizeUrl(e.endpoint);if(e.baseUrl){let t=this.normalizeUrl(e.baseUrl);return t.endsWith("/chat/completions")?t:`${t}/chat/completions`}return Ve}normalizeUrl(e){return e.trim().replace(/\/+$/,"")}};var kt=class{static async fetchToolSchemas(e){try{let t={"Content-Type":"application/json"};e.authorization_token&&(t.Authorization=`Bearer ${e.authorization_token}`);let i=await(await _.post(`${e.url}/tools`,{},t)).json();return Array.isArray(i.tools)?i.tools.map(n=>({name:`mcp_${e.name}_${n.name}`,description:n.description||`Tool from ${e.name} MCP server`,parameters:n.inputSchema||{type:"object",properties:{},required:[]}})):[{name:`mcp_${e.name}_search`,description:`Search using ${e.name} MCP server`,parameters:{type:"object",properties:{query:{type:"string",description:"Search query"}},required:["query"]}}]}catch(t){return console.warn(`Failed to fetch MCP schemas from ${e.name}:`,t),[{name:`mcp_${e.name}_search`,description:`Search using ${e.name} MCP server (schema fetch failed)`,parameters:{type:"object",properties:{query:{type:"string",description:"Search query"}},required:["query"]}}]}}static async fetchAllToolSchemas(e){let t=[];for(let o of e)try{let i=await this.fetchToolSchemas(o);t.push(...i)}catch(i){console.error(`Failed to fetch schemas from ${o.name}:`,i)}return t}};function li(r){switch(r){case"system":return"model";case"user":return"user";case"assistant":return"model";default:return"user"}}function pi(r,e={}){let t=[],o=null,i=[],n=()=>{o&&i.length&&(t.push({role:o,parts:[...i]}),i=[])};for(let s of r){let a=li(s.role);if(s.tool_calls){n();for(let l of s.tool_calls)e.callIdMap?.set(l.id,l.function.name),t.push({role:"model",parts:[{functionCall:{name:l.function.name,args:JSON.parse(l.function.arguments||"{}")}}]});continue}if(s.role==="tool"){n();let l=s.name??e.callIdMap?.get(s.tool_call_id)??"result";t.push({role:"user",parts:[{functionResponse:{name:l,response:hi(ui(s.content))}}]});continue}a!==o&&n(),o=a,i.push({text:s.content})}return n(),t}async function ci(r,e={}){let t=e.imageFetcher??_.get,o=e.blobToBase64??rr,i=[],n=null,s=[];for(let a of r){let l=li(a.role);if(a.tool_calls){for(let c of a.tool_calls)i.push({role:"model",parts:[{functionCall:{name:c.function.name,args:JSON.parse(c.function.arguments||"{}")}}]});continue}if(a.role==="tool"){let c=a.name??e.callIdMap?.get(a.tool_call_id)??"result";i.push({role:"user",parts:[{functionResponse:{name:c,response:hi(ui(a.content))}}]});continue}if(l!==n&&s.length>0&&(i.push({role:n,parts:[...s]}),s=[]),n=l,typeof a.content=="string")s.push({text:a.content});else if(Array.isArray(a.content)){for(let c of a.content)if(c.type==="text")s.push({text:c.text});else if(c.type==="image_url")try{let u=await(await t(c.image_url.url)).blob(),m=await o(u);s.push({inlineData:{mimeType:u.type||"image/jpeg",data:m.split(",")[1]}})}catch(d){throw console.error("Error processing image:",d),new Error(`Failed to process image: ${d.message}`)}}}return n&&s.length>0&&i.push({role:n,parts:[...s]}),i}function ui(r){try{return JSON.parse(r)}catch{return r}}function hi(r){return r===null?{content:null}:typeof r=="object"?r:{content:r}}function rr(r){return new Promise((e,t)=>{let o=new FileReader;o.onloadend=()=>e(o.result),o.onerror=t,o.readAsDataURL(r)})}function nr(r,e){return[...r,...e].map(t=>({name:t.name,description:t.description,parameters:t.parameters}))}function mi(r,e){let t=nr(r,e);if(t.length!==0)return{tools:[{functionDeclarations:t}],toolConfig:{functionCallingConfig:{mode:"AUTO"}}}}function di(r){return r.map(e=>({name:`mcp_${e.name}_search`,description:`Search using ${e.name} MCP server (fallback)`,parameters:{type:"object",properties:{query:{type:"string",description:"Search query"}},required:["query"]}}))}var me=class{constructor(e,t=X,o=X,i=[],n=[],s){this.provider="gemini";this.mcpToolSchemas=[];this.mcpSchemasInitialized=!1;this.callIdMap=new Map;if(this.apiKey=e,this.model=t,this.responseLength=s,!De.includes(o))throw new Error(`Model ${o} does not support vision capabilities.`);this.visionModel=o,this.tools=i,this.mcpServers=n}isGemma4Model(e){return/^gemma-4-/.test(e)}shouldMinimizeThinking(e){return e===We||this.isGemma4Model(e)}shouldExposeTextPart(e,t){return!(!e.text||this.isGemma4Model(t)&&e.thought===!0)}adaptKeysForApi(e){let t={toolConfig:"tool_config",functionCallingConfig:"function_calling_config",functionDeclarations:"function_declarations",functionCall:"function_call",functionResponse:"function_response"};return Array.isArray(e)?e.map(o=>this.adaptKeysForApi(o)):e&&typeof e=="object"?Object.fromEntries(Object.entries(e).map(([o,i])=>[t[o]??o,this.adaptKeysForApi(i)])):e}getModel(){return this.model}getVisionModel(){return this.visionModel}getMCPServers(){return this.mcpServers}addMCPServer(e){this.mcpServers.push(e),this.mcpSchemasInitialized=!1}removeMCPServer(e){this.mcpServers=this.mcpServers.filter(t=>t.name!==e),this.mcpSchemasInitialized=!1}hasMCPServers(){return this.mcpServers.length>0}async initializeMCPSchemas(){if(!(this.mcpSchemasInitialized||this.mcpServers.length===0))try{let e=new Promise((o,i)=>setTimeout(()=>i(new Error("MCP schema fetch timeout")),5e3)),t=kt.fetchAllToolSchemas(this.mcpServers);this.mcpToolSchemas=await Promise.race([t,e]),this.mcpSchemasInitialized=!0}catch(e){console.warn("Failed to initialize MCP schemas, using fallback:",e),this.mcpToolSchemas=di(this.mcpServers),this.mcpSchemasInitialized=!0}}async processChat(e,t,o){try{await f({hasTools:this.tools.length>0||this.mcpServers.length>0,runWithoutTools:async()=>{let i=await this.callGemini(e,this.model,!0),{blocks:n}=await this.parseStream(i,t,this.model);return M.getFullText(n)},runWithTools:()=>this.chatOnce(e,!0,t),onCompleteResponse:o,toolErrorMessage:"Received functionCall. Use chatOnce() loop when tools are enabled."})}catch(i){throw console.error("Error in processChat:",i),i}}async processVisionChat(e,t,o){try{await f({hasTools:this.tools.length>0||this.mcpServers.length>0,runWithoutTools:async()=>{let i=await this.callGemini(e,this.visionModel,!0),{blocks:n}=await this.parseStream(i,t,this.visionModel);return M.getFullText(n)},runWithTools:()=>this.visionChatOnce(e),onToolBlocks:i=>{i.filter(n=>n.type==="text").forEach(n=>t(n.text))},onCompleteResponse:o,toolErrorMessage:"Received functionCall. Use visionChatOnce() loop when tools are enabled."})}catch(i){throw console.error("Error in processVisionChat:",i),i}}async callGemini(e,t,o=!1,i){let a={contents:e.some(v=>Array.isArray(v.content)&&v.content.some(T=>T?.type==="image_url"||T?.inlineData))?await ci(e,{callIdMap:this.callIdMap}):pi(e,{callIdMap:this.callIdMap}),generationConfig:{maxOutputTokens:i!==void 0?i:E(this.responseLength)}};this.shouldMinimizeThinking(t)&&(a.generationConfig.thinkingConfig={includeThoughts:!1,thinkingLevel:"MINIMAL"});let l=[];if(this.mcpServers.length>0)try{await this.initializeMCPSchemas(),l=this.mcpToolSchemas}catch(v){console.warn("MCP initialization failed, skipping MCP tools:",v)}let c=mi(this.tools,l);c&&Object.assign(a,c);let d=async(v,T)=>{let fi=o?"streamGenerateContent":"generateContent",Co=o?"?alt=sse":"",Mi=`${zt}/${v}/models/${t}:${fi}${Co}${Co?"&":"?"}key=${this.apiKey}`;return _.post(Mi,T)},u=/flash[-_]lite/.test(t),m=this.isGemma4Model(t),p=/gemini-2\.5/.test(t),h=/^gemini-3(?:\.[0-9]+)?-/.test(t),g=u||m||p||h,S=g?"v1beta":"v1",A=async()=>{try{let v=S==="v1"?a:this.adaptKeysForApi(a);return await d(S,v)}catch(v){let T=/Unknown name|Cannot find field|404/.test(v?.message||"")||v?.status===404;if(!g&&T)return await d("v1beta",this.adaptKeysForApi(a));throw v}};try{return await A()}catch(v){throw v.body&&(console.error("Gemini API Error Details:",v.body),console.error("Request Body:",JSON.stringify(a,null,2))),v}}async parseStream(e,t,o){let i=e.body.getReader(),n=new TextDecoder,s=[],a=[],l="",c=u=>{if(!u||u==="[DONE]")return;let m;try{m=JSON.parse(u)}catch{return}for(let p of m.candidates??[])for(let h of p.content?.parts??[])this.shouldExposeTextPart(h,o)&&(t(h.text),M.addTextBlock(s,h.text)),h.functionCall&&a.push({type:"tool_use",id:this.genUUID(),name:h.functionCall.name,input:h.functionCall.args??{}}),h.functionResponse&&a.push({type:"tool_result",tool_use_id:h.functionResponse.name,content:JSON.stringify(h.functionResponse.response)})};for(;;){let{done:u,value:m}=await i.read();if(u)break;l+=n.decode(m,{stream:!0});let p;for(;(p=l.indexOf(`
14
- `))!==-1;){let h=l.slice(0,p);if(l=l.slice(p+1),h.endsWith("\r")&&(h=h.slice(0,-1)),!h.trim()){c("");continue}h.startsWith("data:")&&(h=h.slice(5).trim()),h&&c(h)}}return l&&c(l),{blocks:[...s,...a],stop_reason:a.some(u=>u.type==="tool_use")?"tool_use":"end"}}parseOneShot(e,t){let o=[],i=[];for(let s of e.candidates??[])for(let a of s.content?.parts??[])this.shouldExposeTextPart(a,t)&&o.push({type:"text",text:a.text}),a.functionCall&&i.push({type:"tool_use",id:this.genUUID(),name:a.functionCall.name,input:a.functionCall.args??{}}),a.functionResponse&&i.push({type:"tool_result",tool_use_id:a.functionResponse.name,content:JSON.stringify(a.functionResponse.response)});return{blocks:[...o,...i],stop_reason:i.some(s=>s.type==="tool_use")?"tool_use":"end"}}async chatOnce(e,t=!0,o=()=>{},i){let n=await this.callGemini(e,this.model,t,i);return t?this.parseStream(n,o,this.model):this.parseOneShot(await n.json(),this.model)}async visionChatOnce(e,t=!1,o=()=>{},i){let n=await this.callGemini(e,this.visionModel,t,i);return t?this.parseStream(n,o,this.visionModel):this.parseOneShot(await n.json(),this.visionModel)}genUUID(){return typeof crypto<"u"&&crypto.randomUUID?crypto.randomUUID():"xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx".replace(/[xy]/g,e=>{let t=Math.random()*16|0;return(e==="x"?t:t&3|8).toString(16)})}};var de=class{createChatService(e){let t=O({model:e.model,visionModel:e.visionModel,defaultModel:this.getDefaultModel(),defaultVisionModel:this.getDefaultModel(),supportsVisionForModel:o=>this.supportsVisionForModel(o),validate:"resolved"});return new me(e.apiKey,e.model||this.getDefaultModel(),t,e.tools||[],e.mcpServers||[],e.responseLength)}getProviderName(){return"gemini"}getSupportedModels(){return[...$e]}getDefaultModel(){return X}supportsVision(){return this.getVisionSupportLevel()!=="unsupported"}getVisionSupportLevel(){return"supported"}supportsVisionForModel(e){return De.includes(e)}getVisionSupportLevelForModel(e){return this.supportsVisionForModel(e)?"supported":"unsupported"}};function sr(){if(typeof globalThis<"u"&&"LanguageModel"in globalThis)return globalThis.LanguageModel}var ge=class{constructor(e={}){this.provider="gemini-nano";this.expectedInputLanguages=e.expectedInputLanguages??["ja"],this.expectedOutputLanguages=e.expectedOutputLanguages??["ja"],this._responseLength=e.responseLength}getModel(){return Y}getVisionModel(){return Y}async processChat(e,t,o){let i=await this.generateResponse(e);t(i),await o(i)}async processVisionChat(e,t,o){throw new Error("Gemini Nano does not support vision capabilities.")}async chatOnce(e,t=!1,o=()=>{},i){let n=await this.generateResponse(e);return o(n),{blocks:[{type:"text",text:n}],stop_reason:"end"}}async visionChatOnce(e,t=!1,o=()=>{},i){throw new Error("Gemini Nano does not support vision capabilities.")}async generateResponse(e){let t=sr();if(!t)throw new Error("Gemini Nano is not available in this environment. Chrome 138+ with Prompt API enabled is required.");let o=await t.availability();if(o!=="available"&&o!=="downloadable")throw new Error(`Gemini Nano Prompt API is not ready in this environment. LanguageModel.availability() returned "${o}". Expected "available" or "downloadable".`);let n=e.filter(c=>c.role==="system").map(c=>c.content).join(`
10
+ `;var Y="gemini-nano",vo=20;var H=class extends Error{constructor(t,o,i){super(`HTTP ${t}: ${o}`);this.status=t;this.statusText=o;this.body=i;this.name="HttpError"}},Fe=class Fe{static setFetch(e){this.fetchImpl=e}static async post(e,t,o={},i={}){let{timeout:n=3e4,retries:s=0,retryDelay:a=1e3}=i,c={...{"Content-Type":"application/json"},...o},d=null;for(let u=0;u<=s;u++)try{let m=typeof AbortController<"u",p=m?new AbortController:void 0,h=m?setTimeout(()=>p.abort(),n):void 0,g=await Fe.fetchImpl(e,{method:"POST",headers:c,body:typeof t=="string"?t:JSON.stringify(t),...p?{signal:p.signal}:{}});if(h&&clearTimeout(h),!g.ok){let S=await g.text();throw new H(g.status,g.statusText,S)}return g}catch(m){if(d=m,m instanceof H&&m.status>=400&&m.status<500)throw m;if(m instanceof Error&&m.name==="AbortError")throw new Error(`Request timeout after ${n}ms`);u<s&&await new Promise(p=>setTimeout(p,a*(u+1)))}throw d||new Error("Request failed")}static async handleErrorResponse(e){let t=await e.text();throw new H(e.status,e.statusText,t)}static async get(e,t={},o={}){let{timeout:i=3e4,retries:n=0,retryDelay:s=1e3}=o,a=null;for(let l=0;l<=n;l++)try{let c=typeof AbortController<"u",d=c?new AbortController:void 0,u=c?setTimeout(()=>d.abort(),i):void 0,m=await Fe.fetchImpl(e,{method:"GET",headers:t,...d?{signal:d.signal}:{}});if(u&&clearTimeout(u),!m.ok){let p=await m.text();throw new H(m.status,m.statusText,p)}return m}catch(c){if(a=c,c instanceof H&&c.status>=400&&c.status<500)throw c;if(c instanceof Error&&c.name==="AbortError")throw new Error(`Request timeout after ${i}ms`);l<n&&await new Promise(d=>setTimeout(d,s*(l+1)))}throw a||new Error("Request failed")}};Fe.fetchImpl=(e,t)=>fetch(e,t);var _=Fe;var M=class{static append(e,t){if(!t)return;let o=e[e.length-1];o&&o.type==="text"?o.text+=t:e.push({type:"text",text:t})}static getFullText(e){return e.filter(t=>t.type==="text").map(t=>t.text).join("")}static addTextBlock(e,t){t&&e.push({type:"text",text:t})}};var Ri=["happy","sad","angry","surprised","neutral"],qo=/\[([a-z]+)\]/i,Oo=/\[[a-z]+\]\s*/gi,le=class{static extractEmotion(e){let t=e.match(qo);if(t){let o=t[1].toLowerCase(),i=e.replace(Oo,"").trim();return{emotion:o,cleanText:i}}return{cleanText:e}}static isValidEmotion(e){return Ri.includes(e)}static cleanEmotionTags(e){return e.replace(Oo,"").trim()}static addEmotionTag(e,t){return`[${e}] ${t}`}};function zo(r){let{emotion:e,cleanText:t}=le.extractEmotion(r);return e?{emotion:e,text:t}:{text:t}}function bi(r){return r.map(e=>zo(e))}function Ni(r){return r.emotion?le.addEmotionTag(r.emotion,r.text):r.text}async function wi(r,e){let{blocks:t}=await r.chatOnce(e,!1,()=>{});return M.getFullText(t)}var Xo=(r,e)=>{try{return JSON.parse(r)}catch(t){if(e){e(r,t);return}throw t}},Eo=r=>typeof r=="string"?r:Array.isArray(r)?r.map(e=>typeof e=="string"?e:e&&typeof e=="object"&&e.type==="text"&&typeof e.text=="string"?e.text:"").join(""):"",Jo=async(r,e)=>{let t=r.body?.getReader();if(!t)throw new Error("Response body is null.");let o=new TextDecoder,i="",n=!1;for(;!n;){let{done:s,value:a}=await t.read();if(s)break;i+=o.decode(a,{stream:!0});let l=i.split(`
11
+ `);i=l.pop()||"";for(let c of l){let d=c.trim();if(!d||d.startsWith(":")||!d.startsWith("data:"))continue;let u=d.slice(5).trim();if(u==="[DONE]"){n=!0;break}e(u)}}};async function L(r,e,t={}){let o="";return await Jo(r,i=>{let n=Xo(i,t.onJsonError);if(!n)return;let s=Eo(n.choices?.[0]?.delta?.content);s&&(e(s),o+=s)}),o}async function P(r,e,t={}){let o=[],i=new Map,n,s,a=t.appendTextBlock??M.append;await Jo(r,d=>{let u=Xo(d,t.onJsonError);if(!u)return;let m=u.choices?.[0];typeof m?.finish_reason=="string"&&(n=m.finish_reason),u.usage&&(s=u.usage);let p=m?.delta,h=Eo(p?.content);h&&(e(h),a(o,h)),p?.tool_calls&&p.tool_calls.forEach(g=>{let S=i.get(g.index)??{id:g.id,name:g.function?.name,args:""};S.args+=g.function?.arguments||"",i.set(g.index,S)})});let l=Array.from(i.entries()).sort((d,u)=>d[0]-u[0]).map(([d,u])=>({type:"tool_use",id:u.id,name:u.name,input:JSON.parse(u.args||"{}")}));return{blocks:[...o,...l],stop_reason:l.length?"tool_use":"end",truncated:n==="length",finish_reason:n,usage:s}}function x(r){let e=r?.choices?.[0],t=[];if(e?.message?.tool_calls?.length)e.message.tool_calls.forEach(o=>t.push({type:"tool_use",id:o.id,name:o.function?.name,input:JSON.parse(o.function?.arguments||"{}")}));else{let o=Eo(e?.message?.content);o&&t.push({type:"text",text:o})}return{blocks:t,stop_reason:e?.finish_reason==="tool_calls"||t.some(o=>o.type==="tool_use")?"tool_use":"end",truncated:e?.finish_reason==="length",finish_reason:e?.finish_reason,usage:r?.usage}}var I=(r,e="chat-completions")=>r.length===0?[]:e==="responses"?r.map(t=>({type:"function",name:t.name,description:t.description,parameters:t.parameters})):r.map(t=>({type:"function",function:{name:t.name,description:t.description,parameters:t.parameters}}));async function f(r){if(!r.hasTools){let t=await r.runWithoutTools();await r.onCompleteResponse(t);return}let e=await r.runWithTools();if(r.onToolBlocks&&r.onToolBlocks(e.blocks),e.stop_reason==="end"){let t=M.getFullText(e.blocks);await r.onCompleteResponse(t);return}throw new Error(r.toolErrorMessage)}var O=r=>{let e=r.model??r.defaultModel,t=r.visionModel??(r.supportsVisionForModel(e)?e:r.defaultVisionModel);if(r.validate==="explicit"&&r.visionModel&&!r.supportsVisionForModel(r.visionModel))throw new Error(`Model ${r.visionModel} does not support vision capabilities.`);if(r.validate==="resolved"&&!r.supportsVisionForModel(t))throw new Error(`Model ${t} does not support vision capabilities.`);return t};var Vi="https://openrouter.ai/api/v1/models",ki=2,Gi=12e3,Fi=1,Ui=10;function So(r){return r instanceof Error?r.message:String(r)}function wt(r,e){return typeof r!="number"||!Number.isFinite(r)?e:Math.max(1,Math.floor(r))}function Hi(r){let e=new Set,t=[];for(let o of r){let i=o.trim();!i||e.has(i)||(e.add(i),t.push(i))}return t}async function Zo(r,e,t){if(!(typeof AbortController<"u"))return fetch(r,e);let i=new AbortController,n=setTimeout(()=>i.abort(),t);try{return await fetch(r,{...e,signal:i.signal})}catch(s){throw s instanceof Error&&s.name==="AbortError"?new Error(`Timeout after ${t}ms`):s}finally{clearTimeout(n)}}async function Yo(r){let e=`HTTP ${r.status} ${r.statusText}`.trim(),t="";try{t=await r.text()}catch{return e}let o=t.replace(/\s+/g," ").trim().slice(0,200);return o?`${e}: ${o}`:e}function Ki(r){if(!r||typeof r!="object")throw new Error("Invalid models response shape");let e=r,t=Array.isArray(e.data)?e.data:Array.isArray(e.models)?e.models:[];if(t.length===0)return[];let o=t.map(i=>i.id).filter(i=>typeof i=="string");return Hi(o)}async function Bi({modelId:r,apiKey:e,endpoint:t,timeoutMs:o,appName:i,appUrl:n}){let s={Authorization:`Bearer ${e}`,"Content-Type":"application/json"};i&&(s["X-Title"]=i),n&&(s["HTTP-Referer"]=n);try{let a=await Zo(t,{method:"POST",headers:s,body:JSON.stringify({model:r,messages:[{role:"user",content:"Reply only with OK."}],stream:!1})},o);if(!a.ok)return{id:r,ok:!1,reason:await Yo(a)};try{await a.json()}catch(l){return{id:r,ok:!1,reason:`JSON parse failed: ${So(l)}`}}return{id:r,ok:!0}}catch(a){return{id:r,ok:!1,reason:So(a)}}}async function Wi(r,e,t){if(r.length===0)return[];let o=new Array(r.length),i=0,n=Math.min(e,r.length);return await Promise.all(Array.from({length:n},async()=>{for(;i<r.length;){let s=i;i+=1,o[s]=await t(r[s])}})),o}async function $i(r){let e=r.apiKey.trim();if(!e)throw new Error("OpenRouter API key is required.");let t=r.modelsEndpoint||Vi,o=r.endpoint||be,i=wt(r.timeoutMs,Gi),n=wt(r.concurrency,ki),s=wt(r.maxCandidates,Fi),a=wt(r.maxWorking,Ui),l=await Zo(t,{method:"GET"},i);if(!l.ok)throw new Error(await Yo(l));let c;try{c=await l.json()}catch(h){throw new Error(`JSON parse failed: ${So(h)}`)}let d=Ki(c).filter(h=>J(h)).slice(0,s),u=await Wi(d,n,h=>Bi({modelId:h,apiKey:e,endpoint:o,timeoutMs:i,appName:r.appName,appUrl:r.appUrl})),m=u.filter(h=>h.ok).map(h=>h.id).slice(0,a),p=u.filter(h=>!h.ok).map(h=>({id:h.id,reason:h.reason||"Unknown error"}));return{working:m,failed:p,fetchedAt:Date.now()}}function Qo(r){return r.map(e=>({role:Vt(e.role),content:e.content}))}function ei(r){return r.map(e=>{if(typeof e.content=="string")return{role:Vt(e.role),content:[{type:"text",text:e.content}]};if(Array.isArray(e.content)){let t=e.content.map(o=>{if(o.type==="image_url"){if(o.image_url.url.startsWith("data:")){let i=o.image_url.url.match(/^data:([^;]+);base64,(.+)$/);return i?{type:"image",source:{type:"base64",media_type:i[1],data:i[2]}}:null}return{type:"image",source:{type:"url",url:o.image_url.url,media_type:ji(o.image_url.url)}}}return o}).filter(o=>o);return{role:Vt(e.role),content:t}}return{role:Vt(e.role),content:[]}})}function Vt(r){switch(r){case"system":return"system";case"user":return"user";case"assistant":return"assistant";default:return"user"}}function ji(r){switch(r.split(".").pop()?.toLowerCase()){case"jpg":case"jpeg":return"image/jpeg";case"png":return"image/png";case"gif":return"image/gif";case"webp":return"image/webp";default:return"image/jpeg"}}var pe=class{constructor(e,t=R,o=R,i=[],n=[],s){this.provider="claude";if(this.apiKey=e,this.model=t||R,this.visionModel=o||R,this.tools=i,this.mcpServers=n,this.responseLength=s,!Re.includes(this.visionModel))throw new Error(`Model ${this.visionModel} does not support vision capabilities.`)}getModel(){return this.model}getVisionModel(){return this.visionModel}getMCPServers(){return this.mcpServers}addMCPServer(e){this.mcpServers.push(e)}removeMCPServer(e){this.mcpServers=this.mcpServers.filter(t=>t.name!==e)}hasMCPServers(){return this.mcpServers.length>0}async processChat(e,t,o){await f({hasTools:this.tools.length>0||this.mcpServers.length>0,runWithoutTools:async()=>{let i=await this.callClaude(e,this.model,!0);return this.parsePureStream(i,t)},runWithTools:()=>this.chatOnce(e,!0,t),onCompleteResponse:o,toolErrorMessage:"processChat received tool_calls. ChatProcessor must use chatOnce() loop when tools are enabled."})}async processVisionChat(e,t,o){await f({hasTools:this.tools.length>0||this.mcpServers.length>0,runWithoutTools:async()=>{let i=await this.callClaude(e,this.visionModel,!0);return this.parsePureStream(i,t)},runWithTools:()=>this.visionChatOnce(e),onCompleteResponse:o,toolErrorMessage:"processVisionChat received tool_calls. ChatProcessor must use chatOnce() loop when tools are enabled."})}async callClaude(e,t,o,i){let n=e.find(u=>u.role==="system")?.content??"",s=e.filter(u=>u.role!=="system"),a=s.some(u=>Array.isArray(u.content)&&u.content.some(m=>m.type==="image_url"||m.type==="image")),l={model:t,system:n,messages:a?ei(s):Qo(s),stream:o,max_tokens:i!==void 0?i:E(this.responseLength)};this.tools.length&&(l.tools=this.tools.map(u=>({name:u.name,description:u.description,input_schema:u.parameters})),l.tool_choice={type:"auto"}),this.mcpServers.length>0&&(l.mcp_servers=this.mcpServers);let c={"Content-Type":"application/json","x-api-key":this.apiKey,"anthropic-version":"2023-06-01","anthropic-dangerous-direct-browser-access":"true"};return this.mcpServers.length>0&&(c["anthropic-beta"]="mcp-client-2025-04-04"),await _.post(Xt,l,c)}async parseStream(e,t){let o=e.body.getReader(),i=new TextDecoder,n=[],s=new Map,a="";for(;;){let{done:l,value:c}=await o.read();if(l)break;a+=i.decode(c,{stream:!0});let d;for(;(d=a.indexOf(`
12
+ `))!==-1;){let u=a.slice(0,d).trim();if(a=a.slice(d+1),!u.startsWith("data:"))continue;let m=u.slice(5).trim();if(m==="[DONE]")break;let p=JSON.parse(m);if(p.type==="content_block_delta"&&p.delta?.text&&(t(p.delta.text),n.push({type:"text",text:p.delta.text})),p.type==="content_block_start"&&p.content_block?.type==="tool_use"?s.set(p.index,{id:p.content_block.id,name:p.content_block.name,args:""}):p.type==="content_block_start"&&p.content_block?.type==="mcp_tool_use"?s.set(p.index,{id:p.content_block.id,name:p.content_block.name,args:"",server_name:p.content_block.server_name}):p.type==="content_block_start"&&p.content_block?.type==="tool_result"?n.push({type:"tool_result",tool_use_id:p.content_block.tool_use_id,content:p.content_block.content??""}):p.type==="content_block_start"&&p.content_block?.type==="mcp_tool_result"&&n.push({type:"mcp_tool_result",tool_use_id:p.content_block.tool_use_id,is_error:p.content_block.is_error??!1,content:p.content_block.content??[]}),p.type==="content_block_delta"&&p.delta?.type==="input_json_delta"){let h=s.get(p.index);h&&(h.args+=p.delta.partial_json||"")}if(p.type==="content_block_stop"&&s.has(p.index)){let{id:h,name:g,args:S,server_name:A}=s.get(p.index);A?n.push({type:"mcp_tool_use",id:h,name:g,server_name:A,input:JSON.parse(S||"{}")}):n.push({type:"tool_use",id:h,name:g,input:JSON.parse(S||"{}")}),s.delete(p.index)}}}return{blocks:n,stop_reason:n.some(l=>l.type==="tool_use"||l.type==="mcp_tool_use")?"tool_use":"end"}}async parsePureStream(e,t){let{blocks:o}=await this.parseStream(e,t);return o.filter(i=>i.type==="text").map(i=>i.text).join("")}parseOneShot(e){let t=[];return(e.content??[]).forEach(o=>{o.type==="text"?t.push({type:"text",text:o.text}):o.type==="tool_use"?t.push({type:"tool_use",id:o.id,name:o.name,input:o.input??{}}):o.type==="mcp_tool_use"?t.push({type:"mcp_tool_use",id:o.id,name:o.name,server_name:o.server_name,input:o.input??{}}):o.type==="tool_result"?t.push({type:"tool_result",tool_use_id:o.tool_use_id,content:o.content??""}):o.type==="mcp_tool_result"&&t.push({type:"mcp_tool_result",tool_use_id:o.tool_use_id,is_error:o.is_error??!1,content:o.content??[]})}),{blocks:t,stop_reason:t.some(o=>o.type==="tool_use"||o.type==="mcp_tool_use")?"tool_use":"end"}}async chatOnce(e,t=!0,o=()=>{},i){let n=await this.callClaude(e,this.model,t,i),s=t?await this.parseStream(n,o):this.parseOneShot(await n.json());return this.convertToStandardCompletion(s)}async visionChatOnce(e,t=!1,o=()=>{},i){let n=await this.callClaude(e,this.visionModel,t,i),s=t?await this.parseStream(n,o):this.parseOneShot(await n.json());return this.convertToStandardCompletion(s)}convertToStandardCompletion(e){return{blocks:e.blocks.filter(o=>o.type==="text"||o.type==="tool_use"||o.type==="tool_result"),stop_reason:e.stop_reason}}};var ce=class{createChatService(e){let t=O({model:e.model,visionModel:e.visionModel,defaultModel:this.getDefaultModel(),defaultVisionModel:this.getDefaultModel(),supportsVisionForModel:o=>this.supportsVisionForModel(o),validate:"resolved"});return new pe(e.apiKey,e.model||this.getDefaultModel(),t,e.tools??[],e.mcpServers??[],e.responseLength)}getProviderName(){return"claude"}getSupportedModels(){return[qe,ze,Xe,R,Je,Ze,Ye,Qe,et,je]}getDefaultModel(){return R}supportsVision(){return this.getVisionSupportLevel()!=="unsupported"}getVisionSupportLevel(){return"supported"}supportsVisionForModel(e){return Re.includes(e)}getVisionSupportLevelForModel(e){return this.supportsVisionForModel(e)?"supported":"unsupported"}};async function kt(r,e){let t=r.body.getReader(),o=new TextDecoder,i=[],n=new Map,s,a,l,c="";for(;;){let{done:u,value:m}=await t.read();if(u)break;c+=o.decode(m,{stream:!0});let p="",h="",g=c.split(`
13
+ `);c=g.pop()||"";for(let S=0;S<g.length;S++){let A=g[S].trim();if(A.startsWith("event:"))p=A.slice(6).trim();else if(A.startsWith("data:"))h=A.slice(5).trim();else if(A===""&&p&&h){try{let v=JSON.parse(h);qi(p,v,e,i,n,T=>{T.responseStatus!==void 0&&(s=T.responseStatus),T.incompleteDetails!==void 0&&(a=T.incompleteDetails),T.usage!==void 0&&(l=T.usage)})}catch{console.warn("Failed to parse SSE data:",h)}p="",h=""}}}let d=Array.from(n.values()).map(u=>({type:"tool_use",id:u.id,name:u.name,input:u.input||{}}));return{blocks:[...i,...d],stop_reason:d.length?"tool_use":"end",truncated:s==="incomplete",response_status:s,incomplete_details:a,usage:l}}function qi(r,e,t,o,i,n){switch(r){case"response.output_item.added":e.item?.type==="message"&&Array.isArray(e.item.content)?e.item.content.forEach(s=>{s.type==="output_text"&&s.text&&(t(s.text),M.append(o,s.text))}):e.item?.type==="function_call"&&i.set(e.item.id,{id:e.item.id,name:e.item.name,input:e.item.arguments?JSON.parse(e.item.arguments):{}});break;case"response.content_part.added":e.part?.type==="output_text"&&typeof e.part.text=="string"&&(t(e.part.text),M.append(o,e.part.text));break;case"response.output_text.delta":case"response.content_part.delta":{let s=typeof e.delta=="string"?e.delta:e.delta?.text??"";s&&(t(s),M.append(o,s));break}case"response.output_text.done":case"response.content_part.done":case"response.reasoning.started":case"response.reasoning.delta":case"response.reasoning.done":break;case"response.completed":n(ti(e,"completed"));break;case"response.incomplete":n(ti(e,"incomplete"));break;default:break}}function ti(r,e){let t=r?.response??r;return{responseStatus:t?.status??e,incompleteDetails:t?.incomplete_details??null,usage:t?.usage}}function oi(r){let e=[];return r.output&&Array.isArray(r.output)&&r.output.forEach(t=>{t.type==="message"&&t.content&&t.content.forEach(o=>{o.type==="output_text"&&o.text&&e.push({type:"text",text:o.text})}),t.type==="function_call"&&e.push({type:"tool_use",id:t.id,name:t.name,input:t.arguments?JSON.parse(t.arguments):{}})}),{blocks:e,stop_reason:e.some(t=>t.type==="tool_use")?"tool_use":"end",truncated:r?.status==="incomplete",response_status:r?.status,incomplete_details:r?.incomplete_details??null,usage:r?.usage}}function ii({tools:r,mcpServers:e,isResponsesAPI:t}){let o=[];return r.length>0&&o.push(...I(r,t?"responses":"chat-completions")),e.length>0&&t&&o.push(...zi(e)),o}function zi(r){return r.map(e=>{let t={type:"mcp",server_label:e.name,server_url:e.url};return e.require_approval&&(t.require_approval=e.require_approval),e.tool_configuration?.allowed_tools&&(t.allowed_tools=e.tool_configuration.allowed_tools),e.authorization_token&&(t.headers={Authorization:`Bearer ${e.authorization_token}`}),t})}var Xi={[C.VERY_SHORT]:800,[C.SHORT]:1200,[C.MEDIUM]:2e3,[C.LONG]:3e3,[C.VERY_LONG]:8e3,[C.DEEP]:25e3},Ji={none:1200,minimal:1600,low:2500,medium:4e3,high:8e3,xhigh:12e3},Zi=new Set(["openai-compatible","deepseek","mistral"]);function ri({provider:r,endpoint:e,messages:t,model:o,stream:i,tools:n,mcpServers:s,responseLength:a,verbosity:l,reasoning_effort:c,enableReasoningSummary:d,maxTokens:u}){let m=e===D;Qi(e,s);let p={model:o,stream:i},h=Yi({provider:r,model:o,responseLength:a,reasoning_effort:c,maxTokens:u});m?h!==void 0&&(p.max_output_tokens=h):h!==void 0&&(ni(r)?p.max_tokens=h:p.max_completion_tokens=h),m?p.input=er(t):p.messages=r==="mistral"?tr(t):t,z(o)&&(m?(c&&(p.reasoning={...p.reasoning,effort:c},d&&(p.reasoning.summary="auto")),l&&(p.text={...p.text,format:{type:"text"},verbosity:l})):(c&&(p.reasoning_effort=c),l&&(p.verbosity=l))),r==="mistral"&&Ge(o)&&c&&go(c)&&(p.reasoning_effort=c);let g=ii({tools:n,mcpServers:s,isResponsesAPI:m});return g.length>0&&(p.tools=g,m||(p.tool_choice="auto")),p}function Yi({provider:r,model:e,responseLength:t,reasoning_effort:o,maxTokens:i}){if(i!==void 0)return i;let n=ni(r)?t!==void 0?E(t):void 0:E(t);if(r!=="openai"||!z(e)||t===void 0)return n;let s=o??b(e);return Math.max(n??0,Xi[t],Ji[s])}function Qi(r,e){if(e.length>0&&r===K)throw new Error(`MCP servers are not supported with Chat Completions API. Current endpoint: ${r}. Please use OpenAI Responses API endpoint: ${D}. MCP tools are only available in the Responses API endpoint.`)}function er(r){return r.map(e=>{let o={role:e.role==="tool"?"user":e.role};return typeof e.content=="string"?o.content=e.content:Array.isArray(e.content)?o.content=e.content.map(i=>i.type==="text"?{type:"input_text",text:i.text}:i.type==="image_url"?{type:"input_image",image_url:i.image_url.url}:i):o.content=e.content,o})}function tr(r){return r.map(e=>{let t={role:e.role};return Array.isArray(e.content)?(t.content=e.content.map(o=>o.type==="image_url"&&typeof o.image_url=="object"&&typeof o.image_url?.url=="string"?{type:"image_url",image_url:o.image_url.url}:o),t):(t.content=e.content,t)})}function ni(r){return Zi.has(r)}var y=class{constructor(e,t=q,o=q,i,n=K,s=[],a,l,c,d=!1,u="openai",m=!0){if(this.provider=u,this.apiKey=e,this.model=t,this.tools=i||[],this.endpoint=n,this.mcpServers=s,this.responseLength=a,this.verbosity=l,this.reasoning_effort=c,this.enableReasoningSummary=d,m&&!Ae.includes(o))throw new Error(`Model ${o} does not support vision capabilities.`);this.visionModel=o}getModel(){return this.model}getVisionModel(){return this.visionModel}async processChat(e,t,o){await f({hasTools:this.tools.length>0,runWithoutTools:async()=>{let i=await this.callOpenAI(e,this.model,!0),n=this.endpoint===D;try{if(n){let s=await kt(i,t);return M.getFullText(s.blocks)}return this.handleStream(i,t)}catch(s){throw console.error("[processChat] Error in streaming/completion:",s),s}},runWithTools:()=>this.chatOnce(e,!0,t),onCompleteResponse:o,toolErrorMessage:"processChat received tool_calls. ChatProcessor must use chatOnce() loop when tools are enabled."})}async processVisionChat(e,t,o){try{await f({hasTools:this.tools.length>0,runWithoutTools:async()=>{let i=await this.callOpenAI(e,this.visionModel,!0),n=this.endpoint===D;try{if(n){let s=await kt(i,t);return M.getFullText(s.blocks)}return this.handleStream(i,t)}catch(s){throw console.error("[processVisionChat] Error in streaming/completion:",s),s}},runWithTools:()=>this.visionChatOnce(e,!0,t),onCompleteResponse:o,toolErrorMessage:"processVisionChat received tool_calls. ChatProcessor must use visionChatOnce() loop when tools are enabled."})}catch(i){throw console.error("Error in processVisionChat:",i),i}}async chatOnce(e,t=!0,o=()=>{},i){let n=await this.callOpenAI(e,this.model,t,i);return this.parseResponse(n,t,o)}async visionChatOnce(e,t=!1,o=()=>{},i){let n=await this.callOpenAI(e,this.visionModel,t,i);return this.parseResponse(n,t,o)}async parseResponse(e,t,o){return this.endpoint===D?t?kt(e,o):oi(await e.json()):t?this.parseStream(e,o):this.parseOneShot(await e.json())}async callOpenAI(e,t,o=!1,i){let n=ri({provider:this.provider,endpoint:this.endpoint,messages:e,model:t,stream:o,tools:this.tools,mcpServers:this.mcpServers,responseLength:this.responseLength,verbosity:this.verbosity,reasoning_effort:this.reasoning_effort,enableReasoningSummary:this.enableReasoningSummary,maxTokens:i}),s={};return(this.provider!=="openai-compatible"||this.apiKey.trim()!=="")&&(s.Authorization=`Bearer ${this.apiKey}`),await _.post(this.endpoint,n,s)}async handleStream(e,t){return L(e,t)}async parseStream(e,t){return P(e,t,{appendTextBlock:M.addTextBlock})}parseOneShot(e){return x(e)}};var ue=class extends y{constructor(e,t=ae,o=t,i,n=Ve,s){super(e,t,o,i,n,[],s,void 0,void 0,!1,"deepseek",!1)}};var he=class{createChatService(e){this.validateRequiredOptions(e);let t=e.model||this.getDefaultModel(),o=e.tools;return new ue(e.apiKey,t,e.visionModel??t,o,this.resolveEndpoint(e),e.responseLength)}getProviderName(){return"deepseek"}getSupportedModels(){return[...lo]}getDefaultModel(){return ae}supportsVision(){return!1}getVisionSupportLevel(){return"unsupported"}supportsVisionForModel(e){return!1}getVisionSupportLevelForModel(e){return"unsupported"}validateRequiredOptions(e){if(!e.apiKey?.trim())throw new Error("deepseek provider requires apiKey.")}resolveEndpoint(e){if(e.endpoint)return this.normalizeUrl(e.endpoint);if(e.baseUrl){let t=this.normalizeUrl(e.baseUrl);return t.endsWith("/chat/completions")?t:`${t}/chat/completions`}return Ve}normalizeUrl(e){return e.trim().replace(/\/+$/,"")}};var Gt=class{static async fetchToolSchemas(e){try{let t={"Content-Type":"application/json"};e.authorization_token&&(t.Authorization=`Bearer ${e.authorization_token}`);let i=await(await _.post(`${e.url}/tools`,{},t)).json();return Array.isArray(i.tools)?i.tools.map(n=>({name:`mcp_${e.name}_${n.name}`,description:n.description||`Tool from ${e.name} MCP server`,parameters:n.inputSchema||{type:"object",properties:{},required:[]}})):[{name:`mcp_${e.name}_search`,description:`Search using ${e.name} MCP server`,parameters:{type:"object",properties:{query:{type:"string",description:"Search query"}},required:["query"]}}]}catch(t){return console.warn(`Failed to fetch MCP schemas from ${e.name}:`,t),[{name:`mcp_${e.name}_search`,description:`Search using ${e.name} MCP server (schema fetch failed)`,parameters:{type:"object",properties:{query:{type:"string",description:"Search query"}},required:["query"]}}]}}static async fetchAllToolSchemas(e){let t=[];for(let o of e)try{let i=await this.fetchToolSchemas(o);t.push(...i)}catch(i){console.error(`Failed to fetch schemas from ${o.name}:`,i)}return t}};function si(r){switch(r){case"system":return"model";case"user":return"user";case"assistant":return"model";default:return"user"}}function ai(r,e={}){let t=[],o=null,i=[],n=()=>{o&&i.length&&(t.push({role:o,parts:[...i]}),i=[])};for(let s of r){let a=si(s.role);if(s.tool_calls){n();for(let l of s.tool_calls)e.callIdMap?.set(l.id,l.function.name),t.push({role:"model",parts:[{functionCall:{name:l.function.name,args:JSON.parse(l.function.arguments||"{}")}}]});continue}if(s.role==="tool"){n();let l=s.name??e.callIdMap?.get(s.tool_call_id)??"result";t.push({role:"user",parts:[{functionResponse:{name:l,response:ci(pi(s.content))}}]});continue}a!==o&&n(),o=a,i.push({text:s.content})}return n(),t}async function li(r,e={}){let t=e.imageFetcher??_.get,o=e.blobToBase64??or,i=[],n=null,s=[];for(let a of r){let l=si(a.role);if(a.tool_calls){for(let c of a.tool_calls)i.push({role:"model",parts:[{functionCall:{name:c.function.name,args:JSON.parse(c.function.arguments||"{}")}}]});continue}if(a.role==="tool"){let c=a.name??e.callIdMap?.get(a.tool_call_id)??"result";i.push({role:"user",parts:[{functionResponse:{name:c,response:ci(pi(a.content))}}]});continue}if(l!==n&&s.length>0&&(i.push({role:n,parts:[...s]}),s=[]),n=l,typeof a.content=="string")s.push({text:a.content});else if(Array.isArray(a.content)){for(let c of a.content)if(c.type==="text")s.push({text:c.text});else if(c.type==="image_url")try{let u=await(await t(c.image_url.url)).blob(),m=await o(u);s.push({inlineData:{mimeType:u.type||"image/jpeg",data:m.split(",")[1]}})}catch(d){throw console.error("Error processing image:",d),new Error(`Failed to process image: ${d.message}`)}}}return n&&s.length>0&&i.push({role:n,parts:[...s]}),i}function pi(r){try{return JSON.parse(r)}catch{return r}}function ci(r){return r===null?{content:null}:typeof r=="object"?r:{content:r}}function or(r){return new Promise((e,t)=>{let o=new FileReader;o.onloadend=()=>e(o.result),o.onerror=t,o.readAsDataURL(r)})}function ir(r,e){return[...r,...e].map(t=>({name:t.name,description:t.description,parameters:t.parameters}))}function ui(r,e){let t=ir(r,e);if(t.length!==0)return{tools:[{functionDeclarations:t}],toolConfig:{functionCallingConfig:{mode:"AUTO"}}}}function hi(r){return r.map(e=>({name:`mcp_${e.name}_search`,description:`Search using ${e.name} MCP server (fallback)`,parameters:{type:"object",properties:{query:{type:"string",description:"Search query"}},required:["query"]}}))}var me=class{constructor(e,t=X,o=X,i=[],n=[],s){this.provider="gemini";this.mcpToolSchemas=[];this.mcpSchemasInitialized=!1;this.callIdMap=new Map;if(this.apiKey=e,this.model=t,this.responseLength=s,!De.includes(o))throw new Error(`Model ${o} does not support vision capabilities.`);this.visionModel=o,this.tools=i,this.mcpServers=n}isGemma4Model(e){return/^gemma-4-/.test(e)}shouldMinimizeThinking(e){return e===We||this.isGemma4Model(e)}shouldExposeTextPart(e,t){return!(!e.text||this.isGemma4Model(t)&&e.thought===!0)}adaptKeysForApi(e){let t={toolConfig:"tool_config",functionCallingConfig:"function_calling_config",functionDeclarations:"function_declarations",functionCall:"function_call",functionResponse:"function_response"};return Array.isArray(e)?e.map(o=>this.adaptKeysForApi(o)):e&&typeof e=="object"?Object.fromEntries(Object.entries(e).map(([o,i])=>[t[o]??o,this.adaptKeysForApi(i)])):e}getModel(){return this.model}getVisionModel(){return this.visionModel}getMCPServers(){return this.mcpServers}addMCPServer(e){this.mcpServers.push(e),this.mcpSchemasInitialized=!1}removeMCPServer(e){this.mcpServers=this.mcpServers.filter(t=>t.name!==e),this.mcpSchemasInitialized=!1}hasMCPServers(){return this.mcpServers.length>0}async initializeMCPSchemas(){if(!(this.mcpSchemasInitialized||this.mcpServers.length===0))try{let e=new Promise((o,i)=>setTimeout(()=>i(new Error("MCP schema fetch timeout")),5e3)),t=Gt.fetchAllToolSchemas(this.mcpServers);this.mcpToolSchemas=await Promise.race([t,e]),this.mcpSchemasInitialized=!0}catch(e){console.warn("Failed to initialize MCP schemas, using fallback:",e),this.mcpToolSchemas=hi(this.mcpServers),this.mcpSchemasInitialized=!0}}async processChat(e,t,o){try{await f({hasTools:this.tools.length>0||this.mcpServers.length>0,runWithoutTools:async()=>{let i=await this.callGemini(e,this.model,!0),{blocks:n}=await this.parseStream(i,t,this.model);return M.getFullText(n)},runWithTools:()=>this.chatOnce(e,!0,t),onCompleteResponse:o,toolErrorMessage:"Received functionCall. Use chatOnce() loop when tools are enabled."})}catch(i){throw console.error("Error in processChat:",i),i}}async processVisionChat(e,t,o){try{await f({hasTools:this.tools.length>0||this.mcpServers.length>0,runWithoutTools:async()=>{let i=await this.callGemini(e,this.visionModel,!0),{blocks:n}=await this.parseStream(i,t,this.visionModel);return M.getFullText(n)},runWithTools:()=>this.visionChatOnce(e),onToolBlocks:i=>{i.filter(n=>n.type==="text").forEach(n=>t(n.text))},onCompleteResponse:o,toolErrorMessage:"Received functionCall. Use visionChatOnce() loop when tools are enabled."})}catch(i){throw console.error("Error in processVisionChat:",i),i}}async callGemini(e,t,o=!1,i){let a={contents:e.some(v=>Array.isArray(v.content)&&v.content.some(T=>T?.type==="image_url"||T?.inlineData))?await li(e,{callIdMap:this.callIdMap}):ai(e,{callIdMap:this.callIdMap}),generationConfig:{maxOutputTokens:i!==void 0?i:E(this.responseLength)}};this.shouldMinimizeThinking(t)&&(a.generationConfig.thinkingConfig={includeThoughts:!1,thinkingLevel:"MINIMAL"});let l=[];if(this.mcpServers.length>0)try{await this.initializeMCPSchemas(),l=this.mcpToolSchemas}catch(v){console.warn("MCP initialization failed, skipping MCP tools:",v)}let c=ui(this.tools,l);c&&Object.assign(a,c);let d=async(v,T)=>{let gi=o?"streamGenerateContent":"generateContent",Co=o?"?alt=sse":"",_i=`${zt}/${v}/models/${t}:${gi}${Co}${Co?"&":"?"}key=${this.apiKey}`;return _.post(_i,T)},u=/flash[-_]lite/.test(t),m=this.isGemma4Model(t),p=/gemini-2\.5/.test(t),h=/^gemini-3(?:\.[0-9]+)?-/.test(t),g=u||m||p||h,S=g?"v1beta":"v1",A=async()=>{try{let v=S==="v1"?a:this.adaptKeysForApi(a);return await d(S,v)}catch(v){let T=/Unknown name|Cannot find field|404/.test(v?.message||"")||v?.status===404;if(!g&&T)return await d("v1beta",this.adaptKeysForApi(a));throw v}};try{return await A()}catch(v){throw v.body&&(console.error("Gemini API Error Details:",v.body),console.error("Request Body:",JSON.stringify(a,null,2))),v}}async parseStream(e,t,o){let i=e.body.getReader(),n=new TextDecoder,s=[],a=[],l="",c=u=>{if(!u||u==="[DONE]")return;let m;try{m=JSON.parse(u)}catch{return}for(let p of m.candidates??[])for(let h of p.content?.parts??[])this.shouldExposeTextPart(h,o)&&(t(h.text),M.addTextBlock(s,h.text)),h.functionCall&&a.push({type:"tool_use",id:this.genUUID(),name:h.functionCall.name,input:h.functionCall.args??{}}),h.functionResponse&&a.push({type:"tool_result",tool_use_id:h.functionResponse.name,content:JSON.stringify(h.functionResponse.response)})};for(;;){let{done:u,value:m}=await i.read();if(u)break;l+=n.decode(m,{stream:!0});let p;for(;(p=l.indexOf(`
14
+ `))!==-1;){let h=l.slice(0,p);if(l=l.slice(p+1),h.endsWith("\r")&&(h=h.slice(0,-1)),!h.trim()){c("");continue}h.startsWith("data:")&&(h=h.slice(5).trim()),h&&c(h)}}return l&&c(l),{blocks:[...s,...a],stop_reason:a.some(u=>u.type==="tool_use")?"tool_use":"end"}}parseOneShot(e,t){let o=[],i=[];for(let s of e.candidates??[])for(let a of s.content?.parts??[])this.shouldExposeTextPart(a,t)&&o.push({type:"text",text:a.text}),a.functionCall&&i.push({type:"tool_use",id:this.genUUID(),name:a.functionCall.name,input:a.functionCall.args??{}}),a.functionResponse&&i.push({type:"tool_result",tool_use_id:a.functionResponse.name,content:JSON.stringify(a.functionResponse.response)});return{blocks:[...o,...i],stop_reason:i.some(s=>s.type==="tool_use")?"tool_use":"end"}}async chatOnce(e,t=!0,o=()=>{},i){let n=await this.callGemini(e,this.model,t,i);return t?this.parseStream(n,o,this.model):this.parseOneShot(await n.json(),this.model)}async visionChatOnce(e,t=!1,o=()=>{},i){let n=await this.callGemini(e,this.visionModel,t,i);return t?this.parseStream(n,o,this.visionModel):this.parseOneShot(await n.json(),this.visionModel)}genUUID(){return typeof crypto<"u"&&crypto.randomUUID?crypto.randomUUID():"xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx".replace(/[xy]/g,e=>{let t=Math.random()*16|0;return(e==="x"?t:t&3|8).toString(16)})}};var de=class{createChatService(e){let t=O({model:e.model,visionModel:e.visionModel,defaultModel:this.getDefaultModel(),defaultVisionModel:this.getDefaultModel(),supportsVisionForModel:o=>this.supportsVisionForModel(o),validate:"resolved"});return new me(e.apiKey,e.model||this.getDefaultModel(),t,e.tools||[],e.mcpServers||[],e.responseLength)}getProviderName(){return"gemini"}getSupportedModels(){return[...$e]}getDefaultModel(){return X}supportsVision(){return this.getVisionSupportLevel()!=="unsupported"}getVisionSupportLevel(){return"supported"}supportsVisionForModel(e){return De.includes(e)}getVisionSupportLevelForModel(e){return this.supportsVisionForModel(e)?"supported":"unsupported"}};function rr(){if(typeof globalThis<"u"&&"LanguageModel"in globalThis)return globalThis.LanguageModel}var ge=class{constructor(e={}){this.provider="gemini-nano";this.expectedInputLanguages=e.expectedInputLanguages??["ja"],this.expectedOutputLanguages=e.expectedOutputLanguages??["ja"],this._responseLength=e.responseLength}getModel(){return Y}getVisionModel(){return Y}async processChat(e,t,o){let i=await this.generateResponse(e);t(i),await o(i)}async processVisionChat(e,t,o){throw new Error("Gemini Nano does not support vision capabilities.")}async chatOnce(e,t=!1,o=()=>{},i){let n=await this.generateResponse(e);return o(n),{blocks:[{type:"text",text:n}],stop_reason:"end"}}async visionChatOnce(e,t=!1,o=()=>{},i){throw new Error("Gemini Nano does not support vision capabilities.")}async generateResponse(e){let t=rr();if(!t)throw new Error("Gemini Nano is not available in this environment. Chrome 138+ with Prompt API enabled is required.");let o=await t.availability();if(o!=="available"&&o!=="downloadable")throw new Error(`Gemini Nano Prompt API is not ready in this environment. LanguageModel.availability() returned "${o}". Expected "available" or "downloadable".`);let n=e.filter(c=>c.role==="system").map(c=>c.content).join(`
15
15
  `),s=e.filter(c=>c.role!=="system").slice(-20),a=[...s].reverse().find(c=>c.role==="user");if(!a)throw new Error("No user message found in the provided messages.");let l=await this.createSession(t,n,s);try{return await l.prompt(a.content)}finally{try{l.destroy()}catch{}}}async createSession(e,t,o){let i=this.buildSystemPrompt(t),n=o.slice(0,-1);if(n.length>0){let s=n.map(a=>`${a.role==="user"?"User":"Assistant"}: ${a.content}`).join(`
16
16
  `);i+=`
17
17
 
18
18
  The following is the prior conversation history. Use it as context for your response:
19
19
  `+s}return e.create({systemPrompt:i,expectedInputs:[{type:"text",languages:this.expectedInputLanguages}],expectedOutputs:[{type:"text",languages:this.expectedOutputLanguages}]})}buildSystemPrompt(e){let t=[];e&&t.push(e);let o=this.getResponseLengthInstruction();return o&&t.push(o),t.join(`
20
20
 
21
- `)}getResponseLengthInstruction(){if(!this._responseLength)return;let e=Nt[this._responseLength];if(e)return`Please keep your response concise, within approximately ${e} tokens.`}};var _e=class{createChatService(e){return new ge({expectedInputLanguages:e.expectedInputLanguages,expectedOutputLanguages:e.expectedOutputLanguages,responseLength:e.responseLength})}getProviderName(){return"gemini-nano"}getSupportedModels(){return[Y]}getDefaultModel(){return Y}supportsVision(){return!1}getVisionSupportLevel(){return"unsupported"}};var fe=class{constructor(e,t=w,o=w,i,n=ne,s,a,l){this.provider="kimi";this.apiKey=e,this.model=t,this.tools=i||[],this.endpoint=n,this.responseLength=s,this.responseFormat=a,this.thinking=l??{type:"enabled"},this.visionModel=o}getModel(){return this.model}getVisionModel(){return this.visionModel}async processChat(e,t,o){await f({hasTools:this.tools.length>0,runWithoutTools:async()=>{let i=await this.callKimi(e,this.model,!0);return this.handleStream(i,t)},runWithTools:()=>this.chatOnce(e,!0,t),onCompleteResponse:o,toolErrorMessage:"processChat received tool_calls. ChatProcessor must use chatOnce() loop when tools are enabled."})}async processVisionChat(e,t,o){if(!se(this.visionModel))throw new Error(`Model ${this.visionModel} does not support vision capabilities.`);await f({hasTools:this.tools.length>0,runWithoutTools:async()=>{let i=await this.callKimi(e,this.visionModel,!0);return this.handleStream(i,t)},runWithTools:()=>this.visionChatOnce(e,!0,t),onCompleteResponse:o,toolErrorMessage:"processVisionChat received tool_calls. ChatProcessor must use visionChatOnce() loop when tools are enabled."})}async chatOnce(e,t=!0,o=()=>{},i){let n=await this.callKimi(e,this.model,t,i);return this.parseResponse(n,t,o)}async visionChatOnce(e,t=!1,o=()=>{},i){if(!se(this.visionModel))throw new Error(`Model ${this.visionModel} does not support vision capabilities.`);let n=await this.callKimi(e,this.visionModel,t,i);return this.parseResponse(n,t,o)}async parseResponse(e,t,o){return t?this.parseStream(e,o):this.parseOneShot(await e.json())}async callKimi(e,t,o=!1,i){let n=this.buildRequestBody(e,t,o,i);return await _.post(this.endpoint,n,{Authorization:`Bearer ${this.apiKey}`})}buildRequestBody(e,t,o,i){let n={model:t,stream:o,messages:e},s=i!==void 0?i:E(this.responseLength);s!==void 0&&(n.max_tokens=s),this.responseFormat&&(n.response_format=this.responseFormat);let a=this.tools.length>0?{type:"disabled"}:this.thinking;a&&(this.isSelfHostedEndpoint()?a.type==="disabled"&&(n.chat_template_kwargs={thinking:!1}):n.thinking=a);let l=this.buildToolsDefinition();return l.length>0&&(n.tools=l,n.tool_choice="auto"),n}isSelfHostedEndpoint(){return this.normalizeEndpoint(this.endpoint)!==this.normalizeEndpoint(ne)}normalizeEndpoint(e){return e.replace(/\/+$/,"")}buildToolsDefinition(){return x(this.tools,"chat-completions")}async handleStream(e,t){return L(e,t,{onJsonError:o=>console.debug("Failed to parse SSE data:",o)})}async parseStream(e,t){return P(e,t,{onJsonError:o=>console.debug("Failed to parse SSE data:",o)})}parseOneShot(e){return I(e)}};var Me=class{createChatService(e){let t=this.resolveEndpoint(e),o=e.model||this.getDefaultModel(),i=O({model:o,visionModel:e.visionModel,defaultModel:this.getDefaultModel(),defaultVisionModel:this.getDefaultVisionModel(),supportsVisionForModel:l=>this.supportsVisionForModel(l),validate:"explicit"}),n=e.tools,s=e.thinking??{type:"enabled"},a=n&&n.length>0?{type:"disabled"}:s;return new fe(e.apiKey,o,i,n,t,e.responseLength,e.responseFormat,a)}getProviderName(){return"kimi"}getSupportedModels(){return[w,Rt]}getDefaultModel(){return w}getDefaultVisionModel(){return w}supportsVision(){return this.getVisionSupportLevel()!=="unsupported"}getVisionSupportLevel(){return"supported"}supportsVisionForModel(e){return se(e)}getVisionSupportLevelForModel(e){return this.supportsVisionForModel(e)?"supported":"unsupported"}resolveEndpoint(e){if(e.endpoint)return this.normalizeEndpoint(e.endpoint);if(e.baseUrl){let t=this.normalizeEndpoint(e.baseUrl);return t.endsWith("/chat/completions")?t:`${t}/chat/completions`}return ne}normalizeEndpoint(e){return e.replace(/\/+$/,"")}};var ve=class extends y{constructor(e,t=V,o=t,i,n=Ge,s,a){super(e,t,o,i,n,[],s,void 0,a,!1,"mistral",!1)}};var Oe=class{createChatService(e){this.validateRequiredOptions(e);let t=e.model||this.getDefaultModel(),o=O({model:t,visionModel:e.visionModel,defaultModel:this.getDefaultModel(),defaultVisionModel:this.getDefaultVisionModel(),supportsVisionForModel:s=>this.supportsVisionForModel(s),validate:"explicit"}),i=e.tools,n=ke(t)?e.reasoning_effort:void 0;return new ve(e.apiKey,t,o,i,this.resolveEndpoint(e),e.responseLength,n)}getProviderName(){return"mistral"}getSupportedModels(){return[...mo]}getDefaultModel(){return V}getDefaultVisionModel(){return V}supportsVision(){return this.getVisionSupportLevel()!=="unsupported"}getVisionSupportLevel(){return"supported"}supportsVisionForModel(e){return _o(e)}getVisionSupportLevelForModel(e){return this.supportsVisionForModel(e)?"supported":"unsupported"}validateRequiredOptions(e){if(!e.apiKey?.trim())throw new Error("mistral provider requires apiKey.")}resolveEndpoint(e){if(e.endpoint)return this.normalizeUrl(e.endpoint);if(e.baseUrl){let t=this.normalizeUrl(e.baseUrl);return t.endsWith("/chat/completions")?t:`${t}/chat/completions`}return Ge}normalizeUrl(e){return e.trim().replace(/\/+$/,"")}};var Ee=class{createChatService(e){return this.validateRequiredOptions(e),new y(e.apiKey?.trim()??"",e.model,e.visionModel??e.model,e.tools,e.endpoint,[],e.responseLength,e.verbosity,e.reasoning_effort,e.enableReasoningSummary,this.getProviderName(),!1)}getProviderName(){return"openai-compatible"}getSupportedModels(){return[]}supportsVision(){return this.getVisionSupportLevel()!=="unsupported"}getVisionSupportLevel(){return"unknown"}supportsVisionForModel(e){return!0}getVisionSupportLevelForModel(e){return"unknown"}getDefaultModel(){return"local-model"}validateRequiredOptions(e){if(e.mcpServers!==void 0)throw new Error("openai-compatible provider does not support mcpServers.");let t=e.endpoint?.trim();if(!t)throw new Error("openai-compatible provider requires endpoint (full URL).");let o;try{o=new URL(t)}catch{throw new Error("openai-compatible provider requires endpoint to be a full URL.")}if(o.protocol!=="http:"&&o.protocol!=="https:")throw new Error("openai-compatible provider requires endpoint to be a full URL.");if(!e.model?.trim())throw new Error("openai-compatible provider requires model.")}};var Se=class{createChatService(e){let t=this.optimizeGPT5Options(e),o=O({model:t.model,visionModel:t.visionModel,defaultModel:this.getDefaultModel(),defaultVisionModel:this.getDefaultModel(),supportsVisionForModel:c=>this.supportsVisionForModel(c),validate:"resolved"}),i=t.tools,n=t.mcpServers??[],s=t.model||this.getDefaultModel(),a=!1;n.length>0||Bt(s)?a=!0:z(s)&&(a=(t.gpt5EndpointPreference||"chat")==="responses");let l=t.endpoint||(a?D:K);return new y(t.apiKey,s,o,i,l,n,t.responseLength,t.verbosity,t.reasoning_effort,t.enableReasoningSummary,this.getProviderName())}getProviderName(){return"openai"}getSupportedModels(){return[B,Q,ee,W,G,k,$,j,F,Ue,He,Ke,q,Be,Ut,Ht,"o1"]}getDefaultModel(){return B}supportsVision(){return this.getVisionSupportLevel()!=="unsupported"}getVisionSupportLevel(){return"supported"}supportsVisionForModel(e){return Ae.includes(e)}getVisionSupportLevelForModel(e){return this.supportsVisionForModel(e)?"supported":"unsupported"}optimizeGPT5Options(e){let t=e.model||this.getDefaultModel();if(!z(t))return e;let o={...e};if(e.gpt5Preset){let i=Mo[e.gpt5Preset];o.reasoning_effort=i.reasoning_effort,o.verbosity=i.verbosity}else e.reasoning_effort||(o.reasoning_effort=b(t));return o.reasoning_effort=this.normalizeReasoningEffort(t,o.reasoning_effort),o}normalizeReasoningEffort(e,t){if(t)return t==="none"&&!$t(e)?b(e):t==="minimal"&&!jt(e)?b(e):t==="low"&&!qt(e)?b(e):t==="xhigh"&&!Wt(e)?b(e):t}};var Ce=class{constructor(e,t=U,o=U,i,n=be,s,a,l,c,d,u){this.provider="openrouter";this.lastRequestTime=0;this.requestCount=0;this.apiKey=e,this.model=t,this.tools=i||[],this.endpoint=n,this.responseLength=s,this.appName=a,this.appUrl=l,this.reasoning_effort=c,this.includeReasoning=d,this.reasoningMaxTokens=u,this.visionModel=o}getModel(){return this.model}getVisionModel(){return this.visionModel}async applyRateLimiting(){if(!J(this.model))return;let e=Date.now(),t=e-this.lastRequestTime;if(t>6e4&&(this.requestCount=0),this.requestCount>=to){let o=6e4-t;o>0&&(console.log(`Rate limit reached for free tier. Waiting ${o}ms...`),await new Promise(i=>setTimeout(i,o)),this.requestCount=0)}this.lastRequestTime=e,this.requestCount++}async processChat(e,t,o){await this.applyRateLimiting(),await f({hasTools:this.tools.length>0,runWithoutTools:async()=>{let i=await this.callOpenRouter(e,this.model,!0);return this.handleStream(i,t)},runWithTools:()=>this.chatOnce(e,!0,t),onCompleteResponse:o,toolErrorMessage:"processChat received tool_calls. ChatProcessor must use chatOnce() loop when tools are enabled."})}async processVisionChat(e,t,o){if(!te(this.visionModel))throw new Error(`Model ${this.visionModel} does not support vision capabilities.`);await this.applyRateLimiting();try{await f({hasTools:this.tools.length>0,runWithoutTools:async()=>{let i=await this.callOpenRouter(e,this.visionModel,!0);return this.handleStream(i,t)},runWithTools:()=>this.visionChatOnce(e,!0,t),onCompleteResponse:o,toolErrorMessage:"processVisionChat received tool_calls. ChatProcessor must use visionChatOnce() loop when tools are enabled."})}catch(i){throw console.error("Error in processVisionChat:",i),i}}async chatOnce(e,t=!0,o=()=>{},i){await this.applyRateLimiting();let n=await this.callOpenRouter(e,this.model,t,i);return t?this.parseStream(n,o):this.parseOneShot(await n.json())}async visionChatOnce(e,t=!1,o=()=>{},i){if(!te(this.visionModel))throw new Error(`Model ${this.visionModel} does not support vision capabilities.`);await this.applyRateLimiting();let n=await this.callOpenRouter(e,this.visionModel,t,i);return t?this.parseStream(n,o):this.parseOneShot(await n.json())}async callOpenRouter(e,t,o=!1,i){let n=this.buildRequestBody(e,t,o,i),s={Authorization:`Bearer ${this.apiKey}`};return this.appUrl&&(s["HTTP-Referer"]=this.appUrl),this.appName&&(s["X-Title"]=this.appName),await _.post(this.endpoint,n,s)}buildRequestBody(e,t,o,i){let n={model:t,messages:e,stream:o};if((i!==void 0?i:E(this.responseLength))&&console.warn("OpenRouter: Token limits are not supported for gpt-oss-20b model due to known issues. Using unlimited tokens instead."),this.reasoning_effort!==void 0||this.includeReasoning!==void 0||this.reasoningMaxTokens){if(n.reasoning={},this.reasoning_effort&&this.reasoning_effort!=="none"){let a=this.reasoning_effort==="minimal"?"low":this.reasoning_effort;n.reasoning.effort=a}(this.reasoning_effort==="none"||this.includeReasoning!==!0)&&(n.reasoning.exclude=!0),this.reasoningMaxTokens&&(n.reasoning.max_tokens=this.reasoningMaxTokens)}else n.reasoning={exclude:!0};return this.tools.length>0&&(n.tools=x(this.tools,"chat-completions"),n.tool_choice="auto"),n}async handleStream(e,t){return L(e,t,{onJsonError:o=>console.debug("Failed to parse SSE data:",o)})}async parseStream(e,t){return P(e,t,{onJsonError:o=>console.debug("Failed to parse SSE data:",o)})}parseOneShot(e){return I(e)}};var Te=class{createChatService(e){let t=O({model:e.model,visionModel:e.visionModel,defaultModel:this.getDefaultModel(),defaultVisionModel:e.model||this.getDefaultModel(),supportsVisionForModel:s=>this.supportsVisionForModel(s),validate:"explicit"}),o=e.tools,i=e.appName,n=e.appUrl;return new Ce(e.apiKey,e.model||this.getDefaultModel(),t,o,e.endpoint,e.responseLength,i,n,e.reasoning_effort,e.includeReasoning,e.reasoningMaxTokens)}getProviderName(){return"openrouter"}getSupportedModels(){return[Jt,U,yt,it,rt,nt,st,at,lt,pt,ct,ut,ht,mt,dt,gt,_t,ft,Mt,Zt,vt,Ot,Et,St,Ct,Tt,Yt,Qt,ot,tt]}getDefaultModel(){return U}supportsVision(){return this.getVisionSupportLevel()!=="unsupported"}getVisionSupportLevel(){return this.getSupportedModels().some(e=>this.supportsVisionForModel(e))?"supported":"unsupported"}supportsVisionForModel(e){return te(e)}getVisionSupportLevelForModel(e){return this.supportsVisionForModel(e)?"supported":"unsupported"}getFreeModels(){return eo}isModelFree(e){return J(e)}};var ye=class{constructor(e,t=N,o=N,i,n=we,s){this.provider="xai";this.apiKey=e,this.model=t,this.tools=i||[],this.endpoint=n,this.responseLength=s,this.visionModel=o}getModel(){return this.model}getVisionModel(){return this.visionModel}async processChat(e,t,o){await f({hasTools:this.tools.length>0,runWithoutTools:async()=>{let i=await this.callXAI(e,this.model,!0);return this.handleStream(i,t)},runWithTools:()=>this.chatOnce(e,!0,t),onCompleteResponse:o,toolErrorMessage:"processChat received tool_calls. ChatProcessor must use chatOnce() loop when tools are enabled."})}async processVisionChat(e,t,o){if(!re(this.visionModel))throw new Error(`Model ${this.visionModel} does not support vision capabilities.`);await f({hasTools:this.tools.length>0,runWithoutTools:async()=>{let i=await this.callXAI(e,this.visionModel,!0);return this.handleStream(i,t)},runWithTools:()=>this.visionChatOnce(e,!0,t),onCompleteResponse:o,toolErrorMessage:"processVisionChat received tool_calls. ChatProcessor must use visionChatOnce() loop when tools are enabled."})}async chatOnce(e,t=!0,o=()=>{},i){let n=await this.callXAI(e,this.model,t,i);return this.parseResponse(n,t,o)}async visionChatOnce(e,t=!1,o=()=>{},i){if(!re(this.visionModel))throw new Error(`Model ${this.visionModel} does not support vision capabilities.`);let n=await this.callXAI(e,this.visionModel,t,i);return this.parseResponse(n,t,o)}async parseResponse(e,t,o){return t?this.parseStream(e,o):this.parseOneShot(await e.json())}async callXAI(e,t,o=!1,i){let n=this.buildRequestBody(e,t,o,i);return await _.post(this.endpoint,n,{Authorization:`Bearer ${this.apiKey}`})}buildRequestBody(e,t,o,i){let n={model:t,stream:o,messages:e},s=i!==void 0?i:E(this.responseLength);s!==void 0&&(n.max_tokens=s);let a=this.buildToolsDefinition();return a.length>0&&(n.tools=a,n.tool_choice="auto"),n}buildToolsDefinition(){return x(this.tools,"chat-completions")}async handleStream(e,t){return L(e,t,{onJsonError:o=>console.debug("Failed to parse SSE data:",o)})}async parseStream(e,t){return P(e,t,{onJsonError:o=>console.debug("Failed to parse SSE data:",o)})}parseOneShot(e){return I(e)}};var Le=class{createChatService(e){let t=e.model||this.getDefaultModel(),o=O({model:t,visionModel:e.visionModel,defaultModel:this.getDefaultModel(),defaultVisionModel:this.getDefaultVisionModel(),supportsVisionForModel:n=>this.supportsVisionForModel(n),validate:"explicit"}),i=e.tools;return new ye(e.apiKey,t,o,i,e.endpoint||we,e.responseLength)}getProviderName(){return"xai"}getSupportedModels(){return[It,xt,At,Dt,N]}getDefaultModel(){return N}getDefaultVisionModel(){return N}supportsVision(){return this.getVisionSupportLevel()!=="unsupported"}getVisionSupportLevel(){return"supported"}supportsVisionForModel(e){return re(e)}getVisionSupportLevelForModel(e){return this.supportsVisionForModel(e)?"supported":"unsupported"}};var Pe=class{constructor(e,t=oe,o=Z,i,n=Ne,s,a,l){this.provider="zai";this.apiKey=e,this.model=t,this.tools=i||[],this.endpoint=n,this.responseLength=s,this.responseFormat=a,this.thinking=l??{type:"disabled"},this.visionModel=o}getModel(){return this.model}getVisionModel(){return this.visionModel}async processChat(e,t,o){await f({hasTools:this.tools.length>0,runWithoutTools:async()=>{let i=await this.callZAI(e,this.model,!0);return this.handleStream(i,t)},runWithTools:()=>this.chatOnce(e,!0,t),onCompleteResponse:o,toolErrorMessage:"processChat received tool_calls. ChatProcessor must use chatOnce() loop when tools are enabled."})}async processVisionChat(e,t,o){if(!ie(this.visionModel))throw new Error(`Model ${this.visionModel} does not support vision capabilities.`);await f({hasTools:this.tools.length>0,runWithoutTools:async()=>{let i=await this.callZAI(e,this.visionModel,!0);return this.handleStream(i,t)},runWithTools:()=>this.visionChatOnce(e,!0,t),onCompleteResponse:o,toolErrorMessage:"processVisionChat received tool_calls. ChatProcessor must use visionChatOnce() loop when tools are enabled."})}async chatOnce(e,t=!0,o=()=>{},i){let n=await this.callZAI(e,this.model,t,i);return this.parseResponse(n,t,o)}async visionChatOnce(e,t=!1,o=()=>{},i){if(!ie(this.visionModel))throw new Error(`Model ${this.visionModel} does not support vision capabilities.`);let n=await this.callZAI(e,this.visionModel,t,i);return this.parseResponse(n,t,o)}async parseResponse(e,t,o){return t?this.parseStream(e,o):this.parseOneShot(await e.json())}async callZAI(e,t,o=!1,i){let n=this.buildRequestBody(e,t,o,i);return await _.post(this.endpoint,n,{Authorization:`Bearer ${this.apiKey}`})}buildRequestBody(e,t,o,i){let n={model:t,stream:o,messages:e},s=i!==void 0?i:E(this.responseLength);s!==void 0&&(n.max_tokens=s),this.responseFormat&&(n.response_format=this.responseFormat),this.thinking&&(n.thinking=this.thinking);let a=this.buildToolsDefinition();return a.length>0&&(n.tools=a,n.tool_choice="auto",o&&ao(t)&&(n.tool_stream=!0)),n}buildToolsDefinition(){return x(this.tools,"chat-completions")}async handleStream(e,t){return L(e,t,{onJsonError:o=>console.debug("Failed to parse SSE data:",o)})}async parseStream(e,t){return P(e,t,{onJsonError:o=>console.debug("Failed to parse SSE data:",o)})}parseOneShot(e){return I(e)}};var Ie=class{createChatService(e){let t=e.model||this.getDefaultModel(),o=O({model:t,visionModel:e.visionModel,defaultModel:this.getDefaultModel(),defaultVisionModel:this.getDefaultVisionModel(),supportsVisionForModel:s=>this.supportsVisionForModel(s),validate:"explicit"}),i=e.tools,n=e.thinking??{type:"disabled"};return new Pe(e.apiKey,t,o,i,e.endpoint||Ne,e.responseLength,e.responseFormat,n)}getProviderName(){return"zai"}getSupportedModels(){return[oo,io,oe,ro,no,so,Lt,Pt,Z]}getDefaultModel(){return oe}getDefaultVisionModel(){return Z}supportsVision(){return this.getVisionSupportLevel()!=="unsupported"}getVisionSupportLevel(){return"supported"}supportsVisionForModel(e){return ie(e)}getVisionSupportLevelForModel(e){return this.supportsVisionForModel(e)?"supported":"unsupported"}};var gi=[new Se,new Ee,new de,new _e,new ce,new Te,new Ie,new Le,new Me,new he,new Oe];var xe=class{static registerProvider(e){this.providers.set(e.getProviderName(),e)}static createChatService(e,t){let o=this.providers.get(e);if(!o)throw new Error(`Unknown chat provider: ${e}`);return o.createChatService(t)}static getProviders(){return this.providers}static getAvailableProviders(){return Array.from(this.providers.keys())}static getSupportedModels(e){let t=this.providers.get(e);return t?t.getSupportedModels():[]}static getVisionSupportLevel(e){let t=this.providers.get(e);return t?t.getVisionSupportLevel():"unsupported"}static getVisionSupportLevelForModel(e,t){let o=this.providers.get(e);return o?o.getVisionSupportLevelForModel?o.getVisionSupportLevelForModel(t):o.supportsVisionForModel?o.supportsVisionForModel(t)?"supported":"unsupported":o.getVisionSupportLevel():"unsupported"}};xe.providers=new Map;gi.forEach(r=>xe.registerProvider(r));function _i(){_.setFetch(async(r,e={})=>{let t=(e.method||"GET").toString().toUpperCase(),o=e.headers,i={};if(Array.isArray(o))for(let[u,m]of o)i[u]=String(m);else if(o&&typeof o=="object")for(let[u,m]of Object.entries(o))i[u]=String(m);let n={method:t,headers:i,muteHttpExceptions:!0},s=e.body;typeof s=="string"?n.payload=s:s!=null&&(i["Content-Type"]||(i["Content-Type"]="application/json"),n.payload=JSON.stringify(s));let a=UrlFetchApp.fetch(r,n),l=a.getResponseCode(),c=a.getContentText();return{ok:l>=200&&l<300,status:l,statusText:String(l),text:async()=>c,json:async()=>c?JSON.parse(c):null}})}return Ti(ar);})();
21
+ `)}getResponseLengthInstruction(){if(!this._responseLength)return;let e=Nt[this._responseLength];if(e)return`Please keep your response concise, within approximately ${e} tokens.`}};var _e=class{createChatService(e){return new ge({expectedInputLanguages:e.expectedInputLanguages,expectedOutputLanguages:e.expectedOutputLanguages,responseLength:e.responseLength})}getProviderName(){return"gemini-nano"}getSupportedModels(){return[Y]}getDefaultModel(){return Y}supportsVision(){return!1}getVisionSupportLevel(){return"unsupported"}};var fe=class{constructor(e,t=w,o=w,i,n=ne,s,a,l){this.provider="kimi";this.apiKey=e,this.model=t,this.tools=i||[],this.endpoint=n,this.responseLength=s,this.responseFormat=a,this.thinking=l??{type:"enabled"},this.visionModel=o}getModel(){return this.model}getVisionModel(){return this.visionModel}async processChat(e,t,o){await f({hasTools:this.tools.length>0,runWithoutTools:async()=>{let i=await this.callKimi(e,this.model,!0);return this.handleStream(i,t)},runWithTools:()=>this.chatOnce(e,!0,t),onCompleteResponse:o,toolErrorMessage:"processChat received tool_calls. ChatProcessor must use chatOnce() loop when tools are enabled."})}async processVisionChat(e,t,o){if(!se(this.visionModel))throw new Error(`Model ${this.visionModel} does not support vision capabilities.`);await f({hasTools:this.tools.length>0,runWithoutTools:async()=>{let i=await this.callKimi(e,this.visionModel,!0);return this.handleStream(i,t)},runWithTools:()=>this.visionChatOnce(e,!0,t),onCompleteResponse:o,toolErrorMessage:"processVisionChat received tool_calls. ChatProcessor must use visionChatOnce() loop when tools are enabled."})}async chatOnce(e,t=!0,o=()=>{},i){let n=await this.callKimi(e,this.model,t,i);return this.parseResponse(n,t,o)}async visionChatOnce(e,t=!1,o=()=>{},i){if(!se(this.visionModel))throw new Error(`Model ${this.visionModel} does not support vision capabilities.`);let n=await this.callKimi(e,this.visionModel,t,i);return this.parseResponse(n,t,o)}async parseResponse(e,t,o){return t?this.parseStream(e,o):this.parseOneShot(await e.json())}async callKimi(e,t,o=!1,i){let n=this.buildRequestBody(e,t,o,i);return await _.post(this.endpoint,n,{Authorization:`Bearer ${this.apiKey}`})}buildRequestBody(e,t,o,i){let n={model:t,stream:o,messages:e},s=i!==void 0?i:E(this.responseLength);s!==void 0&&(n.max_tokens=s),this.responseFormat&&(n.response_format=this.responseFormat);let a=this.tools.length>0?{type:"disabled"}:this.thinking;a&&(this.isSelfHostedEndpoint()?a.type==="disabled"&&(n.chat_template_kwargs={thinking:!1}):n.thinking=a);let l=this.buildToolsDefinition();return l.length>0&&(n.tools=l,n.tool_choice="auto"),n}isSelfHostedEndpoint(){return this.normalizeEndpoint(this.endpoint)!==this.normalizeEndpoint(ne)}normalizeEndpoint(e){return e.replace(/\/+$/,"")}buildToolsDefinition(){return I(this.tools,"chat-completions")}async handleStream(e,t){return L(e,t,{onJsonError:o=>console.debug("Failed to parse SSE data:",o)})}async parseStream(e,t){return P(e,t,{onJsonError:o=>console.debug("Failed to parse SSE data:",o)})}parseOneShot(e){return x(e)}};var Me=class{createChatService(e){let t=this.resolveEndpoint(e),o=e.model||this.getDefaultModel(),i=O({model:o,visionModel:e.visionModel,defaultModel:this.getDefaultModel(),defaultVisionModel:this.getDefaultVisionModel(),supportsVisionForModel:l=>this.supportsVisionForModel(l),validate:"explicit"}),n=e.tools,s=e.thinking??{type:"enabled"},a=n&&n.length>0?{type:"disabled"}:s;return new fe(e.apiKey,o,i,n,t,e.responseLength,e.responseFormat,a)}getProviderName(){return"kimi"}getSupportedModels(){return[w,Rt]}getDefaultModel(){return w}getDefaultVisionModel(){return w}supportsVision(){return this.getVisionSupportLevel()!=="unsupported"}getVisionSupportLevel(){return"supported"}supportsVisionForModel(e){return se(e)}getVisionSupportLevelForModel(e){return this.supportsVisionForModel(e)?"supported":"unsupported"}resolveEndpoint(e){if(e.endpoint)return this.normalizeEndpoint(e.endpoint);if(e.baseUrl){let t=this.normalizeEndpoint(e.baseUrl);return t.endsWith("/chat/completions")?t:`${t}/chat/completions`}return ne}normalizeEndpoint(e){return e.replace(/\/+$/,"")}};var ve=class extends y{constructor(e,t=V,o=t,i,n=ke,s,a){super(e,t,o,i,n,[],s,void 0,a,!1,"mistral",!1)}};var Oe=class{createChatService(e){this.validateRequiredOptions(e);let t=e.model||this.getDefaultModel(),o=O({model:t,visionModel:e.visionModel,defaultModel:this.getDefaultModel(),defaultVisionModel:this.getDefaultVisionModel(),supportsVisionForModel:s=>this.supportsVisionForModel(s),validate:"explicit"}),i=e.tools,n=Ge(t)?e.reasoning_effort:void 0;return new ve(e.apiKey,t,o,i,this.resolveEndpoint(e),e.responseLength,n)}getProviderName(){return"mistral"}getSupportedModels(){return[...mo]}getDefaultModel(){return V}getDefaultVisionModel(){return V}supportsVision(){return this.getVisionSupportLevel()!=="unsupported"}getVisionSupportLevel(){return"supported"}supportsVisionForModel(e){return _o(e)}getVisionSupportLevelForModel(e){return this.supportsVisionForModel(e)?"supported":"unsupported"}validateRequiredOptions(e){if(!e.apiKey?.trim())throw new Error("mistral provider requires apiKey.")}resolveEndpoint(e){if(e.endpoint)return this.normalizeUrl(e.endpoint);if(e.baseUrl){let t=this.normalizeUrl(e.baseUrl);return t.endsWith("/chat/completions")?t:`${t}/chat/completions`}return ke}normalizeUrl(e){return e.trim().replace(/\/+$/,"")}};var Ee=class{createChatService(e){return this.validateRequiredOptions(e),new y(e.apiKey?.trim()??"",e.model,e.visionModel??e.model,e.tools,e.endpoint,[],e.responseLength,e.verbosity,e.reasoning_effort,e.enableReasoningSummary,this.getProviderName(),!1)}getProviderName(){return"openai-compatible"}getSupportedModels(){return[]}supportsVision(){return this.getVisionSupportLevel()!=="unsupported"}getVisionSupportLevel(){return"unknown"}supportsVisionForModel(e){return!0}getVisionSupportLevelForModel(e){return"unknown"}getDefaultModel(){return"local-model"}validateRequiredOptions(e){if(e.mcpServers!==void 0)throw new Error("openai-compatible provider does not support mcpServers.");let t=e.endpoint?.trim();if(!t)throw new Error("openai-compatible provider requires endpoint (full URL).");let o;try{o=new URL(t)}catch{throw new Error("openai-compatible provider requires endpoint to be a full URL.")}if(o.protocol!=="http:"&&o.protocol!=="https:")throw new Error("openai-compatible provider requires endpoint to be a full URL.");if(!e.model?.trim())throw new Error("openai-compatible provider requires model.")}};var Se=class{createChatService(e){let t=this.optimizeGPT5Options(e),o=O({model:t.model,visionModel:t.visionModel,defaultModel:this.getDefaultModel(),defaultVisionModel:this.getDefaultModel(),supportsVisionForModel:c=>this.supportsVisionForModel(c),validate:"resolved"}),i=t.tools,n=t.mcpServers??[],s=t.model||this.getDefaultModel(),a=!1;n.length>0||Bt(s)?a=!0:z(s)&&(a=(t.gpt5EndpointPreference||"chat")==="responses");let l=t.endpoint||(a?D:K);return new y(t.apiKey,s,o,i,l,n,t.responseLength,t.verbosity,t.reasoning_effort,t.enableReasoningSummary,this.getProviderName())}getProviderName(){return"openai"}getSupportedModels(){return[B,Q,ee,W,k,G,$,j,F,Ue,He,Ke,q,Be,Ut,Ht,"o1"]}getDefaultModel(){return B}supportsVision(){return this.getVisionSupportLevel()!=="unsupported"}getVisionSupportLevel(){return"supported"}supportsVisionForModel(e){return Ae.includes(e)}getVisionSupportLevelForModel(e){return this.supportsVisionForModel(e)?"supported":"unsupported"}optimizeGPT5Options(e){let t=e.model||this.getDefaultModel();if(!z(t))return e;let o={...e};if(e.gpt5Preset){let i=Mo[e.gpt5Preset];o.reasoning_effort=i.reasoning_effort,o.verbosity=i.verbosity}else e.reasoning_effort||(o.reasoning_effort=b(t));return o.reasoning_effort=this.normalizeReasoningEffort(t,o.reasoning_effort),o}normalizeReasoningEffort(e,t){if(t)return t==="none"&&!$t(e)?b(e):t==="minimal"&&!jt(e)?b(e):t==="low"&&!qt(e)?b(e):t==="xhigh"&&!Wt(e)?b(e):t}};var Ce=class{constructor(e,t=U,o=U,i,n=be,s,a,l,c,d,u){this.provider="openrouter";this.lastRequestTime=0;this.requestCount=0;this.apiKey=e,this.model=t,this.tools=i||[],this.endpoint=n,this.responseLength=s,this.appName=a,this.appUrl=l,this.reasoning_effort=c,this.includeReasoning=d,this.reasoningMaxTokens=u,this.visionModel=o}getModel(){return this.model}getVisionModel(){return this.visionModel}async applyRateLimiting(){if(!J(this.model))return;let e=Date.now(),t=e-this.lastRequestTime;if(t>6e4&&(this.requestCount=0),this.requestCount>=to){let o=6e4-t;o>0&&(console.log(`Rate limit reached for free tier. Waiting ${o}ms...`),await new Promise(i=>setTimeout(i,o)),this.requestCount=0)}this.lastRequestTime=e,this.requestCount++}async processChat(e,t,o){await this.applyRateLimiting(),await f({hasTools:this.tools.length>0,runWithoutTools:async()=>{let i=await this.callOpenRouter(e,this.model,!0);return this.handleStream(i,t)},runWithTools:()=>this.chatOnce(e,!0,t),onCompleteResponse:o,toolErrorMessage:"processChat received tool_calls. ChatProcessor must use chatOnce() loop when tools are enabled."})}async processVisionChat(e,t,o){if(!te(this.visionModel))throw new Error(`Model ${this.visionModel} does not support vision capabilities.`);await this.applyRateLimiting();try{await f({hasTools:this.tools.length>0,runWithoutTools:async()=>{let i=await this.callOpenRouter(e,this.visionModel,!0);return this.handleStream(i,t)},runWithTools:()=>this.visionChatOnce(e,!0,t),onCompleteResponse:o,toolErrorMessage:"processVisionChat received tool_calls. ChatProcessor must use visionChatOnce() loop when tools are enabled."})}catch(i){throw console.error("Error in processVisionChat:",i),i}}async chatOnce(e,t=!0,o=()=>{},i){await this.applyRateLimiting();let n=await this.callOpenRouter(e,this.model,t,i);return t?this.parseStream(n,o):this.parseOneShot(await n.json())}async visionChatOnce(e,t=!1,o=()=>{},i){if(!te(this.visionModel))throw new Error(`Model ${this.visionModel} does not support vision capabilities.`);await this.applyRateLimiting();let n=await this.callOpenRouter(e,this.visionModel,t,i);return t?this.parseStream(n,o):this.parseOneShot(await n.json())}async callOpenRouter(e,t,o=!1,i){let n=this.buildRequestBody(e,t,o,i),s={Authorization:`Bearer ${this.apiKey}`};return this.appUrl&&(s["HTTP-Referer"]=this.appUrl),this.appName&&(s["X-Title"]=this.appName),await _.post(this.endpoint,n,s)}buildRequestBody(e,t,o,i){let n={model:t,messages:e,stream:o};if((i!==void 0?i:E(this.responseLength))&&console.warn("OpenRouter: Token limits are not supported for gpt-oss-20b model due to known issues. Using unlimited tokens instead."),this.reasoning_effort!==void 0||this.includeReasoning!==void 0||this.reasoningMaxTokens){if(n.reasoning={},this.reasoning_effort&&this.reasoning_effort!=="none"){let a=this.reasoning_effort==="minimal"?"low":this.reasoning_effort;n.reasoning.effort=a}(this.reasoning_effort==="none"||this.includeReasoning!==!0)&&(n.reasoning.exclude=!0),this.reasoningMaxTokens&&(n.reasoning.max_tokens=this.reasoningMaxTokens)}else n.reasoning={exclude:!0};return this.tools.length>0&&(n.tools=I(this.tools,"chat-completions"),n.tool_choice="auto"),n}async handleStream(e,t){return L(e,t,{onJsonError:o=>console.debug("Failed to parse SSE data:",o)})}async parseStream(e,t){return P(e,t,{onJsonError:o=>console.debug("Failed to parse SSE data:",o)})}parseOneShot(e){return x(e)}};var Te=class{createChatService(e){let t=O({model:e.model,visionModel:e.visionModel,defaultModel:this.getDefaultModel(),defaultVisionModel:e.model||this.getDefaultModel(),supportsVisionForModel:s=>this.supportsVisionForModel(s),validate:"explicit"}),o=e.tools,i=e.appName,n=e.appUrl;return new Ce(e.apiKey,e.model||this.getDefaultModel(),t,o,e.endpoint,e.responseLength,i,n,e.reasoning_effort,e.includeReasoning,e.reasoningMaxTokens)}getProviderName(){return"openrouter"}getSupportedModels(){return[Jt,U,yt,it,rt,nt,st,at,lt,pt,ct,ut,ht,mt,dt,gt,_t,ft,Mt,Zt,vt,Ot,Et,St,Ct,Tt,Yt,Qt,ot,tt]}getDefaultModel(){return U}supportsVision(){return this.getVisionSupportLevel()!=="unsupported"}getVisionSupportLevel(){return this.getSupportedModels().some(e=>this.supportsVisionForModel(e))?"supported":"unsupported"}supportsVisionForModel(e){return te(e)}getVisionSupportLevelForModel(e){return this.supportsVisionForModel(e)?"supported":"unsupported"}getFreeModels(){return eo}isModelFree(e){return J(e)}};var ye=class{constructor(e,t=N,o=N,i,n=we,s){this.provider="xai";this.apiKey=e,this.model=t,this.tools=i||[],this.endpoint=n,this.responseLength=s,this.visionModel=o}getModel(){return this.model}getVisionModel(){return this.visionModel}async processChat(e,t,o){await f({hasTools:this.tools.length>0,runWithoutTools:async()=>{let i=await this.callXAI(e,this.model,!0);return this.handleStream(i,t)},runWithTools:()=>this.chatOnce(e,!0,t),onCompleteResponse:o,toolErrorMessage:"processChat received tool_calls. ChatProcessor must use chatOnce() loop when tools are enabled."})}async processVisionChat(e,t,o){if(!re(this.visionModel))throw new Error(`Model ${this.visionModel} does not support vision capabilities.`);await f({hasTools:this.tools.length>0,runWithoutTools:async()=>{let i=await this.callXAI(e,this.visionModel,!0);return this.handleStream(i,t)},runWithTools:()=>this.visionChatOnce(e,!0,t),onCompleteResponse:o,toolErrorMessage:"processVisionChat received tool_calls. ChatProcessor must use visionChatOnce() loop when tools are enabled."})}async chatOnce(e,t=!0,o=()=>{},i){let n=await this.callXAI(e,this.model,t,i);return this.parseResponse(n,t,o)}async visionChatOnce(e,t=!1,o=()=>{},i){if(!re(this.visionModel))throw new Error(`Model ${this.visionModel} does not support vision capabilities.`);let n=await this.callXAI(e,this.visionModel,t,i);return this.parseResponse(n,t,o)}async parseResponse(e,t,o){return t?this.parseStream(e,o):this.parseOneShot(await e.json())}async callXAI(e,t,o=!1,i){let n=this.buildRequestBody(e,t,o,i);return await _.post(this.endpoint,n,{Authorization:`Bearer ${this.apiKey}`})}buildRequestBody(e,t,o,i){let n={model:t,stream:o,messages:e},s=i!==void 0?i:E(this.responseLength);s!==void 0&&(n.max_tokens=s);let a=this.buildToolsDefinition();return a.length>0&&(n.tools=a,n.tool_choice="auto"),n}buildToolsDefinition(){return I(this.tools,"chat-completions")}async handleStream(e,t){return L(e,t,{onJsonError:o=>console.debug("Failed to parse SSE data:",o)})}async parseStream(e,t){return P(e,t,{onJsonError:o=>console.debug("Failed to parse SSE data:",o)})}parseOneShot(e){return x(e)}};var Le=class{createChatService(e){let t=e.model||this.getDefaultModel(),o=O({model:t,visionModel:e.visionModel,defaultModel:this.getDefaultModel(),defaultVisionModel:this.getDefaultVisionModel(),supportsVisionForModel:n=>this.supportsVisionForModel(n),validate:"explicit"}),i=e.tools;return new ye(e.apiKey,t,o,i,e.endpoint||we,e.responseLength)}getProviderName(){return"xai"}getSupportedModels(){return[xt,It,At,Dt,N]}getDefaultModel(){return N}getDefaultVisionModel(){return N}supportsVision(){return this.getVisionSupportLevel()!=="unsupported"}getVisionSupportLevel(){return"supported"}supportsVisionForModel(e){return re(e)}getVisionSupportLevelForModel(e){return this.supportsVisionForModel(e)?"supported":"unsupported"}};var Pe=class{constructor(e,t=oe,o=Z,i,n=Ne,s,a,l){this.provider="zai";this.apiKey=e,this.model=t,this.tools=i||[],this.endpoint=n,this.responseLength=s,this.responseFormat=a,this.thinking=l??{type:"disabled"},this.visionModel=o}getModel(){return this.model}getVisionModel(){return this.visionModel}async processChat(e,t,o){await f({hasTools:this.tools.length>0,runWithoutTools:async()=>{let i=await this.callZAI(e,this.model,!0);return this.handleStream(i,t)},runWithTools:()=>this.chatOnce(e,!0,t),onCompleteResponse:o,toolErrorMessage:"processChat received tool_calls. ChatProcessor must use chatOnce() loop when tools are enabled."})}async processVisionChat(e,t,o){if(!ie(this.visionModel))throw new Error(`Model ${this.visionModel} does not support vision capabilities.`);await f({hasTools:this.tools.length>0,runWithoutTools:async()=>{let i=await this.callZAI(e,this.visionModel,!0);return this.handleStream(i,t)},runWithTools:()=>this.visionChatOnce(e,!0,t),onCompleteResponse:o,toolErrorMessage:"processVisionChat received tool_calls. ChatProcessor must use visionChatOnce() loop when tools are enabled."})}async chatOnce(e,t=!0,o=()=>{},i){let n=await this.callZAI(e,this.model,t,i);return this.parseResponse(n,t,o)}async visionChatOnce(e,t=!1,o=()=>{},i){if(!ie(this.visionModel))throw new Error(`Model ${this.visionModel} does not support vision capabilities.`);let n=await this.callZAI(e,this.visionModel,t,i);return this.parseResponse(n,t,o)}async parseResponse(e,t,o){return t?this.parseStream(e,o):this.parseOneShot(await e.json())}async callZAI(e,t,o=!1,i){let n=this.buildRequestBody(e,t,o,i);return await _.post(this.endpoint,n,{Authorization:`Bearer ${this.apiKey}`})}buildRequestBody(e,t,o,i){let n={model:t,stream:o,messages:e},s=i!==void 0?i:E(this.responseLength);s!==void 0&&(n.max_tokens=s),this.responseFormat&&(n.response_format=this.responseFormat),this.thinking&&(n.thinking=this.thinking);let a=this.buildToolsDefinition();return a.length>0&&(n.tools=a,n.tool_choice="auto",o&&ao(t)&&(n.tool_stream=!0)),n}buildToolsDefinition(){return I(this.tools,"chat-completions")}async handleStream(e,t){return L(e,t,{onJsonError:o=>console.debug("Failed to parse SSE data:",o)})}async parseStream(e,t){return P(e,t,{onJsonError:o=>console.debug("Failed to parse SSE data:",o)})}parseOneShot(e){return x(e)}};var xe=class{createChatService(e){let t=e.model||this.getDefaultModel(),o=O({model:t,visionModel:e.visionModel,defaultModel:this.getDefaultModel(),defaultVisionModel:this.getDefaultVisionModel(),supportsVisionForModel:s=>this.supportsVisionForModel(s),validate:"explicit"}),i=e.tools,n=e.thinking??{type:"disabled"};return new Pe(e.apiKey,t,o,i,e.endpoint||Ne,e.responseLength,e.responseFormat,n)}getProviderName(){return"zai"}getSupportedModels(){return[oo,io,oe,ro,no,so,Lt,Pt,Z]}getDefaultModel(){return oe}getDefaultVisionModel(){return Z}supportsVision(){return this.getVisionSupportLevel()!=="unsupported"}getVisionSupportLevel(){return"supported"}supportsVisionForModel(e){return ie(e)}getVisionSupportLevelForModel(e){return this.supportsVisionForModel(e)?"supported":"unsupported"}};var mi=[new Se,new Ee,new de,new _e,new ce,new Te,new xe,new Le,new Me,new he,new Oe];var Ie=class{static registerProvider(e){this.providers.set(e.getProviderName(),e)}static createChatService(e,t){let o=this.providers.get(e);if(!o)throw new Error(`Unknown chat provider: ${e}`);return o.createChatService(t)}static getProviders(){return this.providers}static getAvailableProviders(){return Array.from(this.providers.keys())}static getSupportedModels(e){let t=this.providers.get(e);return t?t.getSupportedModels():[]}static getVisionSupportLevel(e){let t=this.providers.get(e);return t?t.getVisionSupportLevel():"unsupported"}static getVisionSupportLevelForModel(e,t){let o=this.providers.get(e);return o?o.getVisionSupportLevelForModel?o.getVisionSupportLevelForModel(t):o.supportsVisionForModel?o.supportsVisionForModel(t)?"supported":"unsupported":o.getVisionSupportLevel():"unsupported"}};Ie.providers=new Map;mi.forEach(r=>Ie.registerProvider(r));function di(){_.setFetch(async(r,e={})=>{let t=(e.method||"GET").toString().toUpperCase(),o=e.headers,i={};if(Array.isArray(o))for(let[u,m]of o)i[u]=String(m);else if(o&&typeof o=="object")for(let[u,m]of Object.entries(o))i[u]=String(m);let n={method:t,headers:i,muteHttpExceptions:!0},s=e.body;typeof s=="string"?n.payload=s:s!=null&&(i["Content-Type"]||(i["Content-Type"]="application/json"),n.payload=JSON.stringify(s));let a=UrlFetchApp.fetch(r,n),l=a.getResponseCode(),c=a.getContentText();return{ok:l>=200&&l<300,status:l,statusText:String(l),text:async()=>c,json:async()=>c?JSON.parse(c):null}})}return Si(nr);})();
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@aituber-onair/chat",
3
- "version": "0.36.0",
3
+ "version": "0.37.0",
4
4
  "description": "Chat and LLM API integration library for AITuber OnAir",
5
5
  "main": "dist/cjs/index.js",
6
6
  "module": "dist/esm/index.js",