You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
NextWeb/.next/static/webpack/app/page.e2528c1f3f5999ac.hot-u...

22 lines
70 KiB
JavaScript

This file contains ambiguous Unicode characters!

This file contains ambiguous Unicode characters that may be confused with others in your current locale. If your use case is intentional and legitimate, you can safely ignore this warning. Use the Escape button to highlight these characters.

"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://<your_resource_name>.openai.azure.com/openai/deployments/<your_deployment_name>/images/generations?api-version=<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-R1-Distill-Llama-8B\";\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-R1\",\n \"deepseek-ai/DeepSeek-V3\",\n \"deepseek-ai/DeepSeek-R1-Distill-Llama-8B\"\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-R1-Distill-Llama-8B\";\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-R1\",\r\n  \"deepseek-ai/DeepSeek-V3\",\r\n  \"deepseek-ai/DeepSeek-R1-Distill-Llama-8B\",\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"));
/***/ })
});