es.ts 18 KB

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