constant.ts 6.2 KB

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