"use strict"; /* * ATTENTION: An "eval-source-map" devtool has been used. * This devtool is neither made for production nor for readable output files. * It uses "eval()" calls to create a separate source file with attached SourceMaps in the browser devtools. * If you are trying to read the output file, select a different devtool (https://webpack.js.org/configuration/devtool/) * or disable the default devtool with "devtool: false". * If you are looking for production-ready output files, see mode: "production" (https://webpack.js.org/configuration/mode/). */ self["webpackHotUpdate_N_E"]("app/page",{ /***/ "(app-pages-browser)/./app/constant.ts": /*!*************************!*\ !*** ./app/constant.ts ***! \*************************/ /***/ (function(module, __webpack_exports__, __webpack_require__) { eval(__webpack_require__.ts("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ ACCESS_CODE_PREFIX: function() { return /* binding */ ACCESS_CODE_PREFIX; },\n/* harmony export */ ALIBABA_BASE_URL: function() { return /* binding */ ALIBABA_BASE_URL; },\n/* harmony export */ ANTHROPIC_BASE_URL: function() { return /* binding */ ANTHROPIC_BASE_URL; },\n/* harmony export */ Alibaba: function() { return /* binding */ Alibaba; },\n/* harmony export */ Anthropic: function() { return /* binding */ Anthropic; },\n/* harmony export */ ApiPath: function() { return /* binding */ ApiPath; },\n/* harmony export */ Azure: function() { return /* binding */ Azure; },\n/* harmony export */ BAIDU_BASE_URL: function() { return /* binding */ BAIDU_BASE_URL; },\n/* harmony export */ BAIDU_OATUH_URL: function() { return /* binding */ BAIDU_OATUH_URL; },\n/* harmony export */ BYTEDANCE_BASE_URL: function() { return /* binding */ BYTEDANCE_BASE_URL; },\n/* harmony export */ Baidu: function() { return /* binding */ Baidu; },\n/* harmony export */ ByteDance: function() { return /* binding */ ByteDance; },\n/* harmony export */ CACHE_URL_PREFIX: function() { return /* binding */ CACHE_URL_PREFIX; },\n/* harmony export */ CHATGLM_BASE_URL: function() { return /* binding */ CHATGLM_BASE_URL; },\n/* harmony export */ CHAT_PAGE_SIZE: function() { return /* binding */ CHAT_PAGE_SIZE; },\n/* harmony export */ ChatGLM: function() { return /* binding */ ChatGLM; },\n/* harmony export */ DEEPSEEK_BASE_URL: function() { return /* binding */ DEEPSEEK_BASE_URL; },\n/* harmony export */ DEEPSEEK_SUMMARIZE_MODEL: function() { return /* binding */ DEEPSEEK_SUMMARIZE_MODEL; },\n/* harmony export */ DEFAULT_GA_ID: function() { return /* binding */ DEFAULT_GA_ID; },\n/* harmony export */ DEFAULT_INPUT_TEMPLATE: function() { return /* binding */ DEFAULT_INPUT_TEMPLATE; },\n/* harmony export */ DEFAULT_MODELS: function() { return /* binding */ DEFAULT_MODELS; },\n/* harmony export */ DEFAULT_SIDEBAR_WIDTH: function() { return /* binding */ DEFAULT_SIDEBAR_WIDTH; },\n/* harmony export */ DEFAULT_SYSTEM_TEMPLATE: function() { return /* binding */ DEFAULT_SYSTEM_TEMPLATE; },\n/* harmony export */ DEFAULT_TTS_ENGINE: function() { return /* binding */ DEFAULT_TTS_ENGINE; },\n/* harmony export */ DEFAULT_TTS_ENGINES: function() { return /* binding */ DEFAULT_TTS_ENGINES; },\n/* harmony export */ DEFAULT_TTS_MODEL: function() { return /* binding */ DEFAULT_TTS_MODEL; },\n/* harmony export */ DEFAULT_TTS_MODELS: function() { return /* binding */ DEFAULT_TTS_MODELS; },\n/* harmony export */ DEFAULT_TTS_VOICE: function() { return /* binding */ DEFAULT_TTS_VOICE; },\n/* harmony export */ DEFAULT_TTS_VOICES: function() { return /* binding */ DEFAULT_TTS_VOICES; },\n/* harmony export */ DeepSeek: function() { return /* binding */ DeepSeek; },\n/* harmony export */ EXCLUDE_VISION_MODEL_REGEXES: function() { return /* binding */ EXCLUDE_VISION_MODEL_REGEXES; },\n/* harmony export */ EXPORT_MESSAGE_CLASS_NAME: function() { return /* binding */ EXPORT_MESSAGE_CLASS_NAME; },\n/* harmony export */ FETCH_COMMIT_URL: function() { return /* binding */ FETCH_COMMIT_URL; },\n/* harmony export */ FETCH_TAG_URL: function() { return /* binding */ FETCH_TAG_URL; },\n/* harmony export */ FileName: function() { return /* binding */ FileName; },\n/* harmony export */ GEMINI_BASE_URL: function() { return /* binding */ GEMINI_BASE_URL; },\n/* harmony export */ GEMINI_SUMMARIZE_MODEL: function() { return /* binding */ GEMINI_SUMMARIZE_MODEL; },\n/* harmony export */ Google: function() { return /* binding */ Google; },\n/* harmony export */ GoogleSafetySettingsThreshold: function() { return /* binding */ GoogleSafetySettingsThreshold; },\n/* harmony export */ IFLYTEK_BASE_URL: function() { return /* binding */ IFLYTEK_BASE_URL; },\n/* harmony export */ ISSUE_URL: function() { return /* binding */ ISSUE_URL; },\n/* harmony export */ Iflytek: function() { return /* binding */ Iflytek; },\n/* harmony export */ KnowledgeCutOffDate: function() { return /* binding */ KnowledgeCutOffDate; },\n/* harmony export */ LAST_INPUT_KEY: function() { return /* binding */ LAST_INPUT_KEY; },\n/* harmony export */ MAX_RENDER_MSG_COUNT: function() { return /* binding */ MAX_RENDER_MSG_COUNT; },\n/* harmony export */ MAX_SIDEBAR_WIDTH: function() { return /* binding */ MAX_SIDEBAR_WIDTH; },\n/* harmony export */ MCP_SYSTEM_TEMPLATE: function() { return /* binding */ MCP_SYSTEM_TEMPLATE; },\n/* harmony export */ MCP_TOOLS_TEMPLATE: function() { return /* binding */ MCP_TOOLS_TEMPLATE; },\n/* harmony export */ MIN_SIDEBAR_WIDTH: function() { return /* binding */ MIN_SIDEBAR_WIDTH; },\n/* harmony export */ MOONSHOT_BASE_URL: function() { return /* binding */ MOONSHOT_BASE_URL; },\n/* harmony export */ ModelProvider: function() { return /* binding */ ModelProvider; },\n/* harmony export */ Moonshot: function() { return /* binding */ Moonshot; },\n/* harmony export */ NARROW_SIDEBAR_WIDTH: function() { return /* binding */ NARROW_SIDEBAR_WIDTH; },\n/* harmony export */ OPENAI_BASE_URL: function() { return /* binding */ OPENAI_BASE_URL; },\n/* harmony export */ OWNER: function() { return /* binding */ OWNER; },\n/* harmony export */ OpenaiPath: function() { return /* binding */ OpenaiPath; },\n/* harmony export */ PLUGINS_REPO_URL: function() { return /* binding */ PLUGINS_REPO_URL; },\n/* harmony export */ Path: function() { return /* binding */ Path; },\n/* harmony export */ RELEASE_URL: function() { return /* binding */ RELEASE_URL; },\n/* harmony export */ REPO: function() { return /* binding */ REPO; },\n/* harmony export */ REPO_URL: function() { return /* binding */ REPO_URL; },\n/* harmony export */ REQUEST_TIMEOUT_MS: function() { return /* binding */ REQUEST_TIMEOUT_MS; },\n/* harmony export */ REQUEST_TIMEOUT_MS_FOR_THINKING: function() { return /* binding */ REQUEST_TIMEOUT_MS_FOR_THINKING; },\n/* harmony export */ RUNTIME_CONFIG_DOM: function() { return /* binding */ RUNTIME_CONFIG_DOM; },\n/* harmony export */ SAAS_CHAT_URL: function() { return /* binding */ SAAS_CHAT_URL; },\n/* harmony export */ SAAS_CHAT_UTM_URL: function() { return /* binding */ SAAS_CHAT_UTM_URL; },\n/* harmony export */ SILICONFLOW_BASE_URL: function() { return /* binding */ SILICONFLOW_BASE_URL; },\n/* harmony export */ STABILITY_BASE_URL: function() { return /* binding */ STABILITY_BASE_URL; },\n/* harmony export */ STORAGE_KEY: function() { return /* binding */ STORAGE_KEY; },\n/* harmony export */ SUMMARIZE_MODEL: function() { return /* binding */ SUMMARIZE_MODEL; },\n/* harmony export */ ServiceProvider: function() { return /* binding */ ServiceProvider; },\n/* harmony export */ SiliconFlow: function() { return /* binding */ SiliconFlow; },\n/* harmony export */ SlotID: function() { return /* binding */ SlotID; },\n/* harmony export */ Stability: function() { return /* binding */ Stability; },\n/* harmony export */ StoreKey: function() { return /* binding */ StoreKey; },\n/* harmony export */ TENCENT_BASE_URL: function() { return /* binding */ TENCENT_BASE_URL; },\n/* harmony export */ Tencent: function() { return /* binding */ Tencent; },\n/* harmony export */ UNFINISHED_INPUT: function() { return /* binding */ UNFINISHED_INPUT; },\n/* harmony export */ UPDATE_URL: function() { return /* binding */ UPDATE_URL; },\n/* harmony export */ UPLOAD_URL: function() { return /* binding */ UPLOAD_URL; },\n/* harmony export */ VISION_MODEL_REGEXES: function() { return /* binding */ VISION_MODEL_REGEXES; },\n/* harmony export */ XAI: function() { return /* binding */ XAI; },\n/* harmony export */ XAI_BASE_URL: function() { return /* binding */ XAI_BASE_URL; },\n/* harmony export */ internalAllowedWebDavEndpoints: function() { return /* binding */ internalAllowedWebDavEndpoints; }\n/* harmony export */ });\nconst OWNER = \"ChatGPTNextWeb\";\nconst REPO = \"ChatGPT-Next-Web\";\nconst REPO_URL = \"https://github.com/\".concat(OWNER, \"/\").concat(REPO);\nconst PLUGINS_REPO_URL = \"https://github.com/\".concat(OWNER, \"/NextChat-Awesome-Plugins\");\nconst ISSUE_URL = \"https://github.com/\".concat(OWNER, \"/\").concat(REPO, \"/issues\");\nconst UPDATE_URL = \"\".concat(REPO_URL, \"#keep-updated\");\nconst RELEASE_URL = \"\".concat(REPO_URL, \"/releases\");\nconst FETCH_COMMIT_URL = \"https://api.github.com/repos/\".concat(OWNER, \"/\").concat(REPO, \"/commits?per_page=1\");\nconst FETCH_TAG_URL = \"https://api.github.com/repos/\".concat(OWNER, \"/\").concat(REPO, \"/tags?per_page=1\");\nconst RUNTIME_CONFIG_DOM = \"danger-runtime-config\";\nconst STABILITY_BASE_URL = \"https://api.stability.ai\";\nconst OPENAI_BASE_URL = \"https://api.openai.com\";\nconst ANTHROPIC_BASE_URL = \"https://api.anthropic.com\";\nconst GEMINI_BASE_URL = \"https://generativelanguage.googleapis.com/\";\nconst BAIDU_BASE_URL = \"https://aip.baidubce.com\";\nconst BAIDU_OATUH_URL = \"\".concat(BAIDU_BASE_URL, \"/oauth/2.0/token\");\nconst BYTEDANCE_BASE_URL = \"https://ark.cn-beijing.volces.com\";\nconst ALIBABA_BASE_URL = \"https://dashscope.aliyuncs.com/api/\";\nconst TENCENT_BASE_URL = \"https://hunyuan.tencentcloudapi.com\";\nconst MOONSHOT_BASE_URL = \"https://api.moonshot.cn\";\nconst IFLYTEK_BASE_URL = \"https://spark-api-open.xf-yun.com\";\nconst DEEPSEEK_BASE_URL = \"https://api.deepseek.com\";\nconst XAI_BASE_URL = \"https://api.x.ai\";\nconst CHATGLM_BASE_URL = \"https://open.bigmodel.cn\";\nconst SILICONFLOW_BASE_URL = \"https://api.siliconflow.cn\";\nconst CACHE_URL_PREFIX = \"/api/cache\";\nconst UPLOAD_URL = \"\".concat(CACHE_URL_PREFIX, \"/upload\");\nvar Path;\n(function(Path) {\n Path[\"Home\"] = \"/\";\n Path[\"Chat\"] = \"/chat\";\n Path[\"Settings\"] = \"/settings\";\n Path[\"NewChat\"] = \"/new-chat\";\n Path[\"Masks\"] = \"/masks\";\n Path[\"Plugins\"] = \"/plugins\";\n Path[\"Auth\"] = \"/auth\";\n Path[\"Sd\"] = \"/sd\";\n Path[\"SdNew\"] = \"/sd-new\";\n Path[\"Artifacts\"] = \"/artifacts\";\n Path[\"SearchChat\"] = \"/search-chat\";\n Path[\"McpMarket\"] = \"/mcp-market\";\n})(Path || (Path = {}));\nvar ApiPath;\n(function(ApiPath) {\n ApiPath[\"Cors\"] = \"\";\n ApiPath[\"Azure\"] = \"/api/azure\";\n ApiPath[\"OpenAI\"] = \"/api/openai\";\n ApiPath[\"Anthropic\"] = \"/api/anthropic\";\n ApiPath[\"Google\"] = \"/api/google\";\n ApiPath[\"Baidu\"] = \"/api/baidu\";\n ApiPath[\"ByteDance\"] = \"/api/bytedance\";\n ApiPath[\"Alibaba\"] = \"/api/alibaba\";\n ApiPath[\"Tencent\"] = \"/api/tencent\";\n ApiPath[\"Moonshot\"] = \"/api/moonshot\";\n ApiPath[\"Iflytek\"] = \"/api/iflytek\";\n ApiPath[\"Stability\"] = \"/api/stability\";\n ApiPath[\"Artifacts\"] = \"/api/artifacts\";\n ApiPath[\"XAI\"] = \"/api/xai\";\n ApiPath[\"ChatGLM\"] = \"/api/chatglm\";\n ApiPath[\"DeepSeek\"] = \"/api/deepseek\";\n ApiPath[\"SiliconFlow\"] = \"/api/siliconflow\";\n})(ApiPath || (ApiPath = {}));\nvar SlotID;\n(function(SlotID) {\n SlotID[\"AppBody\"] = \"app-body\";\n SlotID[\"CustomModel\"] = \"custom-model\";\n})(SlotID || (SlotID = {}));\nvar FileName;\n(function(FileName) {\n FileName[\"Masks\"] = \"masks.json\";\n FileName[\"Prompts\"] = \"prompts.json\";\n})(FileName || (FileName = {}));\nvar StoreKey;\n(function(StoreKey) {\n StoreKey[\"Chat\"] = \"chat-next-web-store\";\n StoreKey[\"Plugin\"] = \"chat-next-web-plugin\";\n StoreKey[\"Access\"] = \"access-control\";\n StoreKey[\"Config\"] = \"app-config\";\n StoreKey[\"Mask\"] = \"mask-store\";\n StoreKey[\"Prompt\"] = \"prompt-store\";\n StoreKey[\"Update\"] = \"chat-update\";\n StoreKey[\"Sync\"] = \"sync\";\n StoreKey[\"SdList\"] = \"sd-list\";\n StoreKey[\"Mcp\"] = \"mcp-store\";\n})(StoreKey || (StoreKey = {}));\nconst DEFAULT_SIDEBAR_WIDTH = 300;\nconst MAX_SIDEBAR_WIDTH = 500;\nconst MIN_SIDEBAR_WIDTH = 230;\nconst NARROW_SIDEBAR_WIDTH = 100;\nconst ACCESS_CODE_PREFIX = \"nk-\";\nconst LAST_INPUT_KEY = \"last-input\";\nconst UNFINISHED_INPUT = (id)=>\"unfinished-input-\" + id;\nconst STORAGE_KEY = \"chatgpt-next-web\";\nconst REQUEST_TIMEOUT_MS = 60000;\nconst REQUEST_TIMEOUT_MS_FOR_THINKING = REQUEST_TIMEOUT_MS * 5;\nconst EXPORT_MESSAGE_CLASS_NAME = \"export-markdown\";\nvar ServiceProvider;\n(function(ServiceProvider) {\n ServiceProvider[\"OpenAI\"] = \"OpenAI\";\n ServiceProvider[\"Azure\"] = \"Azure\";\n ServiceProvider[\"Google\"] = \"Google\";\n ServiceProvider[\"Anthropic\"] = \"Anthropic\";\n ServiceProvider[\"Baidu\"] = \"Baidu\";\n ServiceProvider[\"ByteDance\"] = \"ByteDance\";\n ServiceProvider[\"Alibaba\"] = \"Alibaba\";\n ServiceProvider[\"Tencent\"] = \"Tencent\";\n ServiceProvider[\"Moonshot\"] = \"Moonshot\";\n ServiceProvider[\"Stability\"] = \"Stability\";\n ServiceProvider[\"Iflytek\"] = \"Iflytek\";\n ServiceProvider[\"XAI\"] = \"XAI\";\n ServiceProvider[\"ChatGLM\"] = \"ChatGLM\";\n ServiceProvider[\"DeepSeek\"] = \"DeepSeek\";\n ServiceProvider[\"SiliconFlow\"] = \"SiliconFlow\";\n})(ServiceProvider || (ServiceProvider = {}));\nvar GoogleSafetySettingsThreshold;\n(function(GoogleSafetySettingsThreshold) {\n GoogleSafetySettingsThreshold[\"BLOCK_NONE\"] = \"BLOCK_NONE\";\n GoogleSafetySettingsThreshold[\"BLOCK_ONLY_HIGH\"] = \"BLOCK_ONLY_HIGH\";\n GoogleSafetySettingsThreshold[\"BLOCK_MEDIUM_AND_ABOVE\"] = \"BLOCK_MEDIUM_AND_ABOVE\";\n GoogleSafetySettingsThreshold[\"BLOCK_LOW_AND_ABOVE\"] = \"BLOCK_LOW_AND_ABOVE\";\n})(GoogleSafetySettingsThreshold || (GoogleSafetySettingsThreshold = {}));\nvar ModelProvider;\n(function(ModelProvider) {\n ModelProvider[\"Stability\"] = \"Stability\";\n ModelProvider[\"GPT\"] = \"GPT\";\n ModelProvider[\"GeminiPro\"] = \"GeminiPro\";\n ModelProvider[\"Claude\"] = \"Claude\";\n ModelProvider[\"Ernie\"] = \"Ernie\";\n ModelProvider[\"Doubao\"] = \"Doubao\";\n ModelProvider[\"Qwen\"] = \"Qwen\";\n ModelProvider[\"Hunyuan\"] = \"Hunyuan\";\n ModelProvider[\"Moonshot\"] = \"Moonshot\";\n ModelProvider[\"Iflytek\"] = \"Iflytek\";\n ModelProvider[\"XAI\"] = \"XAI\";\n ModelProvider[\"ChatGLM\"] = \"ChatGLM\";\n ModelProvider[\"DeepSeek\"] = \"DeepSeek\";\n ModelProvider[\"SiliconFlow\"] = \"SiliconFlow\";\n})(ModelProvider || (ModelProvider = {}));\nconst Stability = {\n GeneratePath: \"v2beta/stable-image/generate\",\n ExampleEndpoint: \"https://api.stability.ai\"\n};\nconst Anthropic = {\n ChatPath: \"v1/messages\",\n ChatPath1: \"v1/complete\",\n ExampleEndpoint: \"https://api.anthropic.com\",\n Vision: \"2023-06-01\"\n};\nconst OpenaiPath = {\n ChatPath: \"v1/chat/completions\",\n SpeechPath: \"v1/audio/speech\",\n ImagePath: \"v1/images/generations\",\n UsagePath: \"dashboard/billing/usage\",\n SubsPath: \"dashboard/billing/subscription\",\n ListModelPath: \"v1/models\"\n};\nconst Azure = {\n ChatPath: (deployName, apiVersion)=>\"deployments/\".concat(deployName, \"/chat/completions?api-version=\").concat(apiVersion),\n // https://.openai.azure.com/openai/deployments//images/generations?api-version=\n ImagePath: (deployName, apiVersion)=>\"deployments/\".concat(deployName, \"/images/generations?api-version=\").concat(apiVersion),\n ExampleEndpoint: \"https://{resource-url}/openai\"\n};\nconst Google = {\n ExampleEndpoint: \"https://generativelanguage.googleapis.com/\",\n ChatPath: (modelName)=>\"v1beta/models/\".concat(modelName, \":streamGenerateContent\")\n};\nconst Baidu = {\n ExampleEndpoint: BAIDU_BASE_URL,\n ChatPath: (modelName)=>{\n let endpoint = modelName;\n if (modelName === \"ernie-4.0-8k\") {\n endpoint = \"completions_pro\";\n }\n if (modelName === \"ernie-4.0-8k-preview-0518\") {\n endpoint = \"completions_adv_pro\";\n }\n if (modelName === \"ernie-3.5-8k\") {\n endpoint = \"completions\";\n }\n if (modelName === \"ernie-speed-8k\") {\n endpoint = \"ernie_speed\";\n }\n return \"rpc/2.0/ai_custom/v1/wenxinworkshop/chat/\".concat(endpoint);\n }\n};\nconst ByteDance = {\n ExampleEndpoint: \"https://ark.cn-beijing.volces.com/api/\",\n ChatPath: \"api/v3/chat/completions\"\n};\nconst Alibaba = {\n ExampleEndpoint: ALIBABA_BASE_URL,\n ChatPath: \"v1/services/aigc/text-generation/generation\"\n};\nconst Tencent = {\n ExampleEndpoint: TENCENT_BASE_URL\n};\nconst Moonshot = {\n ExampleEndpoint: MOONSHOT_BASE_URL,\n ChatPath: \"v1/chat/completions\"\n};\nconst Iflytek = {\n ExampleEndpoint: IFLYTEK_BASE_URL,\n ChatPath: \"v1/chat/completions\"\n};\nconst DeepSeek = {\n ExampleEndpoint: DEEPSEEK_BASE_URL,\n ChatPath: \"chat/completions\"\n};\nconst XAI = {\n ExampleEndpoint: XAI_BASE_URL,\n ChatPath: \"v1/chat/completions\"\n};\nconst ChatGLM = {\n ExampleEndpoint: CHATGLM_BASE_URL,\n ChatPath: \"api/paas/v4/chat/completions\",\n ImagePath: \"api/paas/v4/images/generations\",\n VideoPath: \"api/paas/v4/videos/generations\"\n};\nconst SiliconFlow = {\n ExampleEndpoint: SILICONFLOW_BASE_URL,\n ChatPath: \"v1/chat/completions\"\n};\nconst DEFAULT_INPUT_TEMPLATE = \"{{input}}\"; // input / time / model / lang\n// export const DEFAULT_SYSTEM_TEMPLATE = `\n// You are ChatGPT, a large language model trained by {{ServiceProvider}}.\n// Knowledge cutoff: {{cutoff}}\n// Current model: {{model}}\n// Current time: {{time}}\n// Latex inline: $x^2$\n// Latex block: $$e=mc^2$$\n// `;\nconst DEFAULT_SYSTEM_TEMPLATE = \"\\nYou are ChatGPT, a large language model trained by {{ServiceProvider}}.\\nKnowledge cutoff: {{cutoff}}\\nCurrent model: {{model}}\\nCurrent time: {{time}}\\nLatex inline: \\\\(x^2\\\\) \\nLatex block: $$e=mc^2$$\\n\";\nconst MCP_TOOLS_TEMPLATE = \"\\n[clientId]\\n{{ clientId }}\\n[tools]\\n{{ tools }}\\n\";\nconst MCP_SYSTEM_TEMPLATE = '\\nYou are an AI assistant with access to system tools. Your role is to help users by combining natural language understanding with tool operations when needed.\\n\\n1. AVAILABLE TOOLS:\\n{{ MCP_TOOLS }}\\n\\n2. WHEN TO USE TOOLS:\\n - ALWAYS USE TOOLS when they can help answer user questions\\n - DO NOT just describe what you could do - TAKE ACTION immediately\\n - If you\\'re not sure whether to use a tool, USE IT\\n - Common triggers for tool use:\\n * Questions about files or directories\\n * Requests to check, list, or manipulate system resources\\n * Any query that can be answered with available tools\\n\\n3. HOW TO USE TOOLS:\\n A. Tool Call Format:\\n - Use markdown code blocks with format: ```json:mcp:{clientId}```\\n - Always include:\\n * method: \"tools/call\"(Only this method is supported)\\n * params: \\n - name: must match an available primitive name\\n - arguments: required parameters for the primitive\\n\\n B. Response Format:\\n - Tool responses will come as user messages\\n - Format: ```json:mcp-response:{clientId}```\\n - Wait for response before making another tool call\\n\\n C. Important Rules:\\n - Only use tools/call method\\n - Only ONE tool call per message\\n - ALWAYS TAKE ACTION instead of just describing what you could do\\n - Include the correct clientId in code block language tag\\n - Verify arguments match the primitive\\'s requirements\\n\\n4. INTERACTION FLOW:\\n A. When user makes a request:\\n - IMMEDIATELY use appropriate tool if available\\n - DO NOT ask if user wants you to use the tool\\n - DO NOT just describe what you could do\\n B. After receiving tool response:\\n - Explain results clearly\\n - Take next appropriate action if needed\\n C. If tools fail:\\n - Explain the error\\n - Try alternative approach immediately\\n\\n5. EXAMPLE INTERACTION:\\n\\n good example:\\n\\n ```json:mcp:filesystem\\n {\\n \"method\": \"tools/call\",\\n \"params\": {\\n \"name\": \"list_allowed_directories\",\\n \"arguments\": {}\\n }\\n }\\n ```\"\\n\\n\\n ```json:mcp-response:filesystem\\n {\\n \"method\": \"tools/call\",\\n \"params\": {\\n \"name\": \"write_file\",\\n \"arguments\": {\\n \"path\": \"/Users/river/dev/nextchat/test/joke.txt\",\\n \"content\": \"为什么数学书总是感到忧伤?因为它有太多的问题。\"\\n }\\n }\\n }\\n```\\n\\n follwing is the wrong! mcp json example:\\n\\n ```json:mcp:filesystem\\n {\\n \"method\": \"write_file\",\\n \"params\": {\\n \"path\": \"NextChat_Information.txt\",\\n \"content\": \"1\"\\n }\\n }\\n ```\\n\\n This is wrong because the method is not tools/call.\\n \\n ```{\\n \"method\": \"search_repositories\",\\n \"params\": {\\n \"query\": \"2oeee\"\\n }\\n}\\n ```\\n\\n This is wrong because the method is not tools/call.!!!!!!!!!!!\\n\\n the right format is:\\n ```json:mcp:filesystem\\n {\\n \"method\": \"tools/call\",\\n \"params\": {\\n \"name\": \"search_repositories\",\\n \"arguments\": {\\n \"query\": \"2oeee\"\\n }\\n }\\n }\\n ```\\n \\n please follow the format strictly ONLY use tools/call method!!!!!!!!!!!\\n \\n';\nconst SUMMARIZE_MODEL = \"gpt-4o-mini\";\nconst GEMINI_SUMMARIZE_MODEL = \"gemini-pro\";\nconst DEEPSEEK_SUMMARIZE_MODEL = \"deepseek-ai/DeepSeek-V3\";\nconst KnowledgeCutOffDate = {\n default: \"2021-09\",\n \"gpt-4-turbo\": \"2023-12\",\n \"gpt-4-turbo-2024-04-09\": \"2023-12\",\n \"gpt-4-turbo-preview\": \"2023-12\",\n \"gpt-4o\": \"2023-10\",\n \"gpt-4o-2024-05-13\": \"2023-10\",\n \"gpt-4o-2024-08-06\": \"2023-10\",\n \"gpt-4o-2024-11-20\": \"2023-10\",\n \"chatgpt-4o-latest\": \"2023-10\",\n \"gpt-4o-mini\": \"2023-10\",\n \"gpt-4o-mini-2024-07-18\": \"2023-10\",\n \"gpt-4-vision-preview\": \"2023-04\",\n \"o1-mini-2024-09-12\": \"2023-10\",\n \"o1-mini\": \"2023-10\",\n \"o1-preview-2024-09-12\": \"2023-10\",\n \"o1-preview\": \"2023-10\",\n \"o1-2024-12-17\": \"2023-10\",\n o1: \"2023-10\",\n \"o3-mini-2025-01-31\": \"2023-10\",\n \"o3-mini\": \"2023-10\",\n // After improvements,\n // it's now easier to add \"KnowledgeCutOffDate\" instead of stupid hardcoding it, as was done previously.\n \"gemini-pro\": \"2023-12\",\n \"gemini-pro-vision\": \"2023-12\",\n \"deepseek-chat\": \"2024-07\",\n \"deepseek-coder\": \"2024-07\"\n};\nconst DEFAULT_TTS_ENGINE = \"OpenAI-TTS\";\nconst DEFAULT_TTS_ENGINES = [\n \"OpenAI-TTS\",\n \"Edge-TTS\"\n];\nconst DEFAULT_TTS_MODEL = \"tts-1\";\nconst DEFAULT_TTS_VOICE = \"alloy\";\nconst DEFAULT_TTS_MODELS = [\n \"tts-1\",\n \"tts-1-hd\"\n];\nconst DEFAULT_TTS_VOICES = [\n \"alloy\",\n \"echo\",\n \"fable\",\n \"onyx\",\n \"nova\",\n \"shimmer\"\n];\nconst VISION_MODEL_REGEXES = [\n /vision/,\n /gpt-4o/,\n /claude-3/,\n /gemini-1\\.5/,\n /gemini-exp/,\n /gemini-2\\.0/,\n /learnlm/,\n /qwen-vl/,\n /qwen2-vl/,\n /gpt-4-turbo(?!.*preview)/,\n /^dall-e-3$/,\n /glm-4v/\n];\nconst EXCLUDE_VISION_MODEL_REGEXES = [\n /claude-3-5-haiku-20241022/\n];\nconst openaiModels = [];\nconst googleModels = [];\nconst anthropicModels = [];\nconst baiduModels = [];\nconst bytedanceModels = [];\nconst alibabaModes = [];\nconst tencentModels = [];\nconst moonshotModes = [];\nconst iflytekModels = [];\nconst deepseekModels = [];\nconst xAIModes = [];\nconst chatglmModels = [];\nconst siliconflowModels = [\n \"deepseek-ai/DeepSeek-V3\",\n \"deepseek-ai/DeepSeek-R1\"\n];\nlet seq = 1000; // 内置的模型序号生成器从1000开始\nconst DEFAULT_MODELS = [\n ...openaiModels.map((name)=>({\n name,\n available: true,\n sorted: seq++,\n provider: {\n id: \"openai\",\n providerName: \"OpenAI\",\n providerType: \"openai\",\n sorted: 1\n }\n })),\n ...openaiModels.map((name)=>({\n name,\n available: true,\n sorted: seq++,\n provider: {\n id: \"azure\",\n providerName: \"Azure\",\n providerType: \"azure\",\n sorted: 2\n }\n })),\n ...googleModels.map((name)=>({\n name,\n available: true,\n sorted: seq++,\n provider: {\n id: \"google\",\n providerName: \"Google\",\n providerType: \"google\",\n sorted: 3\n }\n })),\n ...anthropicModels.map((name)=>({\n name,\n available: true,\n sorted: seq++,\n provider: {\n id: \"anthropic\",\n providerName: \"Anthropic\",\n providerType: \"anthropic\",\n sorted: 4\n }\n })),\n ...baiduModels.map((name)=>({\n name,\n available: true,\n sorted: seq++,\n provider: {\n id: \"baidu\",\n providerName: \"Baidu\",\n providerType: \"baidu\",\n sorted: 5\n }\n })),\n ...bytedanceModels.map((name)=>({\n name,\n available: true,\n sorted: seq++,\n provider: {\n id: \"bytedance\",\n providerName: \"ByteDance\",\n providerType: \"bytedance\",\n sorted: 6\n }\n })),\n ...alibabaModes.map((name)=>({\n name,\n available: true,\n sorted: seq++,\n provider: {\n id: \"alibaba\",\n providerName: \"Alibaba\",\n providerType: \"alibaba\",\n sorted: 7\n }\n })),\n ...tencentModels.map((name)=>({\n name,\n available: true,\n sorted: seq++,\n provider: {\n id: \"tencent\",\n providerName: \"Tencent\",\n providerType: \"tencent\",\n sorted: 8\n }\n })),\n ...moonshotModes.map((name)=>({\n name,\n available: true,\n sorted: seq++,\n provider: {\n id: \"moonshot\",\n providerName: \"Moonshot\",\n providerType: \"moonshot\",\n sorted: 9\n }\n })),\n ...iflytekModels.map((name)=>({\n name,\n available: true,\n sorted: seq++,\n provider: {\n id: \"iflytek\",\n providerName: \"Iflytek\",\n providerType: \"iflytek\",\n sorted: 10\n }\n })),\n ...xAIModes.map((name)=>({\n name,\n available: true,\n sorted: seq++,\n provider: {\n id: \"xai\",\n providerName: \"XAI\",\n providerType: \"xai\",\n sorted: 11\n }\n })),\n ...chatglmModels.map((name)=>({\n name,\n available: true,\n sorted: seq++,\n provider: {\n id: \"chatglm\",\n providerName: \"ChatGLM\",\n providerType: \"chatglm\",\n sorted: 12\n }\n })),\n ...deepseekModels.map((name)=>({\n name,\n available: true,\n sorted: seq++,\n provider: {\n id: \"deepseek\",\n providerName: \"DeepSeek\",\n providerType: \"deepseek\",\n sorted: 13\n }\n })),\n ...siliconflowModels.map((name)=>({\n name,\n available: true,\n sorted: seq++,\n provider: {\n id: \"siliconflow\",\n providerName: \"SiliconFlow\",\n providerType: \"siliconflow\",\n sorted: 14\n }\n }))\n];\nconst CHAT_PAGE_SIZE = 15;\nconst MAX_RENDER_MSG_COUNT = 45;\n// some famous webdav endpoints\nconst internalAllowedWebDavEndpoints = [\n \"https://dav.jianguoyun.com/dav/\",\n \"https://dav.dropdav.com/\",\n \"https://dav.box.com/dav\",\n \"https://nanao.teracloud.jp/dav/\",\n \"https://bora.teracloud.jp/dav/\",\n \"https://webdav.4shared.com/\",\n \"https://dav.idrivesync.com\",\n \"https://webdav.yandex.com\",\n \"https://app.koofr.net/dav/Koofr\"\n];\nconst DEFAULT_GA_ID = \"G-89WN60ZK2E\";\nconst SAAS_CHAT_URL = \"https://nextchat.dev/chat\";\nconst SAAS_CHAT_UTM_URL = \"https://nextchat.dev/chat?utm=github\";\n\n\n;\n // Wrapped in an IIFE to avoid polluting the global scope\n ;\n (function () {\n var _a, _b;\n // Legacy CSS implementations will `eval` browser code in a Node.js context\n // to extract CSS. For backwards compatibility, we need to check we're in a\n // browser context before continuing.\n if (typeof self !== 'undefined' &&\n // AMP / No-JS mode does not inject these helpers:\n '$RefreshHelpers$' in self) {\n // @ts-ignore __webpack_module__ is global\n var currentExports = module.exports;\n // @ts-ignore __webpack_module__ is global\n var prevSignature = (_b = (_a = module.hot.data) === null || _a === void 0 ? void 0 : _a.prevSignature) !== null && _b !== void 0 ? _b : null;\n // This cannot happen in MainTemplate because the exports mismatch between\n // templating and execution.\n self.$RefreshHelpers$.registerExportsForReactRefresh(currentExports, module.id);\n // A module can be accepted automatically based on its exports, e.g. when\n // it is a Refresh Boundary.\n if (self.$RefreshHelpers$.isReactRefreshBoundary(currentExports)) {\n // Save the previous exports signature on update so we can compare the boundary\n // signatures. We avoid saving exports themselves since it causes memory leaks (https://github.com/vercel/next.js/pull/53797)\n module.hot.dispose(function (data) {\n data.prevSignature =\n self.$RefreshHelpers$.getRefreshBoundarySignature(currentExports);\n });\n // Unconditionally accept an update to this module, we'll check if it's\n // still a Refresh Boundary later.\n // @ts-ignore importMeta is replaced in the loader\n module.hot.accept();\n // This field is set when the previous version of this module was a\n // Refresh Boundary, letting us know we need to check for invalidation or\n // enqueue an update.\n if (prevSignature !== null) {\n // A boundary can become ineligible if its exports are incompatible\n // with the previous exports.\n //\n // For example, if you add/remove/change exports, we'll want to\n // re-execute the importing modules, and force those components to\n // re-render. Similarly, if you convert a class component to a\n // function, we want to invalidate the boundary.\n if (self.$RefreshHelpers$.shouldInvalidateReactRefreshBoundary(prevSignature, self.$RefreshHelpers$.getRefreshBoundarySignature(currentExports))) {\n module.hot.invalidate();\n }\n else {\n self.$RefreshHelpers$.scheduleUpdate();\n }\n }\n }\n else {\n // Since we just executed the code for the module, it's possible that the\n // new exports made it ineligible for being a boundary.\n // We only care about the case when we were _previously_ a boundary,\n // because we already accepted this update (accidental side effect).\n var isNoLongerABoundary = prevSignature !== null;\n if (isNoLongerABoundary) {\n module.hot.invalidate();\n }\n }\n }\n })();\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"(app-pages-browser)/./app/constant.ts","mappings":"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","sources":["webpack://_N_E/./app/constant.ts?af44"],"sourcesContent":["export const OWNER = \"ChatGPTNextWeb\";\r\nexport const REPO = \"ChatGPT-Next-Web\";\r\nexport const REPO_URL = `https://github.com/${OWNER}/${REPO}`;\r\nexport const PLUGINS_REPO_URL = `https://github.com/${OWNER}/NextChat-Awesome-Plugins`;\r\nexport const ISSUE_URL = `https://github.com/${OWNER}/${REPO}/issues`;\r\nexport const UPDATE_URL = `${REPO_URL}#keep-updated`;\r\nexport const RELEASE_URL = `${REPO_URL}/releases`;\r\nexport const FETCH_COMMIT_URL = `https://api.github.com/repos/${OWNER}/${REPO}/commits?per_page=1`;\r\nexport const FETCH_TAG_URL = `https://api.github.com/repos/${OWNER}/${REPO}/tags?per_page=1`;\r\nexport const RUNTIME_CONFIG_DOM = \"danger-runtime-config\";\r\n\r\nexport const STABILITY_BASE_URL = \"https://api.stability.ai\";\r\n\r\nexport const OPENAI_BASE_URL = \"https://api.openai.com\";\r\nexport const ANTHROPIC_BASE_URL = \"https://api.anthropic.com\";\r\n\r\nexport const GEMINI_BASE_URL = \"https://generativelanguage.googleapis.com/\";\r\n\r\nexport const BAIDU_BASE_URL = \"https://aip.baidubce.com\";\r\nexport const BAIDU_OATUH_URL = `${BAIDU_BASE_URL}/oauth/2.0/token`;\r\n\r\nexport const BYTEDANCE_BASE_URL = \"https://ark.cn-beijing.volces.com\";\r\n\r\nexport const ALIBABA_BASE_URL = \"https://dashscope.aliyuncs.com/api/\";\r\n\r\nexport const TENCENT_BASE_URL = \"https://hunyuan.tencentcloudapi.com\";\r\n\r\nexport const MOONSHOT_BASE_URL = \"https://api.moonshot.cn\";\r\nexport const IFLYTEK_BASE_URL = \"https://spark-api-open.xf-yun.com\";\r\n\r\nexport const DEEPSEEK_BASE_URL = \"https://api.deepseek.com\";\r\n\r\nexport const XAI_BASE_URL = \"https://api.x.ai\";\r\n\r\nexport const CHATGLM_BASE_URL = \"https://open.bigmodel.cn\";\r\n\r\nexport const SILICONFLOW_BASE_URL = \"https://api.siliconflow.cn\";\r\n\r\nexport const CACHE_URL_PREFIX = \"/api/cache\";\r\nexport const UPLOAD_URL = `${CACHE_URL_PREFIX}/upload`;\r\n\r\nexport enum Path {\r\n  Home = \"/\",\r\n  Chat = \"/chat\",\r\n  Settings = \"/settings\",\r\n  NewChat = \"/new-chat\",\r\n  Masks = \"/masks\",\r\n  Plugins = \"/plugins\",\r\n  Auth = \"/auth\",\r\n  Sd = \"/sd\",\r\n  SdNew = \"/sd-new\",\r\n  Artifacts = \"/artifacts\",\r\n  SearchChat = \"/search-chat\",\r\n  McpMarket = \"/mcp-market\",\r\n}\r\n\r\nexport enum ApiPath {\r\n  Cors = \"\",\r\n  Azure = \"/api/azure\",\r\n  OpenAI = \"/api/openai\",\r\n  Anthropic = \"/api/anthropic\",\r\n  Google = \"/api/google\",\r\n  Baidu = \"/api/baidu\",\r\n  ByteDance = \"/api/bytedance\",\r\n  Alibaba = \"/api/alibaba\",\r\n  Tencent = \"/api/tencent\",\r\n  Moonshot = \"/api/moonshot\",\r\n  Iflytek = \"/api/iflytek\",\r\n  Stability = \"/api/stability\",\r\n  Artifacts = \"/api/artifacts\",\r\n  XAI = \"/api/xai\",\r\n  ChatGLM = \"/api/chatglm\",\r\n  DeepSeek = \"/api/deepseek\",\r\n  SiliconFlow = \"/api/siliconflow\",\r\n}\r\n\r\nexport enum SlotID {\r\n  AppBody = \"app-body\",\r\n  CustomModel = \"custom-model\",\r\n}\r\n\r\nexport enum FileName {\r\n  Masks = \"masks.json\",\r\n  Prompts = \"prompts.json\",\r\n}\r\n\r\nexport enum StoreKey {\r\n  Chat = \"chat-next-web-store\",\r\n  Plugin = \"chat-next-web-plugin\",\r\n  Access = \"access-control\",\r\n  Config = \"app-config\",\r\n  Mask = \"mask-store\",\r\n  Prompt = \"prompt-store\",\r\n  Update = \"chat-update\",\r\n  Sync = \"sync\",\r\n  SdList = \"sd-list\",\r\n  Mcp = \"mcp-store\",\r\n}\r\n\r\nexport const DEFAULT_SIDEBAR_WIDTH = 300;\r\nexport const MAX_SIDEBAR_WIDTH = 500;\r\nexport const MIN_SIDEBAR_WIDTH = 230;\r\nexport const NARROW_SIDEBAR_WIDTH = 100;\r\n\r\nexport const ACCESS_CODE_PREFIX = \"nk-\";\r\n\r\nexport const LAST_INPUT_KEY = \"last-input\";\r\nexport const UNFINISHED_INPUT = (id: string) => \"unfinished-input-\" + id;\r\n\r\nexport const STORAGE_KEY = \"chatgpt-next-web\";\r\n\r\nexport const REQUEST_TIMEOUT_MS = 60000;\r\nexport const REQUEST_TIMEOUT_MS_FOR_THINKING = REQUEST_TIMEOUT_MS * 5;\r\n\r\nexport const EXPORT_MESSAGE_CLASS_NAME = \"export-markdown\";\r\n\r\nexport enum ServiceProvider {\r\n  OpenAI = \"OpenAI\",\r\n  Azure = \"Azure\",\r\n  Google = \"Google\",\r\n  Anthropic = \"Anthropic\",\r\n  Baidu = \"Baidu\",\r\n  ByteDance = \"ByteDance\",\r\n  Alibaba = \"Alibaba\",\r\n  Tencent = \"Tencent\",\r\n  Moonshot = \"Moonshot\",\r\n  Stability = \"Stability\",\r\n  Iflytek = \"Iflytek\",\r\n  XAI = \"XAI\",\r\n  ChatGLM = \"ChatGLM\",\r\n  DeepSeek = \"DeepSeek\",\r\n  SiliconFlow = \"SiliconFlow\",\r\n}\r\n\r\n// Google API safety settings, see https://ai.google.dev/gemini-api/docs/safety-settings\r\n// BLOCK_NONE will not block any content, and BLOCK_ONLY_HIGH will block only high-risk content.\r\nexport enum GoogleSafetySettingsThreshold {\r\n  BLOCK_NONE = \"BLOCK_NONE\",\r\n  BLOCK_ONLY_HIGH = \"BLOCK_ONLY_HIGH\",\r\n  BLOCK_MEDIUM_AND_ABOVE = \"BLOCK_MEDIUM_AND_ABOVE\",\r\n  BLOCK_LOW_AND_ABOVE = \"BLOCK_LOW_AND_ABOVE\",\r\n}\r\n\r\nexport enum ModelProvider {\r\n  Stability = \"Stability\",\r\n  GPT = \"GPT\",\r\n  GeminiPro = \"GeminiPro\",\r\n  Claude = \"Claude\",\r\n  Ernie = \"Ernie\",\r\n  Doubao = \"Doubao\",\r\n  Qwen = \"Qwen\",\r\n  Hunyuan = \"Hunyuan\",\r\n  Moonshot = \"Moonshot\",\r\n  Iflytek = \"Iflytek\",\r\n  XAI = \"XAI\",\r\n  ChatGLM = \"ChatGLM\",\r\n  DeepSeek = \"DeepSeek\",\r\n  SiliconFlow = \"SiliconFlow\",\r\n}\r\n\r\nexport const Stability = {\r\n  GeneratePath: \"v2beta/stable-image/generate\",\r\n  ExampleEndpoint: \"https://api.stability.ai\",\r\n};\r\n\r\nexport const Anthropic = {\r\n  ChatPath: \"v1/messages\",\r\n  ChatPath1: \"v1/complete\",\r\n  ExampleEndpoint: \"https://api.anthropic.com\",\r\n  Vision: \"2023-06-01\",\r\n};\r\n\r\nexport const OpenaiPath = {\r\n  ChatPath: \"v1/chat/completions\",\r\n  SpeechPath: \"v1/audio/speech\",\r\n  ImagePath: \"v1/images/generations\",\r\n  UsagePath: \"dashboard/billing/usage\",\r\n  SubsPath: \"dashboard/billing/subscription\",\r\n  ListModelPath: \"v1/models\",\r\n};\r\n\r\nexport const Azure = {\r\n  ChatPath: (deployName: string, apiVersion: string) =>\r\n    `deployments/${deployName}/chat/completions?api-version=${apiVersion}`,\r\n  // https://<your_resource_name>.openai.azure.com/openai/deployments/<your_deployment_name>/images/generations?api-version=<api_version>\r\n  ImagePath: (deployName: string, apiVersion: string) =>\r\n    `deployments/${deployName}/images/generations?api-version=${apiVersion}`,\r\n  ExampleEndpoint: \"https://{resource-url}/openai\",\r\n};\r\n\r\nexport const Google = {\r\n  ExampleEndpoint: \"https://generativelanguage.googleapis.com/\",\r\n  ChatPath: (modelName: string) =>\r\n    `v1beta/models/${modelName}:streamGenerateContent`,\r\n};\r\n\r\nexport const Baidu = {\r\n  ExampleEndpoint: BAIDU_BASE_URL,\r\n  ChatPath: (modelName: string) => {\r\n    let endpoint = modelName;\r\n    if (modelName === \"ernie-4.0-8k\") {\r\n      endpoint = \"completions_pro\";\r\n    }\r\n    if (modelName === \"ernie-4.0-8k-preview-0518\") {\r\n      endpoint = \"completions_adv_pro\";\r\n    }\r\n    if (modelName === \"ernie-3.5-8k\") {\r\n      endpoint = \"completions\";\r\n    }\r\n    if (modelName === \"ernie-speed-8k\") {\r\n      endpoint = \"ernie_speed\";\r\n    }\r\n    return `rpc/2.0/ai_custom/v1/wenxinworkshop/chat/${endpoint}`;\r\n  },\r\n};\r\n\r\nexport const ByteDance = {\r\n  ExampleEndpoint: \"https://ark.cn-beijing.volces.com/api/\",\r\n  ChatPath: \"api/v3/chat/completions\",\r\n};\r\n\r\nexport const Alibaba = {\r\n  ExampleEndpoint: ALIBABA_BASE_URL,\r\n  ChatPath: \"v1/services/aigc/text-generation/generation\",\r\n};\r\n\r\nexport const Tencent = {\r\n  ExampleEndpoint: TENCENT_BASE_URL,\r\n};\r\n\r\nexport const Moonshot = {\r\n  ExampleEndpoint: MOONSHOT_BASE_URL,\r\n  ChatPath: \"v1/chat/completions\",\r\n};\r\n\r\nexport const Iflytek = {\r\n  ExampleEndpoint: IFLYTEK_BASE_URL,\r\n  ChatPath: \"v1/chat/completions\",\r\n};\r\n\r\nexport const DeepSeek = {\r\n  ExampleEndpoint: DEEPSEEK_BASE_URL,\r\n  ChatPath: \"chat/completions\",\r\n};\r\n\r\nexport const XAI = {\r\n  ExampleEndpoint: XAI_BASE_URL,\r\n  ChatPath: \"v1/chat/completions\",\r\n};\r\n\r\nexport const ChatGLM = {\r\n  ExampleEndpoint: CHATGLM_BASE_URL,\r\n  ChatPath: \"api/paas/v4/chat/completions\",\r\n  ImagePath: \"api/paas/v4/images/generations\",\r\n  VideoPath: \"api/paas/v4/videos/generations\",\r\n};\r\n\r\nexport const SiliconFlow = {\r\n  ExampleEndpoint: SILICONFLOW_BASE_URL,\r\n  ChatPath: \"v1/chat/completions\",\r\n};\r\n\r\nexport const DEFAULT_INPUT_TEMPLATE = `{{input}}`; // input / time / model / lang\r\n// export const DEFAULT_SYSTEM_TEMPLATE = `\r\n// You are ChatGPT, a large language model trained by {{ServiceProvider}}.\r\n// Knowledge cutoff: {{cutoff}}\r\n// Current model: {{model}}\r\n// Current time: {{time}}\r\n// Latex inline: $x^2$\r\n// Latex block: $$e=mc^2$$\r\n// `;\r\nexport const DEFAULT_SYSTEM_TEMPLATE = `\r\nYou are ChatGPT, a large language model trained by {{ServiceProvider}}.\r\nKnowledge cutoff: {{cutoff}}\r\nCurrent model: {{model}}\r\nCurrent time: {{time}}\r\nLatex inline: \\\\(x^2\\\\) \r\nLatex block: $$e=mc^2$$\r\n`;\r\n\r\nexport const MCP_TOOLS_TEMPLATE = `\r\n[clientId]\r\n{{ clientId }}\r\n[tools]\r\n{{ tools }}\r\n`;\r\n\r\nexport const MCP_SYSTEM_TEMPLATE = `\r\nYou are an AI assistant with access to system tools. Your role is to help users by combining natural language understanding with tool operations when needed.\r\n\r\n1. AVAILABLE TOOLS:\r\n{{ MCP_TOOLS }}\r\n\r\n2. WHEN TO USE TOOLS:\r\n   - ALWAYS USE TOOLS when they can help answer user questions\r\n   - DO NOT just describe what you could do - TAKE ACTION immediately\r\n   - If you're not sure whether to use a tool, USE IT\r\n   - Common triggers for tool use:\r\n     * Questions about files or directories\r\n     * Requests to check, list, or manipulate system resources\r\n     * Any query that can be answered with available tools\r\n\r\n3. HOW TO USE TOOLS:\r\n   A. Tool Call Format:\r\n      - Use markdown code blocks with format: \\`\\`\\`json:mcp:{clientId}\\`\\`\\`\r\n      - Always include:\r\n        * method: \"tools/call\"（Only this method is supported）\r\n        * params: \r\n          - name: must match an available primitive name\r\n          - arguments: required parameters for the primitive\r\n\r\n   B. Response Format:\r\n      - Tool responses will come as user messages\r\n      - Format: \\`\\`\\`json:mcp-response:{clientId}\\`\\`\\`\r\n      - Wait for response before making another tool call\r\n\r\n   C. Important Rules:\r\n      - Only use tools/call method\r\n      - Only ONE tool call per message\r\n      - ALWAYS TAKE ACTION instead of just describing what you could do\r\n      - Include the correct clientId in code block language tag\r\n      - Verify arguments match the primitive's requirements\r\n\r\n4. INTERACTION FLOW:\r\n   A. When user makes a request:\r\n      - IMMEDIATELY use appropriate tool if available\r\n      - DO NOT ask if user wants you to use the tool\r\n      - DO NOT just describe what you could do\r\n   B. After receiving tool response:\r\n      - Explain results clearly\r\n      - Take next appropriate action if needed\r\n   C. If tools fail:\r\n      - Explain the error\r\n      - Try alternative approach immediately\r\n\r\n5. EXAMPLE INTERACTION:\r\n\r\n  good example:\r\n\r\n   \\`\\`\\`json:mcp:filesystem\r\n   {\r\n     \"method\": \"tools/call\",\r\n     \"params\": {\r\n       \"name\": \"list_allowed_directories\",\r\n       \"arguments\": {}\r\n     }\r\n   }\r\n   \\`\\`\\`\"\r\n\r\n\r\n  \\`\\`\\`json:mcp-response:filesystem\r\n  {\r\n  \"method\": \"tools/call\",\r\n  \"params\": {\r\n    \"name\": \"write_file\",\r\n    \"arguments\": {\r\n      \"path\": \"/Users/river/dev/nextchat/test/joke.txt\",\r\n      \"content\": \"为什么数学书总是感到忧伤？因为它有太多的问题。\"\r\n    }\r\n  }\r\n  }\r\n\\`\\`\\`\r\n\r\n   follwing is the wrong! mcp json example:\r\n\r\n   \\`\\`\\`json:mcp:filesystem\r\n   {\r\n      \"method\": \"write_file\",\r\n      \"params\": {\r\n        \"path\": \"NextChat_Information.txt\",\r\n        \"content\": \"1\"\r\n    }\r\n   }\r\n   \\`\\`\\`\r\n\r\n   This is wrong because the method is not tools/call.\r\n   \r\n   \\`\\`\\`{\r\n  \"method\": \"search_repositories\",\r\n  \"params\": {\r\n    \"query\": \"2oeee\"\r\n  }\r\n}\r\n   \\`\\`\\`\r\n\r\n   This is wrong because the method is not tools/call.!!!!!!!!!!!\r\n\r\n   the right format is:\r\n   \\`\\`\\`json:mcp:filesystem\r\n   {\r\n     \"method\": \"tools/call\",\r\n     \"params\": {\r\n       \"name\": \"search_repositories\",\r\n       \"arguments\": {\r\n         \"query\": \"2oeee\"\r\n       }\r\n     }\r\n   }\r\n   \\`\\`\\`\r\n   \r\n   please follow the format strictly ONLY use tools/call method!!!!!!!!!!!\r\n   \r\n`;\r\n\r\nexport const SUMMARIZE_MODEL = \"gpt-4o-mini\";\r\nexport const GEMINI_SUMMARIZE_MODEL = \"gemini-pro\";\r\nexport const DEEPSEEK_SUMMARIZE_MODEL = \"deepseek-ai/DeepSeek-V3\";\r\n\r\nexport const KnowledgeCutOffDate: Record<string, string> = {\r\n  default: \"2021-09\",\r\n  \"gpt-4-turbo\": \"2023-12\",\r\n  \"gpt-4-turbo-2024-04-09\": \"2023-12\",\r\n  \"gpt-4-turbo-preview\": \"2023-12\",\r\n  \"gpt-4o\": \"2023-10\",\r\n  \"gpt-4o-2024-05-13\": \"2023-10\",\r\n  \"gpt-4o-2024-08-06\": \"2023-10\",\r\n  \"gpt-4o-2024-11-20\": \"2023-10\",\r\n  \"chatgpt-4o-latest\": \"2023-10\",\r\n  \"gpt-4o-mini\": \"2023-10\",\r\n  \"gpt-4o-mini-2024-07-18\": \"2023-10\",\r\n  \"gpt-4-vision-preview\": \"2023-04\",\r\n  \"o1-mini-2024-09-12\": \"2023-10\",\r\n  \"o1-mini\": \"2023-10\",\r\n  \"o1-preview-2024-09-12\": \"2023-10\",\r\n  \"o1-preview\": \"2023-10\",\r\n  \"o1-2024-12-17\": \"2023-10\",\r\n  o1: \"2023-10\",\r\n  \"o3-mini-2025-01-31\": \"2023-10\",\r\n  \"o3-mini\": \"2023-10\",\r\n  // After improvements,\r\n  // it's now easier to add \"KnowledgeCutOffDate\" instead of stupid hardcoding it, as was done previously.\r\n  \"gemini-pro\": \"2023-12\",\r\n  \"gemini-pro-vision\": \"2023-12\",\r\n  \"deepseek-chat\": \"2024-07\",\r\n  \"deepseek-coder\": \"2024-07\",\r\n};\r\n\r\nexport const DEFAULT_TTS_ENGINE = \"OpenAI-TTS\";\r\nexport const DEFAULT_TTS_ENGINES = [\"OpenAI-TTS\", \"Edge-TTS\"];\r\nexport const DEFAULT_TTS_MODEL = \"tts-1\";\r\nexport const DEFAULT_TTS_VOICE = \"alloy\";\r\nexport const DEFAULT_TTS_MODELS = [\"tts-1\", \"tts-1-hd\"];\r\nexport const DEFAULT_TTS_VOICES = [\r\n  \"alloy\",\r\n  \"echo\",\r\n  \"fable\",\r\n  \"onyx\",\r\n  \"nova\",\r\n  \"shimmer\",\r\n];\r\n\r\nexport const VISION_MODEL_REGEXES = [\r\n  /vision/,\r\n  /gpt-4o/,\r\n  /claude-3/,\r\n  /gemini-1\\.5/,\r\n  /gemini-exp/,\r\n  /gemini-2\\.0/,\r\n  /learnlm/,\r\n  /qwen-vl/,\r\n  /qwen2-vl/,\r\n  /gpt-4-turbo(?!.*preview)/, // Matches \"gpt-4-turbo\" but not \"gpt-4-turbo-preview\"\r\n  /^dall-e-3$/, // Matches exactly \"dall-e-3\"\r\n  /glm-4v/,\r\n];\r\n\r\nexport const EXCLUDE_VISION_MODEL_REGEXES = [/claude-3-5-haiku-20241022/];\r\n\r\nconst openaiModels = [\r\n];\r\n\r\nconst googleModels = [\r\n];\r\n\r\nconst anthropicModels = [\r\n];\r\n\r\nconst baiduModels = [\r\n];\r\n\r\nconst bytedanceModels = [\r\n];\r\n\r\nconst alibabaModes = [\r\n];\r\n\r\nconst tencentModels = [\r\n];\r\n\r\nconst moonshotModes = [];\r\n\r\nconst iflytekModels = [\r\n];\r\n\r\nconst deepseekModels = [];\r\n\r\nconst xAIModes = [\r\n];\r\n\r\nconst chatglmModels = [\r\n];\r\n\r\nconst siliconflowModels = [\r\n  \"deepseek-ai/DeepSeek-V3\",\r\n  \"deepseek-ai/DeepSeek-R1\",\r\n];\r\n\r\nlet seq = 1000; // 内置的模型序号生成器从1000开始\r\nexport const DEFAULT_MODELS = [\r\n  ...openaiModels.map((name) => ({\r\n    name,\r\n    available: true,\r\n    sorted: seq++, // Global sequence sort(index)\r\n    provider: {\r\n      id: \"openai\",\r\n      providerName: \"OpenAI\",\r\n      providerType: \"openai\",\r\n      sorted: 1, // 这里是固定的，确保顺序与之前内置的版本一致\r\n    },\r\n  })),\r\n  ...openaiModels.map((name) => ({\r\n    name,\r\n    available: true,\r\n    sorted: seq++,\r\n    provider: {\r\n      id: \"azure\",\r\n      providerName: \"Azure\",\r\n      providerType: \"azure\",\r\n      sorted: 2,\r\n    },\r\n  })),\r\n  ...googleModels.map((name) => ({\r\n    name,\r\n    available: true,\r\n    sorted: seq++,\r\n    provider: {\r\n      id: \"google\",\r\n      providerName: \"Google\",\r\n      providerType: \"google\",\r\n      sorted: 3,\r\n    },\r\n  })),\r\n  ...anthropicModels.map((name) => ({\r\n    name,\r\n    available: true,\r\n    sorted: seq++,\r\n    provider: {\r\n      id: \"anthropic\",\r\n      providerName: \"Anthropic\",\r\n      providerType: \"anthropic\",\r\n      sorted: 4,\r\n    },\r\n  })),\r\n  ...baiduModels.map((name) => ({\r\n    name,\r\n    available: true,\r\n    sorted: seq++,\r\n    provider: {\r\n      id: \"baidu\",\r\n      providerName: \"Baidu\",\r\n      providerType: \"baidu\",\r\n      sorted: 5,\r\n    },\r\n  })),\r\n  ...bytedanceModels.map((name) => ({\r\n    name,\r\n    available: true,\r\n    sorted: seq++,\r\n    provider: {\r\n      id: \"bytedance\",\r\n      providerName: \"ByteDance\",\r\n      providerType: \"bytedance\",\r\n      sorted: 6,\r\n    },\r\n  })),\r\n  ...alibabaModes.map((name) => ({\r\n    name,\r\n    available: true,\r\n    sorted: seq++,\r\n    provider: {\r\n      id: \"alibaba\",\r\n      providerName: \"Alibaba\",\r\n      providerType: \"alibaba\",\r\n      sorted: 7,\r\n    },\r\n  })),\r\n  ...tencentModels.map((name) => ({\r\n    name,\r\n    available: true,\r\n    sorted: seq++,\r\n    provider: {\r\n      id: \"tencent\",\r\n      providerName: \"Tencent\",\r\n      providerType: \"tencent\",\r\n      sorted: 8,\r\n    },\r\n  })),\r\n  ...moonshotModes.map((name) => ({\r\n    name,\r\n    available: true,\r\n    sorted: seq++,\r\n    provider: {\r\n      id: \"moonshot\",\r\n      providerName: \"Moonshot\",\r\n      providerType: \"moonshot\",\r\n      sorted: 9,\r\n    },\r\n  })),\r\n  ...iflytekModels.map((name) => ({\r\n    name,\r\n    available: true,\r\n    sorted: seq++,\r\n    provider: {\r\n      id: \"iflytek\",\r\n      providerName: \"Iflytek\",\r\n      providerType: \"iflytek\",\r\n      sorted: 10,\r\n    },\r\n  })),\r\n  ...xAIModes.map((name) => ({\r\n    name,\r\n    available: true,\r\n    sorted: seq++,\r\n    provider: {\r\n      id: \"xai\",\r\n      providerName: \"XAI\",\r\n      providerType: \"xai\",\r\n      sorted: 11,\r\n    },\r\n  })),\r\n  ...chatglmModels.map((name) => ({\r\n    name,\r\n    available: true,\r\n    sorted: seq++,\r\n    provider: {\r\n      id: \"chatglm\",\r\n      providerName: \"ChatGLM\",\r\n      providerType: \"chatglm\",\r\n      sorted: 12,\r\n    },\r\n  })),\r\n  ...deepseekModels.map((name) => ({\r\n    name,\r\n    available: true,\r\n    sorted: seq++,\r\n    provider: {\r\n      id: \"deepseek\",\r\n      providerName: \"DeepSeek\",\r\n      providerType: \"deepseek\",\r\n      sorted: 13,\r\n    },\r\n  })),\r\n  ...siliconflowModels.map((name) => ({\r\n    name,\r\n    available: true,\r\n    sorted: seq++,\r\n    provider: {\r\n      id: \"siliconflow\",\r\n      providerName: \"SiliconFlow\",\r\n      providerType: \"siliconflow\",\r\n      sorted: 14,\r\n    },\r\n  })),\r\n] as const;\r\n\r\nexport const CHAT_PAGE_SIZE = 15;\r\nexport const MAX_RENDER_MSG_COUNT = 45;\r\n\r\n// some famous webdav endpoints\r\nexport const internalAllowedWebDavEndpoints = [\r\n  \"https://dav.jianguoyun.com/dav/\",\r\n  \"https://dav.dropdav.com/\",\r\n  \"https://dav.box.com/dav\",\r\n  \"https://nanao.teracloud.jp/dav/\",\r\n  \"https://bora.teracloud.jp/dav/\",\r\n  \"https://webdav.4shared.com/\",\r\n  \"https://dav.idrivesync.com\",\r\n  \"https://webdav.yandex.com\",\r\n  \"https://app.koofr.net/dav/Koofr\",\r\n];\r\n\r\nexport const DEFAULT_GA_ID = \"G-89WN60ZK2E\";\r\n\r\nexport const SAAS_CHAT_URL = \"https://nextchat.dev/chat\";\r\nexport const SAAS_CHAT_UTM_URL = \"https://nextchat.dev/chat?utm=github\";\r\n"],"names":["OWNER","REPO","REPO_URL","PLUGINS_REPO_URL","ISSUE_URL","UPDATE_URL","RELEASE_URL","FETCH_COMMIT_URL","FETCH_TAG_URL","RUNTIME_CONFIG_DOM","STABILITY_BASE_URL","OPENAI_BASE_URL","ANTHROPIC_BASE_URL","GEMINI_BASE_URL","BAIDU_BASE_URL","BAIDU_OATUH_URL","BYTEDANCE_BASE_URL","ALIBABA_BASE_URL","TENCENT_BASE_URL","MOONSHOT_BASE_URL","IFLYTEK_BASE_URL","DEEPSEEK_BASE_URL","XAI_BASE_URL","CHATGLM_BASE_URL","SILICONFLOW_BASE_URL","CACHE_URL_PREFIX","UPLOAD_URL","Path","ApiPath","SlotID","FileName","StoreKey","DEFAULT_SIDEBAR_WIDTH","MAX_SIDEBAR_WIDTH","MIN_SIDEBAR_WIDTH","NARROW_SIDEBAR_WIDTH","ACCESS_CODE_PREFIX","LAST_INPUT_KEY","UNFINISHED_INPUT","id","STORAGE_KEY","REQUEST_TIMEOUT_MS","REQUEST_TIMEOUT_MS_FOR_THINKING","EXPORT_MESSAGE_CLASS_NAME","ServiceProvider","GoogleSafetySettingsThreshold","ModelProvider","Stability","GeneratePath","ExampleEndpoint","Anthropic","ChatPath","ChatPath1","Vision","OpenaiPath","SpeechPath","ImagePath","UsagePath","SubsPath","ListModelPath","Azure","deployName","apiVersion","Google","modelName","Baidu","endpoint","ByteDance","Alibaba","Tencent","Moonshot","Iflytek","DeepSeek","XAI","ChatGLM","VideoPath","SiliconFlow","DEFAULT_INPUT_TEMPLATE","DEFAULT_SYSTEM_TEMPLATE","MCP_TOOLS_TEMPLATE","MCP_SYSTEM_TEMPLATE","SUMMARIZE_MODEL","GEMINI_SUMMARIZE_MODEL","DEEPSEEK_SUMMARIZE_MODEL","KnowledgeCutOffDate","default","o1","DEFAULT_TTS_ENGINE","DEFAULT_TTS_ENGINES","DEFAULT_TTS_MODEL","DEFAULT_TTS_VOICE","DEFAULT_TTS_MODELS","DEFAULT_TTS_VOICES","VISION_MODEL_REGEXES","EXCLUDE_VISION_MODEL_REGEXES","openaiModels","googleModels","anthropicModels","baiduModels","bytedanceModels","alibabaModes","tencentModels","moonshotModes","iflytekModels","deepseekModels","xAIModes","chatglmModels","siliconflowModels","seq","DEFAULT_MODELS","map","name","available","sorted","provider","providerName","providerType","CHAT_PAGE_SIZE","MAX_RENDER_MSG_COUNT","internalAllowedWebDavEndpoints","DEFAULT_GA_ID","SAAS_CHAT_URL","SAAS_CHAT_UTM_URL"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///(app-pages-browser)/./app/constant.ts\n")); /***/ }) });