constant.ts 6.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295
  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 GEMINI_BASE_URL = "https://generativelanguage.googleapis.com/";
  13. export enum Path {
  14. Home = "/",
  15. Chat = "/chat",
  16. Settings = "/settings",
  17. NewChat = "/new-chat",
  18. Masks = "/masks",
  19. Auth = "/auth",
  20. }
  21. export enum ApiPath {
  22. Cors = "/api/cors",
  23. OpenAI = "/api/openai",
  24. }
  25. export enum SlotID {
  26. AppBody = "app-body",
  27. CustomModel = "custom-model",
  28. }
  29. export enum FileName {
  30. Masks = "masks.json",
  31. Prompts = "prompts.json",
  32. }
  33. export enum StoreKey {
  34. Chat = "chat-next-web-store",
  35. Access = "access-control",
  36. Config = "app-config",
  37. Mask = "mask-store",
  38. Prompt = "prompt-store",
  39. Update = "chat-update",
  40. Sync = "sync",
  41. }
  42. export const DEFAULT_SIDEBAR_WIDTH = 300;
  43. export const MAX_SIDEBAR_WIDTH = 500;
  44. export const MIN_SIDEBAR_WIDTH = 230;
  45. export const NARROW_SIDEBAR_WIDTH = 100;
  46. export const ACCESS_CODE_PREFIX = "nk-";
  47. export const LAST_INPUT_KEY = "last-input";
  48. export const UNFINISHED_INPUT = (id: string) => "unfinished-input-" + id;
  49. export const STORAGE_KEY = "chatgpt-next-web";
  50. export const REQUEST_TIMEOUT_MS = 60000;
  51. export const EXPORT_MESSAGE_CLASS_NAME = "export-markdown";
  52. export enum ServiceProvider {
  53. OpenAI = "OpenAI",
  54. Azure = "Azure",
  55. Google = "Google",
  56. }
  57. export enum ModelProvider {
  58. GPT = "GPT",
  59. GeminiPro = "GeminiPro",
  60. }
  61. export const OpenaiPath = {
  62. ChatPath: "v1/chat/completions",
  63. UsagePath: "dashboard/billing/usage",
  64. SubsPath: "dashboard/billing/subscription",
  65. ListModelPath: "v1/models",
  66. };
  67. export const Azure = {
  68. ExampleEndpoint: "https://{resource-url}/openai/deployments/{deploy-id}",
  69. };
  70. export const Google = {
  71. ExampleEndpoint: "https://generativelanguage.googleapis.com/",
  72. ChatPath: "v1beta/models/gemini-pro:generateContent",
  73. VisionChatPath: "v1beta/models/gemini-pro-vision:generateContent",
  74. // /api/openai/v1/chat/completions
  75. };
  76. export const DEFAULT_INPUT_TEMPLATE = `{{input}}`; // input / time / model / lang
  77. export const DEFAULT_SYSTEM_TEMPLATE = `
  78. You are ChatGPT, a large language model trained by {{ServiceProvider}}.
  79. Knowledge cutoff: {{cutoff}}
  80. Current model: {{model}}
  81. Current time: {{time}}
  82. Latex inline: $x^2$
  83. Latex block: $$e=mc^2$$
  84. `;
  85. export const SUMMARIZE_MODEL = "gpt-3.5-turbo";
  86. export const GEMINI_SUMMARIZE_MODEL = "gemini-pro";
  87. export const KnowledgeCutOffDate: Record<string, string> = {
  88. default: "2021-09",
  89. "gpt-4-turbo-preview": "2023-12",
  90. "gpt-4-1106-preview": "2023-04",
  91. "gpt-4-0125-preview": "2023-12",
  92. "gpt-4-vision-preview": "2023-04",
  93. // After improvements,
  94. // it's now easier to add "KnowledgeCutOffDate" instead of stupid hardcoding it, as was done previously.
  95. "gemini-pro": "2023-12",
  96. };
  97. export const DEFAULT_MODELS = [
  98. {
  99. name: "gpt-4",
  100. available: true,
  101. provider: {
  102. id: "openai",
  103. providerName: "OpenAI",
  104. providerType: "openai",
  105. },
  106. },
  107. {
  108. name: "gpt-4-0314",
  109. available: true,
  110. provider: {
  111. id: "openai",
  112. providerName: "OpenAI",
  113. providerType: "openai",
  114. },
  115. },
  116. {
  117. name: "gpt-4-0613",
  118. available: true,
  119. provider: {
  120. id: "openai",
  121. providerName: "OpenAI",
  122. providerType: "openai",
  123. },
  124. },
  125. {
  126. name: "gpt-4-32k",
  127. available: true,
  128. provider: {
  129. id: "openai",
  130. providerName: "OpenAI",
  131. providerType: "openai",
  132. },
  133. },
  134. {
  135. name: "gpt-4-32k-0314",
  136. available: true,
  137. provider: {
  138. id: "openai",
  139. providerName: "OpenAI",
  140. providerType: "openai",
  141. },
  142. },
  143. {
  144. name: "gpt-4-32k-0613",
  145. available: true,
  146. provider: {
  147. id: "openai",
  148. providerName: "OpenAI",
  149. providerType: "openai",
  150. },
  151. },
  152. {
  153. name: "gpt-4-turbo-preview",
  154. available: true,
  155. provider: {
  156. id: "openai",
  157. providerName: "OpenAI",
  158. providerType: "openai",
  159. },
  160. },
  161. {
  162. name: "gpt-4-1106-preview",
  163. available: true,
  164. provider: {
  165. id: "openai",
  166. providerName: "OpenAI",
  167. providerType: "openai",
  168. },
  169. },
  170. {
  171. name: "gpt-4-0125-preview",
  172. available: true,
  173. provider: {
  174. id: "openai",
  175. providerName: "OpenAI",
  176. providerType: "openai",
  177. },
  178. },
  179. {
  180. name: "gpt-4-vision-preview",
  181. available: true,
  182. provider: {
  183. id: "openai",
  184. providerName: "OpenAI",
  185. providerType: "openai",
  186. },
  187. },
  188. {
  189. name: "gpt-3.5-turbo",
  190. available: true,
  191. provider: {
  192. id: "openai",
  193. providerName: "OpenAI",
  194. providerType: "openai",
  195. },
  196. },
  197. {
  198. name: "gpt-3.5-turbo-0125",
  199. available: true,
  200. provider: {
  201. id: "openai",
  202. providerName: "OpenAI",
  203. providerType: "openai",
  204. },
  205. },
  206. {
  207. name: "gpt-3.5-turbo-0301",
  208. available: true,
  209. provider: {
  210. id: "openai",
  211. providerName: "OpenAI",
  212. providerType: "openai",
  213. },
  214. },
  215. {
  216. name: "gpt-3.5-turbo-0613",
  217. available: true,
  218. provider: {
  219. id: "openai",
  220. providerName: "OpenAI",
  221. providerType: "openai",
  222. },
  223. },
  224. {
  225. name: "gpt-3.5-turbo-1106",
  226. available: true,
  227. provider: {
  228. id: "openai",
  229. providerName: "OpenAI",
  230. providerType: "openai",
  231. },
  232. },
  233. {
  234. name: "gpt-3.5-turbo-16k",
  235. available: true,
  236. provider: {
  237. id: "openai",
  238. providerName: "OpenAI",
  239. providerType: "openai",
  240. },
  241. },
  242. {
  243. name: "gpt-3.5-turbo-16k-0613",
  244. available: true,
  245. provider: {
  246. id: "openai",
  247. providerName: "OpenAI",
  248. providerType: "openai",
  249. },
  250. },
  251. {
  252. name: "gemini-pro",
  253. available: true,
  254. provider: {
  255. id: "google",
  256. providerName: "Google",
  257. providerType: "google",
  258. },
  259. },
  260. {
  261. name: "gemini-pro-vision",
  262. available: true,
  263. provider: {
  264. id: "google",
  265. providerName: "Google",
  266. providerType: "google",
  267. },
  268. },
  269. ] as const;
  270. export const CHAT_PAGE_SIZE = 15;
  271. export const MAX_RENDER_MSG_COUNT = 45;