constant.ts 6.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284
  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. // /api/openai/v1/chat/completions
  74. };
  75. export const DEFAULT_INPUT_TEMPLATE = `{{input}}`; // input / time / model / lang
  76. export const DEFAULT_SYSTEM_TEMPLATE = `
  77. You are ChatGPT, a large language model trained by {{ServiceProvider}}.
  78. Knowledge cutoff: {{cutoff}}
  79. Current model: {{model}}
  80. Current time: {{time}}
  81. Latex inline: $x^2$
  82. Latex block: $$e=mc^2$$
  83. `;
  84. export const SUMMARIZE_MODEL = "gpt-3.5-turbo";
  85. export const KnowledgeCutOffDate: Record<string, string> = {
  86. default: "2021-09",
  87. "gpt-4-turbo-preview": "2023-04",
  88. "gpt-4-1106-preview": "2023-04",
  89. "gpt-4-0125-preview": "2023-04",
  90. "gpt-4-vision-preview": "2023-04",
  91. // After improvements,
  92. // it's now easier to add "KnowledgeCutOffDate" instead of stupid hardcoding it, as was done previously.
  93. "gemini-pro": "2023-12",
  94. };
  95. export const DEFAULT_MODELS = [
  96. {
  97. name: "gpt-4",
  98. available: true,
  99. provider: {
  100. id: "openai",
  101. providerName: "OpenAI",
  102. providerType: "openai",
  103. },
  104. },
  105. {
  106. name: "gpt-4-0314",
  107. available: true,
  108. provider: {
  109. id: "openai",
  110. providerName: "OpenAI",
  111. providerType: "openai",
  112. },
  113. },
  114. {
  115. name: "gpt-4-0613",
  116. available: true,
  117. provider: {
  118. id: "openai",
  119. providerName: "OpenAI",
  120. providerType: "openai",
  121. },
  122. },
  123. {
  124. name: "gpt-4-32k",
  125. available: true,
  126. provider: {
  127. id: "openai",
  128. providerName: "OpenAI",
  129. providerType: "openai",
  130. },
  131. },
  132. {
  133. name: "gpt-4-32k-0314",
  134. available: true,
  135. provider: {
  136. id: "openai",
  137. providerName: "OpenAI",
  138. providerType: "openai",
  139. },
  140. },
  141. {
  142. name: "gpt-4-32k-0613",
  143. available: true,
  144. provider: {
  145. id: "openai",
  146. providerName: "OpenAI",
  147. providerType: "openai",
  148. },
  149. },
  150. {
  151. name: "gpt-4-turbo-preview",
  152. available: true,
  153. provider: {
  154. id: "openai",
  155. providerName: "OpenAI",
  156. providerType: "openai",
  157. },
  158. },
  159. {
  160. name: "gpt-4-1106-preview",
  161. available: true,
  162. provider: {
  163. id: "openai",
  164. providerName: "OpenAI",
  165. providerType: "openai",
  166. },
  167. },
  168. {
  169. name: "gpt-4-0125-preview",
  170. available: true,
  171. provider: {
  172. id: "openai",
  173. providerName: "OpenAI",
  174. providerType: "openai",
  175. },
  176. },
  177. {
  178. name: "gpt-4-vision-preview",
  179. available: true,
  180. provider: {
  181. id: "openai",
  182. providerName: "OpenAI",
  183. providerType: "openai",
  184. },
  185. },
  186. {
  187. name: "gpt-3.5-turbo",
  188. available: true,
  189. provider: {
  190. id: "openai",
  191. providerName: "OpenAI",
  192. providerType: "openai",
  193. },
  194. },
  195. {
  196. name: "gpt-3.5-turbo-0125",
  197. available: true,
  198. provider: {
  199. id: "openai",
  200. providerName: "OpenAI",
  201. providerType: "openai",
  202. },
  203. },
  204. {
  205. name: "gpt-3.5-turbo-0301",
  206. available: true,
  207. provider: {
  208. id: "openai",
  209. providerName: "OpenAI",
  210. providerType: "openai",
  211. },
  212. },
  213. {
  214. name: "gpt-3.5-turbo-0613",
  215. available: true,
  216. provider: {
  217. id: "openai",
  218. providerName: "OpenAI",
  219. providerType: "openai",
  220. },
  221. },
  222. {
  223. name: "gpt-3.5-turbo-1106",
  224. available: true,
  225. provider: {
  226. id: "openai",
  227. providerName: "OpenAI",
  228. providerType: "openai",
  229. },
  230. },
  231. {
  232. name: "gpt-3.5-turbo-16k",
  233. available: true,
  234. provider: {
  235. id: "openai",
  236. providerName: "OpenAI",
  237. providerType: "openai",
  238. },
  239. },
  240. {
  241. name: "gpt-3.5-turbo-16k-0613",
  242. available: true,
  243. provider: {
  244. id: "openai",
  245. providerName: "OpenAI",
  246. providerType: "openai",
  247. },
  248. },
  249. {
  250. name: "gemini-pro",
  251. available: true,
  252. provider: {
  253. id: "google",
  254. providerName: "Google",
  255. providerType: "google",
  256. },
  257. },
  258. ] as const;
  259. export const CHAT_PAGE_SIZE = 15;
  260. export const MAX_RENDER_MSG_COUNT = 45;