es.ts 19 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599
  1. import { SubmitKey } from "../store/config";
  2. import type { PartialLocaleType } from "./index";
  3. import { getClientConfig } from "../config/client";
  4. import { SAAS_CHAT_UTM_URL } from "@/app/constant";
  5. const isApp = !!getClientConfig()?.isApp;
  6. const es: PartialLocaleType = {
  7. WIP: "En construcción...",
  8. Error: {
  9. Unauthorized: isApp
  10. ? `😆 La conversación encontró algunos problemas, no te preocupes:
  11. \\ 1️⃣ Si deseas comenzar sin configuración, [haz clic aquí para empezar a chatear inmediatamente 🚀](${SAAS_CHAT_UTM_URL})
  12. \\ 2️⃣ Si deseas usar tus propios recursos de OpenAI, haz clic [aquí](/#/settings) para modificar la configuración ⚙️`
  13. : `😆 La conversación encontró algunos problemas, no te preocupes:
  14. \ 1️⃣ Si deseas comenzar sin configuración, [haz clic aquí para empezar a chatear inmediatamente 🚀](${SAAS_CHAT_UTM_URL})
  15. \ 2️⃣ Si estás utilizando una versión de implementación privada, haz clic [aquí](/#/auth) para ingresar la clave de acceso 🔑
  16. \ 3️⃣ Si deseas usar tus propios recursos de OpenAI, haz clic [aquí](/#/settings) para modificar la configuración ⚙️
  17. `,
  18. },
  19. Auth: {
  20. Title: "Se requiere contraseña",
  21. Tips: "El administrador ha habilitado la verificación de contraseña. Introduce el código de acceso a continuación",
  22. SubTips: "O ingresa tu clave API de OpenAI o Google",
  23. Input: "Introduce el código de acceso aquí",
  24. Confirm: "Confirmar",
  25. Later: "Más tarde",
  26. Return: "Regresar",
  27. SaasTips:
  28. "La configuración es demasiado complicada, quiero usarlo de inmediato",
  29. TopTips:
  30. "🥳 Oferta de lanzamiento de NextChat AI, desbloquea OpenAI o1, GPT-4o, Claude-3.5 y los últimos grandes modelos",
  31. },
  32. ChatItem: {
  33. ChatItemCount: (count: number) => `${count} conversaciones`,
  34. },
  35. Chat: {
  36. SubTitle: (count: number) => `Total de ${count} conversaciones`,
  37. EditMessage: {
  38. Title: "Editar registro de mensajes",
  39. Topic: {
  40. Title: "Tema de la conversación",
  41. SubTitle: "Cambiar el tema de la conversación actual",
  42. },
  43. },
  44. Actions: {
  45. ChatList: "Ver lista de mensajes",
  46. CompressedHistory: "Ver historial de Prompts comprimidos",
  47. Export: "Exportar historial de chat",
  48. Copy: "Copiar",
  49. Stop: "Detener",
  50. Retry: "Reintentar",
  51. Pin: "Fijar",
  52. PinToastContent:
  53. "Se ha fijado 1 conversación a los prompts predeterminados",
  54. PinToastAction: "Ver",
  55. Delete: "Eliminar",
  56. Edit: "Editar",
  57. RefreshTitle: "Actualizar título",
  58. RefreshToast: "Se ha enviado la solicitud de actualización del título",
  59. },
  60. Commands: {
  61. new: "Nueva conversación",
  62. newm: "Nueva conversación desde la máscara",
  63. next: "Siguiente conversación",
  64. prev: "Conversación anterior",
  65. clear: "Limpiar contexto",
  66. del: "Eliminar conversación",
  67. },
  68. InputActions: {
  69. Stop: "Detener respuesta",
  70. ToBottom: "Ir al más reciente",
  71. Theme: {
  72. auto: "Tema automático",
  73. light: "Modo claro",
  74. dark: "Modo oscuro",
  75. },
  76. Prompt: "Comandos rápidos",
  77. Masks: "Todas las máscaras",
  78. Clear: "Limpiar chat",
  79. Settings: "Configuración de conversación",
  80. UploadImage: "Subir imagen",
  81. },
  82. Rename: "Renombrar conversación",
  83. Typing: "Escribiendo…",
  84. Input: (submitKey: string) => {
  85. var inputHints = `${submitKey} para enviar`;
  86. if (submitKey === String(SubmitKey.Enter)) {
  87. inputHints += ",Shift + Enter para nueva línea";
  88. }
  89. return (
  90. inputHints + ",/ para activar autocompletado,: para activar comandos"
  91. );
  92. },
  93. Send: "Enviar",
  94. Config: {
  95. Reset: "Borrar memoria",
  96. SaveAs: "Guardar como máscara",
  97. },
  98. IsContext: "Prompt predeterminado",
  99. },
  100. Export: {
  101. Title: "Compartir historial de chat",
  102. Copy: "Copiar todo",
  103. Download: "Descargar archivo",
  104. Share: "Compartir en ShareGPT",
  105. MessageFromYou: "Usuario",
  106. MessageFromChatGPT: "ChatGPT",
  107. Format: {
  108. Title: "Formato de exportación",
  109. SubTitle: "Puedes exportar como texto Markdown o imagen PNG",
  110. },
  111. IncludeContext: {
  112. Title: "Incluir contexto de máscara",
  113. SubTitle: "Mostrar contexto de máscara en los mensajes",
  114. },
  115. Steps: {
  116. Select: "Seleccionar",
  117. Preview: "Vista previa",
  118. },
  119. Image: {
  120. Toast: "Generando captura de pantalla",
  121. Modal: "Mantén presionado o haz clic derecho para guardar la imagen",
  122. },
  123. },
  124. Select: {
  125. Search: "Buscar mensajes",
  126. All: "Seleccionar todo",
  127. Latest: "Últimos mensajes",
  128. Clear: "Limpiar selección",
  129. },
  130. Memory: {
  131. Title: "Resumen histórico",
  132. EmptyContent:
  133. "El contenido de la conversación es demasiado corto para resumir",
  134. Send: "Comprimir automáticamente el historial de chat y enviarlo como contexto",
  135. Copy: "Copiar resumen",
  136. Reset: "[no usado]",
  137. ResetConfirm: "¿Confirmar para borrar el resumen histórico?",
  138. },
  139. Home: {
  140. NewChat: "Nueva conversación",
  141. DeleteChat: "¿Confirmar la eliminación de la conversación seleccionada?",
  142. DeleteToast: "Conversación eliminada",
  143. Revert: "Deshacer",
  144. },
  145. Settings: {
  146. Title: "Configuración",
  147. SubTitle: "Todas las opciones de configuración",
  148. Danger: {
  149. Reset: {
  150. Title: "Restablecer todas las configuraciones",
  151. SubTitle:
  152. "Restablecer todas las configuraciones a los valores predeterminados",
  153. Action: "Restablecer ahora",
  154. Confirm: "¿Confirmar el restablecimiento de todas las configuraciones?",
  155. },
  156. Clear: {
  157. Title: "Eliminar todos los datos",
  158. SubTitle: "Eliminar todos los chats y datos de configuración",
  159. Action: "Eliminar ahora",
  160. Confirm:
  161. "¿Confirmar la eliminación de todos los chats y datos de configuración?",
  162. },
  163. },
  164. Lang: {
  165. Name: "Language", // ATENCIÓN: si deseas agregar una nueva traducción, por favor no traduzcas este valor, déjalo como `Language`
  166. All: "Todos los idiomas",
  167. },
  168. Avatar: "Avatar",
  169. FontSize: {
  170. Title: "Tamaño de fuente",
  171. SubTitle: "Tamaño de la fuente del contenido del chat",
  172. },
  173. FontFamily: {
  174. Title: "Fuente del Chat",
  175. SubTitle:
  176. "Fuente del contenido del chat, dejar vacío para aplicar la fuente predeterminada global",
  177. Placeholder: "Nombre de la Fuente",
  178. },
  179. InjectSystemPrompts: {
  180. Title: "Inyectar mensajes del sistema",
  181. SubTitle:
  182. "Forzar la adición de un mensaje del sistema simulado de ChatGPT al principio de cada lista de mensajes",
  183. },
  184. InputTemplate: {
  185. Title: "Preprocesamiento de entrada del usuario",
  186. SubTitle: "El último mensaje del usuario se rellenará en esta plantilla",
  187. },
  188. SendKey: "Tecla de enviar",
  189. Theme: "Tema",
  190. TightBorder: "Modo sin borde",
  191. SendPreviewBubble: {
  192. Title: "Vista previa del globo",
  193. SubTitle:
  194. "Previsualiza el contenido Markdown en un globo de vista previa",
  195. },
  196. AutoGenerateTitle: {
  197. Title: "Generar título automáticamente",
  198. SubTitle: "Generar un título adecuado basado en el contenido del chat",
  199. },
  200. Sync: {
  201. CloudState: "Datos en la nube",
  202. NotSyncYet: "Aún no se ha sincronizado",
  203. Success: "Sincronización exitosa",
  204. Fail: "Sincronización fallida",
  205. Config: {
  206. Modal: {
  207. Title: "Configurar sincronización en la nube",
  208. Check: "Verificar disponibilidad",
  209. },
  210. SyncType: {
  211. Title: "Tipo de sincronización",
  212. SubTitle: "Selecciona el servidor de sincronización preferido",
  213. },
  214. Proxy: {
  215. Title: "Habilitar proxy",
  216. SubTitle:
  217. "Debes habilitar el proxy para sincronizar en el navegador y evitar restricciones de CORS",
  218. },
  219. ProxyUrl: {
  220. Title: "Dirección del proxy",
  221. SubTitle: "Solo para el proxy CORS incluido en este proyecto",
  222. },
  223. WebDav: {
  224. Endpoint: "Dirección WebDAV",
  225. UserName: "Nombre de usuario",
  226. Password: "Contraseña",
  227. },
  228. UpStash: {
  229. Endpoint: "URL de REST de UpStash Redis",
  230. UserName: "Nombre de respaldo",
  231. Password: "Token de REST de UpStash Redis",
  232. },
  233. },
  234. LocalState: "Datos locales",
  235. Overview: (overview: any) => {
  236. return `${overview.chat} conversaciones, ${overview.message} mensajes, ${overview.prompt} prompts, ${overview.mask} máscaras`;
  237. },
  238. ImportFailed: "Importación fallida",
  239. },
  240. Mask: {
  241. Splash: {
  242. Title: "Pantalla de inicio de máscara",
  243. SubTitle:
  244. "Mostrar la pantalla de inicio de la máscara al iniciar un nuevo chat",
  245. },
  246. Builtin: {
  247. Title: "Ocultar máscaras integradas",
  248. SubTitle:
  249. "Ocultar las máscaras integradas en todas las listas de máscaras",
  250. },
  251. },
  252. Prompt: {
  253. Disable: {
  254. Title: "Deshabilitar autocompletado de prompts",
  255. SubTitle:
  256. "Escribe / al principio del campo de entrada para activar el autocompletado",
  257. },
  258. List: "Lista de prompts personalizados",
  259. ListCount: (builtin: number, custom: number) =>
  260. `Integrados ${builtin}, definidos por el usuario ${custom}`,
  261. Edit: "Editar",
  262. Modal: {
  263. Title: "Lista de prompts",
  264. Add: "Nuevo",
  265. Search: "Buscar prompts",
  266. },
  267. EditModal: {
  268. Title: "Editar prompt",
  269. },
  270. },
  271. HistoryCount: {
  272. Title: "Número de mensajes históricos adjuntos",
  273. SubTitle: "Número de mensajes históricos enviados con cada solicitud",
  274. },
  275. CompressThreshold: {
  276. Title: "Umbral de compresión de mensajes históricos",
  277. SubTitle:
  278. "Cuando los mensajes históricos no comprimidos superan este valor, se realizará la compresión",
  279. },
  280. Access: {
  281. SaasStart: {
  282. Title: "Use NextChat AI",
  283. Label: "(The most cost-effective solution)",
  284. SubTitle:
  285. "Officially maintained by NextChat, zero configuration ready to use, supports the latest large models like OpenAI o1, GPT-4o, and Claude-3.5",
  286. ChatNow: "Chat Now",
  287. },
  288. AccessCode: {
  289. Title: "Contraseña de acceso",
  290. SubTitle: "El administrador ha habilitado el acceso encriptado",
  291. Placeholder: "Introduce la contraseña de acceso",
  292. },
  293. CustomEndpoint: {
  294. Title: "Interfaz personalizada",
  295. SubTitle: "¿Usar servicios personalizados de Azure u OpenAI?",
  296. },
  297. Provider: {
  298. Title: "Proveedor de modelos",
  299. SubTitle: "Cambiar entre diferentes proveedores",
  300. },
  301. OpenAI: {
  302. ApiKey: {
  303. Title: "Clave API",
  304. SubTitle:
  305. "Usa una clave API de OpenAI personalizada para omitir la restricción de acceso por contraseña",
  306. Placeholder: "Clave API de OpenAI",
  307. },
  308. Endpoint: {
  309. Title: "Dirección del endpoint",
  310. SubTitle:
  311. "Debe incluir http(s):// además de la dirección predeterminada",
  312. },
  313. },
  314. Azure: {
  315. ApiKey: {
  316. Title: "Clave de interfaz",
  317. SubTitle:
  318. "Usa una clave de Azure personalizada para omitir la restricción de acceso por contraseña",
  319. Placeholder: "Clave API de Azure",
  320. },
  321. Endpoint: {
  322. Title: "Dirección del endpoint",
  323. SubTitle: "Ejemplo:",
  324. },
  325. ApiVerion: {
  326. Title: "Versión de la interfaz (versión de api de azure)",
  327. SubTitle: "Selecciona una versión específica",
  328. },
  329. },
  330. Anthropic: {
  331. ApiKey: {
  332. Title: "Clave de interfaz",
  333. SubTitle:
  334. "Usa una clave de Anthropic personalizada para omitir la restricción de acceso por contraseña",
  335. Placeholder: "Clave API de Anthropic",
  336. },
  337. Endpoint: {
  338. Title: "Dirección del endpoint",
  339. SubTitle: "Ejemplo:",
  340. },
  341. ApiVerion: {
  342. Title: "Versión de la interfaz (versión de claude api)",
  343. SubTitle: "Selecciona una versión específica de la API",
  344. },
  345. },
  346. Google: {
  347. ApiKey: {
  348. Title: "Clave API",
  349. SubTitle: "Obtén tu clave API de Google AI",
  350. Placeholder: "Introduce tu clave API de Google AI Studio",
  351. },
  352. Endpoint: {
  353. Title: "Dirección del endpoint",
  354. SubTitle: "Ejemplo:",
  355. },
  356. ApiVersion: {
  357. Title: "Versión de la API (solo para gemini-pro)",
  358. SubTitle: "Selecciona una versión específica de la API",
  359. },
  360. GoogleSafetySettings: {
  361. Title: "Nivel de filtrado de seguridad de Google",
  362. SubTitle: "Configura el nivel de filtrado de contenido",
  363. },
  364. },
  365. Baidu: {
  366. ApiKey: {
  367. Title: "Clave API",
  368. SubTitle: "Usa una clave API de Baidu personalizada",
  369. Placeholder: "Clave API de Baidu",
  370. },
  371. SecretKey: {
  372. Title: "Clave secreta",
  373. SubTitle: "Usa una clave secreta de Baidu personalizada",
  374. Placeholder: "Clave secreta de Baidu",
  375. },
  376. Endpoint: {
  377. Title: "Dirección del endpoint",
  378. SubTitle:
  379. "No admite personalización, dirígete a .env para configurarlo",
  380. },
  381. },
  382. ByteDance: {
  383. ApiKey: {
  384. Title: "Clave de interfaz",
  385. SubTitle: "Usa una clave API de ByteDance personalizada",
  386. Placeholder: "Clave API de ByteDance",
  387. },
  388. Endpoint: {
  389. Title: "Dirección del endpoint",
  390. SubTitle: "Ejemplo:",
  391. },
  392. },
  393. Alibaba: {
  394. ApiKey: {
  395. Title: "Clave de interfaz",
  396. SubTitle: "Usa una clave API de Alibaba Cloud personalizada",
  397. Placeholder: "Clave API de Alibaba Cloud",
  398. },
  399. Endpoint: {
  400. Title: "Dirección del endpoint",
  401. SubTitle: "Ejemplo:",
  402. },
  403. },
  404. AI302: {
  405. ApiKey: {
  406. Title: "Clave de interfaz",
  407. SubTitle: "Usa una clave API de 302.AI personalizada",
  408. Placeholder: "Clave API de 302.AI",
  409. },
  410. Endpoint: {
  411. Title: "Dirección del endpoint",
  412. SubTitle: "Ejemplo:",
  413. },
  414. },
  415. CustomModel: {
  416. Title: "Nombre del modelo personalizado",
  417. SubTitle:
  418. "Agrega opciones de modelos personalizados, separados por comas",
  419. },
  420. },
  421. Model: "Modelo (model)",
  422. CompressModel: {
  423. Title: "Modelo de compresión",
  424. SubTitle: "Modelo utilizado para comprimir el historial",
  425. },
  426. Temperature: {
  427. Title: "Aleatoriedad (temperature)",
  428. SubTitle: "Cuanto mayor sea el valor, más aleatorio será el resultado",
  429. },
  430. TopP: {
  431. Title: "Muestreo por núcleo (top_p)",
  432. SubTitle: "Similar a la aleatoriedad, pero no cambies ambos a la vez",
  433. },
  434. MaxTokens: {
  435. Title: "Límite de tokens por respuesta (max_tokens)",
  436. SubTitle: "Número máximo de tokens utilizados en una sola interacción",
  437. },
  438. PresencePenalty: {
  439. Title: "Novedad de temas (presence_penalty)",
  440. SubTitle:
  441. "Cuanto mayor sea el valor, más probable es que se amplíen a nuevos temas",
  442. },
  443. FrequencyPenalty: {
  444. Title: "Penalización de frecuencia (frequency_penalty)",
  445. SubTitle:
  446. "Cuanto mayor sea el valor, más probable es que se reduzcan las palabras repetidas",
  447. },
  448. },
  449. Store: {
  450. DefaultTopic: "Nuevo chat",
  451. BotHello: "¿En qué puedo ayudarte?",
  452. Error: "Hubo un error, inténtalo de nuevo más tarde",
  453. Prompt: {
  454. History: (content: string) =>
  455. "Este es un resumen del chat histórico como referencia: " + content,
  456. Topic:
  457. "Devuelve un tema breve de esta frase en cuatro a cinco palabras, sin explicación, sin puntuación, sin muletillas, sin texto adicional, sin negritas. Si no hay tema, devuelve 'charlas casuales'",
  458. Summarize:
  459. "Resume brevemente el contenido de la conversación para usar como un prompt de contexto, manteniéndolo dentro de 200 palabras",
  460. },
  461. },
  462. Copy: {
  463. Success: "Copiado al portapapeles",
  464. Failed: "Error al copiar, por favor otorga permisos al portapapeles",
  465. },
  466. Download: {
  467. Success: "Contenido descargado en tu directorio.",
  468. Failed: "Error al descargar.",
  469. },
  470. Context: {
  471. Toast: (x: any) => `Contiene ${x} prompts predefinidos`,
  472. Edit: "Configuración del chat actual",
  473. Add: "Agregar una conversación",
  474. Clear: "Contexto borrado",
  475. Revert: "Restaurar contexto",
  476. },
  477. Plugin: {
  478. Name: "Complemento",
  479. },
  480. FineTuned: {
  481. Sysmessage: "Eres un asistente",
  482. },
  483. SearchChat: {
  484. Name: "Buscar",
  485. Page: {
  486. Title: "Buscar en el historial de chat",
  487. Search: "Ingrese la palabra clave de búsqueda",
  488. NoResult: "No se encontraron resultados",
  489. NoData: "Sin datos",
  490. Loading: "Cargando",
  491. SubTitle: (count: number) => `Se encontraron ${count} resultados`,
  492. },
  493. Item: {
  494. View: "Ver",
  495. },
  496. },
  497. Mask: {
  498. Name: "Máscara",
  499. Page: {
  500. Title: "Máscaras de rol predefinidas",
  501. SubTitle: (count: number) => `${count} definiciones de rol predefinidas`,
  502. Search: "Buscar máscara de rol",
  503. Create: "Crear nuevo",
  504. },
  505. Item: {
  506. Info: (count: number) => `Contiene ${count} conversaciones predefinidas`,
  507. Chat: "Chat",
  508. View: "Ver",
  509. Edit: "Editar",
  510. Delete: "Eliminar",
  511. DeleteConfirm: "¿Confirmar eliminación?",
  512. },
  513. EditModal: {
  514. Title: (readonly: boolean) =>
  515. `Editar máscara predefinida ${readonly ? "(solo lectura)" : ""}`,
  516. Download: "Descargar predefinido",
  517. Clone: "Clonar predefinido",
  518. },
  519. Config: {
  520. Avatar: "Avatar del rol",
  521. Name: "Nombre del rol",
  522. Sync: {
  523. Title: "Usar configuración global",
  524. SubTitle:
  525. "¿Usar la configuración global del modelo para la conversación actual?",
  526. Confirm:
  527. "La configuración personalizada de la conversación actual se sobrescribirá automáticamente, ¿confirmar habilitar la configuración global?",
  528. },
  529. HideContext: {
  530. Title: "Ocultar conversaciones predefinidas",
  531. SubTitle:
  532. "Las conversaciones predefinidas ocultas no aparecerán en la interfaz de chat",
  533. },
  534. Share: {
  535. Title: "Compartir esta máscara",
  536. SubTitle: "Generar un enlace directo a esta máscara",
  537. Action: "Copiar enlace",
  538. },
  539. },
  540. },
  541. NewChat: {
  542. Return: "Regresar",
  543. Skip: "Comenzar ahora",
  544. NotShow: "No mostrar más",
  545. ConfirmNoShow:
  546. "¿Confirmar desactivación? Puedes reactivar en la configuración en cualquier momento.",
  547. Title: "Selecciona una máscara",
  548. SubTitle: "Comienza ahora y colisiona con la mente detrás de la máscara",
  549. More: "Ver todo",
  550. },
  551. URLCommand: {
  552. Code: "Detectado un código de acceso en el enlace, ¿deseas autocompletarlo?",
  553. Settings:
  554. "Detectada configuración predefinida en el enlace, ¿deseas autocompletarla?",
  555. },
  556. UI: {
  557. Confirm: "Confirmar",
  558. Cancel: "Cancelar",
  559. Close: "Cerrar",
  560. Create: "Crear",
  561. Edit: "Editar",
  562. Export: "Exportar",
  563. Import: "Importar",
  564. Sync: "Sincronizar",
  565. Config: "Configurar",
  566. },
  567. Exporter: {
  568. Description: {
  569. Title: "Solo se mostrarán los mensajes después de borrar el contexto",
  570. },
  571. Model: "Modelo",
  572. Messages: "Mensajes",
  573. Topic: "Tema",
  574. Time: "Hora",
  575. },
  576. };
  577. export default es;