sub.php 14 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' => 'Copier l’URL suivante dans l’outil qui utilisera l’API.',
  14. 'title' => 'API', // IGNORE
  15. ),
  16. 'bookmarklet' => array(
  17. 'documentation' => 'Glisser ce bouton dans la barre des favoris ou cliquer droit dessus et choisir « Enregistrer ce lien ». Ensuite, cliquer sur le bouton « S’abonner » sur les pages auxquelles vous voulez vous abonner.',
  18. 'label' => 'S’abonner',
  19. 'title' => 'Bookmarklet', // IGNORE
  20. ),
  21. 'category' => array(
  22. '_' => 'Catégorie',
  23. 'add' => 'Ajouter catégorie',
  24. 'archiving' => 'Archivage',
  25. 'dynamic_opml' => array(
  26. '_' => 'OPML dynamique',
  27. 'help' => 'Fournir l’URL d’un <a href="http://opml.org/" target="_blank">fichier OPML</a> qui donnera dynamiquement la liste des flux de cette catégorie',
  28. ),
  29. 'empty' => 'Catégorie vide',
  30. 'expand' => 'Développer la catégorie',
  31. 'information' => 'Informations',
  32. 'open' => 'Ouvrir la catégorie',
  33. 'opml_url' => 'URL de l’OPML',
  34. 'position' => 'Position d’affichage',
  35. 'position_help' => 'Pour contrôler l’ordre de tri des catégories',
  36. 'title' => 'Titre',
  37. ),
  38. 'feed' => array(
  39. 'accept_cookies' => 'Autoriser les cookies',
  40. 'accept_cookies_help' => 'Accepte les cookies du flux (stocké en mémoire seulement le temps de la requête)',
  41. 'add' => 'Ajouter un flux',
  42. 'advanced' => 'Avancé',
  43. 'archiving' => 'Archivage',
  44. 'auth' => array(
  45. 'configuration' => 'Identification',
  46. 'help' => 'La connexion permet d’accéder aux flux protégés par une authentification HTTP.',
  47. 'http' => 'Authentification HTTP',
  48. 'password' => 'Mot de passe HTTP',
  49. 'username' => 'Identifiant HTTP',
  50. ),
  51. 'clear_cache' => 'Toujours vider le cache',
  52. 'content_action' => array(
  53. '_' => 'Action à effectuer pour la réception du contenu des articles',
  54. 'append' => 'Ajouter après le contenu existant',
  55. 'prepend' => 'Ajouter avant le contenu existant',
  56. 'replace' => 'Remplacer le contenu existant',
  57. ),
  58. 'content_retrieval' => 'Récupération de contenu',
  59. 'css_cookie' => 'Utiliser des cookies pour la réception du contenu des articles',
  60. 'css_cookie_help' => 'Exemple : <kbd>foo=bar; gdpr_consent=true; cookie=value</kbd>',
  61. 'css_help' => 'Permet de récupérer les flux tronqués (attention, demande plus de temps !)',
  62. 'css_path' => 'Sélecteur CSS des articles sur le site d’origine',
  63. 'css_path_filter' => array(
  64. '_' => 'Sélecteur CSS des éléments à supprimer',
  65. 'help' => 'Un sélecteur CSS peut être une liste comme : <kbd>footer, aside, p[data-sanitized-class~="menu"]</kbd>',
  66. ),
  67. 'description' => 'Description', // IGNORE
  68. 'empty' => 'Ce flux est vide. Veuillez vérifier qu’il est encore maintenu.',
  69. 'error' => 'Ce flux a rencontré un problème. Si la situation persiste, vérifiez qu’il est encore accessible.',
  70. 'export-as-opml' => array(
  71. 'download' => 'Télécharger',
  72. 'help' => 'Fichier XML (données partielles. <a href="https://freshrss.github.io/FreshRSS/en/developers/OPML.html" target="_blank">Voir documentation</a>)',
  73. 'label' => 'Exporter en OPML',
  74. ),
  75. 'filteractions' => array(
  76. '_' => 'Filtres d’action',
  77. 'help' => 'Écrivez une recherche par ligne. Voir la <a href="https://freshrss.github.io/FreshRSS/fr/users/03_Main_view.html#gr%C3%A2ce-au-champ-de-recherche" target="_blank">documentation des opérateurs</a>.',
  78. ),
  79. 'http_headers' => 'Entêtes HTTP',
  80. 'http_headers_help' => 'Un entête HTTP par ligne, avec le nom et la valeur séparés par un deux-points (ex. : <kbd><code>Accept: application/atom+xml<br />Authorization: Bearer some-token</code></kbd>).',
  81. 'information' => 'Informations',
  82. 'keep_min' => 'Nombre minimum d’articles à conserver',
  83. 'kind' => array(
  84. '_' => 'Type de source de flux',
  85. 'html_json' => array(
  86. '_' => 'HTML + XPath + JSON notation point (JSON dans HTML)',
  87. 'xpath' => array(
  88. '_' => 'XPath pour JSON dans HTML',
  89. 'help' => 'Exemple : <code>normalize-space(//script[@type="application/json"])</code> (JSON unique)<br />ou : <code>//script[@type="application/ld+json"]</code> (un objet JSON par article)',
  90. ),
  91. ),
  92. 'html_xpath' => array(
  93. '_' => 'HTML + XPath (Moissonnage du Web)',
  94. 'feed_title' => array(
  95. '_' => 'titre de flux',
  96. 'help' => 'Exemple : <code>//title</code> ou un texte statique : <code>"Mon flux personnalisé"</code>',
  97. ),
  98. 'help' => '<dfn><a href="https://www.w3.org/TR/xpath-10/" target="_blank">XPath 1.0</a></dfn> est un langage de requête pour les utilisateurs avancés, supporté par FreshRSS pour le moissonnage du Web (Web scraping).',
  99. 'item' => array(
  100. '_' => 'trouver les <strong>articles</strong><br /><small>(c’est le plus important)</small>',
  101. 'help' => 'Exemple : <code>//div[@class="article"]</code>',
  102. ),
  103. 'item_author' => array(
  104. '_' => 'auteur de l’article',
  105. 'help' => 'Peut aussi être une chaîne de texte statique. Exemple : <code>"Anonyme"</code>',
  106. ),
  107. 'item_categories' => 'catégories (tags) de l’article',
  108. 'item_content' => array(
  109. '_' => 'contenu de l’article',
  110. 'help' => 'Exemple pour prendre l’article complet : <code>.</code>',
  111. ),
  112. 'item_thumbnail' => array(
  113. '_' => 'miniature de l’article',
  114. 'help' => 'Exemple : <code>descendant::img/@src</code>',
  115. ),
  116. 'item_timeFormat' => array(
  117. '_' => 'Format personnalisé pour interpréter la date',
  118. 'help' => 'Optionnel. Un format supporté par <a href="https://php.net/datetime.createfromformat" target="_blank"><code>DateTime::createFromFormat()</code></a> comme <code>d-m-Y H:i:s</code>',
  119. ),
  120. 'item_timestamp' => array(
  121. '_' => 'date de l’article',
  122. 'help' => 'Le résultat sera passé à la fonction <a href="https://php.net/strtotime" target="_blank"><code>strtotime()</code></a>',
  123. ),
  124. 'item_title' => array(
  125. '_' => 'titre de l’article',
  126. 'help' => 'Utiliser en particulier l’<a href="https://developer.mozilla.org/docs/Web/XPath/Axes" target="_blank">axe XPath</a> <code>descendant::</code> comme <code>descendant::h2</code>',
  127. ),
  128. 'item_uid' => array(
  129. '_' => 'identifiant unique de l’article',
  130. 'help' => 'Optionnel. Exemple : <code>descendant::div/@data-uri</code>',
  131. ),
  132. 'item_uri' => array(
  133. '_' => 'lien (URL) de l’article',
  134. 'help' => 'Exemple : <code>descendant::a/@href</code>',
  135. ),
  136. 'relative' => 'XPath (relatif à l’article) pour :',
  137. 'xpath' => 'XPath pour :',
  138. ),
  139. 'json_dotnotation' => array(
  140. '_' => 'JSON (notation point)',
  141. 'feed_title' => array(
  142. '_' => 'titre de flux',
  143. 'help' => 'Exemple : <code>meta.title</code> ou un texte statique : <code>"Mon flux personnalisé"</code>',
  144. ),
  145. 'help' => 'La notation point pour JSON utilise le point comme séparateur objet, et des crochets pour un tableau : (ex : <code>data.items[0].title</code>)',
  146. 'item' => array(
  147. '_' => 'trouver les <strong>articles</strong><br /><small>(c’est le plus important)</small>',
  148. 'help' => 'Chemin vers le tableau contenant les articles, par exemple <code>$</code> ou <code>newsItems</code>',
  149. ),
  150. 'item_author' => 'auteur de l’article',
  151. 'item_categories' => 'catégories (tags) de l’article',
  152. 'item_content' => array(
  153. '_' => 'contenu de l’article',
  154. 'help' => 'Chemin JSON pour le contenu, par exemple <code>content</code>',
  155. ),
  156. 'item_thumbnail' => array(
  157. '_' => 'miniature de l’article',
  158. 'help' => 'Exemple : <code>image</code>',
  159. ),
  160. 'item_timeFormat' => array(
  161. '_' => 'Format personnalisé pour interpréter la date',
  162. 'help' => 'Optionnel. Un format supporté par <a href="https://php.net/datetime.createfromformat" target="_blank"><code>DateTime::createFromFormat()</code></a> comme <code>d-m-Y H:i:s</code>',
  163. ),
  164. 'item_timestamp' => array(
  165. '_' => 'date de l’article',
  166. 'help' => 'Le résultat sera passé à la fonction <a href="https://php.net/strtotime" target="_blank"><code>strtotime()</code></a>',
  167. ),
  168. 'item_title' => 'titre de l’article',
  169. 'item_uid' => 'identifiant unique de l’article',
  170. 'item_uri' => array(
  171. '_' => 'lien (URL) de l’article',
  172. 'help' => 'Exemple : <code>permalink</code>',
  173. ),
  174. 'json' => 'notation point pour :',
  175. 'relative' => 'notation point relative à l’article pour :',
  176. ),
  177. 'jsonfeed' => 'JSON Feed', // IGNORE
  178. 'rss' => 'RSS / Atom (par défaut)',
  179. 'xml_xpath' => 'XML + XPath', // IGNORE
  180. ),
  181. 'maintenance' => array(
  182. 'clear_cache' => 'Vider le cache',
  183. 'clear_cache_help' => 'Supprime le cache de ce flux.',
  184. 'reload_articles' => 'Recharger les articles',
  185. 'reload_articles_help' => 'Recharge cette quantité d’articles et récupère le contenu complet si un sélecteur est défini.',
  186. 'title' => 'Maintenance', // IGNORE
  187. ),
  188. 'max_http_redir' => 'Maximum de redirections HTTP',
  189. 'max_http_redir_help' => 'Mettre à 0 ou vide pour désactiver, -1 pour un nombre illimité de redirections',
  190. 'method' => array(
  191. '_' => 'Méthode HTTP',
  192. ),
  193. 'method_help' => 'Les données POST supportent automatiquement <code>application/x-www-form-urlencoded</code> et <code>application/json</code>',
  194. 'method_postparams' => 'Données pour POST',
  195. 'moved_category_deleted' => 'Lors de la suppression d’une catégorie, ses flux seront automatiquement classés dans <em>%s</em>.',
  196. 'mute' => array(
  197. '_' => 'désactivé',
  198. 'state_is_muted' => 'Ce flux est désactivé',
  199. ),
  200. 'no_selected' => 'Aucun flux sélectionné.',
  201. 'number_entries' => '%d articles', // IGNORE
  202. 'open_feed' => 'Ouvrir le flux %s',
  203. 'path_entries_conditions' => 'Conditions pour la récupération de contenu',
  204. 'priority' => array(
  205. '_' => 'Visibilité',
  206. 'archived' => 'Ne pas afficher (archivé)',
  207. 'category' => 'Afficher dans sa catégorie',
  208. 'important' => 'Afficher dans les flux importants',
  209. 'main_stream' => 'Afficher dans les flux principaux',
  210. ),
  211. 'proxy' => 'Utiliser un proxy pour télécharger ce flux',
  212. 'proxy_help' => 'Sélectionner un protocole (ex : SOCKS5) et entrer l’adresse du proxy (ex. : <kbd>127.0.0.1:1080</kbd> ou <kbd>utilisateur:mot-de-passe@127.0.0.1:1080</kbd>)',
  213. 'selector_preview' => array(
  214. 'show_raw' => 'Afficher le code source',
  215. 'show_rendered' => 'Afficher le contenu',
  216. ),
  217. 'show' => array(
  218. 'all' => 'Montrer tous les flux',
  219. 'error' => 'Montrer seulement les flux en erreur',
  220. ),
  221. 'showing' => array(
  222. 'error' => 'Montre seulement les flux en erreur',
  223. ),
  224. 'ssl_verify' => 'Vérification sécurité SSL',
  225. 'stats' => 'Statistiques',
  226. 'think_to_add' => 'Vous pouvez ajouter des flux.',
  227. 'timeout' => 'Délai d’attente en secondes',
  228. 'title' => 'Titre',
  229. 'title_add' => 'Ajouter un flux RSS',
  230. 'ttl' => 'Ne pas automatiquement rafraîchir plus souvent que',
  231. 'unicityCriteria' => array(
  232. '_' => 'Critère d’unicité des articles',
  233. 'forced' => '<span title="Bloque le critère d’unicité même en cas de doublons">forcé</span>',
  234. 'help' => 'Utile pour les flux invalides.<br />⚠️ Changer le critère peut créer des doublons.',
  235. 'id' => 'ID standard (défaut)',
  236. 'link' => 'Lien',
  237. 'sha1:link_published' => 'Lien + Date',
  238. 'sha1:link_published_title' => 'Lien + Date + Titre',
  239. 'sha1:link_published_title_content' => 'Lien + Date + Titre + Contenu',
  240. ),
  241. 'url' => 'URL du flux',
  242. 'useragent' => 'Sélectionner l’agent utilisateur pour télécharger ce flux',
  243. 'useragent_help' => 'Exemple : <kbd>Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:86.0)</kbd>',
  244. 'validator' => 'Vérifier la validité du flux',
  245. 'website' => 'URL du site',
  246. 'websub' => 'Notifications instantanée par WebSub',
  247. ),
  248. 'import_export' => array(
  249. 'export' => array(
  250. '_' => 'Exporter',
  251. 'sqlite' => 'Télécharger la base de donnée de l’utilisateur au format SQLite',
  252. ),
  253. 'export_labelled' => 'Exporter les articles étiquetés',
  254. 'export_opml' => 'Exporter la liste des flux (OPML)',
  255. 'export_starred' => 'Exporter les favoris',
  256. 'feed_list' => 'Liste des articles de %s',
  257. 'file_to_import' => 'Fichier à importer<br />(OPML, JSON ou ZIP)',
  258. 'file_to_import_no_zip' => 'Fichier à importer<br />(OPML ou JSON)',
  259. 'import' => 'Importer',
  260. 'starred_list' => 'Liste des articles favoris',
  261. 'title' => 'Importer / exporter',
  262. ),
  263. 'menu' => array(
  264. 'add' => 'Ajouter un flux/une catégorie',
  265. 'import_export' => 'Importer / exporter',
  266. 'label_management' => 'Gestion des étiquettes',
  267. 'stats' => array(
  268. 'idle' => 'Flux inactifs',
  269. 'main' => 'Statistiques principales',
  270. 'repartition' => 'Répartition des articles',
  271. ),
  272. 'subscription_management' => 'Gestion des abonnements',
  273. 'subscription_tools' => 'Outils d’abonnement',
  274. ),
  275. 'tag' => array(
  276. 'auto_label' => 'Ajoute l’étiquette aux nouveaux articles',
  277. 'name' => 'Nom',
  278. 'new_name' => 'Nouveau nom',
  279. 'old_name' => 'Ancien nom',
  280. ),
  281. 'title' => array(
  282. '_' => 'Gestion des abonnements',
  283. 'add' => 'Ajouter un flux/une catégorie',
  284. 'add_category' => 'Ajouter une catégorie',
  285. 'add_dynamic_opml' => 'Ajouter un OPML dynamique',
  286. 'add_feed' => 'Ajouter un flux',
  287. 'add_label' => 'Ajouter une étiquette',
  288. 'add_opml_category' => 'Nom de la catégorie OPML',
  289. 'delete_label' => 'Supprimer une étiquette',
  290. 'feed_management' => 'Gestion des flux RSS',
  291. 'rename_label' => 'Renommer une étiquette',
  292. 'subscription_tools' => 'Outils d’abonnement',
  293. ),
  294. );