constant.ts 6.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250
  1. export const OWNER = "Yidadaa";
  2. export const REPO = "ChatGPT-Next-Web";
  3. export const REPO_URL = `https://github.com/${OWNER}/${REPO}`;
  4. export const ISSUE_URL = `https://github.com/${OWNER}/${REPO}/issues`;
  5. export const UPDATE_URL = `${REPO_URL}#keep-updated`;
  6. export const RELEASE_URL = `${REPO_URL}/releases`;
  7. export const FETCH_COMMIT_URL = `https://api.github.com/repos/${OWNER}/${REPO}/commits?per_page=1`;
  8. export const FETCH_TAG_URL = `https://api.github.com/repos/${OWNER}/${REPO}/tags?per_page=1`;
  9. export const RUNTIME_CONFIG_DOM = "danger-runtime-config";
  10. export const DEFAULT_API_HOST = "https://api.nextchat.dev";
  11. export const OPENAI_BASE_URL = "https://api.openai.com";
  12. export const ANTHROPIC_BASE_URL = "https://api.anthropic.com";
  13. export const GEMINI_BASE_URL = "https://generativelanguage.googleapis.com/";
  14. export const BYTEDANCE_BASE_URL = "https://ark.cn-beijing.volces.com";
  15. export enum Path {
  16. Home = "/",
  17. Chat = "/chat",
  18. Settings = "/settings",
  19. NewChat = "/new-chat",
  20. Masks = "/masks",
  21. Auth = "/auth",
  22. }
  23. export enum ApiPath {
  24. Cors = "",
  25. Azure = "/api/azure",
  26. OpenAI = "/api/openai",
  27. Anthropic = "/api/anthropic",
  28. ByteDance = "/api/bytedance",
  29. }
  30. export enum SlotID {
  31. AppBody = "app-body",
  32. CustomModel = "custom-model",
  33. }
  34. export enum FileName {
  35. Masks = "masks.json",
  36. Prompts = "prompts.json",
  37. }
  38. export enum StoreKey {
  39. Chat = "chat-next-web-store",
  40. Access = "access-control",
  41. Config = "app-config",
  42. Mask = "mask-store",
  43. Prompt = "prompt-store",
  44. Update = "chat-update",
  45. Sync = "sync",
  46. }
  47. export const DEFAULT_SIDEBAR_WIDTH = 300;
  48. export const MAX_SIDEBAR_WIDTH = 500;
  49. export const MIN_SIDEBAR_WIDTH = 230;
  50. export const NARROW_SIDEBAR_WIDTH = 100;
  51. export const ACCESS_CODE_PREFIX = "nk-";
  52. export const LAST_INPUT_KEY = "last-input";
  53. export const UNFINISHED_INPUT = (id: string) => "unfinished-input-" + id;
  54. export const STORAGE_KEY = "chatgpt-next-web";
  55. export const REQUEST_TIMEOUT_MS = 60000;
  56. export const EXPORT_MESSAGE_CLASS_NAME = "export-markdown";
  57. export enum ServiceProvider {
  58. OpenAI = "OpenAI",
  59. Azure = "Azure",
  60. Google = "Google",
  61. Anthropic = "Anthropic",
  62. ByteDance = "ByteDance",
  63. }
  64. export enum ModelProvider {
  65. GPT = "GPT",
  66. GeminiPro = "GeminiPro",
  67. Claude = "Claude",
  68. Doubao = "Doubao",
  69. }
  70. export const Anthropic = {
  71. ChatPath: "v1/messages",
  72. ChatPath1: "v1/complete",
  73. ExampleEndpoint: "https://api.anthropic.com",
  74. Vision: "2023-06-01",
  75. };
  76. export const OpenaiPath = {
  77. ChatPath: "v1/chat/completions",
  78. UsagePath: "dashboard/billing/usage",
  79. SubsPath: "dashboard/billing/subscription",
  80. ListModelPath: "v1/models",
  81. };
  82. export const Azure = {
  83. ChatPath: (deployName: string, apiVersion: string) =>
  84. `deployments/${deployName}/chat/completions?api-version=${apiVersion}`,
  85. ExampleEndpoint: "https://{resource-url}/openai/deployments/{deploy-id}",
  86. };
  87. export const Google = {
  88. ExampleEndpoint: "https://generativelanguage.googleapis.com/",
  89. ChatPath: (modelName: string) => `v1beta/models/${modelName}:generateContent`,
  90. };
  91. export const ByteDance = {
  92. ExampleEndpoint: "https://ark.cn-beijing.volces.com/api/v3/chat/completions",
  93. ChatPath: "/api/v3/chat/completions",
  94. };
  95. export const DEFAULT_INPUT_TEMPLATE = `{{input}}`; // input / time / model / lang
  96. // export const DEFAULT_SYSTEM_TEMPLATE = `
  97. // You are ChatGPT, a large language model trained by {{ServiceProvider}}.
  98. // Knowledge cutoff: {{cutoff}}
  99. // Current model: {{model}}
  100. // Current time: {{time}}
  101. // Latex inline: $x^2$
  102. // Latex block: $$e=mc^2$$
  103. // `;
  104. export const DEFAULT_SYSTEM_TEMPLATE = `
  105. You are ChatGPT, a large language model trained by {{ServiceProvider}}.
  106. Knowledge cutoff: {{cutoff}}
  107. Current model: {{model}}
  108. Current time: {{time}}
  109. Latex inline: \\(x^2\\)
  110. Latex block: $$e=mc^2$$
  111. `;
  112. export const SUMMARIZE_MODEL = "gpt-3.5-turbo";
  113. export const GEMINI_SUMMARIZE_MODEL = "gemini-pro";
  114. export const KnowledgeCutOffDate: Record<string, string> = {
  115. default: "2021-09",
  116. "gpt-4-turbo": "2023-12",
  117. "gpt-4-turbo-2024-04-09": "2023-12",
  118. "gpt-4-turbo-preview": "2023-12",
  119. "gpt-4o": "2023-10",
  120. "gpt-4o-2024-05-13": "2023-10",
  121. "gpt-4-vision-preview": "2023-04",
  122. // After improvements,
  123. // it's now easier to add "KnowledgeCutOffDate" instead of stupid hardcoding it, as was done previously.
  124. "gemini-pro": "2023-12",
  125. "gemini-pro-vision": "2023-12",
  126. };
  127. const openaiModels = [
  128. "gpt-3.5-turbo",
  129. "gpt-3.5-turbo-1106",
  130. "gpt-3.5-turbo-0125",
  131. "gpt-4",
  132. "gpt-4-0613",
  133. "gpt-4-32k",
  134. "gpt-4-32k-0613",
  135. "gpt-4-turbo",
  136. "gpt-4-turbo-preview",
  137. "gpt-4o",
  138. "gpt-4o-2024-05-13",
  139. "gpt-4-vision-preview",
  140. "gpt-4-turbo-2024-04-09",
  141. "gpt-4-1106-preview",
  142. ];
  143. const googleModels = [
  144. "gemini-1.0-pro",
  145. "gemini-1.5-pro-latest",
  146. "gemini-1.5-flash-latest",
  147. "gemini-pro-vision",
  148. ];
  149. const anthropicModels = [
  150. "claude-instant-1.2",
  151. "claude-2.0",
  152. "claude-2.1",
  153. "claude-3-sonnet-20240229",
  154. "claude-3-opus-20240229",
  155. "claude-3-haiku-20240307",
  156. "claude-3-5-sonnet-20240620",
  157. ];
  158. const bytedanceModels = ["ep-20240520082937-424bw=Doubao-lite-4k"];
  159. export const DEFAULT_MODELS = [
  160. ...openaiModels.map((name) => ({
  161. name,
  162. available: true,
  163. provider: {
  164. id: "openai",
  165. providerName: "OpenAI",
  166. providerType: "openai",
  167. },
  168. })),
  169. ...openaiModels.map((name) => ({
  170. name,
  171. available: true,
  172. provider: {
  173. id: "azure",
  174. providerName: "Azure",
  175. providerType: "azure",
  176. },
  177. })),
  178. ...googleModels.map((name) => ({
  179. name,
  180. available: true,
  181. provider: {
  182. id: "google",
  183. providerName: "Google",
  184. providerType: "google",
  185. },
  186. })),
  187. ...anthropicModels.map((name) => ({
  188. name,
  189. available: true,
  190. provider: {
  191. id: "anthropic",
  192. providerName: "Anthropic",
  193. providerType: "anthropic",
  194. },
  195. })),
  196. ...bytedanceModels.map((name) => ({
  197. name,
  198. available: true,
  199. provider: {
  200. id: "bytedance",
  201. providerName: "ByteDance",
  202. providerType: "bytedance",
  203. },
  204. })),
  205. ] as const;
  206. export const CHAT_PAGE_SIZE = 15;
  207. export const MAX_RENDER_MSG_COUNT = 45;
  208. // some famous webdav endpoints
  209. export const internalAllowedWebDavEndpoints = [
  210. "https://dav.jianguoyun.com/dav/",
  211. "https://dav.dropdav.com/",
  212. "https://dav.box.com/dav",
  213. "https://nanao.teracloud.jp/dav/",
  214. "https://bora.teracloud.jp/dav/",
  215. "https://webdav.4shared.com/",
  216. "https://dav.idrivesync.com",
  217. "https://webdav.yandex.com",
  218. "https://app.koofr.net/dav/Koofr",
  219. ];