constant.ts 6.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282
  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. };
  93. export const DEFAULT_MODELS = [
  94. {
  95. name: "gpt-4",
  96. available: true,
  97. provider: {
  98. id: "openai",
  99. providerName: "OpenAI",
  100. providerType: "openai",
  101. },
  102. },
  103. {
  104. name: "gpt-4-0314",
  105. available: true,
  106. provider: {
  107. id: "openai",
  108. providerName: "OpenAI",
  109. providerType: "openai",
  110. },
  111. },
  112. {
  113. name: "gpt-4-0613",
  114. available: true,
  115. provider: {
  116. id: "openai",
  117. providerName: "OpenAI",
  118. providerType: "openai",
  119. },
  120. },
  121. {
  122. name: "gpt-4-32k",
  123. available: true,
  124. provider: {
  125. id: "openai",
  126. providerName: "OpenAI",
  127. providerType: "openai",
  128. },
  129. },
  130. {
  131. name: "gpt-4-32k-0314",
  132. available: true,
  133. provider: {
  134. id: "openai",
  135. providerName: "OpenAI",
  136. providerType: "openai",
  137. },
  138. },
  139. {
  140. name: "gpt-4-32k-0613",
  141. available: true,
  142. provider: {
  143. id: "openai",
  144. providerName: "OpenAI",
  145. providerType: "openai",
  146. },
  147. },
  148. {
  149. name: "gpt-4-turbo-preview",
  150. available: true,
  151. provider: {
  152. id: "openai",
  153. providerName: "OpenAI",
  154. providerType: "openai",
  155. },
  156. },
  157. {
  158. name: "gpt-4-1106-preview",
  159. available: true,
  160. provider: {
  161. id: "openai",
  162. providerName: "OpenAI",
  163. providerType: "openai",
  164. },
  165. },
  166. {
  167. name: "gpt-4-0125-preview",
  168. available: true,
  169. provider: {
  170. id: "openai",
  171. providerName: "OpenAI",
  172. providerType: "openai",
  173. },
  174. },
  175. {
  176. name: "gpt-4-vision-preview",
  177. available: true,
  178. provider: {
  179. id: "openai",
  180. providerName: "OpenAI",
  181. providerType: "openai",
  182. },
  183. },
  184. {
  185. name: "gpt-3.5-turbo",
  186. available: true,
  187. provider: {
  188. id: "openai",
  189. providerName: "OpenAI",
  190. providerType: "openai",
  191. },
  192. },
  193. {
  194. name: "gpt-3.5-turbo-0125",
  195. available: true,
  196. provider: {
  197. id: "openai",
  198. providerName: "OpenAI",
  199. providerType: "openai",
  200. },
  201. },
  202. {
  203. name: "gpt-3.5-turbo-0301",
  204. available: true,
  205. provider: {
  206. id: "openai",
  207. providerName: "OpenAI",
  208. providerType: "openai",
  209. },
  210. },
  211. {
  212. name: "gpt-3.5-turbo-0613",
  213. available: true,
  214. provider: {
  215. id: "openai",
  216. providerName: "OpenAI",
  217. providerType: "openai",
  218. },
  219. },
  220. {
  221. name: "gpt-3.5-turbo-1106",
  222. available: true,
  223. provider: {
  224. id: "openai",
  225. providerName: "OpenAI",
  226. providerType: "openai",
  227. },
  228. },
  229. {
  230. name: "gpt-3.5-turbo-16k",
  231. available: true,
  232. provider: {
  233. id: "openai",
  234. providerName: "OpenAI",
  235. providerType: "openai",
  236. },
  237. },
  238. {
  239. name: "gpt-3.5-turbo-16k-0613",
  240. available: true,
  241. provider: {
  242. id: "openai",
  243. providerName: "OpenAI",
  244. providerType: "openai",
  245. },
  246. },
  247. {
  248. name: "gemini-pro",
  249. available: true,
  250. provider: {
  251. id: "google",
  252. providerName: "Google",
  253. providerType: "google",
  254. },
  255. },
  256. ] as const;
  257. export const CHAT_PAGE_SIZE = 15;
  258. export const MAX_RENDER_MSG_COUNT = 45;