common.ts 36 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629
  1. const translation = {
  2. api: {
  3. success: 'Успешно',
  4. actionSuccess: 'Действие выполнено успешно',
  5. saved: 'Сохранено',
  6. create: 'Создано',
  7. remove: 'Удалено',
  8. },
  9. operation: {
  10. create: 'Создать',
  11. confirm: 'Подтвердить',
  12. cancel: 'Отмена',
  13. clear: 'Очистить',
  14. save: 'Сохранить',
  15. saveAndEnable: 'Сохранить и включить',
  16. edit: 'Редактировать',
  17. add: 'Добавить',
  18. added: 'Добавлено',
  19. refresh: 'Перезапустить',
  20. reset: 'Сбросить',
  21. search: 'Поиск',
  22. change: 'Изменить',
  23. remove: 'Удалить',
  24. send: 'Отправить',
  25. copy: 'Копировать',
  26. lineBreak: 'Разрыв строки',
  27. sure: 'Я уверен',
  28. download: 'Скачать',
  29. delete: 'Удалить',
  30. settings: 'Настройки',
  31. setup: 'Настроить',
  32. getForFree: 'Получить бесплатно',
  33. reload: 'Перезагрузить',
  34. ok: 'ОК',
  35. log: 'Журнал',
  36. learnMore: 'Узнать больше',
  37. params: 'Параметры',
  38. duplicate: 'Дублировать',
  39. rename: 'Переименовать',
  40. audioSourceUnavailable: 'AudioSource недоступен',
  41. zoomIn: 'Увеличить',
  42. zoomOut: 'Уменьшение масштаба',
  43. openInNewTab: 'Открыть в новой вкладке',
  44. copyImage: 'Скопировать изображение',
  45. close: 'Закрывать',
  46. regenerate: 'Регенерировать',
  47. view: 'Вид',
  48. viewMore: 'ПОДРОБНЕЕ',
  49. saveAndRegenerate: 'Сохранение и повторное создание дочерних блоков',
  50. submit: 'Отправить',
  51. skip: 'Корабль',
  52. imageCopied: 'Скопированное изображение',
  53. deleteApp: 'Удалить приложение',
  54. },
  55. errorMsg: {
  56. fieldRequired: '{{field}} обязательно',
  57. urlError: 'URL должен начинаться с http:// или https://',
  58. },
  59. placeholder: {
  60. input: 'Пожалуйста, введите',
  61. select: 'Пожалуйста, выберите',
  62. },
  63. voice: {
  64. language: {
  65. zhHans: 'Китайский',
  66. zhHant: 'Традиционный китайский',
  67. enUS: 'Английский',
  68. deDE: 'Немецкий',
  69. frFR: 'Французский',
  70. esES: 'Испанский',
  71. itIT: 'Итальянский',
  72. thTH: 'Тайский',
  73. idID: 'Индонезийский',
  74. jaJP: 'Японский',
  75. koKR: 'Корейский',
  76. ptBR: 'Португальский',
  77. ruRU: 'Русский',
  78. ukUA: 'Украинский',
  79. viVN: 'Вьетнамский',
  80. plPL: 'Польский',
  81. roRO: 'Румынский',
  82. hiIN: 'Хинди',
  83. trTR: 'Турецкий',
  84. faIR: 'Персидский',
  85. },
  86. },
  87. unit: {
  88. char: 'символов',
  89. },
  90. actionMsg: {
  91. noModification: 'На данный момент нет изменений.',
  92. modifiedSuccessfully: 'Изменено успешно',
  93. modifiedUnsuccessfully: 'Изменено неудачно',
  94. copySuccessfully: 'Скопировано успешно',
  95. paySucceeded: 'Оплата прошла успешно',
  96. payCancelled: 'Оплата отменена',
  97. generatedSuccessfully: 'Сгенерировано успешно',
  98. generatedUnsuccessfully: 'Сгенерировано неудачно',
  99. },
  100. model: {
  101. params: {
  102. temperature: 'Temperature',
  103. temperatureTip:
  104. 'Контролирует случайность: более низкое значение приводит к менее случайным завершениям. По мере приближения температуры к нулю модель станет детерминированной и повторяющейся.',
  105. top_p: 'Top P',
  106. top_pTip:
  107. 'Контролирует разнообразие с помощью ядерной выборки: 0,5 означает, что рассматривается половина всех вариантов, взвешенных по вероятности.',
  108. presence_penalty: 'Presence penalty',
  109. presence_penaltyTip:
  110. 'Насколько штрафовать новые токены в зависимости от того, появляются ли они в тексте до сих пор.\nУвеличивает вероятность того, что модель будет говорить о новых темах.',
  111. frequency_penalty: 'Frequency penalty',
  112. frequency_penaltyTip:
  113. 'Насколько штрафовать новые токены в зависимости от их существующей частоты в тексте до сих пор.\nУменьшает вероятность того, что модель будет повторять одну и ту же строку дословно.',
  114. max_tokens: 'Максимальное количество токенов',
  115. max_tokensTip:
  116. 'Используется для ограничения максимальной длины ответа в токенах. \nБольшие значения могут ограничивать пространство, оставленное для подсказок, журналов чата и знаний. \nРекомендуется установить его ниже двух третей\ngpt-4-1106-preview, gpt-4-vision-preview max token (input 128k output 4k)',
  117. maxTokenSettingTip: 'Ваша настройка максимального количества токенов высока, что потенциально ограничивает пространство для подсказок, запросов и данных. Подумайте о том, чтобы установить его ниже 2/3.',
  118. setToCurrentModelMaxTokenTip: 'Максимальное количество токенов обновлено до 80% максимального количества токенов текущей модели {{maxToken}}.',
  119. stop_sequences: 'Стоп-последовательности',
  120. stop_sequencesTip: 'До четырех последовательностей, где API прекратит генерировать дальнейшие токены. Возвращаемый текст не будет содержать стоп-последовательность.',
  121. stop_sequencesPlaceholder: 'Введите последовательность и нажмите Tab',
  122. },
  123. tone: {
  124. Creative: 'Творческий',
  125. Balanced: 'Сбалансированный',
  126. Precise: 'Точный',
  127. Custom: 'Пользовательский',
  128. },
  129. addMoreModel: 'Перейдите в настройки, чтобы добавить больше моделей',
  130. },
  131. menus: {
  132. status: 'бета',
  133. explore: 'Исследовать',
  134. apps: 'Студия',
  135. plugins: 'Плагины',
  136. pluginsTips: 'Интегрируйте сторонние плагины или создавайте совместимые с ChatGPT AI-плагины.',
  137. datasets: 'Знания',
  138. datasetsTips: 'СКОРО: Импортируйте свои собственные текстовые данные или записывайте данные в режиме реального времени через Webhook для улучшения контекста LLM.',
  139. newApp: 'Новое приложение',
  140. newDataset: 'Создать знания',
  141. tools: 'Инструменты',
  142. },
  143. userProfile: {
  144. settings: 'Настройки',
  145. emailSupport: 'Поддержка по электронной почте',
  146. workspace: 'Рабочее пространство',
  147. createWorkspace: 'Создать рабочее пространство',
  148. helpCenter: 'Помощь',
  149. communityFeedback: 'Обратная связь',
  150. roadmap: 'План развития',
  151. community: 'Сообщество',
  152. about: 'О нас',
  153. logout: 'Выйти',
  154. },
  155. settings: {
  156. accountGroup: 'АККАУНТ',
  157. workplaceGroup: 'РАБОЧЕЕ ПРОСТРАНСТВО',
  158. account: 'Моя учетная запись',
  159. members: 'Участники',
  160. billing: 'Оплата',
  161. integrations: 'Интеграции',
  162. language: 'Язык',
  163. provider: 'Поставщик модели',
  164. dataSource: 'Источник данных',
  165. plugin: 'Плагины',
  166. apiBasedExtension: 'API расширение',
  167. },
  168. account: {
  169. avatar: 'Аватар',
  170. name: 'Имя',
  171. email: 'Электронная почта',
  172. password: 'Пароль',
  173. passwordTip: 'Вы можете установить постоянный пароль, если не хотите использовать временные коды входа',
  174. setPassword: 'Установить пароль',
  175. resetPassword: 'Сбросить пароль',
  176. currentPassword: 'Текущий пароль',
  177. newPassword: 'Новый пароль',
  178. confirmPassword: 'Подтвердите пароль',
  179. notEqual: 'Два пароля различаются.',
  180. langGeniusAccount: 'Учетная запись Dify',
  181. langGeniusAccountTip: 'Ваша учетная запись Dify и связанные с ней пользовательские данные.',
  182. editName: 'Редактировать имя',
  183. showAppLength: 'Показать {{length}} приложений',
  184. delete: 'Удалить учетную запись',
  185. deleteTip: 'Удаление вашей учетной записи приведет к безвозвратному удалению всех ваших данных, и их невозможно будет восстановить.',
  186. deleteConfirmTip: 'Для подтверждения, пожалуйста, отправьте следующее с вашего зарегистрированного адреса электронной почты на ',
  187. account: 'Счет',
  188. studio: 'Студия Dify',
  189. myAccount: 'Моя учетная запись',
  190. deletePrivacyLink: 'Политика конфиденциальности.',
  191. deletePlaceholder: 'Пожалуйста, введите свой адрес электронной почты',
  192. sendVerificationButton: 'Отправить код подтверждения',
  193. verificationLabel: 'Проверочный код',
  194. verificationPlaceholder: 'Вставьте 6-значный код',
  195. feedbackTitle: 'Обратная связь',
  196. feedbackLabel: 'Расскажите нам, почему вы удалили свой аккаунт?',
  197. feedbackPlaceholder: 'Необязательный',
  198. permanentlyDeleteButton: 'Окончательно удалить учетную запись',
  199. deleteLabel: 'Для подтверждения, пожалуйста, введите свой адрес электронной почты ниже',
  200. deleteSuccessTip: 'Вашему аккаунту требуется время, чтобы завершить удаление. Мы свяжемся с вами по электронной почте, когда все будет готово.',
  201. deletePrivacyLinkTip: 'Для получения дополнительной информации о том, как мы обрабатываем ваши данные, ознакомьтесь с нашим',
  202. },
  203. members: {
  204. team: 'Команда',
  205. invite: 'Добавить',
  206. name: 'ИМЯ',
  207. lastActive: 'ПОСЛЕДНЯЯ АКТИВНОСТЬ',
  208. role: 'РОЛИ',
  209. pending: 'Ожидание...',
  210. owner: 'Владелец',
  211. admin: 'Администратор',
  212. adminTip: 'Может создавать приложения и управлять настройками команды',
  213. normal: 'Обычный',
  214. normalTip: 'Может только использовать приложения, не может создавать приложения',
  215. builder: 'Разработчик',
  216. builderTip: 'Может создавать и редактировать собственные приложения',
  217. editor: 'Редактор',
  218. editorTip: 'Может создавать и редактировать приложения',
  219. datasetOperator: 'Администратор знаний',
  220. datasetOperatorTip: 'Может управлять только базой знаний',
  221. inviteTeamMember: 'Добавить участника команды',
  222. inviteTeamMemberTip: 'Они могут получить доступ к данным вашей команды сразу после входа в систему.',
  223. emailNotSetup: 'Почтовый сервер не настроен, поэтому приглашения по электронной почте не могут быть отправлены. Пожалуйста, уведомите пользователей о ссылке для приглашения, которая будет выдана после приглашения.',
  224. email: 'Электронная почта',
  225. emailInvalid: 'Неверный формат электронной почты',
  226. emailPlaceholder: 'Пожалуйста, введите адреса электронной почты',
  227. sendInvite: 'Отправить приглашение',
  228. invitedAsRole: 'Приглашен как пользователь с ролью {{role}}',
  229. invitationSent: 'Приглашение отправлено',
  230. invitationSentTip: 'Приглашение отправлено, и они могут войти в Dify, чтобы получить доступ к данным вашей команды.',
  231. invitationLink: 'Ссылка для приглашения',
  232. failedInvitationEmails: 'Следующие пользователи не были успешно приглашены',
  233. ok: 'ОК',
  234. removeFromTeam: 'Удалить из команды',
  235. removeFromTeamTip: 'Удалить доступ к команде',
  236. setAdmin: 'Назначить администратором',
  237. setMember: 'Назначить обычным участником',
  238. setBuilder: 'Назначить разработчиком',
  239. setEditor: 'Назначить редактором',
  240. disInvite: 'Отменить приглашение',
  241. deleteMember: 'Удалить участника',
  242. you: '(Вы)',
  243. },
  244. integrations: {
  245. connected: 'Подключено',
  246. google: 'Google',
  247. googleAccount: 'Войти с помощью учетной записи Google',
  248. github: 'GitHub',
  249. githubAccount: 'Войти с помощью учетной записи GitHub',
  250. connect: 'Подключить',
  251. },
  252. language: {
  253. displayLanguage: 'Язык отображения',
  254. timezone: 'Часовой пояс',
  255. },
  256. provider: {
  257. apiKey: 'Ключ API',
  258. enterYourKey: 'Введите свой ключ API здесь',
  259. invalidKey: 'Неверный ключ API OpenAI',
  260. validatedError: 'Ошибка валидации: ',
  261. validating: 'Проверка ключа...',
  262. saveFailed: 'Ошибка сохранения ключа API',
  263. apiKeyExceedBill: 'Этот API-ключ не имеет доступной квоты, пожалуйста, прочитайте',
  264. addKey: 'Добавить ключ',
  265. comingSoon: 'Скоро',
  266. editKey: 'Редактировать',
  267. invalidApiKey: 'Неверный ключ API',
  268. azure: {
  269. apiBase: 'Базовый API',
  270. apiBasePlaceholder: 'Базовый URL-адрес API вашей конечной точки Azure OpenAI.',
  271. apiKey: 'Ключ API',
  272. apiKeyPlaceholder: 'Введите свой ключ API здесь',
  273. helpTip: 'Узнать о службе Azure OpenAI',
  274. },
  275. openaiHosted: {
  276. openaiHosted: 'Размещенный OpenAI',
  277. onTrial: 'ПРОБНАЯ ВЕРСИЯ',
  278. exhausted: 'КВОТА ИСЧЕРПАНА',
  279. desc: 'Хостинговая служба OpenAI, предоставляемая Dify, позволяет вам использовать такие модели, как GPT-3.5. Прежде чем ваша пробная квота будет исчерпана, вам необходимо настроить других поставщиков моделей.',
  280. callTimes: 'Количество вызовов',
  281. usedUp: 'Пробная квота исчерпана. Добавьте собственного поставщика модели.',
  282. useYourModel: 'В настоящее время используется собственный поставщик модели.',
  283. close: 'Закрыть',
  284. },
  285. anthropicHosted: {
  286. anthropicHosted: 'Anthropic Claude',
  287. onTrial: 'ПРОБНАЯ ВЕРСИЯ',
  288. exhausted: 'КВОТА ИСЧЕРПАНА',
  289. desc: 'Мощная модель, которая отлично справляется с широким спектром задач, от сложных диалогов и создания творческого контента до подробных инструкций.',
  290. callTimes: 'Количество вызовов',
  291. usedUp: 'Пробная квота исчерпана. Добавьте собственного поставщика модели.',
  292. useYourModel: 'В настоящее время используется собственный поставщик модели.',
  293. close: 'Закрыть',
  294. trialQuotaTip: 'Ваша квота на пробную версию Anthropic истечет 11.03.2025 и больше не будет доступна. Пожалуйста, используйте его вовремя.',
  295. },
  296. anthropic: {
  297. using: 'Возможность встраивания использует',
  298. enableTip: 'Чтобы включить модель Anthropic, вам необходимо сначала привязаться к OpenAI или Azure OpenAI Service.',
  299. notEnabled: 'Не включено',
  300. keyFrom: 'Получите свой ключ API от Anthropic',
  301. },
  302. encrypted: {
  303. front: 'Ваш API-ключ будет зашифрован и сохранен с использованием',
  304. back: ' технологии.',
  305. },
  306. },
  307. modelProvider: {
  308. notConfigured: 'Системная модель еще не полностью настроена, и некоторые функции могут быть недоступны.',
  309. systemModelSettings: 'Настройки системной модели',
  310. systemModelSettingsLink: 'Зачем нужно настраивать системную модель?',
  311. selectModel: 'Выберите свою модель',
  312. setupModelFirst: 'Пожалуйста, сначала настройте свою модель',
  313. systemReasoningModel: {
  314. key: 'Модель системного мышления',
  315. tip: 'Установите модель вывода по умолчанию, которая будет использоваться для создания приложений, а также такие функции, как генерация имени диалога и предложение следующего вопроса, также будут использовать модель вывода по умолчанию.',
  316. },
  317. embeddingModel: {
  318. key: 'Модель встраивания',
  319. tip: 'Установите модель по умолчанию для обработки встраивания документов знаний, как поиск, так и импорт знаний используют эту модель встраивания для обработки векторизации. Переключение приведет к несоответствию векторного измерения между импортированными знаниями и вопросом, что приведет к сбою поиска. Чтобы избежать сбоя поиска, пожалуйста, не переключайте эту модель по своему усмотрению.',
  320. required: 'Модель встраивания обязательна',
  321. },
  322. speechToTextModel: {
  323. key: 'Модель преобразования речи в текст',
  324. tip: 'Установите модель по умолчанию для ввода речи в текст в разговоре.',
  325. },
  326. ttsModel: {
  327. key: 'Модель преобразования текста в речь',
  328. tip: 'Установите модель по умолчанию для ввода текста в речь в разговоре.',
  329. },
  330. rerankModel: {
  331. key: 'Модель повторного ранжирования',
  332. tip: 'Модель повторного ранжирования изменит порядок списка документов-кандидатов на основе семантического соответствия запросу пользователя, улучшая результаты семантического ранжирования',
  333. },
  334. apiKey: 'API-КЛЮЧ',
  335. quota: 'Квота',
  336. searchModel: 'Поиск модели',
  337. noModelFound: 'Модель не найдена для {{model}}',
  338. models: 'Модели',
  339. showMoreModelProvider: 'Показать больше поставщиков моделей',
  340. selector: {
  341. tip: 'Эта модель была удалена. Пожалуйста, добавьте модель или выберите другую модель.',
  342. emptyTip: 'Нет доступных моделей',
  343. emptySetting: 'Пожалуйста, перейдите в настройки для настройки',
  344. rerankTip: 'Пожалуйста, настройте модель повторного ранжирования',
  345. },
  346. card: {
  347. quota: 'КВОТА',
  348. onTrial: 'Пробная версия',
  349. paid: 'Платный',
  350. quotaExhausted: 'Квота исчерпана',
  351. callTimes: 'Количество вызовов',
  352. tokens: 'Токены',
  353. buyQuota: 'Купить квоту',
  354. priorityUse: 'Приоритетное использование',
  355. removeKey: 'Удалить API-ключ',
  356. tip: 'Приоритет будет отдаваться платной квоте. Пробная квота будет использоваться после исчерпания платной квоты.',
  357. },
  358. item: {
  359. deleteDesc: '{{modelName}} используются в качестве моделей системного мышления. Некоторые функции будут недоступны после удаления. Пожалуйста, подтвердите.',
  360. freeQuota: 'БЕСПЛАТНАЯ КВОТА',
  361. },
  362. addApiKey: 'Добавьте свой API-ключ',
  363. invalidApiKey: 'Неверный API-ключ',
  364. encrypted: {
  365. front: 'Ваш API-ключ будет зашифрован и сохранен с использованием',
  366. back: ' технологии.',
  367. },
  368. freeQuota: {
  369. howToEarn: 'Как заработать',
  370. },
  371. addMoreModelProvider: 'ДОБАВИТЬ БОЛЬШЕ ПОСТАВЩИКОВ МОДЕЛЕЙ',
  372. addModel: 'Добавить модель',
  373. modelsNum: '{{num}} Моделей',
  374. showModels: 'Показать модели',
  375. showModelsNum: 'Показать {{num}} моделей',
  376. collapse: 'Свернуть',
  377. config: 'Настройка',
  378. modelAndParameters: 'Модель и параметры',
  379. model: 'Модель',
  380. featureSupported: '{{feature}} поддерживается',
  381. callTimes: 'Количество вызовов',
  382. credits: 'Кредиты на сообщения',
  383. buyQuota: 'Купить квоту',
  384. getFreeTokens: 'Получить бесплатные токены',
  385. priorityUsing: 'Приоритетное использование',
  386. deprecated: 'Устаревший',
  387. confirmDelete: 'Подтвердить удаление?',
  388. quotaTip: 'Оставшиеся доступные бесплатные токены',
  389. loadPresets: 'Загрузить предустановки',
  390. parameters: 'ПАРАМЕТРЫ',
  391. loadBalancing: 'Балансировка нагрузки',
  392. loadBalancingDescription: 'Снизьте нагрузку с помощью нескольких наборов учетных данных.',
  393. loadBalancingHeadline: 'Балансировка нагрузки',
  394. configLoadBalancing: 'Настроить балансировку нагрузки',
  395. modelHasBeenDeprecated: 'Эта модель устарела',
  396. providerManaged: 'Управляется поставщиком',
  397. providerManagedDescription: 'Используйте один набор учетных данных, предоставленный поставщиком модели.',
  398. defaultConfig: 'Настройка по умолчанию',
  399. apiKeyStatusNormal: 'Статус APIKey в норме',
  400. apiKeyRateLimit: 'Достигнут предел скорости, доступен через {{seconds}}s',
  401. addConfig: 'Добавить конфигурацию',
  402. editConfig: 'Редактировать конфигурацию',
  403. loadBalancingLeastKeyWarning: 'Для включения балансировки нагрузки необходимо включить не менее 2 ключей.',
  404. loadBalancingInfo: 'По умолчанию балансировка нагрузки использует стратегию Round-robin. Если срабатывает ограничение скорости, будет применен 1-минутный период охлаждения.',
  405. upgradeForLoadBalancing: 'Обновите свой тарифный план, чтобы включить балансировку нагрузки.',
  406. },
  407. dataSource: {
  408. add: 'Добавить источник данных',
  409. connect: 'Подключить',
  410. configure: 'Настроить',
  411. notion: {
  412. title: 'Notion',
  413. description: 'Использование Notion в качестве источника данных для знаний.',
  414. connectedWorkspace: 'Подключенное рабочее пространство',
  415. addWorkspace: 'Добавить рабочее пространство',
  416. connected: 'Подключено',
  417. disconnected: 'Отключено',
  418. changeAuthorizedPages: 'Изменить авторизованные страницы',
  419. pagesAuthorized: 'Авторизованные страницы',
  420. sync: 'Синхронизировать',
  421. remove: 'Удалить',
  422. selector: {
  423. pageSelected: 'Выбранные страницы',
  424. searchPages: 'Поиск страниц...',
  425. noSearchResult: 'Нет результатов поиска',
  426. addPages: 'Добавить страницы',
  427. preview: 'ПРЕДПРОСМОТР',
  428. },
  429. },
  430. website: {
  431. title: 'Веб-сайт',
  432. description: 'Импортировать контент с веб-сайтов с помощью веб-краулера.',
  433. with: 'С',
  434. configuredCrawlers: 'Настроенные краулеры',
  435. active: 'Активный',
  436. inactive: 'Неактивный',
  437. },
  438. },
  439. plugin: {
  440. serpapi: {
  441. apiKey: 'Ключ API',
  442. apiKeyPlaceholder: 'Введите свой ключ API',
  443. keyFrom: 'Получите свой ключ SerpAPI на странице учетной записи SerpAPI',
  444. },
  445. },
  446. apiBasedExtension: {
  447. title: 'API-расширения обеспечивают централизованное управление API, упрощая настройку для удобного использования в приложениях Dify.',
  448. link: 'Узнайте, как разработать собственное API-расширение.',
  449. linkUrl: 'https://docs.dify.ai/features/extension/api_based_extension',
  450. add: 'Добавить API Extension',
  451. selector: {
  452. title: 'API Extension',
  453. placeholder: 'Пожалуйста, выберите API-расширение',
  454. manage: 'Управление API-расширением',
  455. },
  456. modal: {
  457. title: 'Добавить API-расширение',
  458. editTitle: 'Редактировать API-расширение',
  459. name: {
  460. title: 'Имя',
  461. placeholder: 'Пожалуйста, введите имя',
  462. },
  463. apiEndpoint: {
  464. title: 'API Endpoint',
  465. placeholder: 'Пожалуйста, введите конечную точку API',
  466. },
  467. apiKey: {
  468. title: 'API-ключ',
  469. placeholder: 'Пожалуйста, введите API-ключ',
  470. lengthError: 'Длина API-ключа не может быть меньше 5 символов',
  471. },
  472. },
  473. type: 'Тип',
  474. },
  475. about: {
  476. changeLog: 'Журнал изменений',
  477. updateNow: 'Обновить сейчас',
  478. nowAvailable: 'Dify {{version}} теперь доступен.',
  479. latestAvailable: 'Dify {{version}} - последняя доступная версия.',
  480. },
  481. appMenus: {
  482. overview: 'Мониторинг',
  483. promptEng: 'Оркестрация',
  484. apiAccess: 'Доступ к API',
  485. logAndAnn: 'Журналы и аннотации',
  486. logs: 'Журналы',
  487. },
  488. environment: {
  489. testing: 'ТЕСТИРОВАНИЕ',
  490. development: 'РАЗРАБОТКА',
  491. },
  492. appModes: {
  493. completionApp: 'Генератор текста',
  494. chatApp: 'Чат-приложение',
  495. },
  496. datasetMenus: {
  497. documents: 'Документы',
  498. hitTesting: 'Тестирование поиска',
  499. settings: 'Настройки',
  500. emptyTip: 'Знания не были связаны, пожалуйста, перейдите в приложение или плагин, чтобы завершить связывание.',
  501. viewDoc: 'Просмотреть документацию',
  502. relatedApp: 'связанные приложения',
  503. noRelatedApp: 'Нет связанных приложений',
  504. },
  505. voiceInput: {
  506. speaking: 'Говорите сейчас...',
  507. converting: 'Преобразование в текст...',
  508. notAllow: 'микрофон не авторизован',
  509. },
  510. modelName: {
  511. 'gpt-3.5-turbo': 'GPT-3.5-Turbo',
  512. 'gpt-3.5-turbo-16k': 'GPT-3.5-Turbo-16K',
  513. 'gpt-4': 'GPT-4',
  514. 'gpt-4-32k': 'GPT-4-32K',
  515. 'text-davinci-003': 'Text-Davinci-003',
  516. 'text-embedding-ada-002': 'Text-Embedding-Ada-002',
  517. 'whisper-1': 'Whisper-1',
  518. 'claude-instant-1': 'Claude-Instant',
  519. 'claude-2': 'Claude-2',
  520. },
  521. chat: {
  522. renameConversation: 'Переименовать разговор',
  523. conversationName: 'Название разговора',
  524. conversationNamePlaceholder: 'Пожалуйста, введите название разговора',
  525. conversationNameCanNotEmpty: 'Название разговора обязательно',
  526. citation: {
  527. title: 'ЦИТАТЫ',
  528. linkToDataset: 'Ссылка на знания',
  529. characters: 'Символы:',
  530. hitCount: 'Количество совпадений:',
  531. vectorHash: 'Векторный хэш:',
  532. hitScore: 'Оценка совпадения:',
  533. },
  534. inputPlaceholder: 'Поговорить с ботом',
  535. thinking: 'Мыслящий...',
  536. thought: 'Мысль',
  537. },
  538. promptEditor: {
  539. placeholder: 'Напишите здесь свое ключевое слово подсказки, введите \'{\', чтобы вставить переменную, введите \'/\', чтобы вставить блок содержимого подсказки',
  540. context: {
  541. item: {
  542. title: 'Контекст',
  543. desc: 'Вставить шаблон контекста',
  544. },
  545. modal: {
  546. title: '{{num}} знаний в контексте',
  547. add: 'Добавить контекст ',
  548. footer: 'Вы можете управлять контекстами в разделе «Контекст» ниже.',
  549. },
  550. },
  551. history: {
  552. item: {
  553. title: 'История разговоров',
  554. desc: 'Вставить шаблон исторического сообщения',
  555. },
  556. modal: {
  557. title: 'ПРИМЕР',
  558. user: 'Привет',
  559. assistant: 'Привет! Как я могу вам помочь сегодня?',
  560. edit: 'Редактировать имена ролей разговора',
  561. },
  562. },
  563. variable: {
  564. item: {
  565. title: 'Переменные и внешние инструменты',
  566. desc: 'Вставить переменные и внешние инструменты',
  567. },
  568. outputToolDisabledItem: {
  569. title: 'Переменные',
  570. desc: 'Вставить переменные',
  571. },
  572. modal: {
  573. add: 'Новая переменная',
  574. addTool: 'Новый инструмент',
  575. },
  576. },
  577. query: {
  578. item: {
  579. title: 'Запрос',
  580. desc: 'Вставить шаблон запроса пользователя',
  581. },
  582. },
  583. existed: 'Уже существует в подсказке',
  584. },
  585. imageUploader: {
  586. uploadFromComputer: 'Загрузить с компьютера',
  587. uploadFromComputerReadError: 'Ошибка чтения изображения, повторите попытку.',
  588. uploadFromComputerUploadError: 'Ошибка загрузки изображения, загрузите еще раз.',
  589. uploadFromComputerLimit: 'Загружаемые изображения не могут превышать {{size}} МБ',
  590. pasteImageLink: 'Вставить ссылку на изображение',
  591. pasteImageLinkInputPlaceholder: 'Вставьте ссылку на изображение здесь',
  592. pasteImageLinkInvalid: 'Неверная ссылка на изображение',
  593. imageUpload: 'Загрузка изображения',
  594. },
  595. tag: {
  596. placeholder: 'Все теги',
  597. addNew: 'Добавить новый тег',
  598. noTag: 'Нет тегов',
  599. noTagYet: 'Еще нет тегов',
  600. addTag: 'Добавить теги',
  601. editTag: 'Редактировать теги',
  602. manageTags: 'Управление тегами',
  603. selectorPlaceholder: 'Введите для поиска или создания',
  604. create: 'Создать',
  605. delete: 'Удалить тег',
  606. deleteTip: 'Тег используется, удалить его?',
  607. created: 'Тег успешно создан',
  608. failed: 'Ошибка создания тега',
  609. },
  610. fileUploader: {
  611. pasteFileLinkInputPlaceholder: 'Введите URL...',
  612. pasteFileLink: 'Вставить ссылку на файл',
  613. uploadFromComputer: 'Локальная загрузка',
  614. fileExtensionNotSupport: 'Расширение файла не поддерживается',
  615. uploadFromComputerReadError: 'Чтение файла не удалось, пожалуйста, повторите попытку.',
  616. pasteFileLinkInvalid: 'Неверная ссылка на файл',
  617. uploadFromComputerLimit: 'Файл загрузки не может превышать {{size}}',
  618. uploadFromComputerUploadError: 'Загрузка файла не удалась, пожалуйста, загрузите еще раз.',
  619. },
  620. license: {
  621. expiring: 'Срок действия истекает за один день',
  622. expiring_plural: 'Срок действия истекает через {{count}} дней',
  623. },
  624. pagination: {
  625. perPage: 'Элементов на странице',
  626. },
  627. }
  628. export default translation