@aituber-onair/chat 0.7.0 → 0.8.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
@@ -403,7 +403,7 @@ type ChatResponseLength = 'veryShort' | 'short' | 'medium' | 'long' | 'veryLong'
403
403
 
404
404
  - **OpenAI**: GPT-5.1、GPT-5(Nano/Mini/Standard)、GPT-4.1(miniとnanoを含む), GPT-4, GPT-4o-mini, O3-mini, o1, o1-miniのモデルをサポート
405
405
  - **Gemini**: Gemini 2.5 Pro, Gemini 2.5 Flash, Gemini 2.5 Flash Lite Preview, Gemini 2.0 Flash, Gemini 2.0 Flash-Liteのモデルをサポート
406
- - **Claude**: 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のモデルをサポート
406
+ - **Claude**: 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のモデルをサポート
407
407
  - **OpenRouter**: `openai/gpt-oss-20b:free`(トークン制限の特別処理がある無料利用枠モデル)をサポート
408
408
 
409
409
  ## ライセンス
package/README.md CHANGED
@@ -1,6 +1,6 @@
1
1
  # @aituber-onair/chat
2
2
 
3
- ![@aituber-onair/chat logo](./images/aituber-onair-chat.png)
3
+ ![@aituber-onair/chat logo](https://github.com/shinshin86/aituber-onair/raw/main/packages/chat/images/aituber-onair-chat.png)
4
4
 
5
5
  Chat and LLM API integration library for AITuber OnAir. This package provides a unified interface for interacting with various AI chat providers including OpenAI, Claude, Gemini, and OpenRouter.
6
6
 
@@ -403,7 +403,7 @@ Currently, the following AI providers are built-in:
403
403
 
404
404
  - **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
405
405
  - **Gemini**: Supports models like Gemini 2.5 Pro, Gemini 2.5 Flash, Gemini 2.5 Flash Lite Preview, Gemini 2.0 Flash, Gemini 2.0 Flash-Lite
406
- - **Claude**: Supports models like 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
406
+ - **Claude**: Supports models like 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
407
407
  - **OpenRouter**: Supports `openai/gpt-oss-20b:free` (free tier model with special handling for token limits)
408
408
 
409
409
  ## License
@@ -7,5 +7,6 @@ export declare const MODEL_CLAUDE_4_SONNET = "claude-4-sonnet-20250514";
7
7
  export declare const MODEL_CLAUDE_4_OPUS = "claude-4-opus-20250514";
8
8
  export declare const MODEL_CLAUDE_4_5_SONNET = "claude-sonnet-4-5-20250929";
9
9
  export declare const MODEL_CLAUDE_4_5_HAIKU = "claude-haiku-4-5-20251001";
10
+ export declare const MODEL_CLAUDE_4_5_OPUS = "claude-opus-4-5-20251101";
10
11
  export declare const CLAUDE_VISION_SUPPORTED_MODELS: string[];
11
12
  //# sourceMappingURL=claude.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"claude.d.ts","sourceRoot":"","sources":["../../../src/constants/claude.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,mBAAmB,0CAA0C,CAAC;AAG3E,eAAO,MAAM,oBAAoB,4BAA4B,CAAC;AAC9D,eAAO,MAAM,sBAAsB,8BAA8B,CAAC;AAClE,eAAO,MAAM,uBAAuB,+BAA+B,CAAC;AACpE,eAAO,MAAM,uBAAuB,+BAA+B,CAAC;AACpE,eAAO,MAAM,qBAAqB,6BAA6B,CAAC;AAChE,eAAO,MAAM,mBAAmB,2BAA2B,CAAC;AAC5D,eAAO,MAAM,uBAAuB,+BAA+B,CAAC;AACpE,eAAO,MAAM,sBAAsB,8BAA8B,CAAC;AAElE,eAAO,MAAM,8BAA8B,UAS1C,CAAC"}
1
+ {"version":3,"file":"claude.d.ts","sourceRoot":"","sources":["../../../src/constants/claude.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,mBAAmB,0CAA0C,CAAC;AAG3E,eAAO,MAAM,oBAAoB,4BAA4B,CAAC;AAC9D,eAAO,MAAM,sBAAsB,8BAA8B,CAAC;AAClE,eAAO,MAAM,uBAAuB,+BAA+B,CAAC;AACpE,eAAO,MAAM,uBAAuB,+BAA+B,CAAC;AACpE,eAAO,MAAM,qBAAqB,6BAA6B,CAAC;AAChE,eAAO,MAAM,mBAAmB,2BAA2B,CAAC;AAC5D,eAAO,MAAM,uBAAuB,+BAA+B,CAAC;AACpE,eAAO,MAAM,sBAAsB,8BAA8B,CAAC;AAClE,eAAO,MAAM,qBAAqB,6BAA6B,CAAC;AAEhE,eAAO,MAAM,8BAA8B,UAU1C,CAAC"}
@@ -1,6 +1,6 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.CLAUDE_VISION_SUPPORTED_MODELS = exports.MODEL_CLAUDE_4_5_HAIKU = exports.MODEL_CLAUDE_4_5_SONNET = exports.MODEL_CLAUDE_4_OPUS = exports.MODEL_CLAUDE_4_SONNET = exports.MODEL_CLAUDE_3_7_SONNET = exports.MODEL_CLAUDE_3_5_SONNET = exports.MODEL_CLAUDE_3_5_HAIKU = exports.MODEL_CLAUDE_3_HAIKU = exports.ENDPOINT_CLAUDE_API = void 0;
3
+ exports.CLAUDE_VISION_SUPPORTED_MODELS = exports.MODEL_CLAUDE_4_5_OPUS = exports.MODEL_CLAUDE_4_5_HAIKU = exports.MODEL_CLAUDE_4_5_SONNET = exports.MODEL_CLAUDE_4_OPUS = exports.MODEL_CLAUDE_4_SONNET = exports.MODEL_CLAUDE_3_7_SONNET = exports.MODEL_CLAUDE_3_5_SONNET = exports.MODEL_CLAUDE_3_5_HAIKU = exports.MODEL_CLAUDE_3_HAIKU = exports.ENDPOINT_CLAUDE_API = void 0;
4
4
  exports.ENDPOINT_CLAUDE_API = 'https://api.anthropic.com/v1/messages';
5
5
  // claude model
6
6
  exports.MODEL_CLAUDE_3_HAIKU = 'claude-3-haiku-20240307';
@@ -11,6 +11,7 @@ exports.MODEL_CLAUDE_4_SONNET = 'claude-4-sonnet-20250514';
11
11
  exports.MODEL_CLAUDE_4_OPUS = 'claude-4-opus-20250514';
12
12
  exports.MODEL_CLAUDE_4_5_SONNET = 'claude-sonnet-4-5-20250929';
13
13
  exports.MODEL_CLAUDE_4_5_HAIKU = 'claude-haiku-4-5-20251001';
14
+ exports.MODEL_CLAUDE_4_5_OPUS = 'claude-opus-4-5-20251101';
14
15
  exports.CLAUDE_VISION_SUPPORTED_MODELS = [
15
16
  exports.MODEL_CLAUDE_3_HAIKU,
16
17
  exports.MODEL_CLAUDE_3_5_HAIKU,
@@ -20,5 +21,6 @@ exports.CLAUDE_VISION_SUPPORTED_MODELS = [
20
21
  exports.MODEL_CLAUDE_4_OPUS,
21
22
  exports.MODEL_CLAUDE_4_5_SONNET,
22
23
  exports.MODEL_CLAUDE_4_5_HAIKU,
24
+ exports.MODEL_CLAUDE_4_5_OPUS,
23
25
  ];
24
26
  //# sourceMappingURL=claude.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"claude.js","sourceRoot":"","sources":["../../../src/constants/claude.ts"],"names":[],"mappings":";;;AAAa,QAAA,mBAAmB,GAAG,uCAAuC,CAAC;AAE3E,eAAe;AACF,QAAA,oBAAoB,GAAG,yBAAyB,CAAC;AACjD,QAAA,sBAAsB,GAAG,2BAA2B,CAAC;AACrD,QAAA,uBAAuB,GAAG,4BAA4B,CAAC;AACvD,QAAA,uBAAuB,GAAG,4BAA4B,CAAC;AACvD,QAAA,qBAAqB,GAAG,0BAA0B,CAAC;AACnD,QAAA,mBAAmB,GAAG,wBAAwB,CAAC;AAC/C,QAAA,uBAAuB,GAAG,4BAA4B,CAAC;AACvD,QAAA,sBAAsB,GAAG,2BAA2B,CAAC;AAErD,QAAA,8BAA8B,GAAG;IAC5C,4BAAoB;IACpB,8BAAsB;IACtB,+BAAuB;IACvB,+BAAuB;IACvB,6BAAqB;IACrB,2BAAmB;IACnB,+BAAuB;IACvB,8BAAsB;CACvB,CAAC"}
1
+ {"version":3,"file":"claude.js","sourceRoot":"","sources":["../../../src/constants/claude.ts"],"names":[],"mappings":";;;AAAa,QAAA,mBAAmB,GAAG,uCAAuC,CAAC;AAE3E,eAAe;AACF,QAAA,oBAAoB,GAAG,yBAAyB,CAAC;AACjD,QAAA,sBAAsB,GAAG,2BAA2B,CAAC;AACrD,QAAA,uBAAuB,GAAG,4BAA4B,CAAC;AACvD,QAAA,uBAAuB,GAAG,4BAA4B,CAAC;AACvD,QAAA,qBAAqB,GAAG,0BAA0B,CAAC;AACnD,QAAA,mBAAmB,GAAG,wBAAwB,CAAC;AAC/C,QAAA,uBAAuB,GAAG,4BAA4B,CAAC;AACvD,QAAA,sBAAsB,GAAG,2BAA2B,CAAC;AACrD,QAAA,qBAAqB,GAAG,0BAA0B,CAAC;AAEnD,QAAA,8BAA8B,GAAG;IAC5C,4BAAoB;IACpB,8BAAsB;IACtB,+BAAuB;IACvB,+BAAuB;IACvB,6BAAqB;IACrB,2BAAmB;IACnB,+BAAuB;IACvB,8BAAsB;IACtB,6BAAqB;CACtB,CAAC"}
@@ -1 +1 @@
1
- {"version":3,"file":"ClaudeChatServiceProvider.d.ts","sourceRoot":"","sources":["../../../../../src/services/providers/claude/ClaudeChatServiceProvider.ts"],"names":[],"mappings":"AAWA,OAAO,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAGhD,OAAO,EACL,kBAAkB,EAClB,mBAAmB,EACpB,MAAM,wBAAwB,CAAC;AAEhC;;GAEG;AACH,qBAAa,yBAA0B,YAAW,mBAAmB;IACnE;;;;OAIG;IACH,iBAAiB,CAAC,OAAO,EAAE,kBAAkB,GAAG,WAAW;IAkB3D;;;OAGG;IACH,eAAe,IAAI,MAAM;IAIzB;;;OAGG;IACH,kBAAkB,IAAI,MAAM,EAAE;IAa9B;;;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":"ClaudeChatServiceProvider.d.ts","sourceRoot":"","sources":["../../../../../src/services/providers/claude/ClaudeChatServiceProvider.ts"],"names":[],"mappings":"AAYA,OAAO,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAGhD,OAAO,EACL,kBAAkB,EAClB,mBAAmB,EACpB,MAAM,wBAAwB,CAAC;AAEhC;;GAEG;AACH,qBAAa,yBAA0B,YAAW,mBAAmB;IACnE;;;;OAIG;IACH,iBAAiB,CAAC,OAAO,EAAE,kBAAkB,GAAG,WAAW;IAkB3D;;;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"}
@@ -41,6 +41,7 @@ class ClaudeChatServiceProvider {
41
41
  constants_1.MODEL_CLAUDE_4_OPUS,
42
42
  constants_1.MODEL_CLAUDE_4_5_SONNET,
43
43
  constants_1.MODEL_CLAUDE_4_5_HAIKU,
44
+ constants_1.MODEL_CLAUDE_4_5_OPUS,
44
45
  ];
45
46
  }
46
47
  /**
@@ -1 +1 @@
1
- {"version":3,"file":"ClaudeChatServiceProvider.js","sourceRoot":"","sources":["../../../../../src/services/providers/claude/ClaudeChatServiceProvider.ts"],"names":[],"mappings":";;;AAAA,kDAU4B;AAE5B,2DAAwD;AAOxD;;GAEG;AACH,MAAa,yBAAyB;IACpC;;;;OAIG;IACH,iBAAiB,CAAC,OAA2B;QAC3C,gFAAgF;QAChF,MAAM,WAAW,GACf,OAAO,CAAC,WAAW;YACnB,CAAC,IAAI,CAAC,sBAAsB,CAAC,OAAO,CAAC,KAAK,IAAI,IAAI,CAAC,eAAe,EAAE,CAAC;gBACnE,CAAC,CAAC,OAAO,CAAC,KAAK;gBACf,CAAC,CAAC,IAAI,CAAC,eAAe,EAAE,CAAC,CAAC;QAE9B,OAAO,IAAI,qCAAiB,CAC1B,OAAO,CAAC,MAAM,EACd,OAAO,CAAC,KAAK,IAAI,IAAI,CAAC,eAAe,EAAE,EACvC,WAAW,EACX,OAAO,CAAC,KAAK,IAAI,EAAE,EAClB,OAAe,CAAC,UAAU,IAAI,EAAE,EACjC,OAAO,CAAC,cAAc,CACvB,CAAC;IACJ,CAAC;IAED;;;OAGG;IACH,eAAe;QACb,OAAO,QAAQ,CAAC;IAClB,CAAC;IAED;;;OAGG;IACH,kBAAkB;QAChB,OAAO;YACL,gCAAoB;YACpB,kCAAsB;YACtB,mCAAuB;YACvB,mCAAuB;YACvB,iCAAqB;YACrB,+BAAmB;YACnB,mCAAuB;YACvB,kCAAsB;SACvB,CAAC;IACJ,CAAC;IAED;;;OAGG;IACH,eAAe;QACb,OAAO,gCAAoB,CAAC;IAC9B,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;AAzED,8DAyEC"}
1
+ {"version":3,"file":"ClaudeChatServiceProvider.js","sourceRoot":"","sources":["../../../../../src/services/providers/claude/ClaudeChatServiceProvider.ts"],"names":[],"mappings":";;;AAAA,kDAW4B;AAE5B,2DAAwD;AAOxD;;GAEG;AACH,MAAa,yBAAyB;IACpC;;;;OAIG;IACH,iBAAiB,CAAC,OAA2B;QAC3C,gFAAgF;QAChF,MAAM,WAAW,GACf,OAAO,CAAC,WAAW;YACnB,CAAC,IAAI,CAAC,sBAAsB,CAAC,OAAO,CAAC,KAAK,IAAI,IAAI,CAAC,eAAe,EAAE,CAAC;gBACnE,CAAC,CAAC,OAAO,CAAC,KAAK;gBACf,CAAC,CAAC,IAAI,CAAC,eAAe,EAAE,CAAC,CAAC;QAE9B,OAAO,IAAI,qCAAiB,CAC1B,OAAO,CAAC,MAAM,EACd,OAAO,CAAC,KAAK,IAAI,IAAI,CAAC,eAAe,EAAE,EACvC,WAAW,EACX,OAAO,CAAC,KAAK,IAAI,EAAE,EAClB,OAAe,CAAC,UAAU,IAAI,EAAE,EACjC,OAAO,CAAC,cAAc,CACvB,CAAC;IACJ,CAAC;IAED;;;OAGG;IACH,eAAe;QACb,OAAO,QAAQ,CAAC;IAClB,CAAC;IAED;;;OAGG;IACH,kBAAkB;QAChB,OAAO;YACL,gCAAoB;YACpB,kCAAsB;YACtB,mCAAuB;YACvB,mCAAuB;YACvB,iCAAqB;YACrB,+BAAmB;YACnB,mCAAuB;YACvB,kCAAsB;YACtB,iCAAqB;SACtB,CAAC;IACJ,CAAC;IAED;;;OAGG;IACH,eAAe;QACb,OAAO,gCAAoB,CAAC;IAC9B,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;AA1ED,8DA0EC"}
@@ -7,5 +7,6 @@ export declare const MODEL_CLAUDE_4_SONNET = "claude-4-sonnet-20250514";
7
7
  export declare const MODEL_CLAUDE_4_OPUS = "claude-4-opus-20250514";
8
8
  export declare const MODEL_CLAUDE_4_5_SONNET = "claude-sonnet-4-5-20250929";
9
9
  export declare const MODEL_CLAUDE_4_5_HAIKU = "claude-haiku-4-5-20251001";
10
+ export declare const MODEL_CLAUDE_4_5_OPUS = "claude-opus-4-5-20251101";
10
11
  export declare const CLAUDE_VISION_SUPPORTED_MODELS: string[];
11
12
  //# sourceMappingURL=claude.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"claude.d.ts","sourceRoot":"","sources":["../../../src/constants/claude.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,mBAAmB,0CAA0C,CAAC;AAG3E,eAAO,MAAM,oBAAoB,4BAA4B,CAAC;AAC9D,eAAO,MAAM,sBAAsB,8BAA8B,CAAC;AAClE,eAAO,MAAM,uBAAuB,+BAA+B,CAAC;AACpE,eAAO,MAAM,uBAAuB,+BAA+B,CAAC;AACpE,eAAO,MAAM,qBAAqB,6BAA6B,CAAC;AAChE,eAAO,MAAM,mBAAmB,2BAA2B,CAAC;AAC5D,eAAO,MAAM,uBAAuB,+BAA+B,CAAC;AACpE,eAAO,MAAM,sBAAsB,8BAA8B,CAAC;AAElE,eAAO,MAAM,8BAA8B,UAS1C,CAAC"}
1
+ {"version":3,"file":"claude.d.ts","sourceRoot":"","sources":["../../../src/constants/claude.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,mBAAmB,0CAA0C,CAAC;AAG3E,eAAO,MAAM,oBAAoB,4BAA4B,CAAC;AAC9D,eAAO,MAAM,sBAAsB,8BAA8B,CAAC;AAClE,eAAO,MAAM,uBAAuB,+BAA+B,CAAC;AACpE,eAAO,MAAM,uBAAuB,+BAA+B,CAAC;AACpE,eAAO,MAAM,qBAAqB,6BAA6B,CAAC;AAChE,eAAO,MAAM,mBAAmB,2BAA2B,CAAC;AAC5D,eAAO,MAAM,uBAAuB,+BAA+B,CAAC;AACpE,eAAO,MAAM,sBAAsB,8BAA8B,CAAC;AAClE,eAAO,MAAM,qBAAqB,6BAA6B,CAAC;AAEhE,eAAO,MAAM,8BAA8B,UAU1C,CAAC"}
@@ -8,6 +8,7 @@ export const MODEL_CLAUDE_4_SONNET = 'claude-4-sonnet-20250514';
8
8
  export const MODEL_CLAUDE_4_OPUS = 'claude-4-opus-20250514';
9
9
  export const MODEL_CLAUDE_4_5_SONNET = 'claude-sonnet-4-5-20250929';
10
10
  export const MODEL_CLAUDE_4_5_HAIKU = 'claude-haiku-4-5-20251001';
11
+ export const MODEL_CLAUDE_4_5_OPUS = 'claude-opus-4-5-20251101';
11
12
  export const CLAUDE_VISION_SUPPORTED_MODELS = [
12
13
  MODEL_CLAUDE_3_HAIKU,
13
14
  MODEL_CLAUDE_3_5_HAIKU,
@@ -17,5 +18,6 @@ export const CLAUDE_VISION_SUPPORTED_MODELS = [
17
18
  MODEL_CLAUDE_4_OPUS,
18
19
  MODEL_CLAUDE_4_5_SONNET,
19
20
  MODEL_CLAUDE_4_5_HAIKU,
21
+ MODEL_CLAUDE_4_5_OPUS,
20
22
  ];
21
23
  //# sourceMappingURL=claude.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"claude.js","sourceRoot":"","sources":["../../../src/constants/claude.ts"],"names":[],"mappings":"AAAA,MAAM,CAAC,MAAM,mBAAmB,GAAG,uCAAuC,CAAC;AAE3E,eAAe;AACf,MAAM,CAAC,MAAM,oBAAoB,GAAG,yBAAyB,CAAC;AAC9D,MAAM,CAAC,MAAM,sBAAsB,GAAG,2BAA2B,CAAC;AAClE,MAAM,CAAC,MAAM,uBAAuB,GAAG,4BAA4B,CAAC;AACpE,MAAM,CAAC,MAAM,uBAAuB,GAAG,4BAA4B,CAAC;AACpE,MAAM,CAAC,MAAM,qBAAqB,GAAG,0BAA0B,CAAC;AAChE,MAAM,CAAC,MAAM,mBAAmB,GAAG,wBAAwB,CAAC;AAC5D,MAAM,CAAC,MAAM,uBAAuB,GAAG,4BAA4B,CAAC;AACpE,MAAM,CAAC,MAAM,sBAAsB,GAAG,2BAA2B,CAAC;AAElE,MAAM,CAAC,MAAM,8BAA8B,GAAG;IAC5C,oBAAoB;IACpB,sBAAsB;IACtB,uBAAuB;IACvB,uBAAuB;IACvB,qBAAqB;IACrB,mBAAmB;IACnB,uBAAuB;IACvB,sBAAsB;CACvB,CAAC"}
1
+ {"version":3,"file":"claude.js","sourceRoot":"","sources":["../../../src/constants/claude.ts"],"names":[],"mappings":"AAAA,MAAM,CAAC,MAAM,mBAAmB,GAAG,uCAAuC,CAAC;AAE3E,eAAe;AACf,MAAM,CAAC,MAAM,oBAAoB,GAAG,yBAAyB,CAAC;AAC9D,MAAM,CAAC,MAAM,sBAAsB,GAAG,2BAA2B,CAAC;AAClE,MAAM,CAAC,MAAM,uBAAuB,GAAG,4BAA4B,CAAC;AACpE,MAAM,CAAC,MAAM,uBAAuB,GAAG,4BAA4B,CAAC;AACpE,MAAM,CAAC,MAAM,qBAAqB,GAAG,0BAA0B,CAAC;AAChE,MAAM,CAAC,MAAM,mBAAmB,GAAG,wBAAwB,CAAC;AAC5D,MAAM,CAAC,MAAM,uBAAuB,GAAG,4BAA4B,CAAC;AACpE,MAAM,CAAC,MAAM,sBAAsB,GAAG,2BAA2B,CAAC;AAClE,MAAM,CAAC,MAAM,qBAAqB,GAAG,0BAA0B,CAAC;AAEhE,MAAM,CAAC,MAAM,8BAA8B,GAAG;IAC5C,oBAAoB;IACpB,sBAAsB;IACtB,uBAAuB;IACvB,uBAAuB;IACvB,qBAAqB;IACrB,mBAAmB;IACnB,uBAAuB;IACvB,sBAAsB;IACtB,qBAAqB;CACtB,CAAC"}
@@ -1 +1 @@
1
- {"version":3,"file":"ClaudeChatServiceProvider.d.ts","sourceRoot":"","sources":["../../../../../src/services/providers/claude/ClaudeChatServiceProvider.ts"],"names":[],"mappings":"AAWA,OAAO,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAGhD,OAAO,EACL,kBAAkB,EAClB,mBAAmB,EACpB,MAAM,wBAAwB,CAAC;AAEhC;;GAEG;AACH,qBAAa,yBAA0B,YAAW,mBAAmB;IACnE;;;;OAIG;IACH,iBAAiB,CAAC,OAAO,EAAE,kBAAkB,GAAG,WAAW;IAkB3D;;;OAGG;IACH,eAAe,IAAI,MAAM;IAIzB;;;OAGG;IACH,kBAAkB,IAAI,MAAM,EAAE;IAa9B;;;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":"ClaudeChatServiceProvider.d.ts","sourceRoot":"","sources":["../../../../../src/services/providers/claude/ClaudeChatServiceProvider.ts"],"names":[],"mappings":"AAYA,OAAO,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAGhD,OAAO,EACL,kBAAkB,EAClB,mBAAmB,EACpB,MAAM,wBAAwB,CAAC;AAEhC;;GAEG;AACH,qBAAa,yBAA0B,YAAW,mBAAmB;IACnE;;;;OAIG;IACH,iBAAiB,CAAC,OAAO,EAAE,kBAAkB,GAAG,WAAW;IAkB3D;;;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,4 +1,4 @@
1
- import { MODEL_CLAUDE_3_HAIKU, MODEL_CLAUDE_3_5_HAIKU, MODEL_CLAUDE_3_5_SONNET, MODEL_CLAUDE_3_7_SONNET, MODEL_CLAUDE_4_SONNET, MODEL_CLAUDE_4_OPUS, MODEL_CLAUDE_4_5_SONNET, MODEL_CLAUDE_4_5_HAIKU, CLAUDE_VISION_SUPPORTED_MODELS, } from '../../../constants';
1
+ import { MODEL_CLAUDE_3_HAIKU, MODEL_CLAUDE_3_5_HAIKU, MODEL_CLAUDE_3_5_SONNET, MODEL_CLAUDE_3_7_SONNET, MODEL_CLAUDE_4_SONNET, MODEL_CLAUDE_4_OPUS, MODEL_CLAUDE_4_5_SONNET, MODEL_CLAUDE_4_5_HAIKU, MODEL_CLAUDE_4_5_OPUS, CLAUDE_VISION_SUPPORTED_MODELS, } from '../../../constants';
2
2
  import { ClaudeChatService } from './ClaudeChatService';
3
3
  /**
4
4
  * Claude API provider implementation
@@ -38,6 +38,7 @@ export class ClaudeChatServiceProvider {
38
38
  MODEL_CLAUDE_4_OPUS,
39
39
  MODEL_CLAUDE_4_5_SONNET,
40
40
  MODEL_CLAUDE_4_5_HAIKU,
41
+ MODEL_CLAUDE_4_5_OPUS,
41
42
  ];
42
43
  }
43
44
  /**
@@ -1 +1 @@
1
- {"version":3,"file":"ClaudeChatServiceProvider.js","sourceRoot":"","sources":["../../../../../src/services/providers/claude/ClaudeChatServiceProvider.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,oBAAoB,EACpB,sBAAsB,EACtB,uBAAuB,EACvB,uBAAuB,EACvB,qBAAqB,EACrB,mBAAmB,EACnB,uBAAuB,EACvB,sBAAsB,EACtB,8BAA8B,GAC/B,MAAM,oBAAoB,CAAC;AAE5B,OAAO,EAAE,iBAAiB,EAAE,MAAM,qBAAqB,CAAC;AAOxD;;GAEG;AACH,MAAM,OAAO,yBAAyB;IACpC;;;;OAIG;IACH,iBAAiB,CAAC,OAA2B;QAC3C,gFAAgF;QAChF,MAAM,WAAW,GACf,OAAO,CAAC,WAAW;YACnB,CAAC,IAAI,CAAC,sBAAsB,CAAC,OAAO,CAAC,KAAK,IAAI,IAAI,CAAC,eAAe,EAAE,CAAC;gBACnE,CAAC,CAAC,OAAO,CAAC,KAAK;gBACf,CAAC,CAAC,IAAI,CAAC,eAAe,EAAE,CAAC,CAAC;QAE9B,OAAO,IAAI,iBAAiB,CAC1B,OAAO,CAAC,MAAM,EACd,OAAO,CAAC,KAAK,IAAI,IAAI,CAAC,eAAe,EAAE,EACvC,WAAW,EACX,OAAO,CAAC,KAAK,IAAI,EAAE,EAClB,OAAe,CAAC,UAAU,IAAI,EAAE,EACjC,OAAO,CAAC,cAAc,CACvB,CAAC;IACJ,CAAC;IAED;;;OAGG;IACH,eAAe;QACb,OAAO,QAAQ,CAAC;IAClB,CAAC;IAED;;;OAGG;IACH,kBAAkB;QAChB,OAAO;YACL,oBAAoB;YACpB,sBAAsB;YACtB,uBAAuB;YACvB,uBAAuB;YACvB,qBAAqB;YACrB,mBAAmB;YACnB,uBAAuB;YACvB,sBAAsB;SACvB,CAAC;IACJ,CAAC;IAED;;;OAGG;IACH,eAAe;QACb,OAAO,oBAAoB,CAAC;IAC9B,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":"ClaudeChatServiceProvider.js","sourceRoot":"","sources":["../../../../../src/services/providers/claude/ClaudeChatServiceProvider.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,oBAAoB,EACpB,sBAAsB,EACtB,uBAAuB,EACvB,uBAAuB,EACvB,qBAAqB,EACrB,mBAAmB,EACnB,uBAAuB,EACvB,sBAAsB,EACtB,qBAAqB,EACrB,8BAA8B,GAC/B,MAAM,oBAAoB,CAAC;AAE5B,OAAO,EAAE,iBAAiB,EAAE,MAAM,qBAAqB,CAAC;AAOxD;;GAEG;AACH,MAAM,OAAO,yBAAyB;IACpC;;;;OAIG;IACH,iBAAiB,CAAC,OAA2B;QAC3C,gFAAgF;QAChF,MAAM,WAAW,GACf,OAAO,CAAC,WAAW;YACnB,CAAC,IAAI,CAAC,sBAAsB,CAAC,OAAO,CAAC,KAAK,IAAI,IAAI,CAAC,eAAe,EAAE,CAAC;gBACnE,CAAC,CAAC,OAAO,CAAC,KAAK;gBACf,CAAC,CAAC,IAAI,CAAC,eAAe,EAAE,CAAC,CAAC;QAE9B,OAAO,IAAI,iBAAiB,CAC1B,OAAO,CAAC,MAAM,EACd,OAAO,CAAC,KAAK,IAAI,IAAI,CAAC,eAAe,EAAE,EACvC,WAAW,EACX,OAAO,CAAC,KAAK,IAAI,EAAE,EAClB,OAAe,CAAC,UAAU,IAAI,EAAE,EACjC,OAAO,CAAC,cAAc,CACvB,CAAC;IACJ,CAAC;IAED;;;OAGG;IACH,eAAe;QACb,OAAO,QAAQ,CAAC;IAClB,CAAC;IAED;;;OAGG;IACH,kBAAkB;QAChB,OAAO;YACL,oBAAoB;YACpB,sBAAsB;YACtB,uBAAuB;YACvB,uBAAuB;YACvB,qBAAqB;YACrB,mBAAmB;YACnB,uBAAuB;YACvB,sBAAsB;YACtB,qBAAqB;SACtB,CAAC;IACJ,CAAC;IAED;;;OAGG;IACH,eAAe;QACb,OAAO,oBAAoB,CAAC;IAC9B,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"}
@@ -50,6 +50,7 @@ var AITuberOnAirChat = (() => {
50
50
  MODEL_CLAUDE_3_7_SONNET: () => MODEL_CLAUDE_3_7_SONNET,
51
51
  MODEL_CLAUDE_3_HAIKU: () => MODEL_CLAUDE_3_HAIKU,
52
52
  MODEL_CLAUDE_4_5_HAIKU: () => MODEL_CLAUDE_4_5_HAIKU,
53
+ MODEL_CLAUDE_4_5_OPUS: () => MODEL_CLAUDE_4_5_OPUS,
53
54
  MODEL_CLAUDE_4_5_SONNET: () => MODEL_CLAUDE_4_5_SONNET,
54
55
  MODEL_CLAUDE_4_OPUS: () => MODEL_CLAUDE_4_OPUS,
55
56
  MODEL_CLAUDE_4_SONNET: () => MODEL_CLAUDE_4_SONNET,
@@ -171,6 +172,7 @@ var AITuberOnAirChat = (() => {
171
172
  var MODEL_CLAUDE_4_OPUS = "claude-4-opus-20250514";
172
173
  var MODEL_CLAUDE_4_5_SONNET = "claude-sonnet-4-5-20250929";
173
174
  var MODEL_CLAUDE_4_5_HAIKU = "claude-haiku-4-5-20251001";
175
+ var MODEL_CLAUDE_4_5_OPUS = "claude-opus-4-5-20251101";
174
176
  var CLAUDE_VISION_SUPPORTED_MODELS = [
175
177
  MODEL_CLAUDE_3_HAIKU,
176
178
  MODEL_CLAUDE_3_5_HAIKU,
@@ -179,7 +181,8 @@ var AITuberOnAirChat = (() => {
179
181
  MODEL_CLAUDE_4_SONNET,
180
182
  MODEL_CLAUDE_4_OPUS,
181
183
  MODEL_CLAUDE_4_5_SONNET,
182
- MODEL_CLAUDE_4_5_HAIKU
184
+ MODEL_CLAUDE_4_5_HAIKU,
185
+ MODEL_CLAUDE_4_5_OPUS
183
186
  ];
184
187
 
185
188
  // src/constants/openrouter.ts
@@ -2388,7 +2391,8 @@ If it's in another language, summarize in that language.
2388
2391
  MODEL_CLAUDE_4_SONNET,
2389
2392
  MODEL_CLAUDE_4_OPUS,
2390
2393
  MODEL_CLAUDE_4_5_SONNET,
2391
- MODEL_CLAUDE_4_5_HAIKU
2394
+ MODEL_CLAUDE_4_5_HAIKU,
2395
+ MODEL_CLAUDE_4_5_OPUS
2392
2396
  ];
2393
2397
  }
2394
2398
  /**
@@ -1,4 +1,4 @@
1
- "use strict";var AITuberOnAirChat=(()=>{var fe=Object.defineProperty;var ke=Object.getOwnPropertyDescriptor;var Ue=Object.getOwnPropertyNames;var Ge=Object.prototype.hasOwnProperty;var Ve=(d,e)=>{for(var t in e)fe(d,t,{get:e[t],enumerable:!0})},Fe=(d,e,t,o)=>{if(e&&typeof e=="object"||typeof e=="function")for(let s of Ue(e))!Ge.call(d,s)&&s!==t&&fe(d,s,{get:()=>e[s],enumerable:!(o=ke(e,s))||o.enumerable});return d};var Be=d=>Fe(fe({},"__esModule",{value:!0}),d);var Xe={};Ve(Xe,{CHAT_RESPONSE_LENGTH:()=>R,CLAUDE_VISION_SUPPORTED_MODELS:()=>K,ChatServiceFactory:()=>x,ChatServiceHttpClient:()=>y,ClaudeChatService:()=>V,ClaudeChatServiceProvider:()=>F,DEFAULT_MAX_TOKENS:()=>Te,DEFAULT_SUMMARY_PROMPT_TEMPLATE:()=>qe,DEFAULT_VISION_PROMPT:()=>$e,EMOTION_TAG_CLEANUP_REGEX:()=>we,EMOTION_TAG_REGEX:()=>Le,ENDPOINT_CLAUDE_API:()=>Me,ENDPOINT_GEMINI_API:()=>Se,ENDPOINT_OPENAI_CHAT_COMPLETIONS_API:()=>D,ENDPOINT_OPENAI_RESPONSES_API:()=>S,ENDPOINT_OPENROUTER_API:()=>Ee,EmotionParser:()=>H,GEMINI_VISION_SUPPORTED_MODELS:()=>z,GPT5_PRESETS:()=>Pe,GPT_5_MODELS:()=>Re,GeminiChatService:()=>U,GeminiChatServiceProvider:()=>G,HttpError:()=>w,MAX_TOKENS_BY_LENGTH:()=>Ie,MODEL_CLAUDE_3_5_HAIKU:()=>ae,MODEL_CLAUDE_3_5_SONNET:()=>le,MODEL_CLAUDE_3_7_SONNET:()=>ce,MODEL_CLAUDE_3_HAIKU:()=>M,MODEL_CLAUDE_4_5_HAIKU:()=>me,MODEL_CLAUDE_4_5_SONNET:()=>he,MODEL_CLAUDE_4_OPUS:()=>ue,MODEL_CLAUDE_4_SONNET:()=>pe,MODEL_GEMINI_2_0_FLASH:()=>ie,MODEL_GEMINI_2_0_FLASH_LITE:()=>T,MODEL_GEMINI_2_5_FLASH:()=>se,MODEL_GEMINI_2_5_FLASH_LITE:()=>ne,MODEL_GEMINI_2_5_FLASH_LITE_PREVIEW_06_17:()=>re,MODEL_GEMINI_2_5_PRO:()=>oe,MODEL_GPT_4O:()=>ee,MODEL_GPT_4O_MINI:()=>b,MODEL_GPT_4_1:()=>X,MODEL_GPT_4_1_MINI:()=>Q,MODEL_GPT_4_1_NANO:()=>Z,MODEL_GPT_4_5_PREVIEW:()=>te,MODEL_GPT_5:()=>$,MODEL_GPT_5_1:()=>O,MODEL_GPT_5_MINI:()=>W,MODEL_GPT_5_NANO:()=>I,MODEL_GPT_OSS_20B_FREE:()=>P,MODEL_O1:()=>ye,MODEL_O1_MINI:()=>_e,MODEL_O3_MINI:()=>ge,OPENROUTER_CREDITS_THRESHOLD:()=>We,OPENROUTER_FREE_DAILY_LIMIT_HIGH_CREDITS:()=>He,OPENROUTER_FREE_DAILY_LIMIT_LOW_CREDITS:()=>je,OPENROUTER_FREE_MODELS:()=>J,OPENROUTER_FREE_RATE_LIMIT_PER_MINUTE:()=>xe,OPENROUTER_VISION_SUPPORTED_MODELS:()=>De,OpenAIChatService:()=>A,OpenAIChatServiceProvider:()=>k,OpenRouterChatService:()=>B,OpenRouterChatServiceProvider:()=>j,StreamTextAccumulator:()=>v,VISION_SUPPORTED_MODELS:()=>q,allowsReasoningMinimal:()=>Ce,allowsReasoningNone:()=>ve,getMaxTokensForResponseLength:()=>E,installGASFetch:()=>Ae,isGPT5Model:()=>L,isOpenRouterFreeModel:()=>Oe,isOpenRouterVisionModel:()=>N,runOnceText:()=>Ye,screenplayToText:()=>Je,textToScreenplay:()=>Ne,textsToScreenplay:()=>Ke});var D="https://api.openai.com/v1/chat/completions",S="https://api.openai.com/v1/responses",I="gpt-5-nano",W="gpt-5-mini",$="gpt-5",O="gpt-5.1",X="gpt-4.1",Q="gpt-4.1-mini",Z="gpt-4.1-nano",b="gpt-4o-mini",ee="gpt-4o",ge="o3-mini",_e="o1-mini",ye="o1",te="gpt-4.5-preview",q=[I,W,$,O,X,Q,Z,b,ee,te,"o1"],Re=[I,W,$,O];function L(d){return Re.includes(d)}function ve(d){return d===O}function Ce(d){return d!==O}var Se="https://generativelanguage.googleapis.com",oe="gemini-2.5-pro",se="gemini-2.5-flash",ne="gemini-2.5-flash-lite",re="gemini-2.5-flash-lite-preview-06-17",ie="gemini-2.0-flash",T="gemini-2.0-flash-lite",z=[oe,se,ne,re,ie,T];var Me="https://api.anthropic.com/v1/messages",M="claude-3-haiku-20240307",ae="claude-3-5-haiku-20241022",le="claude-3-5-sonnet-20241022",ce="claude-3-7-sonnet-20250219",pe="claude-4-sonnet-20250514",ue="claude-4-opus-20250514",he="claude-sonnet-4-5-20250929",me="claude-haiku-4-5-20251001",K=[M,ae,le,ce,pe,ue,he,me];var Ee="https://openrouter.ai/api/v1/chat/completions",P="openai/gpt-oss-20b:free",J=[P],De=[],xe=20,je=50,He=1e3,We=10;function Oe(d){return J.some(e=>d.includes(e))}function N(d){return De.some(e=>d.includes(e))}var R={VERY_SHORT:"veryShort",SHORT:"short",MEDIUM:"medium",LONG:"long",VERY_LONG:"veryLong",DEEP:"deep"},Ie={[R.VERY_SHORT]:40,[R.SHORT]:100,[R.MEDIUM]:200,[R.LONG]:300,[R.VERY_LONG]:1e3,[R.DEEP]:5e3},Te=5e3,Pe={casual:{reasoning_effort:"minimal",verbosity:"low",description:"Fast responses for casual chat, quick questions (GPT-4 like experience)"},balanced:{reasoning_effort:"medium",verbosity:"medium",description:"Balanced reasoning for business tasks, learning, general problem solving"},expert:{reasoning_effort:"high",verbosity:"high",description:"Deep reasoning for research, complex analysis, expert-level tasks"}};function E(d){return d?Ie[d]??Te:Te}var $e="You are a friendly AI avatar. Comment on the situation based on the broadcast screen.",qe=`You are a skilled summarizing assistant.
1
+ "use strict";var AITuberOnAirChat=(()=>{var ge=Object.defineProperty;var Ue=Object.getOwnPropertyDescriptor;var Ge=Object.getOwnPropertyNames;var Ve=Object.prototype.hasOwnProperty;var Fe=(d,e)=>{for(var t in e)ge(d,t,{get:e[t],enumerable:!0})},Be=(d,e,t,o)=>{if(e&&typeof e=="object"||typeof e=="function")for(let s of Ge(e))!Ve.call(d,s)&&s!==t&&ge(d,s,{get:()=>e[s],enumerable:!(o=Ue(e,s))||o.enumerable});return d};var je=d=>Be(ge({},"__esModule",{value:!0}),d);var Qe={};Fe(Qe,{CHAT_RESPONSE_LENGTH:()=>R,CLAUDE_VISION_SUPPORTED_MODELS:()=>K,ChatServiceFactory:()=>x,ChatServiceHttpClient:()=>y,ClaudeChatService:()=>V,ClaudeChatServiceProvider:()=>F,DEFAULT_MAX_TOKENS:()=>Pe,DEFAULT_SUMMARY_PROMPT_TEMPLATE:()=>ze,DEFAULT_VISION_PROMPT:()=>qe,EMOTION_TAG_CLEANUP_REGEX:()=>be,EMOTION_TAG_REGEX:()=>Ne,ENDPOINT_CLAUDE_API:()=>Me,ENDPOINT_GEMINI_API:()=>Ee,ENDPOINT_OPENAI_CHAT_COMPLETIONS_API:()=>D,ENDPOINT_OPENAI_RESPONSES_API:()=>S,ENDPOINT_OPENROUTER_API:()=>xe,EmotionParser:()=>H,GEMINI_VISION_SUPPORTED_MODELS:()=>z,GPT5_PRESETS:()=>we,GPT_5_MODELS:()=>De,GeminiChatService:()=>U,GeminiChatServiceProvider:()=>G,HttpError:()=>w,MAX_TOKENS_BY_LENGTH:()=>Le,MODEL_CLAUDE_3_5_HAIKU:()=>ae,MODEL_CLAUDE_3_5_SONNET:()=>le,MODEL_CLAUDE_3_7_SONNET:()=>ce,MODEL_CLAUDE_3_HAIKU:()=>E,MODEL_CLAUDE_4_5_HAIKU:()=>me,MODEL_CLAUDE_4_5_OPUS:()=>de,MODEL_CLAUDE_4_5_SONNET:()=>he,MODEL_CLAUDE_4_OPUS:()=>ue,MODEL_CLAUDE_4_SONNET:()=>pe,MODEL_GEMINI_2_0_FLASH:()=>ie,MODEL_GEMINI_2_0_FLASH_LITE:()=>T,MODEL_GEMINI_2_5_FLASH:()=>se,MODEL_GEMINI_2_5_FLASH_LITE:()=>ne,MODEL_GEMINI_2_5_FLASH_LITE_PREVIEW_06_17:()=>re,MODEL_GEMINI_2_5_PRO:()=>oe,MODEL_GPT_4O:()=>ee,MODEL_GPT_4O_MINI:()=>b,MODEL_GPT_4_1:()=>X,MODEL_GPT_4_1_MINI:()=>Q,MODEL_GPT_4_1_NANO:()=>Z,MODEL_GPT_4_5_PREVIEW:()=>te,MODEL_GPT_5:()=>$,MODEL_GPT_5_1:()=>O,MODEL_GPT_5_MINI:()=>W,MODEL_GPT_5_NANO:()=>I,MODEL_GPT_OSS_20B_FREE:()=>P,MODEL_O1:()=>ve,MODEL_O1_MINI:()=>ye,MODEL_O3_MINI:()=>_e,OPENROUTER_CREDITS_THRESHOLD:()=>$e,OPENROUTER_FREE_DAILY_LIMIT_HIGH_CREDITS:()=>We,OPENROUTER_FREE_DAILY_LIMIT_LOW_CREDITS:()=>He,OPENROUTER_FREE_MODELS:()=>J,OPENROUTER_FREE_RATE_LIMIT_PER_MINUTE:()=>Oe,OPENROUTER_VISION_SUPPORTED_MODELS:()=>Ie,OpenAIChatService:()=>A,OpenAIChatServiceProvider:()=>k,OpenRouterChatService:()=>B,OpenRouterChatServiceProvider:()=>j,StreamTextAccumulator:()=>v,VISION_SUPPORTED_MODELS:()=>q,allowsReasoningMinimal:()=>Se,allowsReasoningNone:()=>Ce,getMaxTokensForResponseLength:()=>M,installGASFetch:()=>ke,isGPT5Model:()=>L,isOpenRouterFreeModel:()=>Te,isOpenRouterVisionModel:()=>N,runOnceText:()=>Xe,screenplayToText:()=>Ye,textToScreenplay:()=>Ae,textsToScreenplay:()=>Je});var D="https://api.openai.com/v1/chat/completions",S="https://api.openai.com/v1/responses",I="gpt-5-nano",W="gpt-5-mini",$="gpt-5",O="gpt-5.1",X="gpt-4.1",Q="gpt-4.1-mini",Z="gpt-4.1-nano",b="gpt-4o-mini",ee="gpt-4o",_e="o3-mini",ye="o1-mini",ve="o1",te="gpt-4.5-preview",q=[I,W,$,O,X,Q,Z,b,ee,te,"o1"],De=[I,W,$,O];function L(d){return De.includes(d)}function Ce(d){return d===O}function Se(d){return d!==O}var Ee="https://generativelanguage.googleapis.com",oe="gemini-2.5-pro",se="gemini-2.5-flash",ne="gemini-2.5-flash-lite",re="gemini-2.5-flash-lite-preview-06-17",ie="gemini-2.0-flash",T="gemini-2.0-flash-lite",z=[oe,se,ne,re,ie,T];var Me="https://api.anthropic.com/v1/messages",E="claude-3-haiku-20240307",ae="claude-3-5-haiku-20241022",le="claude-3-5-sonnet-20241022",ce="claude-3-7-sonnet-20250219",pe="claude-4-sonnet-20250514",ue="claude-4-opus-20250514",he="claude-sonnet-4-5-20250929",me="claude-haiku-4-5-20251001",de="claude-opus-4-5-20251101",K=[E,ae,le,ce,pe,ue,he,me,de];var xe="https://openrouter.ai/api/v1/chat/completions",P="openai/gpt-oss-20b:free",J=[P],Ie=[],Oe=20,He=50,We=1e3,$e=10;function Te(d){return J.some(e=>d.includes(e))}function N(d){return Ie.some(e=>d.includes(e))}var R={VERY_SHORT:"veryShort",SHORT:"short",MEDIUM:"medium",LONG:"long",VERY_LONG:"veryLong",DEEP:"deep"},Le={[R.VERY_SHORT]:40,[R.SHORT]:100,[R.MEDIUM]:200,[R.LONG]:300,[R.VERY_LONG]:1e3,[R.DEEP]:5e3},Pe=5e3,we={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 M(d){return d?Le[d]??Pe:Pe}var qe="You are a friendly AI avatar. Comment on the situation based on the broadcast screen.",ze=`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,13 +7,13 @@ 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 v=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 w=class extends Error{constructor(t,o,s){super(`HTTP ${t}: ${o}`);this.status=t;this.statusText=o;this.body=s;this.name="HttpError"}},Y=class Y{static setFetch(e){this.fetchImpl=e}static async post(e,t,o={},s={}){let{timeout:n=3e4,retries:r=0,retryDelay:i=1e3}=s,u={...{"Content-Type":"application/json"},...o},p=null;for(let c=0;c<=r;c++)try{let h=typeof AbortController<"u",a=h?new AbortController:void 0,m=h?setTimeout(()=>a.abort(),n):void 0,f=await Y.fetchImpl(e,{method:"POST",headers:u,body:typeof t=="string"?t:JSON.stringify(t),...a?{signal:a.signal}:{}});if(m&&clearTimeout(m),!f.ok){let g=await f.text();throw new w(f.status,f.statusText,g)}return f}catch(h){if(p=h,h instanceof w&&h.status>=400&&h.status<500)throw h;if(h instanceof Error&&h.name==="AbortError")throw new Error(`Request timeout after ${n}ms`);c<r&&await new Promise(a=>setTimeout(a,i*(c+1)))}throw p||new Error("Request failed")}static async handleErrorResponse(e){let t=await e.text();throw new w(e.status,e.statusText,t)}static async get(e,t={},o={}){let{timeout:s=3e4,retries:n=0,retryDelay:r=1e3}=o,i=null;for(let l=0;l<=n;l++)try{let u=typeof AbortController<"u",p=u?new AbortController:void 0,c=u?setTimeout(()=>p.abort(),s):void 0,h=await Y.fetchImpl(e,{method:"GET",headers:t,...p?{signal:p.signal}:{}});if(c&&clearTimeout(c),!h.ok){let a=await h.text();throw new w(h.status,h.statusText,a)}return h}catch(u){if(i=u,u instanceof w&&u.status>=400&&u.status<500)throw u;if(u instanceof Error&&u.name==="AbortError")throw new Error(`Request timeout after ${s}ms`);l<n&&await new Promise(p=>setTimeout(p,r*(l+1)))}throw i||new Error("Request failed")}};Y.fetchImpl=(e,t)=>fetch(e,t);var y=Y;var A=class{constructor(e,t=b,o=b,s,n=D,r=[],i,l,u,p=!1){this.provider="openai";if(this.apiKey=e,this.model=t,this.tools=s||[],this.endpoint=n,this.mcpServers=r,this.responseLength=i,this.verbosity=l,this.reasoning_effort=u,this.enableReasoningSummary=p,!q.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){if(this.tools.length===0){let r=await this.callOpenAI(e,this.model,!0),i=this.endpoint===S;try{if(i){let u=(await this.parseResponsesStream(r,t)).blocks.filter(p=>p.type==="text").map(p=>p.text).join("");await o(u)}else{let l=await this.handleStream(r,t);await o(l)}}catch(l){throw console.error("[processChat] Error in streaming/completion:",l),l}return}let{blocks:s,stop_reason:n}=await this.chatOnce(e);if(n==="end"){let r=s.filter(i=>i.type==="text").map(i=>i.text).join("");await o(r);return}throw new Error("processChat received tool_calls. ChatProcessor must use chatOnce() loop when tools are enabled.")}async processVisionChat(e,t,o){try{if(this.tools.length===0){let r=await this.callOpenAI(e,this.visionModel,!0),i=this.endpoint===S;try{if(i){let u=(await this.parseResponsesStream(r,t)).blocks.filter(p=>p.type==="text").map(p=>p.text).join("");await o(u)}else{let l=await this.handleStream(r,t);await o(l)}}catch(l){throw console.error("[processVisionChat] Error in streaming/completion:",l),l}return}let{blocks:s,stop_reason:n}=await this.visionChatOnce(e,!0,t);if(n==="end"){let r=s.filter(i=>i.type==="text").map(i=>i.text).join("");await o(r);return}throw new Error("processVisionChat received tool_calls. ChatProcessor must use visionChatOnce() loop when tools are enabled.")}catch(s){throw console.error("Error in processVisionChat:",s),s}}async chatOnce(e,t=!0,o=()=>{},s){let n=await this.callOpenAI(e,this.model,t,s);return this.parseResponse(n,t,o)}async visionChatOnce(e,t=!1,o=()=>{},s){let n=await this.callOpenAI(e,this.visionModel,t,s);return this.parseResponse(n,t,o)}async parseResponse(e,t,o){return this.endpoint===S?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,s){let n=this.buildRequestBody(e,t,o,s);return await y.post(this.endpoint,n,{Authorization:`Bearer ${this.apiKey}`})}buildRequestBody(e,t,o,s){let n=this.endpoint===S;this.validateMCPCompatibility();let r={model:t,stream:o},i=s!==void 0?s:E(this.responseLength);n?r.max_output_tokens=i:r.max_completion_tokens=i,n?r.input=this.cleanMessagesForResponsesAPI(e):r.messages=e,L(t)&&(n?(this.reasoning_effort&&(r.reasoning={...r.reasoning,effort:this.reasoning_effort},this.enableReasoningSummary&&(r.reasoning.summary="auto")),this.verbosity&&(r.text={...r.text,format:{type:"text"},verbosity:this.verbosity})):(this.reasoning_effort&&(r.reasoning_effort=this.reasoning_effort),this.verbosity&&(r.verbosity=this.verbosity)));let l=this.buildToolsDefinition();return l.length>0&&(r.tools=l,n||(r.tool_choice="auto")),r}validateMCPCompatibility(){if(this.mcpServers.length>0&&this.endpoint===D)throw new Error(`MCP servers are not supported with Chat Completions API. Current endpoint: ${this.endpoint}. Please use OpenAI Responses API endpoint: ${S}. MCP tools are only available in the Responses API endpoint.`)}cleanMessagesForResponsesAPI(e){return e.map(t=>{let s={role:t.role==="tool"?"user":t.role};return typeof t.content=="string"?s.content=t.content:Array.isArray(t.content)?s.content=t.content.map(n=>n.type==="text"?{type:"input_text",text:n.text}:n.type==="image_url"?{type:"input_image",image_url:n.image_url.url}:n):s.content=t.content,s})}buildToolsDefinition(){let e=this.endpoint===S,t=[];return this.tools.length>0&&(e?t.push(...this.tools.map(o=>({type:"function",name:o.name,description:o.description,parameters:o.parameters}))):t.push(...this.tools.map(o=>({type:"function",function:{name:o.name,description:o.description,parameters:o.parameters}})))),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.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){let o=e.body.getReader(),s=new TextDecoder,n="",r="";for(;;){let{done:i,value:l}=await o.read();if(i)break;n+=s.decode(l,{stream:!0});let u;for(;(u=n.indexOf(`
10
+ `;var v=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 w=class extends Error{constructor(t,o,s){super(`HTTP ${t}: ${o}`);this.status=t;this.statusText=o;this.body=s;this.name="HttpError"}},Y=class Y{static setFetch(e){this.fetchImpl=e}static async post(e,t,o={},s={}){let{timeout:n=3e4,retries:r=0,retryDelay:i=1e3}=s,u={...{"Content-Type":"application/json"},...o},p=null;for(let c=0;c<=r;c++)try{let h=typeof AbortController<"u",a=h?new AbortController:void 0,m=h?setTimeout(()=>a.abort(),n):void 0,f=await Y.fetchImpl(e,{method:"POST",headers:u,body:typeof t=="string"?t:JSON.stringify(t),...a?{signal:a.signal}:{}});if(m&&clearTimeout(m),!f.ok){let g=await f.text();throw new w(f.status,f.statusText,g)}return f}catch(h){if(p=h,h instanceof w&&h.status>=400&&h.status<500)throw h;if(h instanceof Error&&h.name==="AbortError")throw new Error(`Request timeout after ${n}ms`);c<r&&await new Promise(a=>setTimeout(a,i*(c+1)))}throw p||new Error("Request failed")}static async handleErrorResponse(e){let t=await e.text();throw new w(e.status,e.statusText,t)}static async get(e,t={},o={}){let{timeout:s=3e4,retries:n=0,retryDelay:r=1e3}=o,i=null;for(let l=0;l<=n;l++)try{let u=typeof AbortController<"u",p=u?new AbortController:void 0,c=u?setTimeout(()=>p.abort(),s):void 0,h=await Y.fetchImpl(e,{method:"GET",headers:t,...p?{signal:p.signal}:{}});if(c&&clearTimeout(c),!h.ok){let a=await h.text();throw new w(h.status,h.statusText,a)}return h}catch(u){if(i=u,u instanceof w&&u.status>=400&&u.status<500)throw u;if(u instanceof Error&&u.name==="AbortError")throw new Error(`Request timeout after ${s}ms`);l<n&&await new Promise(p=>setTimeout(p,r*(l+1)))}throw i||new Error("Request failed")}};Y.fetchImpl=(e,t)=>fetch(e,t);var y=Y;var A=class{constructor(e,t=b,o=b,s,n=D,r=[],i,l,u,p=!1){this.provider="openai";if(this.apiKey=e,this.model=t,this.tools=s||[],this.endpoint=n,this.mcpServers=r,this.responseLength=i,this.verbosity=l,this.reasoning_effort=u,this.enableReasoningSummary=p,!q.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){if(this.tools.length===0){let r=await this.callOpenAI(e,this.model,!0),i=this.endpoint===S;try{if(i){let u=(await this.parseResponsesStream(r,t)).blocks.filter(p=>p.type==="text").map(p=>p.text).join("");await o(u)}else{let l=await this.handleStream(r,t);await o(l)}}catch(l){throw console.error("[processChat] Error in streaming/completion:",l),l}return}let{blocks:s,stop_reason:n}=await this.chatOnce(e);if(n==="end"){let r=s.filter(i=>i.type==="text").map(i=>i.text).join("");await o(r);return}throw new Error("processChat received tool_calls. ChatProcessor must use chatOnce() loop when tools are enabled.")}async processVisionChat(e,t,o){try{if(this.tools.length===0){let r=await this.callOpenAI(e,this.visionModel,!0),i=this.endpoint===S;try{if(i){let u=(await this.parseResponsesStream(r,t)).blocks.filter(p=>p.type==="text").map(p=>p.text).join("");await o(u)}else{let l=await this.handleStream(r,t);await o(l)}}catch(l){throw console.error("[processVisionChat] Error in streaming/completion:",l),l}return}let{blocks:s,stop_reason:n}=await this.visionChatOnce(e,!0,t);if(n==="end"){let r=s.filter(i=>i.type==="text").map(i=>i.text).join("");await o(r);return}throw new Error("processVisionChat received tool_calls. ChatProcessor must use visionChatOnce() loop when tools are enabled.")}catch(s){throw console.error("Error in processVisionChat:",s),s}}async chatOnce(e,t=!0,o=()=>{},s){let n=await this.callOpenAI(e,this.model,t,s);return this.parseResponse(n,t,o)}async visionChatOnce(e,t=!1,o=()=>{},s){let n=await this.callOpenAI(e,this.visionModel,t,s);return this.parseResponse(n,t,o)}async parseResponse(e,t,o){return this.endpoint===S?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,s){let n=this.buildRequestBody(e,t,o,s);return await y.post(this.endpoint,n,{Authorization:`Bearer ${this.apiKey}`})}buildRequestBody(e,t,o,s){let n=this.endpoint===S;this.validateMCPCompatibility();let r={model:t,stream:o},i=s!==void 0?s:M(this.responseLength);n?r.max_output_tokens=i:r.max_completion_tokens=i,n?r.input=this.cleanMessagesForResponsesAPI(e):r.messages=e,L(t)&&(n?(this.reasoning_effort&&(r.reasoning={...r.reasoning,effort:this.reasoning_effort},this.enableReasoningSummary&&(r.reasoning.summary="auto")),this.verbosity&&(r.text={...r.text,format:{type:"text"},verbosity:this.verbosity})):(this.reasoning_effort&&(r.reasoning_effort=this.reasoning_effort),this.verbosity&&(r.verbosity=this.verbosity)));let l=this.buildToolsDefinition();return l.length>0&&(r.tools=l,n||(r.tool_choice="auto")),r}validateMCPCompatibility(){if(this.mcpServers.length>0&&this.endpoint===D)throw new Error(`MCP servers are not supported with Chat Completions API. Current endpoint: ${this.endpoint}. Please use OpenAI Responses API endpoint: ${S}. MCP tools are only available in the Responses API endpoint.`)}cleanMessagesForResponsesAPI(e){return e.map(t=>{let s={role:t.role==="tool"?"user":t.role};return typeof t.content=="string"?s.content=t.content:Array.isArray(t.content)?s.content=t.content.map(n=>n.type==="text"?{type:"input_text",text:n.text}:n.type==="image_url"?{type:"input_image",image_url:n.image_url.url}:n):s.content=t.content,s})}buildToolsDefinition(){let e=this.endpoint===S,t=[];return this.tools.length>0&&(e?t.push(...this.tools.map(o=>({type:"function",name:o.name,description:o.description,parameters:o.parameters}))):t.push(...this.tools.map(o=>({type:"function",function:{name:o.name,description:o.description,parameters:o.parameters}})))),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.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){let o=e.body.getReader(),s=new TextDecoder,n="",r="";for(;;){let{done:i,value:l}=await o.read();if(i)break;n+=s.decode(l,{stream:!0});let u;for(;(u=n.indexOf(`
11
11
 
12
12
  `))!==-1;){let p=n.slice(0,u).trim();if(n=n.slice(u+2),!p.startsWith("data:"))continue;let c=p.slice(5).trim();if(c==="[DONE]"){n="";break}let a=JSON.parse(c).choices[0]?.delta?.content||"";a&&(t(a),r+=a)}}return r}async parseStream(e,t){let o=e.body.getReader(),s=new TextDecoder,n=[],r=new Map,i="";for(;;){let{done:p,value:c}=await o.read();if(p)break;i+=s.decode(c,{stream:!0});let h;for(;(h=i.indexOf(`
13
13
 
14
14
  `))!==-1;){let a=i.slice(0,h).trim();if(i=i.slice(h+2),!a.startsWith("data:"))continue;let m=a.slice(5).trim();if(m==="[DONE]"){i="";break}let g=JSON.parse(m).choices[0].delta;g.content&&(t(g.content),n.push({type:"text",text:g.content})),g.tool_calls&&g.tool_calls.forEach(_=>{let C=r.get(_.index)??{id:_.id,name:_.function.name,args:""};C.args+=_.function.arguments||"",r.set(_.index,C)})}}let l=Array.from(r.entries()).sort((p,c)=>p[0]-c[0]).map(([p,c])=>({type:"tool_use",id:c.id,name:c.name,input:JSON.parse(c.args||"{}")}));return{blocks:[...n,...l],stop_reason:l.length?"tool_use":"end"}}parseOneShot(e){let t=e.choices[0],o=[];return t.finish_reason==="tool_calls"?t.message.tool_calls.forEach(s=>o.push({type:"tool_use",id:s.id,name:s.function.name,input:JSON.parse(s.function.arguments||"{}")})):o.push({type:"text",text:t.message.content}),{blocks:o,stop_reason:t.finish_reason==="tool_calls"?"tool_use":"end"}}async parseResponsesStream(e,t){let o=e.body.getReader(),s=new TextDecoder,n=[],r=new Map,i="";for(;;){let{done:p,value:c}=await o.read();if(p)break;i+=s.decode(c,{stream:!0});let h="",a="",m=i.split(`
15
- `);i=m.pop()||"";for(let f=0;f<m.length;f++){let g=m[f].trim();if(g.startsWith("event:"))h=g.slice(6).trim();else if(g.startsWith("data:"))a=g.slice(5).trim();else if(g===""&&h&&a){try{let _=JSON.parse(a),C=this.handleResponsesSSEEvent(h,_,t,n,r)}catch{console.warn("Failed to parse SSE data:",a)}h="",a=""}}}let l=Array.from(r.values()).map(p=>({type:"tool_use",id:p.id,name:p.name,input:p.input||{}}));return{blocks:[...n,...l],stop_reason:l.length?"tool_use":"end"}}handleResponsesSSEEvent(e,t,o,s,n){switch(e){case"response.output_item.added":t.item?.type==="message"&&Array.isArray(t.item.content)?t.item.content.forEach(r=>{r.type==="output_text"&&r.text&&(o(r.text),v.append(s,r.text))}):t.item?.type==="function_call"&&n.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),v.append(s,t.part.text));break;case"response.output_text.delta":case"response.content_part.delta":{let r=typeof t.delta=="string"?t.delta:t.delta?.text??"";r&&(o(r),v.append(s,r))}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(s=>{s.type==="output_text"&&s.text&&t.push({type:"text",text:s.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 k=class{createChatService(e){let t=this.optimizeGPT5Options(e),o=t.visionModel||(this.supportsVisionForModel(t.model||this.getDefaultModel())?t.model:this.getDefaultModel()),s=t.tools,n=t.mcpServers??[],r=t.model||this.getDefaultModel(),i=!1;n.length>0?i=!0:L(r)&&(i=(t.gpt5EndpointPreference||"chat")==="responses");let l=t.endpoint||(i?S:D);return new A(t.apiKey,r,o,s,l,n,t.responseLength,t.verbosity,t.reasoning_effort,t.enableReasoningSummary)}getProviderName(){return"openai"}getSupportedModels(){return[I,W,$,O,X,Q,Z,b,ee,ge,_e,"o1",te]}getDefaultModel(){return I}supportsVision(){return!0}supportsVisionForModel(e){return q.includes(e)}optimizeGPT5Options(e){let t=e.model||this.getDefaultModel();if(!L(t))return e;let o={...e};if(e.gpt5Preset){let s=Pe[e.gpt5Preset];o.reasoning_effort=s.reasoning_effort,o.verbosity=s.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===O?"none":"medium"}normalizeReasoningEffort(e,t){if(t)return t==="none"&&!ve(e)?this.getDefaultReasoningEffortForModel(e):t==="minimal"&&!Ce(e)?"none":t}};var de=class{static async fetchToolSchemas(e){try{let t={"Content-Type":"application/json"};e.authorization_token&&(t.Authorization=`Bearer ${e.authorization_token}`);let s=await(await y.post(`${e.url}/tools`,{},t)).json();return Array.isArray(s.tools)?s.tools.map(n=>({name:`mcp_${e.name}_${n.name}`,description:n.description||`Tool from ${e.name} MCP server`,parameters:n.inputSchema||{type:"object",properties:{},required:[]}})):[{name:`mcp_${e.name}_search`,description:`Search using ${e.name} MCP server`,parameters:{type:"object",properties:{query:{type:"string",description:"Search query"}},required:["query"]}}]}catch(t){return console.warn(`Failed to fetch MCP schemas from ${e.name}:`,t),[{name:`mcp_${e.name}_search`,description:`Search using ${e.name} MCP server (schema fetch failed)`,parameters:{type:"object",properties:{query:{type:"string",description:"Search query"}},required:["query"]}}]}}static async fetchAllToolSchemas(e){let t=[];for(let o of e)try{let s=await this.fetchToolSchemas(o);t.push(...s)}catch(s){console.error(`Failed to fetch schemas from ${o.name}:`,s)}return t}};var U=class{constructor(e,t=T,o=T,s=[],n=[],r){this.provider="gemini";this.mcpToolSchemas=[];this.mcpSchemasInitialized=!1;this.callIdMap=new Map;if(this.apiKey=e,this.model=t,this.responseLength=r,!z.includes(o))throw new Error(`Model ${o} does not support vision capabilities.`);this.visionModel=o,this.tools=s,this.mcpServers=n}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,s])=>[t[o]??o,this.adaptKeysForApi(s)])):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,s)=>setTimeout(()=>s(new Error("MCP schema fetch timeout")),5e3)),t=de.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{if(this.tools.length===0&&this.mcpServers.length===0){let r=await this.callGemini(e,this.model,!0),{blocks:i}=await this.parseStream(r,t),l=i.filter(u=>u.type==="text").map(u=>u.text).join("");await o(l);return}let{blocks:s,stop_reason:n}=await this.chatOnce(e,!0,t);if(n==="end"){let r=s.filter(i=>i.type==="text").map(i=>i.text).join("");await o(r);return}throw new Error("Received functionCall. Use chatOnce() loop when tools are enabled.")}catch(s){throw console.error("Error in processChat:",s),s}}async processVisionChat(e,t,o){try{if(this.tools.length===0&&this.mcpServers.length===0){let r=await this.callGemini(e,this.visionModel,!0),{blocks:i}=await this.parseStream(r,t),l=i.filter(u=>u.type==="text").map(u=>u.text).join("");await o(l);return}let{blocks:s,stop_reason:n}=await this.visionChatOnce(e);if(s.filter(r=>r.type==="text").forEach(r=>t(r.text)),n==="end"){let r=s.filter(i=>i.type==="text").map(i=>i.text).join("");await o(r);return}throw new Error("Received functionCall. Use visionChatOnce() loop when tools are enabled.")}catch(s){throw console.error("Error in processVisionChat:",s),s}}convertMessagesToGeminiFormat(e){let t=[],o=null,s=[],n=()=>{o&&s.length&&(t.push({role:o,parts:[...s]}),s=[])};for(let r of e){let i=this.mapRoleToGemini(r.role);if(r.tool_calls){n();for(let l of r.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(r.role==="tool"){n();let l=r.name??this.callIdMap.get(r.tool_call_id)??"result";t.push({role:"user",parts:[{functionResponse:{name:l,response:this.normalizeToolResult(this.safeJsonParse(r.content))}}]});continue}i!==o&&n(),o=i,s.push({text:r.content})}return n(),t}async callGemini(e,t,o=!1,s){let i={contents:e.some(m=>Array.isArray(m.content)&&m.content.some(f=>f?.type==="image_url"||f?.inlineData))?await this.convertVisionMessagesToGeminiFormat(e):this.convertMessagesToGeminiFormat(e),generationConfig:{maxOutputTokens:s!==void 0?s:E(this.responseLength)}},l=[];if(this.tools.length>0&&l.push(...this.tools.map(m=>({name:m.name,description:m.description,parameters:m.parameters}))),this.mcpServers.length>0)try{await this.initializeMCPSchemas(),l.push(...this.mcpToolSchemas.map(m=>({name:m.name,description:m.description,parameters:m.parameters})))}catch(m){console.warn("MCP initialization failed, skipping MCP tools:",m)}l.length>0&&(i.tools=[{functionDeclarations:l}],i.toolConfig={functionCallingConfig:{mode:"AUTO"}});let u=async(m,f)=>{let g=o?"streamGenerateContent":"generateContent",_=o?"?alt=sse":"",C=`${Se}/${m}/models/${t}:${g}${_}${_?"&":"?"}key=${this.apiKey}`;return y.post(C,f)},p=/flash[-_]lite/.test(t),c=/gemini-2\.5/.test(t),h=p||c?"v1beta":"v1",a=async()=>{try{let m=h==="v1"?i:this.adaptKeysForApi(i);return await u(h,m)}catch(m){if(!(p||c)&&/Unknown name|Cannot find field|404/.test(m.message))return await u("v1beta",this.adaptKeysForApi(i));throw m}};try{return await a()}catch(m){throw m.body&&(console.error("Gemini API Error Details:",m.body),console.error("Request Body:",JSON.stringify(i,null,2))),m}}async convertVisionMessagesToGeminiFormat(e){let t=[],o=null,s=[];for(let n of e){let r=this.mapRoleToGemini(n.role);if(n.tool_calls){for(let i of n.tool_calls)t.push({role:"model",parts:[{functionCall:{name:i.function.name,args:JSON.parse(i.function.arguments||"{}")}}]});continue}if(n.role==="tool"){let i=n.name??this.callIdMap.get(n.tool_call_id)??"result";t.push({role:"user",parts:[{functionResponse:{name:i,response:this.normalizeToolResult(this.safeJsonParse(n.content))}}]});continue}if(r!==o&&s.length>0&&(t.push({role:o,parts:[...s]}),s=[]),o=r,typeof n.content=="string")s.push({text:n.content});else if(Array.isArray(n.content)){for(let i of n.content)if(i.type==="text")s.push({text:i.text});else if(i.type==="image_url")try{let u=await(await y.get(i.image_url.url)).blob(),p=await this.blobToBase64(u);s.push({inlineData:{mimeType:u.type||"image/jpeg",data:p.split(",")[1]}})}catch(l){throw console.error("Error processing image:",l),new Error(`Failed to process image: ${l.message}`)}}}return o&&s.length>0&&t.push({role:o,parts:[...s]}),t}blobToBase64(e){return new Promise((t,o)=>{let s=new FileReader;s.onloadend=()=>t(s.result),s.onerror=o,s.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(),s=new TextDecoder,n=[],r=[],i="",l=p=>{if(!p||p==="[DONE]")return;let c;try{c=JSON.parse(p)}catch{return}for(let h of c.candidates??[])for(let a of h.content?.parts??[])a.text&&(t(a.text),v.addTextBlock(n,a.text)),a.functionCall&&r.push({type:"tool_use",id:this.genUUID(),name:a.functionCall.name,input:a.functionCall.args??{}}),a.functionResponse&&r.push({type:"tool_result",tool_use_id:a.functionResponse.name,content:JSON.stringify(a.functionResponse.response)})};for(;;){let{done:p,value:c}=await o.read();if(p)break;i+=s.decode(c,{stream:!0});let h;for(;(h=i.indexOf(`
16
- `))!==-1;){let a=i.slice(0,h);if(i=i.slice(h+1),a.endsWith("\r")&&(a=a.slice(0,-1)),!a.trim()){l("");continue}a.startsWith("data:")&&(a=a.slice(5).trim()),a&&l(a)}}return i&&l(i),{blocks:[...n,...r],stop_reason:r.some(p=>p.type==="tool_use")?"tool_use":"end"}}parseOneShot(e){let t=[],o=[];for(let n of e.candidates??[])for(let r of n.content?.parts??[])r.text&&t.push({type:"text",text:r.text}),r.functionCall&&o.push({type:"tool_use",id:this.genUUID(),name:r.functionCall.name,input:r.functionCall.args??{}}),r.functionResponse&&o.push({type:"tool_result",tool_use_id:r.functionResponse.name,content:JSON.stringify(r.functionResponse.response)});return{blocks:[...t,...o],stop_reason:o.some(n=>n.type==="tool_use")?"tool_use":"end"}}async chatOnce(e,t=!0,o=()=>{},s){let n=await this.callGemini(e,this.model,t,s);return t?this.parseStream(n,o):this.parseOneShot(await n.json())}async visionChatOnce(e,t=!1,o=()=>{},s){let n=await this.callGemini(e,this.visionModel,t,s);return t?this.parseStream(n,o):this.parseOneShot(await n.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 G=class{createChatService(e){let t=e.visionModel||(this.supportsVisionForModel(e.model||this.getDefaultModel())?e.model:this.getDefaultModel());return new U(e.apiKey,e.model||this.getDefaultModel(),t,e.tools||[],e.mcpServers||[],e.responseLength)}getProviderName(){return"gemini"}getSupportedModels(){return[oe,se,ne,re,ie,T]}getDefaultModel(){return T}supportsVision(){return!0}supportsVisionForModel(e){return z.includes(e)}};var V=class{constructor(e,t=M,o=M,s=[],n=[],r){this.provider="claude";if(this.apiKey=e,this.model=t||M,this.visionModel=o||M,this.tools=s,this.mcpServers=n,this.responseLength=r,!K.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){if(this.tools.length===0&&this.mcpServers.length===0){let n=await this.callClaude(e,this.model,!0),r=await this.parsePureStream(n,t);await o(r);return}let s=await this.chatOnce(e,!0,t);if(s.stop_reason==="end"){let n=s.blocks.filter(r=>r.type==="text").map(r=>r.text).join("");await o(n);return}throw new Error("processChat received tool_calls. ChatProcessor must use chatOnce() loop when tools are enabled.")}async processVisionChat(e,t,o){if(this.tools.length===0&&this.mcpServers.length===0){let n=await this.callClaude(e,this.visionModel,!0),r=await this.parsePureStream(n,t);await o(r);return}let s=await this.visionChatOnce(e);if(s.stop_reason==="end"){let n=s.blocks.filter(r=>r.type==="text").map(r=>r.text).join("");await o(n);return}throw new Error("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(s=>{if(s.type==="image_url"){if(s.image_url.url.startsWith("data:")){let n=s.image_url.url.match(/^data:([^;]+);base64,(.+)$/);return n?{type:"image",source:{type:"base64",media_type:n[1],data:n[2]}}:null}return{type:"image",source:{type:"url",url:s.image_url.url,media_type:this.getMimeTypeFromUrl(s.image_url.url)}}}return s}).filter(s=>s);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,s){let n=e.find(c=>c.role==="system")?.content??"",r=e.filter(c=>c.role!=="system"),i=r.some(c=>Array.isArray(c.content)&&c.content.some(h=>h.type==="image_url"||h.type==="image")),l={model:t,system:n,messages:i?this.convertVisionMessagesToClaudeFormat(r):this.convertMessagesToClaudeFormat(r),stream:o,max_tokens:s!==void 0?s:E(this.responseLength)};this.tools.length&&(l.tools=this.tools.map(c=>({name:c.name,description:c.description,input_schema:c.parameters})),l.tool_choice={type:"auto"}),this.mcpServers.length>0&&(l.mcp_servers=this.mcpServers);let u={"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&&(u["anthropic-beta"]="mcp-client-2025-04-04"),await y.post(Me,l,u)}async parseStream(e,t){let o=e.body.getReader(),s=new TextDecoder,n=[],r=new Map,i="";for(;;){let{done:l,value:u}=await o.read();if(l)break;i+=s.decode(u,{stream:!0});let p;for(;(p=i.indexOf(`
17
- `))!==-1;){let c=i.slice(0,p).trim();if(i=i.slice(p+1),!c.startsWith("data:"))continue;let h=c.slice(5).trim();if(h==="[DONE]")break;let a=JSON.parse(h);if(a.type==="content_block_delta"&&a.delta?.text&&(t(a.delta.text),n.push({type:"text",text:a.delta.text})),a.type==="content_block_start"&&a.content_block?.type==="tool_use"?r.set(a.index,{id:a.content_block.id,name:a.content_block.name,args:""}):a.type==="content_block_start"&&a.content_block?.type==="mcp_tool_use"?r.set(a.index,{id:a.content_block.id,name:a.content_block.name,args:"",server_name:a.content_block.server_name}):a.type==="content_block_start"&&a.content_block?.type==="tool_result"?n.push({type:"tool_result",tool_use_id:a.content_block.tool_use_id,content:a.content_block.content??""}):a.type==="content_block_start"&&a.content_block?.type==="mcp_tool_result"&&n.push({type:"mcp_tool_result",tool_use_id:a.content_block.tool_use_id,is_error:a.content_block.is_error??!1,content:a.content_block.content??[]}),a.type==="content_block_delta"&&a.delta?.type==="input_json_delta"){let m=r.get(a.index);m&&(m.args+=a.delta.partial_json||"")}if(a.type==="content_block_stop"&&r.has(a.index)){let{id:m,name:f,args:g,server_name:_}=r.get(a.index);_?n.push({type:"mcp_tool_use",id:m,name:f,server_name:_,input:JSON.parse(g||"{}")}):n.push({type:"tool_use",id:m,name:f,input:JSON.parse(g||"{}")}),r.delete(a.index)}}}return{blocks:n,stop_reason:n.some(l=>l.type==="tool_use"||l.type==="mcp_tool_use")?"tool_use":"end"}}async parsePureStream(e,t){let{blocks:o}=await this.parseStream(e,t);return o.filter(s=>s.type==="text").map(s=>s.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=()=>{},s){let n=await this.callClaude(e,this.model,t,s),r=t?await this.parseStream(n,o):this.parseOneShot(await n.json());return this.convertToStandardCompletion(r)}async visionChatOnce(e,t=!1,o=()=>{},s){let n=await this.callClaude(e,this.visionModel,t,s),r=t?await this.parseStream(n,o):this.parseOneShot(await n.json());return this.convertToStandardCompletion(r)}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 F=class{createChatService(e){let t=e.visionModel||(this.supportsVisionForModel(e.model||this.getDefaultModel())?e.model:this.getDefaultModel());return new V(e.apiKey,e.model||this.getDefaultModel(),t,e.tools??[],e.mcpServers??[],e.responseLength)}getProviderName(){return"claude"}getSupportedModels(){return[M,ae,le,ce,pe,ue,he,me]}getDefaultModel(){return M}supportsVision(){return!0}supportsVisionForModel(e){return K.includes(e)}};var B=class{constructor(e,t=P,o=P,s,n=Ee,r,i,l,u,p,c){this.provider="openrouter";this.lastRequestTime=0;this.requestCount=0;this.apiKey=e,this.model=t,this.tools=s||[],this.endpoint=n,this.responseLength=r,this.appName=i,this.appUrl=l,this.reasoning_effort=u,this.includeReasoning=p,this.reasoningMaxTokens=c,this.visionModel=o}getModel(){return this.model}getVisionModel(){return this.visionModel}async applyRateLimiting(){if(!Oe(this.model))return;let e=Date.now(),t=e-this.lastRequestTime;if(t>6e4&&(this.requestCount=0),this.requestCount>=xe){let o=6e4-t;o>0&&(console.log(`Rate limit reached for free tier. Waiting ${o}ms...`),await new Promise(s=>setTimeout(s,o)),this.requestCount=0)}this.lastRequestTime=e,this.requestCount++}async processChat(e,t,o){if(await this.applyRateLimiting(),this.tools.length===0){let r=await this.callOpenRouter(e,this.model,!0),i=await this.handleStream(r,t);await o(i);return}let{blocks:s,stop_reason:n}=await this.chatOnce(e);if(n==="end"){let r=s.filter(i=>i.type==="text").map(i=>i.text).join("");await o(r);return}throw new Error("processChat received tool_calls. ChatProcessor must use chatOnce() loop when tools are enabled.")}async processVisionChat(e,t,o){if(!N(this.visionModel))throw new Error(`Model ${this.visionModel} does not support vision capabilities.`);await this.applyRateLimiting();try{if(this.tools.length===0){let r=await this.callOpenRouter(e,this.visionModel,!0),i=await this.handleStream(r,t);await o(i);return}let{blocks:s,stop_reason:n}=await this.visionChatOnce(e,!0,t);if(n==="end"){let r=s.filter(i=>i.type==="text").map(i=>i.text).join("");await o(r);return}throw new Error("processVisionChat received tool_calls. ChatProcessor must use visionChatOnce() loop when tools are enabled.")}catch(s){throw console.error("Error in processVisionChat:",s),s}}async chatOnce(e,t=!0,o=()=>{},s){await this.applyRateLimiting();let n=await this.callOpenRouter(e,this.model,t,s);return t?this.parseStream(n,o):this.parseOneShot(await n.json())}async visionChatOnce(e,t=!1,o=()=>{},s){if(!N(this.visionModel))throw new Error(`Model ${this.visionModel} does not support vision capabilities.`);await this.applyRateLimiting();let n=await this.callOpenRouter(e,this.visionModel,t,s);return t?this.parseStream(n,o):this.parseOneShot(await n.json())}async callOpenRouter(e,t,o=!1,s){let n=this.buildRequestBody(e,t,o,s),r={Authorization:`Bearer ${this.apiKey}`};return this.appUrl&&(r["HTTP-Referer"]=this.appUrl),this.appName&&(r["X-Title"]=this.appName),await y.post(this.endpoint,n,r)}buildRequestBody(e,t,o,s){let n={model:t,messages:e,stream:o};if((s!==void 0?s:E(this.responseLength))&&console.warn("OpenRouter: Token limits are not supported for gpt-oss-20b model due to known issues. Using unlimited tokens instead."),this.reasoning_effort!==void 0||this.includeReasoning!==void 0||this.reasoningMaxTokens){if(n.reasoning={},this.reasoning_effort&&this.reasoning_effort!=="none"){let i=this.reasoning_effort==="minimal"?"low":this.reasoning_effort;n.reasoning.effort=i}(this.reasoning_effort==="none"||this.includeReasoning!==!0)&&(n.reasoning.exclude=!0),this.reasoningMaxTokens&&(n.reasoning.max_tokens=this.reasoningMaxTokens)}else n.reasoning={exclude:!0};return this.tools.length>0&&(n.tools=this.tools.map(i=>({type:"function",function:{name:i.name,description:i.description,parameters:i.parameters}})),n.tool_choice="auto"),n}async handleStream(e,t){let o=e.body.getReader(),s=new TextDecoder,n="",r="";for(;;){let{done:i,value:l}=await o.read();if(i)break;n+=s.decode(l,{stream:!0});let u=n.split(`
15
+ `);i=m.pop()||"";for(let f=0;f<m.length;f++){let g=m[f].trim();if(g.startsWith("event:"))h=g.slice(6).trim();else if(g.startsWith("data:"))a=g.slice(5).trim();else if(g===""&&h&&a){try{let _=JSON.parse(a),C=this.handleResponsesSSEEvent(h,_,t,n,r)}catch{console.warn("Failed to parse SSE data:",a)}h="",a=""}}}let l=Array.from(r.values()).map(p=>({type:"tool_use",id:p.id,name:p.name,input:p.input||{}}));return{blocks:[...n,...l],stop_reason:l.length?"tool_use":"end"}}handleResponsesSSEEvent(e,t,o,s,n){switch(e){case"response.output_item.added":t.item?.type==="message"&&Array.isArray(t.item.content)?t.item.content.forEach(r=>{r.type==="output_text"&&r.text&&(o(r.text),v.append(s,r.text))}):t.item?.type==="function_call"&&n.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),v.append(s,t.part.text));break;case"response.output_text.delta":case"response.content_part.delta":{let r=typeof t.delta=="string"?t.delta:t.delta?.text??"";r&&(o(r),v.append(s,r))}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(s=>{s.type==="output_text"&&s.text&&t.push({type:"text",text:s.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 k=class{createChatService(e){let t=this.optimizeGPT5Options(e),o=t.visionModel||(this.supportsVisionForModel(t.model||this.getDefaultModel())?t.model:this.getDefaultModel()),s=t.tools,n=t.mcpServers??[],r=t.model||this.getDefaultModel(),i=!1;n.length>0?i=!0:L(r)&&(i=(t.gpt5EndpointPreference||"chat")==="responses");let l=t.endpoint||(i?S:D);return new A(t.apiKey,r,o,s,l,n,t.responseLength,t.verbosity,t.reasoning_effort,t.enableReasoningSummary)}getProviderName(){return"openai"}getSupportedModels(){return[I,W,$,O,X,Q,Z,b,ee,_e,ye,"o1",te]}getDefaultModel(){return I}supportsVision(){return!0}supportsVisionForModel(e){return q.includes(e)}optimizeGPT5Options(e){let t=e.model||this.getDefaultModel();if(!L(t))return e;let o={...e};if(e.gpt5Preset){let s=we[e.gpt5Preset];o.reasoning_effort=s.reasoning_effort,o.verbosity=s.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===O?"none":"medium"}normalizeReasoningEffort(e,t){if(t)return t==="none"&&!Ce(e)?this.getDefaultReasoningEffortForModel(e):t==="minimal"&&!Se(e)?"none":t}};var fe=class{static async fetchToolSchemas(e){try{let t={"Content-Type":"application/json"};e.authorization_token&&(t.Authorization=`Bearer ${e.authorization_token}`);let s=await(await y.post(`${e.url}/tools`,{},t)).json();return Array.isArray(s.tools)?s.tools.map(n=>({name:`mcp_${e.name}_${n.name}`,description:n.description||`Tool from ${e.name} MCP server`,parameters:n.inputSchema||{type:"object",properties:{},required:[]}})):[{name:`mcp_${e.name}_search`,description:`Search using ${e.name} MCP server`,parameters:{type:"object",properties:{query:{type:"string",description:"Search query"}},required:["query"]}}]}catch(t){return console.warn(`Failed to fetch MCP schemas from ${e.name}:`,t),[{name:`mcp_${e.name}_search`,description:`Search using ${e.name} MCP server (schema fetch failed)`,parameters:{type:"object",properties:{query:{type:"string",description:"Search query"}},required:["query"]}}]}}static async fetchAllToolSchemas(e){let t=[];for(let o of e)try{let s=await this.fetchToolSchemas(o);t.push(...s)}catch(s){console.error(`Failed to fetch schemas from ${o.name}:`,s)}return t}};var U=class{constructor(e,t=T,o=T,s=[],n=[],r){this.provider="gemini";this.mcpToolSchemas=[];this.mcpSchemasInitialized=!1;this.callIdMap=new Map;if(this.apiKey=e,this.model=t,this.responseLength=r,!z.includes(o))throw new Error(`Model ${o} does not support vision capabilities.`);this.visionModel=o,this.tools=s,this.mcpServers=n}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,s])=>[t[o]??o,this.adaptKeysForApi(s)])):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,s)=>setTimeout(()=>s(new Error("MCP schema fetch timeout")),5e3)),t=fe.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{if(this.tools.length===0&&this.mcpServers.length===0){let r=await this.callGemini(e,this.model,!0),{blocks:i}=await this.parseStream(r,t),l=i.filter(u=>u.type==="text").map(u=>u.text).join("");await o(l);return}let{blocks:s,stop_reason:n}=await this.chatOnce(e,!0,t);if(n==="end"){let r=s.filter(i=>i.type==="text").map(i=>i.text).join("");await o(r);return}throw new Error("Received functionCall. Use chatOnce() loop when tools are enabled.")}catch(s){throw console.error("Error in processChat:",s),s}}async processVisionChat(e,t,o){try{if(this.tools.length===0&&this.mcpServers.length===0){let r=await this.callGemini(e,this.visionModel,!0),{blocks:i}=await this.parseStream(r,t),l=i.filter(u=>u.type==="text").map(u=>u.text).join("");await o(l);return}let{blocks:s,stop_reason:n}=await this.visionChatOnce(e);if(s.filter(r=>r.type==="text").forEach(r=>t(r.text)),n==="end"){let r=s.filter(i=>i.type==="text").map(i=>i.text).join("");await o(r);return}throw new Error("Received functionCall. Use visionChatOnce() loop when tools are enabled.")}catch(s){throw console.error("Error in processVisionChat:",s),s}}convertMessagesToGeminiFormat(e){let t=[],o=null,s=[],n=()=>{o&&s.length&&(t.push({role:o,parts:[...s]}),s=[])};for(let r of e){let i=this.mapRoleToGemini(r.role);if(r.tool_calls){n();for(let l of r.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(r.role==="tool"){n();let l=r.name??this.callIdMap.get(r.tool_call_id)??"result";t.push({role:"user",parts:[{functionResponse:{name:l,response:this.normalizeToolResult(this.safeJsonParse(r.content))}}]});continue}i!==o&&n(),o=i,s.push({text:r.content})}return n(),t}async callGemini(e,t,o=!1,s){let i={contents:e.some(m=>Array.isArray(m.content)&&m.content.some(f=>f?.type==="image_url"||f?.inlineData))?await this.convertVisionMessagesToGeminiFormat(e):this.convertMessagesToGeminiFormat(e),generationConfig:{maxOutputTokens:s!==void 0?s:M(this.responseLength)}},l=[];if(this.tools.length>0&&l.push(...this.tools.map(m=>({name:m.name,description:m.description,parameters:m.parameters}))),this.mcpServers.length>0)try{await this.initializeMCPSchemas(),l.push(...this.mcpToolSchemas.map(m=>({name:m.name,description:m.description,parameters:m.parameters})))}catch(m){console.warn("MCP initialization failed, skipping MCP tools:",m)}l.length>0&&(i.tools=[{functionDeclarations:l}],i.toolConfig={functionCallingConfig:{mode:"AUTO"}});let u=async(m,f)=>{let g=o?"streamGenerateContent":"generateContent",_=o?"?alt=sse":"",C=`${Ee}/${m}/models/${t}:${g}${_}${_?"&":"?"}key=${this.apiKey}`;return y.post(C,f)},p=/flash[-_]lite/.test(t),c=/gemini-2\.5/.test(t),h=p||c?"v1beta":"v1",a=async()=>{try{let m=h==="v1"?i:this.adaptKeysForApi(i);return await u(h,m)}catch(m){if(!(p||c)&&/Unknown name|Cannot find field|404/.test(m.message))return await u("v1beta",this.adaptKeysForApi(i));throw m}};try{return await a()}catch(m){throw m.body&&(console.error("Gemini API Error Details:",m.body),console.error("Request Body:",JSON.stringify(i,null,2))),m}}async convertVisionMessagesToGeminiFormat(e){let t=[],o=null,s=[];for(let n of e){let r=this.mapRoleToGemini(n.role);if(n.tool_calls){for(let i of n.tool_calls)t.push({role:"model",parts:[{functionCall:{name:i.function.name,args:JSON.parse(i.function.arguments||"{}")}}]});continue}if(n.role==="tool"){let i=n.name??this.callIdMap.get(n.tool_call_id)??"result";t.push({role:"user",parts:[{functionResponse:{name:i,response:this.normalizeToolResult(this.safeJsonParse(n.content))}}]});continue}if(r!==o&&s.length>0&&(t.push({role:o,parts:[...s]}),s=[]),o=r,typeof n.content=="string")s.push({text:n.content});else if(Array.isArray(n.content)){for(let i of n.content)if(i.type==="text")s.push({text:i.text});else if(i.type==="image_url")try{let u=await(await y.get(i.image_url.url)).blob(),p=await this.blobToBase64(u);s.push({inlineData:{mimeType:u.type||"image/jpeg",data:p.split(",")[1]}})}catch(l){throw console.error("Error processing image:",l),new Error(`Failed to process image: ${l.message}`)}}}return o&&s.length>0&&t.push({role:o,parts:[...s]}),t}blobToBase64(e){return new Promise((t,o)=>{let s=new FileReader;s.onloadend=()=>t(s.result),s.onerror=o,s.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(),s=new TextDecoder,n=[],r=[],i="",l=p=>{if(!p||p==="[DONE]")return;let c;try{c=JSON.parse(p)}catch{return}for(let h of c.candidates??[])for(let a of h.content?.parts??[])a.text&&(t(a.text),v.addTextBlock(n,a.text)),a.functionCall&&r.push({type:"tool_use",id:this.genUUID(),name:a.functionCall.name,input:a.functionCall.args??{}}),a.functionResponse&&r.push({type:"tool_result",tool_use_id:a.functionResponse.name,content:JSON.stringify(a.functionResponse.response)})};for(;;){let{done:p,value:c}=await o.read();if(p)break;i+=s.decode(c,{stream:!0});let h;for(;(h=i.indexOf(`
16
+ `))!==-1;){let a=i.slice(0,h);if(i=i.slice(h+1),a.endsWith("\r")&&(a=a.slice(0,-1)),!a.trim()){l("");continue}a.startsWith("data:")&&(a=a.slice(5).trim()),a&&l(a)}}return i&&l(i),{blocks:[...n,...r],stop_reason:r.some(p=>p.type==="tool_use")?"tool_use":"end"}}parseOneShot(e){let t=[],o=[];for(let n of e.candidates??[])for(let r of n.content?.parts??[])r.text&&t.push({type:"text",text:r.text}),r.functionCall&&o.push({type:"tool_use",id:this.genUUID(),name:r.functionCall.name,input:r.functionCall.args??{}}),r.functionResponse&&o.push({type:"tool_result",tool_use_id:r.functionResponse.name,content:JSON.stringify(r.functionResponse.response)});return{blocks:[...t,...o],stop_reason:o.some(n=>n.type==="tool_use")?"tool_use":"end"}}async chatOnce(e,t=!0,o=()=>{},s){let n=await this.callGemini(e,this.model,t,s);return t?this.parseStream(n,o):this.parseOneShot(await n.json())}async visionChatOnce(e,t=!1,o=()=>{},s){let n=await this.callGemini(e,this.visionModel,t,s);return t?this.parseStream(n,o):this.parseOneShot(await n.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 G=class{createChatService(e){let t=e.visionModel||(this.supportsVisionForModel(e.model||this.getDefaultModel())?e.model:this.getDefaultModel());return new U(e.apiKey,e.model||this.getDefaultModel(),t,e.tools||[],e.mcpServers||[],e.responseLength)}getProviderName(){return"gemini"}getSupportedModels(){return[oe,se,ne,re,ie,T]}getDefaultModel(){return T}supportsVision(){return!0}supportsVisionForModel(e){return z.includes(e)}};var V=class{constructor(e,t=E,o=E,s=[],n=[],r){this.provider="claude";if(this.apiKey=e,this.model=t||E,this.visionModel=o||E,this.tools=s,this.mcpServers=n,this.responseLength=r,!K.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){if(this.tools.length===0&&this.mcpServers.length===0){let n=await this.callClaude(e,this.model,!0),r=await this.parsePureStream(n,t);await o(r);return}let s=await this.chatOnce(e,!0,t);if(s.stop_reason==="end"){let n=s.blocks.filter(r=>r.type==="text").map(r=>r.text).join("");await o(n);return}throw new Error("processChat received tool_calls. ChatProcessor must use chatOnce() loop when tools are enabled.")}async processVisionChat(e,t,o){if(this.tools.length===0&&this.mcpServers.length===0){let n=await this.callClaude(e,this.visionModel,!0),r=await this.parsePureStream(n,t);await o(r);return}let s=await this.visionChatOnce(e);if(s.stop_reason==="end"){let n=s.blocks.filter(r=>r.type==="text").map(r=>r.text).join("");await o(n);return}throw new Error("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(s=>{if(s.type==="image_url"){if(s.image_url.url.startsWith("data:")){let n=s.image_url.url.match(/^data:([^;]+);base64,(.+)$/);return n?{type:"image",source:{type:"base64",media_type:n[1],data:n[2]}}:null}return{type:"image",source:{type:"url",url:s.image_url.url,media_type:this.getMimeTypeFromUrl(s.image_url.url)}}}return s}).filter(s=>s);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,s){let n=e.find(c=>c.role==="system")?.content??"",r=e.filter(c=>c.role!=="system"),i=r.some(c=>Array.isArray(c.content)&&c.content.some(h=>h.type==="image_url"||h.type==="image")),l={model:t,system:n,messages:i?this.convertVisionMessagesToClaudeFormat(r):this.convertMessagesToClaudeFormat(r),stream:o,max_tokens:s!==void 0?s:M(this.responseLength)};this.tools.length&&(l.tools=this.tools.map(c=>({name:c.name,description:c.description,input_schema:c.parameters})),l.tool_choice={type:"auto"}),this.mcpServers.length>0&&(l.mcp_servers=this.mcpServers);let u={"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&&(u["anthropic-beta"]="mcp-client-2025-04-04"),await y.post(Me,l,u)}async parseStream(e,t){let o=e.body.getReader(),s=new TextDecoder,n=[],r=new Map,i="";for(;;){let{done:l,value:u}=await o.read();if(l)break;i+=s.decode(u,{stream:!0});let p;for(;(p=i.indexOf(`
17
+ `))!==-1;){let c=i.slice(0,p).trim();if(i=i.slice(p+1),!c.startsWith("data:"))continue;let h=c.slice(5).trim();if(h==="[DONE]")break;let a=JSON.parse(h);if(a.type==="content_block_delta"&&a.delta?.text&&(t(a.delta.text),n.push({type:"text",text:a.delta.text})),a.type==="content_block_start"&&a.content_block?.type==="tool_use"?r.set(a.index,{id:a.content_block.id,name:a.content_block.name,args:""}):a.type==="content_block_start"&&a.content_block?.type==="mcp_tool_use"?r.set(a.index,{id:a.content_block.id,name:a.content_block.name,args:"",server_name:a.content_block.server_name}):a.type==="content_block_start"&&a.content_block?.type==="tool_result"?n.push({type:"tool_result",tool_use_id:a.content_block.tool_use_id,content:a.content_block.content??""}):a.type==="content_block_start"&&a.content_block?.type==="mcp_tool_result"&&n.push({type:"mcp_tool_result",tool_use_id:a.content_block.tool_use_id,is_error:a.content_block.is_error??!1,content:a.content_block.content??[]}),a.type==="content_block_delta"&&a.delta?.type==="input_json_delta"){let m=r.get(a.index);m&&(m.args+=a.delta.partial_json||"")}if(a.type==="content_block_stop"&&r.has(a.index)){let{id:m,name:f,args:g,server_name:_}=r.get(a.index);_?n.push({type:"mcp_tool_use",id:m,name:f,server_name:_,input:JSON.parse(g||"{}")}):n.push({type:"tool_use",id:m,name:f,input:JSON.parse(g||"{}")}),r.delete(a.index)}}}return{blocks:n,stop_reason:n.some(l=>l.type==="tool_use"||l.type==="mcp_tool_use")?"tool_use":"end"}}async parsePureStream(e,t){let{blocks:o}=await this.parseStream(e,t);return o.filter(s=>s.type==="text").map(s=>s.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=()=>{},s){let n=await this.callClaude(e,this.model,t,s),r=t?await this.parseStream(n,o):this.parseOneShot(await n.json());return this.convertToStandardCompletion(r)}async visionChatOnce(e,t=!1,o=()=>{},s){let n=await this.callClaude(e,this.visionModel,t,s),r=t?await this.parseStream(n,o):this.parseOneShot(await n.json());return this.convertToStandardCompletion(r)}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 F=class{createChatService(e){let t=e.visionModel||(this.supportsVisionForModel(e.model||this.getDefaultModel())?e.model:this.getDefaultModel());return new V(e.apiKey,e.model||this.getDefaultModel(),t,e.tools??[],e.mcpServers??[],e.responseLength)}getProviderName(){return"claude"}getSupportedModels(){return[E,ae,le,ce,pe,ue,he,me,de]}getDefaultModel(){return E}supportsVision(){return!0}supportsVisionForModel(e){return K.includes(e)}};var B=class{constructor(e,t=P,o=P,s,n=xe,r,i,l,u,p,c){this.provider="openrouter";this.lastRequestTime=0;this.requestCount=0;this.apiKey=e,this.model=t,this.tools=s||[],this.endpoint=n,this.responseLength=r,this.appName=i,this.appUrl=l,this.reasoning_effort=u,this.includeReasoning=p,this.reasoningMaxTokens=c,this.visionModel=o}getModel(){return this.model}getVisionModel(){return this.visionModel}async applyRateLimiting(){if(!Te(this.model))return;let e=Date.now(),t=e-this.lastRequestTime;if(t>6e4&&(this.requestCount=0),this.requestCount>=Oe){let o=6e4-t;o>0&&(console.log(`Rate limit reached for free tier. Waiting ${o}ms...`),await new Promise(s=>setTimeout(s,o)),this.requestCount=0)}this.lastRequestTime=e,this.requestCount++}async processChat(e,t,o){if(await this.applyRateLimiting(),this.tools.length===0){let r=await this.callOpenRouter(e,this.model,!0),i=await this.handleStream(r,t);await o(i);return}let{blocks:s,stop_reason:n}=await this.chatOnce(e);if(n==="end"){let r=s.filter(i=>i.type==="text").map(i=>i.text).join("");await o(r);return}throw new Error("processChat received tool_calls. ChatProcessor must use chatOnce() loop when tools are enabled.")}async processVisionChat(e,t,o){if(!N(this.visionModel))throw new Error(`Model ${this.visionModel} does not support vision capabilities.`);await this.applyRateLimiting();try{if(this.tools.length===0){let r=await this.callOpenRouter(e,this.visionModel,!0),i=await this.handleStream(r,t);await o(i);return}let{blocks:s,stop_reason:n}=await this.visionChatOnce(e,!0,t);if(n==="end"){let r=s.filter(i=>i.type==="text").map(i=>i.text).join("");await o(r);return}throw new Error("processVisionChat received tool_calls. ChatProcessor must use visionChatOnce() loop when tools are enabled.")}catch(s){throw console.error("Error in processVisionChat:",s),s}}async chatOnce(e,t=!0,o=()=>{},s){await this.applyRateLimiting();let n=await this.callOpenRouter(e,this.model,t,s);return t?this.parseStream(n,o):this.parseOneShot(await n.json())}async visionChatOnce(e,t=!1,o=()=>{},s){if(!N(this.visionModel))throw new Error(`Model ${this.visionModel} does not support vision capabilities.`);await this.applyRateLimiting();let n=await this.callOpenRouter(e,this.visionModel,t,s);return t?this.parseStream(n,o):this.parseOneShot(await n.json())}async callOpenRouter(e,t,o=!1,s){let n=this.buildRequestBody(e,t,o,s),r={Authorization:`Bearer ${this.apiKey}`};return this.appUrl&&(r["HTTP-Referer"]=this.appUrl),this.appName&&(r["X-Title"]=this.appName),await y.post(this.endpoint,n,r)}buildRequestBody(e,t,o,s){let n={model:t,messages:e,stream:o};if((s!==void 0?s:M(this.responseLength))&&console.warn("OpenRouter: Token limits are not supported for gpt-oss-20b model due to known issues. Using unlimited tokens instead."),this.reasoning_effort!==void 0||this.includeReasoning!==void 0||this.reasoningMaxTokens){if(n.reasoning={},this.reasoning_effort&&this.reasoning_effort!=="none"){let i=this.reasoning_effort==="minimal"?"low":this.reasoning_effort;n.reasoning.effort=i}(this.reasoning_effort==="none"||this.includeReasoning!==!0)&&(n.reasoning.exclude=!0),this.reasoningMaxTokens&&(n.reasoning.max_tokens=this.reasoningMaxTokens)}else n.reasoning={exclude:!0};return this.tools.length>0&&(n.tools=this.tools.map(i=>({type:"function",function:{name:i.name,description:i.description,parameters:i.parameters}})),n.tool_choice="auto"),n}async handleStream(e,t){let o=e.body.getReader(),s=new TextDecoder,n="",r="";for(;;){let{done:i,value:l}=await o.read();if(i)break;n+=s.decode(l,{stream:!0});let u=n.split(`
18
18
  `);n=u.pop()||"";for(let p of u){let c=p.trim();if(!c||c.startsWith(":")||!c.startsWith("data:"))continue;let h=c.slice(5).trim();if(h==="[DONE]")return r;try{let m=JSON.parse(h).choices?.[0]?.delta?.content||"";m&&(t(m),r+=m)}catch{console.debug("Failed to parse SSE data:",h)}}}return r}async parseStream(e,t){let o=e.body.getReader(),s=new TextDecoder,n=[],r=new Map,i="";for(;;){let{done:p,value:c}=await o.read();if(p)break;i+=s.decode(c,{stream:!0});let h=i.split(`
19
- `);i=h.pop()||"";for(let a of h){let m=a.trim();if(!m||m.startsWith(":")||!m.startsWith("data:"))continue;let f=m.slice(5).trim();if(f==="[DONE]")break;try{let _=JSON.parse(f).choices?.[0]?.delta;_?.content&&(t(_.content),v.append(n,_.content)),_?.tool_calls&&_.tool_calls.forEach(C=>{let be=r.get(C.index)??{id:C.id,name:C.function?.name,args:""};be.args+=C.function?.arguments||"",r.set(C.index,be)})}catch{console.debug("Failed to parse SSE data:",f)}}}let l=Array.from(r.entries()).sort((p,c)=>p[0]-c[0]).map(([p,c])=>({type:"tool_use",id:c.id,name:c.name,input:JSON.parse(c.args||"{}")}));return{blocks:[...n,...l],stop_reason:l.length?"tool_use":"end"}}parseOneShot(e){let t=e.choices?.[0],o=[];return t?.finish_reason==="tool_calls"&&t?.message?.tool_calls?t.message.tool_calls.forEach(s=>o.push({type:"tool_use",id:s.id,name:s.function?.name,input:JSON.parse(s.function?.arguments||"{}")})):t?.message?.content&&o.push({type:"text",text:t.message.content}),{blocks:o,stop_reason:t?.finish_reason==="tool_calls"?"tool_use":"end"}}};var j=class{createChatService(e){let t=e.visionModel||e.model||this.getDefaultModel();if(e.visionModel&&!this.supportsVisionForModel(e.visionModel))throw new Error(`Model ${e.visionModel} does not support vision capabilities.`);let o=e.tools,s=e.appName,n=e.appUrl;return new B(e.apiKey,e.model||this.getDefaultModel(),t,o,e.endpoint,e.responseLength,s,n,e.reasoning_effort,e.includeReasoning,e.reasoningMaxTokens)}getProviderName(){return"openrouter"}getSupportedModels(){return[P]}getDefaultModel(){return P}supportsVision(){return!1}supportsVisionForModel(e){return N(e)}getFreeModels(){return J}isModelFree(e){return J.includes(e)||e.endsWith(":free")}};var x=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():[]}};x.providers=new Map;x.registerProvider(new k);x.registerProvider(new G);x.registerProvider(new F);x.registerProvider(new j);var ze=["happy","sad","angry","surprised","neutral"],Le=/\[([a-z]+)\]/i,we=/\[[a-z]+\]\s*/gi,H=class{static extractEmotion(e){let t=e.match(Le);if(t){let o=t[1].toLowerCase(),s=e.replace(we,"").trim();return{emotion:o,cleanText:s}}return{cleanText:e}}static isValidEmotion(e){return ze.includes(e)}static cleanEmotionTags(e){return e.replace(we,"").trim()}static addEmotionTag(e,t){return`[${e}] ${t}`}};function Ne(d){let{emotion:e,cleanText:t}=H.extractEmotion(d);return e?{emotion:e,text:t}:{text:t}}function Ke(d){return d.map(e=>Ne(e))}function Je(d){return d.emotion?H.addEmotionTag(d.emotion,d.text):d.text}async function Ye(d,e){let{blocks:t}=await d.chatOnce(e,!1,()=>{});return v.getFullText(t)}function Ae(){y.setFetch(async(d,e={})=>{let t=(e.method||"GET").toString().toUpperCase(),o=e.headers,s={};if(Array.isArray(o))for(let[c,h]of o)s[c]=String(h);else if(o&&typeof o=="object")for(let[c,h]of Object.entries(o))s[c]=String(h);let n={method:t,headers:s,muteHttpExceptions:!0},r=e.body;typeof r=="string"?n.payload=r:r!=null&&(s["Content-Type"]||(s["Content-Type"]="application/json"),n.payload=JSON.stringify(r));let i=UrlFetchApp.fetch(d,n),l=i.getResponseCode(),u=i.getContentText();return{ok:l>=200&&l<300,status:l,statusText:String(l),text:async()=>u,json:async()=>u?JSON.parse(u):null}})}return Be(Xe);})();
19
+ `);i=h.pop()||"";for(let a of h){let m=a.trim();if(!m||m.startsWith(":")||!m.startsWith("data:"))continue;let f=m.slice(5).trim();if(f==="[DONE]")break;try{let _=JSON.parse(f).choices?.[0]?.delta;_?.content&&(t(_.content),v.append(n,_.content)),_?.tool_calls&&_.tool_calls.forEach(C=>{let Re=r.get(C.index)??{id:C.id,name:C.function?.name,args:""};Re.args+=C.function?.arguments||"",r.set(C.index,Re)})}catch{console.debug("Failed to parse SSE data:",f)}}}let l=Array.from(r.entries()).sort((p,c)=>p[0]-c[0]).map(([p,c])=>({type:"tool_use",id:c.id,name:c.name,input:JSON.parse(c.args||"{}")}));return{blocks:[...n,...l],stop_reason:l.length?"tool_use":"end"}}parseOneShot(e){let t=e.choices?.[0],o=[];return t?.finish_reason==="tool_calls"&&t?.message?.tool_calls?t.message.tool_calls.forEach(s=>o.push({type:"tool_use",id:s.id,name:s.function?.name,input:JSON.parse(s.function?.arguments||"{}")})):t?.message?.content&&o.push({type:"text",text:t.message.content}),{blocks:o,stop_reason:t?.finish_reason==="tool_calls"?"tool_use":"end"}}};var j=class{createChatService(e){let t=e.visionModel||e.model||this.getDefaultModel();if(e.visionModel&&!this.supportsVisionForModel(e.visionModel))throw new Error(`Model ${e.visionModel} does not support vision capabilities.`);let o=e.tools,s=e.appName,n=e.appUrl;return new B(e.apiKey,e.model||this.getDefaultModel(),t,o,e.endpoint,e.responseLength,s,n,e.reasoning_effort,e.includeReasoning,e.reasoningMaxTokens)}getProviderName(){return"openrouter"}getSupportedModels(){return[P]}getDefaultModel(){return P}supportsVision(){return!1}supportsVisionForModel(e){return N(e)}getFreeModels(){return J}isModelFree(e){return J.includes(e)||e.endsWith(":free")}};var x=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():[]}};x.providers=new Map;x.registerProvider(new k);x.registerProvider(new G);x.registerProvider(new F);x.registerProvider(new j);var Ke=["happy","sad","angry","surprised","neutral"],Ne=/\[([a-z]+)\]/i,be=/\[[a-z]+\]\s*/gi,H=class{static extractEmotion(e){let t=e.match(Ne);if(t){let o=t[1].toLowerCase(),s=e.replace(be,"").trim();return{emotion:o,cleanText:s}}return{cleanText:e}}static isValidEmotion(e){return Ke.includes(e)}static cleanEmotionTags(e){return e.replace(be,"").trim()}static addEmotionTag(e,t){return`[${e}] ${t}`}};function Ae(d){let{emotion:e,cleanText:t}=H.extractEmotion(d);return e?{emotion:e,text:t}:{text:t}}function Je(d){return d.map(e=>Ae(e))}function Ye(d){return d.emotion?H.addEmotionTag(d.emotion,d.text):d.text}async function Xe(d,e){let{blocks:t}=await d.chatOnce(e,!1,()=>{});return v.getFullText(t)}function ke(){y.setFetch(async(d,e={})=>{let t=(e.method||"GET").toString().toUpperCase(),o=e.headers,s={};if(Array.isArray(o))for(let[c,h]of o)s[c]=String(h);else if(o&&typeof o=="object")for(let[c,h]of Object.entries(o))s[c]=String(h);let n={method:t,headers:s,muteHttpExceptions:!0},r=e.body;typeof r=="string"?n.payload=r:r!=null&&(s["Content-Type"]||(s["Content-Type"]="application/json"),n.payload=JSON.stringify(r));let i=UrlFetchApp.fetch(d,n),l=i.getResponseCode(),u=i.getContentText();return{ok:l>=200&&l<300,status:l,statusText:String(l),text:async()=>u,json:async()=>u?JSON.parse(u):null}})}return je(Qe);})();
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@aituber-onair/chat",
3
- "version": "0.7.0",
3
+ "version": "0.8.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",