Directionality support/fr

La prise en charge des différentes directions d' (de gauche à droite, de droite à gauche) est un aspect important pour les logiciels multilingues. Depuis, la prise en charge a été considérablement améliorée.

Cette page donne quelques informations importantes, ainsi que des règles pour les développeurs et les administrateurs de wiki pour rendre une fonctionnalité ou une extension compatible avec l'interface écrite de droite à gauche et les différentes directions d'écriture en général.

Conseils aux utilisateurs
Voici quelques indications générales pour les utilisateurs avant d'aller plus en détails pour les développeurs :


 * La plupart des navigateurs prennent en charge le changement de direction des zones d'édition de texte brut, comme les boîtes de recherche d'articles, la modification de la syntaxe wiki, le résumé des modifications, etc... En fonction des navigateurs et des systèmes d'exploitation, vous pouvez utiliser Ctrl-Shift (Chrome et Internet Explorer sous Windows), Ctrl-Shift-X (Firefox), Option-Click-Changer la direction (Mac). Ceci doit vous permettre de saisir du texte dans une direction différente de celle habituellement utilisée par le site.
 * Lorsque vous saisissez du texte dans une langue qui a une direction différente de celle du site, ajoutez une balise  avec la langue concernée et les attributs   et  . Par exemple, lorsque vous saisissez du texte en anglais dans la Wikipédia en arabe, tapez   au début et  à la fin.
 * Si vous ne saisissez que quelques mots dans un paragraphe, incluez-les dans une balise avec les attributs   et   correspondants. (Beaucoup de wikis possèdent un modèle pour cela, tel que  ).
 * Pour séparer les nombres accolés à un mot pour des sens d'écriture différents, utilisez la chaîne RLM ou LRM. Beaucoup de wikis possèdent des modèles pour cela, par exemple dans la Wikipédia en hébreu,  dans la Wikipédia arabe,  dans la Wikipédia en persan, etc... Quand un modèle est disponible, il est généralement préférable de l'appeler plutôt que d'utiliser le caractère Unicode lui-même.

Vous pouvez rapporter dans Phabricator les bogues concernant la gestion du RTL pour n'importe quel projet lié à MediaWiki en utilisant la balise RTL.

ResourceLoader
Grâce à ResourceLoader qui inclut CSSJanus, le CSS est automatiquement permuté de droite à gauche quand la langue de l'utilisateur est RTL. C'est le fonctionnement par défaut depuis la version 1.18 (dans les versions précédentes, cela dépendait de la langue du contenu du wiki). Il n'existe que très peu de CSS qui dépendent réellement de la langue du contenu.


 * Attention : lorsque vous utilisez le mode debogue du ResourceLoader, le CSS peut s'afficher de manière incohérente comparé au mode production. Comme contournement temporaire, testez l'interface RTL en mode debug off (suivi tâche T29025.)

De quel type de langue parle-t-on ?
Article principal :


 * $wgLang - langue de l'utilisateur (et la direction correspondante)
 * $wgContLang - langue du contenu du site (et la direction correspondante) -> ici LTR
 * Titre->getPageLanguage - langue du contenu de la page (et la direction correspondante) -> par défaut il s'agit de la direction de la langue de contenu du site
 * Il existe quelques exceptions par défaut : voir ci-dessous
 * Il peut être initialisé par les extensions via le point d'entrée
 * Ceci positionne la table des matières (et d'autres choses telles que la grammaire, bien que n'étant pas prépondérantes dans la plupart des cas) pour cette langue. Pour ne faire que cela, utilisez
 * Pour les extensions qui doivent rester compatibles avec la version 1.17, vous pouvez utilisez wfUILang, néanmoins ceci casse la compatibilité avec la version 1.16 et antérieures. Ceci retourne $wgLang dans les versions 1.18 et plus récentes, et $wgContLang dans la version 1.17 (par défaut).

Éléments dépendants du type de langue
.
 * Les pages spéciales suivent la langue de l'utilisateur par défaut.
 * Le code source doit être en anglais (les pages CSS/JS sont initialisées à 'anglais' par défaut).
 * Les pages ayant des sous-pages traduites doivent suivre la langue de traduction (par exemple "Page" vaut wgContLang, "Page/he" vaut "he"). Ceci est le fonctionnement par défaut pour l'espace de noms MediaWiki.
 * Les boîtes de saisie et les zones de texte suivent par défaut, la direction du contenu.
 * Lorsque vous affichez un diff, il suit la langue de l'utilisateur, mais le texte effectif du diff est affiché dans la langue du contenu de la page.

Que dois-je ajouter dans le code source ?

 * Sur les pages spéciales, tout ce qui est différent de la langue de l'utilisateur doit avoir une balise.
 * Par exemple : SpecialRecentchanges->setTopText qui ajoute le message « recentchangestext » dans la langue du contenu wiki.
 * Tous ce qui est dans des espaces de noms personnalisés et qui contient du texte différent du contenu wiki par défaut, doit avoir une balise.
 * Quand le texte du diff n'est pas le même que la langue du contenu de la page, utilisez là où $diff est un objet DifferenceEngine.

Attributs lang/dir
Vous devriez utiliser le HTML :

mais quelques fois ceci est difficile dans les éléments générés dynamiquement et vous pourrez vous replier sur le CSS :

