@aituber-onair/chat 0.17.0 → 0.18.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
@@ -245,7 +245,7 @@ const claudeService = ChatServiceFactory.createChatService('claude', {
245
245
  ```typescript
246
246
  const geminiService = ChatServiceFactory.createChatService('gemini', {
247
247
  apiKey: process.env.GOOGLE_API_KEY,
248
- model: 'gemini-pro'
248
+ model: 'gemini-3.1-flash-lite-preview'
249
249
  });
250
250
  ```
251
251
 
@@ -572,7 +572,7 @@ type ChatResponseLength = 'veryShort' | 'short' | 'medium' | 'long' | 'veryLong'
572
572
  現在、以下のAIプロバイダーが組み込まれています:
573
573
 
574
574
  - **OpenAI**: GPT-5.1、GPT-5(Nano/Mini/Standard)、GPT-4.1(miniとnanoを含む), GPT-4, GPT-4o-mini, O3-mini, o1, o1-miniのモデルをサポート
575
- - **Gemini**: Gemini 3.1 Pro Preview, Gemini 3 Pro Preview, Gemini 3 Flash Preview, Gemini 2.5 Pro, Gemini 2.5 Flash, Gemini 2.5 Flash Lite Preview, Gemini 2.0 Flash, Gemini 2.0 Flash-Liteのモデルをサポート
575
+ - **Gemini**: Gemini 3.1 Pro Preview, Gemini 3.1 Flash-Lite Preview, Gemini 3 Pro Preview, Gemini 3 Flash Preview, Gemini 2.5 Pro, Gemini 2.5 Flash, Gemini 2.5 Flash Lite Preview, Gemini 2.0 Flash, Gemini 2.0 Flash-Liteのモデルをサポート
576
576
  - **Claude**: Claude Sonnet 4.6, Claude Opus 4.6, Claude Opus 4.5, Claude Sonnet 4.5, Claude Haiku 4.5, Claude 4 Sonnet, Claude 4 Opus, Claude 3.7 Sonnet, Claude 3.5 Haiku/Sonnet, Claude 3 Haikuのモデルをサポート
577
577
  - **OpenRouter**: OpenRouterのキュレーション済みモデル一覧(OpenAI/Claude/Gemini/Z.ai/Kimi)をサポート。モデルIDはOpenRouter節を参照してください
578
578
  - **Z.ai**: GLM-5(テキスト)、GLM-4.7/4.6(テキスト)、GLM-4.6V系(ビジョン)をサポート
package/README.md CHANGED
@@ -242,7 +242,7 @@ const claudeService = ChatServiceFactory.createChatService('claude', {
242
242
  ```typescript
243
243
  const geminiService = ChatServiceFactory.createChatService('gemini', {
244
244
  apiKey: process.env.GOOGLE_API_KEY,
245
- model: 'gemini-pro'
245
+ model: 'gemini-3.1-flash-lite-preview'
246
246
  });
247
247
  ```
248
248
 
@@ -568,7 +568,7 @@ type ChatResponseLength = 'veryShort' | 'short' | 'medium' | 'long' | 'veryLong'
568
568
  Currently, the following AI providers are built-in:
569
569
 
570
570
  - **OpenAI**: Supports models like 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
571
- - **Gemini**: Supports models like Gemini 3.1 Pro Preview, Gemini 3 Pro Preview, Gemini 3 Flash Preview, Gemini 2.5 Pro, Gemini 2.5 Flash, Gemini 2.5 Flash Lite Preview, Gemini 2.0 Flash, Gemini 2.0 Flash-Lite
571
+ - **Gemini**: Supports models like Gemini 3.1 Pro Preview, Gemini 3.1 Flash-Lite Preview, Gemini 3 Pro Preview, Gemini 3 Flash Preview, Gemini 2.5 Pro, Gemini 2.5 Flash, Gemini 2.5 Flash Lite Preview, Gemini 2.0 Flash, Gemini 2.0 Flash-Lite
572
572
  - **Claude**: Supports models like Claude Sonnet 4.6, Claude Opus 4.6, Claude Opus 4.5, Claude Sonnet 4.5, Claude Haiku 4.5, Claude 4 Sonnet, Claude 4 Opus, Claude 3.7 Sonnet, Claude 3.5 Haiku/Sonnet, Claude 3 Haiku
573
573
  - **OpenRouter**: Supports a curated OpenRouter model list (OpenAI/Claude/Gemini/Z.ai/Kimi). See the OpenRouter section for model IDs.
574
574
  - **Z.ai**: Supports GLM-5 (text), GLM-4.7/4.6 (text), and GLM-4.6V family (vision)
@@ -1,5 +1,6 @@
1
1
  export declare const ENDPOINT_GEMINI_API = "https://generativelanguage.googleapis.com";
2
2
  export declare const MODEL_GEMINI_3_1_PRO_PREVIEW = "gemini-3.1-pro-preview";
3
+ export declare const MODEL_GEMINI_3_1_FLASH_LITE_PREVIEW = "gemini-3.1-flash-lite-preview";
3
4
  export declare const MODEL_GEMINI_3_PRO_PREVIEW = "gemini-3-pro-preview";
4
5
  export declare const MODEL_GEMINI_3_FLASH_PREVIEW = "gemini-3-flash-preview";
5
6
  export declare const MODEL_GEMINI_2_5_PRO = "gemini-2.5-pro";
@@ -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,4BAA4B,2BAA2B,CAAC;AACrE,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,eAAO,MAAM,yCAAyC,wCACf,CAAC;AACxC,eAAO,MAAM,sBAAsB,qBAAqB,CAAC;AACzD,eAAO,MAAM,2BAA2B,0BAA0B,CAAC;AAGnE,eAAO,MAAM,8BAA8B,UAU1C,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,4BAA4B,2BAA2B,CAAC;AACrE,eAAO,MAAM,mCAAmC,kCACf,CAAC;AAClC,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,eAAO,MAAM,yCAAyC,wCACf,CAAC;AACxC,eAAO,MAAM,sBAAsB,qBAAqB,CAAC;AACzD,eAAO,MAAM,2BAA2B,0BAA0B,CAAC;AAGnE,eAAO,MAAM,8BAA8B,UAW1C,CAAC"}
@@ -1,10 +1,11 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.GEMINI_VISION_SUPPORTED_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_PRO_PREVIEW = exports.ENDPOINT_GEMINI_API = void 0;
3
+ exports.GEMINI_VISION_SUPPORTED_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_PRO_PREVIEW = exports.ENDPOINT_GEMINI_API = void 0;
4
4
  // API Endpoints
5
5
  exports.ENDPOINT_GEMINI_API = 'https://generativelanguage.googleapis.com';
6
6
  // gemini model
7
7
  exports.MODEL_GEMINI_3_1_PRO_PREVIEW = 'gemini-3.1-pro-preview';
8
+ exports.MODEL_GEMINI_3_1_FLASH_LITE_PREVIEW = 'gemini-3.1-flash-lite-preview';
8
9
  exports.MODEL_GEMINI_3_PRO_PREVIEW = 'gemini-3-pro-preview';
9
10
  exports.MODEL_GEMINI_3_FLASH_PREVIEW = 'gemini-3-flash-preview';
10
11
  exports.MODEL_GEMINI_2_5_PRO = 'gemini-2.5-pro';
@@ -16,6 +17,7 @@ exports.MODEL_GEMINI_2_0_FLASH_LITE = 'gemini-2.0-flash-lite';
16
17
  // Vision support for Gemini models
17
18
  exports.GEMINI_VISION_SUPPORTED_MODELS = [
18
19
  exports.MODEL_GEMINI_3_1_PRO_PREVIEW,
20
+ exports.MODEL_GEMINI_3_1_FLASH_LITE_PREVIEW,
19
21
  exports.MODEL_GEMINI_3_PRO_PREVIEW,
20
22
  exports.MODEL_GEMINI_3_FLASH_PREVIEW,
21
23
  exports.MODEL_GEMINI_2_5_PRO,
@@ -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,eAAe;AACF,QAAA,4BAA4B,GAAG,wBAAwB,CAAC;AACxD,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;AACtD,QAAA,yCAAyC,GACpD,qCAAqC,CAAC;AAC3B,QAAA,sBAAsB,GAAG,kBAAkB,CAAC;AAC5C,QAAA,2BAA2B,GAAG,uBAAuB,CAAC;AAEnE,mCAAmC;AACtB,QAAA,8BAA8B,GAAG;IAC5C,oCAA4B;IAC5B,kCAA0B;IAC1B,oCAA4B;IAC5B,4BAAoB;IACpB,8BAAsB;IACtB,mCAA2B;IAC3B,iDAAyC;IACzC,8BAAsB;IACtB,mCAA2B;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,eAAe;AACF,QAAA,4BAA4B,GAAG,wBAAwB,CAAC;AACxD,QAAA,mCAAmC,GAC9C,+BAA+B,CAAC;AACrB,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;AACtD,QAAA,yCAAyC,GACpD,qCAAqC,CAAC;AAC3B,QAAA,sBAAsB,GAAG,kBAAkB,CAAC;AAC5C,QAAA,2BAA2B,GAAG,uBAAuB,CAAC;AAEnE,mCAAmC;AACtB,QAAA,8BAA8B,GAAG;IAC5C,oCAA4B;IAC5B,2CAAmC;IACnC,kCAA0B;IAC1B,oCAA4B;IAC5B,4BAAoB;IACpB,8BAAsB;IACtB,mCAA2B;IAC3B,iDAAyC;IACzC,8BAAsB;IACtB,mCAA2B;CAC5B,CAAC"}
@@ -1 +1 @@
1
- {"version":3,"file":"GeminiChatServiceProvider.d.ts","sourceRoot":"","sources":["../../../../../src/services/providers/gemini/GeminiChatServiceProvider.ts"],"names":[],"mappings":"AAYA,OAAO,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAEhD,OAAO,EACL,wBAAwB,EACxB,mBAAmB,EACpB,MAAM,wBAAwB,CAAC;AAGhC;;GAEG;AACH,qBAAa,yBACX,YAAW,mBAAmB,CAAC,wBAAwB,CAAC;IAExD;;;;OAIG;IACH,iBAAiB,CAAC,OAAO,EAAE,wBAAwB,GAAG,WAAW;IAqBjE;;;OAGG;IACH,eAAe,IAAI,MAAM;IAIzB;;;OAGG;IACH,kBAAkB,IAAI,MAAM,EAAE;IAc9B;;;OAGG;IACH,eAAe,IAAI,MAAM;IAIzB;;;OAGG;IACH,cAAc,IAAI,OAAO;IAIzB;;;;OAIG;IACH,sBAAsB,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO;CAG/C"}
1
+ {"version":3,"file":"GeminiChatServiceProvider.d.ts","sourceRoot":"","sources":["../../../../../src/services/providers/gemini/GeminiChatServiceProvider.ts"],"names":[],"mappings":"AAaA,OAAO,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAEhD,OAAO,EACL,wBAAwB,EACxB,mBAAmB,EACpB,MAAM,wBAAwB,CAAC;AAGhC;;GAEG;AACH,qBAAa,yBACX,YAAW,mBAAmB,CAAC,wBAAwB,CAAC;IAExD;;;;OAIG;IACH,iBAAiB,CAAC,OAAO,EAAE,wBAAwB,GAAG,WAAW;IAqBjE;;;OAGG;IACH,eAAe,IAAI,MAAM;IAIzB;;;OAGG;IACH,kBAAkB,IAAI,MAAM,EAAE;IAe9B;;;OAGG;IACH,eAAe,IAAI,MAAM;IAIzB;;;OAGG;IACH,cAAc,IAAI,OAAO;IAIzB;;;;OAIG;IACH,sBAAsB,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO;CAG/C"}
@@ -39,6 +39,7 @@ class GeminiChatServiceProvider {
39
39
  getSupportedModels() {
40
40
  return [
41
41
  constants_1.MODEL_GEMINI_3_1_PRO_PREVIEW,
42
+ constants_1.MODEL_GEMINI_3_1_FLASH_LITE_PREVIEW,
42
43
  constants_1.MODEL_GEMINI_3_PRO_PREVIEW,
43
44
  constants_1.MODEL_GEMINI_3_FLASH_PREVIEW,
44
45
  constants_1.MODEL_GEMINI_2_5_PRO,
@@ -1 +1 @@
1
- {"version":3,"file":"GeminiChatServiceProvider.js","sourceRoot":"","sources":["../../../../../src/services/providers/gemini/GeminiChatServiceProvider.ts"],"names":[],"mappings":";;;AAAA,kDAW4B;AAE5B,2DAAwD;AAKxD,0CAAoD;AAEpD;;GAEG;AACH,MAAa,yBAAyB;IAGpC;;;;OAIG;IACH,iBAAiB,CAAC,OAAiC;QACjD,gFAAgF;QAChF,MAAM,WAAW,GAAG,IAAA,0BAAkB,EAAC;YACrC,KAAK,EAAE,OAAO,CAAC,KAAK;YACpB,WAAW,EAAE,OAAO,CAAC,WAAW;YAChC,YAAY,EAAE,IAAI,CAAC,eAAe,EAAE;YACpC,kBAAkB,EAAE,IAAI,CAAC,eAAe,EAAE;YAC1C,sBAAsB,EAAE,CAAC,KAAK,EAAE,EAAE,CAAC,IAAI,CAAC,sBAAsB,CAAC,KAAK,CAAC;YACrE,QAAQ,EAAE,UAAU;SACrB,CAAC,CAAC;QAEH,OAAO,IAAI,qCAAiB,CAC1B,OAAO,CAAC,MAAM,EACd,OAAO,CAAC,KAAK,IAAI,IAAI,CAAC,eAAe,EAAE,EACvC,WAAW,EACX,OAAO,CAAC,KAAK,IAAI,EAAE,EACnB,OAAO,CAAC,UAAU,IAAI,EAAE,EACxB,OAAO,CAAC,cAAc,CACvB,CAAC;IACJ,CAAC;IAED;;;OAGG;IACH,eAAe;QACb,OAAO,QAAQ,CAAC;IAClB,CAAC;IAED;;;OAGG;IACH,kBAAkB;QAChB,OAAO;YACL,wCAA4B;YAC5B,sCAA0B;YAC1B,wCAA4B;YAC5B,gCAAoB;YACpB,kCAAsB;YACtB,uCAA2B;YAC3B,qDAAyC;YACzC,kCAAsB;YACtB,uCAA2B;SAC5B,CAAC;IACJ,CAAC;IAED;;;OAGG;IACH,eAAe;QACb,OAAO,uCAA2B,CAAC;IACrC,CAAC;IAED;;;OAGG;IACH,cAAc;QACZ,OAAO,IAAI,CAAC;IACd,CAAC;IAED;;;;OAIG;IACH,sBAAsB,CAAC,KAAa;QAClC,OAAO,0CAA8B,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;IACxD,CAAC;CACF;AA/ED,8DA+EC"}
1
+ {"version":3,"file":"GeminiChatServiceProvider.js","sourceRoot":"","sources":["../../../../../src/services/providers/gemini/GeminiChatServiceProvider.ts"],"names":[],"mappings":";;;AAAA,kDAY4B;AAE5B,2DAAwD;AAKxD,0CAAoD;AAEpD;;GAEG;AACH,MAAa,yBAAyB;IAGpC;;;;OAIG;IACH,iBAAiB,CAAC,OAAiC;QACjD,gFAAgF;QAChF,MAAM,WAAW,GAAG,IAAA,0BAAkB,EAAC;YACrC,KAAK,EAAE,OAAO,CAAC,KAAK;YACpB,WAAW,EAAE,OAAO,CAAC,WAAW;YAChC,YAAY,EAAE,IAAI,CAAC,eAAe,EAAE;YACpC,kBAAkB,EAAE,IAAI,CAAC,eAAe,EAAE;YAC1C,sBAAsB,EAAE,CAAC,KAAK,EAAE,EAAE,CAAC,IAAI,CAAC,sBAAsB,CAAC,KAAK,CAAC;YACrE,QAAQ,EAAE,UAAU;SACrB,CAAC,CAAC;QAEH,OAAO,IAAI,qCAAiB,CAC1B,OAAO,CAAC,MAAM,EACd,OAAO,CAAC,KAAK,IAAI,IAAI,CAAC,eAAe,EAAE,EACvC,WAAW,EACX,OAAO,CAAC,KAAK,IAAI,EAAE,EACnB,OAAO,CAAC,UAAU,IAAI,EAAE,EACxB,OAAO,CAAC,cAAc,CACvB,CAAC;IACJ,CAAC;IAED;;;OAGG;IACH,eAAe;QACb,OAAO,QAAQ,CAAC;IAClB,CAAC;IAED;;;OAGG;IACH,kBAAkB;QAChB,OAAO;YACL,wCAA4B;YAC5B,+CAAmC;YACnC,sCAA0B;YAC1B,wCAA4B;YAC5B,gCAAoB;YACpB,kCAAsB;YACtB,uCAA2B;YAC3B,qDAAyC;YACzC,kCAAsB;YACtB,uCAA2B;SAC5B,CAAC;IACJ,CAAC;IAED;;;OAGG;IACH,eAAe;QACb,OAAO,uCAA2B,CAAC;IACrC,CAAC;IAED;;;OAGG;IACH,cAAc;QACZ,OAAO,IAAI,CAAC;IACd,CAAC;IAED;;;;OAIG;IACH,sBAAsB,CAAC,KAAa;QAClC,OAAO,0CAA8B,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;IACxD,CAAC;CACF;AAhFD,8DAgFC"}
@@ -1,5 +1,6 @@
1
1
  export declare const ENDPOINT_GEMINI_API = "https://generativelanguage.googleapis.com";
2
2
  export declare const MODEL_GEMINI_3_1_PRO_PREVIEW = "gemini-3.1-pro-preview";
3
+ export declare const MODEL_GEMINI_3_1_FLASH_LITE_PREVIEW = "gemini-3.1-flash-lite-preview";
3
4
  export declare const MODEL_GEMINI_3_PRO_PREVIEW = "gemini-3-pro-preview";
4
5
  export declare const MODEL_GEMINI_3_FLASH_PREVIEW = "gemini-3-flash-preview";
5
6
  export declare const MODEL_GEMINI_2_5_PRO = "gemini-2.5-pro";
@@ -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,4BAA4B,2BAA2B,CAAC;AACrE,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,eAAO,MAAM,yCAAyC,wCACf,CAAC;AACxC,eAAO,MAAM,sBAAsB,qBAAqB,CAAC;AACzD,eAAO,MAAM,2BAA2B,0BAA0B,CAAC;AAGnE,eAAO,MAAM,8BAA8B,UAU1C,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,4BAA4B,2BAA2B,CAAC;AACrE,eAAO,MAAM,mCAAmC,kCACf,CAAC;AAClC,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,eAAO,MAAM,yCAAyC,wCACf,CAAC;AACxC,eAAO,MAAM,sBAAsB,qBAAqB,CAAC;AACzD,eAAO,MAAM,2BAA2B,0BAA0B,CAAC;AAGnE,eAAO,MAAM,8BAA8B,UAW1C,CAAC"}
@@ -2,6 +2,7 @@
2
2
  export const ENDPOINT_GEMINI_API = 'https://generativelanguage.googleapis.com';
3
3
  // gemini model
4
4
  export const MODEL_GEMINI_3_1_PRO_PREVIEW = 'gemini-3.1-pro-preview';
5
+ export const MODEL_GEMINI_3_1_FLASH_LITE_PREVIEW = 'gemini-3.1-flash-lite-preview';
5
6
  export const MODEL_GEMINI_3_PRO_PREVIEW = 'gemini-3-pro-preview';
6
7
  export const MODEL_GEMINI_3_FLASH_PREVIEW = 'gemini-3-flash-preview';
7
8
  export const MODEL_GEMINI_2_5_PRO = 'gemini-2.5-pro';
@@ -13,6 +14,7 @@ export const MODEL_GEMINI_2_0_FLASH_LITE = 'gemini-2.0-flash-lite';
13
14
  // Vision support for Gemini models
14
15
  export const GEMINI_VISION_SUPPORTED_MODELS = [
15
16
  MODEL_GEMINI_3_1_PRO_PREVIEW,
17
+ MODEL_GEMINI_3_1_FLASH_LITE_PREVIEW,
16
18
  MODEL_GEMINI_3_PRO_PREVIEW,
17
19
  MODEL_GEMINI_3_FLASH_PREVIEW,
18
20
  MODEL_GEMINI_2_5_PRO,
@@ -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,eAAe;AACf,MAAM,CAAC,MAAM,4BAA4B,GAAG,wBAAwB,CAAC;AACrE,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,MAAM,CAAC,MAAM,yCAAyC,GACpD,qCAAqC,CAAC;AACxC,MAAM,CAAC,MAAM,sBAAsB,GAAG,kBAAkB,CAAC;AACzD,MAAM,CAAC,MAAM,2BAA2B,GAAG,uBAAuB,CAAC;AAEnE,mCAAmC;AACnC,MAAM,CAAC,MAAM,8BAA8B,GAAG;IAC5C,4BAA4B;IAC5B,0BAA0B;IAC1B,4BAA4B;IAC5B,oBAAoB;IACpB,sBAAsB;IACtB,2BAA2B;IAC3B,yCAAyC;IACzC,sBAAsB;IACtB,2BAA2B;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,eAAe;AACf,MAAM,CAAC,MAAM,4BAA4B,GAAG,wBAAwB,CAAC;AACrE,MAAM,CAAC,MAAM,mCAAmC,GAC9C,+BAA+B,CAAC;AAClC,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,MAAM,CAAC,MAAM,yCAAyC,GACpD,qCAAqC,CAAC;AACxC,MAAM,CAAC,MAAM,sBAAsB,GAAG,kBAAkB,CAAC;AACzD,MAAM,CAAC,MAAM,2BAA2B,GAAG,uBAAuB,CAAC;AAEnE,mCAAmC;AACnC,MAAM,CAAC,MAAM,8BAA8B,GAAG;IAC5C,4BAA4B;IAC5B,mCAAmC;IACnC,0BAA0B;IAC1B,4BAA4B;IAC5B,oBAAoB;IACpB,sBAAsB;IACtB,2BAA2B;IAC3B,yCAAyC;IACzC,sBAAsB;IACtB,2BAA2B;CAC5B,CAAC"}
@@ -1 +1 @@
1
- {"version":3,"file":"GeminiChatServiceProvider.d.ts","sourceRoot":"","sources":["../../../../../src/services/providers/gemini/GeminiChatServiceProvider.ts"],"names":[],"mappings":"AAYA,OAAO,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAEhD,OAAO,EACL,wBAAwB,EACxB,mBAAmB,EACpB,MAAM,wBAAwB,CAAC;AAGhC;;GAEG;AACH,qBAAa,yBACX,YAAW,mBAAmB,CAAC,wBAAwB,CAAC;IAExD;;;;OAIG;IACH,iBAAiB,CAAC,OAAO,EAAE,wBAAwB,GAAG,WAAW;IAqBjE;;;OAGG;IACH,eAAe,IAAI,MAAM;IAIzB;;;OAGG;IACH,kBAAkB,IAAI,MAAM,EAAE;IAc9B;;;OAGG;IACH,eAAe,IAAI,MAAM;IAIzB;;;OAGG;IACH,cAAc,IAAI,OAAO;IAIzB;;;;OAIG;IACH,sBAAsB,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO;CAG/C"}
1
+ {"version":3,"file":"GeminiChatServiceProvider.d.ts","sourceRoot":"","sources":["../../../../../src/services/providers/gemini/GeminiChatServiceProvider.ts"],"names":[],"mappings":"AAaA,OAAO,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAEhD,OAAO,EACL,wBAAwB,EACxB,mBAAmB,EACpB,MAAM,wBAAwB,CAAC;AAGhC;;GAEG;AACH,qBAAa,yBACX,YAAW,mBAAmB,CAAC,wBAAwB,CAAC;IAExD;;;;OAIG;IACH,iBAAiB,CAAC,OAAO,EAAE,wBAAwB,GAAG,WAAW;IAqBjE;;;OAGG;IACH,eAAe,IAAI,MAAM;IAIzB;;;OAGG;IACH,kBAAkB,IAAI,MAAM,EAAE;IAe9B;;;OAGG;IACH,eAAe,IAAI,MAAM;IAIzB;;;OAGG;IACH,cAAc,IAAI,OAAO;IAIzB;;;;OAIG;IACH,sBAAsB,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO;CAG/C"}
@@ -1,4 +1,4 @@
1
- import { MODEL_GEMINI_3_1_PRO_PREVIEW, MODEL_GEMINI_3_PRO_PREVIEW, MODEL_GEMINI_3_FLASH_PREVIEW, MODEL_GEMINI_2_5_PRO, MODEL_GEMINI_2_5_FLASH, MODEL_GEMINI_2_5_FLASH_LITE, MODEL_GEMINI_2_5_FLASH_LITE_PREVIEW_06_17, MODEL_GEMINI_2_0_FLASH, MODEL_GEMINI_2_0_FLASH_LITE, GEMINI_VISION_SUPPORTED_MODELS, } from '../../../constants';
1
+ import { MODEL_GEMINI_3_1_PRO_PREVIEW, MODEL_GEMINI_3_1_FLASH_LITE_PREVIEW, MODEL_GEMINI_3_PRO_PREVIEW, MODEL_GEMINI_3_FLASH_PREVIEW, MODEL_GEMINI_2_5_PRO, MODEL_GEMINI_2_5_FLASH, MODEL_GEMINI_2_5_FLASH_LITE, MODEL_GEMINI_2_5_FLASH_LITE_PREVIEW_06_17, MODEL_GEMINI_2_0_FLASH, MODEL_GEMINI_2_0_FLASH_LITE, GEMINI_VISION_SUPPORTED_MODELS, } from '../../../constants';
2
2
  import { GeminiChatService } from './GeminiChatService';
3
3
  import { resolveVisionModel } from '../../../utils';
4
4
  /**
@@ -36,6 +36,7 @@ export class GeminiChatServiceProvider {
36
36
  getSupportedModels() {
37
37
  return [
38
38
  MODEL_GEMINI_3_1_PRO_PREVIEW,
39
+ MODEL_GEMINI_3_1_FLASH_LITE_PREVIEW,
39
40
  MODEL_GEMINI_3_PRO_PREVIEW,
40
41
  MODEL_GEMINI_3_FLASH_PREVIEW,
41
42
  MODEL_GEMINI_2_5_PRO,
@@ -1 +1 @@
1
- {"version":3,"file":"GeminiChatServiceProvider.js","sourceRoot":"","sources":["../../../../../src/services/providers/gemini/GeminiChatServiceProvider.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,4BAA4B,EAC5B,0BAA0B,EAC1B,4BAA4B,EAC5B,oBAAoB,EACpB,sBAAsB,EACtB,2BAA2B,EAC3B,yCAAyC,EACzC,sBAAsB,EACtB,2BAA2B,EAC3B,8BAA8B,GAC/B,MAAM,oBAAoB,CAAC;AAE5B,OAAO,EAAE,iBAAiB,EAAE,MAAM,qBAAqB,CAAC;AAKxD,OAAO,EAAE,kBAAkB,EAAE,MAAM,gBAAgB,CAAC;AAEpD;;GAEG;AACH,MAAM,OAAO,yBAAyB;IAGpC;;;;OAIG;IACH,iBAAiB,CAAC,OAAiC;QACjD,gFAAgF;QAChF,MAAM,WAAW,GAAG,kBAAkB,CAAC;YACrC,KAAK,EAAE,OAAO,CAAC,KAAK;YACpB,WAAW,EAAE,OAAO,CAAC,WAAW;YAChC,YAAY,EAAE,IAAI,CAAC,eAAe,EAAE;YACpC,kBAAkB,EAAE,IAAI,CAAC,eAAe,EAAE;YAC1C,sBAAsB,EAAE,CAAC,KAAK,EAAE,EAAE,CAAC,IAAI,CAAC,sBAAsB,CAAC,KAAK,CAAC;YACrE,QAAQ,EAAE,UAAU;SACrB,CAAC,CAAC;QAEH,OAAO,IAAI,iBAAiB,CAC1B,OAAO,CAAC,MAAM,EACd,OAAO,CAAC,KAAK,IAAI,IAAI,CAAC,eAAe,EAAE,EACvC,WAAW,EACX,OAAO,CAAC,KAAK,IAAI,EAAE,EACnB,OAAO,CAAC,UAAU,IAAI,EAAE,EACxB,OAAO,CAAC,cAAc,CACvB,CAAC;IACJ,CAAC;IAED;;;OAGG;IACH,eAAe;QACb,OAAO,QAAQ,CAAC;IAClB,CAAC;IAED;;;OAGG;IACH,kBAAkB;QAChB,OAAO;YACL,4BAA4B;YAC5B,0BAA0B;YAC1B,4BAA4B;YAC5B,oBAAoB;YACpB,sBAAsB;YACtB,2BAA2B;YAC3B,yCAAyC;YACzC,sBAAsB;YACtB,2BAA2B;SAC5B,CAAC;IACJ,CAAC;IAED;;;OAGG;IACH,eAAe;QACb,OAAO,2BAA2B,CAAC;IACrC,CAAC;IAED;;;OAGG;IACH,cAAc;QACZ,OAAO,IAAI,CAAC;IACd,CAAC;IAED;;;;OAIG;IACH,sBAAsB,CAAC,KAAa;QAClC,OAAO,8BAA8B,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;IACxD,CAAC;CACF"}
1
+ {"version":3,"file":"GeminiChatServiceProvider.js","sourceRoot":"","sources":["../../../../../src/services/providers/gemini/GeminiChatServiceProvider.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,4BAA4B,EAC5B,mCAAmC,EACnC,0BAA0B,EAC1B,4BAA4B,EAC5B,oBAAoB,EACpB,sBAAsB,EACtB,2BAA2B,EAC3B,yCAAyC,EACzC,sBAAsB,EACtB,2BAA2B,EAC3B,8BAA8B,GAC/B,MAAM,oBAAoB,CAAC;AAE5B,OAAO,EAAE,iBAAiB,EAAE,MAAM,qBAAqB,CAAC;AAKxD,OAAO,EAAE,kBAAkB,EAAE,MAAM,gBAAgB,CAAC;AAEpD;;GAEG;AACH,MAAM,OAAO,yBAAyB;IAGpC;;;;OAIG;IACH,iBAAiB,CAAC,OAAiC;QACjD,gFAAgF;QAChF,MAAM,WAAW,GAAG,kBAAkB,CAAC;YACrC,KAAK,EAAE,OAAO,CAAC,KAAK;YACpB,WAAW,EAAE,OAAO,CAAC,WAAW;YAChC,YAAY,EAAE,IAAI,CAAC,eAAe,EAAE;YACpC,kBAAkB,EAAE,IAAI,CAAC,eAAe,EAAE;YAC1C,sBAAsB,EAAE,CAAC,KAAK,EAAE,EAAE,CAAC,IAAI,CAAC,sBAAsB,CAAC,KAAK,CAAC;YACrE,QAAQ,EAAE,UAAU;SACrB,CAAC,CAAC;QAEH,OAAO,IAAI,iBAAiB,CAC1B,OAAO,CAAC,MAAM,EACd,OAAO,CAAC,KAAK,IAAI,IAAI,CAAC,eAAe,EAAE,EACvC,WAAW,EACX,OAAO,CAAC,KAAK,IAAI,EAAE,EACnB,OAAO,CAAC,UAAU,IAAI,EAAE,EACxB,OAAO,CAAC,cAAc,CACvB,CAAC;IACJ,CAAC;IAED;;;OAGG;IACH,eAAe;QACb,OAAO,QAAQ,CAAC;IAClB,CAAC;IAED;;;OAGG;IACH,kBAAkB;QAChB,OAAO;YACL,4BAA4B;YAC5B,mCAAmC;YACnC,0BAA0B;YAC1B,4BAA4B;YAC5B,oBAAoB;YACpB,sBAAsB;YACtB,2BAA2B;YAC3B,yCAAyC;YACzC,sBAAsB;YACtB,2BAA2B;SAC5B,CAAC;IACJ,CAAC;IAED;;;OAGG;IACH,eAAe;QACb,OAAO,2BAA2B,CAAC;IACrC,CAAC;IAED;;;OAGG;IACH,cAAc;QACZ,OAAO,IAAI,CAAC;IACd,CAAC;IAED;;;;OAIG;IACH,sBAAsB,CAAC,KAAa;QAClC,OAAO,8BAA8B,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;IACxD,CAAC;CACF"}
@@ -72,6 +72,7 @@ var AITuberOnAirChat = (() => {
72
72
  MODEL_GEMINI_2_5_FLASH_LITE: () => MODEL_GEMINI_2_5_FLASH_LITE,
73
73
  MODEL_GEMINI_2_5_FLASH_LITE_PREVIEW_06_17: () => MODEL_GEMINI_2_5_FLASH_LITE_PREVIEW_06_17,
74
74
  MODEL_GEMINI_2_5_PRO: () => MODEL_GEMINI_2_5_PRO,
75
+ MODEL_GEMINI_3_1_FLASH_LITE_PREVIEW: () => MODEL_GEMINI_3_1_FLASH_LITE_PREVIEW,
75
76
  MODEL_GEMINI_3_1_PRO_PREVIEW: () => MODEL_GEMINI_3_1_PRO_PREVIEW,
76
77
  MODEL_GEMINI_3_FLASH_PREVIEW: () => MODEL_GEMINI_3_FLASH_PREVIEW,
77
78
  MODEL_GEMINI_3_PRO_PREVIEW: () => MODEL_GEMINI_3_PRO_PREVIEW,
@@ -197,6 +198,7 @@ var AITuberOnAirChat = (() => {
197
198
  // src/constants/gemini.ts
198
199
  var ENDPOINT_GEMINI_API = "https://generativelanguage.googleapis.com";
199
200
  var MODEL_GEMINI_3_1_PRO_PREVIEW = "gemini-3.1-pro-preview";
201
+ var MODEL_GEMINI_3_1_FLASH_LITE_PREVIEW = "gemini-3.1-flash-lite-preview";
200
202
  var MODEL_GEMINI_3_PRO_PREVIEW = "gemini-3-pro-preview";
201
203
  var MODEL_GEMINI_3_FLASH_PREVIEW = "gemini-3-flash-preview";
202
204
  var MODEL_GEMINI_2_5_PRO = "gemini-2.5-pro";
@@ -207,6 +209,7 @@ var AITuberOnAirChat = (() => {
207
209
  var MODEL_GEMINI_2_0_FLASH_LITE = "gemini-2.0-flash-lite";
208
210
  var GEMINI_VISION_SUPPORTED_MODELS = [
209
211
  MODEL_GEMINI_3_1_PRO_PREVIEW,
212
+ MODEL_GEMINI_3_1_FLASH_LITE_PREVIEW,
210
213
  MODEL_GEMINI_3_PRO_PREVIEW,
211
214
  MODEL_GEMINI_3_FLASH_PREVIEW,
212
215
  MODEL_GEMINI_2_5_PRO,
@@ -2245,6 +2248,7 @@ If it's in another language, summarize in that language.
2245
2248
  getSupportedModels() {
2246
2249
  return [
2247
2250
  MODEL_GEMINI_3_1_PRO_PREVIEW,
2251
+ MODEL_GEMINI_3_1_FLASH_LITE_PREVIEW,
2248
2252
  MODEL_GEMINI_3_PRO_PREVIEW,
2249
2253
  MODEL_GEMINI_3_FLASH_PREVIEW,
2250
2254
  MODEL_GEMINI_2_5_PRO,
@@ -1,4 +1,4 @@
1
- "use strict";var AITuberOnAirChat=(()=>{var st=Object.defineProperty;var Ht=Object.getOwnPropertyDescriptor;var Wt=Object.getOwnPropertyNames;var Bt=Object.prototype.hasOwnProperty;var Kt=(n,e)=>{for(var t in e)st(n,t,{get:e[t],enumerable:!0})},$t=(n,e,t,o)=>{if(e&&typeof e=="object"||typeof e=="function")for(let r of Wt(e))!Bt.call(n,r)&&r!==t&&st(n,r,{get:()=>e[r],enumerable:!(o=Ht(e,r))||o.enumerable});return n};var jt=n=>$t(st({},"__esModule",{value:!0}),n);var mo={};Kt(mo,{CHAT_RESPONSE_LENGTH:()=>F,CLAUDE_VISION_SUPPORTED_MODELS:()=>he,ChatServiceFactory:()=>ne,ChatServiceHttpClient:()=>g,ClaudeChatService:()=>q,ClaudeChatServiceProvider:()=>J,DEFAULT_MAX_TOKENS:()=>Et,DEFAULT_SUMMARY_PROMPT_TEMPLATE:()=>Xt,DEFAULT_VISION_PROMPT:()=>Zt,EMOTION_TAG_CLEANUP_REGEX:()=>Tt,EMOTION_TAG_REGEX:()=>Dt,ENDPOINT_CLAUDE_API:()=>ht,ENDPOINT_GEMINI_API:()=>ct,ENDPOINT_KIMI_CHAT_COMPLETIONS_API:()=>$,ENDPOINT_OPENAI_CHAT_COMPLETIONS_API:()=>G,ENDPOINT_OPENAI_RESPONSES_API:()=>y,ENDPOINT_OPENROUTER_API:()=>me,ENDPOINT_ZAI_CHAT_COMPLETIONS_API:()=>ue,EmotionParser:()=>z,GEMINI_VISION_SUPPORTED_MODELS:()=>ce,GPT5_PRESETS:()=>yt,GPT_5_MODELS:()=>xt,GeminiChatService:()=>Z,GeminiChatServiceProvider:()=>X,HttpError:()=>A,KIMI_VISION_SUPPORTED_MODELS:()=>Lt,KimiChatService:()=>Y,KimiChatServiceProvider:()=>Q,MAX_TOKENS_BY_LENGTH:()=>Rt,MODEL_ANTHROPIC_CLAUDE_3_5_SONNET:()=>mt,MODEL_ANTHROPIC_CLAUDE_3_7_SONNET:()=>ze,MODEL_ANTHROPIC_CLAUDE_4_5_HAIKU:()=>qe,MODEL_ANTHROPIC_CLAUDE_OPUS_4:()=>$e,MODEL_ANTHROPIC_CLAUDE_SONNET_4:()=>je,MODEL_CLAUDE_3_5_HAIKU:()=>xe,MODEL_CLAUDE_3_5_SONNET:()=>Ie,MODEL_CLAUDE_3_7_SONNET:()=>be,MODEL_CLAUDE_3_HAIKU:()=>T,MODEL_CLAUDE_4_5_HAIKU:()=>Ae,MODEL_CLAUDE_4_5_OPUS:()=>we,MODEL_CLAUDE_4_5_SONNET:()=>De,MODEL_CLAUDE_4_6_OPUS:()=>ke,MODEL_CLAUDE_4_6_SONNET:()=>Ne,MODEL_CLAUDE_4_OPUS:()=>Re,MODEL_CLAUDE_4_SONNET:()=>Le,MODEL_GEMINI_2_0_FLASH:()=>Pe,MODEL_GEMINI_2_0_FLASH_LITE:()=>R,MODEL_GEMINI_2_5_FLASH:()=>ye,MODEL_GEMINI_2_5_FLASH_LITE:()=>Te,MODEL_GEMINI_2_5_FLASH_LITE_PREVIEW_06_17:()=>Se,MODEL_GEMINI_2_5_PRO:()=>Ee,MODEL_GEMINI_3_1_PRO_PREVIEW:()=>Me,MODEL_GEMINI_3_FLASH_PREVIEW:()=>Oe,MODEL_GEMINI_3_PRO_PREVIEW:()=>Ce,MODEL_GLM_4_6:()=>Ct,MODEL_GLM_4_6V:()=>Qe,MODEL_GLM_4_6V_FLASH:()=>V,MODEL_GLM_4_6V_FLASHX:()=>et,MODEL_GLM_4_7:()=>B,MODEL_GLM_4_7_FLASH:()=>Mt,MODEL_GLM_4_7_FLASHX:()=>vt,MODEL_GLM_5:()=>ft,MODEL_GOOGLE_GEMINI_2_5_FLASH:()=>Ze,MODEL_GOOGLE_GEMINI_2_5_FLASH_LITE_PREVIEW_09_2025:()=>Xe,MODEL_GOOGLE_GEMINI_2_5_PRO:()=>Je,MODEL_GPT_4O:()=>ve,MODEL_GPT_4O_MINI:()=>N,MODEL_GPT_4_1:()=>_e,MODEL_GPT_4_1_MINI:()=>ge,MODEL_GPT_4_1_NANO:()=>fe,MODEL_GPT_5:()=>le,MODEL_GPT_5_1:()=>L,MODEL_GPT_5_MINI:()=>ae,MODEL_GPT_5_NANO:()=>U,MODEL_GPT_OSS_20B_FREE:()=>D,MODEL_KIMI_K2_5:()=>S,MODEL_MOONSHOTAI_KIMI_K2_5:()=>Ve,MODEL_O1:()=>at,MODEL_O1_MINI:()=>nt,MODEL_O3_MINI:()=>it,MODEL_OPENAI_GPT_4O:()=>We,MODEL_OPENAI_GPT_4_1_MINI:()=>Be,MODEL_OPENAI_GPT_4_1_NANO:()=>Ke,MODEL_OPENAI_GPT_5_1_CHAT:()=>Fe,MODEL_OPENAI_GPT_5_1_CODEX:()=>Ge,MODEL_OPENAI_GPT_5_MINI:()=>Ue,MODEL_OPENAI_GPT_5_NANO:()=>He,MODEL_ZAI_GLM_4_5_AIR:()=>dt,MODEL_ZAI_GLM_4_5_AIR_FREE:()=>Ye,MODEL_ZAI_GLM_4_7_FLASH:()=>ut,OPENROUTER_CREDITS_THRESHOLD:()=>Jt,OPENROUTER_FREE_DAILY_LIMIT_HIGH_CREDITS:()=>qt,OPENROUTER_FREE_DAILY_LIMIT_LOW_CREDITS:()=>zt,OPENROUTER_FREE_MODELS:()=>_t,OPENROUTER_FREE_RATE_LIMIT_PER_MINUTE:()=>gt,OPENROUTER_VISION_SUPPORTED_MODELS:()=>It,OpenAIChatService:()=>w,OpenAIChatServiceProvider:()=>te,OpenAICompatibleChatServiceProvider:()=>ee,OpenRouterChatService:()=>oe,OpenRouterChatServiceProvider:()=>re,StreamTextAccumulator:()=>f,VISION_SUPPORTED_MODELS:()=>pe,ZAIChatService:()=>se,ZAIChatServiceProvider:()=>ie,ZAI_VISION_SUPPORTED_MODELS:()=>bt,allowsReasoningMinimal:()=>pt,allowsReasoningNone:()=>lt,buildOpenAICompatibleTools:()=>b,getMaxTokensForResponseLength:()=>C,installGASFetch:()=>Gt,isGPT5Model:()=>H,isKimiVisionModel:()=>j,isOpenRouterFreeModel:()=>k,isOpenRouterVisionModel:()=>W,isZaiToolStreamModel:()=>Ot,isZaiVisionModel:()=>K,parseOpenAICompatibleOneShot:()=>I,parseOpenAICompatibleTextStream:()=>P,parseOpenAICompatibleToolStream:()=>x,processChatWithOptionalTools:()=>v,refreshOpenRouterFreeModels:()=>ho,resolveVisionModel:()=>O,runOnceText:()=>to,screenplayToText:()=>eo,textToScreenplay:()=>At,textsToScreenplay:()=>Qt});var G="https://api.openai.com/v1/chat/completions",y="https://api.openai.com/v1/responses",U="gpt-5-nano",ae="gpt-5-mini",le="gpt-5",L="gpt-5.1",_e="gpt-4.1",ge="gpt-4.1-mini",fe="gpt-4.1-nano",N="gpt-4o-mini",ve="gpt-4o",it="o3-mini",nt="o1-mini",at="o1",pe=[U,ae,le,L,_e,ge,fe,N,ve,"o1"],xt=[U,ae,le,L];function H(n){return xt.includes(n)}function lt(n){return n===L}function pt(n){return n!==L}var ct="https://generativelanguage.googleapis.com",Me="gemini-3.1-pro-preview",Ce="gemini-3-pro-preview",Oe="gemini-3-flash-preview",Ee="gemini-2.5-pro",ye="gemini-2.5-flash",Te="gemini-2.5-flash-lite",Se="gemini-2.5-flash-lite-preview-06-17",Pe="gemini-2.0-flash",R="gemini-2.0-flash-lite",ce=[Me,Ce,Oe,Ee,ye,Te,Se,Pe,R];var ht="https://api.anthropic.com/v1/messages",T="claude-3-haiku-20240307",xe="claude-3-5-haiku-20241022",Ie="claude-3-5-sonnet-20241022",be="claude-3-7-sonnet-20250219",Le="claude-4-sonnet-20250514",Re="claude-4-opus-20250514",De="claude-sonnet-4-5-20250929",Ae="claude-haiku-4-5-20251001",we="claude-opus-4-5-20251101",Ne="claude-sonnet-4-6",ke="claude-opus-4-6",he=[T,xe,Ie,be,Le,Re,De,Ae,we,Ne,ke];var me="https://openrouter.ai/api/v1/chat/completions",D="openai/gpt-oss-20b:free",Ve="moonshotai/kimi-k2.5",Fe="openai/gpt-5.1-chat",Ge="openai/gpt-5.1-codex",Ue="openai/gpt-5-mini",He="openai/gpt-5-nano",We="openai/gpt-4o",Be="openai/gpt-4.1-mini",Ke="openai/gpt-4.1-nano",$e="anthropic/claude-opus-4",je="anthropic/claude-sonnet-4",ze="anthropic/claude-3.7-sonnet",mt="anthropic/claude-3.5-sonnet",qe="anthropic/claude-haiku-4.5",Je="google/gemini-2.5-pro",Ze="google/gemini-2.5-flash",Xe="google/gemini-2.5-flash-lite-preview-09-2025",ut="z-ai/glm-4.7-flash",dt="z-ai/glm-4.5-air",Ye="z-ai/glm-4.5-air:free",_t=[D,Ye],It=[Fe,Ge,Ue,He,We,Be,Ke,$e,je,ze,qe,Je,Ze,Xe,Ve],gt=20,zt=50,qt=1e3,Jt=10;function k(n){return n.trim().endsWith(":free")}function W(n){return It.some(e=>n.includes(e))}var ue="https://api.z.ai/api/paas/v4/chat/completions",ft="glm-5",B="glm-4.7",vt="glm-4.7-FlashX",Mt="glm-4.7-Flash",Ct="glm-4.6",Qe="glm-4.6V",et="glm-4.6V-FlashX",V="glm-4.6V-Flash",bt=[Qe,et,V];function K(n){return bt.includes(n)}function Ot(n){return n.toLowerCase().startsWith("glm-4.6")}var $="https://api.moonshot.ai/v1/chat/completions",S="kimi-k2.5",Lt=[S];function j(n){return Lt.includes(n)}var F={VERY_SHORT:"veryShort",SHORT:"short",MEDIUM:"medium",LONG:"long",VERY_LONG:"veryLong",DEEP:"deep"},Rt={[F.VERY_SHORT]:40,[F.SHORT]:100,[F.MEDIUM]:200,[F.LONG]:300,[F.VERY_LONG]:1e3,[F.DEEP]:5e3},Et=5e3,yt={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 C(n){return n?Rt[n]??Et:Et}var Zt="You are a friendly AI avatar. Comment on the situation based on the broadcast screen.",Xt=`You are a skilled summarizing assistant.
1
+ "use strict";var AITuberOnAirChat=(()=>{var it=Object.defineProperty;var Wt=Object.getOwnPropertyDescriptor;var Bt=Object.getOwnPropertyNames;var Kt=Object.prototype.hasOwnProperty;var $t=(n,e)=>{for(var t in e)it(n,t,{get:e[t],enumerable:!0})},jt=(n,e,t,o)=>{if(e&&typeof e=="object"||typeof e=="function")for(let r of Bt(e))!Kt.call(n,r)&&r!==t&&it(n,r,{get:()=>e[r],enumerable:!(o=Wt(e,r))||o.enumerable});return n};var zt=n=>jt(it({},"__esModule",{value:!0}),n);var uo={};$t(uo,{CHAT_RESPONSE_LENGTH:()=>F,CLAUDE_VISION_SUPPORTED_MODELS:()=>he,ChatServiceFactory:()=>ne,ChatServiceHttpClient:()=>g,ClaudeChatService:()=>q,ClaudeChatServiceProvider:()=>J,DEFAULT_MAX_TOKENS:()=>yt,DEFAULT_SUMMARY_PROMPT_TEMPLATE:()=>Yt,DEFAULT_VISION_PROMPT:()=>Xt,EMOTION_TAG_CLEANUP_REGEX:()=>St,EMOTION_TAG_REGEX:()=>At,ENDPOINT_CLAUDE_API:()=>mt,ENDPOINT_GEMINI_API:()=>ht,ENDPOINT_KIMI_CHAT_COMPLETIONS_API:()=>$,ENDPOINT_OPENAI_CHAT_COMPLETIONS_API:()=>G,ENDPOINT_OPENAI_RESPONSES_API:()=>y,ENDPOINT_OPENROUTER_API:()=>me,ENDPOINT_ZAI_CHAT_COMPLETIONS_API:()=>ue,EmotionParser:()=>z,GEMINI_VISION_SUPPORTED_MODELS:()=>ce,GPT5_PRESETS:()=>Tt,GPT_5_MODELS:()=>It,GeminiChatService:()=>Z,GeminiChatServiceProvider:()=>X,HttpError:()=>A,KIMI_VISION_SUPPORTED_MODELS:()=>Rt,KimiChatService:()=>Y,KimiChatServiceProvider:()=>Q,MAX_TOKENS_BY_LENGTH:()=>Dt,MODEL_ANTHROPIC_CLAUDE_3_5_SONNET:()=>ut,MODEL_ANTHROPIC_CLAUDE_3_7_SONNET:()=>qe,MODEL_ANTHROPIC_CLAUDE_4_5_HAIKU:()=>Je,MODEL_ANTHROPIC_CLAUDE_OPUS_4:()=>je,MODEL_ANTHROPIC_CLAUDE_SONNET_4:()=>ze,MODEL_CLAUDE_3_5_HAIKU:()=>Ie,MODEL_CLAUDE_3_5_SONNET:()=>be,MODEL_CLAUDE_3_7_SONNET:()=>Le,MODEL_CLAUDE_3_HAIKU:()=>T,MODEL_CLAUDE_4_5_HAIKU:()=>we,MODEL_CLAUDE_4_5_OPUS:()=>Ne,MODEL_CLAUDE_4_5_SONNET:()=>Ae,MODEL_CLAUDE_4_6_OPUS:()=>Ve,MODEL_CLAUDE_4_6_SONNET:()=>ke,MODEL_CLAUDE_4_OPUS:()=>De,MODEL_CLAUDE_4_SONNET:()=>Re,MODEL_GEMINI_2_0_FLASH:()=>xe,MODEL_GEMINI_2_0_FLASH_LITE:()=>R,MODEL_GEMINI_2_5_FLASH:()=>Te,MODEL_GEMINI_2_5_FLASH_LITE:()=>Se,MODEL_GEMINI_2_5_FLASH_LITE_PREVIEW_06_17:()=>Pe,MODEL_GEMINI_2_5_PRO:()=>ye,MODEL_GEMINI_3_1_FLASH_LITE_PREVIEW:()=>Oe,MODEL_GEMINI_3_1_PRO_PREVIEW:()=>Me,MODEL_GEMINI_3_FLASH_PREVIEW:()=>Ee,MODEL_GEMINI_3_PRO_PREVIEW:()=>Ce,MODEL_GLM_4_6:()=>Ct,MODEL_GLM_4_6V:()=>et,MODEL_GLM_4_6V_FLASH:()=>V,MODEL_GLM_4_6V_FLASHX:()=>tt,MODEL_GLM_4_7:()=>B,MODEL_GLM_4_7_FLASH:()=>Ot,MODEL_GLM_4_7_FLASHX:()=>Mt,MODEL_GLM_5:()=>vt,MODEL_GOOGLE_GEMINI_2_5_FLASH:()=>Xe,MODEL_GOOGLE_GEMINI_2_5_FLASH_LITE_PREVIEW_09_2025:()=>Ye,MODEL_GOOGLE_GEMINI_2_5_PRO:()=>Ze,MODEL_GPT_4O:()=>ve,MODEL_GPT_4O_MINI:()=>N,MODEL_GPT_4_1:()=>_e,MODEL_GPT_4_1_MINI:()=>ge,MODEL_GPT_4_1_NANO:()=>fe,MODEL_GPT_5:()=>le,MODEL_GPT_5_1:()=>L,MODEL_GPT_5_MINI:()=>ae,MODEL_GPT_5_NANO:()=>U,MODEL_GPT_OSS_20B_FREE:()=>D,MODEL_KIMI_K2_5:()=>S,MODEL_MOONSHOTAI_KIMI_K2_5:()=>Fe,MODEL_O1:()=>lt,MODEL_O1_MINI:()=>at,MODEL_O3_MINI:()=>nt,MODEL_OPENAI_GPT_4O:()=>Be,MODEL_OPENAI_GPT_4_1_MINI:()=>Ke,MODEL_OPENAI_GPT_4_1_NANO:()=>$e,MODEL_OPENAI_GPT_5_1_CHAT:()=>Ge,MODEL_OPENAI_GPT_5_1_CODEX:()=>Ue,MODEL_OPENAI_GPT_5_MINI:()=>He,MODEL_OPENAI_GPT_5_NANO:()=>We,MODEL_ZAI_GLM_4_5_AIR:()=>_t,MODEL_ZAI_GLM_4_5_AIR_FREE:()=>Qe,MODEL_ZAI_GLM_4_7_FLASH:()=>dt,OPENROUTER_CREDITS_THRESHOLD:()=>Zt,OPENROUTER_FREE_DAILY_LIMIT_HIGH_CREDITS:()=>Jt,OPENROUTER_FREE_DAILY_LIMIT_LOW_CREDITS:()=>qt,OPENROUTER_FREE_MODELS:()=>gt,OPENROUTER_FREE_RATE_LIMIT_PER_MINUTE:()=>ft,OPENROUTER_VISION_SUPPORTED_MODELS:()=>bt,OpenAIChatService:()=>w,OpenAIChatServiceProvider:()=>te,OpenAICompatibleChatServiceProvider:()=>ee,OpenRouterChatService:()=>oe,OpenRouterChatServiceProvider:()=>re,StreamTextAccumulator:()=>f,VISION_SUPPORTED_MODELS:()=>pe,ZAIChatService:()=>se,ZAIChatServiceProvider:()=>ie,ZAI_VISION_SUPPORTED_MODELS:()=>Lt,allowsReasoningMinimal:()=>ct,allowsReasoningNone:()=>pt,buildOpenAICompatibleTools:()=>b,getMaxTokensForResponseLength:()=>O,installGASFetch:()=>Ut,isGPT5Model:()=>H,isKimiVisionModel:()=>j,isOpenRouterFreeModel:()=>k,isOpenRouterVisionModel:()=>W,isZaiToolStreamModel:()=>Et,isZaiVisionModel:()=>K,parseOpenAICompatibleOneShot:()=>I,parseOpenAICompatibleTextStream:()=>P,parseOpenAICompatibleToolStream:()=>x,processChatWithOptionalTools:()=>v,refreshOpenRouterFreeModels:()=>mo,resolveVisionModel:()=>C,runOnceText:()=>oo,screenplayToText:()=>to,textToScreenplay:()=>wt,textsToScreenplay:()=>eo});var G="https://api.openai.com/v1/chat/completions",y="https://api.openai.com/v1/responses",U="gpt-5-nano",ae="gpt-5-mini",le="gpt-5",L="gpt-5.1",_e="gpt-4.1",ge="gpt-4.1-mini",fe="gpt-4.1-nano",N="gpt-4o-mini",ve="gpt-4o",nt="o3-mini",at="o1-mini",lt="o1",pe=[U,ae,le,L,_e,ge,fe,N,ve,"o1"],It=[U,ae,le,L];function H(n){return It.includes(n)}function pt(n){return n===L}function ct(n){return n!==L}var ht="https://generativelanguage.googleapis.com",Me="gemini-3.1-pro-preview",Oe="gemini-3.1-flash-lite-preview",Ce="gemini-3-pro-preview",Ee="gemini-3-flash-preview",ye="gemini-2.5-pro",Te="gemini-2.5-flash",Se="gemini-2.5-flash-lite",Pe="gemini-2.5-flash-lite-preview-06-17",xe="gemini-2.0-flash",R="gemini-2.0-flash-lite",ce=[Me,Oe,Ce,Ee,ye,Te,Se,Pe,xe,R];var mt="https://api.anthropic.com/v1/messages",T="claude-3-haiku-20240307",Ie="claude-3-5-haiku-20241022",be="claude-3-5-sonnet-20241022",Le="claude-3-7-sonnet-20250219",Re="claude-4-sonnet-20250514",De="claude-4-opus-20250514",Ae="claude-sonnet-4-5-20250929",we="claude-haiku-4-5-20251001",Ne="claude-opus-4-5-20251101",ke="claude-sonnet-4-6",Ve="claude-opus-4-6",he=[T,Ie,be,Le,Re,De,Ae,we,Ne,ke,Ve];var me="https://openrouter.ai/api/v1/chat/completions",D="openai/gpt-oss-20b:free",Fe="moonshotai/kimi-k2.5",Ge="openai/gpt-5.1-chat",Ue="openai/gpt-5.1-codex",He="openai/gpt-5-mini",We="openai/gpt-5-nano",Be="openai/gpt-4o",Ke="openai/gpt-4.1-mini",$e="openai/gpt-4.1-nano",je="anthropic/claude-opus-4",ze="anthropic/claude-sonnet-4",qe="anthropic/claude-3.7-sonnet",ut="anthropic/claude-3.5-sonnet",Je="anthropic/claude-haiku-4.5",Ze="google/gemini-2.5-pro",Xe="google/gemini-2.5-flash",Ye="google/gemini-2.5-flash-lite-preview-09-2025",dt="z-ai/glm-4.7-flash",_t="z-ai/glm-4.5-air",Qe="z-ai/glm-4.5-air:free",gt=[D,Qe],bt=[Ge,Ue,He,We,Be,Ke,$e,je,ze,qe,Je,Ze,Xe,Ye,Fe],ft=20,qt=50,Jt=1e3,Zt=10;function k(n){return n.trim().endsWith(":free")}function W(n){return bt.some(e=>n.includes(e))}var ue="https://api.z.ai/api/paas/v4/chat/completions",vt="glm-5",B="glm-4.7",Mt="glm-4.7-FlashX",Ot="glm-4.7-Flash",Ct="glm-4.6",et="glm-4.6V",tt="glm-4.6V-FlashX",V="glm-4.6V-Flash",Lt=[et,tt,V];function K(n){return Lt.includes(n)}function Et(n){return n.toLowerCase().startsWith("glm-4.6")}var $="https://api.moonshot.ai/v1/chat/completions",S="kimi-k2.5",Rt=[S];function j(n){return Rt.includes(n)}var F={VERY_SHORT:"veryShort",SHORT:"short",MEDIUM:"medium",LONG:"long",VERY_LONG:"veryLong",DEEP:"deep"},Dt={[F.VERY_SHORT]:40,[F.SHORT]:100,[F.MEDIUM]:200,[F.LONG]:300,[F.VERY_LONG]:1e3,[F.DEEP]:5e3},yt=5e3,Tt={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 O(n){return n?Dt[n]??yt:yt}var Xt="You are a friendly AI avatar. Comment on the situation based on the broadcast screen.",Yt=`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,8 +7,8 @@ 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 A=class extends Error{constructor(t,o,r){super(`HTTP ${t}: ${o}`);this.status=t;this.statusText=o;this.body=r;this.name="HttpError"}},de=class de{static setFetch(e){this.fetchImpl=e}static async post(e,t,o={},r={}){let{timeout:s=3e4,retries:i=0,retryDelay:a=1e3}=r,c={...{"Content-Type":"application/json"},...o},m=null;for(let h=0;h<=i;h++)try{let u=typeof AbortController<"u",p=u?new AbortController:void 0,_=u?setTimeout(()=>p.abort(),s):void 0,M=await de.fetchImpl(e,{method:"POST",headers:c,body:typeof t=="string"?t:JSON.stringify(t),...p?{signal:p.signal}:{}});if(_&&clearTimeout(_),!M.ok){let d=await M.text();throw new A(M.status,M.statusText,d)}return M}catch(u){if(m=u,u instanceof A&&u.status>=400&&u.status<500)throw u;if(u instanceof Error&&u.name==="AbortError")throw new Error(`Request timeout after ${s}ms`);h<i&&await new Promise(p=>setTimeout(p,a*(h+1)))}throw m||new Error("Request failed")}static async handleErrorResponse(e){let t=await e.text();throw new A(e.status,e.statusText,t)}static async get(e,t={},o={}){let{timeout:r=3e4,retries:s=0,retryDelay:i=1e3}=o,a=null;for(let l=0;l<=s;l++)try{let c=typeof AbortController<"u",m=c?new AbortController:void 0,h=c?setTimeout(()=>m.abort(),r):void 0,u=await de.fetchImpl(e,{method:"GET",headers:t,...m?{signal:m.signal}:{}});if(h&&clearTimeout(h),!u.ok){let p=await u.text();throw new A(u.status,u.statusText,p)}return u}catch(c){if(a=c,c instanceof A&&c.status>=400&&c.status<500)throw c;if(c instanceof Error&&c.name==="AbortError")throw new Error(`Request timeout after ${r}ms`);l<s&&await new Promise(m=>setTimeout(m,i*(l+1)))}throw a||new Error("Request failed")}};de.fetchImpl=(e,t)=>fetch(e,t);var g=de;var f=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 Yt=["happy","sad","angry","surprised","neutral"],Dt=/\[([a-z]+)\]/i,Tt=/\[[a-z]+\]\s*/gi,z=class{static extractEmotion(e){let t=e.match(Dt);if(t){let o=t[1].toLowerCase(),r=e.replace(Tt,"").trim();return{emotion:o,cleanText:r}}return{cleanText:e}}static isValidEmotion(e){return Yt.includes(e)}static cleanEmotionTags(e){return e.replace(Tt,"").trim()}static addEmotionTag(e,t){return`[${e}] ${t}`}};function At(n){let{emotion:e,cleanText:t}=z.extractEmotion(n);return e?{emotion:e,text:t}:{text:t}}function Qt(n){return n.map(e=>At(e))}function eo(n){return n.emotion?z.addEmotionTag(n.emotion,n.text):n.text}async function to(n,e){let{blocks:t}=await n.chatOnce(e,!1,()=>{});return f.getFullText(t)}var wt=(n,e)=>{try{return JSON.parse(n)}catch(t){if(e){e(n,t);return}throw t}},Nt=async(n,e)=>{let t=n.body?.getReader();if(!t)throw new Error("Response body is null.");let o=new TextDecoder,r="",s=!1;for(;!s;){let{done:i,value:a}=await t.read();if(i)break;r+=o.decode(a,{stream:!0});let l=r.split(`
11
- `);r=l.pop()||"";for(let c of l){let m=c.trim();if(!m||m.startsWith(":")||!m.startsWith("data:"))continue;let h=m.slice(5).trim();if(h==="[DONE]"){s=!0;break}e(h)}}};async function P(n,e,t={}){let o="";return await Nt(n,r=>{let s=wt(r,t.onJsonError);if(!s)return;let i=s.choices?.[0]?.delta?.content||"";i&&(e(i),o+=i)}),o}async function x(n,e,t={}){let o=[],r=new Map,s=t.appendTextBlock??f.append;await Nt(n,l=>{let c=wt(l,t.onJsonError);if(!c)return;let m=c.choices?.[0]?.delta;m?.content&&(e(m.content),s(o,m.content)),m?.tool_calls&&m.tool_calls.forEach(h=>{let u=r.get(h.index)??{id:h.id,name:h.function?.name,args:""};u.args+=h.function?.arguments||"",r.set(h.index,u)})});let i=Array.from(r.entries()).sort((l,c)=>l[0]-c[0]).map(([l,c])=>({type:"tool_use",id:c.id,name:c.name,input:JSON.parse(c.args||"{}")}));return{blocks:[...o,...i],stop_reason:i.length?"tool_use":"end"}}function I(n){let e=n?.choices?.[0],t=[];return 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||"{}")})):e?.message?.content&&t.push({type:"text",text:e.message.content}),{blocks:t,stop_reason:e?.finish_reason==="tool_calls"||t.some(o=>o.type==="tool_use")?"tool_use":"end"}}var b=(n,e="chat-completions")=>n.length===0?[]:e==="responses"?n.map(t=>({type:"function",name:t.name,description:t.description,parameters:t.parameters})):n.map(t=>({type:"function",function:{name:t.name,description:t.description,parameters:t.parameters}}));async function v(n){if(!n.hasTools){let t=await n.runWithoutTools();await n.onCompleteResponse(t);return}let e=await n.runWithTools();if(n.onToolBlocks&&n.onToolBlocks(e.blocks),e.stop_reason==="end"){let t=f.getFullText(e.blocks);await n.onCompleteResponse(t);return}throw new Error(n.toolErrorMessage)}var O=n=>{let e=n.model??n.defaultModel,t=n.visionModel??(n.supportsVisionForModel(e)?e:n.defaultVisionModel);if(n.validate==="explicit"&&n.visionModel&&!n.supportsVisionForModel(n.visionModel))throw new Error(`Model ${n.visionModel} does not support vision capabilities.`);if(n.validate==="resolved"&&!n.supportsVisionForModel(t))throw new Error(`Model ${t} does not support vision capabilities.`);return t};var oo="https://openrouter.ai/api/v1/models",ro=2,so=12e3,io=1,no=10;function St(n){return n instanceof Error?n.message:String(n)}function tt(n,e){return typeof n!="number"||!Number.isFinite(n)?e:Math.max(1,Math.floor(n))}function ao(n){let e=new Set,t=[];for(let o of n){let r=o.trim();!r||e.has(r)||(e.add(r),t.push(r))}return t}async function kt(n,e,t){if(!(typeof AbortController<"u"))return fetch(n,e);let r=new AbortController,s=setTimeout(()=>r.abort(),t);try{return await fetch(n,{...e,signal:r.signal})}catch(i){throw i instanceof Error&&i.name==="AbortError"?new Error(`Timeout after ${t}ms`):i}finally{clearTimeout(s)}}async function Vt(n){let e=`HTTP ${n.status} ${n.statusText}`.trim(),t="";try{t=await n.text()}catch{return e}let o=t.replace(/\s+/g," ").trim().slice(0,200);return o?`${e}: ${o}`:e}function lo(n){if(!n||typeof n!="object")throw new Error("Invalid models response shape");let e=n,t=Array.isArray(e.data)?e.data:Array.isArray(e.models)?e.models:[];if(t.length===0)return[];let o=t.map(r=>r.id).filter(r=>typeof r=="string");return ao(o)}async function po({modelId:n,apiKey:e,endpoint:t,timeoutMs:o,appName:r,appUrl:s}){let i={Authorization:`Bearer ${e}`,"Content-Type":"application/json"};r&&(i["X-Title"]=r),s&&(i["HTTP-Referer"]=s);try{let a=await kt(t,{method:"POST",headers:i,body:JSON.stringify({model:n,messages:[{role:"user",content:"Reply only with OK."}],stream:!1})},o);if(!a.ok)return{id:n,ok:!1,reason:await Vt(a)};try{await a.json()}catch(l){return{id:n,ok:!1,reason:`JSON parse failed: ${St(l)}`}}return{id:n,ok:!0}}catch(a){return{id:n,ok:!1,reason:St(a)}}}async function co(n,e,t){if(n.length===0)return[];let o=new Array(n.length),r=0,s=Math.min(e,n.length);return await Promise.all(Array.from({length:s},async()=>{for(;r<n.length;){let i=r;r+=1,o[i]=await t(n[i])}})),o}async function ho(n){let e=n.apiKey.trim();if(!e)throw new Error("OpenRouter API key is required.");let t=n.modelsEndpoint||oo,o=n.endpoint||me,r=tt(n.timeoutMs,so),s=tt(n.concurrency,ro),i=tt(n.maxCandidates,io),a=tt(n.maxWorking,no),l=await kt(t,{method:"GET"},r);if(!l.ok)throw new Error(await Vt(l));let c;try{c=await l.json()}catch(_){throw new Error(`JSON parse failed: ${St(_)}`)}let m=lo(c).filter(_=>k(_)).slice(0,i),h=await co(m,s,_=>po({modelId:_,apiKey:e,endpoint:o,timeoutMs:r,appName:n.appName,appUrl:n.appUrl})),u=h.filter(_=>_.ok).map(_=>_.id).slice(0,a),p=h.filter(_=>!_.ok).map(_=>({id:_.id,reason:_.reason||"Unknown error"}));return{working:u,failed:p,fetchedAt:Date.now()}}var q=class{constructor(e,t=T,o=T,r=[],s=[],i){this.provider="claude";if(this.apiKey=e,this.model=t||T,this.visionModel=o||T,this.tools=r,this.mcpServers=s,this.responseLength=i,!he.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 v({hasTools:this.tools.length>0||this.mcpServers.length>0,runWithoutTools:async()=>{let r=await this.callClaude(e,this.model,!0);return this.parsePureStream(r,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 v({hasTools:this.tools.length>0||this.mcpServers.length>0,runWithoutTools:async()=>{let r=await this.callClaude(e,this.visionModel,!0);return this.parsePureStream(r,t)},runWithTools:()=>this.visionChatOnce(e),onCompleteResponse:o,toolErrorMessage:"processVisionChat received tool_calls. ChatProcessor must use chatOnce() loop when tools are enabled."})}convertMessagesToClaudeFormat(e){return e.map(t=>({role:this.mapRoleToClaude(t.role),content:t.content}))}convertVisionMessagesToClaudeFormat(e){return e.map(t=>{if(typeof t.content=="string")return{role:this.mapRoleToClaude(t.role),content:[{type:"text",text:t.content}]};if(Array.isArray(t.content)){let o=t.content.map(r=>{if(r.type==="image_url"){if(r.image_url.url.startsWith("data:")){let s=r.image_url.url.match(/^data:([^;]+);base64,(.+)$/);return s?{type:"image",source:{type:"base64",media_type:s[1],data:s[2]}}:null}return{type:"image",source:{type:"url",url:r.image_url.url,media_type:this.getMimeTypeFromUrl(r.image_url.url)}}}return r}).filter(r=>r);return{role:this.mapRoleToClaude(t.role),content:o}}return{role:this.mapRoleToClaude(t.role),content:[]}})}mapRoleToClaude(e){switch(e){case"system":return"system";case"user":return"user";case"assistant":return"assistant";default:return"user"}}getMimeTypeFromUrl(e){switch(e.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"}}async callClaude(e,t,o,r){let s=e.find(h=>h.role==="system")?.content??"",i=e.filter(h=>h.role!=="system"),a=i.some(h=>Array.isArray(h.content)&&h.content.some(u=>u.type==="image_url"||u.type==="image")),l={model:t,system:s,messages:a?this.convertVisionMessagesToClaudeFormat(i):this.convertMessagesToClaudeFormat(i),stream:o,max_tokens:r!==void 0?r:C(this.responseLength)};this.tools.length&&(l.tools=this.tools.map(h=>({name:h.name,description:h.description,input_schema:h.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 g.post(ht,l,c)}async parseStream(e,t){let o=e.body.getReader(),r=new TextDecoder,s=[],i=new Map,a="";for(;;){let{done:l,value:c}=await o.read();if(l)break;a+=r.decode(c,{stream:!0});let m;for(;(m=a.indexOf(`
12
- `))!==-1;){let h=a.slice(0,m).trim();if(a=a.slice(m+1),!h.startsWith("data:"))continue;let u=h.slice(5).trim();if(u==="[DONE]")break;let p=JSON.parse(u);if(p.type==="content_block_delta"&&p.delta?.text&&(t(p.delta.text),s.push({type:"text",text:p.delta.text})),p.type==="content_block_start"&&p.content_block?.type==="tool_use"?i.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"?i.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"?s.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"&&s.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 _=i.get(p.index);_&&(_.args+=p.delta.partial_json||"")}if(p.type==="content_block_stop"&&i.has(p.index)){let{id:_,name:M,args:d,server_name:E}=i.get(p.index);E?s.push({type:"mcp_tool_use",id:_,name:M,server_name:E,input:JSON.parse(d||"{}")}):s.push({type:"tool_use",id:_,name:M,input:JSON.parse(d||"{}")}),i.delete(p.index)}}}return{blocks:s,stop_reason:s.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(r=>r.type==="text").map(r=>r.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=()=>{},r){let s=await this.callClaude(e,this.model,t,r),i=t?await this.parseStream(s,o):this.parseOneShot(await s.json());return this.convertToStandardCompletion(i)}async visionChatOnce(e,t=!1,o=()=>{},r){let s=await this.callClaude(e,this.visionModel,t,r),i=t?await this.parseStream(s,o):this.parseOneShot(await s.json());return this.convertToStandardCompletion(i)}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 J=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 q(e.apiKey,e.model||this.getDefaultModel(),t,e.tools??[],e.mcpServers??[],e.responseLength)}getProviderName(){return"claude"}getSupportedModels(){return[T,xe,Ie,be,Le,Re,De,Ae,we,Ne,ke]}getDefaultModel(){return T}supportsVision(){return!0}supportsVisionForModel(e){return he.includes(e)}};var ot=class{static async fetchToolSchemas(e){try{let t={"Content-Type":"application/json"};e.authorization_token&&(t.Authorization=`Bearer ${e.authorization_token}`);let r=await(await g.post(`${e.url}/tools`,{},t)).json();return Array.isArray(r.tools)?r.tools.map(s=>({name:`mcp_${e.name}_${s.name}`,description:s.description||`Tool from ${e.name} MCP server`,parameters:s.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 r=await this.fetchToolSchemas(o);t.push(...r)}catch(r){console.error(`Failed to fetch schemas from ${o.name}:`,r)}return t}};var Z=class{constructor(e,t=R,o=R,r=[],s=[],i){this.provider="gemini";this.mcpToolSchemas=[];this.mcpSchemasInitialized=!1;this.callIdMap=new Map;if(this.apiKey=e,this.model=t,this.responseLength=i,!ce.includes(o))throw new Error(`Model ${o} does not support vision capabilities.`);this.visionModel=o,this.tools=r,this.mcpServers=s}safeJsonParse(e){try{return JSON.parse(e)}catch{return e}}normalizeToolResult(e){return e===null?{content:null}:typeof e=="object"?e:{content:e}}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,r])=>[t[o]??o,this.adaptKeysForApi(r)])):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,r)=>setTimeout(()=>r(new Error("MCP schema fetch timeout")),5e3)),t=ot.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=this.mcpServers.map(t=>({name:`mcp_${t.name}_search`,description:`Search using ${t.name} MCP server (fallback)`,parameters:{type:"object",properties:{query:{type:"string",description:"Search query"}},required:["query"]}})),this.mcpSchemasInitialized=!0}}async processChat(e,t,o){try{await v({hasTools:this.tools.length>0||this.mcpServers.length>0,runWithoutTools:async()=>{let r=await this.callGemini(e,this.model,!0),{blocks:s}=await this.parseStream(r,t);return f.getFullText(s)},runWithTools:()=>this.chatOnce(e,!0,t),onCompleteResponse:o,toolErrorMessage:"Received functionCall. Use chatOnce() loop when tools are enabled."})}catch(r){throw console.error("Error in processChat:",r),r}}async processVisionChat(e,t,o){try{await v({hasTools:this.tools.length>0||this.mcpServers.length>0,runWithoutTools:async()=>{let r=await this.callGemini(e,this.visionModel,!0),{blocks:s}=await this.parseStream(r,t);return f.getFullText(s)},runWithTools:()=>this.visionChatOnce(e),onToolBlocks:r=>{r.filter(s=>s.type==="text").forEach(s=>t(s.text))},onCompleteResponse:o,toolErrorMessage:"Received functionCall. Use visionChatOnce() loop when tools are enabled."})}catch(r){throw console.error("Error in processVisionChat:",r),r}}convertMessagesToGeminiFormat(e){let t=[],o=null,r=[],s=()=>{o&&r.length&&(t.push({role:o,parts:[...r]}),r=[])};for(let i of e){let a=this.mapRoleToGemini(i.role);if(i.tool_calls){s();for(let l of i.tool_calls)this.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(i.role==="tool"){s();let l=i.name??this.callIdMap.get(i.tool_call_id)??"result";t.push({role:"user",parts:[{functionResponse:{name:l,response:this.normalizeToolResult(this.safeJsonParse(i.content))}}]});continue}a!==o&&s(),o=a,r.push({text:i.content})}return s(),t}async callGemini(e,t,o=!1,r){let a={contents:e.some(d=>Array.isArray(d.content)&&d.content.some(E=>E?.type==="image_url"||E?.inlineData))?await this.convertVisionMessagesToGeminiFormat(e):this.convertMessagesToGeminiFormat(e),generationConfig:{maxOutputTokens:r!==void 0?r:C(this.responseLength)}},l=[];if(this.tools.length>0&&l.push(...this.tools.map(d=>({name:d.name,description:d.description,parameters:d.parameters}))),this.mcpServers.length>0)try{await this.initializeMCPSchemas(),l.push(...this.mcpToolSchemas.map(d=>({name:d.name,description:d.description,parameters:d.parameters})))}catch(d){console.warn("MCP initialization failed, skipping MCP tools:",d)}l.length>0&&(a.tools=[{functionDeclarations:l}],a.toolConfig={functionCallingConfig:{mode:"AUTO"}});let c=async(d,E)=>{let rt=o?"streamGenerateContent":"generateContent",Pt=o?"?alt=sse":"",Ut=`${ct}/${d}/models/${t}:${rt}${Pt}${Pt?"&":"?"}key=${this.apiKey}`;return g.post(Ut,E)},m=/flash[-_]lite/.test(t),h=/gemini-2\.5/.test(t),u=/^gemini-3(?:\.[0-9]+)?-.*preview/.test(t),p=m||h||u,_=p?"v1beta":"v1",M=async()=>{try{let d=_==="v1"?a:this.adaptKeysForApi(a);return await c(_,d)}catch(d){let E=/Unknown name|Cannot find field|404/.test(d?.message||"")||d?.status===404;if(!p&&E)return await c("v1beta",this.adaptKeysForApi(a));throw d}};try{return await M()}catch(d){throw d.body&&(console.error("Gemini API Error Details:",d.body),console.error("Request Body:",JSON.stringify(a,null,2))),d}}async convertVisionMessagesToGeminiFormat(e){let t=[],o=null,r=[];for(let s of e){let i=this.mapRoleToGemini(s.role);if(s.tool_calls){for(let a of s.tool_calls)t.push({role:"model",parts:[{functionCall:{name:a.function.name,args:JSON.parse(a.function.arguments||"{}")}}]});continue}if(s.role==="tool"){let a=s.name??this.callIdMap.get(s.tool_call_id)??"result";t.push({role:"user",parts:[{functionResponse:{name:a,response:this.normalizeToolResult(this.safeJsonParse(s.content))}}]});continue}if(i!==o&&r.length>0&&(t.push({role:o,parts:[...r]}),r=[]),o=i,typeof s.content=="string")r.push({text:s.content});else if(Array.isArray(s.content)){for(let a of s.content)if(a.type==="text")r.push({text:a.text});else if(a.type==="image_url")try{let c=await(await g.get(a.image_url.url)).blob(),m=await this.blobToBase64(c);r.push({inlineData:{mimeType:c.type||"image/jpeg",data:m.split(",")[1]}})}catch(l){throw console.error("Error processing image:",l),new Error(`Failed to process image: ${l.message}`)}}}return o&&r.length>0&&t.push({role:o,parts:[...r]}),t}blobToBase64(e){return new Promise((t,o)=>{let r=new FileReader;r.onloadend=()=>t(r.result),r.onerror=o,r.readAsDataURL(e)})}mapRoleToGemini(e){switch(e){case"system":return"model";case"user":return"user";case"assistant":return"model";default:return"user"}}async parseStream(e,t){let o=e.body.getReader(),r=new TextDecoder,s=[],i=[],a="",l=m=>{if(!m||m==="[DONE]")return;let h;try{h=JSON.parse(m)}catch{return}for(let u of h.candidates??[])for(let p of u.content?.parts??[])p.text&&(t(p.text),f.addTextBlock(s,p.text)),p.functionCall&&i.push({type:"tool_use",id:this.genUUID(),name:p.functionCall.name,input:p.functionCall.args??{}}),p.functionResponse&&i.push({type:"tool_result",tool_use_id:p.functionResponse.name,content:JSON.stringify(p.functionResponse.response)})};for(;;){let{done:m,value:h}=await o.read();if(m)break;a+=r.decode(h,{stream:!0});let u;for(;(u=a.indexOf(`
13
- `))!==-1;){let p=a.slice(0,u);if(a=a.slice(u+1),p.endsWith("\r")&&(p=p.slice(0,-1)),!p.trim()){l("");continue}p.startsWith("data:")&&(p=p.slice(5).trim()),p&&l(p)}}return a&&l(a),{blocks:[...s,...i],stop_reason:i.some(m=>m.type==="tool_use")?"tool_use":"end"}}parseOneShot(e){let t=[],o=[];for(let s of e.candidates??[])for(let i of s.content?.parts??[])i.text&&t.push({type:"text",text:i.text}),i.functionCall&&o.push({type:"tool_use",id:this.genUUID(),name:i.functionCall.name,input:i.functionCall.args??{}}),i.functionResponse&&o.push({type:"tool_result",tool_use_id:i.functionResponse.name,content:JSON.stringify(i.functionResponse.response)});return{blocks:[...t,...o],stop_reason:o.some(s=>s.type==="tool_use")?"tool_use":"end"}}async chatOnce(e,t=!0,o=()=>{},r){let s=await this.callGemini(e,this.model,t,r);return t?this.parseStream(s,o):this.parseOneShot(await s.json())}async visionChatOnce(e,t=!1,o=()=>{},r){let s=await this.callGemini(e,this.visionModel,t,r);return t?this.parseStream(s,o):this.parseOneShot(await s.json())}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 X=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 Z(e.apiKey,e.model||this.getDefaultModel(),t,e.tools||[],e.mcpServers||[],e.responseLength)}getProviderName(){return"gemini"}getSupportedModels(){return[Me,Ce,Oe,Ee,ye,Te,Se,Pe,R]}getDefaultModel(){return R}supportsVision(){return!0}supportsVisionForModel(e){return ce.includes(e)}};var Y=class{constructor(e,t=S,o=S,r,s=$,i,a,l){this.provider="kimi";this.apiKey=e,this.model=t,this.tools=r||[],this.endpoint=s,this.responseLength=i,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 v({hasTools:this.tools.length>0,runWithoutTools:async()=>{let r=await this.callKimi(e,this.model,!0);return this.handleStream(r,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(!j(this.visionModel))throw new Error(`Model ${this.visionModel} does not support vision capabilities.`);await v({hasTools:this.tools.length>0,runWithoutTools:async()=>{let r=await this.callKimi(e,this.visionModel,!0);return this.handleStream(r,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=()=>{},r){let s=await this.callKimi(e,this.model,t,r);return this.parseResponse(s,t,o)}async visionChatOnce(e,t=!1,o=()=>{},r){if(!j(this.visionModel))throw new Error(`Model ${this.visionModel} does not support vision capabilities.`);let s=await this.callKimi(e,this.visionModel,t,r);return this.parseResponse(s,t,o)}async parseResponse(e,t,o){return t?this.parseStream(e,o):this.parseOneShot(await e.json())}async callKimi(e,t,o=!1,r){let s=this.buildRequestBody(e,t,o,r);return await g.post(this.endpoint,s,{Authorization:`Bearer ${this.apiKey}`})}buildRequestBody(e,t,o,r){let s={model:t,stream:o,messages:e},i=r!==void 0?r:C(this.responseLength);i!==void 0&&(s.max_tokens=i),this.responseFormat&&(s.response_format=this.responseFormat);let a=this.tools.length>0?{type:"disabled"}:this.thinking;a&&(this.isSelfHostedEndpoint()?a.type==="disabled"&&(s.chat_template_kwargs={thinking:!1}):s.thinking=a);let l=this.buildToolsDefinition();return l.length>0&&(s.tools=l,s.tool_choice="auto"),s}isSelfHostedEndpoint(){return this.normalizeEndpoint(this.endpoint)!==this.normalizeEndpoint($)}normalizeEndpoint(e){return e.replace(/\/+$/,"")}buildToolsDefinition(){return b(this.tools,"chat-completions")}async handleStream(e,t){return P(e,t,{onJsonError:o=>console.debug("Failed to parse SSE data:",o)})}async parseStream(e,t){return x(e,t,{onJsonError:o=>console.debug("Failed to parse SSE data:",o)})}parseOneShot(e){return I(e)}};var Q=class{createChatService(e){let t=this.resolveEndpoint(e),o=e.model||this.getDefaultModel(),r=O({model:o,visionModel:e.visionModel,defaultModel:this.getDefaultModel(),defaultVisionModel:this.getDefaultVisionModel(),supportsVisionForModel:l=>this.supportsVisionForModel(l),validate:"explicit"}),s=e.tools,i=e.thinking??{type:"enabled"},a=s&&s.length>0?{type:"disabled"}:i;return new Y(e.apiKey,o,r,s,t,e.responseLength,e.responseFormat,a)}getProviderName(){return"kimi"}getSupportedModels(){return[S]}getDefaultModel(){return S}getDefaultVisionModel(){return S}supportsVision(){return!0}supportsVisionForModel(e){return j(e)}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 $}normalizeEndpoint(e){return e.replace(/\/+$/,"")}};var w=class{constructor(e,t=N,o=N,r,s=G,i=[],a,l,c,m=!1,h="openai",u=!0){if(this.provider=h,this.apiKey=e,this.model=t,this.tools=r||[],this.endpoint=s,this.mcpServers=i,this.responseLength=a,this.verbosity=l,this.reasoning_effort=c,this.enableReasoningSummary=m,u&&!pe.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 v({hasTools:this.tools.length>0,runWithoutTools:async()=>{let r=await this.callOpenAI(e,this.model,!0),s=this.endpoint===y;try{if(s){let i=await this.parseResponsesStream(r,t);return f.getFullText(i.blocks)}return this.handleStream(r,t)}catch(i){throw console.error("[processChat] Error in streaming/completion:",i),i}},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 v({hasTools:this.tools.length>0,runWithoutTools:async()=>{let r=await this.callOpenAI(e,this.visionModel,!0),s=this.endpoint===y;try{if(s){let i=await this.parseResponsesStream(r,t);return f.getFullText(i.blocks)}return this.handleStream(r,t)}catch(i){throw console.error("[processVisionChat] Error in streaming/completion:",i),i}},runWithTools:()=>this.visionChatOnce(e,!0,t),onCompleteResponse:o,toolErrorMessage:"processVisionChat received tool_calls. ChatProcessor must use visionChatOnce() loop when tools are enabled."})}catch(r){throw console.error("Error in processVisionChat:",r),r}}async chatOnce(e,t=!0,o=()=>{},r){let s=await this.callOpenAI(e,this.model,t,r);return this.parseResponse(s,t,o)}async visionChatOnce(e,t=!1,o=()=>{},r){let s=await this.callOpenAI(e,this.visionModel,t,r);return this.parseResponse(s,t,o)}async parseResponse(e,t,o){return this.endpoint===y?t?this.parseResponsesStream(e,o):this.parseResponsesOneShot(await e.json()):t?this.parseStream(e,o):this.parseOneShot(await e.json())}async callOpenAI(e,t,o=!1,r){let s=this.buildRequestBody(e,t,o,r),i={};return(this.provider!=="openai-compatible"||this.apiKey.trim()!=="")&&(i.Authorization=`Bearer ${this.apiKey}`),await g.post(this.endpoint,s,i)}buildRequestBody(e,t,o,r){let s=this.endpoint===y;this.validateMCPCompatibility();let i={model:t,stream:o},a=r!==void 0?r:this.provider==="openai-compatible"?this.responseLength!==void 0?C(this.responseLength):void 0:C(this.responseLength);s?a!==void 0&&(i.max_output_tokens=a):a!==void 0&&(this.provider==="openai-compatible"?i.max_tokens=a:i.max_completion_tokens=a),s?i.input=this.cleanMessagesForResponsesAPI(e):i.messages=e,H(t)&&(s?(this.reasoning_effort&&(i.reasoning={...i.reasoning,effort:this.reasoning_effort},this.enableReasoningSummary&&(i.reasoning.summary="auto")),this.verbosity&&(i.text={...i.text,format:{type:"text"},verbosity:this.verbosity})):(this.reasoning_effort&&(i.reasoning_effort=this.reasoning_effort),this.verbosity&&(i.verbosity=this.verbosity)));let l=this.buildToolsDefinition();return l.length>0&&(i.tools=l,s||(i.tool_choice="auto")),i}validateMCPCompatibility(){if(this.mcpServers.length>0&&this.endpoint===G)throw new Error(`MCP servers are not supported with Chat Completions API. Current endpoint: ${this.endpoint}. Please use OpenAI Responses API endpoint: ${y}. MCP tools are only available in the Responses API endpoint.`)}cleanMessagesForResponsesAPI(e){return e.map(t=>{let r={role:t.role==="tool"?"user":t.role};return typeof t.content=="string"?r.content=t.content:Array.isArray(t.content)?r.content=t.content.map(s=>s.type==="text"?{type:"input_text",text:s.text}:s.type==="image_url"?{type:"input_image",image_url:s.image_url.url}:s):r.content=t.content,r})}buildToolsDefinition(){let e=this.endpoint===y,t=[];return this.tools.length>0&&t.push(...b(this.tools,e?"responses":"chat-completions")),this.mcpServers.length>0&&e&&t.push(...this.buildMCPToolsDefinition()),t}buildMCPToolsDefinition(){return this.mcpServers.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})}async handleStream(e,t){return P(e,t)}async parseStream(e,t){return x(e,t,{appendTextBlock:f.addTextBlock})}parseOneShot(e){return I(e)}async parseResponsesStream(e,t){let o=e.body.getReader(),r=new TextDecoder,s=[],i=new Map,a="";for(;;){let{done:m,value:h}=await o.read();if(m)break;a+=r.decode(h,{stream:!0});let u="",p="",_=a.split(`
14
- `);a=_.pop()||"";for(let M=0;M<_.length;M++){let d=_[M].trim();if(d.startsWith("event:"))u=d.slice(6).trim();else if(d.startsWith("data:"))p=d.slice(5).trim();else if(d===""&&u&&p){try{let E=JSON.parse(p),rt=this.handleResponsesSSEEvent(u,E,t,s,i)}catch{console.warn("Failed to parse SSE data:",p)}u="",p=""}}}let l=Array.from(i.values()).map(m=>({type:"tool_use",id:m.id,name:m.name,input:m.input||{}}));return{blocks:[...s,...l],stop_reason:l.length?"tool_use":"end"}}handleResponsesSSEEvent(e,t,o,r,s){switch(e){case"response.output_item.added":t.item?.type==="message"&&Array.isArray(t.item.content)?t.item.content.forEach(i=>{i.type==="output_text"&&i.text&&(o(i.text),f.append(r,i.text))}):t.item?.type==="function_call"&&s.set(t.item.id,{id:t.item.id,name:t.item.name,input:t.item.arguments?JSON.parse(t.item.arguments):{}});break;case"response.content_part.added":t.part?.type==="output_text"&&typeof t.part.text=="string"&&(o(t.part.text),f.append(r,t.part.text));break;case"response.output_text.delta":case"response.content_part.delta":{let i=typeof t.delta=="string"?t.delta:t.delta?.text??"";i&&(o(i),f.append(r,i))}break;case"response.output_text.done":case"response.content_part.done":break;case"response.completed":return"completed";case"response.reasoning.started":case"response.reasoning.delta":case"response.reasoning.done":break;default:break}}parseResponsesOneShot(e){let t=[];return e.output&&Array.isArray(e.output)&&e.output.forEach(o=>{o.type==="message"&&o.content&&o.content.forEach(r=>{r.type==="output_text"&&r.text&&t.push({type:"text",text:r.text})}),o.type==="function_call"&&t.push({type:"tool_use",id:o.id,name:o.name,input:o.arguments?JSON.parse(o.arguments):{}})}),{blocks:t,stop_reason:t.some(o=>o.type==="tool_use")?"tool_use":"end"}}};var ee=class{createChatService(e){return this.validateRequiredOptions(e),new w(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!1}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 te=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"}),r=t.tools,s=t.mcpServers??[],i=t.model||this.getDefaultModel(),a=!1;s.length>0?a=!0:H(i)&&(a=(t.gpt5EndpointPreference||"chat")==="responses");let l=t.endpoint||(a?y:G);return new w(t.apiKey,i,o,r,l,s,t.responseLength,t.verbosity,t.reasoning_effort,t.enableReasoningSummary,this.getProviderName())}getProviderName(){return"openai"}getSupportedModels(){return[U,ae,le,L,_e,ge,fe,N,ve,it,nt,"o1"]}getDefaultModel(){return U}supportsVision(){return!0}supportsVisionForModel(e){return pe.includes(e)}optimizeGPT5Options(e){let t=e.model||this.getDefaultModel();if(!H(t))return e;let o={...e};if(e.gpt5Preset){let r=yt[e.gpt5Preset];o.reasoning_effort=r.reasoning_effort,o.verbosity=r.verbosity}else e.reasoning_effort||(o.reasoning_effort=this.getDefaultReasoningEffortForModel(t));return o.reasoning_effort=this.normalizeReasoningEffort(t,o.reasoning_effort),o}getDefaultReasoningEffortForModel(e){return e===L?"none":"medium"}normalizeReasoningEffort(e,t){if(t)return t==="none"&&!lt(e)?this.getDefaultReasoningEffortForModel(e):t==="minimal"&&!pt(e)?"none":t}};var oe=class{constructor(e,t=D,o=D,r,s=me,i,a,l,c,m,h){this.provider="openrouter";this.lastRequestTime=0;this.requestCount=0;this.apiKey=e,this.model=t,this.tools=r||[],this.endpoint=s,this.responseLength=i,this.appName=a,this.appUrl=l,this.reasoning_effort=c,this.includeReasoning=m,this.reasoningMaxTokens=h,this.visionModel=o}getModel(){return this.model}getVisionModel(){return this.visionModel}async applyRateLimiting(){if(!k(this.model))return;let e=Date.now(),t=e-this.lastRequestTime;if(t>6e4&&(this.requestCount=0),this.requestCount>=gt){let o=6e4-t;o>0&&(console.log(`Rate limit reached for free tier. Waiting ${o}ms...`),await new Promise(r=>setTimeout(r,o)),this.requestCount=0)}this.lastRequestTime=e,this.requestCount++}async processChat(e,t,o){await this.applyRateLimiting(),await v({hasTools:this.tools.length>0,runWithoutTools:async()=>{let r=await this.callOpenRouter(e,this.model,!0);return this.handleStream(r,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(!W(this.visionModel))throw new Error(`Model ${this.visionModel} does not support vision capabilities.`);await this.applyRateLimiting();try{await v({hasTools:this.tools.length>0,runWithoutTools:async()=>{let r=await this.callOpenRouter(e,this.visionModel,!0);return this.handleStream(r,t)},runWithTools:()=>this.visionChatOnce(e,!0,t),onCompleteResponse:o,toolErrorMessage:"processVisionChat received tool_calls. ChatProcessor must use visionChatOnce() loop when tools are enabled."})}catch(r){throw console.error("Error in processVisionChat:",r),r}}async chatOnce(e,t=!0,o=()=>{},r){await this.applyRateLimiting();let s=await this.callOpenRouter(e,this.model,t,r);return t?this.parseStream(s,o):this.parseOneShot(await s.json())}async visionChatOnce(e,t=!1,o=()=>{},r){if(!W(this.visionModel))throw new Error(`Model ${this.visionModel} does not support vision capabilities.`);await this.applyRateLimiting();let s=await this.callOpenRouter(e,this.visionModel,t,r);return t?this.parseStream(s,o):this.parseOneShot(await s.json())}async callOpenRouter(e,t,o=!1,r){let s=this.buildRequestBody(e,t,o,r),i={Authorization:`Bearer ${this.apiKey}`};return this.appUrl&&(i["HTTP-Referer"]=this.appUrl),this.appName&&(i["X-Title"]=this.appName),await g.post(this.endpoint,s,i)}buildRequestBody(e,t,o,r){let s={model:t,messages:e,stream:o};if((r!==void 0?r:C(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(s.reasoning={},this.reasoning_effort&&this.reasoning_effort!=="none"){let a=this.reasoning_effort==="minimal"?"low":this.reasoning_effort;s.reasoning.effort=a}(this.reasoning_effort==="none"||this.includeReasoning!==!0)&&(s.reasoning.exclude=!0),this.reasoningMaxTokens&&(s.reasoning.max_tokens=this.reasoningMaxTokens)}else s.reasoning={exclude:!0};return this.tools.length>0&&(s.tools=b(this.tools,"chat-completions"),s.tool_choice="auto"),s}async handleStream(e,t){return P(e,t,{onJsonError:o=>console.debug("Failed to parse SSE data:",o)})}async parseStream(e,t){return x(e,t,{onJsonError:o=>console.debug("Failed to parse SSE data:",o)})}parseOneShot(e){return I(e)}};var re=class{createChatService(e){let t=O({model:e.model,visionModel:e.visionModel,defaultModel:this.getDefaultModel(),defaultVisionModel:e.model||this.getDefaultModel(),supportsVisionForModel:i=>this.supportsVisionForModel(i),validate:"explicit"}),o=e.tools,r=e.appName,s=e.appUrl;return new oe(e.apiKey,e.model||this.getDefaultModel(),t,o,e.endpoint,e.responseLength,r,s,e.reasoning_effort,e.includeReasoning,e.reasoningMaxTokens)}getProviderName(){return"openrouter"}getSupportedModels(){return[D,Ye,Fe,Ge,Ue,He,We,Be,Ke,$e,je,ze,mt,qe,Je,Ze,Xe,ut,dt,Ve]}getDefaultModel(){return D}supportsVision(){return this.getSupportedModels().some(e=>this.supportsVisionForModel(e))}supportsVisionForModel(e){return W(e)}getFreeModels(){return _t}isModelFree(e){return k(e)}};var se=class{constructor(e,t=B,o=V,r,s=ue,i,a,l){this.provider="zai";this.apiKey=e,this.model=t,this.tools=r||[],this.endpoint=s,this.responseLength=i,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 v({hasTools:this.tools.length>0,runWithoutTools:async()=>{let r=await this.callZAI(e,this.model,!0);return this.handleStream(r,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(!K(this.visionModel))throw new Error(`Model ${this.visionModel} does not support vision capabilities.`);await v({hasTools:this.tools.length>0,runWithoutTools:async()=>{let r=await this.callZAI(e,this.visionModel,!0);return this.handleStream(r,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=()=>{},r){let s=await this.callZAI(e,this.model,t,r);return this.parseResponse(s,t,o)}async visionChatOnce(e,t=!1,o=()=>{},r){if(!K(this.visionModel))throw new Error(`Model ${this.visionModel} does not support vision capabilities.`);let s=await this.callZAI(e,this.visionModel,t,r);return this.parseResponse(s,t,o)}async parseResponse(e,t,o){return t?this.parseStream(e,o):this.parseOneShot(await e.json())}async callZAI(e,t,o=!1,r){let s=this.buildRequestBody(e,t,o,r);return await g.post(this.endpoint,s,{Authorization:`Bearer ${this.apiKey}`})}buildRequestBody(e,t,o,r){let s={model:t,stream:o,messages:e},i=r!==void 0?r:C(this.responseLength);i!==void 0&&(s.max_tokens=i),this.responseFormat&&(s.response_format=this.responseFormat),this.thinking&&(s.thinking=this.thinking);let a=this.buildToolsDefinition();return a.length>0&&(s.tools=a,s.tool_choice="auto",o&&Ot(t)&&(s.tool_stream=!0)),s}buildToolsDefinition(){return b(this.tools,"chat-completions")}async handleStream(e,t){return P(e,t,{onJsonError:o=>console.debug("Failed to parse SSE data:",o)})}async parseStream(e,t){return x(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:i=>this.supportsVisionForModel(i),validate:"explicit"}),r=e.tools,s=e.thinking??{type:"disabled"};return new se(e.apiKey,t,o,r,e.endpoint||ue,e.responseLength,e.responseFormat,s)}getProviderName(){return"zai"}getSupportedModels(){return[ft,B,vt,Mt,Ct,Qe,et,V]}getDefaultModel(){return B}getDefaultVisionModel(){return V}supportsVision(){return!0}supportsVisionForModel(e){return K(e)}};var Ft=[new te,new ee,new X,new J,new re,new ie,new Q];var ne=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():[]}};ne.providers=new Map;Ft.forEach(n=>ne.registerProvider(n));function Gt(){g.setFetch(async(n,e={})=>{let t=(e.method||"GET").toString().toUpperCase(),o=e.headers,r={};if(Array.isArray(o))for(let[h,u]of o)r[h]=String(u);else if(o&&typeof o=="object")for(let[h,u]of Object.entries(o))r[h]=String(u);let s={method:t,headers:r,muteHttpExceptions:!0},i=e.body;typeof i=="string"?s.payload=i:i!=null&&(r["Content-Type"]||(r["Content-Type"]="application/json"),s.payload=JSON.stringify(i));let a=UrlFetchApp.fetch(n,s),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 jt(mo);})();
10
+ `;var A=class extends Error{constructor(t,o,r){super(`HTTP ${t}: ${o}`);this.status=t;this.statusText=o;this.body=r;this.name="HttpError"}},de=class de{static setFetch(e){this.fetchImpl=e}static async post(e,t,o={},r={}){let{timeout:s=3e4,retries:i=0,retryDelay:a=1e3}=r,c={...{"Content-Type":"application/json"},...o},m=null;for(let h=0;h<=i;h++)try{let u=typeof AbortController<"u",p=u?new AbortController:void 0,_=u?setTimeout(()=>p.abort(),s):void 0,M=await de.fetchImpl(e,{method:"POST",headers:c,body:typeof t=="string"?t:JSON.stringify(t),...p?{signal:p.signal}:{}});if(_&&clearTimeout(_),!M.ok){let d=await M.text();throw new A(M.status,M.statusText,d)}return M}catch(u){if(m=u,u instanceof A&&u.status>=400&&u.status<500)throw u;if(u instanceof Error&&u.name==="AbortError")throw new Error(`Request timeout after ${s}ms`);h<i&&await new Promise(p=>setTimeout(p,a*(h+1)))}throw m||new Error("Request failed")}static async handleErrorResponse(e){let t=await e.text();throw new A(e.status,e.statusText,t)}static async get(e,t={},o={}){let{timeout:r=3e4,retries:s=0,retryDelay:i=1e3}=o,a=null;for(let l=0;l<=s;l++)try{let c=typeof AbortController<"u",m=c?new AbortController:void 0,h=c?setTimeout(()=>m.abort(),r):void 0,u=await de.fetchImpl(e,{method:"GET",headers:t,...m?{signal:m.signal}:{}});if(h&&clearTimeout(h),!u.ok){let p=await u.text();throw new A(u.status,u.statusText,p)}return u}catch(c){if(a=c,c instanceof A&&c.status>=400&&c.status<500)throw c;if(c instanceof Error&&c.name==="AbortError")throw new Error(`Request timeout after ${r}ms`);l<s&&await new Promise(m=>setTimeout(m,i*(l+1)))}throw a||new Error("Request failed")}};de.fetchImpl=(e,t)=>fetch(e,t);var g=de;var f=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 Qt=["happy","sad","angry","surprised","neutral"],At=/\[([a-z]+)\]/i,St=/\[[a-z]+\]\s*/gi,z=class{static extractEmotion(e){let t=e.match(At);if(t){let o=t[1].toLowerCase(),r=e.replace(St,"").trim();return{emotion:o,cleanText:r}}return{cleanText:e}}static isValidEmotion(e){return Qt.includes(e)}static cleanEmotionTags(e){return e.replace(St,"").trim()}static addEmotionTag(e,t){return`[${e}] ${t}`}};function wt(n){let{emotion:e,cleanText:t}=z.extractEmotion(n);return e?{emotion:e,text:t}:{text:t}}function eo(n){return n.map(e=>wt(e))}function to(n){return n.emotion?z.addEmotionTag(n.emotion,n.text):n.text}async function oo(n,e){let{blocks:t}=await n.chatOnce(e,!1,()=>{});return f.getFullText(t)}var Nt=(n,e)=>{try{return JSON.parse(n)}catch(t){if(e){e(n,t);return}throw t}},kt=async(n,e)=>{let t=n.body?.getReader();if(!t)throw new Error("Response body is null.");let o=new TextDecoder,r="",s=!1;for(;!s;){let{done:i,value:a}=await t.read();if(i)break;r+=o.decode(a,{stream:!0});let l=r.split(`
11
+ `);r=l.pop()||"";for(let c of l){let m=c.trim();if(!m||m.startsWith(":")||!m.startsWith("data:"))continue;let h=m.slice(5).trim();if(h==="[DONE]"){s=!0;break}e(h)}}};async function P(n,e,t={}){let o="";return await kt(n,r=>{let s=Nt(r,t.onJsonError);if(!s)return;let i=s.choices?.[0]?.delta?.content||"";i&&(e(i),o+=i)}),o}async function x(n,e,t={}){let o=[],r=new Map,s=t.appendTextBlock??f.append;await kt(n,l=>{let c=Nt(l,t.onJsonError);if(!c)return;let m=c.choices?.[0]?.delta;m?.content&&(e(m.content),s(o,m.content)),m?.tool_calls&&m.tool_calls.forEach(h=>{let u=r.get(h.index)??{id:h.id,name:h.function?.name,args:""};u.args+=h.function?.arguments||"",r.set(h.index,u)})});let i=Array.from(r.entries()).sort((l,c)=>l[0]-c[0]).map(([l,c])=>({type:"tool_use",id:c.id,name:c.name,input:JSON.parse(c.args||"{}")}));return{blocks:[...o,...i],stop_reason:i.length?"tool_use":"end"}}function I(n){let e=n?.choices?.[0],t=[];return 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||"{}")})):e?.message?.content&&t.push({type:"text",text:e.message.content}),{blocks:t,stop_reason:e?.finish_reason==="tool_calls"||t.some(o=>o.type==="tool_use")?"tool_use":"end"}}var b=(n,e="chat-completions")=>n.length===0?[]:e==="responses"?n.map(t=>({type:"function",name:t.name,description:t.description,parameters:t.parameters})):n.map(t=>({type:"function",function:{name:t.name,description:t.description,parameters:t.parameters}}));async function v(n){if(!n.hasTools){let t=await n.runWithoutTools();await n.onCompleteResponse(t);return}let e=await n.runWithTools();if(n.onToolBlocks&&n.onToolBlocks(e.blocks),e.stop_reason==="end"){let t=f.getFullText(e.blocks);await n.onCompleteResponse(t);return}throw new Error(n.toolErrorMessage)}var C=n=>{let e=n.model??n.defaultModel,t=n.visionModel??(n.supportsVisionForModel(e)?e:n.defaultVisionModel);if(n.validate==="explicit"&&n.visionModel&&!n.supportsVisionForModel(n.visionModel))throw new Error(`Model ${n.visionModel} does not support vision capabilities.`);if(n.validate==="resolved"&&!n.supportsVisionForModel(t))throw new Error(`Model ${t} does not support vision capabilities.`);return t};var ro="https://openrouter.ai/api/v1/models",so=2,io=12e3,no=1,ao=10;function Pt(n){return n instanceof Error?n.message:String(n)}function ot(n,e){return typeof n!="number"||!Number.isFinite(n)?e:Math.max(1,Math.floor(n))}function lo(n){let e=new Set,t=[];for(let o of n){let r=o.trim();!r||e.has(r)||(e.add(r),t.push(r))}return t}async function Vt(n,e,t){if(!(typeof AbortController<"u"))return fetch(n,e);let r=new AbortController,s=setTimeout(()=>r.abort(),t);try{return await fetch(n,{...e,signal:r.signal})}catch(i){throw i instanceof Error&&i.name==="AbortError"?new Error(`Timeout after ${t}ms`):i}finally{clearTimeout(s)}}async function Ft(n){let e=`HTTP ${n.status} ${n.statusText}`.trim(),t="";try{t=await n.text()}catch{return e}let o=t.replace(/\s+/g," ").trim().slice(0,200);return o?`${e}: ${o}`:e}function po(n){if(!n||typeof n!="object")throw new Error("Invalid models response shape");let e=n,t=Array.isArray(e.data)?e.data:Array.isArray(e.models)?e.models:[];if(t.length===0)return[];let o=t.map(r=>r.id).filter(r=>typeof r=="string");return lo(o)}async function co({modelId:n,apiKey:e,endpoint:t,timeoutMs:o,appName:r,appUrl:s}){let i={Authorization:`Bearer ${e}`,"Content-Type":"application/json"};r&&(i["X-Title"]=r),s&&(i["HTTP-Referer"]=s);try{let a=await Vt(t,{method:"POST",headers:i,body:JSON.stringify({model:n,messages:[{role:"user",content:"Reply only with OK."}],stream:!1})},o);if(!a.ok)return{id:n,ok:!1,reason:await Ft(a)};try{await a.json()}catch(l){return{id:n,ok:!1,reason:`JSON parse failed: ${Pt(l)}`}}return{id:n,ok:!0}}catch(a){return{id:n,ok:!1,reason:Pt(a)}}}async function ho(n,e,t){if(n.length===0)return[];let o=new Array(n.length),r=0,s=Math.min(e,n.length);return await Promise.all(Array.from({length:s},async()=>{for(;r<n.length;){let i=r;r+=1,o[i]=await t(n[i])}})),o}async function mo(n){let e=n.apiKey.trim();if(!e)throw new Error("OpenRouter API key is required.");let t=n.modelsEndpoint||ro,o=n.endpoint||me,r=ot(n.timeoutMs,io),s=ot(n.concurrency,so),i=ot(n.maxCandidates,no),a=ot(n.maxWorking,ao),l=await Vt(t,{method:"GET"},r);if(!l.ok)throw new Error(await Ft(l));let c;try{c=await l.json()}catch(_){throw new Error(`JSON parse failed: ${Pt(_)}`)}let m=po(c).filter(_=>k(_)).slice(0,i),h=await ho(m,s,_=>co({modelId:_,apiKey:e,endpoint:o,timeoutMs:r,appName:n.appName,appUrl:n.appUrl})),u=h.filter(_=>_.ok).map(_=>_.id).slice(0,a),p=h.filter(_=>!_.ok).map(_=>({id:_.id,reason:_.reason||"Unknown error"}));return{working:u,failed:p,fetchedAt:Date.now()}}var q=class{constructor(e,t=T,o=T,r=[],s=[],i){this.provider="claude";if(this.apiKey=e,this.model=t||T,this.visionModel=o||T,this.tools=r,this.mcpServers=s,this.responseLength=i,!he.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 v({hasTools:this.tools.length>0||this.mcpServers.length>0,runWithoutTools:async()=>{let r=await this.callClaude(e,this.model,!0);return this.parsePureStream(r,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 v({hasTools:this.tools.length>0||this.mcpServers.length>0,runWithoutTools:async()=>{let r=await this.callClaude(e,this.visionModel,!0);return this.parsePureStream(r,t)},runWithTools:()=>this.visionChatOnce(e),onCompleteResponse:o,toolErrorMessage:"processVisionChat received tool_calls. ChatProcessor must use chatOnce() loop when tools are enabled."})}convertMessagesToClaudeFormat(e){return e.map(t=>({role:this.mapRoleToClaude(t.role),content:t.content}))}convertVisionMessagesToClaudeFormat(e){return e.map(t=>{if(typeof t.content=="string")return{role:this.mapRoleToClaude(t.role),content:[{type:"text",text:t.content}]};if(Array.isArray(t.content)){let o=t.content.map(r=>{if(r.type==="image_url"){if(r.image_url.url.startsWith("data:")){let s=r.image_url.url.match(/^data:([^;]+);base64,(.+)$/);return s?{type:"image",source:{type:"base64",media_type:s[1],data:s[2]}}:null}return{type:"image",source:{type:"url",url:r.image_url.url,media_type:this.getMimeTypeFromUrl(r.image_url.url)}}}return r}).filter(r=>r);return{role:this.mapRoleToClaude(t.role),content:o}}return{role:this.mapRoleToClaude(t.role),content:[]}})}mapRoleToClaude(e){switch(e){case"system":return"system";case"user":return"user";case"assistant":return"assistant";default:return"user"}}getMimeTypeFromUrl(e){switch(e.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"}}async callClaude(e,t,o,r){let s=e.find(h=>h.role==="system")?.content??"",i=e.filter(h=>h.role!=="system"),a=i.some(h=>Array.isArray(h.content)&&h.content.some(u=>u.type==="image_url"||u.type==="image")),l={model:t,system:s,messages:a?this.convertVisionMessagesToClaudeFormat(i):this.convertMessagesToClaudeFormat(i),stream:o,max_tokens:r!==void 0?r:O(this.responseLength)};this.tools.length&&(l.tools=this.tools.map(h=>({name:h.name,description:h.description,input_schema:h.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 g.post(mt,l,c)}async parseStream(e,t){let o=e.body.getReader(),r=new TextDecoder,s=[],i=new Map,a="";for(;;){let{done:l,value:c}=await o.read();if(l)break;a+=r.decode(c,{stream:!0});let m;for(;(m=a.indexOf(`
12
+ `))!==-1;){let h=a.slice(0,m).trim();if(a=a.slice(m+1),!h.startsWith("data:"))continue;let u=h.slice(5).trim();if(u==="[DONE]")break;let p=JSON.parse(u);if(p.type==="content_block_delta"&&p.delta?.text&&(t(p.delta.text),s.push({type:"text",text:p.delta.text})),p.type==="content_block_start"&&p.content_block?.type==="tool_use"?i.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"?i.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"?s.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"&&s.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 _=i.get(p.index);_&&(_.args+=p.delta.partial_json||"")}if(p.type==="content_block_stop"&&i.has(p.index)){let{id:_,name:M,args:d,server_name:E}=i.get(p.index);E?s.push({type:"mcp_tool_use",id:_,name:M,server_name:E,input:JSON.parse(d||"{}")}):s.push({type:"tool_use",id:_,name:M,input:JSON.parse(d||"{}")}),i.delete(p.index)}}}return{blocks:s,stop_reason:s.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(r=>r.type==="text").map(r=>r.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=()=>{},r){let s=await this.callClaude(e,this.model,t,r),i=t?await this.parseStream(s,o):this.parseOneShot(await s.json());return this.convertToStandardCompletion(i)}async visionChatOnce(e,t=!1,o=()=>{},r){let s=await this.callClaude(e,this.visionModel,t,r),i=t?await this.parseStream(s,o):this.parseOneShot(await s.json());return this.convertToStandardCompletion(i)}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 J=class{createChatService(e){let t=C({model:e.model,visionModel:e.visionModel,defaultModel:this.getDefaultModel(),defaultVisionModel:this.getDefaultModel(),supportsVisionForModel:o=>this.supportsVisionForModel(o),validate:"resolved"});return new q(e.apiKey,e.model||this.getDefaultModel(),t,e.tools??[],e.mcpServers??[],e.responseLength)}getProviderName(){return"claude"}getSupportedModels(){return[T,Ie,be,Le,Re,De,Ae,we,Ne,ke,Ve]}getDefaultModel(){return T}supportsVision(){return!0}supportsVisionForModel(e){return he.includes(e)}};var rt=class{static async fetchToolSchemas(e){try{let t={"Content-Type":"application/json"};e.authorization_token&&(t.Authorization=`Bearer ${e.authorization_token}`);let r=await(await g.post(`${e.url}/tools`,{},t)).json();return Array.isArray(r.tools)?r.tools.map(s=>({name:`mcp_${e.name}_${s.name}`,description:s.description||`Tool from ${e.name} MCP server`,parameters:s.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 r=await this.fetchToolSchemas(o);t.push(...r)}catch(r){console.error(`Failed to fetch schemas from ${o.name}:`,r)}return t}};var Z=class{constructor(e,t=R,o=R,r=[],s=[],i){this.provider="gemini";this.mcpToolSchemas=[];this.mcpSchemasInitialized=!1;this.callIdMap=new Map;if(this.apiKey=e,this.model=t,this.responseLength=i,!ce.includes(o))throw new Error(`Model ${o} does not support vision capabilities.`);this.visionModel=o,this.tools=r,this.mcpServers=s}safeJsonParse(e){try{return JSON.parse(e)}catch{return e}}normalizeToolResult(e){return e===null?{content:null}:typeof e=="object"?e:{content:e}}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,r])=>[t[o]??o,this.adaptKeysForApi(r)])):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,r)=>setTimeout(()=>r(new Error("MCP schema fetch timeout")),5e3)),t=rt.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=this.mcpServers.map(t=>({name:`mcp_${t.name}_search`,description:`Search using ${t.name} MCP server (fallback)`,parameters:{type:"object",properties:{query:{type:"string",description:"Search query"}},required:["query"]}})),this.mcpSchemasInitialized=!0}}async processChat(e,t,o){try{await v({hasTools:this.tools.length>0||this.mcpServers.length>0,runWithoutTools:async()=>{let r=await this.callGemini(e,this.model,!0),{blocks:s}=await this.parseStream(r,t);return f.getFullText(s)},runWithTools:()=>this.chatOnce(e,!0,t),onCompleteResponse:o,toolErrorMessage:"Received functionCall. Use chatOnce() loop when tools are enabled."})}catch(r){throw console.error("Error in processChat:",r),r}}async processVisionChat(e,t,o){try{await v({hasTools:this.tools.length>0||this.mcpServers.length>0,runWithoutTools:async()=>{let r=await this.callGemini(e,this.visionModel,!0),{blocks:s}=await this.parseStream(r,t);return f.getFullText(s)},runWithTools:()=>this.visionChatOnce(e),onToolBlocks:r=>{r.filter(s=>s.type==="text").forEach(s=>t(s.text))},onCompleteResponse:o,toolErrorMessage:"Received functionCall. Use visionChatOnce() loop when tools are enabled."})}catch(r){throw console.error("Error in processVisionChat:",r),r}}convertMessagesToGeminiFormat(e){let t=[],o=null,r=[],s=()=>{o&&r.length&&(t.push({role:o,parts:[...r]}),r=[])};for(let i of e){let a=this.mapRoleToGemini(i.role);if(i.tool_calls){s();for(let l of i.tool_calls)this.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(i.role==="tool"){s();let l=i.name??this.callIdMap.get(i.tool_call_id)??"result";t.push({role:"user",parts:[{functionResponse:{name:l,response:this.normalizeToolResult(this.safeJsonParse(i.content))}}]});continue}a!==o&&s(),o=a,r.push({text:i.content})}return s(),t}async callGemini(e,t,o=!1,r){let a={contents:e.some(d=>Array.isArray(d.content)&&d.content.some(E=>E?.type==="image_url"||E?.inlineData))?await this.convertVisionMessagesToGeminiFormat(e):this.convertMessagesToGeminiFormat(e),generationConfig:{maxOutputTokens:r!==void 0?r:O(this.responseLength)}},l=[];if(this.tools.length>0&&l.push(...this.tools.map(d=>({name:d.name,description:d.description,parameters:d.parameters}))),this.mcpServers.length>0)try{await this.initializeMCPSchemas(),l.push(...this.mcpToolSchemas.map(d=>({name:d.name,description:d.description,parameters:d.parameters})))}catch(d){console.warn("MCP initialization failed, skipping MCP tools:",d)}l.length>0&&(a.tools=[{functionDeclarations:l}],a.toolConfig={functionCallingConfig:{mode:"AUTO"}});let c=async(d,E)=>{let st=o?"streamGenerateContent":"generateContent",xt=o?"?alt=sse":"",Ht=`${ht}/${d}/models/${t}:${st}${xt}${xt?"&":"?"}key=${this.apiKey}`;return g.post(Ht,E)},m=/flash[-_]lite/.test(t),h=/gemini-2\.5/.test(t),u=/^gemini-3(?:\.[0-9]+)?-.*preview/.test(t),p=m||h||u,_=p?"v1beta":"v1",M=async()=>{try{let d=_==="v1"?a:this.adaptKeysForApi(a);return await c(_,d)}catch(d){let E=/Unknown name|Cannot find field|404/.test(d?.message||"")||d?.status===404;if(!p&&E)return await c("v1beta",this.adaptKeysForApi(a));throw d}};try{return await M()}catch(d){throw d.body&&(console.error("Gemini API Error Details:",d.body),console.error("Request Body:",JSON.stringify(a,null,2))),d}}async convertVisionMessagesToGeminiFormat(e){let t=[],o=null,r=[];for(let s of e){let i=this.mapRoleToGemini(s.role);if(s.tool_calls){for(let a of s.tool_calls)t.push({role:"model",parts:[{functionCall:{name:a.function.name,args:JSON.parse(a.function.arguments||"{}")}}]});continue}if(s.role==="tool"){let a=s.name??this.callIdMap.get(s.tool_call_id)??"result";t.push({role:"user",parts:[{functionResponse:{name:a,response:this.normalizeToolResult(this.safeJsonParse(s.content))}}]});continue}if(i!==o&&r.length>0&&(t.push({role:o,parts:[...r]}),r=[]),o=i,typeof s.content=="string")r.push({text:s.content});else if(Array.isArray(s.content)){for(let a of s.content)if(a.type==="text")r.push({text:a.text});else if(a.type==="image_url")try{let c=await(await g.get(a.image_url.url)).blob(),m=await this.blobToBase64(c);r.push({inlineData:{mimeType:c.type||"image/jpeg",data:m.split(",")[1]}})}catch(l){throw console.error("Error processing image:",l),new Error(`Failed to process image: ${l.message}`)}}}return o&&r.length>0&&t.push({role:o,parts:[...r]}),t}blobToBase64(e){return new Promise((t,o)=>{let r=new FileReader;r.onloadend=()=>t(r.result),r.onerror=o,r.readAsDataURL(e)})}mapRoleToGemini(e){switch(e){case"system":return"model";case"user":return"user";case"assistant":return"model";default:return"user"}}async parseStream(e,t){let o=e.body.getReader(),r=new TextDecoder,s=[],i=[],a="",l=m=>{if(!m||m==="[DONE]")return;let h;try{h=JSON.parse(m)}catch{return}for(let u of h.candidates??[])for(let p of u.content?.parts??[])p.text&&(t(p.text),f.addTextBlock(s,p.text)),p.functionCall&&i.push({type:"tool_use",id:this.genUUID(),name:p.functionCall.name,input:p.functionCall.args??{}}),p.functionResponse&&i.push({type:"tool_result",tool_use_id:p.functionResponse.name,content:JSON.stringify(p.functionResponse.response)})};for(;;){let{done:m,value:h}=await o.read();if(m)break;a+=r.decode(h,{stream:!0});let u;for(;(u=a.indexOf(`
13
+ `))!==-1;){let p=a.slice(0,u);if(a=a.slice(u+1),p.endsWith("\r")&&(p=p.slice(0,-1)),!p.trim()){l("");continue}p.startsWith("data:")&&(p=p.slice(5).trim()),p&&l(p)}}return a&&l(a),{blocks:[...s,...i],stop_reason:i.some(m=>m.type==="tool_use")?"tool_use":"end"}}parseOneShot(e){let t=[],o=[];for(let s of e.candidates??[])for(let i of s.content?.parts??[])i.text&&t.push({type:"text",text:i.text}),i.functionCall&&o.push({type:"tool_use",id:this.genUUID(),name:i.functionCall.name,input:i.functionCall.args??{}}),i.functionResponse&&o.push({type:"tool_result",tool_use_id:i.functionResponse.name,content:JSON.stringify(i.functionResponse.response)});return{blocks:[...t,...o],stop_reason:o.some(s=>s.type==="tool_use")?"tool_use":"end"}}async chatOnce(e,t=!0,o=()=>{},r){let s=await this.callGemini(e,this.model,t,r);return t?this.parseStream(s,o):this.parseOneShot(await s.json())}async visionChatOnce(e,t=!1,o=()=>{},r){let s=await this.callGemini(e,this.visionModel,t,r);return t?this.parseStream(s,o):this.parseOneShot(await s.json())}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 X=class{createChatService(e){let t=C({model:e.model,visionModel:e.visionModel,defaultModel:this.getDefaultModel(),defaultVisionModel:this.getDefaultModel(),supportsVisionForModel:o=>this.supportsVisionForModel(o),validate:"resolved"});return new Z(e.apiKey,e.model||this.getDefaultModel(),t,e.tools||[],e.mcpServers||[],e.responseLength)}getProviderName(){return"gemini"}getSupportedModels(){return[Me,Oe,Ce,Ee,ye,Te,Se,Pe,xe,R]}getDefaultModel(){return R}supportsVision(){return!0}supportsVisionForModel(e){return ce.includes(e)}};var Y=class{constructor(e,t=S,o=S,r,s=$,i,a,l){this.provider="kimi";this.apiKey=e,this.model=t,this.tools=r||[],this.endpoint=s,this.responseLength=i,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 v({hasTools:this.tools.length>0,runWithoutTools:async()=>{let r=await this.callKimi(e,this.model,!0);return this.handleStream(r,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(!j(this.visionModel))throw new Error(`Model ${this.visionModel} does not support vision capabilities.`);await v({hasTools:this.tools.length>0,runWithoutTools:async()=>{let r=await this.callKimi(e,this.visionModel,!0);return this.handleStream(r,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=()=>{},r){let s=await this.callKimi(e,this.model,t,r);return this.parseResponse(s,t,o)}async visionChatOnce(e,t=!1,o=()=>{},r){if(!j(this.visionModel))throw new Error(`Model ${this.visionModel} does not support vision capabilities.`);let s=await this.callKimi(e,this.visionModel,t,r);return this.parseResponse(s,t,o)}async parseResponse(e,t,o){return t?this.parseStream(e,o):this.parseOneShot(await e.json())}async callKimi(e,t,o=!1,r){let s=this.buildRequestBody(e,t,o,r);return await g.post(this.endpoint,s,{Authorization:`Bearer ${this.apiKey}`})}buildRequestBody(e,t,o,r){let s={model:t,stream:o,messages:e},i=r!==void 0?r:O(this.responseLength);i!==void 0&&(s.max_tokens=i),this.responseFormat&&(s.response_format=this.responseFormat);let a=this.tools.length>0?{type:"disabled"}:this.thinking;a&&(this.isSelfHostedEndpoint()?a.type==="disabled"&&(s.chat_template_kwargs={thinking:!1}):s.thinking=a);let l=this.buildToolsDefinition();return l.length>0&&(s.tools=l,s.tool_choice="auto"),s}isSelfHostedEndpoint(){return this.normalizeEndpoint(this.endpoint)!==this.normalizeEndpoint($)}normalizeEndpoint(e){return e.replace(/\/+$/,"")}buildToolsDefinition(){return b(this.tools,"chat-completions")}async handleStream(e,t){return P(e,t,{onJsonError:o=>console.debug("Failed to parse SSE data:",o)})}async parseStream(e,t){return x(e,t,{onJsonError:o=>console.debug("Failed to parse SSE data:",o)})}parseOneShot(e){return I(e)}};var Q=class{createChatService(e){let t=this.resolveEndpoint(e),o=e.model||this.getDefaultModel(),r=C({model:o,visionModel:e.visionModel,defaultModel:this.getDefaultModel(),defaultVisionModel:this.getDefaultVisionModel(),supportsVisionForModel:l=>this.supportsVisionForModel(l),validate:"explicit"}),s=e.tools,i=e.thinking??{type:"enabled"},a=s&&s.length>0?{type:"disabled"}:i;return new Y(e.apiKey,o,r,s,t,e.responseLength,e.responseFormat,a)}getProviderName(){return"kimi"}getSupportedModels(){return[S]}getDefaultModel(){return S}getDefaultVisionModel(){return S}supportsVision(){return!0}supportsVisionForModel(e){return j(e)}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 $}normalizeEndpoint(e){return e.replace(/\/+$/,"")}};var w=class{constructor(e,t=N,o=N,r,s=G,i=[],a,l,c,m=!1,h="openai",u=!0){if(this.provider=h,this.apiKey=e,this.model=t,this.tools=r||[],this.endpoint=s,this.mcpServers=i,this.responseLength=a,this.verbosity=l,this.reasoning_effort=c,this.enableReasoningSummary=m,u&&!pe.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 v({hasTools:this.tools.length>0,runWithoutTools:async()=>{let r=await this.callOpenAI(e,this.model,!0),s=this.endpoint===y;try{if(s){let i=await this.parseResponsesStream(r,t);return f.getFullText(i.blocks)}return this.handleStream(r,t)}catch(i){throw console.error("[processChat] Error in streaming/completion:",i),i}},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 v({hasTools:this.tools.length>0,runWithoutTools:async()=>{let r=await this.callOpenAI(e,this.visionModel,!0),s=this.endpoint===y;try{if(s){let i=await this.parseResponsesStream(r,t);return f.getFullText(i.blocks)}return this.handleStream(r,t)}catch(i){throw console.error("[processVisionChat] Error in streaming/completion:",i),i}},runWithTools:()=>this.visionChatOnce(e,!0,t),onCompleteResponse:o,toolErrorMessage:"processVisionChat received tool_calls. ChatProcessor must use visionChatOnce() loop when tools are enabled."})}catch(r){throw console.error("Error in processVisionChat:",r),r}}async chatOnce(e,t=!0,o=()=>{},r){let s=await this.callOpenAI(e,this.model,t,r);return this.parseResponse(s,t,o)}async visionChatOnce(e,t=!1,o=()=>{},r){let s=await this.callOpenAI(e,this.visionModel,t,r);return this.parseResponse(s,t,o)}async parseResponse(e,t,o){return this.endpoint===y?t?this.parseResponsesStream(e,o):this.parseResponsesOneShot(await e.json()):t?this.parseStream(e,o):this.parseOneShot(await e.json())}async callOpenAI(e,t,o=!1,r){let s=this.buildRequestBody(e,t,o,r),i={};return(this.provider!=="openai-compatible"||this.apiKey.trim()!=="")&&(i.Authorization=`Bearer ${this.apiKey}`),await g.post(this.endpoint,s,i)}buildRequestBody(e,t,o,r){let s=this.endpoint===y;this.validateMCPCompatibility();let i={model:t,stream:o},a=r!==void 0?r:this.provider==="openai-compatible"?this.responseLength!==void 0?O(this.responseLength):void 0:O(this.responseLength);s?a!==void 0&&(i.max_output_tokens=a):a!==void 0&&(this.provider==="openai-compatible"?i.max_tokens=a:i.max_completion_tokens=a),s?i.input=this.cleanMessagesForResponsesAPI(e):i.messages=e,H(t)&&(s?(this.reasoning_effort&&(i.reasoning={...i.reasoning,effort:this.reasoning_effort},this.enableReasoningSummary&&(i.reasoning.summary="auto")),this.verbosity&&(i.text={...i.text,format:{type:"text"},verbosity:this.verbosity})):(this.reasoning_effort&&(i.reasoning_effort=this.reasoning_effort),this.verbosity&&(i.verbosity=this.verbosity)));let l=this.buildToolsDefinition();return l.length>0&&(i.tools=l,s||(i.tool_choice="auto")),i}validateMCPCompatibility(){if(this.mcpServers.length>0&&this.endpoint===G)throw new Error(`MCP servers are not supported with Chat Completions API. Current endpoint: ${this.endpoint}. Please use OpenAI Responses API endpoint: ${y}. MCP tools are only available in the Responses API endpoint.`)}cleanMessagesForResponsesAPI(e){return e.map(t=>{let r={role:t.role==="tool"?"user":t.role};return typeof t.content=="string"?r.content=t.content:Array.isArray(t.content)?r.content=t.content.map(s=>s.type==="text"?{type:"input_text",text:s.text}:s.type==="image_url"?{type:"input_image",image_url:s.image_url.url}:s):r.content=t.content,r})}buildToolsDefinition(){let e=this.endpoint===y,t=[];return this.tools.length>0&&t.push(...b(this.tools,e?"responses":"chat-completions")),this.mcpServers.length>0&&e&&t.push(...this.buildMCPToolsDefinition()),t}buildMCPToolsDefinition(){return this.mcpServers.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})}async handleStream(e,t){return P(e,t)}async parseStream(e,t){return x(e,t,{appendTextBlock:f.addTextBlock})}parseOneShot(e){return I(e)}async parseResponsesStream(e,t){let o=e.body.getReader(),r=new TextDecoder,s=[],i=new Map,a="";for(;;){let{done:m,value:h}=await o.read();if(m)break;a+=r.decode(h,{stream:!0});let u="",p="",_=a.split(`
14
+ `);a=_.pop()||"";for(let M=0;M<_.length;M++){let d=_[M].trim();if(d.startsWith("event:"))u=d.slice(6).trim();else if(d.startsWith("data:"))p=d.slice(5).trim();else if(d===""&&u&&p){try{let E=JSON.parse(p),st=this.handleResponsesSSEEvent(u,E,t,s,i)}catch{console.warn("Failed to parse SSE data:",p)}u="",p=""}}}let l=Array.from(i.values()).map(m=>({type:"tool_use",id:m.id,name:m.name,input:m.input||{}}));return{blocks:[...s,...l],stop_reason:l.length?"tool_use":"end"}}handleResponsesSSEEvent(e,t,o,r,s){switch(e){case"response.output_item.added":t.item?.type==="message"&&Array.isArray(t.item.content)?t.item.content.forEach(i=>{i.type==="output_text"&&i.text&&(o(i.text),f.append(r,i.text))}):t.item?.type==="function_call"&&s.set(t.item.id,{id:t.item.id,name:t.item.name,input:t.item.arguments?JSON.parse(t.item.arguments):{}});break;case"response.content_part.added":t.part?.type==="output_text"&&typeof t.part.text=="string"&&(o(t.part.text),f.append(r,t.part.text));break;case"response.output_text.delta":case"response.content_part.delta":{let i=typeof t.delta=="string"?t.delta:t.delta?.text??"";i&&(o(i),f.append(r,i))}break;case"response.output_text.done":case"response.content_part.done":break;case"response.completed":return"completed";case"response.reasoning.started":case"response.reasoning.delta":case"response.reasoning.done":break;default:break}}parseResponsesOneShot(e){let t=[];return e.output&&Array.isArray(e.output)&&e.output.forEach(o=>{o.type==="message"&&o.content&&o.content.forEach(r=>{r.type==="output_text"&&r.text&&t.push({type:"text",text:r.text})}),o.type==="function_call"&&t.push({type:"tool_use",id:o.id,name:o.name,input:o.arguments?JSON.parse(o.arguments):{}})}),{blocks:t,stop_reason:t.some(o=>o.type==="tool_use")?"tool_use":"end"}}};var ee=class{createChatService(e){return this.validateRequiredOptions(e),new w(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!1}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 te=class{createChatService(e){let t=this.optimizeGPT5Options(e),o=C({model:t.model,visionModel:t.visionModel,defaultModel:this.getDefaultModel(),defaultVisionModel:this.getDefaultModel(),supportsVisionForModel:c=>this.supportsVisionForModel(c),validate:"resolved"}),r=t.tools,s=t.mcpServers??[],i=t.model||this.getDefaultModel(),a=!1;s.length>0?a=!0:H(i)&&(a=(t.gpt5EndpointPreference||"chat")==="responses");let l=t.endpoint||(a?y:G);return new w(t.apiKey,i,o,r,l,s,t.responseLength,t.verbosity,t.reasoning_effort,t.enableReasoningSummary,this.getProviderName())}getProviderName(){return"openai"}getSupportedModels(){return[U,ae,le,L,_e,ge,fe,N,ve,nt,at,"o1"]}getDefaultModel(){return U}supportsVision(){return!0}supportsVisionForModel(e){return pe.includes(e)}optimizeGPT5Options(e){let t=e.model||this.getDefaultModel();if(!H(t))return e;let o={...e};if(e.gpt5Preset){let r=Tt[e.gpt5Preset];o.reasoning_effort=r.reasoning_effort,o.verbosity=r.verbosity}else e.reasoning_effort||(o.reasoning_effort=this.getDefaultReasoningEffortForModel(t));return o.reasoning_effort=this.normalizeReasoningEffort(t,o.reasoning_effort),o}getDefaultReasoningEffortForModel(e){return e===L?"none":"medium"}normalizeReasoningEffort(e,t){if(t)return t==="none"&&!pt(e)?this.getDefaultReasoningEffortForModel(e):t==="minimal"&&!ct(e)?"none":t}};var oe=class{constructor(e,t=D,o=D,r,s=me,i,a,l,c,m,h){this.provider="openrouter";this.lastRequestTime=0;this.requestCount=0;this.apiKey=e,this.model=t,this.tools=r||[],this.endpoint=s,this.responseLength=i,this.appName=a,this.appUrl=l,this.reasoning_effort=c,this.includeReasoning=m,this.reasoningMaxTokens=h,this.visionModel=o}getModel(){return this.model}getVisionModel(){return this.visionModel}async applyRateLimiting(){if(!k(this.model))return;let e=Date.now(),t=e-this.lastRequestTime;if(t>6e4&&(this.requestCount=0),this.requestCount>=ft){let o=6e4-t;o>0&&(console.log(`Rate limit reached for free tier. Waiting ${o}ms...`),await new Promise(r=>setTimeout(r,o)),this.requestCount=0)}this.lastRequestTime=e,this.requestCount++}async processChat(e,t,o){await this.applyRateLimiting(),await v({hasTools:this.tools.length>0,runWithoutTools:async()=>{let r=await this.callOpenRouter(e,this.model,!0);return this.handleStream(r,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(!W(this.visionModel))throw new Error(`Model ${this.visionModel} does not support vision capabilities.`);await this.applyRateLimiting();try{await v({hasTools:this.tools.length>0,runWithoutTools:async()=>{let r=await this.callOpenRouter(e,this.visionModel,!0);return this.handleStream(r,t)},runWithTools:()=>this.visionChatOnce(e,!0,t),onCompleteResponse:o,toolErrorMessage:"processVisionChat received tool_calls. ChatProcessor must use visionChatOnce() loop when tools are enabled."})}catch(r){throw console.error("Error in processVisionChat:",r),r}}async chatOnce(e,t=!0,o=()=>{},r){await this.applyRateLimiting();let s=await this.callOpenRouter(e,this.model,t,r);return t?this.parseStream(s,o):this.parseOneShot(await s.json())}async visionChatOnce(e,t=!1,o=()=>{},r){if(!W(this.visionModel))throw new Error(`Model ${this.visionModel} does not support vision capabilities.`);await this.applyRateLimiting();let s=await this.callOpenRouter(e,this.visionModel,t,r);return t?this.parseStream(s,o):this.parseOneShot(await s.json())}async callOpenRouter(e,t,o=!1,r){let s=this.buildRequestBody(e,t,o,r),i={Authorization:`Bearer ${this.apiKey}`};return this.appUrl&&(i["HTTP-Referer"]=this.appUrl),this.appName&&(i["X-Title"]=this.appName),await g.post(this.endpoint,s,i)}buildRequestBody(e,t,o,r){let s={model:t,messages:e,stream:o};if((r!==void 0?r:O(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(s.reasoning={},this.reasoning_effort&&this.reasoning_effort!=="none"){let a=this.reasoning_effort==="minimal"?"low":this.reasoning_effort;s.reasoning.effort=a}(this.reasoning_effort==="none"||this.includeReasoning!==!0)&&(s.reasoning.exclude=!0),this.reasoningMaxTokens&&(s.reasoning.max_tokens=this.reasoningMaxTokens)}else s.reasoning={exclude:!0};return this.tools.length>0&&(s.tools=b(this.tools,"chat-completions"),s.tool_choice="auto"),s}async handleStream(e,t){return P(e,t,{onJsonError:o=>console.debug("Failed to parse SSE data:",o)})}async parseStream(e,t){return x(e,t,{onJsonError:o=>console.debug("Failed to parse SSE data:",o)})}parseOneShot(e){return I(e)}};var re=class{createChatService(e){let t=C({model:e.model,visionModel:e.visionModel,defaultModel:this.getDefaultModel(),defaultVisionModel:e.model||this.getDefaultModel(),supportsVisionForModel:i=>this.supportsVisionForModel(i),validate:"explicit"}),o=e.tools,r=e.appName,s=e.appUrl;return new oe(e.apiKey,e.model||this.getDefaultModel(),t,o,e.endpoint,e.responseLength,r,s,e.reasoning_effort,e.includeReasoning,e.reasoningMaxTokens)}getProviderName(){return"openrouter"}getSupportedModels(){return[D,Qe,Ge,Ue,He,We,Be,Ke,$e,je,ze,qe,ut,Je,Ze,Xe,Ye,dt,_t,Fe]}getDefaultModel(){return D}supportsVision(){return this.getSupportedModels().some(e=>this.supportsVisionForModel(e))}supportsVisionForModel(e){return W(e)}getFreeModels(){return gt}isModelFree(e){return k(e)}};var se=class{constructor(e,t=B,o=V,r,s=ue,i,a,l){this.provider="zai";this.apiKey=e,this.model=t,this.tools=r||[],this.endpoint=s,this.responseLength=i,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 v({hasTools:this.tools.length>0,runWithoutTools:async()=>{let r=await this.callZAI(e,this.model,!0);return this.handleStream(r,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(!K(this.visionModel))throw new Error(`Model ${this.visionModel} does not support vision capabilities.`);await v({hasTools:this.tools.length>0,runWithoutTools:async()=>{let r=await this.callZAI(e,this.visionModel,!0);return this.handleStream(r,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=()=>{},r){let s=await this.callZAI(e,this.model,t,r);return this.parseResponse(s,t,o)}async visionChatOnce(e,t=!1,o=()=>{},r){if(!K(this.visionModel))throw new Error(`Model ${this.visionModel} does not support vision capabilities.`);let s=await this.callZAI(e,this.visionModel,t,r);return this.parseResponse(s,t,o)}async parseResponse(e,t,o){return t?this.parseStream(e,o):this.parseOneShot(await e.json())}async callZAI(e,t,o=!1,r){let s=this.buildRequestBody(e,t,o,r);return await g.post(this.endpoint,s,{Authorization:`Bearer ${this.apiKey}`})}buildRequestBody(e,t,o,r){let s={model:t,stream:o,messages:e},i=r!==void 0?r:O(this.responseLength);i!==void 0&&(s.max_tokens=i),this.responseFormat&&(s.response_format=this.responseFormat),this.thinking&&(s.thinking=this.thinking);let a=this.buildToolsDefinition();return a.length>0&&(s.tools=a,s.tool_choice="auto",o&&Et(t)&&(s.tool_stream=!0)),s}buildToolsDefinition(){return b(this.tools,"chat-completions")}async handleStream(e,t){return P(e,t,{onJsonError:o=>console.debug("Failed to parse SSE data:",o)})}async parseStream(e,t){return x(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=C({model:t,visionModel:e.visionModel,defaultModel:this.getDefaultModel(),defaultVisionModel:this.getDefaultVisionModel(),supportsVisionForModel:i=>this.supportsVisionForModel(i),validate:"explicit"}),r=e.tools,s=e.thinking??{type:"disabled"};return new se(e.apiKey,t,o,r,e.endpoint||ue,e.responseLength,e.responseFormat,s)}getProviderName(){return"zai"}getSupportedModels(){return[vt,B,Mt,Ot,Ct,et,tt,V]}getDefaultModel(){return B}getDefaultVisionModel(){return V}supportsVision(){return!0}supportsVisionForModel(e){return K(e)}};var Gt=[new te,new ee,new X,new J,new re,new ie,new Q];var ne=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():[]}};ne.providers=new Map;Gt.forEach(n=>ne.registerProvider(n));function Ut(){g.setFetch(async(n,e={})=>{let t=(e.method||"GET").toString().toUpperCase(),o=e.headers,r={};if(Array.isArray(o))for(let[h,u]of o)r[h]=String(u);else if(o&&typeof o=="object")for(let[h,u]of Object.entries(o))r[h]=String(u);let s={method:t,headers:r,muteHttpExceptions:!0},i=e.body;typeof i=="string"?s.payload=i:i!=null&&(r["Content-Type"]||(r["Content-Type"]="application/json"),s.payload=JSON.stringify(i));let a=UrlFetchApp.fetch(n,s),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 zt(uo);})();
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@aituber-onair/chat",
3
- "version": "0.17.0",
3
+ "version": "0.18.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",