sub.php 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309
  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' => 'Развернуть категорию',
  31. 'information' => 'Информация',
  32. 'open' => 'Открыть категорию',
  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. 'change_favicon' => 'Изменить…',
  52. 'clear_cache' => 'Всегда очищать кэш',
  53. 'content_action' => array(
  54. '_' => 'Действие с содержимым, когда извлекается содержимое статьи',
  55. 'append' => 'Добавить после существующего содержимого',
  56. 'prepend' => 'Добавить перед существующим содержимым',
  57. 'replace' => 'Заменить существующее содержимое',
  58. ),
  59. 'content_retrieval' => 'Получение содержимого',
  60. 'css_cookie' => 'Использовать куки при извлечении содержимого статьи',
  61. 'css_cookie_help' => 'Пример: <kbd>foo=bar; gdpr_consent=true; cookie=value</kbd>',
  62. 'css_help' => 'Получает усечённые RSS-ленты (осторожно, требует больше времени!)',
  63. 'css_path' => 'CSS селектор статьи на сайте',
  64. 'css_path_filter' => array(
  65. '_' => 'CSS селектор элемента для удаления',
  66. 'help' => 'CSS селектор может быть списком как: <kbd>footer, aside, p[data-sanitized-class~="menu"]</kbd>',
  67. ),
  68. 'description' => 'Описание',
  69. 'empty' => 'Лента пустая. Пожалуйста, убедитесь, что её до сих пор обслуживают.',
  70. 'error' => 'С этой лентой возникла проблема. Пожалуйста, убедитесь, что она доступна.',
  71. 'export-as-opml' => array(
  72. 'download' => 'Скачать',
  73. 'help' => 'XML файл (подмножество данных. <a href="https://freshrss.github.io/FreshRSS/en/developers/OPML.html" target="_blank">См. документацию</a>)',
  74. 'label' => 'Экспортировать как OPML',
  75. ),
  76. 'ext_favicon' => 'Установить автоматически',
  77. 'favicon_changed_by_ext' => 'Иконка была установлена расширением <b>%s</b>.',
  78. 'filteractions' => array(
  79. '_' => 'Действия фильтрации',
  80. 'help' => 'Введите по одному поисковому фильтру в строке. См. <a href="https://freshrss.github.io/FreshRSS/en/users/10_filter.html#with-the-search-field" target="_blank">документацию</a>.',
  81. 'view_filter' => 'Предпросмотр фильтров на существующих статьях (новое окно)',
  82. ),
  83. 'http_headers' => 'HTTP-заголовки',
  84. 'http_headers_help' => 'Заголовки разделяются новой строкой, имя и значение заголовка разделяются двоеточием (например: <kbd><code>Accept: application/atom+xml<br />Authorization: Bearer some-token</code></kbd>).',
  85. 'icon' => 'Иконка',
  86. 'information' => 'Информация',
  87. 'keep_min' => 'Оставлять статей не менее',
  88. 'kind' => array(
  89. '_' => 'Тип источника ленты',
  90. 'html_json' => array(
  91. '_' => 'HTML + XPath + JSON точечная нотация (JSON в HTML)',
  92. 'xpath' => array(
  93. '_' => 'XPath для JSON в HTML',
  94. 'help' => 'Пример: <code>normalize-space(//script[@type="application/json"])</code> (один JSON)<br />или: <code>//script[@type="application/ld+json"]</code> (один JSON-объект на статью)',
  95. ),
  96. ),
  97. 'html_xpath' => array(
  98. '_' => 'HTML + XPath (парсинг веб-страниц)',
  99. 'feed_title' => array(
  100. '_' => 'заголовка ленты',
  101. 'help' => 'Пример: <code>//title</code> или статичная строка: <code>"Моя пользовательская лента"</code>',
  102. ),
  103. 'help' => '<dfn><a href="https://www.w3.org/TR/xpath-10/" target="_blank">XPath 1.0</a></dfn> – стандартный язык запросов для опытных пользователей, который поддерживается в FreshRSS для парсинга веб-страниц.',
  104. 'item' => array(
  105. '_' => 'поиска новых <strong>элементов</strong><br /><small>(самое важное)</small>',
  106. 'help' => 'Пример: <code>//div[@class="news-item"]</code>',
  107. ),
  108. 'item_author' => array(
  109. '_' => 'автора элемента',
  110. 'help' => 'Может также быть статической строкой. Пример: <code>"Аноним"</code>',
  111. ),
  112. 'item_categories' => 'тегов элемента',
  113. 'item_content' => array(
  114. '_' => 'содержимого элемента',
  115. 'help' => 'Пример, чтобы взять элемент целиком: <code>.</code>',
  116. ),
  117. 'item_thumbnail' => array(
  118. '_' => 'эскиза элемента',
  119. 'help' => 'Пример: <code>descendant::img/@src</code>',
  120. ),
  121. 'item_timeFormat' => array(
  122. '_' => 'Пользовательский формат даты/времени',
  123. 'help' => 'Выборочно. Формат поддерживается <a href="https://php.net/datetime.createfromformat" target="_blank"><code>DateTime::createFromFormat()</code></a> как <code>d-m-Y H:i:s</code>',
  124. ),
  125. 'item_timestamp' => array(
  126. '_' => 'даты элемента',
  127. 'help' => 'Результат будет распарсен с <a href="https://php.net/strtotime" target="_blank"><code>strtotime()</code></a>',
  128. ),
  129. 'item_title' => array(
  130. '_' => 'заголовка элемента',
  131. 'help' => 'Используйте, в частности, <a href="https://developer.mozilla.org/docs/Web/XPath/Axes" target="_blank">ось XPath</a> <code>descendant::</code>, наподобие <code>descendant::h2</code>',
  132. ),
  133. 'item_uid' => array(
  134. '_' => 'уникальный ID элемента',
  135. 'help' => 'Выборочно. Пример: <code>descendant::div/@data-uri</code>',
  136. ),
  137. 'item_uri' => array(
  138. '_' => 'ссылки элемента (URL)',
  139. 'help' => 'Пример: <code>descendant::a/@href</code>',
  140. ),
  141. 'relative' => 'XPath (относительно элемента) для:',
  142. 'xpath' => 'XPath для:',
  143. ),
  144. 'json_dotnotation' => array(
  145. '_' => 'JSON (точечная нотация)',
  146. 'feed_title' => array(
  147. '_' => 'название ленты',
  148. 'help' => 'Пример: <code>meta.title</code> или статический текст: <code>"Моя пользовательская лента"</code>',
  149. ),
  150. 'help' => 'JSON с точечной нотацией использует точки между объектами и квадратные скобки для массивов (например: <code>data.items[0].title</code>)',
  151. 'item' => array(
  152. '_' => 'Найти новые <strong>элементы</strong><br /><small>(самое важное)</small>',
  153. 'help' => 'JSON-путь к массиву, содержащему элементы, например: <code>$</code> или <code>newsItems</code>',
  154. ),
  155. 'item_author' => 'автор элемента',
  156. 'item_categories' => 'теги элемента',
  157. 'item_content' => array(
  158. '_' => 'содержимое элемента',
  159. 'help' => 'Ключ, по которому найден контент, например: <code>content</code>',
  160. ),
  161. 'item_thumbnail' => array(
  162. '_' => 'эскиз элемента',
  163. 'help' => 'Пример: <code>image</code>',
  164. ),
  165. 'item_timeFormat' => array(
  166. '_' => 'Пользовательский формат даты/времени',
  167. 'help' => 'Выборочно. Формат, поддерживаемый <a href="https://php.net/datetime.createfromformat" target="_blank"><code>DateTime::createFromFormat()</code></a>, например <code>d-m-Y H:i:s</code>',
  168. ),
  169. 'item_timestamp' => array(
  170. '_' => 'дата элемента',
  171. 'help' => 'Результат будет распарсен используя <a href="https://php.net/strtotime" target="_blank"><code>strtotime()</code></a>',
  172. ),
  173. 'item_title' => 'название элемента',
  174. 'item_uid' => 'уникальный ID элемента',
  175. 'item_uri' => array(
  176. '_' => 'ссылка на элемент (URL)',
  177. 'help' => 'Пример: <code>permalink</code>',
  178. ),
  179. 'json' => 'точечная нотация для:',
  180. 'relative' => 'JSON-путь (относительный до элемента) для:',
  181. ),
  182. 'jsonfeed' => 'JSON Лента',
  183. 'rss' => 'RSS / Atom (по умолчанию)',
  184. 'xml_xpath' => 'XML + XPath', // IGNORE
  185. ),
  186. 'maintenance' => array(
  187. 'clear_cache' => 'Очистить кэш',
  188. 'clear_cache_help' => 'Очистить кэш для этой ленты.',
  189. 'reload_articles' => 'Перезагрузить статьи',
  190. 'reload_articles_help' => 'Перезагрузить столько статей и извлечь полное содержимое, если задан селектор.',
  191. 'title' => 'Обслуживание',
  192. ),
  193. 'max_http_redir' => 'Максимум HTTP переводов',
  194. 'max_http_redir_help' => 'Установите 0 или оставьте пустым, чтобы отключить, -1 для бесконечных переводов',
  195. 'method' => array(
  196. '_' => 'HTTP метод',
  197. ),
  198. 'method_help' => 'Полезная нагрузка POST автоматически поддерживает <code>application/x-www-form-urlencoded</code> и <code>application/json</code>',
  199. 'method_postparams' => 'Полезная нагрузка POST',
  200. 'moved_category_deleted' => 'Когда вы удаляете категорию, ленты категории автоматически попадают в категорию <em>%s</em>.',
  201. 'mute' => array(
  202. '_' => 'заглушить',
  203. 'state_is_muted' => 'Эта лента заглушена',
  204. ),
  205. 'no_selected' => 'Ленты не выбраны.',
  206. 'number_entries' => '%d статей',
  207. 'open_feed' => 'Открыть ленту %s',
  208. 'path_entries_conditions' => 'Условия для получения содержимого',
  209. 'priority' => array(
  210. '_' => 'Видимость',
  211. 'category' => 'Показывать в категории ленты',
  212. 'feed' => 'Показывать в своей ленте',
  213. 'hidden' => 'Не показывать',
  214. 'important' => 'Показывать в важных лентах',
  215. 'main_stream' => 'Показывать в основном потоке',
  216. ),
  217. 'proxy' => 'Указать прокси для извлечения этой ленты',
  218. 'proxy_help' => 'Выберите протокол (например, SOCKS5) и введите адрес прокси (например, <kbd>127.0.0.1:1080</kbd> или <kbd>username:password@127.0.0.1:1080</kbd>)',
  219. 'reset_favicon' => 'Сбросить на значение по умолчанию',
  220. 'selector_preview' => array(
  221. 'show_raw' => 'Показать исходный код',
  222. 'show_rendered' => 'Показать содержимое',
  223. ),
  224. 'show' => array(
  225. 'all' => 'Показать все ленты',
  226. 'error' => 'Показать только ленты с ошибками',
  227. ),
  228. 'showing' => array(
  229. 'error' => 'Показываются только ленты с ошибками',
  230. ),
  231. 'ssl_verify' => 'Проверять безопасность SSL',
  232. 'stats' => 'Статистика',
  233. 'think_to_add' => 'Вы можете добавить ленты.',
  234. 'timeout' => 'Таймаут в секундах',
  235. 'title' => 'Заголовок',
  236. 'title_add' => 'Добавить RSS-ленту',
  237. 'ttl' => 'Не обновлять автоматически чаще, чем каждые',
  238. 'unicityCriteria' => array(
  239. '_' => 'Критерии уникальности статьи',
  240. 'forced' => '<span title="Блокировать критерии уникальности, даже когда в ленте есть дубликаты статей">принудительно</span>',
  241. 'help' => 'Актуально для некорректных лент.<br />⚠️ Изменение политики создаст дубликаты.',
  242. 'id' => 'Стандартный ID (по умолчанию)',
  243. 'link' => 'Ссылка',
  244. 'sha1:content' => 'Содержимое',
  245. 'sha1:content_published' => 'Содержимое + Дата',
  246. 'sha1:link_published' => 'Ссылка + Дата',
  247. 'sha1:link_published_title' => 'Ссылка + Дата + Заголовок',
  248. 'sha1:link_published_title_content' => 'Ссылка + Дата + Заголовок + Содержимое',
  249. 'sha1:published' => 'Дата',
  250. 'sha1:title' => 'Заголовок',
  251. 'sha1:title_published' => 'Заголовок + Дата',
  252. 'sha1:title_published_content' => 'Заголовок + Дата + Содержимое',
  253. ),
  254. 'url' => 'URL ленты',
  255. 'useragent' => 'Указать юзерагент для извлечения лент',
  256. 'useragent_help' => 'Пример: <kbd>Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:86.0)</kbd>',
  257. 'validator' => 'Проверить валидность ленты',
  258. 'website' => 'URL сайта',
  259. 'websub' => 'Моментальные оповещения посредством WebSub',
  260. ),
  261. 'import_export' => array(
  262. 'export' => array(
  263. '_' => 'Экспорт',
  264. 'sqlite' => 'Скачать базу данных пользователя в формате SQLite',
  265. ),
  266. 'export_labelled' => 'Экспортировать ваши помеченные статьи',
  267. 'export_opml' => 'Экспортировать список лент (OPML)',
  268. 'export_starred' => 'Экспортировать ваше избранное',
  269. 'feed_list' => 'Список из %s статей',
  270. 'file_to_import' => 'Файл для импорта<br />(OPML, JSON or ZIP)',
  271. 'file_to_import_no_zip' => 'Файл для импорта<br />(OPML or JSON)',
  272. 'import' => 'Импорт',
  273. 'starred_list' => 'Список избранных статей',
  274. 'title' => 'Импорт / экспорт',
  275. ),
  276. 'menu' => array(
  277. 'add' => 'Добавить ленту или категорию',
  278. 'import_export' => 'Импорт / экспорт',
  279. 'label_management' => 'Управление метками',
  280. 'stats' => array(
  281. 'idle' => 'Неактивные ленты',
  282. 'main' => 'Основная статистика',
  283. 'repartition' => 'Расределение статей',
  284. 'unread_dates' => 'Даты непрочтённых',
  285. ),
  286. 'subscription_management' => 'Управление подписками',
  287. 'subscription_tools' => 'Инструменты подписки',
  288. ),
  289. 'tag' => array(
  290. 'auto_label' => 'Добавьте это название к новым статьям',
  291. 'name' => 'Название',
  292. 'new_name' => 'Новое название',
  293. 'old_name' => 'Старое название',
  294. ),
  295. 'title' => array(
  296. '_' => 'Управление подписками',
  297. 'add' => 'Добавить ленту или категорию',
  298. 'add_category' => 'Добавить категорию',
  299. 'add_dynamic_opml' => 'Добавить динамичный OPML',
  300. 'add_feed' => 'Добавить ленту',
  301. 'add_label' => 'Добавить метку',
  302. 'add_opml_category' => 'Название категории OPML',
  303. 'delete_label' => 'Удалить метку',
  304. 'feed_management' => 'Управление RSS-лентами',
  305. 'subscription_tools' => 'Инструменты подписки',
  306. ),
  307. );