Contenu wiki
Vous pouvez utiliser les classes  et   pour utiliser les liens des sections de modification et les éléments ul/ol basés sur cette direction.


 * Par exemple :

Ceci est bien sûr utilisé pour le contenu des pages des articles.


 * Sur les pages de fichiers, il n'est seulement ajouté qu'autour du texte lui-même tandis que le reste de la page du fichier est de l'IHM personnalisée (historique du fichier, ...).
 * Sur les pages de catégories, il est ajouté de la même façon que sur les pages standard, mais le texte de la langue utilisateur est inclus dans un  avec les attributs   et   en fonction de la langue utilisateur.
 * Sur les pages spéciales, il n'est pas ajouté parce qu'elle sont presque toutes dans la langue de l'utilisateur. Un morceau de texte sur les pages spéciales peut être dans la langue de contenu, qui doit ensuite être embarquée dans la classe. Ceci est utilisé par exemple dans l'extension CodeReview pour le résumé du code et pour les commentaires du code, qui peuvent contenir des éléments ul/ol (texte wiki * et #) dans la langue du contenu du wiki et évidemment pas dans la langue de l'utilisateur en principe.

Il ne faut pas ajouter d'éléments d'IHM dans ces classes. Par exemple, les liens de catégorie et le formulaire de vérification FlaggedRevs sont dans #bodyContent mais en dehors de .mw-content-ltr/rtl.

Une nouvelle fonctionnalité est que ces classes peuvent être utilisées à l'intérieur de ces mêmes classes. Par exemple, .mw-content-rtl peut être utilisé dans un article LTR (mw-content-ltr). Ceci est utile pour les pages multilingues. Avant cela, on utilisait des bidouilles locales MediaWiki:Common.css pour afficher correctement, par exemple, des listes de puces dans du texte. C'est pourquoi vous devez utiliser  au lieu de   lorsque vous modifiez des pages wiki.

Voir aussi les IDs et les classes.

Classes de
La balise  possède une classe   ou   par défaut, correspondant à la langue de l'utilisateur. Vous ne devriez pas utiliser cela, car le CSS est automatiquement modifié en fonction de la langue utilisateur. La balise  implémente aussi les nouvelles (1.18) classes   et   qui suivent. Si elle est nécessaire, il est possible d'ajouter également « userlang-ltr/rtl » et/ou « pagelang-ltr/rtl ».

Directives "float" et "text-align"
Vous pouvez utiliser,  ,  ,   qui fournit les valeurs 'right' ou 'left' appropriées.

Vous pouvez utiliser le CSS  ou   qui permute la valeur ("left"/"right"), pour les langues d'interface orientées RTL.

Exemples
Special:AllMessages est une page spéciale, ce qui signifie qu'elle suit la direction de la langue utilisateur. Néanmoins, le message lui-même doit suivre la direction de la langue sélectionnée.


 * Special:Allmessages = anglais, LTR
 * Special:Allmessages/he = hébreu, RTL

Les cellules de la table hébergeant le contenu des messages ont les attributs  et.

L'extension, qui utilise l'accroche PageContentLanguage, initialise la bonne langue (et par conséquent sa direction) pour les pages traduites, voir par exemple Wikimedia_maintenance_notice/ar qui bénéficie de la classe mw-content-rtl sur un wiki LTR.

Wikis locaux
Les pages MediaWiki:Common.css et associées sont également inversées. Cela signifie que vous devez ajouter @noflip là où c'est nécessaire.

Voir T33923 : le CSS des sites ne doit pas être permuté par défaut.

Problèmes

 * La plupart des fonctionnalités et des extensions ont amélioré la prise en charge depuis environ la version 1.19, voir translatewiki:Project:Better directionality and i18n development pour cela.
 * Problèmes connus restants :
 * Les icônes de lien externe sont permutées en fonction de la direction de la langue de l'utilisateur (problème mineur)
 * - Utilisez  au lieu de , sinon la page spéciale renvoie
 * - des chatons alignés à gauche du fichier devraient être alignés à droite dans les wikis RTL (problème mineur)
 * OmegaWiki: a besoin d'une révision générale (les pages Expression et DefinedMeaning doivent suivre la direction de l'utilisateur) + 23035
 * Rechercher les rapports de bogue : https://bugzilla.wikimedia.org/buglist.cgi?quicksearch=rtl

Voir aussi

 * Meilleure prise en charge du sens d'écriture (diaporama de présentation 2011)
 * translatewiki:Project:Better directionality and i18n development (vers 2011) et beaucoup plus ancien BiDi workgroup
 * rtl.wtf - articles et exemples sur la manière de prendre en charge le sens de l'écriture en ligne
 * translatewiki:Project:Better directionality and i18n development (vers 2011) et beaucoup plus ancien BiDi workgroup
 * rtl.wtf - articles et exemples sur la manière de prendre en charge le sens de l'écriture en ligne
 * rtl.wtf - articles et exemples sur la manière de prendre en charge le sens de l'écriture en ligne
 * rtl.wtf - articles et exemples sur la manière de prendre en charge le sens de l'écriture en ligne
 * rtl.wtf - articles et exemples sur la manière de prendre en charge le sens de l'écriture en ligne
 * rtl.wtf - articles et exemples sur la manière de prendre en charge le sens de l'écriture en ligne