@aituber-onair/chat 0.40.0 → 0.42.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.
Files changed (87) hide show
  1. package/README.ja.md +37 -2
  2. package/README.md +39 -2
  3. package/dist/cjs/constants/index.d.ts +2 -0
  4. package/dist/cjs/constants/index.d.ts.map +1 -1
  5. package/dist/cjs/constants/index.js +2 -0
  6. package/dist/cjs/constants/index.js.map +1 -1
  7. package/dist/cjs/constants/plamo.d.ts +7 -0
  8. package/dist/cjs/constants/plamo.d.ts.map +1 -0
  9. package/dist/cjs/constants/plamo.js +12 -0
  10. package/dist/cjs/constants/plamo.js.map +1 -0
  11. package/dist/cjs/constants/sakana.d.ts +7 -0
  12. package/dist/cjs/constants/sakana.d.ts.map +1 -0
  13. package/dist/cjs/constants/sakana.js +14 -0
  14. package/dist/cjs/constants/sakana.js.map +1 -0
  15. package/dist/cjs/index.d.ts +5 -1
  16. package/dist/cjs/index.d.ts.map +1 -1
  17. package/dist/cjs/index.js +11 -1
  18. package/dist/cjs/index.js.map +1 -1
  19. package/dist/cjs/services/providers/ChatServiceProvider.d.ts +9 -1
  20. package/dist/cjs/services/providers/ChatServiceProvider.d.ts.map +1 -1
  21. package/dist/cjs/services/providers/index.d.ts +3 -1
  22. package/dist/cjs/services/providers/index.d.ts.map +1 -1
  23. package/dist/cjs/services/providers/index.js +4 -0
  24. package/dist/cjs/services/providers/index.js.map +1 -1
  25. package/dist/cjs/services/providers/openai/openaiRequestBuilder.d.ts.map +1 -1
  26. package/dist/cjs/services/providers/openai/openaiRequestBuilder.js +8 -0
  27. package/dist/cjs/services/providers/openai/openaiRequestBuilder.js.map +1 -1
  28. package/dist/cjs/services/providers/plamo/PlamoChatService.d.ts +8 -0
  29. package/dist/cjs/services/providers/plamo/PlamoChatService.d.ts.map +1 -0
  30. package/dist/cjs/services/providers/plamo/PlamoChatService.js +12 -0
  31. package/dist/cjs/services/providers/plamo/PlamoChatService.js.map +1 -0
  32. package/dist/cjs/services/providers/plamo/PlamoChatServiceProvider.d.ts +16 -0
  33. package/dist/cjs/services/providers/plamo/PlamoChatServiceProvider.d.ts.map +1 -0
  34. package/dist/cjs/services/providers/plamo/PlamoChatServiceProvider.js +57 -0
  35. package/dist/cjs/services/providers/plamo/PlamoChatServiceProvider.js.map +1 -0
  36. package/dist/cjs/services/providers/sakana/SakanaChatService.d.ts +7 -0
  37. package/dist/cjs/services/providers/sakana/SakanaChatService.d.ts.map +1 -0
  38. package/dist/cjs/services/providers/sakana/SakanaChatService.js +12 -0
  39. package/dist/cjs/services/providers/sakana/SakanaChatService.js.map +1 -0
  40. package/dist/cjs/services/providers/sakana/SakanaChatServiceProvider.d.ts +16 -0
  41. package/dist/cjs/services/providers/sakana/SakanaChatServiceProvider.d.ts.map +1 -0
  42. package/dist/cjs/services/providers/sakana/SakanaChatServiceProvider.js +57 -0
  43. package/dist/cjs/services/providers/sakana/SakanaChatServiceProvider.js.map +1 -0
  44. package/dist/esm/constants/index.d.ts +2 -0
  45. package/dist/esm/constants/index.d.ts.map +1 -1
  46. package/dist/esm/constants/index.js +2 -0
  47. package/dist/esm/constants/index.js.map +1 -1
  48. package/dist/esm/constants/plamo.d.ts +7 -0
  49. package/dist/esm/constants/plamo.d.ts.map +1 -0
  50. package/dist/esm/constants/plamo.js +9 -0
  51. package/dist/esm/constants/plamo.js.map +1 -0
  52. package/dist/esm/constants/sakana.d.ts +7 -0
  53. package/dist/esm/constants/sakana.d.ts.map +1 -0
  54. package/dist/esm/constants/sakana.js +11 -0
  55. package/dist/esm/constants/sakana.js.map +1 -0
  56. package/dist/esm/index.d.ts +5 -1
  57. package/dist/esm/index.d.ts.map +1 -1
  58. package/dist/esm/index.js +6 -0
  59. package/dist/esm/index.js.map +1 -1
  60. package/dist/esm/services/providers/ChatServiceProvider.d.ts +9 -1
  61. package/dist/esm/services/providers/ChatServiceProvider.d.ts.map +1 -1
  62. package/dist/esm/services/providers/index.d.ts +3 -1
  63. package/dist/esm/services/providers/index.d.ts.map +1 -1
  64. package/dist/esm/services/providers/index.js +4 -0
  65. package/dist/esm/services/providers/index.js.map +1 -1
  66. package/dist/esm/services/providers/openai/openaiRequestBuilder.d.ts.map +1 -1
  67. package/dist/esm/services/providers/openai/openaiRequestBuilder.js +8 -0
  68. package/dist/esm/services/providers/openai/openaiRequestBuilder.js.map +1 -1
  69. package/dist/esm/services/providers/plamo/PlamoChatService.d.ts +8 -0
  70. package/dist/esm/services/providers/plamo/PlamoChatService.d.ts.map +1 -0
  71. package/dist/esm/services/providers/plamo/PlamoChatService.js +8 -0
  72. package/dist/esm/services/providers/plamo/PlamoChatService.js.map +1 -0
  73. package/dist/esm/services/providers/plamo/PlamoChatServiceProvider.d.ts +16 -0
  74. package/dist/esm/services/providers/plamo/PlamoChatServiceProvider.d.ts.map +1 -0
  75. package/dist/esm/services/providers/plamo/PlamoChatServiceProvider.js +53 -0
  76. package/dist/esm/services/providers/plamo/PlamoChatServiceProvider.js.map +1 -0
  77. package/dist/esm/services/providers/sakana/SakanaChatService.d.ts +7 -0
  78. package/dist/esm/services/providers/sakana/SakanaChatService.d.ts.map +1 -0
  79. package/dist/esm/services/providers/sakana/SakanaChatService.js +8 -0
  80. package/dist/esm/services/providers/sakana/SakanaChatService.js.map +1 -0
  81. package/dist/esm/services/providers/sakana/SakanaChatServiceProvider.d.ts +16 -0
  82. package/dist/esm/services/providers/sakana/SakanaChatServiceProvider.d.ts.map +1 -0
  83. package/dist/esm/services/providers/sakana/SakanaChatServiceProvider.js +53 -0
  84. package/dist/esm/services/providers/sakana/SakanaChatServiceProvider.js.map +1 -0
  85. package/dist/umd/aituber-onair-chat.js +205 -2
  86. package/dist/umd/aituber-onair-chat.min.js +10 -10
  87. package/package.json +1 -1
