sub.php 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296
  1. <?php
  2. /******************************************************************************/
  3. /* Each entry of that file can be associated with a comment to indicate its */
  4. /* state. When there is no comment, it means the entry is fully translated. */
  5. /* The recognized comments are (comment matching is case-insensitive): */
  6. /* + TODO: the entry has never been translated. */
  7. /* + DIRTY: the entry has been translated but needs to be updated. */
  8. /* + IGNORE: the entry does not need to be translated. */
  9. /* When a comment is not recognized, it is discarded. */
  10. /******************************************************************************/
  11. return array(
  12. 'api' => array(
  13. 'documentation' => 'Скопируйте URL для использования во внешнем инструменте.',
  14. 'title' => 'API', // IGNORE
  15. ),
  16. 'bookmarklet' => array(
  17. 'documentation' => 'Перетяните эту кнопку на вашу панель закладок, или нажмите правой кнопкой мыши и выберите "Добавить ссылку в закладки". Нажимайте кнопку "Подписаться" на любой странице, на которую вы хотите подписаться.<br />',
  18. 'label' => 'Подписаться',
  19. 'title' => 'Букмарклет',
  20. ),
  21. 'category' => array(
  22. '_' => 'Категория',
  23. 'add' => 'Добавить категория',
  24. 'archiving' => 'Архивирование',
  25. 'dynamic_opml' => array(
  26. '_' => 'Динамичный OPML',
  27. 'help' => 'Предоставьте ссылку на <a href="http://opml.org/" target="_blank">OPML файл</a> чтобы динамично заполнять эту категорию лентами',
  28. ),
  29. 'empty' => 'Пустая категория',
  30. 'expand' => 'Expand category', // TODO
  31. 'information' => 'Информация',
  32. 'open' => 'Open category', // TODO
  33. 'opml_url' => 'OPML ссылка',
  34. 'position' => 'Положение отображения',
  35. 'position_help' => 'Влияет на порядок отображения категорий',
  36. 'title' => 'Заголовок',
  37. ),
  38. 'feed' => array(
  39. 'accept_cookies' => 'Разрешить файлы cookies',
  40. 'accept_cookies_help' => 'Разрешить серверу ленты использовать cookies (файлы будут храниться в памяти лишь в течение запроса)',
  41. 'add' => 'Добавить ленту',
  42. 'advanced' => 'Дополнительно',
  43. 'archiving' => 'Архивирование',
  44. 'auth' => array(
  45. 'configuration' => 'Логин',
  46. 'help' => 'Разрешить доступ к HTTP защищённым RSS-лентам',
  47. 'http' => 'HTTP аутентификация',
  48. 'password' => 'Пароль HTTP',
  49. 'username' => 'Имя пользователя HTTP',
  50. ),
  51. 'clear_cache' => 'Всегда очищать кэш',
  52. 'content_action' => array(
  53. '_' => 'Действие с содержимым, когда извлекается содержимое статьи',
  54. 'append' => 'Добавить после существующего содержимого',
  55. 'prepend' => 'Добавить перед существующим содержимым',
  56. 'replace' => 'Заменить существующее содержимое',
  57. ),
  58. 'content_retrieval' => 'Content retrieval', // TODO
  59. 'css_cookie' => 'Использовать куки при извлечении содержимого статьи',
  60. 'css_cookie_help' => 'Пример: <kbd>foo=bar; gdpr_consent=true; cookie=value</kbd>',
  61. 'css_help' => 'Получает усечённые RSS-ленты (осторожно, требует больше времени!)',
  62. 'css_path' => 'CSS селектор статьи на сайте',
  63. 'css_path_filter' => array(
  64. '_' => 'CSS селектор элемента для удаления',
  65. 'help' => 'CSS селектор может быть списком как: <kbd>footer, aside, p[data-sanitized-class~="menu"]</kbd>',
  66. ),
  67. 'description' => 'Описание',
  68. 'empty' => 'Лента пустая. Пожалуйста, убедитесь, что её до сих пор обслуживают.',
  69. 'error' => 'С этой лентой возникла проблема. Пожалуйста, убедитесь, что она всегда досягаема.', // DIRTY
  70. 'export-as-opml' => array(
  71. 'download' => 'Скачать',
  72. 'help' => 'XML файл (data subset. <a href="https://freshrss.github.io/FreshRSS/en/developers/OPML.html" target="_blank">See documentation</a>)', // DIRTY
  73. 'label' => 'Экспортировать как OPML',
  74. ),
  75. 'filteractions' => array(
  76. '_' => 'Действия фильтрации',
  77. 'help' => 'Введите по одному поисковому фильтру в строке. См. <a href="https://freshrss.github.io/FreshRSS/en/users/10_filter.html#with-the-search-field" target="_blank">документацию</a>.',
  78. ),
  79. 'http_headers' => 'HTTP Headers', // TODO
  80. 'http_headers_help' => 'Headers are separated by a newline, and the name and value of a header are separated by a colon (e.g: <kbd><code>Accept: application/atom+xml<br />Authorization: Bearer some-token</code></kbd>).', // TODO
  81. 'information' => 'Информация',
  82. 'keep_min' => 'Оставлять статей не менее',
  83. 'kind' => array(
  84. '_' => 'Тип источника ленты',
  85. 'html_json' => array(
  86. '_' => 'HTML + XPath + JSON dot notation (JSON in HTML)', // TODO
  87. 'xpath' => array(
  88. '_' => 'XPath for JSON in HTML', // TODO
  89. 'help' => 'Example: <code>normalize-space(//script[@type="application/json"])</code> (single JSON)<br />or: <code>//script[@type="application/ld+json"]</code> (one JSON object per article)', // TODO
  90. ),
  91. ),
  92. 'html_xpath' => array(
  93. '_' => 'HTML + XPath (парсинг веб-страниц)',
  94. 'feed_title' => array(
  95. '_' => 'заголовка ленты',
  96. 'help' => 'Пример: <code>//title</code> или статичная строка: <code>"Моя пользовательская лента"</code>',
  97. ),
  98. 'help' => '<dfn><a href="https://www.w3.org/TR/xpath-10/" target="_blank">XPath 1.0</a></dfn> – стандартный язык запросов для опытных пользователей, который поддерживается в FreshRSS для парсинга веб-страниц.',
  99. 'item' => array(
  100. '_' => 'поиска новых <strong>элементов</strong><br /><small>(самое важное)</small>',
  101. 'help' => 'Пример: <code>//div[@class="news-item"]</code>',
  102. ),
  103. 'item_author' => array(
  104. '_' => 'автора элемента',
  105. 'help' => 'Может также быть статической строкой. Пример: <code>"Аноним"</code>',
  106. ),
  107. 'item_categories' => 'тегов элемента',
  108. 'item_content' => array(
  109. '_' => 'содержимого элемента',
  110. 'help' => 'Пример, чтобы взять элемент целиком: <code>.</code>',
  111. ),
  112. 'item_thumbnail' => array(
  113. '_' => 'эскиза элемента',
  114. 'help' => 'Пример: <code>descendant::img/@src</code>',
  115. ),
  116. 'item_timeFormat' => array(
  117. '_' => 'Пользовательский формат даты/времени',
  118. 'help' => 'Выборочно. Формат поддерживается <a href="https://php.net/datetime.createfromformat" target="_blank"><code>DateTime::createFromFormat()</code></a> как <code>d-m-Y H:i:s</code>',
  119. ),
  120. 'item_timestamp' => array(
  121. '_' => 'даты элемента',
  122. 'help' => 'Результат будет распарсен с <a href="https://php.net/strtotime" target="_blank"><code>strtotime()</code></a>',
  123. ),
  124. 'item_title' => array(
  125. '_' => 'заголовка элемента',
  126. 'help' => 'Используйте, в частности, <a href="https://developer.mozilla.org/docs/Web/XPath/Axes" target="_blank">ось XPath</a> <code>descendant::</code>, наподобие <code>descendant::h2</code>',
  127. ),
  128. 'item_uid' => array(
  129. '_' => 'уникальный ID элемента',
  130. 'help' => 'Выборочно. Пример: <code>descendant::div/@data-uri</code>',
  131. ),
  132. 'item_uri' => array(
  133. '_' => 'ссылки элемента (URL)',
  134. 'help' => 'Пример: <code>descendant::a/@href</code>',
  135. ),
  136. 'relative' => 'XPath (относительно элемента) для:',
  137. 'xpath' => 'XPath для:',
  138. ),
  139. 'json_dotnotation' => array(
  140. '_' => 'JSON (точечная нотация)',
  141. 'feed_title' => array(
  142. '_' => 'название ленты',
  143. 'help' => 'Пример: <code>meta.title</code> или статический текст: <code>"Моя пользовательская лента"</code>',
  144. ),
  145. 'help' => 'JSON с точечной нотацией использует точки между объектами и квадратные скобки для массивов (например: <code>data.items[0].title</code>)',
  146. 'item' => array(
  147. '_' => 'Найти новые <strong>элементы</strong><br /><small>(самое важное)</small>',
  148. 'help' => 'JSON-путь к массиву, содержащему элементы, например: <code>$</code> or <code>newsItems</code>', // DIRTY
  149. ),
  150. 'item_author' => 'автор элемента',
  151. 'item_categories' => 'теги элемента',
  152. 'item_content' => array(
  153. '_' => 'содержимое элемента',
  154. 'help' => 'Ключ, по которому найден контент, например: <code>content</code>',
  155. ),
  156. 'item_thumbnail' => array(
  157. '_' => 'эскиз элемента',
  158. 'help' => 'Пример: <code>image</code>',
  159. ),
  160. 'item_timeFormat' => array(
  161. '_' => 'Пользовательский формат даты/времени',
  162. 'help' => 'Выборочно. Формат, поддерживаемый <a href="https://php.net/datetime.createfromformat" target="_blank"><code>DateTime::createFromFormat()</code></a>, например <code>d-m-Y H:i:s</code>',
  163. ),
  164. 'item_timestamp' => array(
  165. '_' => 'дата элемента',
  166. 'help' => 'Результат будет распарсен используя <a href="https://php.net/strtotime" target="_blank"><code>strtotime()</code></a>',
  167. ),
  168. 'item_title' => 'название элемента',
  169. 'item_uid' => 'уникальный ID элемента',
  170. 'item_uri' => array(
  171. '_' => 'ссылка на элемент (URL)',
  172. 'help' => 'Пример: <code>permalink</code>',
  173. ),
  174. 'json' => 'точечная нотация для:',
  175. 'relative' => 'JSON-путь (относительный до элемента) для:',
  176. ),
  177. 'jsonfeed' => 'JSON Лента',
  178. 'rss' => 'RSS / Atom (по умолчанию)',
  179. 'xml_xpath' => 'XML + XPath', // IGNORE
  180. ),
  181. 'maintenance' => array(
  182. 'clear_cache' => 'Очистить кэш',
  183. 'clear_cache_help' => 'Очистить кэш для этой ленты.',
  184. 'reload_articles' => 'Перезагрузить статьи',
  185. 'reload_articles_help' => 'Перезагрузить столько статей и извлечь полное содержимое, если задан селектор.',
  186. 'title' => 'Обслуживание',
  187. ),
  188. 'max_http_redir' => 'Максимум HTTP переводов',
  189. 'max_http_redir_help' => 'Установите 0 или оставьте пустым, чтобы отключить, -1 для бесконечных переводов',
  190. 'method' => array(
  191. '_' => 'HTTP метод',
  192. ),
  193. 'method_help' => 'Полезная нагрузка POST автоматически поддерживает <code>application/x-www-form-urlencoded</code> и <code>application/json</code>',
  194. 'method_postparams' => 'Полезная нагрузка POST',
  195. 'moved_category_deleted' => 'Когда вы удаляете категорию, ленты категории автоматически попадают в категорию <em>%s</em>.',
  196. 'mute' => array(
  197. '_' => 'заглушить',
  198. 'state_is_muted' => 'This feed is muted', // TODO
  199. ),
  200. 'no_selected' => 'Ленты не выбраны.',
  201. 'number_entries' => '%d статей',
  202. 'open_feed' => 'Open feed %s', // TODO
  203. 'path_entries_conditions' => 'Conditions for content retrieval', // TODO
  204. 'priority' => array(
  205. '_' => 'Видимость',
  206. 'archived' => 'Не показывать (архивировано)',
  207. 'category' => 'Показывать в категории ленты',
  208. 'important' => 'Показывать в важных лентах',
  209. 'main_stream' => 'Показывать в основном потоке',
  210. ),
  211. 'proxy' => 'Указать прокси для извлечения этой ленты',
  212. 'proxy_help' => 'Выберите протокол (например, SOCKS5) и введите адрес прокси (например, <kbd>127.0.0.1:1080</kbd> или <kbd>username:password@127.0.0.1:1080</kbd>)', // DIRTY
  213. 'selector_preview' => array(
  214. 'show_raw' => 'Показать исходный код',
  215. 'show_rendered' => 'Показать содержимое',
  216. ),
  217. 'show' => array(
  218. 'all' => 'Показать все ленты',
  219. 'error' => 'Показать только ленты с ошибками',
  220. ),
  221. 'showing' => array(
  222. 'error' => 'Показываются только ленты с ошибками',
  223. ),
  224. 'ssl_verify' => 'Проверять безопасность SSL',
  225. 'stats' => 'Статистика',
  226. 'think_to_add' => 'Вы можете добавить ленты.',
  227. 'timeout' => 'Таймаут в секундах',
  228. 'title' => 'Заголовок',
  229. 'title_add' => 'Добавить RSS-ленту',
  230. 'ttl' => 'Не обновлять автоматически чаще, чем каждые',
  231. 'unicityCriteria' => array(
  232. '_' => 'Article unicity criteria', // TODO
  233. 'forced' => '<span title="Block the unicity criteria, even when the feed has duplicate articles">forced</span>', // TODO
  234. 'help' => 'Relevant for invalid feeds.<br />⚠️ Changing the policy will create duplicates.', // TODO
  235. 'id' => 'Standard ID (default)', // TODO
  236. 'link' => 'Link', // TODO
  237. 'sha1:link_published' => 'Link + Date', // TODO
  238. 'sha1:link_published_title' => 'Link + Date + Title', // TODO
  239. 'sha1:link_published_title_content' => 'Link + Date + Title + Content', // TODO
  240. ),
  241. 'url' => 'URL ленты',
  242. 'useragent' => 'Указать юзерагент для извлечения лент',
  243. 'useragent_help' => 'Пример: <kbd>Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:86.0)</kbd>',
  244. 'validator' => 'Проверить валидность ленты',
  245. 'website' => 'URL сайта',
  246. 'websub' => 'Моментальные оповещения посредством WebSub',
  247. ),
  248. 'import_export' => array(
  249. 'export' => array(
  250. '_' => 'Экспорт',
  251. 'sqlite' => 'Download user database as SQLite', // TODO
  252. ),
  253. 'export_labelled' => 'Экспортировать ваши помеченные статьи',
  254. 'export_opml' => 'Экспортировать список лент (OPML)',
  255. 'export_starred' => 'Экспортировать ваше избранное',
  256. 'feed_list' => 'Список из %s статей',
  257. 'file_to_import' => 'Файл для импорта<br />(OPML, JSON or ZIP)',
  258. 'file_to_import_no_zip' => 'Файл для импорта<br />(OPML or JSON)',
  259. 'import' => 'Импорт',
  260. 'starred_list' => 'Список избранных статей',
  261. 'title' => 'Импорт / экспорт',
  262. ),
  263. 'menu' => array(
  264. 'add' => 'Добавить ленту или категорию',
  265. 'import_export' => 'Импорт / экспорт',
  266. 'label_management' => 'Управление метками',
  267. 'stats' => array(
  268. 'idle' => 'Неактивные ленты',
  269. 'main' => 'Основная статистика',
  270. 'repartition' => 'Расределение статей',
  271. ),
  272. 'subscription_management' => 'Управление подписками',
  273. 'subscription_tools' => 'Инструменты подписки',
  274. ),
  275. 'tag' => array(
  276. 'auto_label' => 'Добавьте это название к новым статьям',
  277. 'name' => 'Название',
  278. 'new_name' => 'Новое название',
  279. 'old_name' => 'Старое название',
  280. ),
  281. 'title' => array(
  282. '_' => 'Управление подписками',
  283. 'add' => 'Добавить ленту или категорию',
  284. 'add_category' => 'Добавить категорию',
  285. 'add_dynamic_opml' => 'Добавить динамичный OPML',
  286. 'add_feed' => 'Добавить ленту',
  287. 'add_label' => 'Добавить метку',
  288. 'add_opml_category' => 'OPML category name', // TODO
  289. 'delete_label' => 'Удалить метку',
  290. 'feed_management' => 'Управление RSS-лентами',
  291. 'rename_label' => 'Переименовать метку',
  292. 'subscription_tools' => 'Инструменты подписки',
  293. ),
  294. );