"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/store/config.ts": /*!*****************************!*\ !*** ./app/store/config.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 */ DEFAULT_CONFIG: function() { return /* binding */ DEFAULT_CONFIG; },\n/* harmony export */ ModalConfigValidator: function() { return /* binding */ ModalConfigValidator; },\n/* harmony export */ SubmitKey: function() { return /* binding */ SubmitKey; },\n/* harmony export */ TTSConfigValidator: function() { return /* binding */ TTSConfigValidator; },\n/* harmony export */ Theme: function() { return /* binding */ Theme; },\n/* harmony export */ limitNumber: function() { return /* binding */ limitNumber; },\n/* harmony export */ useAppConfig: function() { return /* binding */ useAppConfig; }\n/* harmony export */ });\n/* harmony import */ var _config_client__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../config/client */ \"(app-pages-browser)/./app/config/client.ts\");\n/* harmony import */ var _constant__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../constant */ \"(app-pages-browser)/./app/constant.ts\");\n/* harmony import */ var _utils_store__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../utils/store */ \"(app-pages-browser)/./app/utils/store.ts\");\n\n\n\nvar SubmitKey;\n(function(SubmitKey) {\n SubmitKey[\"Enter\"] = \"Enter\";\n SubmitKey[\"CtrlEnter\"] = \"Ctrl + Enter\";\n SubmitKey[\"ShiftEnter\"] = \"Shift + Enter\";\n SubmitKey[\"AltEnter\"] = \"Alt + Enter\";\n SubmitKey[\"MetaEnter\"] = \"Meta + Enter\";\n})(SubmitKey || (SubmitKey = {}));\nvar Theme;\n(function(Theme) {\n Theme[\"Auto\"] = \"auto\";\n Theme[\"Dark\"] = \"dark\";\n Theme[\"Light\"] = \"light\";\n})(Theme || (Theme = {}));\nconst config = (0,_config_client__WEBPACK_IMPORTED_MODULE_0__.getClientConfig)();\nvar _config_template;\nconst DEFAULT_CONFIG = {\n lastUpdate: Date.now(),\n submitKey: \"Enter\",\n avatar: \"1f603\",\n fontSize: 14,\n fontFamily: \"\",\n theme: \"auto\",\n tightBorder: !!(config === null || config === void 0 ? void 0 : config.isApp),\n sendPreviewBubble: true,\n enableAutoGenerateTitle: true,\n sidebarWidth: _constant__WEBPACK_IMPORTED_MODULE_1__.DEFAULT_SIDEBAR_WIDTH,\n enableArtifacts: true,\n enableCodeFold: true,\n disablePromptHint: true,\n dontShowMaskSplashScreen: true,\n hideBuiltinMasks: false,\n customModels: \"\",\n models: _constant__WEBPACK_IMPORTED_MODULE_1__.DEFAULT_MODELS,\n modelConfig: {\n model: \"deepseek-ai/DeepSeek-V3\",\n providerName: \"SiliconFlow\",\n temperature: 0.5,\n top_p: 1,\n max_tokens: 4000,\n presence_penalty: 0,\n frequency_penalty: 0,\n sendMemory: true,\n historyMessageCount: 4,\n compressMessageLengthThreshold: 1000,\n compressModel: \"deepseek-ai/DeepSeek-V3\",\n compressProviderName: \"SiliconFlow\",\n enableInjectSystemPrompts: false,\n template: (_config_template = config === null || config === void 0 ? void 0 : config.template) !== null && _config_template !== void 0 ? _config_template : _constant__WEBPACK_IMPORTED_MODULE_1__.DEFAULT_INPUT_TEMPLATE,\n size: \"1024x1024\",\n quality: \"standard\",\n style: \"vivid\"\n },\n ttsConfig: {\n enable: false,\n autoplay: false,\n engine: _constant__WEBPACK_IMPORTED_MODULE_1__.DEFAULT_TTS_ENGINE,\n model: _constant__WEBPACK_IMPORTED_MODULE_1__.DEFAULT_TTS_MODEL,\n voice: _constant__WEBPACK_IMPORTED_MODULE_1__.DEFAULT_TTS_VOICE,\n speed: 1.0\n },\n realtimeConfig: {\n enable: false,\n provider: \"SiliconFlow\",\n model: \"gpt-4o-realtime-preview-2024-10-01\",\n apiKey: \"\",\n azure: {\n endpoint: \"\",\n deployment: \"\"\n },\n temperature: 0.9,\n voice: \"alloy\"\n }\n};\nfunction limitNumber(x, min, max, defaultValue) {\n if (isNaN(x)) {\n return defaultValue;\n }\n return Math.min(max, Math.max(min, x));\n}\nconst TTSConfigValidator = {\n engine (x) {\n return x;\n },\n model (x) {\n return x;\n },\n voice (x) {\n return x;\n },\n speed (x) {\n return limitNumber(x, 0.25, 4.0, 1.0);\n }\n};\nconst ModalConfigValidator = {\n model (x) {\n return x;\n },\n max_tokens (x) {\n return limitNumber(x, 0, 512000, 1024);\n },\n presence_penalty (x) {\n return limitNumber(x, -2, 2, 0);\n },\n frequency_penalty (x) {\n return limitNumber(x, -2, 2, 0);\n },\n temperature (x) {\n return limitNumber(x, 0, 2, 1);\n },\n top_p (x) {\n return limitNumber(x, 0, 1, 1);\n }\n};\nconst useAppConfig = (0,_utils_store__WEBPACK_IMPORTED_MODULE_2__.createPersistStore)({\n ...DEFAULT_CONFIG\n}, (set, get)=>({\n reset () {\n set(()=>({\n ...DEFAULT_CONFIG\n }));\n },\n mergeModels (newModels) {\n if (!newModels || newModels.length === 0) {\n return;\n }\n const oldModels = get().models;\n const modelMap = {};\n for (const model of oldModels){\n var _model_provider;\n model.available = false;\n modelMap[\"\".concat(model.name, \"@\").concat(model === null || model === void 0 ? void 0 : (_model_provider = model.provider) === null || _model_provider === void 0 ? void 0 : _model_provider.id)] = model;\n }\n for (const model of newModels){\n var _model_provider1;\n model.available = true;\n modelMap[\"\".concat(model.name, \"@\").concat(model === null || model === void 0 ? void 0 : (_model_provider1 = model.provider) === null || _model_provider1 === void 0 ? void 0 : _model_provider1.id)] = model;\n }\n set(()=>({\n models: Object.values(modelMap)\n }));\n },\n allModels () {}\n }), {\n name: _constant__WEBPACK_IMPORTED_MODULE_1__.StoreKey.Config,\n version: 4.1,\n merge (persistedState, currentState) {\n const state = persistedState;\n if (!state) return {\n ...currentState\n };\n const models = currentState.models.slice();\n state.models.forEach((pModel)=>{\n const idx = models.findIndex((v)=>v.name === pModel.name && v.provider === pModel.provider);\n if (idx !== -1) models[idx] = pModel;\n else models.push(pModel);\n });\n return {\n ...currentState,\n ...state,\n models: models\n };\n },\n migrate (persistedState, version) {\n const state = persistedState;\n if (version < 3.4) {\n state.modelConfig.sendMemory = true;\n state.modelConfig.historyMessageCount = 4;\n state.modelConfig.compressMessageLengthThreshold = 1000;\n state.modelConfig.frequency_penalty = 0;\n state.modelConfig.top_p = 1;\n state.modelConfig.template = _constant__WEBPACK_IMPORTED_MODULE_1__.DEFAULT_INPUT_TEMPLATE;\n state.dontShowMaskSplashScreen = true;\n state.hideBuiltinMasks = false;\n }\n if (version < 3.5) {\n state.customModels = \"claude,claude-100k\";\n }\n if (version < 3.6) {\n state.modelConfig.enableInjectSystemPrompts = true;\n }\n if (version < 3.7) {\n state.enableAutoGenerateTitle = true;\n }\n if (version < 3.8) {\n state.lastUpdate = Date.now();\n }\n if (version < 3.9) {\n var _config_template;\n state.modelConfig.template = state.modelConfig.template !== _constant__WEBPACK_IMPORTED_MODULE_1__.DEFAULT_INPUT_TEMPLATE ? state.modelConfig.template : (_config_template = config === null || config === void 0 ? void 0 : config.template) !== null && _config_template !== void 0 ? _config_template : _constant__WEBPACK_IMPORTED_MODULE_1__.DEFAULT_INPUT_TEMPLATE;\n }\n if (version < 4.1) {\n state.modelConfig.compressModel = DEFAULT_CONFIG.modelConfig.compressModel;\n state.modelConfig.compressProviderName = DEFAULT_CONFIG.modelConfig.compressProviderName;\n }\n return state;\n }\n});\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/store/config.ts","mappings":"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","sources":["webpack://_N_E/./app/store/config.ts?9f33"],"sourcesContent":["import { LLMModel } from \"../client/api\";\r\nimport { DalleQuality, DalleStyle, ModelSize } from \"../typing\";\r\nimport { getClientConfig } from \"../config/client\";\r\nimport {\r\n  DEFAULT_INPUT_TEMPLATE,\r\n  DEFAULT_MODELS,\r\n  DEFAULT_SIDEBAR_WIDTH,\r\n  DEFAULT_TTS_ENGINE,\r\n  DEFAULT_TTS_ENGINES,\r\n  DEFAULT_TTS_MODEL,\r\n  DEFAULT_TTS_MODELS,\r\n  DEFAULT_TTS_VOICE,\r\n  DEFAULT_TTS_VOICES,\r\n  StoreKey,\r\n  ServiceProvider,\r\n} from \"../constant\";\r\nimport { createPersistStore } from \"../utils/store\";\r\nimport type { Voice } from \"rt-client\";\r\n\r\nexport type ModelType = (typeof DEFAULT_MODELS)[number][\"name\"];\r\nexport type TTSModelType = (typeof DEFAULT_TTS_MODELS)[number];\r\nexport type TTSVoiceType = (typeof DEFAULT_TTS_VOICES)[number];\r\nexport type TTSEngineType = (typeof DEFAULT_TTS_ENGINES)[number];\r\n\r\nexport enum SubmitKey {\r\n  Enter = \"Enter\",\r\n  CtrlEnter = \"Ctrl + Enter\",\r\n  ShiftEnter = \"Shift + Enter\",\r\n  AltEnter = \"Alt + Enter\",\r\n  MetaEnter = \"Meta + Enter\",\r\n}\r\n\r\nexport enum Theme {\r\n  Auto = \"auto\",\r\n  Dark = \"dark\",\r\n  Light = \"light\",\r\n}\r\n\r\nconst config = getClientConfig();\r\n\r\nexport const DEFAULT_CONFIG = {\r\n  lastUpdate: Date.now(), // timestamp, to merge state\r\n\r\n  submitKey: SubmitKey.Enter,\r\n  avatar: \"1f603\",\r\n  fontSize: 14,\r\n  fontFamily: \"\",\r\n  theme: Theme.Auto as Theme,\r\n  tightBorder: !!config?.isApp,\r\n  sendPreviewBubble: true,\r\n  enableAutoGenerateTitle: true,\r\n  sidebarWidth: DEFAULT_SIDEBAR_WIDTH,\r\n\r\n  enableArtifacts: true, // show artifacts config\r\n\r\n  enableCodeFold: true, // code fold config\r\n\r\n  disablePromptHint: true,\r\n\r\n  dontShowMaskSplashScreen: true, // dont show splash screen when create chat\r\n  hideBuiltinMasks: false, // dont add builtin masks\r\n\r\n  customModels: \"\",\r\n  models: DEFAULT_MODELS as any as LLMModel[],\r\n\r\n  modelConfig: {\r\n    model: \"deepseek-ai/DeepSeek-V3\" as ModelType,\r\n    providerName: \"SiliconFlow\" as ServiceProvider,\r\n    temperature: 0.5,\r\n    top_p: 1,\r\n    max_tokens: 4000,\r\n    presence_penalty: 0,\r\n    frequency_penalty: 0,\r\n    sendMemory: true,\r\n    historyMessageCount: 4,\r\n    compressMessageLengthThreshold: 1000,\r\n    compressModel: \"deepseek-ai/DeepSeek-V3\",\r\n    compressProviderName: \"SiliconFlow\" as ServiceProvider,\r\n    enableInjectSystemPrompts: false,\r\n    template: config?.template ?? DEFAULT_INPUT_TEMPLATE,\r\n    size: \"1024x1024\" as ModelSize,\r\n    quality: \"standard\" as DalleQuality,\r\n    style: \"vivid\" as DalleStyle,\r\n  },\r\n\r\n  ttsConfig: {\r\n    enable: false,\r\n    autoplay: false,\r\n    engine: DEFAULT_TTS_ENGINE,\r\n    model: DEFAULT_TTS_MODEL,\r\n    voice: DEFAULT_TTS_VOICE,\r\n    speed: 1.0,\r\n  },\r\n\r\n  realtimeConfig: {\r\n    enable: false,\r\n    provider: \"SiliconFlow\" as ServiceProvider,\r\n    model: \"gpt-4o-realtime-preview-2024-10-01\",\r\n    apiKey: \"\",\r\n    azure: {\r\n      endpoint: \"\",\r\n      deployment: \"\",\r\n    },\r\n    temperature: 0.9,\r\n    voice: \"alloy\" as Voice,\r\n  },\r\n};\r\n\r\nexport type ChatConfig = typeof DEFAULT_CONFIG;\r\n\r\nexport type ModelConfig = ChatConfig[\"modelConfig\"];\r\nexport type TTSConfig = ChatConfig[\"ttsConfig\"];\r\nexport type RealtimeConfig = ChatConfig[\"realtimeConfig\"];\r\n\r\nexport function limitNumber(\r\n  x: number,\r\n  min: number,\r\n  max: number,\r\n  defaultValue: number,\r\n) {\r\n  if (isNaN(x)) {\r\n    return defaultValue;\r\n  }\r\n\r\n  return Math.min(max, Math.max(min, x));\r\n}\r\n\r\nexport const TTSConfigValidator = {\r\n  engine(x: string) {\r\n    return x as TTSEngineType;\r\n  },\r\n  model(x: string) {\r\n    return x as TTSModelType;\r\n  },\r\n  voice(x: string) {\r\n    return x as TTSVoiceType;\r\n  },\r\n  speed(x: number) {\r\n    return limitNumber(x, 0.25, 4.0, 1.0);\r\n  },\r\n};\r\n\r\nexport const ModalConfigValidator = {\r\n  model(x: string) {\r\n    return x as ModelType;\r\n  },\r\n  max_tokens(x: number) {\r\n    return limitNumber(x, 0, 512000, 1024);\r\n  },\r\n  presence_penalty(x: number) {\r\n    return limitNumber(x, -2, 2, 0);\r\n  },\r\n  frequency_penalty(x: number) {\r\n    return limitNumber(x, -2, 2, 0);\r\n  },\r\n  temperature(x: number) {\r\n    return limitNumber(x, 0, 2, 1);\r\n  },\r\n  top_p(x: number) {\r\n    return limitNumber(x, 0, 1, 1);\r\n  },\r\n};\r\n\r\nexport const useAppConfig = createPersistStore(\r\n  { ...DEFAULT_CONFIG },\r\n  (set, get) => ({\r\n    reset() {\r\n      set(() => ({ ...DEFAULT_CONFIG }));\r\n    },\r\n\r\n    mergeModels(newModels: LLMModel[]) {\r\n      if (!newModels || newModels.length === 0) {\r\n        return;\r\n      }\r\n\r\n      const oldModels = get().models;\r\n      const modelMap: Record<string, LLMModel> = {};\r\n\r\n      for (const model of oldModels) {\r\n        model.available = false;\r\n        modelMap[`${model.name}@${model?.provider?.id}`] = model;\r\n      }\r\n\r\n      for (const model of newModels) {\r\n        model.available = true;\r\n        modelMap[`${model.name}@${model?.provider?.id}`] = model;\r\n      }\r\n\r\n      set(() => ({\r\n        models: Object.values(modelMap),\r\n      }));\r\n    },\r\n\r\n    allModels() {},\r\n  }),\r\n  {\r\n    name: StoreKey.Config,\r\n    version: 4.1,\r\n\r\n    merge(persistedState, currentState) {\r\n      const state = persistedState as ChatConfig | undefined;\r\n      if (!state) return { ...currentState };\r\n      const models = currentState.models.slice();\r\n      state.models.forEach((pModel) => {\r\n        const idx = models.findIndex(\r\n          (v) => v.name === pModel.name && v.provider === pModel.provider,\r\n        );\r\n        if (idx !== -1) models[idx] = pModel;\r\n        else models.push(pModel);\r\n      });\r\n      return { ...currentState, ...state, models: models };\r\n    },\r\n\r\n    migrate(persistedState, version) {\r\n      const state = persistedState as ChatConfig;\r\n\r\n      if (version < 3.4) {\r\n        state.modelConfig.sendMemory = true;\r\n        state.modelConfig.historyMessageCount = 4;\r\n        state.modelConfig.compressMessageLengthThreshold = 1000;\r\n        state.modelConfig.frequency_penalty = 0;\r\n        state.modelConfig.top_p = 1;\r\n        state.modelConfig.template = DEFAULT_INPUT_TEMPLATE;\r\n        state.dontShowMaskSplashScreen = true;\r\n        state.hideBuiltinMasks = false;\r\n      }\r\n\r\n      if (version < 3.5) {\r\n        state.customModels = \"claude,claude-100k\";\r\n      }\r\n\r\n      if (version < 3.6) {\r\n        state.modelConfig.enableInjectSystemPrompts = true;\r\n      }\r\n\r\n      if (version < 3.7) {\r\n        state.enableAutoGenerateTitle = true;\r\n      }\r\n\r\n      if (version < 3.8) {\r\n        state.lastUpdate = Date.now();\r\n      }\r\n\r\n      if (version < 3.9) {\r\n        state.modelConfig.template =\r\n          state.modelConfig.template !== DEFAULT_INPUT_TEMPLATE\r\n            ? state.modelConfig.template\r\n            : config?.template ?? DEFAULT_INPUT_TEMPLATE;\r\n      }\r\n\r\n      if (version < 4.1) {\r\n        state.modelConfig.compressModel =\r\n          DEFAULT_CONFIG.modelConfig.compressModel;\r\n        state.modelConfig.compressProviderName =\r\n          DEFAULT_CONFIG.modelConfig.compressProviderName;\r\n      }\r\n\r\n      return state as any;\r\n    },\r\n  },\r\n);\r\n"],"names":["getClientConfig","DEFAULT_INPUT_TEMPLATE","DEFAULT_MODELS","DEFAULT_SIDEBAR_WIDTH","DEFAULT_TTS_ENGINE","DEFAULT_TTS_MODEL","DEFAULT_TTS_VOICE","StoreKey","createPersistStore","SubmitKey","Theme","config","DEFAULT_CONFIG","lastUpdate","Date","now","submitKey","avatar","fontSize","fontFamily","theme","tightBorder","isApp","sendPreviewBubble","enableAutoGenerateTitle","sidebarWidth","enableArtifacts","enableCodeFold","disablePromptHint","dontShowMaskSplashScreen","hideBuiltinMasks","customModels","models","modelConfig","model","providerName","temperature","top_p","max_tokens","presence_penalty","frequency_penalty","sendMemory","historyMessageCount","compressMessageLengthThreshold","compressModel","compressProviderName","enableInjectSystemPrompts","template","size","quality","style","ttsConfig","enable","autoplay","engine","voice","speed","realtimeConfig","provider","apiKey","azure","endpoint","deployment","limitNumber","x","min","max","defaultValue","isNaN","Math","TTSConfigValidator","ModalConfigValidator","useAppConfig","set","get","reset","mergeModels","newModels","length","oldModels","modelMap","available","name","id","Object","values","allModels","Config","version","merge","persistedState","currentState","state","slice","forEach","pModel","idx","findIndex","v","push","migrate"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///(app-pages-browser)/./app/store/config.ts\n")); /***/ }) });