@@ -1,4 +1,4 @@
1
- "use strict";var AITuberOnAirChat=(()=>{var Jt=Object.defineProperty;var Ii=Object.getOwnPropertyDescriptor;var xi=Object.getOwnPropertyNames;var Di=Object.prototype.hasOwnProperty;var Ai=(i,e)=>{for(var t in e)Jt(i,t,{get:e[t],enumerable:!0})},Ri=(i,e,t,o)=>{if(e&&typeof e=="object"||typeof e=="function")for(let r of xi(e))!Di.call(i,r)&&r!==t&&Jt(i,r,{get:()=>e[r],enumerable:!(o=Ii(e,r))||o.enumerable});return i};var bi=i=>Ri(Jt({},"__esModule",{value:!0}),i);var Mr={};Ai(Mr,{CHAT_RESPONSE_LENGTH:()=>C,CLAUDE_VISION_SUPPORTED_MODELS:()=>ke,ChatServiceFactory:()=>Ae,ChatServiceHttpClient:()=>f,ClaudeChatService:()=>ue,ClaudeChatServiceProvider:()=>he,DEEPSEEK_API_BASE_URL:()=>Xo,DEEPSEEK_DEPRECATED_MODELS:()=>Ui,DEEPSEEK_SUPPORTED_MODELS:()=>Mo,DEFAULT_MAX_TOKENS:()=>Lo,DEFAULT_SUMMARY_PROMPT_TEMPLATE:()=>Ki,DEFAULT_VISION_PROMPT:()=>Hi,DeepSeekChatService:()=>me,DeepSeekChatServiceProvider:()=>de,EMOTION_TAG_CLEANUP_REGEX:()=>xo,EMOTION_TAG_REGEX:()=>ii,ENDPOINT_CLAUDE_API:()=>oo,ENDPOINT_DEEPSEEK_CHAT_COMPLETIONS_API:()=>Be,ENDPOINT_GEMINI_API:()=>to,ENDPOINT_KIMI_CHAT_COMPLETIONS_API:()=>ae,ENDPOINT_MISTRAL_CHAT_COMPLETIONS_API:()=>$e,ENDPOINT_OPENAI_CHAT_COMPLETIONS_API:()=>U,ENDPOINT_OPENAI_RESPONSES_API:()=>A,ENDPOINT_OPENROUTER_API:()=>Ge,ENDPOINT_XAI_CHAT_COMPLETIONS_API:()=>Ue,ENDPOINT_ZAI_CHAT_COMPLETIONS_API:()=>Fe,EmotionParser:()=>ce,GEMINI_DEPRECATED_MODELS:()=>Bo,GEMINI_NANO_MAX_CONTEXT_MESSAGES:()=>Io,GEMINI_RECOMMENDED_MODELS:()=>et,GEMINI_VISION_SUPPORTED_MODELS:()=>Ve,GPT5_PRESETS:()=>Po,GPT_5_MODELS:()=>bo,GeminiChatService:()=>ge,GeminiChatServiceProvider:()=>_e,GeminiNanoChatService:()=>fe,GeminiNanoChatServiceProvider:()=>Me,HttpError:()=>F,KIMI_THINKING_REQUIRED_MODELS:()=>Jo,KIMI_VISION_SUPPORTED_MODELS:()=>qo,KimiChatService:()=>ve,KimiChatServiceProvider:()=>Ee,MAX_TOKENS_BY_LENGTH:()=>Bt,MISTRAL_API_BASE_URL:()=>ei,MISTRAL_REASONING_EFFORT_SUPPORTED_MODELS:()=>ti,MISTRAL_SUPPORTED_MODELS:()=>Co,MISTRAL_VISION_SUPPORTED_MODELS:()=>oi,MODEL_ANTHROPIC_CLAUDE_3_5_SONNET:()=>no,MODEL_ANTHROPIC_CLAUDE_3_7_SONNET:()=>It,MODEL_ANTHROPIC_CLAUDE_4_5_HAIKU:()=>xt,MODEL_ANTHROPIC_CLAUDE_HAIKU_LATEST:()=>yt,MODEL_ANTHROPIC_CLAUDE_OPUS_4:()=>Lt,MODEL_ANTHROPIC_CLAUDE_SONNET_4:()=>Pt,MODEL_ANTHROPIC_CLAUDE_SONNET_LATEST:()=>Tt,MODEL_CLAUDE_3_5_HAIKU:()=>Ni,MODEL_CLAUDE_3_5_SONNET:()=>wi,MODEL_CLAUDE_3_7_SONNET:()=>Vi,MODEL_CLAUDE_3_HAIKU:()=>tt,MODEL_CLAUDE_4_5_HAIKU:()=>R,MODEL_CLAUDE_4_5_OPUS:()=>nt,MODEL_CLAUDE_4_5_SONNET:()=>rt,MODEL_CLAUDE_4_6_OPUS:()=>at,MODEL_CLAUDE_4_6_SONNET:()=>st,MODEL_CLAUDE_4_7_OPUS:()=>lt,MODEL_CLAUDE_4_8_OPUS:()=>pt,MODEL_CLAUDE_4_OPUS:()=>it,MODEL_CLAUDE_4_SONNET:()=>ot,MODEL_DEEPSEEK_CHAT:()=>Yo,MODEL_DEEPSEEK_REASONER:()=>Qo,MODEL_DEEPSEEK_V4_FLASH:()=>pe,MODEL_DEEPSEEK_V4_PRO:()=>Zo,MODEL_GEMINI_2_5_FLASH:()=>Ho,MODEL_GEMINI_2_5_FLASH_LITE:()=>Ko,MODEL_GEMINI_2_5_FLASH_LITE_PREVIEW_06_17:()=>Wo,MODEL_GEMINI_2_5_PRO:()=>Uo,MODEL_GEMINI_3_1_FLASH_LITE:()=>q,MODEL_GEMINI_3_1_FLASH_LITE_PREVIEW:()=>ko,MODEL_GEMINI_3_1_PRO_PREVIEW:()=>Vo,MODEL_GEMINI_3_5_FLASH:()=>Qe,MODEL_GEMINI_3_FLASH_PREVIEW:()=>Fo,MODEL_GEMINI_3_PRO_PREVIEW:()=>Go,MODEL_GEMINI_NANO:()=>Z,MODEL_GEMMA_4_26B_A4B_IT:()=>wo,MODEL_GEMMA_4_31B_IT:()=>No,MODEL_GLM_4_6:()=>_o,MODEL_GLM_4_6V:()=>Vt,MODEL_GLM_4_6V_FLASH:()=>X,MODEL_GLM_4_6V_FLASHX:()=>kt,MODEL_GLM_4_7:()=>ho,MODEL_GLM_4_7_FLASH:()=>go,MODEL_GLM_4_7_FLASHX:()=>mo,MODEL_GLM_5:()=>co,MODEL_GLM_5_2:()=>re,MODEL_GLM_5_TURBO:()=>uo,MODEL_GOOGLE_GEMINI_2_5_FLASH:()=>bt,MODEL_GOOGLE_GEMINI_2_5_FLASH_LITE_PREVIEW_09_2025:()=>Nt,MODEL_GOOGLE_GEMINI_2_5_PRO:()=>Rt,MODEL_GOOGLE_GEMINI_FLASH_LATEST:()=>At,MODEL_GOOGLE_GEMINI_PRO_LATEST:()=>Dt,MODEL_GPT_4O:()=>Ze,MODEL_GPT_4O_MINI:()=>z,MODEL_GPT_4_1:()=>qe,MODEL_GPT_4_1_MINI:()=>Je,MODEL_GPT_4_1_NANO:()=>Xe,MODEL_GPT_5:()=>ee,MODEL_GPT_5_1:()=>te,MODEL_GPT_5_4:()=>K,MODEL_GPT_5_4_MINI:()=>B,MODEL_GPT_5_4_NANO:()=>$,MODEL_GPT_5_4_PRO:()=>G,MODEL_GPT_5_5:()=>W,MODEL_GPT_5_MINI:()=>Q,MODEL_GPT_5_NANO:()=>H,MODEL_GPT_OSS_20B_FREE:()=>b,MODEL_GROK_4_1_FAST_NON_REASONING:()=>N,MODEL_GROK_4_1_FAST_REASONING:()=>Ht,MODEL_GROK_4_20_NON_REASONING:()=>Ut,MODEL_GROK_4_20_REASONING:()=>Ft,MODEL_GROK_4_3:()=>Gt,MODEL_KIMI_K2_5:()=>Kt,MODEL_KIMI_K2_6:()=>w,MODEL_KIMI_K2_7_CODE:()=>He,MODEL_KIMI_K2_7_CODE_HIGHSPEED:()=>Ke,MODEL_MISTRAL_LARGE_2512:()=>So,MODEL_MISTRAL_LARGE_LATEST:()=>Oo,MODEL_MISTRAL_MEDIUM_2508:()=>Eo,MODEL_MISTRAL_MEDIUM_3_5:()=>Wt,MODEL_MISTRAL_SMALL_2603:()=>vo,MODEL_MISTRAL_SMALL_LATEST:()=>V,MODEL_MOONSHOTAI_KIMI_K2_5:()=>ut,MODEL_MOONSHOTAI_KIMI_K2_7_CODE:()=>ct,MODEL_MOONSHOTAI_KIMI_LATEST:()=>ht,MODEL_O1:()=>Yt,MODEL_O1_MINI:()=>Zt,MODEL_O3_MINI:()=>Xt,MODEL_OPENAI_GPT_4O:()=>Ot,MODEL_OPENAI_GPT_4_1_MINI:()=>St,MODEL_OPENAI_GPT_4_1_NANO:()=>Ct,MODEL_OPENAI_GPT_5_1_CHAT:()=>ft,MODEL_OPENAI_GPT_5_1_CODEX:()=>Mt,MODEL_OPENAI_GPT_5_5:()=>_t,MODEL_OPENAI_GPT_5_5_PRO:()=>gt,MODEL_OPENAI_GPT_5_MINI:()=>vt,MODEL_OPENAI_GPT_5_NANO:()=>Et,MODEL_OPENAI_GPT_LATEST:()=>mt,MODEL_OPENAI_GPT_MINI_LATEST:()=>dt,MODEL_OPENROUTER_AUTO:()=>io,MODEL_OPENROUTER_FUSION:()=>ro,MODEL_ZAI_GLM_4_5_AIR:()=>ao,MODEL_ZAI_GLM_4_5_AIR_FREE:()=>wt,MODEL_ZAI_GLM_4_7_FLASH:()=>so,MODEL_ZAI_GLM_5_2:()=>oe,MistralChatService:()=>Oe,MistralChatServiceProvider:()=>Se,OPENROUTER_CREDITS_THRESHOLD:()=>Fi,OPENROUTER_FREE_DAILY_LIMIT_HIGH_CREDITS:()=>Gi,OPENROUTER_FREE_DAILY_LIMIT_LOW_CREDITS:()=>ki,OPENROUTER_FREE_MODELS:()=>lo,OPENROUTER_FREE_RATE_LIMIT_PER_MINUTE:()=>po,OPENROUTER_VISION_SUPPORTED_MODELS:()=>$o,OpenAIChatService:()=>y,OpenAIChatServiceProvider:()=>Te,OpenAICompatibleChatServiceProvider:()=>Ce,OpenRouterChatService:()=>ye,OpenRouterChatServiceProvider:()=>Le,StreamTextAccumulator:()=>v,VISION_SUPPORTED_MODELS:()=>Re,XAIChatService:()=>Pe,XAIChatServiceProvider:()=>Ie,XAI_VISION_SUPPORTED_MODELS:()=>jo,ZAIChatService:()=>xe,ZAIChatServiceProvider:()=>De,ZAI_VISION_SUPPORTED_MODELS:()=>zo,allowsReasoningLow:()=>Ye,allowsReasoningMinimal:()=>Ne,allowsReasoningNone:()=>be,allowsReasoningXHigh:()=>eo,buildOpenAICompatibleTools:()=>x,getDefaultReasoningEffortForGPT5Model:()=>we,getMaxTokensForResponseLength:()=>O,installGASFetch:()=>Li,isGPT5Model:()=>j,isKimiThinkingRequiredModel:()=>We,isKimiVisionModel:()=>le,isMistralReasoningEffort:()=>To,isMistralReasoningEffortModel:()=>ze,isMistralVisionModel:()=>yo,isOpenRouterFreeModel:()=>J,isOpenRouterVisionModel:()=>ie,isResponsesOnlyGPT5Model:()=>Qt,isXaiVisionModel:()=>se,isZaiToolStreamModel:()=>fo,isZaiVisionModel:()=>ne,parseOpenAICompatibleOneShot:()=>I,parseOpenAICompatibleTextStream:()=>L,parseOpenAICompatibleToolStream:()=>P,processChatWithOptionalTools:()=>M,refreshOpenRouterFreeModels:()=>or,resolveVisionModel:()=>E,runOnceText:()=>zi,safeJsonParse:()=>ni,safeParseToolCallInput:()=>Y,screenplayToText:()=>$i,textToScreenplay:()=>ri,textsToScreenplay:()=>Bi});var U="https://api.openai.com/v1/chat/completions",A="https://api.openai.com/v1/responses",H="gpt-5-nano",Q="gpt-5-mini",ee="gpt-5",te="gpt-5.1",K="gpt-5.4",W="gpt-5.5",B="gpt-5.4-mini",$="gpt-5.4-nano",G="gpt-5.4-pro",qe="gpt-4.1",Je="gpt-4.1-mini",Xe="gpt-4.1-nano",z="gpt-4o-mini",Ze="gpt-4o",Xt="o3-mini",Zt="o1-mini",Yt="o1",Re=[H,Q,ee,te,K,W,B,$,G,qe,Je,Xe,z,Ze,"o1"],bo=[H,Q,ee,te,K,W,B,$,G];function j(i){return bo.includes(i)}function Qt(i){return i===G}function eo(i){return i===W||i===K||i===B||i===$||i===G}function be(i){return i===te||i===K||i===W||i===B||i===$}function Ne(i){return i===H||i===Q||i===ee}function Ye(i){return i!==G}function we(i){return be(i)?"none":Ne(i)?"minimal":"medium"}var to="https://generativelanguage.googleapis.com",No="gemma-4-31b-it",wo="gemma-4-26b-a4b-it",Qe="gemini-3.5-flash",Vo="gemini-3.1-pro-preview",q="gemini-3.1-flash-lite",ko="gemini-3.1-flash-lite-preview",Go="gemini-3-pro-preview",Fo="gemini-3-flash-preview",Uo="gemini-2.5-pro",Ho="gemini-2.5-flash",Ko="gemini-2.5-flash-lite",Wo="gemini-2.5-flash-lite-preview-06-17",et=[Qe,q,Vo,Fo,Uo,Ho,Ko,No,wo],Bo=[ko,Go,Wo],Ve=[...et,...Bo];var oo="https://api.anthropic.com/v1/messages",tt="claude-3-haiku-20240307",Ni="claude-3-5-haiku-20241022",wi="claude-3-5-sonnet-20241022",Vi="claude-3-7-sonnet-20250219",ot="claude-sonnet-4-20250514",it="claude-opus-4-20250514",rt="claude-sonnet-4-5-20250929",R="claude-haiku-4-5-20251001",nt="claude-opus-4-5-20251101",st="claude-sonnet-4-6",at="claude-opus-4-6",lt="claude-opus-4-7",pt="claude-opus-4-8",ke=[tt,ot,it,rt,R,nt,st,at,lt,pt];var Ge="https://openrouter.ai/api/v1/chat/completions",io="openrouter/auto",ro="openrouter/fusion",b="openai/gpt-oss-20b:free",ct="moonshotai/kimi-k2.7-code",ut="moonshotai/kimi-k2.5",ht="~moonshotai/kimi-latest",mt="~openai/gpt-latest",dt="~openai/gpt-mini-latest",gt="openai/gpt-5.5-pro",_t="openai/gpt-5.5",ft="openai/gpt-5.1-chat",Mt="openai/gpt-5.1-codex",vt="openai/gpt-5-mini",Et="openai/gpt-5-nano",Ot="openai/gpt-4o",St="openai/gpt-4.1-mini",Ct="openai/gpt-4.1-nano",Tt="~anthropic/claude-sonnet-latest",yt="~anthropic/claude-haiku-latest",Lt="anthropic/claude-opus-4",Pt="anthropic/claude-sonnet-4",It="anthropic/claude-3.7-sonnet",no="anthropic/claude-3.5-sonnet",xt="anthropic/claude-haiku-4.5",Dt="~google/gemini-pro-latest",At="~google/gemini-flash-latest",Rt="google/gemini-2.5-pro",bt="google/gemini-2.5-flash",Nt="google/gemini-2.5-flash-lite-preview-09-2025",oe="z-ai/glm-5.2",so="z-ai/glm-4.7-flash",ao="z-ai/glm-4.5-air",wt="z-ai/glm-4.5-air:free",lo=[b,wt],$o=[ht,mt,dt,gt,_t,ft,Mt,vt,Et,Ot,St,Ct,Tt,yt,Lt,Pt,It,xt,Dt,At,Rt,bt,Nt,ct,ut],po=20,ki=50,Gi=1e3,Fi=10;function J(i){return i.trim().endsWith(":free")}function ie(i){return $o.some(e=>i.includes(e))}var Fe="https://api.z.ai/api/paas/v4/chat/completions",re="glm-5.2",co="glm-5",uo="glm-5-turbo",ho="glm-4.7",mo="glm-4.7-FlashX",go="glm-4.7-Flash",_o="glm-4.6",Vt="glm-4.6V",kt="glm-4.6V-FlashX",X="glm-4.6V-Flash",zo=[Vt,kt,X];function ne(i){return zo.includes(i)}function fo(i){return i.toLowerCase().startsWith("glm-4.6")}var Ue="https://api.x.ai/v1/chat/completions",Gt="grok-4.3",Ft="grok-4.20-0309-reasoning",Ut="grok-4.20-0309-non-reasoning",Ht="grok-4-1-fast-reasoning",N="grok-4-1-fast-non-reasoning",jo=[Gt,Ft,Ut,Ht,N];function se(i){return jo.includes(i)}var ae="https://api.moonshot.ai/v1/chat/completions",He="kimi-k2.7-code",Ke="kimi-k2.7-code-highspeed",w="kimi-k2.6",Kt="kimi-k2.5",qo=[He,Ke,w,Kt],Jo=[He,Ke];function le(i){return qo.includes(i)}function We(i){return Jo.includes(i)}var Xo="https://api.deepseek.com",Be=`${Xo}/chat/completions`,pe="deepseek-v4-flash",Zo="deepseek-v4-pro",Yo="deepseek-chat",Qo="deepseek-reasoner",Mo=[pe,Zo],Ui=[Yo,Qo];var ei="https://api.mistral.ai/v1",$e=`${ei}/chat/completions`,V="mistral-small-latest",vo="mistral-small-2603",Wt="mistral-medium-3-5",Eo="mistral-medium-2508",Oo="mistral-large-latest",So="mistral-large-2512",Co=[V,Wt,Oo,So,vo,Eo],ti=[V,Wt],oi=[V,vo,Wt,Eo,Oo,So];function ze(i){return ti.includes(i)}function To(i){return i==="none"||i==="high"}function yo(i){return oi.includes(i)}var C={VERY_SHORT:"veryShort",SHORT:"short",MEDIUM:"medium",LONG:"long",VERY_LONG:"veryLong",DEEP:"deep"},Bt={[C.VERY_SHORT]:40,[C.SHORT]:100,[C.MEDIUM]:200,[C.LONG]:300,[C.VERY_LONG]:1e3,[C.DEEP]:5e3},Lo=5e3,Po={casual:{reasoning_effort:"minimal",verbosity:"low",description:"Fast responses for casual chat, quick questions (GPT-4 like experience)"},balanced:{reasoning_effort:"medium",verbosity:"medium",description:"Balanced reasoning for business tasks, learning, general problem solving"},expert:{reasoning_effort:"high",verbosity:"high",description:"Deep reasoning for research, complex analysis, expert-level tasks"}};function O(i){return i?Bt[i]??Lo:Lo}var Hi="You are a friendly AI avatar. Comment on the situation based on the broadcast screen.",Ki=`You are a skilled summarizing assistant.
1
+ "use strict";var AITuberOnAirChat=(()=>{var ro=Object.defineProperty;var Wr=Object.getOwnPropertyDescriptor;var Br=Object.getOwnPropertyNames;var $r=Object.prototype.hasOwnProperty;var zr=(r,e)=>{for(var t in e)ro(r,t,{get:e[t],enumerable:!0})},qr=(r,e,t,o)=>{if(e&&typeof e=="object"||typeof e=="function")for(let i of Br(e))!$r.call(r,i)&&i!==t&&ro(r,i,{get:()=>e[i],enumerable:!(o=Wr(e,i))||o.enumerable});return r};var jr=r=>qr(ro({},"__esModule",{value:!0}),r);var bi={};zr(bi,{CHAT_RESPONSE_LENGTH:()=>T,CLAUDE_VISION_SUPPORTED_MODELS:()=>We,ChatServiceFactory:()=>ke,ChatServiceHttpClient:()=>f,ClaudeChatService:()=>me,ClaudeChatServiceProvider:()=>de,DEEPSEEK_API_BASE_URL:()=>sr,DEEPSEEK_DEPRECATED_MODELS:()=>ti,DEEPSEEK_SUPPORTED_MODELS:()=>Po,DEFAULT_MAX_TOKENS:()=>Vo,DEFAULT_SUMMARY_PROMPT_TEMPLATE:()=>ri,DEFAULT_VISION_PROMPT:()=>oi,DeepSeekChatService:()=>ge,DeepSeekChatServiceProvider:()=>_e,EMOTION_TAG_CLEANUP_REGEX:()=>Fo,EMOTION_TAG_REGEX:()=>Mr,ENDPOINT_CLAUDE_API:()=>co,ENDPOINT_DEEPSEEK_CHAT_COMPLETIONS_API:()=>Xe,ENDPOINT_GEMINI_API:()=>po,ENDPOINT_KIMI_CHAT_COMPLETIONS_API:()=>ae,ENDPOINT_MISTRAL_CHAT_COMPLETIONS_API:()=>Ze,ENDPOINT_OPENAI_CHAT_COMPLETIONS_API:()=>U,ENDPOINT_OPENAI_RESPONSES_API:()=>A,ENDPOINT_OPENROUTER_API:()=>Be,ENDPOINT_PLAMO_CHAT_COMPLETIONS_API:()=>et,ENDPOINT_SAKANA_CHAT_COMPLETIONS_API:()=>Qe,ENDPOINT_XAI_CHAT_COMPLETIONS_API:()=>ze,ENDPOINT_ZAI_CHAT_COMPLETIONS_API:()=>$e,EmotionParser:()=>he,GEMINI_DEPRECATED_MODELS:()=>er,GEMINI_NANO_MAX_CONTEXT_MESSAGES:()=>Go,GEMINI_RECOMMENDED_MODELS:()=>lt,GEMINI_VISION_SUPPORTED_MODELS:()=>He,GPT5_PRESETS:()=>ko,GPT_5_MODELS:()=>Wo,GeminiChatService:()=>fe,GeminiChatServiceProvider:()=>Me,GeminiNanoChatService:()=>ve,GeminiNanoChatServiceProvider:()=>Oe,HttpError:()=>F,KIMI_THINKING_REQUIRED_MODELS:()=>nr,KIMI_VISION_SUPPORTED_MODELS:()=>ir,KimiChatService:()=>Ee,KimiChatServiceProvider:()=>Se,MAX_TOKENS_BY_LENGTH:()=>Yt,MISTRAL_API_BASE_URL:()=>cr,MISTRAL_REASONING_EFFORT_SUPPORTED_MODELS:()=>ur,MISTRAL_SUPPORTED_MODELS:()=>Ao,MISTRAL_VISION_SUPPORTED_MODELS:()=>hr,MODEL_ANTHROPIC_CLAUDE_3_5_SONNET:()=>mo,MODEL_ANTHROPIC_CLAUDE_3_7_SONNET:()=>Vt,MODEL_ANTHROPIC_CLAUDE_4_5_HAIKU:()=>kt,MODEL_ANTHROPIC_CLAUDE_HAIKU_LATEST:()=>bt,MODEL_ANTHROPIC_CLAUDE_OPUS_4:()=>Nt,MODEL_ANTHROPIC_CLAUDE_SONNET_4:()=>wt,MODEL_ANTHROPIC_CLAUDE_SONNET_LATEST:()=>Rt,MODEL_CLAUDE_3_5_HAIKU:()=>Jr,MODEL_CLAUDE_3_5_SONNET:()=>Xr,MODEL_CLAUDE_3_7_SONNET:()=>Zr,MODEL_CLAUDE_3_HAIKU:()=>pt,MODEL_CLAUDE_4_5_HAIKU:()=>R,MODEL_CLAUDE_4_5_OPUS:()=>mt,MODEL_CLAUDE_4_5_SONNET:()=>ht,MODEL_CLAUDE_4_6_OPUS:()=>gt,MODEL_CLAUDE_4_6_SONNET:()=>dt,MODEL_CLAUDE_4_7_OPUS:()=>_t,MODEL_CLAUDE_4_8_OPUS:()=>ft,MODEL_CLAUDE_4_OPUS:()=>ut,MODEL_CLAUDE_4_SONNET:()=>ct,MODEL_DEEPSEEK_CHAT:()=>lr,MODEL_DEEPSEEK_REASONER:()=>pr,MODEL_DEEPSEEK_V4_FLASH:()=>pe,MODEL_DEEPSEEK_V4_PRO:()=>ar,MODEL_FUGU:()=>ce,MODEL_FUGU_ULTRA:()=>dr,MODEL_FUGU_ULTRA_20260615:()=>gr,MODEL_GEMINI_2_5_FLASH:()=>Zo,MODEL_GEMINI_2_5_FLASH_LITE:()=>Yo,MODEL_GEMINI_2_5_FLASH_LITE_PREVIEW_06_17:()=>Qo,MODEL_GEMINI_2_5_PRO:()=>Xo,MODEL_GEMINI_3_1_FLASH_LITE:()=>j,MODEL_GEMINI_3_1_FLASH_LITE_PREVIEW:()=>qo,MODEL_GEMINI_3_1_PRO_PREVIEW:()=>zo,MODEL_GEMINI_3_5_FLASH:()=>at,MODEL_GEMINI_3_FLASH_PREVIEW:()=>Jo,MODEL_GEMINI_3_PRO_PREVIEW:()=>jo,MODEL_GEMINI_NANO:()=>Z,MODEL_GEMMA_4_26B_A4B_IT:()=>$o,MODEL_GEMMA_4_31B_IT:()=>Bo,MODEL_GLM_4_6:()=>To,MODEL_GLM_4_6V:()=>Bt,MODEL_GLM_4_6V_FLASH:()=>X,MODEL_GLM_4_6V_FLASHX:()=>$t,MODEL_GLM_4_7:()=>Eo,MODEL_GLM_4_7_FLASH:()=>Co,MODEL_GLM_4_7_FLASHX:()=>So,MODEL_GLM_5:()=>vo,MODEL_GLM_5_2:()=>ie,MODEL_GLM_5_TURBO:()=>Oo,MODEL_GOOGLE_GEMINI_2_5_FLASH:()=>Kt,MODEL_GOOGLE_GEMINI_2_5_FLASH_LITE_PREVIEW_09_2025:()=>Ht,MODEL_GOOGLE_GEMINI_2_5_PRO:()=>Ut,MODEL_GOOGLE_GEMINI_FLASH_LATEST:()=>Ft,MODEL_GOOGLE_GEMINI_PRO_LATEST:()=>Gt,MODEL_GPT_4O:()=>nt,MODEL_GPT_4O_MINI:()=>z,MODEL_GPT_4_1:()=>ot,MODEL_GPT_4_1_MINI:()=>rt,MODEL_GPT_4_1_NANO:()=>it,MODEL_GPT_5:()=>ee,MODEL_GPT_5_1:()=>te,MODEL_GPT_5_4:()=>H,MODEL_GPT_5_4_MINI:()=>B,MODEL_GPT_5_4_NANO:()=>$,MODEL_GPT_5_4_PRO:()=>G,MODEL_GPT_5_5:()=>W,MODEL_GPT_5_MINI:()=>Q,MODEL_GPT_5_NANO:()=>K,MODEL_GPT_OSS_20B_FREE:()=>b,MODEL_GROK_4_1_FAST_NON_REASONING:()=>N,MODEL_GROK_4_1_FAST_REASONING:()=>Jt,MODEL_GROK_4_20_NON_REASONING:()=>jt,MODEL_GROK_4_20_REASONING:()=>qt,MODEL_GROK_4_3:()=>zt,MODEL_KIMI_K2_5:()=>Xt,MODEL_KIMI_K2_6:()=>w,MODEL_KIMI_K2_7_CODE:()=>qe,MODEL_KIMI_K2_7_CODE_HIGHSPEED:()=>je,MODEL_MISTRAL_LARGE_2512:()=>Do,MODEL_MISTRAL_LARGE_LATEST:()=>xo,MODEL_MISTRAL_MEDIUM_2508:()=>Io,MODEL_MISTRAL_MEDIUM_3_5:()=>Zt,MODEL_MISTRAL_SMALL_2603:()=>yo,MODEL_MISTRAL_SMALL_LATEST:()=>V,MODEL_MOONSHOTAI_KIMI_K2_5:()=>vt,MODEL_MOONSHOTAI_KIMI_K2_7_CODE:()=>Mt,MODEL_MOONSHOTAI_KIMI_LATEST:()=>Ot,MODEL_O1:()=>so,MODEL_O1_MINI:()=>no,MODEL_O3_MINI:()=>io,MODEL_OPENAI_GPT_4O:()=>xt,MODEL_OPENAI_GPT_4_1_MINI:()=>Dt,MODEL_OPENAI_GPT_4_1_NANO:()=>At,MODEL_OPENAI_GPT_5_1_CHAT:()=>Lt,MODEL_OPENAI_GPT_5_1_CODEX:()=>Pt,MODEL_OPENAI_GPT_5_5:()=>Tt,MODEL_OPENAI_GPT_5_5_PRO:()=>Ct,MODEL_OPENAI_GPT_5_MINI:()=>yt,MODEL_OPENAI_GPT_5_NANO:()=>It,MODEL_OPENAI_GPT_LATEST:()=>Et,MODEL_OPENAI_GPT_MINI_LATEST:()=>St,MODEL_OPENROUTER_AUTO:()=>uo,MODEL_OPENROUTER_FUSION:()=>ho,MODEL_PLAMO_2_2_PRIME:()=>fr,MODEL_PLAMO_3_0_PRIME:()=>ue,MODEL_ZAI_GLM_4_5_AIR:()=>_o,MODEL_ZAI_GLM_4_5_AIR_FREE:()=>Wt,MODEL_ZAI_GLM_4_7_FLASH:()=>go,MODEL_ZAI_GLM_5_2:()=>oe,MistralChatService:()=>Ce,MistralChatServiceProvider:()=>Te,OPENROUTER_CREDITS_THRESHOLD:()=>ei,OPENROUTER_FREE_DAILY_LIMIT_HIGH_CREDITS:()=>Qr,OPENROUTER_FREE_DAILY_LIMIT_LOW_CREDITS:()=>Yr,OPENROUTER_FREE_MODELS:()=>fo,OPENROUTER_FREE_RATE_LIMIT_PER_MINUTE:()=>Mo,OPENROUTER_VISION_SUPPORTED_MODELS:()=>tr,OpenAIChatService:()=>S,OpenAIChatServiceProvider:()=>Pe,OpenAICompatibleChatServiceProvider:()=>Le,OpenRouterChatService:()=>ye,OpenRouterChatServiceProvider:()=>Ie,PLAMO_API_BASE_URL:()=>_r,PLAMO_SUPPORTED_MODELS:()=>wo,PlamoChatService:()=>xe,PlamoChatServiceProvider:()=>De,SAKANA_API_BASE_URL:()=>mr,SAKANA_SUPPORTED_MODELS:()=>No,SakanaChatService:()=>Ae,SakanaChatServiceProvider:()=>Re,StreamTextAccumulator:()=>v,VISION_SUPPORTED_MODELS:()=>Ge,XAIChatService:()=>be,XAIChatServiceProvider:()=>Ne,XAI_VISION_SUPPORTED_MODELS:()=>rr,ZAIChatService:()=>we,ZAIChatServiceProvider:()=>Ve,ZAI_VISION_SUPPORTED_MODELS:()=>or,allowsReasoningLow:()=>st,allowsReasoningMinimal:()=>Ue,allowsReasoningNone:()=>Fe,allowsReasoningXHigh:()=>lo,buildOpenAICompatibleTools:()=>x,getDefaultReasoningEffortForGPT5Model:()=>Ke,getMaxTokensForResponseLength:()=>E,installGASFetch:()=>Kr,isGPT5Model:()=>q,isKimiThinkingRequiredModel:()=>Je,isKimiVisionModel:()=>le,isMistralReasoningEffort:()=>Ro,isMistralReasoningEffortModel:()=>Ye,isMistralVisionModel:()=>bo,isOpenRouterFreeModel:()=>J,isOpenRouterVisionModel:()=>re,isResponsesOnlyGPT5Model:()=>ao,isXaiVisionModel:()=>se,isZaiToolStreamModel:()=>Lo,isZaiVisionModel:()=>ne,parseOpenAICompatibleOneShot:()=>I,parseOpenAICompatibleTextStream:()=>P,parseOpenAICompatibleToolStream:()=>y,processChatWithOptionalTools:()=>M,refreshOpenRouterFreeModels:()=>fi,resolveVisionModel:()=>O,runOnceText:()=>ai,safeJsonParse:()=>Or,safeParseToolCallInput:()=>Y,screenplayToText:()=>si,textToScreenplay:()=>vr,textsToScreenplay:()=>ni});var U="https://api.openai.com/v1/chat/completions",A="https://api.openai.com/v1/responses",K="gpt-5-nano",Q="gpt-5-mini",ee="gpt-5",te="gpt-5.1",H="gpt-5.4",W="gpt-5.5",B="gpt-5.4-mini",$="gpt-5.4-nano",G="gpt-5.4-pro",ot="gpt-4.1",rt="gpt-4.1-mini",it="gpt-4.1-nano",z="gpt-4o-mini",nt="gpt-4o",io="o3-mini",no="o1-mini",so="o1",Ge=[K,Q,ee,te,H,W,B,$,G,ot,rt,it,z,nt,"o1"],Wo=[K,Q,ee,te,H,W,B,$,G];function q(r){return Wo.includes(r)}function ao(r){return r===G}function lo(r){return r===W||r===H||r===B||r===$||r===G}function Fe(r){return r===te||r===H||r===W||r===B||r===$}function Ue(r){return r===K||r===Q||r===ee}function st(r){return r!==G}function Ke(r){return Fe(r)?"none":Ue(r)?"minimal":"medium"}var po="https://generativelanguage.googleapis.com",Bo="gemma-4-31b-it",$o="gemma-4-26b-a4b-it",at="gemini-3.5-flash",zo="gemini-3.1-pro-preview",j="gemini-3.1-flash-lite",qo="gemini-3.1-flash-lite-preview",jo="gemini-3-pro-preview",Jo="gemini-3-flash-preview",Xo="gemini-2.5-pro",Zo="gemini-2.5-flash",Yo="gemini-2.5-flash-lite",Qo="gemini-2.5-flash-lite-preview-06-17",lt=[at,j,zo,Jo,Xo,Zo,Yo,Bo,$o],er=[qo,jo,Qo],He=[...lt,...er];var co="https://api.anthropic.com/v1/messages",pt="claude-3-haiku-20240307",Jr="claude-3-5-haiku-20241022",Xr="claude-3-5-sonnet-20241022",Zr="claude-3-7-sonnet-20250219",ct="claude-sonnet-4-20250514",ut="claude-opus-4-20250514",ht="claude-sonnet-4-5-20250929",R="claude-haiku-4-5-20251001",mt="claude-opus-4-5-20251101",dt="claude-sonnet-4-6",gt="claude-opus-4-6",_t="claude-opus-4-7",ft="claude-opus-4-8",We=[pt,ct,ut,ht,R,mt,dt,gt,_t,ft];var Be="https://openrouter.ai/api/v1/chat/completions",uo="openrouter/auto",ho="openrouter/fusion",b="openai/gpt-oss-20b:free",Mt="moonshotai/kimi-k2.7-code",vt="moonshotai/kimi-k2.5",Ot="~moonshotai/kimi-latest",Et="~openai/gpt-latest",St="~openai/gpt-mini-latest",Ct="openai/gpt-5.5-pro",Tt="openai/gpt-5.5",Lt="openai/gpt-5.1-chat",Pt="openai/gpt-5.1-codex",yt="openai/gpt-5-mini",It="openai/gpt-5-nano",xt="openai/gpt-4o",Dt="openai/gpt-4.1-mini",At="openai/gpt-4.1-nano",Rt="~anthropic/claude-sonnet-latest",bt="~anthropic/claude-haiku-latest",Nt="anthropic/claude-opus-4",wt="anthropic/claude-sonnet-4",Vt="anthropic/claude-3.7-sonnet",mo="anthropic/claude-3.5-sonnet",kt="anthropic/claude-haiku-4.5",Gt="~google/gemini-pro-latest",Ft="~google/gemini-flash-latest",Ut="google/gemini-2.5-pro",Kt="google/gemini-2.5-flash",Ht="google/gemini-2.5-flash-lite-preview-09-2025",oe="z-ai/glm-5.2",go="z-ai/glm-4.7-flash",_o="z-ai/glm-4.5-air",Wt="z-ai/glm-4.5-air:free",fo=[b,Wt],tr=[Ot,Et,St,Ct,Tt,Lt,Pt,yt,It,xt,Dt,At,Rt,bt,Nt,wt,Vt,kt,Gt,Ft,Ut,Kt,Ht,Mt,vt],Mo=20,Yr=50,Qr=1e3,ei=10;function J(r){return r.trim().endsWith(":free")}function re(r){return tr.some(e=>r.includes(e))}var $e="https://api.z.ai/api/paas/v4/chat/completions",ie="glm-5.2",vo="glm-5",Oo="glm-5-turbo",Eo="glm-4.7",So="glm-4.7-FlashX",Co="glm-4.7-Flash",To="glm-4.6",Bt="glm-4.6V",$t="glm-4.6V-FlashX",X="glm-4.6V-Flash",or=[Bt,$t,X];function ne(r){return or.includes(r)}function Lo(r){return r.toLowerCase().startsWith("glm-4.6")}var ze="https://api.x.ai/v1/chat/completions",zt="grok-4.3",qt="grok-4.20-0309-reasoning",jt="grok-4.20-0309-non-reasoning",Jt="grok-4-1-fast-reasoning",N="grok-4-1-fast-non-reasoning",rr=[zt,qt,jt,Jt,N];function se(r){return rr.includes(r)}var ae="https://api.moonshot.ai/v1/chat/completions",qe="kimi-k2.7-code",je="kimi-k2.7-code-highspeed",w="kimi-k2.6",Xt="kimi-k2.5",ir=[qe,je,w,Xt],nr=[qe,je];function le(r){return ir.includes(r)}function Je(r){return nr.includes(r)}var sr="https://api.deepseek.com",Xe=`${sr}/chat/completions`,pe="deepseek-v4-flash",ar="deepseek-v4-pro",lr="deepseek-chat",pr="deepseek-reasoner",Po=[pe,ar],ti=[lr,pr];var cr="https://api.mistral.ai/v1",Ze=`${cr}/chat/completions`,V="mistral-small-latest",yo="mistral-small-2603",Zt="mistral-medium-3-5",Io="mistral-medium-2508",xo="mistral-large-latest",Do="mistral-large-2512",Ao=[V,Zt,xo,Do,yo,Io],ur=[V,Zt],hr=[V,yo,Zt,Io,xo,Do];function Ye(r){return ur.includes(r)}function Ro(r){return r==="none"||r==="high"}function bo(r){return hr.includes(r)}var mr="https://api.sakana.ai/v1",Qe=`${mr}/chat/completions`,ce="fugu",dr="fugu-ultra",gr="fugu-ultra-20260615",No=[ce,dr,gr];var _r="https://api.platform.preferredai.jp/v1",et=`${_r}/chat/completions`,ue="plamo-3.0-prime",fr="plamo-2.2-prime",wo=[ue,fr];var T={VERY_SHORT:"veryShort",SHORT:"short",MEDIUM:"medium",LONG:"long",VERY_LONG:"veryLong",DEEP:"deep"},Yt={[T.VERY_SHORT]:40,[T.SHORT]:100,[T.MEDIUM]:200,[T.LONG]:300,[T.VERY_LONG]:1e3,[T.DEEP]:5e3},Vo=5e3,ko={casual:{reasoning_effort:"minimal",verbosity:"low",description:"Fast responses for casual chat, quick questions (GPT-4 like experience)"},balanced:{reasoning_effort:"medium",verbosity:"medium",description:"Balanced reasoning for business tasks, learning, general problem solving"},expert:{reasoning_effort:"high",verbosity:"high",description:"Deep reasoning for research, complex analysis, expert-level tasks"}};function E(r){return r?Yt[r]??Vo:Vo}var oi="You are a friendly AI avatar. Comment on the situation based on the broadcast screen.",ri=`You are a skilled summarizing assistant.
2
2
  Analyze the following conversation and produce a summary in the **same language** as the majority of the conversation:
3
3
  - Summaries should highlight key points
4
4
  - Stay concise (around {maxLength} characters if possible)
@@ -7,15 +7,15 @@ Analyze the following conversation and produce a summary in the **same language*
7
7
  If the conversation is in Japanese, summarize in Japanese.
8
8
  If it's in English, summarize in English.
9
9
  If it's in another language, summarize in that language.
10
- `;var Z="gemini-nano",Io=20;var F=class extends Error{constructor(t,o,r){super(`HTTP ${t}: ${o}`);this.status=t;this.statusText=o;this.body=r;this.name="HttpError"}},je=class je{static setFetch(e){this.fetchImpl=e}static async post(e,t,o={},r={}){let{timeout:n=3e4,retries:s=0,retryDelay:a=1e3}=r,c={...{"Content-Type":"application/json"},...o},d=null;for(let u=0;u<=s;u++)try{let m=typeof AbortController<"u",p=m?new AbortController:void 0,h=m?setTimeout(()=>p.abort(),n):void 0,g=await je.fetchImpl(e,{method:"POST",headers:c,body:typeof t=="string"?t:JSON.stringify(t),...p?{signal:p.signal}:{}});if(h&&clearTimeout(h),!g.ok){let S=await g.text();throw new F(g.status,g.statusText,S)}return g}catch(m){if(d=m,m instanceof F&&m.status>=400&&m.status<500)throw m;if(m instanceof Error&&m.name==="AbortError")throw new Error(`Request timeout after ${n}ms`);u<s&&await new Promise(p=>setTimeout(p,a*(u+1)))}throw d||new Error("Request failed")}static async handleErrorResponse(e){let t=await e.text();throw new F(e.status,e.statusText,t)}static async get(e,t={},o={}){let{timeout:r=3e4,retries:n=0,retryDelay:s=1e3}=o,a=null;for(let l=0;l<=n;l++)try{let c=typeof AbortController<"u",d=c?new AbortController:void 0,u=c?setTimeout(()=>d.abort(),r):void 0,m=await je.fetchImpl(e,{method:"GET",headers:t,...d?{signal:d.signal}:{}});if(u&&clearTimeout(u),!m.ok){let p=await m.text();throw new F(m.status,m.statusText,p)}return m}catch(c){if(a=c,c instanceof F&&c.status>=400&&c.status<500)throw c;if(c instanceof Error&&c.name==="AbortError")throw new Error(`Request timeout after ${r}ms`);l<n&&await new Promise(d=>setTimeout(d,s*(l+1)))}throw a||new Error("Request failed")}};je.fetchImpl=(e,t)=>fetch(e,t);var f=je;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 Wi=["happy","sad","angry","surprised","neutral"],ii=/\[([a-z]+)\]/i,xo=/\[[a-z]+\]\s*/gi,ce=class{static extractEmotion(e){let t=e.match(ii);if(t){let o=t[1].toLowerCase(),r=e.replace(xo,"").trim();return{emotion:o,cleanText:r}}return{cleanText:e}}static isValidEmotion(e){return Wi.includes(e)}static cleanEmotionTags(e){return e.replace(xo,"").trim()}static addEmotionTag(e,t){return`[${e}] ${t}`}};function ri(i){let{emotion:e,cleanText:t}=ce.extractEmotion(i);return e?{emotion:e,text:t}:{text:t}}function Bi(i){return i.map(e=>ri(e))}function $i(i){return i.emotion?ce.addEmotionTag(i.emotion,i.text):i.text}async function zi(i,e){let{blocks:t}=await i.chatOnce(e,!1,()=>{});return v.getFullText(t)}var ni=(i,e,t)=>{try{return JSON.parse(i)}catch(o){return t?.(i,o),e}},Y=(i,e)=>i?ni(i,{},e):{};var si=(i,e)=>{try{return JSON.parse(i)}catch(t){if(e){e(i,t);return}throw t}},Do=i=>typeof i=="string"?i:Array.isArray(i)?i.map(e=>typeof e=="string"?e:e&&typeof e=="object"&&e.type==="text"&&typeof e.text=="string"?e.text:"").join(""):"",ai=async(i,e)=>{let t=i.body?.getReader();if(!t)throw new Error("Response body is null.");let o=new TextDecoder,r="",n=!1;for(;!n;){let{done:s,value:a}=await t.read();if(s)break;r+=o.decode(a,{stream:!0});let l=r.split(`
11
- `);r=l.pop()||"";for(let c of l){let d=c.trim();if(!d||d.startsWith(":")||!d.startsWith("data:"))continue;let u=d.slice(5).trim();if(u==="[DONE]"){n=!0;break}e(u)}}};async function L(i,e,t={}){let o="";return await ai(i,r=>{let n=si(r,t.onJsonError);if(!n)return;let s=Do(n.choices?.[0]?.delta?.content);s&&(e(s),o+=s)}),o}async function P(i,e,t={}){let o=[],r=new Map,n,s,a=t.appendTextBlock??v.append;await ai(i,d=>{let u=si(d,t.onJsonError);if(!u)return;let m=u.choices?.[0];typeof m?.finish_reason=="string"&&(n=m.finish_reason),u.usage&&(s=u.usage);let p=m?.delta,h=Do(p?.content);h&&(e(h),a(o,h)),p?.tool_calls&&p.tool_calls.forEach(g=>{let S=r.get(g.index)??{id:g.id,name:g.function?.name,args:""};S.args+=g.function?.arguments||"",r.set(g.index,S)})});let l=Array.from(r.entries()).sort((d,u)=>d[0]-u[0]).map(([d,u])=>({type:"tool_use",id:u.id,name:u.name,input:Y(u.args,t.onJsonError)}));return{blocks:[...o,...l],stop_reason:l.length?"tool_use":"end",truncated:n==="length",finish_reason:n,usage:s}}function I(i,e={}){let t=i?.choices?.[0],o=[];if(t?.message?.tool_calls?.length)t.message.tool_calls.forEach(r=>o.push({type:"tool_use",id:r.id,name:r.function?.name,input:Y(r.function?.arguments,e.onJsonError)}));else{let r=Do(t?.message?.content);r&&o.push({type:"text",text:r})}return{blocks:o,stop_reason:t?.finish_reason==="tool_calls"||o.some(r=>r.type==="tool_use")?"tool_use":"end",truncated:t?.finish_reason==="length",finish_reason:t?.finish_reason,usage:i?.usage}}var x=(i,e="chat-completions")=>i.length===0?[]:e==="responses"?i.map(t=>({type:"function",name:t.name,description:t.description,parameters:t.parameters})):i.map(t=>({type:"function",function:{name:t.name,description:t.description,parameters:t.parameters}}));async function M(i){if(!i.hasTools){let t=await i.runWithoutTools();await i.onCompleteResponse(t);return}let e=await i.runWithTools();if(i.onToolBlocks&&i.onToolBlocks(e.blocks),e.stop_reason==="end"){let t=v.getFullText(e.blocks);await i.onCompleteResponse(t);return}throw new Error(i.toolErrorMessage)}var E=i=>{let e=i.model??i.defaultModel,t=i.visionModel??(i.supportsVisionForModel(e)?e:i.defaultVisionModel);if(i.validate==="explicit"&&i.visionModel&&!i.supportsVisionForModel(i.visionModel))throw new Error(`Model ${i.visionModel} does not support vision capabilities.`);if(i.validate==="resolved"&&!i.supportsVisionForModel(t))throw new Error(`Model ${t} does not support vision capabilities.`);return t};var ji="https://openrouter.ai/api/v1/models",qi=2,Ji=12e3,Xi=1,Zi=10;function Ao(i){return i instanceof Error?i.message:String(i)}function $t(i,e){return typeof i!="number"||!Number.isFinite(i)?e:Math.max(1,Math.floor(i))}function Yi(i){let e=new Set,t=[];for(let o of i){let r=o.trim();!r||e.has(r)||(e.add(r),t.push(r))}return t}async function li(i,e,t){if(!(typeof AbortController<"u"))return fetch(i,e);let r=new AbortController,n=setTimeout(()=>r.abort(),t);try{return await fetch(i,{...e,signal:r.signal})}catch(s){throw s instanceof Error&&s.name==="AbortError"?new Error(`Timeout after ${t}ms`):s}finally{clearTimeout(n)}}async function pi(i){let e=`HTTP ${i.status} ${i.statusText}`.trim(),t="";try{t=await i.text()}catch{return e}let o=t.replace(/\s+/g," ").trim().slice(0,200);return o?`${e}: ${o}`:e}function Qi(i){if(!i||typeof i!="object")throw new Error("Invalid models response shape");let e=i,t=Array.isArray(e.data)?e.data:Array.isArray(e.models)?e.models:[];if(t.length===0)return[];let o=t.map(r=>r.id).filter(r=>typeof r=="string");return Yi(o)}async function er({modelId:i,apiKey:e,endpoint:t,timeoutMs:o,appName:r,appUrl:n}){let s={Authorization:`Bearer ${e}`,"Content-Type":"application/json"};r&&(s["X-Title"]=r),n&&(s["HTTP-Referer"]=n);try{let a=await li(t,{method:"POST",headers:s,body:JSON.stringify({model:i,messages:[{role:"user",content:"Reply only with OK."}],stream:!1})},o);if(!a.ok)return{id:i,ok:!1,reason:await pi(a)};try{await a.json()}catch(l){return{id:i,ok:!1,reason:`JSON parse failed: ${Ao(l)}`}}return{id:i,ok:!0}}catch(a){return{id:i,ok:!1,reason:Ao(a)}}}async function tr(i,e,t){if(i.length===0)return[];let o=new Array(i.length),r=0,n=Math.min(e,i.length);return await Promise.all(Array.from({length:n},async()=>{for(;r<i.length;){let s=r;r+=1,o[s]=await t(i[s])}})),o}async function or(i){let e=i.apiKey.trim();if(!e)throw new Error("OpenRouter API key is required.");let t=i.modelsEndpoint||ji,o=i.endpoint||Ge,r=$t(i.timeoutMs,Ji),n=$t(i.concurrency,qi),s=$t(i.maxCandidates,Xi),a=$t(i.maxWorking,Zi),l=await li(t,{method:"GET"},r);if(!l.ok)throw new Error(await pi(l));let c;try{c=await l.json()}catch(h){throw new Error(`JSON parse failed: ${Ao(h)}`)}let d=Qi(c).filter(h=>J(h)).slice(0,s),u=await tr(d,n,h=>er({modelId:h,apiKey:e,endpoint:o,timeoutMs:r,appName:i.appName,appUrl:i.appUrl})),m=u.filter(h=>h.ok).map(h=>h.id).slice(0,a),p=u.filter(h=>!h.ok).map(h=>({id:h.id,reason:h.reason||"Unknown error"}));return{working:m,failed:p,fetchedAt:Date.now()}}function ci(i){return i.map(e=>({role:zt(e.role),content:e.content}))}function ui(i){return i.map(e=>{if(typeof e.content=="string")return{role:zt(e.role),content:[{type:"text",text:e.content}]};if(Array.isArray(e.content)){let t=e.content.map(o=>{if(o.type==="image_url"){if(o.image_url.url.startsWith("data:")){let r=o.image_url.url.match(/^data:([^;]+);base64,(.+)$/);return r?{type:"image",source:{type:"base64",media_type:r[1],data:r[2]}}:null}return{type:"image",source:{type:"url",url:o.image_url.url,media_type:ir(o.image_url.url)}}}return o}).filter(o=>o);return{role:zt(e.role),content:t}}return{role:zt(e.role),content:[]}})}function zt(i){switch(i){case"system":return"system";case"user":return"user";case"assistant":return"assistant";default:return"user"}}function ir(i){switch(i.split(".").pop()?.toLowerCase()){case"jpg":case"jpeg":return"image/jpeg";case"png":return"image/png";case"gif":return"image/gif";case"webp":return"image/webp";default:return"image/jpeg"}}var ue=class{constructor(e,t=R,o=R,r=[],n=[],s){this.provider="claude";if(this.apiKey=e,this.model=t||R,this.visionModel=o||R,this.tools=r,this.mcpServers=n,this.responseLength=s,!ke.includes(this.visionModel))throw new Error(`Model ${this.visionModel} does not support vision capabilities.`)}getModel(){return this.model}getVisionModel(){return this.visionModel}getMCPServers(){return this.mcpServers}addMCPServer(e){this.mcpServers.push(e)}removeMCPServer(e){this.mcpServers=this.mcpServers.filter(t=>t.name!==e)}hasMCPServers(){return this.mcpServers.length>0}async processChat(e,t,o){await M({hasTools:this.tools.length>0||this.mcpServers.length>0,runWithoutTools:async()=>{let r=await this.callClaude(e,this.model,!0);return this.parsePureStream(r,t)},runWithTools:()=>this.chatOnce(e,!0,t),onCompleteResponse:o,toolErrorMessage:"processChat received tool_calls. ChatProcessor must use chatOnce() loop when tools are enabled."})}async processVisionChat(e,t,o){await M({hasTools:this.tools.length>0||this.mcpServers.length>0,runWithoutTools:async()=>{let r=await this.callClaude(e,this.visionModel,!0);return this.parsePureStream(r,t)},runWithTools:()=>this.visionChatOnce(e),onCompleteResponse:o,toolErrorMessage:"processVisionChat received tool_calls. ChatProcessor must use chatOnce() loop when tools are enabled."})}async callClaude(e,t,o,r){let n=e.find(u=>u.role==="system")?.content??"",s=e.filter(u=>u.role!=="system"),a=s.some(u=>Array.isArray(u.content)&&u.content.some(m=>m.type==="image_url"||m.type==="image")),l={model:t,system:n,messages:a?ui(s):ci(s),stream:o,max_tokens:r!==void 0?r:O(this.responseLength)};this.tools.length&&(l.tools=this.tools.map(u=>({name:u.name,description:u.description,input_schema:u.parameters})),l.tool_choice={type:"auto"}),this.mcpServers.length>0&&(l.mcp_servers=this.mcpServers);let c={"Content-Type":"application/json","x-api-key":this.apiKey,"anthropic-version":"2023-06-01","anthropic-dangerous-direct-browser-access":"true"};return this.mcpServers.length>0&&(c["anthropic-beta"]="mcp-client-2025-04-04"),await f.post(oo,l,c)}async parseStream(e,t){let o=e.body.getReader(),r=new TextDecoder,n=[],s=new Map,a="";for(;;){let{done:l,value:c}=await o.read();if(l)break;a+=r.decode(c,{stream:!0});let d;for(;(d=a.indexOf(`
12
- `))!==-1;){let u=a.slice(0,d).trim();if(a=a.slice(d+1),!u.startsWith("data:"))continue;let m=u.slice(5).trim();if(m==="[DONE]")break;let p=JSON.parse(m);if(p.type==="content_block_delta"&&p.delta?.text&&(t(p.delta.text),n.push({type:"text",text:p.delta.text})),p.type==="content_block_start"&&p.content_block?.type==="tool_use"?s.set(p.index,{id:p.content_block.id,name:p.content_block.name,args:""}):p.type==="content_block_start"&&p.content_block?.type==="mcp_tool_use"?s.set(p.index,{id:p.content_block.id,name:p.content_block.name,args:"",server_name:p.content_block.server_name}):p.type==="content_block_start"&&p.content_block?.type==="tool_result"?n.push({type:"tool_result",tool_use_id:p.content_block.tool_use_id,content:p.content_block.content??""}):p.type==="content_block_start"&&p.content_block?.type==="mcp_tool_result"&&n.push({type:"mcp_tool_result",tool_use_id:p.content_block.tool_use_id,is_error:p.content_block.is_error??!1,content:p.content_block.content??[]}),p.type==="content_block_delta"&&p.delta?.type==="input_json_delta"){let h=s.get(p.index);h&&(h.args+=p.delta.partial_json||"")}if(p.type==="content_block_stop"&&s.has(p.index)){let{id:h,name:g,args:S,server_name:k}=s.get(p.index);k?n.push({type:"mcp_tool_use",id:h,name:g,server_name:k,input:JSON.parse(S||"{}")}):n.push({type:"tool_use",id:h,name:g,input:JSON.parse(S||"{}")}),s.delete(p.index)}}}return{blocks:n,stop_reason:n.some(l=>l.type==="tool_use"||l.type==="mcp_tool_use")?"tool_use":"end"}}async parsePureStream(e,t){let{blocks:o}=await this.parseStream(e,t);return o.filter(r=>r.type==="text").map(r=>r.text).join("")}parseOneShot(e){let t=[];return(e.content??[]).forEach(o=>{o.type==="text"?t.push({type:"text",text:o.text}):o.type==="tool_use"?t.push({type:"tool_use",id:o.id,name:o.name,input:o.input??{}}):o.type==="mcp_tool_use"?t.push({type:"mcp_tool_use",id:o.id,name:o.name,server_name:o.server_name,input:o.input??{}}):o.type==="tool_result"?t.push({type:"tool_result",tool_use_id:o.tool_use_id,content:o.content??""}):o.type==="mcp_tool_result"&&t.push({type:"mcp_tool_result",tool_use_id:o.tool_use_id,is_error:o.is_error??!1,content:o.content??[]})}),{blocks:t,stop_reason:t.some(o=>o.type==="tool_use"||o.type==="mcp_tool_use")?"tool_use":"end"}}async chatOnce(e,t=!0,o=()=>{},r){let n=await this.callClaude(e,this.model,t,r),s=t?await this.parseStream(n,o):this.parseOneShot(await n.json());return this.convertToStandardCompletion(s)}async visionChatOnce(e,t=!1,o=()=>{},r){let n=await this.callClaude(e,this.visionModel,t,r),s=t?await this.parseStream(n,o):this.parseOneShot(await n.json());return this.convertToStandardCompletion(s)}convertToStandardCompletion(e){return{blocks:e.blocks.filter(o=>o.type==="text"||o.type==="tool_use"||o.type==="tool_result"),stop_reason:e.stop_reason}}};var he=class{createChatService(e){let t=E({model:e.model,visionModel:e.visionModel,defaultModel:this.getDefaultModel(),defaultVisionModel:this.getDefaultModel(),supportsVisionForModel:o=>this.supportsVisionForModel(o),validate:"resolved"});return new ue(e.apiKey,e.model||this.getDefaultModel(),t,e.tools??[],e.mcpServers??[],e.responseLength)}getProviderName(){return"claude"}getSupportedModels(){return[ot,it,rt,R,nt,st,at,lt,pt,tt]}getDefaultModel(){return R}supportsVision(){return this.getVisionSupportLevel()!=="unsupported"}getVisionSupportLevel(){return"supported"}supportsVisionForModel(e){return ke.includes(e)}getVisionSupportLevelForModel(e){return this.supportsVisionForModel(e)?"supported":"unsupported"}};async function jt(i,e,t={}){let o=i.body.getReader(),r=new TextDecoder,n=[],s=new Map,a,l,c,d="";for(;;){let{done:m,value:p}=await o.read();if(m)break;d+=r.decode(p,{stream:!0});let h="",g="",S=d.split(`
13
- `);d=S.pop()||"";for(let k=0;k<S.length;k++){let _=S[k].trim();if(_.startsWith("event:"))h=_.slice(6).trim();else if(_.startsWith("data:"))g=_.slice(5).trim();else if(_===""&&h&&g){try{let D=JSON.parse(g);rr(h,D,e,n,s,t,T=>{T.responseStatus!==void 0&&(a=T.responseStatus),T.incompleteDetails!==void 0&&(l=T.incompleteDetails),T.usage!==void 0&&(c=T.usage)})}catch(D){t.onJsonError?.(g,D),console.warn("Failed to parse SSE data:",g)}h="",g=""}}}let u=Array.from(s.values()).map(m=>({type:"tool_use",id:m.id,name:m.name,input:m.input||{}}));return{blocks:[...n,...u],stop_reason:u.length?"tool_use":"end",truncated:a==="incomplete",response_status:a,incomplete_details:l,usage:c}}function rr(i,e,t,o,r,n,s){switch(i){case"response.output_item.added":e.item?.type==="message"&&Array.isArray(e.item.content)?e.item.content.forEach(a=>{a.type==="output_text"&&a.text&&(t(a.text),v.append(o,a.text))}):e.item?.type==="function_call"&&r.set(e.item.id,{id:e.item.id,name:e.item.name,input:Y(e.item.arguments,n.onJsonError)});break;case"response.content_part.added":e.part?.type==="output_text"&&typeof e.part.text=="string"&&(t(e.part.text),v.append(o,e.part.text));break;case"response.output_text.delta":case"response.content_part.delta":{let a=typeof e.delta=="string"?e.delta:e.delta?.text??"";a&&(t(a),v.append(o,a));break}case"response.output_text.done":case"response.content_part.done":case"response.reasoning.started":case"response.reasoning.delta":case"response.reasoning.done":break;case"response.completed":s(hi(e,"completed"));break;case"response.incomplete":s(hi(e,"incomplete"));break;default:break}}function hi(i,e){let t=i?.response??i;return{responseStatus:t?.status??e,incompleteDetails:t?.incomplete_details??null,usage:t?.usage}}function mi(i,e={}){let t=[];return i.output&&Array.isArray(i.output)&&i.output.forEach(o=>{o.type==="message"&&o.content&&o.content.forEach(r=>{r.type==="output_text"&&r.text&&t.push({type:"text",text:r.text})}),o.type==="function_call"&&t.push({type:"tool_use",id:o.id,name:o.name,input:Y(o.arguments,e.onJsonError)})}),{blocks:t,stop_reason:t.some(o=>o.type==="tool_use")?"tool_use":"end",truncated:i?.status==="incomplete",response_status:i?.status,incomplete_details:i?.incomplete_details??null,usage:i?.usage}}function di({tools:i,mcpServers:e,isResponsesAPI:t}){let o=[];return i.length>0&&o.push(...x(i,t?"responses":"chat-completions")),e.length>0&&t&&o.push(...nr(e)),o}function nr(i){return i.map(e=>{let t={type:"mcp",server_label:e.name,server_url:e.url};return e.require_approval&&(t.require_approval=e.require_approval),e.tool_configuration?.allowed_tools&&(t.allowed_tools=e.tool_configuration.allowed_tools),e.authorization_token&&(t.headers={Authorization:`Bearer ${e.authorization_token}`}),t})}var sr={[C.VERY_SHORT]:800,[C.SHORT]:1200,[C.MEDIUM]:2e3,[C.LONG]:3e3,[C.VERY_LONG]:8e3,[C.DEEP]:25e3},ar={none:1200,minimal:1600,low:2500,medium:4e3,high:8e3,xhigh:12e3},lr=new Set(["openai-compatible","deepseek","mistral"]);function gi({provider:i,endpoint:e,messages:t,model:o,stream:r,tools:n,mcpServers:s,responseLength:a,verbosity:l,reasoning_effort:c,enableReasoningSummary:d,maxTokens:u}){let m=e===A;cr(e,s);let p={model:o,stream:r},h=pr({provider:i,model:o,responseLength:a,reasoning_effort:c,maxTokens:u});m?h!==void 0&&(p.max_output_tokens=h):h!==void 0&&(_i(i)?p.max_tokens=h:p.max_completion_tokens=h),m?p.input=ur(t):p.messages=i==="mistral"?hr(t):t,j(o)&&(m?(c&&(p.reasoning={...p.reasoning,effort:c},d&&(p.reasoning.summary="auto")),l&&(p.text={...p.text,format:{type:"text"},verbosity:l})):(c&&(p.reasoning_effort=c),l&&(p.verbosity=l))),i==="mistral"&&ze(o)&&c&&To(c)&&(p.reasoning_effort=c);let g=di({tools:n,mcpServers:s,isResponsesAPI:m});return g.length>0&&(p.tools=g,m||(p.tool_choice="auto")),p}function pr({provider:i,model:e,responseLength:t,reasoning_effort:o,maxTokens:r}){if(r!==void 0)return r;let n=_i(i)?t!==void 0?O(t):void 0:O(t);if(i!=="openai"||!j(e)||t===void 0)return n;let s=o??we(e);return Math.max(n??0,sr[t],ar[s])}function cr(i,e){if(e.length>0&&i===U)throw new Error(`MCP servers are not supported with Chat Completions API. Current endpoint: ${i}. Please use OpenAI Responses API endpoint: ${A}. MCP tools are only available in the Responses API endpoint.`)}function ur(i){return i.map(e=>{let o={role:e.role==="tool"?"user":e.role};return typeof e.content=="string"?o.content=e.content:Array.isArray(e.content)?o.content=e.content.map(r=>r.type==="text"?{type:"input_text",text:r.text}:r.type==="image_url"?{type:"input_image",image_url:r.image_url.url}:r):o.content=e.content,o})}function hr(i){return i.map(e=>{let t={role:e.role};return Array.isArray(e.content)?(t.content=e.content.map(o=>o.type==="image_url"&&typeof o.image_url=="object"&&typeof o.image_url?.url=="string"?{type:"image_url",image_url:o.image_url.url}:o),t):(t.content=e.content,t)})}function _i(i){return lr.has(i)}var y=class{constructor(e,t=z,o=z,r,n=U,s=[],a,l,c,d=!1,u="openai",m=!0){if(this.provider=u,this.apiKey=e,this.model=t,this.tools=r||[],this.endpoint=n,this.mcpServers=s,this.responseLength=a,this.verbosity=l,this.reasoning_effort=c,this.enableReasoningSummary=d,m&&!Re.includes(o))throw new Error(`Model ${o} does not support vision capabilities.`);this.visionModel=o}getModel(){return this.model}getVisionModel(){return this.visionModel}async processChat(e,t,o){await M({hasTools:this.tools.length>0,runWithoutTools:async()=>{let r=await this.callOpenAI(e,this.model,!0),n=this.endpoint===A;try{if(n){let s=await jt(r,t);return v.getFullText(s.blocks)}return this.handleStream(r,t)}catch(s){throw console.error("[processChat] Error in streaming/completion:",s),s}},runWithTools:()=>this.chatOnce(e,!0,t),onCompleteResponse:o,toolErrorMessage:"processChat received tool_calls. ChatProcessor must use chatOnce() loop when tools are enabled."})}async processVisionChat(e,t,o){try{await M({hasTools:this.tools.length>0,runWithoutTools:async()=>{let r=await this.callOpenAI(e,this.visionModel,!0),n=this.endpoint===A;try{if(n){let s=await jt(r,t);return v.getFullText(s.blocks)}return this.handleStream(r,t)}catch(s){throw console.error("[processVisionChat] Error in streaming/completion:",s),s}},runWithTools:()=>this.visionChatOnce(e,!0,t),onCompleteResponse:o,toolErrorMessage:"processVisionChat received tool_calls. ChatProcessor must use visionChatOnce() loop when tools are enabled."})}catch(r){throw console.error("Error in processVisionChat:",r),r}}async chatOnce(e,t=!0,o=()=>{},r){let n=await this.callOpenAI(e,this.model,t,r);return this.parseResponse(n,t,o)}async visionChatOnce(e,t=!1,o=()=>{},r){let n=await this.callOpenAI(e,this.visionModel,t,r);return this.parseResponse(n,t,o)}async parseResponse(e,t,o){return this.endpoint===A?t?jt(e,o):mi(await e.json()):t?this.parseStream(e,o):this.parseOneShot(await e.json())}async callOpenAI(e,t,o=!1,r){let n=gi({provider:this.provider,endpoint:this.endpoint,messages:e,model:t,stream:o,tools:this.tools,mcpServers:this.mcpServers,responseLength:this.responseLength,verbosity:this.verbosity,reasoning_effort:this.reasoning_effort,enableReasoningSummary:this.enableReasoningSummary,maxTokens:r}),s={};return(this.provider!=="openai-compatible"||this.apiKey.trim()!=="")&&(s.Authorization=`Bearer ${this.apiKey}`),await f.post(this.endpoint,n,s)}async handleStream(e,t){return L(e,t)}async parseStream(e,t){return P(e,t,{appendTextBlock:v.addTextBlock})}parseOneShot(e){return I(e)}};var me=class extends y{constructor(e,t=pe,o=t,r,n=Be,s){super(e,t,o,r,n,[],s,void 0,void 0,!1,"deepseek",!1)}};var de=class{createChatService(e){this.validateRequiredOptions(e);let t=e.model||this.getDefaultModel(),o=e.tools;return new me(e.apiKey,t,e.visionModel??t,o,this.resolveEndpoint(e),e.responseLength)}getProviderName(){return"deepseek"}getSupportedModels(){return[...Mo]}getDefaultModel(){return pe}supportsVision(){return!1}getVisionSupportLevel(){return"unsupported"}supportsVisionForModel(e){return!1}getVisionSupportLevelForModel(e){return"unsupported"}validateRequiredOptions(e){if(!e.apiKey?.trim())throw new Error("deepseek provider requires apiKey.")}resolveEndpoint(e){if(e.endpoint)return this.normalizeUrl(e.endpoint);if(e.baseUrl){let t=this.normalizeUrl(e.baseUrl);return t.endsWith("/chat/completions")?t:`${t}/chat/completions`}return Be}normalizeUrl(e){return e.trim().replace(/\/+$/,"")}};var fi=(i,e)=>({name:`mcp_${i.name}_search`,description:e==="schema-fetch-failed"?`Search using ${i.name} MCP server (schema fetch failed)`:`Search using ${i.name} MCP server`,parameters:{type:"object",properties:{query:{type:"string",description:"Search query"}},required:["query"]}}),qt=class{static async fetchToolSchemas(e){return(await this.fetchToolSchemasWithStatus(e)).schemas}static async fetchToolSchemasWithStatus(e){try{let t={"Content-Type":"application/json"};e.authorization_token&&(t.Authorization=`Bearer ${e.authorization_token}`);let r=await(await f.post(`${e.url}/tools`,{},t)).json();return Array.isArray(r.tools)?{schemas:r.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:[]}})),failures:[]}:{schemas:[fi(e)],failures:[]}}catch(t){return console.warn(`Failed to fetch MCP schemas from ${e.name}:`,t),{schemas:[fi(e,"schema-fetch-failed")],failures:[{server:e,error:t}]}}}static async fetchAllToolSchemas(e){return(await this.fetchAllToolSchemasWithStatus(e)).schemas}static async fetchAllToolSchemasWithStatus(e){let t=[],o=[];for(let r of e)try{let n=await this.fetchToolSchemasWithStatus(r);t.push(...n.schemas),o.push(...n.failures)}catch(n){console.error(`Failed to fetch schemas from ${r.name}:`,n),o.push({server:r,error:n})}return{schemas:t,failures:o}}};function Mi(i){switch(i){case"system":return"model";case"user":return"user";case"assistant":return"model";default:return"user"}}function vi(i,e={}){let t=[],o=null,r=[],n=()=>{o&&r.length&&(t.push({role:o,parts:[...r]}),r=[])};for(let s of i){let a=Mi(s.role);if(s.tool_calls){n();for(let l of s.tool_calls)e.callIdMap?.set(l.id,l.function.name),t.push({role:"model",parts:[{functionCall:{name:l.function.name,args:JSON.parse(l.function.arguments||"{}")}}]});continue}if(s.role==="tool"){n();let l=s.name??e.callIdMap?.get(s.tool_call_id)??"result";t.push({role:"user",parts:[{functionResponse:{name:l,response:Si(Oi(s.content))}}]});continue}a!==o&&n(),o=a,r.push({text:s.content})}return n(),t}async function Ei(i,e={}){let t=e.imageFetcher??f.get,o=e.blobToBase64??mr,r=[],n=null,s=[];for(let a of i){let l=Mi(a.role);if(a.tool_calls){for(let c of a.tool_calls)r.push({role:"model",parts:[{functionCall:{name:c.function.name,args:JSON.parse(c.function.arguments||"{}")}}]});continue}if(a.role==="tool"){let c=a.name??e.callIdMap?.get(a.tool_call_id)??"result";r.push({role:"user",parts:[{functionResponse:{name:c,response:Si(Oi(a.content))}}]});continue}if(l!==n&&s.length>0&&(r.push({role:n,parts:[...s]}),s=[]),n=l,typeof a.content=="string")s.push({text:a.content});else if(Array.isArray(a.content)){for(let c of a.content)if(c.type==="text")s.push({text:c.text});else if(c.type==="image_url")try{let u=await(await t(c.image_url.url)).blob(),m=await o(u);s.push({inlineData:{mimeType:u.type||"image/jpeg",data:m.split(",")[1]}})}catch(d){throw console.error("Error processing image:",d),new Error(`Failed to process image: ${d.message}`)}}}return n&&s.length>0&&r.push({role:n,parts:[...s]}),r}function Oi(i){try{return JSON.parse(i)}catch{return i}}function Si(i){return i===null?{content:null}:typeof i=="object"?i:{content:i}}function mr(i){return new Promise((e,t)=>{let o=new FileReader;o.onloadend=()=>e(o.result),o.onerror=t,o.readAsDataURL(i)})}function dr(i,e){return[...i,...e].map(t=>({name:t.name,description:t.description,parameters:t.parameters}))}function Ci(i,e){let t=dr(i,e);if(t.length!==0)return{tools:[{functionDeclarations:t}],toolConfig:{functionCallingConfig:{mode:"AUTO"}}}}function Ti(i){return i.map(e=>({name:`mcp_${e.name}_search`,description:`Search using ${e.name} MCP server (fallback)`,parameters:{type:"object",properties:{query:{type:"string",description:"Search query"}},required:["query"]}}))}var ge=class{constructor(e,t=q,o=q,r=[],n=[],s){this.provider="gemini";this.mcpToolSchemas=[];this.mcpSchemasInitialized=!1;this.callIdMap=new Map;if(this.apiKey=e,this.model=t,this.responseLength=s,!Ve.includes(o))throw new Error(`Model ${o} does not support vision capabilities.`);this.visionModel=o,this.tools=r,this.mcpServers=n}isGemma4Model(e){return/^gemma-4-/.test(e)}shouldMinimizeThinking(e){return e===Qe||this.isGemma4Model(e)}shouldExposeTextPart(e,t){return!(!e.text||this.isGemma4Model(t)&&e.thought===!0)}adaptKeysForApi(e){let t={toolConfig:"tool_config",functionCallingConfig:"function_calling_config",functionDeclarations:"function_declarations",functionCall:"function_call",functionResponse:"function_response"};return Array.isArray(e)?e.map(o=>this.adaptKeysForApi(o)):e&&typeof e=="object"?Object.fromEntries(Object.entries(e).map(([o,r])=>[t[o]??o,this.adaptKeysForApi(r)])):e}getModel(){return this.model}getVisionModel(){return this.visionModel}getMCPServers(){return this.mcpServers}addMCPServer(e){this.mcpServers.push(e),this.mcpSchemasInitialized=!1,this.mcpSchemaInitializationError=void 0}removeMCPServer(e){this.mcpServers=this.mcpServers.filter(t=>t.name!==e),this.mcpSchemasInitialized=!1,this.mcpSchemaInitializationError=void 0}hasMCPServers(){return this.mcpServers.length>0}getMCPSchemaInitializationError(){return this.mcpSchemaInitializationError}async initializeMCPSchemas(){if(!(this.mcpSchemasInitialized||this.mcpServers.length===0))try{let e=new Promise((r,n)=>setTimeout(()=>n(new Error("MCP schema fetch timeout")),5e3)),t=qt.fetchAllToolSchemasWithStatus(this.mcpServers),o=await Promise.race([t,e]);this.mcpToolSchemas=o.schemas,this.mcpSchemasInitialized=!0,this.mcpSchemaInitializationError=o.failures[0]?.error}catch(e){console.warn("Failed to initialize MCP schemas, using fallback:",e),this.mcpSchemaInitializationError=e,this.mcpToolSchemas=Ti(this.mcpServers),this.mcpSchemasInitialized=!0}}async processChat(e,t,o){try{await M({hasTools:this.tools.length>0||this.mcpServers.length>0,runWithoutTools:async()=>{let r=await this.callGemini(e,this.model,!0),{blocks:n}=await this.parseStream(r,t,this.model);return v.getFullText(n)},runWithTools:()=>this.chatOnce(e,!0,t),onCompleteResponse:o,toolErrorMessage:"Received functionCall. Use chatOnce() loop when tools are enabled."})}catch(r){throw console.error("Error in processChat:",r),r}}async processVisionChat(e,t,o){try{await M({hasTools:this.tools.length>0||this.mcpServers.length>0,runWithoutTools:async()=>{let r=await this.callGemini(e,this.visionModel,!0),{blocks:n}=await this.parseStream(r,t,this.visionModel);return v.getFullText(n)},runWithTools:()=>this.visionChatOnce(e),onToolBlocks:r=>{r.filter(n=>n.type==="text").forEach(n=>t(n.text))},onCompleteResponse:o,toolErrorMessage:"Received functionCall. Use visionChatOnce() loop when tools are enabled."})}catch(r){throw console.error("Error in processVisionChat:",r),r}}async callGemini(e,t,o=!1,r){let a={contents:e.some(_=>Array.isArray(_.content)&&_.content.some(D=>D?.type==="image_url"||D?.inlineData))?await Ei(e,{callIdMap:this.callIdMap}):vi(e,{callIdMap:this.callIdMap}),generationConfig:{maxOutputTokens:r!==void 0?r:O(this.responseLength)}};this.shouldMinimizeThinking(t)&&(a.generationConfig.thinkingConfig={includeThoughts:!1,thinkingLevel:"MINIMAL"});let l=[];if(this.mcpServers.length>0)try{await this.initializeMCPSchemas(),l=this.mcpToolSchemas}catch(_){console.warn("MCP initialization failed, skipping MCP tools:",_)}let c=Ci(this.tools,l);c&&Object.assign(a,c);let d=async(_,D)=>{let T=o?"streamGenerateContent":"generateContent",Ro=o?"?alt=sse":"",Pi=`${to}/${_}/models/${t}:${T}${Ro}${Ro?"&":"?"}key=${this.apiKey}`;return f.post(Pi,D)},u=/flash[-_]lite/.test(t),m=this.isGemma4Model(t),p=/gemini-2\.5/.test(t),h=/^gemini-3(?:\.[0-9]+)?-/.test(t),g=u||m||p||h,S=g?"v1beta":"v1",k=async()=>{try{let _=S==="v1"?a:this.adaptKeysForApi(a);return await d(S,_)}catch(_){let D=/Unknown name|Cannot find field|404/.test(_?.message||"")||_?.status===404;if(!g&&D)try{return await d("v1beta",this.adaptKeysForApi(a))}catch(T){throw T instanceof Error&&(T.cause=_),T}throw _}};try{return await k()}catch(_){throw _.body&&(console.error("Gemini API Error Details:",_.body),console.error("Request Body:",JSON.stringify(a,null,2))),_}}async parseStream(e,t,o){let r=e.body.getReader(),n=new TextDecoder,s=[],a=[],l="",c=u=>{if(!u||u==="[DONE]")return;let m;try{m=JSON.parse(u)}catch{return}for(let p of m.candidates??[])for(let h of p.content?.parts??[])this.shouldExposeTextPart(h,o)&&(t(h.text),v.addTextBlock(s,h.text)),h.functionCall&&a.push({type:"tool_use",id:this.genUUID(),name:h.functionCall.name,input:h.functionCall.args??{}}),h.functionResponse&&a.push({type:"tool_result",tool_use_id:h.functionResponse.name,content:JSON.stringify(h.functionResponse.response)})};for(;;){let{done:u,value:m}=await r.read();if(u)break;l+=n.decode(m,{stream:!0});let p;for(;(p=l.indexOf(`
14
- `))!==-1;){let h=l.slice(0,p);if(l=l.slice(p+1),h.endsWith("\r")&&(h=h.slice(0,-1)),!h.trim()){c("");continue}h.startsWith("data:")&&(h=h.slice(5).trim()),h&&c(h)}}return l&&c(l),{blocks:[...s,...a],stop_reason:a.some(u=>u.type==="tool_use")?"tool_use":"end"}}parseOneShot(e,t){let o=[],r=[];for(let s of e.candidates??[])for(let a of s.content?.parts??[])this.shouldExposeTextPart(a,t)&&o.push({type:"text",text:a.text}),a.functionCall&&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)});return{blocks:[...o,...r],stop_reason:r.some(s=>s.type==="tool_use")?"tool_use":"end"}}async chatOnce(e,t=!0,o=()=>{},r){let n=await this.callGemini(e,this.model,t,r);return t?this.parseStream(n,o,this.model):this.parseOneShot(await n.json(),this.model)}async visionChatOnce(e,t=!1,o=()=>{},r){let n=await this.callGemini(e,this.visionModel,t,r);return t?this.parseStream(n,o,this.visionModel):this.parseOneShot(await n.json(),this.visionModel)}genUUID(){return typeof crypto<"u"&&crypto.randomUUID?crypto.randomUUID():"xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx".replace(/[xy]/g,e=>{let t=Math.random()*16|0;return(e==="x"?t:t&3|8).toString(16)})}};var _e=class{createChatService(e){let t=E({model:e.model,visionModel:e.visionModel,defaultModel:this.getDefaultModel(),defaultVisionModel:this.getDefaultModel(),supportsVisionForModel:o=>this.supportsVisionForModel(o),validate:"resolved"});return new ge(e.apiKey,e.model||this.getDefaultModel(),t,e.tools||[],e.mcpServers||[],e.responseLength)}getProviderName(){return"gemini"}getSupportedModels(){return[...et]}getDefaultModel(){return q}supportsVision(){return this.getVisionSupportLevel()!=="unsupported"}getVisionSupportLevel(){return"supported"}supportsVisionForModel(e){return Ve.includes(e)}getVisionSupportLevelForModel(e){return this.supportsVisionForModel(e)?"supported":"unsupported"}};function gr(){if(typeof globalThis<"u"&&"LanguageModel"in globalThis)return globalThis.LanguageModel}var fe=class{constructor(e={}){this.provider="gemini-nano";this.expectedInputLanguages=e.expectedInputLanguages??["ja"],this.expectedOutputLanguages=e.expectedOutputLanguages??["ja"],this._responseLength=e.responseLength}getModel(){return Z}getVisionModel(){return Z}async processChat(e,t,o){let r=await this.generateResponse(e);t(r),await o(r)}async processVisionChat(e,t,o){throw new Error("Gemini Nano does not support vision capabilities.")}async chatOnce(e,t=!1,o=()=>{},r){let n=await this.generateResponse(e);return o(n),{blocks:[{type:"text",text:n}],stop_reason:"end"}}async visionChatOnce(e,t=!1,o=()=>{},r){throw new Error("Gemini Nano does not support vision capabilities.")}async generateResponse(e){let t=gr();if(!t)throw new Error("Gemini Nano is not available in this environment. Chrome 138+ with Prompt API enabled is required.");let o=await t.availability();if(o!=="available"&&o!=="downloadable")throw new Error(`Gemini Nano Prompt API is not ready in this environment. LanguageModel.availability() returned "${o}". Expected "available" or "downloadable".`);let n=e.filter(c=>c.role==="system").map(c=>c.content).join(`
15
- `),s=e.filter(c=>c.role!=="system").slice(-20),a=[...s].reverse().find(c=>c.role==="user");if(!a)throw new Error("No user message found in the provided messages.");let l=await this.createSession(t,n,s);try{return await l.prompt(a.content)}finally{try{l.destroy()}catch{}}}async createSession(e,t,o){let r=this.buildSystemPrompt(t),n=o.slice(0,-1);if(n.length>0){let s=n.map(a=>`${a.role==="user"?"User":"Assistant"}: ${a.content}`).join(`
16
- `);r+=`
10
+ `;var Z="gemini-nano",Go=20;var F=class extends Error{constructor(t,o,i){super(`HTTP ${t}: ${o}`);this.status=t;this.statusText=o;this.body=i;this.name="HttpError"}},tt=class tt{static setFetch(e){this.fetchImpl=e}static async post(e,t,o={},i={}){let{timeout:n=3e4,retries:s=0,retryDelay:a=1e3}=i,c={...{"Content-Type":"application/json"},...o},d=null;for(let u=0;u<=s;u++)try{let m=typeof AbortController<"u",p=m?new AbortController:void 0,h=m?setTimeout(()=>p.abort(),n):void 0,g=await tt.fetchImpl(e,{method:"POST",headers:c,body:typeof t=="string"?t:JSON.stringify(t),...p?{signal:p.signal}:{}});if(h&&clearTimeout(h),!g.ok){let C=await g.text();throw new F(g.status,g.statusText,C)}return g}catch(m){if(d=m,m instanceof F&&m.status>=400&&m.status<500)throw m;if(m instanceof Error&&m.name==="AbortError")throw new Error(`Request timeout after ${n}ms`);u<s&&await new Promise(p=>setTimeout(p,a*(u+1)))}throw d||new Error("Request failed")}static async handleErrorResponse(e){let t=await e.text();throw new F(e.status,e.statusText,t)}static async get(e,t={},o={}){let{timeout:i=3e4,retries:n=0,retryDelay:s=1e3}=o,a=null;for(let l=0;l<=n;l++)try{let c=typeof AbortController<"u",d=c?new AbortController:void 0,u=c?setTimeout(()=>d.abort(),i):void 0,m=await tt.fetchImpl(e,{method:"GET",headers:t,...d?{signal:d.signal}:{}});if(u&&clearTimeout(u),!m.ok){let p=await m.text();throw new F(m.status,m.statusText,p)}return m}catch(c){if(a=c,c instanceof F&&c.status>=400&&c.status<500)throw c;if(c instanceof Error&&c.name==="AbortError")throw new Error(`Request timeout after ${i}ms`);l<n&&await new Promise(d=>setTimeout(d,s*(l+1)))}throw a||new Error("Request failed")}};tt.fetchImpl=(e,t)=>fetch(e,t);var f=tt;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 ii=["happy","sad","angry","surprised","neutral"],Mr=/\[([a-z]+)\]/i,Fo=/\[[a-z]+\]\s*/gi,he=class{static extractEmotion(e){let t=e.match(Mr);if(t){let o=t[1].toLowerCase(),i=e.replace(Fo,"").trim();return{emotion:o,cleanText:i}}return{cleanText:e}}static isValidEmotion(e){return ii.includes(e)}static cleanEmotionTags(e){return e.replace(Fo,"").trim()}static addEmotionTag(e,t){return`[${e}] ${t}`}};function vr(r){let{emotion:e,cleanText:t}=he.extractEmotion(r);return e?{emotion:e,text:t}:{text:t}}function ni(r){return r.map(e=>vr(e))}function si(r){return r.emotion?he.addEmotionTag(r.emotion,r.text):r.text}async function ai(r,e){let{blocks:t}=await r.chatOnce(e,!1,()=>{});return v.getFullText(t)}var Or=(r,e,t)=>{try{return JSON.parse(r)}catch(o){return t?.(r,o),e}},Y=(r,e)=>r?Or(r,{},e):{};var Er=(r,e)=>{try{return JSON.parse(r)}catch(t){if(e){e(r,t);return}throw t}},Uo=r=>typeof r=="string"?r:Array.isArray(r)?r.map(e=>typeof e=="string"?e:e&&typeof e=="object"&&e.type==="text"&&typeof e.text=="string"?e.text:"").join(""):"",Sr=async(r,e)=>{let t=r.body?.getReader();if(!t)throw new Error("Response body is null.");let o=new TextDecoder,i="",n=!1;for(;!n;){let{done:s,value:a}=await t.read();if(s)break;i+=o.decode(a,{stream:!0});let l=i.split(`
11
+ `);i=l.pop()||"";for(let c of l){let d=c.trim();if(!d||d.startsWith(":")||!d.startsWith("data:"))continue;let u=d.slice(5).trim();if(u==="[DONE]"){n=!0;break}e(u)}}};async function P(r,e,t={}){let o="";return await Sr(r,i=>{let n=Er(i,t.onJsonError);if(!n)return;let s=Uo(n.choices?.[0]?.delta?.content);s&&(e(s),o+=s)}),o}async function y(r,e,t={}){let o=[],i=new Map,n,s,a=t.appendTextBlock??v.append;await Sr(r,d=>{let u=Er(d,t.onJsonError);if(!u)return;let m=u.choices?.[0];typeof m?.finish_reason=="string"&&(n=m.finish_reason),u.usage&&(s=u.usage);let p=m?.delta,h=Uo(p?.content);h&&(e(h),a(o,h)),p?.tool_calls&&p.tool_calls.forEach(g=>{let C=i.get(g.index)??{id:g.id,name:g.function?.name,args:""};C.args+=g.function?.arguments||"",i.set(g.index,C)})});let l=Array.from(i.entries()).sort((d,u)=>d[0]-u[0]).map(([d,u])=>({type:"tool_use",id:u.id,name:u.name,input:Y(u.args,t.onJsonError)}));return{blocks:[...o,...l],stop_reason:l.length?"tool_use":"end",truncated:n==="length",finish_reason:n,usage:s}}function I(r,e={}){let t=r?.choices?.[0],o=[];if(t?.message?.tool_calls?.length)t.message.tool_calls.forEach(i=>o.push({type:"tool_use",id:i.id,name:i.function?.name,input:Y(i.function?.arguments,e.onJsonError)}));else{let i=Uo(t?.message?.content);i&&o.push({type:"text",text:i})}return{blocks:o,stop_reason:t?.finish_reason==="tool_calls"||o.some(i=>i.type==="tool_use")?"tool_use":"end",truncated:t?.finish_reason==="length",finish_reason:t?.finish_reason,usage:r?.usage}}var x=(r,e="chat-completions")=>r.length===0?[]:e==="responses"?r.map(t=>({type:"function",name:t.name,description:t.description,parameters:t.parameters})):r.map(t=>({type:"function",function:{name:t.name,description:t.description,parameters:t.parameters}}));async function M(r){if(!r.hasTools){let t=await r.runWithoutTools();await r.onCompleteResponse(t);return}let e=await r.runWithTools();if(r.onToolBlocks&&r.onToolBlocks(e.blocks),e.stop_reason==="end"){let t=v.getFullText(e.blocks);await r.onCompleteResponse(t);return}throw new Error(r.toolErrorMessage)}var O=r=>{let e=r.model??r.defaultModel,t=r.visionModel??(r.supportsVisionForModel(e)?e:r.defaultVisionModel);if(r.validate==="explicit"&&r.visionModel&&!r.supportsVisionForModel(r.visionModel))throw new Error(`Model ${r.visionModel} does not support vision capabilities.`);if(r.validate==="resolved"&&!r.supportsVisionForModel(t))throw new Error(`Model ${t} does not support vision capabilities.`);return t};var li="https://openrouter.ai/api/v1/models",pi=2,ci=12e3,ui=1,hi=10;function Ko(r){return r instanceof Error?r.message:String(r)}function Qt(r,e){return typeof r!="number"||!Number.isFinite(r)?e:Math.max(1,Math.floor(r))}function mi(r){let e=new Set,t=[];for(let o of r){let i=o.trim();!i||e.has(i)||(e.add(i),t.push(i))}return t}async function Cr(r,e,t){if(!(typeof AbortController<"u"))return fetch(r,e);let i=new AbortController,n=setTimeout(()=>i.abort(),t);try{return await fetch(r,{...e,signal:i.signal})}catch(s){throw s instanceof Error&&s.name==="AbortError"?new Error(`Timeout after ${t}ms`):s}finally{clearTimeout(n)}}async function Tr(r){let e=`HTTP ${r.status} ${r.statusText}`.trim(),t="";try{t=await r.text()}catch{return e}let o=t.replace(/\s+/g," ").trim().slice(0,200);return o?`${e}: ${o}`:e}function di(r){if(!r||typeof r!="object")throw new Error("Invalid models response shape");let e=r,t=Array.isArray(e.data)?e.data:Array.isArray(e.models)?e.models:[];if(t.length===0)return[];let o=t.map(i=>i.id).filter(i=>typeof i=="string");return mi(o)}async function gi({modelId:r,apiKey:e,endpoint:t,timeoutMs:o,appName:i,appUrl:n}){let s={Authorization:`Bearer ${e}`,"Content-Type":"application/json"};i&&(s["X-Title"]=i),n&&(s["HTTP-Referer"]=n);try{let a=await Cr(t,{method:"POST",headers:s,body:JSON.stringify({model:r,messages:[{role:"user",content:"Reply only with OK."}],stream:!1})},o);if(!a.ok)return{id:r,ok:!1,reason:await Tr(a)};try{await a.json()}catch(l){return{id:r,ok:!1,reason:`JSON parse failed: ${Ko(l)}`}}return{id:r,ok:!0}}catch(a){return{id:r,ok:!1,reason:Ko(a)}}}async function _i(r,e,t){if(r.length===0)return[];let o=new Array(r.length),i=0,n=Math.min(e,r.length);return await Promise.all(Array.from({length:n},async()=>{for(;i<r.length;){let s=i;i+=1,o[s]=await t(r[s])}})),o}async function fi(r){let e=r.apiKey.trim();if(!e)throw new Error("OpenRouter API key is required.");let t=r.modelsEndpoint||li,o=r.endpoint||Be,i=Qt(r.timeoutMs,ci),n=Qt(r.concurrency,pi),s=Qt(r.maxCandidates,ui),a=Qt(r.maxWorking,hi),l=await Cr(t,{method:"GET"},i);if(!l.ok)throw new Error(await Tr(l));let c;try{c=await l.json()}catch(h){throw new Error(`JSON parse failed: ${Ko(h)}`)}let d=di(c).filter(h=>J(h)).slice(0,s),u=await _i(d,n,h=>gi({modelId:h,apiKey:e,endpoint:o,timeoutMs:i,appName:r.appName,appUrl:r.appUrl})),m=u.filter(h=>h.ok).map(h=>h.id).slice(0,a),p=u.filter(h=>!h.ok).map(h=>({id:h.id,reason:h.reason||"Unknown error"}));return{working:m,failed:p,fetchedAt:Date.now()}}function Lr(r){return r.map(e=>({role:eo(e.role),content:e.content}))}function Pr(r){return r.map(e=>{if(typeof e.content=="string")return{role:eo(e.role),content:[{type:"text",text:e.content}]};if(Array.isArray(e.content)){let t=e.content.map(o=>{if(o.type==="image_url"){if(o.image_url.url.startsWith("data:")){let i=o.image_url.url.match(/^data:([^;]+);base64,(.+)$/);return i?{type:"image",source:{type:"base64",media_type:i[1],data:i[2]}}:null}return{type:"image",source:{type:"url",url:o.image_url.url,media_type:Mi(o.image_url.url)}}}return o}).filter(o=>o);return{role:eo(e.role),content:t}}return{role:eo(e.role),content:[]}})}function eo(r){switch(r){case"system":return"system";case"user":return"user";case"assistant":return"assistant";default:return"user"}}function Mi(r){switch(r.split(".").pop()?.toLowerCase()){case"jpg":case"jpeg":return"image/jpeg";case"png":return"image/png";case"gif":return"image/gif";case"webp":return"image/webp";default:return"image/jpeg"}}var me=class{constructor(e,t=R,o=R,i=[],n=[],s){this.provider="claude";if(this.apiKey=e,this.model=t||R,this.visionModel=o||R,this.tools=i,this.mcpServers=n,this.responseLength=s,!We.includes(this.visionModel))throw new Error(`Model ${this.visionModel} does not support vision capabilities.`)}getModel(){return this.model}getVisionModel(){return this.visionModel}getMCPServers(){return this.mcpServers}addMCPServer(e){this.mcpServers.push(e)}removeMCPServer(e){this.mcpServers=this.mcpServers.filter(t=>t.name!==e)}hasMCPServers(){return this.mcpServers.length>0}async processChat(e,t,o){await M({hasTools:this.tools.length>0||this.mcpServers.length>0,runWithoutTools:async()=>{let i=await this.callClaude(e,this.model,!0);return this.parsePureStream(i,t)},runWithTools:()=>this.chatOnce(e,!0,t),onCompleteResponse:o,toolErrorMessage:"processChat received tool_calls. ChatProcessor must use chatOnce() loop when tools are enabled."})}async processVisionChat(e,t,o){await M({hasTools:this.tools.length>0||this.mcpServers.length>0,runWithoutTools:async()=>{let i=await this.callClaude(e,this.visionModel,!0);return this.parsePureStream(i,t)},runWithTools:()=>this.visionChatOnce(e),onCompleteResponse:o,toolErrorMessage:"processVisionChat received tool_calls. ChatProcessor must use chatOnce() loop when tools are enabled."})}async callClaude(e,t,o,i){let n=e.find(u=>u.role==="system")?.content??"",s=e.filter(u=>u.role!=="system"),a=s.some(u=>Array.isArray(u.content)&&u.content.some(m=>m.type==="image_url"||m.type==="image")),l={model:t,system:n,messages:a?Pr(s):Lr(s),stream:o,max_tokens:i!==void 0?i:E(this.responseLength)};this.tools.length&&(l.tools=this.tools.map(u=>({name:u.name,description:u.description,input_schema:u.parameters})),l.tool_choice={type:"auto"}),this.mcpServers.length>0&&(l.mcp_servers=this.mcpServers);let c={"Content-Type":"application/json","x-api-key":this.apiKey,"anthropic-version":"2023-06-01","anthropic-dangerous-direct-browser-access":"true"};return this.mcpServers.length>0&&(c["anthropic-beta"]="mcp-client-2025-04-04"),await f.post(co,l,c)}async parseStream(e,t){let o=e.body.getReader(),i=new TextDecoder,n=[],s=new Map,a="";for(;;){let{done:l,value:c}=await o.read();if(l)break;a+=i.decode(c,{stream:!0});let d;for(;(d=a.indexOf(`
12
+ `))!==-1;){let u=a.slice(0,d).trim();if(a=a.slice(d+1),!u.startsWith("data:"))continue;let m=u.slice(5).trim();if(m==="[DONE]")break;let p=JSON.parse(m);if(p.type==="content_block_delta"&&p.delta?.text&&(t(p.delta.text),n.push({type:"text",text:p.delta.text})),p.type==="content_block_start"&&p.content_block?.type==="tool_use"?s.set(p.index,{id:p.content_block.id,name:p.content_block.name,args:""}):p.type==="content_block_start"&&p.content_block?.type==="mcp_tool_use"?s.set(p.index,{id:p.content_block.id,name:p.content_block.name,args:"",server_name:p.content_block.server_name}):p.type==="content_block_start"&&p.content_block?.type==="tool_result"?n.push({type:"tool_result",tool_use_id:p.content_block.tool_use_id,content:p.content_block.content??""}):p.type==="content_block_start"&&p.content_block?.type==="mcp_tool_result"&&n.push({type:"mcp_tool_result",tool_use_id:p.content_block.tool_use_id,is_error:p.content_block.is_error??!1,content:p.content_block.content??[]}),p.type==="content_block_delta"&&p.delta?.type==="input_json_delta"){let h=s.get(p.index);h&&(h.args+=p.delta.partial_json||"")}if(p.type==="content_block_stop"&&s.has(p.index)){let{id:h,name:g,args:C,server_name:k}=s.get(p.index);k?n.push({type:"mcp_tool_use",id:h,name:g,server_name:k,input:JSON.parse(C||"{}")}):n.push({type:"tool_use",id:h,name:g,input:JSON.parse(C||"{}")}),s.delete(p.index)}}}return{blocks:n,stop_reason:n.some(l=>l.type==="tool_use"||l.type==="mcp_tool_use")?"tool_use":"end"}}async parsePureStream(e,t){let{blocks:o}=await this.parseStream(e,t);return o.filter(i=>i.type==="text").map(i=>i.text).join("")}parseOneShot(e){let t=[];return(e.content??[]).forEach(o=>{o.type==="text"?t.push({type:"text",text:o.text}):o.type==="tool_use"?t.push({type:"tool_use",id:o.id,name:o.name,input:o.input??{}}):o.type==="mcp_tool_use"?t.push({type:"mcp_tool_use",id:o.id,name:o.name,server_name:o.server_name,input:o.input??{}}):o.type==="tool_result"?t.push({type:"tool_result",tool_use_id:o.tool_use_id,content:o.content??""}):o.type==="mcp_tool_result"&&t.push({type:"mcp_tool_result",tool_use_id:o.tool_use_id,is_error:o.is_error??!1,content:o.content??[]})}),{blocks:t,stop_reason:t.some(o=>o.type==="tool_use"||o.type==="mcp_tool_use")?"tool_use":"end"}}async chatOnce(e,t=!0,o=()=>{},i){let n=await this.callClaude(e,this.model,t,i),s=t?await this.parseStream(n,o):this.parseOneShot(await n.json());return this.convertToStandardCompletion(s)}async visionChatOnce(e,t=!1,o=()=>{},i){let n=await this.callClaude(e,this.visionModel,t,i),s=t?await this.parseStream(n,o):this.parseOneShot(await n.json());return this.convertToStandardCompletion(s)}convertToStandardCompletion(e){return{blocks:e.blocks.filter(o=>o.type==="text"||o.type==="tool_use"||o.type==="tool_result"),stop_reason:e.stop_reason}}};var de=class{createChatService(e){let t=O({model:e.model,visionModel:e.visionModel,defaultModel:this.getDefaultModel(),defaultVisionModel:this.getDefaultModel(),supportsVisionForModel:o=>this.supportsVisionForModel(o),validate:"resolved"});return new me(e.apiKey,e.model||this.getDefaultModel(),t,e.tools??[],e.mcpServers??[],e.responseLength)}getProviderName(){return"claude"}getSupportedModels(){return[ct,ut,ht,R,mt,dt,gt,_t,ft,pt]}getDefaultModel(){return R}supportsVision(){return this.getVisionSupportLevel()!=="unsupported"}getVisionSupportLevel(){return"supported"}supportsVisionForModel(e){return We.includes(e)}getVisionSupportLevelForModel(e){return this.supportsVisionForModel(e)?"supported":"unsupported"}};async function to(r,e,t={}){let o=r.body.getReader(),i=new TextDecoder,n=[],s=new Map,a,l,c,d="";for(;;){let{done:m,value:p}=await o.read();if(m)break;d+=i.decode(p,{stream:!0});let h="",g="",C=d.split(`
13
+ `);d=C.pop()||"";for(let k=0;k<C.length;k++){let _=C[k].trim();if(_.startsWith("event:"))h=_.slice(6).trim();else if(_.startsWith("data:"))g=_.slice(5).trim();else if(_===""&&h&&g){try{let D=JSON.parse(g);vi(h,D,e,n,s,t,L=>{L.responseStatus!==void 0&&(a=L.responseStatus),L.incompleteDetails!==void 0&&(l=L.incompleteDetails),L.usage!==void 0&&(c=L.usage)})}catch(D){t.onJsonError?.(g,D),console.warn("Failed to parse SSE data:",g)}h="",g=""}}}let u=Array.from(s.values()).map(m=>({type:"tool_use",id:m.id,name:m.name,input:m.input||{}}));return{blocks:[...n,...u],stop_reason:u.length?"tool_use":"end",truncated:a==="incomplete",response_status:a,incomplete_details:l,usage:c}}function vi(r,e,t,o,i,n,s){switch(r){case"response.output_item.added":e.item?.type==="message"&&Array.isArray(e.item.content)?e.item.content.forEach(a=>{a.type==="output_text"&&a.text&&(t(a.text),v.append(o,a.text))}):e.item?.type==="function_call"&&i.set(e.item.id,{id:e.item.id,name:e.item.name,input:Y(e.item.arguments,n.onJsonError)});break;case"response.content_part.added":e.part?.type==="output_text"&&typeof e.part.text=="string"&&(t(e.part.text),v.append(o,e.part.text));break;case"response.output_text.delta":case"response.content_part.delta":{let a=typeof e.delta=="string"?e.delta:e.delta?.text??"";a&&(t(a),v.append(o,a));break}case"response.output_text.done":case"response.content_part.done":case"response.reasoning.started":case"response.reasoning.delta":case"response.reasoning.done":break;case"response.completed":s(yr(e,"completed"));break;case"response.incomplete":s(yr(e,"incomplete"));break;default:break}}function yr(r,e){let t=r?.response??r;return{responseStatus:t?.status??e,incompleteDetails:t?.incomplete_details??null,usage:t?.usage}}function Ir(r,e={}){let t=[];return r.output&&Array.isArray(r.output)&&r.output.forEach(o=>{o.type==="message"&&o.content&&o.content.forEach(i=>{i.type==="output_text"&&i.text&&t.push({type:"text",text:i.text})}),o.type==="function_call"&&t.push({type:"tool_use",id:o.id,name:o.name,input:Y(o.arguments,e.onJsonError)})}),{blocks:t,stop_reason:t.some(o=>o.type==="tool_use")?"tool_use":"end",truncated:r?.status==="incomplete",response_status:r?.status,incomplete_details:r?.incomplete_details??null,usage:r?.usage}}function xr({tools:r,mcpServers:e,isResponsesAPI:t}){let o=[];return r.length>0&&o.push(...x(r,t?"responses":"chat-completions")),e.length>0&&t&&o.push(...Oi(e)),o}function Oi(r){return r.map(e=>{let t={type:"mcp",server_label:e.name,server_url:e.url};return e.require_approval&&(t.require_approval=e.require_approval),e.tool_configuration?.allowed_tools&&(t.allowed_tools=e.tool_configuration.allowed_tools),e.authorization_token&&(t.headers={Authorization:`Bearer ${e.authorization_token}`}),t})}var Ei={[T.VERY_SHORT]:800,[T.SHORT]:1200,[T.MEDIUM]:2e3,[T.LONG]:3e3,[T.VERY_LONG]:8e3,[T.DEEP]:25e3},Si={none:1200,minimal:1600,low:2500,medium:4e3,high:8e3,xhigh:12e3},Ci=new Set(["openai-compatible","deepseek","mistral","sakana","plamo"]);function Dr({provider:r,endpoint:e,messages:t,model:o,stream:i,tools:n,mcpServers:s,responseLength:a,verbosity:l,reasoning_effort:c,enableReasoningSummary:d,maxTokens:u}){let m=e===A;Li(e,s);let p={model:o,stream:i},h=Ti({provider:r,model:o,responseLength:a,reasoning_effort:c,maxTokens:u});m?h!==void 0&&(p.max_output_tokens=h):h!==void 0&&(Ar(r)?p.max_tokens=h:p.max_completion_tokens=h),m?p.input=Pi(t):p.messages=r==="mistral"?yi(t):t,q(o)&&(m?(c&&(p.reasoning={...p.reasoning,effort:c},d&&(p.reasoning.summary="auto")),l&&(p.text={...p.text,format:{type:"text"},verbosity:l})):(c&&(p.reasoning_effort=c),l&&(p.verbosity=l))),r==="mistral"&&Ye(o)&&c&&Ro(c)&&(p.reasoning_effort=c),r==="plamo"&&c&&(p.reasoning_effort=c);let g=xr({tools:n,mcpServers:s,isResponsesAPI:m});return g.length>0&&(p.tools=g,m||(p.tool_choice="auto")),p}function Ti({provider:r,model:e,responseLength:t,reasoning_effort:o,maxTokens:i}){if(i!==void 0)return i;let n=Ar(r)?t!==void 0?E(t):void 0:E(t);if(r!=="openai"||!q(e)||t===void 0)return n;let s=o??Ke(e);return Math.max(n??0,Ei[t],Si[s])}function Li(r,e){if(e.length>0&&r===U)throw new Error(`MCP servers are not supported with Chat Completions API. Current endpoint: ${r}. Please use OpenAI Responses API endpoint: ${A}. MCP tools are only available in the Responses API endpoint.`)}function Pi(r){return r.map(e=>{let o={role:e.role==="tool"?"user":e.role};return typeof e.content=="string"?o.content=e.content:Array.isArray(e.content)?o.content=e.content.map(i=>i.type==="text"?{type:"input_text",text:i.text}:i.type==="image_url"?{type:"input_image",image_url:i.image_url.url}:i):o.content=e.content,o})}function yi(r){return r.map(e=>{let t={role:e.role};return Array.isArray(e.content)?(t.content=e.content.map(o=>o.type==="image_url"&&typeof o.image_url=="object"&&typeof o.image_url?.url=="string"?{type:"image_url",image_url:o.image_url.url}:o),t):(t.content=e.content,t)})}function Ar(r){return Ci.has(r)}var S=class{constructor(e,t=z,o=z,i,n=U,s=[],a,l,c,d=!1,u="openai",m=!0){if(this.provider=u,this.apiKey=e,this.model=t,this.tools=i||[],this.endpoint=n,this.mcpServers=s,this.responseLength=a,this.verbosity=l,this.reasoning_effort=c,this.enableReasoningSummary=d,m&&!Ge.includes(o))throw new Error(`Model ${o} does not support vision capabilities.`);this.visionModel=o}getModel(){return this.model}getVisionModel(){return this.visionModel}async processChat(e,t,o){await M({hasTools:this.tools.length>0,runWithoutTools:async()=>{let i=await this.callOpenAI(e,this.model,!0),n=this.endpoint===A;try{if(n){let s=await to(i,t);return v.getFullText(s.blocks)}return this.handleStream(i,t)}catch(s){throw console.error("[processChat] Error in streaming/completion:",s),s}},runWithTools:()=>this.chatOnce(e,!0,t),onCompleteResponse:o,toolErrorMessage:"processChat received tool_calls. ChatProcessor must use chatOnce() loop when tools are enabled."})}async processVisionChat(e,t,o){try{await M({hasTools:this.tools.length>0,runWithoutTools:async()=>{let i=await this.callOpenAI(e,this.visionModel,!0),n=this.endpoint===A;try{if(n){let s=await to(i,t);return v.getFullText(s.blocks)}return this.handleStream(i,t)}catch(s){throw console.error("[processVisionChat] Error in streaming/completion:",s),s}},runWithTools:()=>this.visionChatOnce(e,!0,t),onCompleteResponse:o,toolErrorMessage:"processVisionChat received tool_calls. ChatProcessor must use visionChatOnce() loop when tools are enabled."})}catch(i){throw console.error("Error in processVisionChat:",i),i}}async chatOnce(e,t=!0,o=()=>{},i){let n=await this.callOpenAI(e,this.model,t,i);return this.parseResponse(n,t,o)}async visionChatOnce(e,t=!1,o=()=>{},i){let n=await this.callOpenAI(e,this.visionModel,t,i);return this.parseResponse(n,t,o)}async parseResponse(e,t,o){return this.endpoint===A?t?to(e,o):Ir(await e.json()):t?this.parseStream(e,o):this.parseOneShot(await e.json())}async callOpenAI(e,t,o=!1,i){let n=Dr({provider:this.provider,endpoint:this.endpoint,messages:e,model:t,stream:o,tools:this.tools,mcpServers:this.mcpServers,responseLength:this.responseLength,verbosity:this.verbosity,reasoning_effort:this.reasoning_effort,enableReasoningSummary:this.enableReasoningSummary,maxTokens:i}),s={};return(this.provider!=="openai-compatible"||this.apiKey.trim()!=="")&&(s.Authorization=`Bearer ${this.apiKey}`),await f.post(this.endpoint,n,s)}async handleStream(e,t){return P(e,t)}async parseStream(e,t){return y(e,t,{appendTextBlock:v.addTextBlock})}parseOneShot(e){return I(e)}};var ge=class extends S{constructor(e,t=pe,o=t,i,n=Xe,s){super(e,t,o,i,n,[],s,void 0,void 0,!1,"deepseek",!1)}};var _e=class{createChatService(e){this.validateRequiredOptions(e);let t=e.model||this.getDefaultModel(),o=e.tools;return new ge(e.apiKey,t,e.visionModel??t,o,this.resolveEndpoint(e),e.responseLength)}getProviderName(){return"deepseek"}getSupportedModels(){return[...Po]}getDefaultModel(){return pe}supportsVision(){return!1}getVisionSupportLevel(){return"unsupported"}supportsVisionForModel(e){return!1}getVisionSupportLevelForModel(e){return"unsupported"}validateRequiredOptions(e){if(!e.apiKey?.trim())throw new Error("deepseek provider requires apiKey.")}resolveEndpoint(e){if(e.endpoint)return this.normalizeUrl(e.endpoint);if(e.baseUrl){let t=this.normalizeUrl(e.baseUrl);return t.endsWith("/chat/completions")?t:`${t}/chat/completions`}return Xe}normalizeUrl(e){return e.trim().replace(/\/+$/,"")}};var Rr=(r,e)=>({name:`mcp_${r.name}_search`,description:e==="schema-fetch-failed"?`Search using ${r.name} MCP server (schema fetch failed)`:`Search using ${r.name} MCP server`,parameters:{type:"object",properties:{query:{type:"string",description:"Search query"}},required:["query"]}}),oo=class{static async fetchToolSchemas(e){return(await this.fetchToolSchemasWithStatus(e)).schemas}static async fetchToolSchemasWithStatus(e){try{let t={"Content-Type":"application/json"};e.authorization_token&&(t.Authorization=`Bearer ${e.authorization_token}`);let i=await(await f.post(`${e.url}/tools`,{},t)).json();return Array.isArray(i.tools)?{schemas:i.tools.map(n=>({name:`mcp_${e.name}_${n.name}`,description:n.description||`Tool from ${e.name} MCP server`,parameters:n.inputSchema||{type:"object",properties:{},required:[]}})),failures:[]}:{schemas:[Rr(e)],failures:[]}}catch(t){return console.warn(`Failed to fetch MCP schemas from ${e.name}:`,t),{schemas:[Rr(e,"schema-fetch-failed")],failures:[{server:e,error:t}]}}}static async fetchAllToolSchemas(e){return(await this.fetchAllToolSchemasWithStatus(e)).schemas}static async fetchAllToolSchemasWithStatus(e){let t=[],o=[];for(let i of e)try{let n=await this.fetchToolSchemasWithStatus(i);t.push(...n.schemas),o.push(...n.failures)}catch(n){console.error(`Failed to fetch schemas from ${i.name}:`,n),o.push({server:i,error:n})}return{schemas:t,failures:o}}};function br(r){switch(r){case"system":return"model";case"user":return"user";case"assistant":return"model";default:return"user"}}function Nr(r,e={}){let t=[],o=null,i=[],n=()=>{o&&i.length&&(t.push({role:o,parts:[...i]}),i=[])};for(let s of r){let a=br(s.role);if(s.tool_calls){n();for(let l of s.tool_calls)e.callIdMap?.set(l.id,l.function.name),t.push({role:"model",parts:[{functionCall:{name:l.function.name,args:JSON.parse(l.function.arguments||"{}")}}]});continue}if(s.role==="tool"){n();let l=s.name??e.callIdMap?.get(s.tool_call_id)??"result";t.push({role:"user",parts:[{functionResponse:{name:l,response:kr(Vr(s.content))}}]});continue}a!==o&&n(),o=a,i.push({text:s.content})}return n(),t}async function wr(r,e={}){let t=e.imageFetcher??f.get,o=e.blobToBase64??Ii,i=[],n=null,s=[];for(let a of r){let l=br(a.role);if(a.tool_calls){for(let c of a.tool_calls)i.push({role:"model",parts:[{functionCall:{name:c.function.name,args:JSON.parse(c.function.arguments||"{}")}}]});continue}if(a.role==="tool"){let c=a.name??e.callIdMap?.get(a.tool_call_id)??"result";i.push({role:"user",parts:[{functionResponse:{name:c,response:kr(Vr(a.content))}}]});continue}if(l!==n&&s.length>0&&(i.push({role:n,parts:[...s]}),s=[]),n=l,typeof a.content=="string")s.push({text:a.content});else if(Array.isArray(a.content)){for(let c of a.content)if(c.type==="text")s.push({text:c.text});else if(c.type==="image_url")try{let u=await(await t(c.image_url.url)).blob(),m=await o(u);s.push({inlineData:{mimeType:u.type||"image/jpeg",data:m.split(",")[1]}})}catch(d){throw console.error("Error processing image:",d),new Error(`Failed to process image: ${d.message}`)}}}return n&&s.length>0&&i.push({role:n,parts:[...s]}),i}function Vr(r){try{return JSON.parse(r)}catch{return r}}function kr(r){return r===null?{content:null}:typeof r=="object"?r:{content:r}}function Ii(r){return new Promise((e,t)=>{let o=new FileReader;o.onloadend=()=>e(o.result),o.onerror=t,o.readAsDataURL(r)})}function xi(r,e){return[...r,...e].map(t=>({name:t.name,description:t.description,parameters:t.parameters}))}function Gr(r,e){let t=xi(r,e);if(t.length!==0)return{tools:[{functionDeclarations:t}],toolConfig:{functionCallingConfig:{mode:"AUTO"}}}}function Fr(r){return r.map(e=>({name:`mcp_${e.name}_search`,description:`Search using ${e.name} MCP server (fallback)`,parameters:{type:"object",properties:{query:{type:"string",description:"Search query"}},required:["query"]}}))}var fe=class{constructor(e,t=j,o=j,i=[],n=[],s){this.provider="gemini";this.mcpToolSchemas=[];this.mcpSchemasInitialized=!1;this.callIdMap=new Map;if(this.apiKey=e,this.model=t,this.responseLength=s,!He.includes(o))throw new Error(`Model ${o} does not support vision capabilities.`);this.visionModel=o,this.tools=i,this.mcpServers=n}isGemma4Model(e){return/^gemma-4-/.test(e)}shouldMinimizeThinking(e){return e===at||this.isGemma4Model(e)}shouldExposeTextPart(e,t){return!(!e.text||this.isGemma4Model(t)&&e.thought===!0)}adaptKeysForApi(e){let t={toolConfig:"tool_config",functionCallingConfig:"function_calling_config",functionDeclarations:"function_declarations",functionCall:"function_call",functionResponse:"function_response"};return Array.isArray(e)?e.map(o=>this.adaptKeysForApi(o)):e&&typeof e=="object"?Object.fromEntries(Object.entries(e).map(([o,i])=>[t[o]??o,this.adaptKeysForApi(i)])):e}getModel(){return this.model}getVisionModel(){return this.visionModel}getMCPServers(){return this.mcpServers}addMCPServer(e){this.mcpServers.push(e),this.mcpSchemasInitialized=!1,this.mcpSchemaInitializationError=void 0}removeMCPServer(e){this.mcpServers=this.mcpServers.filter(t=>t.name!==e),this.mcpSchemasInitialized=!1,this.mcpSchemaInitializationError=void 0}hasMCPServers(){return this.mcpServers.length>0}getMCPSchemaInitializationError(){return this.mcpSchemaInitializationError}async initializeMCPSchemas(){if(!(this.mcpSchemasInitialized||this.mcpServers.length===0))try{let e=new Promise((i,n)=>setTimeout(()=>n(new Error("MCP schema fetch timeout")),5e3)),t=oo.fetchAllToolSchemasWithStatus(this.mcpServers),o=await Promise.race([t,e]);this.mcpToolSchemas=o.schemas,this.mcpSchemasInitialized=!0,this.mcpSchemaInitializationError=o.failures[0]?.error}catch(e){console.warn("Failed to initialize MCP schemas, using fallback:",e),this.mcpSchemaInitializationError=e,this.mcpToolSchemas=Fr(this.mcpServers),this.mcpSchemasInitialized=!0}}async processChat(e,t,o){try{await M({hasTools:this.tools.length>0||this.mcpServers.length>0,runWithoutTools:async()=>{let i=await this.callGemini(e,this.model,!0),{blocks:n}=await this.parseStream(i,t,this.model);return v.getFullText(n)},runWithTools:()=>this.chatOnce(e,!0,t),onCompleteResponse:o,toolErrorMessage:"Received functionCall. Use chatOnce() loop when tools are enabled."})}catch(i){throw console.error("Error in processChat:",i),i}}async processVisionChat(e,t,o){try{await M({hasTools:this.tools.length>0||this.mcpServers.length>0,runWithoutTools:async()=>{let i=await this.callGemini(e,this.visionModel,!0),{blocks:n}=await this.parseStream(i,t,this.visionModel);return v.getFullText(n)},runWithTools:()=>this.visionChatOnce(e),onToolBlocks:i=>{i.filter(n=>n.type==="text").forEach(n=>t(n.text))},onCompleteResponse:o,toolErrorMessage:"Received functionCall. Use visionChatOnce() loop when tools are enabled."})}catch(i){throw console.error("Error in processVisionChat:",i),i}}async callGemini(e,t,o=!1,i){let a={contents:e.some(_=>Array.isArray(_.content)&&_.content.some(D=>D?.type==="image_url"||D?.inlineData))?await wr(e,{callIdMap:this.callIdMap}):Nr(e,{callIdMap:this.callIdMap}),generationConfig:{maxOutputTokens:i!==void 0?i:E(this.responseLength)}};this.shouldMinimizeThinking(t)&&(a.generationConfig.thinkingConfig={includeThoughts:!1,thinkingLevel:"MINIMAL"});let l=[];if(this.mcpServers.length>0)try{await this.initializeMCPSchemas(),l=this.mcpToolSchemas}catch(_){console.warn("MCP initialization failed, skipping MCP tools:",_)}let c=Gr(this.tools,l);c&&Object.assign(a,c);let d=async(_,D)=>{let L=o?"streamGenerateContent":"generateContent",Ho=o?"?alt=sse":"",Hr=`${po}/${_}/models/${t}:${L}${Ho}${Ho?"&":"?"}key=${this.apiKey}`;return f.post(Hr,D)},u=/flash[-_]lite/.test(t),m=this.isGemma4Model(t),p=/gemini-2\.5/.test(t),h=/^gemini-3(?:\.[0-9]+)?-/.test(t),g=u||m||p||h,C=g?"v1beta":"v1",k=async()=>{try{let _=C==="v1"?a:this.adaptKeysForApi(a);return await d(C,_)}catch(_){let D=/Unknown name|Cannot find field|404/.test(_?.message||"")||_?.status===404;if(!g&&D)try{return await d("v1beta",this.adaptKeysForApi(a))}catch(L){throw L instanceof Error&&(L.cause=_),L}throw _}};try{return await k()}catch(_){throw _.body&&(console.error("Gemini API Error Details:",_.body),console.error("Request Body:",JSON.stringify(a,null,2))),_}}async parseStream(e,t,o){let i=e.body.getReader(),n=new TextDecoder,s=[],a=[],l="",c=u=>{if(!u||u==="[DONE]")return;let m;try{m=JSON.parse(u)}catch{return}for(let p of m.candidates??[])for(let h of p.content?.parts??[])this.shouldExposeTextPart(h,o)&&(t(h.text),v.addTextBlock(s,h.text)),h.functionCall&&a.push({type:"tool_use",id:this.genUUID(),name:h.functionCall.name,input:h.functionCall.args??{}}),h.functionResponse&&a.push({type:"tool_result",tool_use_id:h.functionResponse.name,content:JSON.stringify(h.functionResponse.response)})};for(;;){let{done:u,value:m}=await i.read();if(u)break;l+=n.decode(m,{stream:!0});let p;for(;(p=l.indexOf(`
14
+ `))!==-1;){let h=l.slice(0,p);if(l=l.slice(p+1),h.endsWith("\r")&&(h=h.slice(0,-1)),!h.trim()){c("");continue}h.startsWith("data:")&&(h=h.slice(5).trim()),h&&c(h)}}return l&&c(l),{blocks:[...s,...a],stop_reason:a.some(u=>u.type==="tool_use")?"tool_use":"end"}}parseOneShot(e,t){let o=[],i=[];for(let s of e.candidates??[])for(let a of s.content?.parts??[])this.shouldExposeTextPart(a,t)&&o.push({type:"text",text:a.text}),a.functionCall&&i.push({type:"tool_use",id:this.genUUID(),name:a.functionCall.name,input:a.functionCall.args??{}}),a.functionResponse&&i.push({type:"tool_result",tool_use_id:a.functionResponse.name,content:JSON.stringify(a.functionResponse.response)});return{blocks:[...o,...i],stop_reason:i.some(s=>s.type==="tool_use")?"tool_use":"end"}}async chatOnce(e,t=!0,o=()=>{},i){let n=await this.callGemini(e,this.model,t,i);return t?this.parseStream(n,o,this.model):this.parseOneShot(await n.json(),this.model)}async visionChatOnce(e,t=!1,o=()=>{},i){let n=await this.callGemini(e,this.visionModel,t,i);return t?this.parseStream(n,o,this.visionModel):this.parseOneShot(await n.json(),this.visionModel)}genUUID(){return typeof crypto<"u"&&crypto.randomUUID?crypto.randomUUID():"xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx".replace(/[xy]/g,e=>{let t=Math.random()*16|0;return(e==="x"?t:t&3|8).toString(16)})}};var Me=class{createChatService(e){let t=O({model:e.model,visionModel:e.visionModel,defaultModel:this.getDefaultModel(),defaultVisionModel:this.getDefaultModel(),supportsVisionForModel:o=>this.supportsVisionForModel(o),validate:"resolved"});return new fe(e.apiKey,e.model||this.getDefaultModel(),t,e.tools||[],e.mcpServers||[],e.responseLength)}getProviderName(){return"gemini"}getSupportedModels(){return[...lt]}getDefaultModel(){return j}supportsVision(){return this.getVisionSupportLevel()!=="unsupported"}getVisionSupportLevel(){return"supported"}supportsVisionForModel(e){return He.includes(e)}getVisionSupportLevelForModel(e){return this.supportsVisionForModel(e)?"supported":"unsupported"}};function Di(){if(typeof globalThis<"u"&&"LanguageModel"in globalThis)return globalThis.LanguageModel}var ve=class{constructor(e={}){this.provider="gemini-nano";this.expectedInputLanguages=e.expectedInputLanguages??["ja"],this.expectedOutputLanguages=e.expectedOutputLanguages??["ja"],this._responseLength=e.responseLength}getModel(){return Z}getVisionModel(){return Z}async processChat(e,t,o){let i=await this.generateResponse(e);t(i),await o(i)}async processVisionChat(e,t,o){throw new Error("Gemini Nano does not support vision capabilities.")}async chatOnce(e,t=!1,o=()=>{},i){let n=await this.generateResponse(e);return o(n),{blocks:[{type:"text",text:n}],stop_reason:"end"}}async visionChatOnce(e,t=!1,o=()=>{},i){throw new Error("Gemini Nano does not support vision capabilities.")}async generateResponse(e){let t=Di();if(!t)throw new Error("Gemini Nano is not available in this environment. Chrome 138+ with Prompt API enabled is required.");let o=await t.availability();if(o!=="available"&&o!=="downloadable")throw new Error(`Gemini Nano Prompt API is not ready in this environment. LanguageModel.availability() returned "${o}". Expected "available" or "downloadable".`);let n=e.filter(c=>c.role==="system").map(c=>c.content).join(`
15
+ `),s=e.filter(c=>c.role!=="system").slice(-20),a=[...s].reverse().find(c=>c.role==="user");if(!a)throw new Error("No user message found in the provided messages.");let l=await this.createSession(t,n,s);try{return await l.prompt(a.content)}finally{try{l.destroy()}catch{}}}async createSession(e,t,o){let i=this.buildSystemPrompt(t),n=o.slice(0,-1);if(n.length>0){let s=n.map(a=>`${a.role==="user"?"User":"Assistant"}: ${a.content}`).join(`
16
+ `);i+=`
17
17
 
18
18
  The following is the prior conversation history. Use it as context for your response:
19
- `+s}return e.create({systemPrompt:r,expectedInputs:[{type:"text",languages:this.expectedInputLanguages}],expectedOutputs:[{type:"text",languages:this.expectedOutputLanguages}]})}buildSystemPrompt(e){let t=[];e&&t.push(e);let o=this.getResponseLengthInstruction();return o&&t.push(o),t.join(`
19
+ `+s}return e.create({systemPrompt:i,expectedInputs:[{type:"text",languages:this.expectedInputLanguages}],expectedOutputs:[{type:"text",languages:this.expectedOutputLanguages}]})}buildSystemPrompt(e){let t=[];e&&t.push(e);let o=this.getResponseLengthInstruction();return o&&t.push(o),t.join(`
20
20
 
21
- `)}getResponseLengthInstruction(){if(!this._responseLength)return;let e=Bt[this._responseLength];if(e)return`Please keep your response concise, within approximately ${e} tokens.`}};var Me=class{createChatService(e){return new fe({expectedInputLanguages:e.expectedInputLanguages,expectedOutputLanguages:e.expectedOutputLanguages,responseLength:e.responseLength})}getProviderName(){return"gemini-nano"}getSupportedModels(){return[Z]}getDefaultModel(){return Z}supportsVision(){return!1}getVisionSupportLevel(){return"unsupported"}};var ve=class{constructor(e,t=w,o=w,r,n=ae,s,a,l){this.provider="kimi";this.apiKey=e,this.model=t,this.tools=r||[],this.endpoint=n,this.responseLength=s,this.responseFormat=a,this.thinking=l??{type:"enabled"},this.visionModel=o}getModel(){return this.model}getVisionModel(){return this.visionModel}async processChat(e,t,o){await M({hasTools:this.tools.length>0,runWithoutTools:async()=>{let r=await this.callKimi(e,this.model,!0);return this.handleStream(r,t)},runWithTools:()=>this.chatOnce(e,!0,t),onCompleteResponse:o,toolErrorMessage:"processChat received tool_calls. ChatProcessor must use chatOnce() loop when tools are enabled."})}async processVisionChat(e,t,o){if(!le(this.visionModel))throw new Error(`Model ${this.visionModel} does not support vision capabilities.`);await M({hasTools:this.tools.length>0,runWithoutTools:async()=>{let r=await this.callKimi(e,this.visionModel,!0);return this.handleStream(r,t)},runWithTools:()=>this.visionChatOnce(e,!0,t),onCompleteResponse:o,toolErrorMessage:"processVisionChat received tool_calls. ChatProcessor must use visionChatOnce() loop when tools are enabled."})}async chatOnce(e,t=!0,o=()=>{},r){let n=await this.callKimi(e,this.model,t,r);return this.parseResponse(n,t,o)}async visionChatOnce(e,t=!1,o=()=>{},r){if(!le(this.visionModel))throw new Error(`Model ${this.visionModel} does not support vision capabilities.`);let n=await this.callKimi(e,this.visionModel,t,r);return this.parseResponse(n,t,o)}async parseResponse(e,t,o){return t?this.parseStream(e,o):this.parseOneShot(await e.json())}async callKimi(e,t,o=!1,r){let n=this.buildRequestBody(e,t,o,r);return await f.post(this.endpoint,n,{Authorization:`Bearer ${this.apiKey}`})}buildRequestBody(e,t,o,r){let n={model:t,stream:o,messages:e},s=r!==void 0?r:O(this.responseLength);s!==void 0&&(n.max_tokens=s),this.responseFormat&&(n.response_format=this.responseFormat);let a=this.resolveEffectiveThinking(t);a&&(this.isSelfHostedEndpoint()?a.type==="disabled"&&(n.chat_template_kwargs={thinking:!1}):n.thinking=a);let l=this.buildToolsDefinition();return l.length>0&&(n.tools=l,n.tool_choice="auto"),n}isSelfHostedEndpoint(){return this.normalizeEndpoint(this.endpoint)!==this.normalizeEndpoint(ae)}normalizeEndpoint(e){return e.replace(/\/+$/,"")}resolveEffectiveThinking(e){if(We(e)){if(this.thinking?.type==="disabled")throw new Error(`Model ${e} requires thinking mode and does not support thinking: disabled.`);return this.thinking??{type:"enabled"}}return this.tools.length>0?{type:"disabled"}:this.thinking}buildToolsDefinition(){return x(this.tools,"chat-completions")}async handleStream(e,t){return L(e,t,{onJsonError:o=>console.debug("Failed to parse SSE data:",o)})}async parseStream(e,t){return P(e,t,{onJsonError:o=>console.debug("Failed to parse SSE data:",o)})}parseOneShot(e){return I(e)}};var Ee=class{constructor(){this.defaultThinking={type:"enabled"}}createChatService(e){let t=this.resolveEndpoint(e),o=e.model||this.getDefaultModel(),r=E({model:o,visionModel:e.visionModel,defaultModel:this.getDefaultModel(),defaultVisionModel:this.getDefaultVisionModel(),supportsVisionForModel:a=>this.supportsVisionForModel(a),validate:"explicit"}),n=e.tools,s=this.resolveThinking(o,n,e.thinking);return new ve(e.apiKey,o,r,n,t,e.responseLength,e.responseFormat,s)}getProviderName(){return"kimi"}getSupportedModels(){return[He,Ke,w,Kt]}getDefaultModel(){return w}getDefaultVisionModel(){return w}supportsVision(){return this.getVisionSupportLevel()!=="unsupported"}getVisionSupportLevel(){return"supported"}supportsVisionForModel(e){return le(e)}getVisionSupportLevelForModel(e){return this.supportsVisionForModel(e)?"supported":"unsupported"}resolveEndpoint(e){if(e.endpoint)return this.normalizeEndpoint(e.endpoint);if(e.baseUrl){let t=this.normalizeEndpoint(e.baseUrl);return t.endsWith("/chat/completions")?t:`${t}/chat/completions`}return ae}normalizeEndpoint(e){return e.replace(/\/+$/,"")}resolveThinking(e,t,o){if(We(e)){if(o?.type==="disabled")throw new Error(`Model ${e} requires thinking mode and does not support thinking: disabled.`);return o??this.defaultThinking}return t&&t.length>0?{type:"disabled"}:o??this.defaultThinking}};var Oe=class extends y{constructor(e,t=V,o=t,r,n=$e,s,a){super(e,t,o,r,n,[],s,void 0,a,!1,"mistral",!1)}};var Se=class{createChatService(e){this.validateRequiredOptions(e);let t=e.model||this.getDefaultModel(),o=E({model:t,visionModel:e.visionModel,defaultModel:this.getDefaultModel(),defaultVisionModel:this.getDefaultVisionModel(),supportsVisionForModel:s=>this.supportsVisionForModel(s),validate:"explicit"}),r=e.tools,n=ze(t)?e.reasoning_effort:void 0;return new Oe(e.apiKey,t,o,r,this.resolveEndpoint(e),e.responseLength,n)}getProviderName(){return"mistral"}getSupportedModels(){return[...Co]}getDefaultModel(){return V}getDefaultVisionModel(){return V}supportsVision(){return this.getVisionSupportLevel()!=="unsupported"}getVisionSupportLevel(){return"supported"}supportsVisionForModel(e){return yo(e)}getVisionSupportLevelForModel(e){return this.supportsVisionForModel(e)?"supported":"unsupported"}validateRequiredOptions(e){if(!e.apiKey?.trim())throw new Error("mistral provider requires apiKey.")}resolveEndpoint(e){if(e.endpoint)return this.normalizeUrl(e.endpoint);if(e.baseUrl){let t=this.normalizeUrl(e.baseUrl);return t.endsWith("/chat/completions")?t:`${t}/chat/completions`}return $e}normalizeUrl(e){return e.trim().replace(/\/+$/,"")}};var Ce=class{createChatService(e){return this.validateRequiredOptions(e),new y(e.apiKey?.trim()??"",e.model,e.visionModel??e.model,e.tools,e.endpoint,[],e.responseLength,e.verbosity,e.reasoning_effort,e.enableReasoningSummary,this.getProviderName(),!1)}getProviderName(){return"openai-compatible"}getSupportedModels(){return[]}supportsVision(){return this.getVisionSupportLevel()!=="unsupported"}getVisionSupportLevel(){return"unknown"}supportsVisionForModel(e){return!0}getVisionSupportLevelForModel(e){return"unknown"}getDefaultModel(){return"local-model"}validateRequiredOptions(e){if(e.mcpServers!==void 0)throw new Error("openai-compatible provider does not support mcpServers.");let t=e.endpoint?.trim();if(!t)throw new Error("openai-compatible provider requires endpoint (full URL).");let o;try{o=new URL(t)}catch{throw new Error("openai-compatible provider requires endpoint to be a full URL.")}if(o.protocol!=="http:"&&o.protocol!=="https:")throw new Error("openai-compatible provider requires endpoint to be a full URL.");if(!e.model?.trim())throw new Error("openai-compatible provider requires model.")}};var Te=class{createChatService(e){let t=this.optimizeGPT5Options(e),o=E({model:t.model,visionModel:t.visionModel,defaultModel:this.getDefaultModel(),defaultVisionModel:this.getDefaultModel(),supportsVisionForModel:c=>this.supportsVisionForModel(c),validate:"resolved"}),r=t.tools,n=t.mcpServers??[],s=t.model||this.getDefaultModel(),a=!1;n.length>0||Qt(s)?a=!0:j(s)&&(a=(t.gpt5EndpointPreference||"chat")==="responses");let l=t.endpoint||(a?A:U);return new y(t.apiKey,s,o,r,l,n,t.responseLength,t.verbosity,t.reasoning_effort,t.enableReasoningSummary,this.getProviderName())}getProviderName(){return"openai"}getSupportedModels(){return[H,Q,ee,te,K,W,B,$,G,qe,Je,Xe,z,Ze,Xt,Zt,"o1"]}getDefaultModel(){return H}supportsVision(){return this.getVisionSupportLevel()!=="unsupported"}getVisionSupportLevel(){return"supported"}supportsVisionForModel(e){return Re.includes(e)}getVisionSupportLevelForModel(e){return this.supportsVisionForModel(e)?"supported":"unsupported"}optimizeGPT5Options(e){let t=e.model||this.getDefaultModel();if(!j(t))return e;let o={...e};if(e.gpt5Preset){let r=Po[e.gpt5Preset];o.reasoning_effort=r.reasoning_effort,o.verbosity=r.verbosity}else e.reasoning_effort||(o.reasoning_effort=we(t));return o.reasoning_effort=this.normalizeReasoningEffort(t,o.reasoning_effort),o}normalizeReasoningEffort(e,t){if(t)return t==="none"&&!be(e)||t==="minimal"&&!Ne(e)?t==="minimal"&&be(e)?"none":t==="none"&&Ne(e)?"minimal":Ye(e)?"low":"medium":t==="low"&&!Ye(e)?"medium":t==="xhigh"&&!eo(e)?"high":t}};var _r=i=>[b,oe].includes(i.trim()),fr=i=>i.trim()===oe?"none":void 0,ye=class{constructor(e,t=b,o=b,r,n=Ge,s,a,l,c,d,u){this.provider="openrouter";this.lastRequestTime=0;this.requestCount=0;this.apiKey=e,this.model=t,this.tools=r||[],this.endpoint=n,this.responseLength=s,this.appName=a,this.appUrl=l,this.reasoning_effort=c,this.includeReasoning=d,this.reasoningMaxTokens=u,this.visionModel=o}getModel(){return this.model}getVisionModel(){return this.visionModel}async applyRateLimiting(){if(!J(this.model))return;let e=Date.now(),t=e-this.lastRequestTime;if(t>6e4&&(this.requestCount=0),this.requestCount>=po){let o=6e4-t;o>0&&(console.log(`Rate limit reached for free tier. Waiting ${o}ms...`),await new Promise(r=>setTimeout(r,o)),this.requestCount=0)}this.lastRequestTime=e,this.requestCount++}async processChat(e,t,o){await this.applyRateLimiting(),await M({hasTools:this.tools.length>0,runWithoutTools:async()=>{let r=await this.callOpenRouter(e,this.model,!0);return this.handleStream(r,t)},runWithTools:()=>this.chatOnce(e,!0,t),onCompleteResponse:o,toolErrorMessage:"processChat received tool_calls. ChatProcessor must use chatOnce() loop when tools are enabled."})}async processVisionChat(e,t,o){if(!ie(this.visionModel))throw new Error(`Model ${this.visionModel} does not support vision capabilities.`);await this.applyRateLimiting();try{await M({hasTools:this.tools.length>0,runWithoutTools:async()=>{let r=await this.callOpenRouter(e,this.visionModel,!0);return this.handleStream(r,t)},runWithTools:()=>this.visionChatOnce(e,!0,t),onCompleteResponse:o,toolErrorMessage:"processVisionChat received tool_calls. ChatProcessor must use visionChatOnce() loop when tools are enabled."})}catch(r){throw console.error("Error in processVisionChat:",r),r}}async chatOnce(e,t=!0,o=()=>{},r){await this.applyRateLimiting();let n=await this.callOpenRouter(e,this.model,t,r);return t?this.parseStream(n,o):this.parseOneShot(await n.json())}async visionChatOnce(e,t=!1,o=()=>{},r){if(!ie(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,r);return t?this.parseStream(n,o):this.parseOneShot(await n.json())}async callOpenRouter(e,t,o=!1,r){let n=this.buildRequestBody(e,t,o,r),s={Authorization:`Bearer ${this.apiKey}`};return this.appUrl&&(s["HTTP-Referer"]=this.appUrl),this.appName&&(s["X-Title"]=this.appName),await f.post(this.endpoint,n,s)}buildRequestBody(e,t,o,r){let n={model:t,messages:e,stream:o},s=r!==void 0?r:O(this.responseLength);s&&_r(t)?console.warn(`OpenRouter: Token limits are disabled for ${t} because this model can return empty content when a token limit is set.`):s&&(n.max_tokens=s);let a=fr(t);if(this.reasoning_effort!==void 0||this.includeReasoning!==void 0||this.reasoningMaxTokens||a){if(n.reasoning={},this.reasoning_effort&&this.reasoning_effort!=="none"){let l=this.reasoning_effort==="minimal"?"low":this.reasoning_effort;n.reasoning.effort=l}else this.reasoning_effort===void 0&&a&&(n.reasoning.effort=a);(this.reasoning_effort==="none"||this.includeReasoning!==!0)&&(n.reasoning.exclude=!0),this.reasoningMaxTokens&&(n.reasoning.max_tokens=this.reasoningMaxTokens)}else n.reasoning={exclude:!0};return this.tools.length>0&&(n.tools=x(this.tools,"chat-completions"),n.tool_choice="auto"),n}async handleStream(e,t){return L(e,t,{onJsonError:o=>console.debug("Failed to parse SSE data:",o)})}async parseStream(e,t){return P(e,t,{onJsonError:o=>console.debug("Failed to parse SSE data:",o)})}parseOneShot(e){return I(e)}};var Le=class{createChatService(e){let t=E({model:e.model,visionModel:e.visionModel,defaultModel:this.getDefaultModel(),defaultVisionModel:e.model||this.getDefaultModel(),supportsVisionForModel:s=>this.supportsVisionForModel(s),validate:"explicit"}),o=e.tools,r=e.appName,n=e.appUrl;return new ye(e.apiKey,e.model||this.getDefaultModel(),t,o,e.endpoint,e.responseLength,r,n,e.reasoning_effort,e.includeReasoning,e.reasoningMaxTokens)}getProviderName(){return"openrouter"}getSupportedModels(){return[io,ro,b,wt,mt,dt,gt,_t,ft,Mt,vt,Et,Ot,St,Ct,Tt,yt,Lt,Pt,It,no,xt,Dt,At,Rt,bt,Nt,oe,so,ao,ht,ct,ut]}getDefaultModel(){return b}supportsVision(){return this.getVisionSupportLevel()!=="unsupported"}getVisionSupportLevel(){return this.getSupportedModels().some(e=>this.supportsVisionForModel(e))?"supported":"unsupported"}supportsVisionForModel(e){return ie(e)}getVisionSupportLevelForModel(e){return this.supportsVisionForModel(e)?"supported":"unsupported"}getFreeModels(){return lo}isModelFree(e){return J(e)}};var Pe=class{constructor(e,t=N,o=N,r,n=Ue,s){this.provider="xai";this.apiKey=e,this.model=t,this.tools=r||[],this.endpoint=n,this.responseLength=s,this.visionModel=o}getModel(){return this.model}getVisionModel(){return this.visionModel}async processChat(e,t,o){await M({hasTools:this.tools.length>0,runWithoutTools:async()=>{let r=await this.callXAI(e,this.model,!0);return this.handleStream(r,t)},runWithTools:()=>this.chatOnce(e,!0,t),onCompleteResponse:o,toolErrorMessage:"processChat received tool_calls. ChatProcessor must use chatOnce() loop when tools are enabled."})}async processVisionChat(e,t,o){if(!se(this.visionModel))throw new Error(`Model ${this.visionModel} does not support vision capabilities.`);await M({hasTools:this.tools.length>0,runWithoutTools:async()=>{let r=await this.callXAI(e,this.visionModel,!0);return this.handleStream(r,t)},runWithTools:()=>this.visionChatOnce(e,!0,t),onCompleteResponse:o,toolErrorMessage:"processVisionChat received tool_calls. ChatProcessor must use visionChatOnce() loop when tools are enabled."})}async chatOnce(e,t=!0,o=()=>{},r){let n=await this.callXAI(e,this.model,t,r);return this.parseResponse(n,t,o)}async visionChatOnce(e,t=!1,o=()=>{},r){if(!se(this.visionModel))throw new Error(`Model ${this.visionModel} does not support vision capabilities.`);let n=await this.callXAI(e,this.visionModel,t,r);return this.parseResponse(n,t,o)}async parseResponse(e,t,o){return t?this.parseStream(e,o):this.parseOneShot(await e.json())}async callXAI(e,t,o=!1,r){let n=this.buildRequestBody(e,t,o,r);return await f.post(this.endpoint,n,{Authorization:`Bearer ${this.apiKey}`})}buildRequestBody(e,t,o,r){let n={model:t,stream:o,messages:e},s=r!==void 0?r:O(this.responseLength);s!==void 0&&(n.max_tokens=s);let a=this.buildToolsDefinition();return a.length>0&&(n.tools=a,n.tool_choice="auto"),n}buildToolsDefinition(){return x(this.tools,"chat-completions")}async handleStream(e,t){return L(e,t,{onJsonError:o=>console.debug("Failed to parse SSE data:",o)})}async parseStream(e,t){return P(e,t,{onJsonError:o=>console.debug("Failed to parse SSE data:",o)})}parseOneShot(e){return I(e)}};var Ie=class{createChatService(e){let t=e.model||this.getDefaultModel(),o=E({model:t,visionModel:e.visionModel,defaultModel:this.getDefaultModel(),defaultVisionModel:this.getDefaultVisionModel(),supportsVisionForModel:n=>this.supportsVisionForModel(n),validate:"explicit"}),r=e.tools;return new Pe(e.apiKey,t,o,r,e.endpoint||Ue,e.responseLength)}getProviderName(){return"xai"}getSupportedModels(){return[Gt,Ft,Ut,Ht,N]}getDefaultModel(){return N}getDefaultVisionModel(){return N}supportsVision(){return this.getVisionSupportLevel()!=="unsupported"}getVisionSupportLevel(){return"supported"}supportsVisionForModel(e){return se(e)}getVisionSupportLevelForModel(e){return this.supportsVisionForModel(e)?"supported":"unsupported"}};var xe=class{constructor(e,t=re,o=X,r,n=Fe,s,a,l){this.provider="zai";this.apiKey=e,this.model=t,this.tools=r||[],this.endpoint=n,this.responseLength=s,this.responseFormat=a,this.thinking=l??{type:"disabled"},this.visionModel=o}getModel(){return this.model}getVisionModel(){return this.visionModel}async processChat(e,t,o){await M({hasTools:this.tools.length>0,runWithoutTools:async()=>{let r=await this.callZAI(e,this.model,!0);return this.handleStream(r,t)},runWithTools:()=>this.chatOnce(e,!0,t),onCompleteResponse:o,toolErrorMessage:"processChat received tool_calls. ChatProcessor must use chatOnce() loop when tools are enabled."})}async processVisionChat(e,t,o){if(!ne(this.visionModel))throw new Error(`Model ${this.visionModel} does not support vision capabilities.`);await M({hasTools:this.tools.length>0,runWithoutTools:async()=>{let r=await this.callZAI(e,this.visionModel,!0);return this.handleStream(r,t)},runWithTools:()=>this.visionChatOnce(e,!0,t),onCompleteResponse:o,toolErrorMessage:"processVisionChat received tool_calls. ChatProcessor must use visionChatOnce() loop when tools are enabled."})}async chatOnce(e,t=!0,o=()=>{},r){let n=await this.callZAI(e,this.model,t,r);return this.parseResponse(n,t,o)}async visionChatOnce(e,t=!1,o=()=>{},r){if(!ne(this.visionModel))throw new Error(`Model ${this.visionModel} does not support vision capabilities.`);let n=await this.callZAI(e,this.visionModel,t,r);return this.parseResponse(n,t,o)}async parseResponse(e,t,o){return t?this.parseStream(e,o):this.parseOneShot(await e.json())}async callZAI(e,t,o=!1,r){let n=this.buildRequestBody(e,t,o,r);return await f.post(this.endpoint,n,{Authorization:`Bearer ${this.apiKey}`})}buildRequestBody(e,t,o,r){let n={model:t,stream:o,messages:e},s=r!==void 0?r:O(this.responseLength);s!==void 0&&(n.max_tokens=s),this.responseFormat&&(n.response_format=this.responseFormat),this.thinking&&(n.thinking=this.thinking);let a=this.buildToolsDefinition();return a.length>0&&(n.tools=a,n.tool_choice="auto",o&&fo(t)&&(n.tool_stream=!0)),n}buildToolsDefinition(){return x(this.tools,"chat-completions")}async handleStream(e,t){return L(e,t,{onJsonError:o=>console.debug("Failed to parse SSE data:",o)})}async parseStream(e,t){return P(e,t,{onJsonError:o=>console.debug("Failed to parse SSE data:",o)})}parseOneShot(e){return I(e)}};var De=class{createChatService(e){let t=e.model||this.getDefaultModel(),o=E({model:t,visionModel:e.visionModel,defaultModel:this.getDefaultModel(),defaultVisionModel:this.getDefaultVisionModel(),supportsVisionForModel:s=>this.supportsVisionForModel(s),validate:"explicit"}),r=e.tools,n=e.thinking??{type:"disabled"};return new xe(e.apiKey,t,o,r,e.endpoint||Fe,e.responseLength,e.responseFormat,n)}getProviderName(){return"zai"}getSupportedModels(){return[re,co,uo,ho,mo,go,_o,Vt,kt,X]}getDefaultModel(){return re}getDefaultVisionModel(){return X}supportsVision(){return this.getVisionSupportLevel()!=="unsupported"}getVisionSupportLevel(){return"supported"}supportsVisionForModel(e){return ne(e)}getVisionSupportLevelForModel(e){return this.supportsVisionForModel(e)?"supported":"unsupported"}};var yi=[new Te,new Ce,new _e,new Me,new he,new Le,new De,new Ie,new Ee,new de,new Se];var Ae=class{static registerProvider(e){this.providers.set(e.getProviderName(),e)}static createChatService(e,t){let o=this.providers.get(e);if(!o)throw new Error(`Unknown chat provider: ${e}`);return o.createChatService(t)}static getProviders(){return this.providers}static getAvailableProviders(){return Array.from(this.providers.keys())}static getSupportedModels(e){let t=this.providers.get(e);return t?t.getSupportedModels():[]}static getVisionSupportLevel(e){let t=this.providers.get(e);return t?t.getVisionSupportLevel():"unsupported"}static getVisionSupportLevelForModel(e,t){let o=this.providers.get(e);return o?o.getVisionSupportLevelForModel?o.getVisionSupportLevelForModel(t):o.supportsVisionForModel?o.supportsVisionForModel(t)?"supported":"unsupported":o.getVisionSupportLevel():"unsupported"}};Ae.providers=new Map;yi.forEach(i=>Ae.registerProvider(i));function Li(){f.setFetch(async(i,e={})=>{let t=(e.method||"GET").toString().toUpperCase(),o=e.headers,r={};if(Array.isArray(o))for(let[u,m]of o)r[u]=String(m);else if(o&&typeof o=="object")for(let[u,m]of Object.entries(o))r[u]=String(m);let n={method:t,headers:r,muteHttpExceptions:!0},s=e.body;typeof s=="string"?n.payload=s:s!=null&&(r["Content-Type"]||(r["Content-Type"]="application/json"),n.payload=JSON.stringify(s));let a=UrlFetchApp.fetch(i,n),l=a.getResponseCode(),c=a.getContentText();return{ok:l>=200&&l<300,status:l,statusText:String(l),text:async()=>c,json:async()=>c?JSON.parse(c):null}})}return bi(Mr);})();
21
+ `)}getResponseLengthInstruction(){if(!this._responseLength)return;let e=Yt[this._responseLength];if(e)return`Please keep your response concise, within approximately ${e} tokens.`}};var Oe=class{createChatService(e){return new ve({expectedInputLanguages:e.expectedInputLanguages,expectedOutputLanguages:e.expectedOutputLanguages,responseLength:e.responseLength})}getProviderName(){return"gemini-nano"}getSupportedModels(){return[Z]}getDefaultModel(){return Z}supportsVision(){return!1}getVisionSupportLevel(){return"unsupported"}};var Ee=class{constructor(e,t=w,o=w,i,n=ae,s,a,l){this.provider="kimi";this.apiKey=e,this.model=t,this.tools=i||[],this.endpoint=n,this.responseLength=s,this.responseFormat=a,this.thinking=l??{type:"enabled"},this.visionModel=o}getModel(){return this.model}getVisionModel(){return this.visionModel}async processChat(e,t,o){await M({hasTools:this.tools.length>0,runWithoutTools:async()=>{let i=await this.callKimi(e,this.model,!0);return this.handleStream(i,t)},runWithTools:()=>this.chatOnce(e,!0,t),onCompleteResponse:o,toolErrorMessage:"processChat received tool_calls. ChatProcessor must use chatOnce() loop when tools are enabled."})}async processVisionChat(e,t,o){if(!le(this.visionModel))throw new Error(`Model ${this.visionModel} does not support vision capabilities.`);await M({hasTools:this.tools.length>0,runWithoutTools:async()=>{let i=await this.callKimi(e,this.visionModel,!0);return this.handleStream(i,t)},runWithTools:()=>this.visionChatOnce(e,!0,t),onCompleteResponse:o,toolErrorMessage:"processVisionChat received tool_calls. ChatProcessor must use visionChatOnce() loop when tools are enabled."})}async chatOnce(e,t=!0,o=()=>{},i){let n=await this.callKimi(e,this.model,t,i);return this.parseResponse(n,t,o)}async visionChatOnce(e,t=!1,o=()=>{},i){if(!le(this.visionModel))throw new Error(`Model ${this.visionModel} does not support vision capabilities.`);let n=await this.callKimi(e,this.visionModel,t,i);return this.parseResponse(n,t,o)}async parseResponse(e,t,o){return t?this.parseStream(e,o):this.parseOneShot(await e.json())}async callKimi(e,t,o=!1,i){let n=this.buildRequestBody(e,t,o,i);return await f.post(this.endpoint,n,{Authorization:`Bearer ${this.apiKey}`})}buildRequestBody(e,t,o,i){let n={model:t,stream:o,messages:e},s=i!==void 0?i:E(this.responseLength);s!==void 0&&(n.max_tokens=s),this.responseFormat&&(n.response_format=this.responseFormat);let a=this.resolveEffectiveThinking(t);a&&(this.isSelfHostedEndpoint()?a.type==="disabled"&&(n.chat_template_kwargs={thinking:!1}):n.thinking=a);let l=this.buildToolsDefinition();return l.length>0&&(n.tools=l,n.tool_choice="auto"),n}isSelfHostedEndpoint(){return this.normalizeEndpoint(this.endpoint)!==this.normalizeEndpoint(ae)}normalizeEndpoint(e){return e.replace(/\/+$/,"")}resolveEffectiveThinking(e){if(Je(e)){if(this.thinking?.type==="disabled")throw new Error(`Model ${e} requires thinking mode and does not support thinking: disabled.`);return this.thinking??{type:"enabled"}}return this.tools.length>0?{type:"disabled"}:this.thinking}buildToolsDefinition(){return x(this.tools,"chat-completions")}async handleStream(e,t){return P(e,t,{onJsonError:o=>console.debug("Failed to parse SSE data:",o)})}async parseStream(e,t){return y(e,t,{onJsonError:o=>console.debug("Failed to parse SSE data:",o)})}parseOneShot(e){return I(e)}};var Se=class{constructor(){this.defaultThinking={type:"enabled"}}createChatService(e){let t=this.resolveEndpoint(e),o=e.model||this.getDefaultModel(),i=O({model:o,visionModel:e.visionModel,defaultModel:this.getDefaultModel(),defaultVisionModel:this.getDefaultVisionModel(),supportsVisionForModel:a=>this.supportsVisionForModel(a),validate:"explicit"}),n=e.tools,s=this.resolveThinking(o,n,e.thinking);return new Ee(e.apiKey,o,i,n,t,e.responseLength,e.responseFormat,s)}getProviderName(){return"kimi"}getSupportedModels(){return[qe,je,w,Xt]}getDefaultModel(){return w}getDefaultVisionModel(){return w}supportsVision(){return this.getVisionSupportLevel()!=="unsupported"}getVisionSupportLevel(){return"supported"}supportsVisionForModel(e){return le(e)}getVisionSupportLevelForModel(e){return this.supportsVisionForModel(e)?"supported":"unsupported"}resolveEndpoint(e){if(e.endpoint)return this.normalizeEndpoint(e.endpoint);if(e.baseUrl){let t=this.normalizeEndpoint(e.baseUrl);return t.endsWith("/chat/completions")?t:`${t}/chat/completions`}return ae}normalizeEndpoint(e){return e.replace(/\/+$/,"")}resolveThinking(e,t,o){if(Je(e)){if(o?.type==="disabled")throw new Error(`Model ${e} requires thinking mode and does not support thinking: disabled.`);return o??this.defaultThinking}return t&&t.length>0?{type:"disabled"}:o??this.defaultThinking}};var Ce=class extends S{constructor(e,t=V,o=t,i,n=Ze,s,a){super(e,t,o,i,n,[],s,void 0,a,!1,"mistral",!1)}};var Te=class{createChatService(e){this.validateRequiredOptions(e);let t=e.model||this.getDefaultModel(),o=O({model:t,visionModel:e.visionModel,defaultModel:this.getDefaultModel(),defaultVisionModel:this.getDefaultVisionModel(),supportsVisionForModel:s=>this.supportsVisionForModel(s),validate:"explicit"}),i=e.tools,n=Ye(t)?e.reasoning_effort:void 0;return new Ce(e.apiKey,t,o,i,this.resolveEndpoint(e),e.responseLength,n)}getProviderName(){return"mistral"}getSupportedModels(){return[...Ao]}getDefaultModel(){return V}getDefaultVisionModel(){return V}supportsVision(){return this.getVisionSupportLevel()!=="unsupported"}getVisionSupportLevel(){return"supported"}supportsVisionForModel(e){return bo(e)}getVisionSupportLevelForModel(e){return this.supportsVisionForModel(e)?"supported":"unsupported"}validateRequiredOptions(e){if(!e.apiKey?.trim())throw new Error("mistral provider requires apiKey.")}resolveEndpoint(e){if(e.endpoint)return this.normalizeUrl(e.endpoint);if(e.baseUrl){let t=this.normalizeUrl(e.baseUrl);return t.endsWith("/chat/completions")?t:`${t}/chat/completions`}return Ze}normalizeUrl(e){return e.trim().replace(/\/+$/,"")}};var Le=class{createChatService(e){return this.validateRequiredOptions(e),new S(e.apiKey?.trim()??"",e.model,e.visionModel??e.model,e.tools,e.endpoint,[],e.responseLength,e.verbosity,e.reasoning_effort,e.enableReasoningSummary,this.getProviderName(),!1)}getProviderName(){return"openai-compatible"}getSupportedModels(){return[]}supportsVision(){return this.getVisionSupportLevel()!=="unsupported"}getVisionSupportLevel(){return"unknown"}supportsVisionForModel(e){return!0}getVisionSupportLevelForModel(e){return"unknown"}getDefaultModel(){return"local-model"}validateRequiredOptions(e){if(e.mcpServers!==void 0)throw new Error("openai-compatible provider does not support mcpServers.");let t=e.endpoint?.trim();if(!t)throw new Error("openai-compatible provider requires endpoint (full URL).");let o;try{o=new URL(t)}catch{throw new Error("openai-compatible provider requires endpoint to be a full URL.")}if(o.protocol!=="http:"&&o.protocol!=="https:")throw new Error("openai-compatible provider requires endpoint to be a full URL.");if(!e.model?.trim())throw new Error("openai-compatible provider requires model.")}};var Pe=class{createChatService(e){let t=this.optimizeGPT5Options(e),o=O({model:t.model,visionModel:t.visionModel,defaultModel:this.getDefaultModel(),defaultVisionModel:this.getDefaultModel(),supportsVisionForModel:c=>this.supportsVisionForModel(c),validate:"resolved"}),i=t.tools,n=t.mcpServers??[],s=t.model||this.getDefaultModel(),a=!1;n.length>0||ao(s)?a=!0:q(s)&&(a=(t.gpt5EndpointPreference||"chat")==="responses");let l=t.endpoint||(a?A:U);return new S(t.apiKey,s,o,i,l,n,t.responseLength,t.verbosity,t.reasoning_effort,t.enableReasoningSummary,this.getProviderName())}getProviderName(){return"openai"}getSupportedModels(){return[K,Q,ee,te,H,W,B,$,G,ot,rt,it,z,nt,io,no,"o1"]}getDefaultModel(){return K}supportsVision(){return this.getVisionSupportLevel()!=="unsupported"}getVisionSupportLevel(){return"supported"}supportsVisionForModel(e){return Ge.includes(e)}getVisionSupportLevelForModel(e){return this.supportsVisionForModel(e)?"supported":"unsupported"}optimizeGPT5Options(e){let t=e.model||this.getDefaultModel();if(!q(t))return e;let o={...e};if(e.gpt5Preset){let i=ko[e.gpt5Preset];o.reasoning_effort=i.reasoning_effort,o.verbosity=i.verbosity}else e.reasoning_effort||(o.reasoning_effort=Ke(t));return o.reasoning_effort=this.normalizeReasoningEffort(t,o.reasoning_effort),o}normalizeReasoningEffort(e,t){if(t)return t==="none"&&!Fe(e)||t==="minimal"&&!Ue(e)?t==="minimal"&&Fe(e)?"none":t==="none"&&Ue(e)?"minimal":st(e)?"low":"medium":t==="low"&&!st(e)?"medium":t==="xhigh"&&!lo(e)?"high":t}};var Ai=r=>[b,oe].includes(r.trim()),Ri=r=>r.trim()===oe?"none":void 0,ye=class{constructor(e,t=b,o=b,i,n=Be,s,a,l,c,d,u){this.provider="openrouter";this.lastRequestTime=0;this.requestCount=0;this.apiKey=e,this.model=t,this.tools=i||[],this.endpoint=n,this.responseLength=s,this.appName=a,this.appUrl=l,this.reasoning_effort=c,this.includeReasoning=d,this.reasoningMaxTokens=u,this.visionModel=o}getModel(){return this.model}getVisionModel(){return this.visionModel}async applyRateLimiting(){if(!J(this.model))return;let e=Date.now(),t=e-this.lastRequestTime;if(t>6e4&&(this.requestCount=0),this.requestCount>=Mo){let o=6e4-t;o>0&&(console.log(`Rate limit reached for free tier. Waiting ${o}ms...`),await new Promise(i=>setTimeout(i,o)),this.requestCount=0)}this.lastRequestTime=e,this.requestCount++}async processChat(e,t,o){await this.applyRateLimiting(),await M({hasTools:this.tools.length>0,runWithoutTools:async()=>{let i=await this.callOpenRouter(e,this.model,!0);return this.handleStream(i,t)},runWithTools:()=>this.chatOnce(e,!0,t),onCompleteResponse:o,toolErrorMessage:"processChat received tool_calls. ChatProcessor must use chatOnce() loop when tools are enabled."})}async processVisionChat(e,t,o){if(!re(this.visionModel))throw new Error(`Model ${this.visionModel} does not support vision capabilities.`);await this.applyRateLimiting();try{await M({hasTools:this.tools.length>0,runWithoutTools:async()=>{let i=await this.callOpenRouter(e,this.visionModel,!0);return this.handleStream(i,t)},runWithTools:()=>this.visionChatOnce(e,!0,t),onCompleteResponse:o,toolErrorMessage:"processVisionChat received tool_calls. ChatProcessor must use visionChatOnce() loop when tools are enabled."})}catch(i){throw console.error("Error in processVisionChat:",i),i}}async chatOnce(e,t=!0,o=()=>{},i){await this.applyRateLimiting();let n=await this.callOpenRouter(e,this.model,t,i);return t?this.parseStream(n,o):this.parseOneShot(await n.json())}async visionChatOnce(e,t=!1,o=()=>{},i){if(!re(this.visionModel))throw new Error(`Model ${this.visionModel} does not support vision capabilities.`);await this.applyRateLimiting();let n=await this.callOpenRouter(e,this.visionModel,t,i);return t?this.parseStream(n,o):this.parseOneShot(await n.json())}async callOpenRouter(e,t,o=!1,i){let n=this.buildRequestBody(e,t,o,i),s={Authorization:`Bearer ${this.apiKey}`};return this.appUrl&&(s["HTTP-Referer"]=this.appUrl),this.appName&&(s["X-Title"]=this.appName),await f.post(this.endpoint,n,s)}buildRequestBody(e,t,o,i){let n={model:t,messages:e,stream:o},s=i!==void 0?i:E(this.responseLength);s&&Ai(t)?console.warn(`OpenRouter: Token limits are disabled for ${t} because this model can return empty content when a token limit is set.`):s&&(n.max_tokens=s);let a=Ri(t);if(this.reasoning_effort!==void 0||this.includeReasoning!==void 0||this.reasoningMaxTokens||a){if(n.reasoning={},this.reasoning_effort&&this.reasoning_effort!=="none"){let l=this.reasoning_effort==="minimal"?"low":this.reasoning_effort;n.reasoning.effort=l}else this.reasoning_effort===void 0&&a&&(n.reasoning.effort=a);(this.reasoning_effort==="none"||this.includeReasoning!==!0)&&(n.reasoning.exclude=!0),this.reasoningMaxTokens&&(n.reasoning.max_tokens=this.reasoningMaxTokens)}else n.reasoning={exclude:!0};return this.tools.length>0&&(n.tools=x(this.tools,"chat-completions"),n.tool_choice="auto"),n}async handleStream(e,t){return P(e,t,{onJsonError:o=>console.debug("Failed to parse SSE data:",o)})}async parseStream(e,t){return y(e,t,{onJsonError:o=>console.debug("Failed to parse SSE data:",o)})}parseOneShot(e){return I(e)}};var Ie=class{createChatService(e){let t=O({model:e.model,visionModel:e.visionModel,defaultModel:this.getDefaultModel(),defaultVisionModel:e.model||this.getDefaultModel(),supportsVisionForModel:s=>this.supportsVisionForModel(s),validate:"explicit"}),o=e.tools,i=e.appName,n=e.appUrl;return new ye(e.apiKey,e.model||this.getDefaultModel(),t,o,e.endpoint,e.responseLength,i,n,e.reasoning_effort,e.includeReasoning,e.reasoningMaxTokens)}getProviderName(){return"openrouter"}getSupportedModels(){return[uo,ho,b,Wt,Et,St,Ct,Tt,Lt,Pt,yt,It,xt,Dt,At,Rt,bt,Nt,wt,Vt,mo,kt,Gt,Ft,Ut,Kt,Ht,oe,go,_o,Ot,Mt,vt]}getDefaultModel(){return b}supportsVision(){return this.getVisionSupportLevel()!=="unsupported"}getVisionSupportLevel(){return this.getSupportedModels().some(e=>this.supportsVisionForModel(e))?"supported":"unsupported"}supportsVisionForModel(e){return re(e)}getVisionSupportLevelForModel(e){return this.supportsVisionForModel(e)?"supported":"unsupported"}getFreeModels(){return fo}isModelFree(e){return J(e)}};var xe=class extends S{constructor(e,t=ue,o=t,i,n=et,s,a){super(e,t,o,i,n,[],s,void 0,a,!1,"plamo",!1)}};var De=class{createChatService(e){this.validateRequiredOptions(e);let t=e.model||this.getDefaultModel(),o=e.tools;return new xe(e.apiKey,t,e.visionModel??t,o,this.resolveEndpoint(e),e.responseLength,e.reasoning_effort)}getProviderName(){return"plamo"}getSupportedModels(){return[...wo]}getDefaultModel(){return ue}supportsVision(){return!1}getVisionSupportLevel(){return"unsupported"}supportsVisionForModel(e){return!1}getVisionSupportLevelForModel(e){return"unsupported"}validateRequiredOptions(e){if(!e.apiKey?.trim())throw new Error("plamo provider requires apiKey.")}resolveEndpoint(e){if(e.endpoint)return this.normalizeUrl(e.endpoint);if(e.baseUrl){let t=this.normalizeUrl(e.baseUrl);return t.endsWith("/chat/completions")?t:`${t}/chat/completions`}return et}normalizeUrl(e){return e.trim().replace(/\/+$/,"")}};var Ae=class extends S{constructor(e,t=ce,o=t,i,n=Qe,s){super(e,t,o,i,n,[],s,void 0,void 0,!1,"sakana",!1)}};var Re=class{createChatService(e){this.validateRequiredOptions(e);let t=e.model||this.getDefaultModel(),o=e.tools;return new Ae(e.apiKey,t,e.visionModel??t,o,this.resolveEndpoint(e),e.responseLength)}getProviderName(){return"sakana"}getSupportedModels(){return[...No]}getDefaultModel(){return ce}supportsVision(){return!1}getVisionSupportLevel(){return"unsupported"}supportsVisionForModel(e){return!1}getVisionSupportLevelForModel(e){return"unsupported"}validateRequiredOptions(e){if(!e.apiKey?.trim())throw new Error("sakana provider requires apiKey.")}resolveEndpoint(e){if(e.endpoint)return this.normalizeUrl(e.endpoint);if(e.baseUrl){let t=this.normalizeUrl(e.baseUrl);return t.endsWith("/chat/completions")?t:`${t}/chat/completions`}return Qe}normalizeUrl(e){return e.trim().replace(/\/+$/,"")}};var be=class{constructor(e,t=N,o=N,i,n=ze,s){this.provider="xai";this.apiKey=e,this.model=t,this.tools=i||[],this.endpoint=n,this.responseLength=s,this.visionModel=o}getModel(){return this.model}getVisionModel(){return this.visionModel}async processChat(e,t,o){await M({hasTools:this.tools.length>0,runWithoutTools:async()=>{let i=await this.callXAI(e,this.model,!0);return this.handleStream(i,t)},runWithTools:()=>this.chatOnce(e,!0,t),onCompleteResponse:o,toolErrorMessage:"processChat received tool_calls. ChatProcessor must use chatOnce() loop when tools are enabled."})}async processVisionChat(e,t,o){if(!se(this.visionModel))throw new Error(`Model ${this.visionModel} does not support vision capabilities.`);await M({hasTools:this.tools.length>0,runWithoutTools:async()=>{let i=await this.callXAI(e,this.visionModel,!0);return this.handleStream(i,t)},runWithTools:()=>this.visionChatOnce(e,!0,t),onCompleteResponse:o,toolErrorMessage:"processVisionChat received tool_calls. ChatProcessor must use visionChatOnce() loop when tools are enabled."})}async chatOnce(e,t=!0,o=()=>{},i){let n=await this.callXAI(e,this.model,t,i);return this.parseResponse(n,t,o)}async visionChatOnce(e,t=!1,o=()=>{},i){if(!se(this.visionModel))throw new Error(`Model ${this.visionModel} does not support vision capabilities.`);let n=await this.callXAI(e,this.visionModel,t,i);return this.parseResponse(n,t,o)}async parseResponse(e,t,o){return t?this.parseStream(e,o):this.parseOneShot(await e.json())}async callXAI(e,t,o=!1,i){let n=this.buildRequestBody(e,t,o,i);return await f.post(this.endpoint,n,{Authorization:`Bearer ${this.apiKey}`})}buildRequestBody(e,t,o,i){let n={model:t,stream:o,messages:e},s=i!==void 0?i:E(this.responseLength);s!==void 0&&(n.max_tokens=s);let a=this.buildToolsDefinition();return a.length>0&&(n.tools=a,n.tool_choice="auto"),n}buildToolsDefinition(){return x(this.tools,"chat-completions")}async handleStream(e,t){return P(e,t,{onJsonError:o=>console.debug("Failed to parse SSE data:",o)})}async parseStream(e,t){return y(e,t,{onJsonError:o=>console.debug("Failed to parse SSE data:",o)})}parseOneShot(e){return I(e)}};var Ne=class{createChatService(e){let t=e.model||this.getDefaultModel(),o=O({model:t,visionModel:e.visionModel,defaultModel:this.getDefaultModel(),defaultVisionModel:this.getDefaultVisionModel(),supportsVisionForModel:n=>this.supportsVisionForModel(n),validate:"explicit"}),i=e.tools;return new be(e.apiKey,t,o,i,e.endpoint||ze,e.responseLength)}getProviderName(){return"xai"}getSupportedModels(){return[zt,qt,jt,Jt,N]}getDefaultModel(){return N}getDefaultVisionModel(){return N}supportsVision(){return this.getVisionSupportLevel()!=="unsupported"}getVisionSupportLevel(){return"supported"}supportsVisionForModel(e){return se(e)}getVisionSupportLevelForModel(e){return this.supportsVisionForModel(e)?"supported":"unsupported"}};var we=class{constructor(e,t=ie,o=X,i,n=$e,s,a,l){this.provider="zai";this.apiKey=e,this.model=t,this.tools=i||[],this.endpoint=n,this.responseLength=s,this.responseFormat=a,this.thinking=l??{type:"disabled"},this.visionModel=o}getModel(){return this.model}getVisionModel(){return this.visionModel}async processChat(e,t,o){await M({hasTools:this.tools.length>0,runWithoutTools:async()=>{let i=await this.callZAI(e,this.model,!0);return this.handleStream(i,t)},runWithTools:()=>this.chatOnce(e,!0,t),onCompleteResponse:o,toolErrorMessage:"processChat received tool_calls. ChatProcessor must use chatOnce() loop when tools are enabled."})}async processVisionChat(e,t,o){if(!ne(this.visionModel))throw new Error(`Model ${this.visionModel} does not support vision capabilities.`);await M({hasTools:this.tools.length>0,runWithoutTools:async()=>{let i=await this.callZAI(e,this.visionModel,!0);return this.handleStream(i,t)},runWithTools:()=>this.visionChatOnce(e,!0,t),onCompleteResponse:o,toolErrorMessage:"processVisionChat received tool_calls. ChatProcessor must use visionChatOnce() loop when tools are enabled."})}async chatOnce(e,t=!0,o=()=>{},i){let n=await this.callZAI(e,this.model,t,i);return this.parseResponse(n,t,o)}async visionChatOnce(e,t=!1,o=()=>{},i){if(!ne(this.visionModel))throw new Error(`Model ${this.visionModel} does not support vision capabilities.`);let n=await this.callZAI(e,this.visionModel,t,i);return this.parseResponse(n,t,o)}async parseResponse(e,t,o){return t?this.parseStream(e,o):this.parseOneShot(await e.json())}async callZAI(e,t,o=!1,i){let n=this.buildRequestBody(e,t,o,i);return await f.post(this.endpoint,n,{Authorization:`Bearer ${this.apiKey}`})}buildRequestBody(e,t,o,i){let n={model:t,stream:o,messages:e},s=i!==void 0?i:E(this.responseLength);s!==void 0&&(n.max_tokens=s),this.responseFormat&&(n.response_format=this.responseFormat),this.thinking&&(n.thinking=this.thinking);let a=this.buildToolsDefinition();return a.length>0&&(n.tools=a,n.tool_choice="auto",o&&Lo(t)&&(n.tool_stream=!0)),n}buildToolsDefinition(){return x(this.tools,"chat-completions")}async handleStream(e,t){return P(e,t,{onJsonError:o=>console.debug("Failed to parse SSE data:",o)})}async parseStream(e,t){return y(e,t,{onJsonError:o=>console.debug("Failed to parse SSE data:",o)})}parseOneShot(e){return I(e)}};var Ve=class{createChatService(e){let t=e.model||this.getDefaultModel(),o=O({model:t,visionModel:e.visionModel,defaultModel:this.getDefaultModel(),defaultVisionModel:this.getDefaultVisionModel(),supportsVisionForModel:s=>this.supportsVisionForModel(s),validate:"explicit"}),i=e.tools,n=e.thinking??{type:"disabled"};return new we(e.apiKey,t,o,i,e.endpoint||$e,e.responseLength,e.responseFormat,n)}getProviderName(){return"zai"}getSupportedModels(){return[ie,vo,Oo,Eo,So,Co,To,Bt,$t,X]}getDefaultModel(){return ie}getDefaultVisionModel(){return X}supportsVision(){return this.getVisionSupportLevel()!=="unsupported"}getVisionSupportLevel(){return"supported"}supportsVisionForModel(e){return ne(e)}getVisionSupportLevelForModel(e){return this.supportsVisionForModel(e)?"supported":"unsupported"}};var Ur=[new Pe,new Le,new Me,new Oe,new de,new Ie,new Ve,new Ne,new Se,new _e,new Te,new Re,new De];var ke=class{static registerProvider(e){this.providers.set(e.getProviderName(),e)}static createChatService(e,t){let o=this.providers.get(e);if(!o)throw new Error(`Unknown chat provider: ${e}`);return o.createChatService(t)}static getProviders(){return this.providers}static getAvailableProviders(){return Array.from(this.providers.keys())}static getSupportedModels(e){let t=this.providers.get(e);return t?t.getSupportedModels():[]}static getVisionSupportLevel(e){let t=this.providers.get(e);return t?t.getVisionSupportLevel():"unsupported"}static getVisionSupportLevelForModel(e,t){let o=this.providers.get(e);return o?o.getVisionSupportLevelForModel?o.getVisionSupportLevelForModel(t):o.supportsVisionForModel?o.supportsVisionForModel(t)?"supported":"unsupported":o.getVisionSupportLevel():"unsupported"}};ke.providers=new Map;Ur.forEach(r=>ke.registerProvider(r));function Kr(){f.setFetch(async(r,e={})=>{let t=(e.method||"GET").toString().toUpperCase(),o=e.headers,i={};if(Array.isArray(o))for(let[u,m]of o)i[u]=String(m);else if(o&&typeof o=="object")for(let[u,m]of Object.entries(o))i[u]=String(m);let n={method:t,headers:i,muteHttpExceptions:!0},s=e.body;typeof s=="string"?n.payload=s:s!=null&&(i["Content-Type"]||(i["Content-Type"]="application/json"),n.payload=JSON.stringify(s));let a=UrlFetchApp.fetch(r,n),l=a.getResponseCode(),c=a.getContentText();return{ok:l>=200&&l<300,status:l,statusText:String(l),text:async()=>c,json:async()=>c?JSON.parse(c):null}})}return jr(bi);})();
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@aituber-onair/chat",
3
- "version": "0.40.0",
3
+ "version": "0.42.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",