Extension:UniversalLanguageSelector/fr

Le Sélecteur Universel de Langue (SUL) est un outil qui autorise les utilisateurs à sélectionner une langue et à configurer son support facilement. Là où il est utilisé, il embarque également les fonctions des extensions polices web et Narayam (les deux étant obsolètes et remplacées par le Sélecteur Universel de Langue). Voir le Selecteur Universel de Langue pour les informations de base et additionnelles.

Utilisation
Le but premier est d'autoriser les utilisateurs à choisir une langue et à configurer son support facilement.

L'extension fournit les fonctions suivantes:


 * 1) Manière souple et facile de sélectionner une langue à partir d'un grand ensemble de langues.
 * 2) La sélection peut être basée sur la région géographique où se fait la consultation ou les recherches.
 * 3) La recherche peut être basée sur le code de langue ISO, le nom de langue écrit dans l'interface de l'utilisateur actuel ou dans sa propre écriture (autonyme)
 * 4) La recherche inter-langues - rechercher des noms de langues en utilisant n'importe quelle écriture
 * 5) Autocomplétion des noms de langue
 * 6) Auto-correction des erreurs d'orthographe dans les chaînes cherchées
 * 7) Suggestion de langue par géolocalisation basée sur l'adresse IP
 * 8) Selection de langue basée sur le navigauteur de l'utilisateur ou la langue du système opérationnel
 * 9) Méthodes de saisie
 * Voir Help:Extension:UniversalLanguageSelector/Input methods pour les instructions complètes.
 * 1) Une collection de méthodes de saisie facilement sélectionnables, disponibles immédiatement dans chaque champ modifiable
 * 2) Fournit un ensemble vaste de méthodes de saisie pour une large gamme de langues
 * 3) * Une liste obsolète est disponible sur Extension:Narayam#Supported schemes
 * 4) Les préférences des méthodes de saisie par langue
 * 5) Les polices web
 * 6) Une grande collection de polices à choisir pour chaque langue à utiliser comme des polices incluses dans la page
 * 7) * Une liste obsolète est disponible sur Extension:WebFonts#Supported languages
 * 8) * Vous pouvez afficher toutes les polices incluses
 * 9) Préférences de police par langue



Ajouter des polices
Supporter davantages de langues n'est que la question de pouvoir inclure les polices correspondantes dans le code. Néanmoins, veuillez noter que nous ajouterons le support seulement pour les polices sous licence libre, par exemple les polices sous licence GNU GPL, SIL OFL, etc. Un exemple de répertoire de telles polices est Google Fonts (pas encore examiné/exploité complètement par les auteurs de cette extension); voir aussi la Bibliothèque des fontes libres.

D'abord, vous devez trouver ou produire une telle fonte libre (c'est la partie la plus importante et vous devez faire cela vous-même); ensuite, elle doit être convertie dans les formats nécessaires, qui sont eot, ttf, woff; finalment, vous pouvez faire une demande dans Phabricator pour que la police soit ajoutée à l'extension.

La préparation des fontes web ci-dessous explique comment convertir les polices: la connaissance de base des systèmes opératoires construits sur GNU/Linux est nécessaire; si vous avez des difficultés pour cela, vous pouvez sauter cette étape et demander à quelqu'un d'autre de la faire pour vous dans la même requête Phabricator (bien sûr cela ralentira le processus).

Preparer les polices web
Sfntly est nécessaire pour créer des polices web (en mode ligne de commande seulement).

Une fois installé, les commandes suivantes peuvent être utilisées.

Création de .woff:

Création de .woff2:

Utilisez https://github.com/google/woff2 pour générer woff2 à partir du ttf. Ceci va produire un fichier woff2 compressé. Les navigateurs modernes supportent ce format.

Créer un fichier font.ini. Voici un exemple:

Un astérisque après un code de langue indique que cette police sera la police par défaut pour cette langue. Si vous voulez simplement avoir la possibilité d'utiliser cette police pour cette langue, omettez l'astérisque.

Après avoir créé les fichiers, faites ce qui suit:
 * 1) Créez un répertoire pour la police sous data/fontrepo/fonts.
 * 2) Placez-y les fichiers ttf, woff, eot et font.ini et ajoutez-les au dépôt d'origine (git add).
 * 3) Allez dans data/fontrepo/scripts et exécutez.
 * 4) Validez les modifications dans le dépôt   et envoyez-les conformément au flux de travail de Git.

Ajouter le support pour un nouveau mappage des touches (méthode de saisie)
Suivez le instructions on the jquery.ime github wiki, mais envoyez les demandes vers le produit Phabricator Wikimedia-extensions-UniversalLanguageSelector.

Mettre à jour LanguageNameIndex
Pour faire des recherches inter-langues, rechercher des autonymes, les données de langue doivent être initialisées. SLU est livré avec un index de nom de langues pré-initialisé (data/langnames.ser). Dans le cas où vous voudriez le mettre à jour, installez Extension:CLDR et entrez les données avec la commande suivante.

php UniversalLanguageSelector/data/LanguageNameIndexer.php et vérifiez que le fichier langnames.ser est bien généré dans le répertoire ULS/data/.

Configuration
The following variables are created automatically during initialization and can be used from JavaScript using mw.config.get( NAME ):
 * - an associative array where the keys are language codes and the values are language names in English.
 * - an array of language codes from the user's Accept-Language value. These are the languages selected in the user's browser preferences.

For serving fonts, you might want to add the following mime types to your webserver if not already there. This guide might help.  application/x-font-woff .woff application/vnd.ms-fontobject .eot application/x-font-ttf .ttf The following variables can also be configured:
 * - ULS can use geolocation services to suggest languages based on the country the user is visiting from. Setting this to false will prevent builtin geolocation from being used. You can provide your own geolocation by setting window.Geo to object which has key 'country_code' or 'country'. If set to true, it will query Wikimedia's geoip service. The service should return jsonp that uses the supplied callback parameter. Defaults to http://freegeoip.net/json/ and expects the same format.
 * - Enable language selection, compact language links, input methods and webfonts for everyone, unless the behavior is overridden by the configuration variables below.  Even if false the classes and resource loader modules are registered for the use of other extensions. Language changing via cookie or setlang query parameter is not possible.
 * - Allow anonymous users to change language with cookie and setlang query param. Do not use if you are caching anonymous page views without taking cookies into account. Does not have any effect if either of   or $wgULSEnableAnon is set to false.
 * - Disable the input methods feature for all users by default. Can still be enabled manually by the user.
 * - The location and the form of the language selection trigger. The possible values are: : as a link near the username or the log in link in the personal toolbar (default).  : as an icon near the header of the list of interlanguage links in the sidebar.
 * - Array of jQuery selectors of elements on which IME must not be enabled. eg:

Position du sélecteur SUL

 * - The location and the form of the language selection trigger. The possible values are: : as a link near the username or the log in link in the personal toolbar (default).  : as an icon near the header of the list of interlanguage links in the sidebar.

Il est aussi possible d'avoir le déclencheur SUL n'importe où sur l'écran. Un élément avec  agira comme déclencheur SUL.

Réécraser les fontes par défaut
ULS has a large font repository to serve as webfonts. Sometimes there are multiple fonts for a language and there is a default font for each language/script. The order of fonts or default font can be overridden as follows using global scripts (MediaWiki:Common.js) or personal scripts (Special:MyPage/common.js):

Ici, languageCode doit être un code de langue valide (par exemple: en, hi, nl). FontA et FontB sont des polices disponibles dans le dépôt font. Dans l'exemple ci-dessus pour languageCode, nous assignons une police disponible sur l'ordinateur local en tant que police par défaut; c'est à dire pas de police web par défaut.

Configuration en cache
Pour s'assurer que les fichiers des polices web sont bien dans le cache des machines client, les types des fichiers de police doivent être ajoutés à la configuration du serveur web. Pour Apache2 cela consiste à :
 * Ajouter les extensions des fichiers de police à l'expression régulière FileTimes dans FilesMatch pour le répertoire concerné; exemple:
 * Ajouter les valeurs ExpiresByType aux types MIME concernés, de la même manière que pour les types de MIME des images.
 * Notez qu'il n'y a pas de type MIME standard pour les TTF. On utilise application/x-font-ttf pour Wikimedia.
 * Ajouter les types MIME :

 AddType application/x-woff .woff AddType application/vnd.ms-fontobject .eot AddType application/x-font-ttf .ttf

Pour un exemple complet, voir la caching configuration update done for the Wikimedia cluster.

Traduction de page
UniversalLanguageSelector is one of the dependencies of the Translate extension, which uses it for several language selection features. One of it is the MyLanguage system for links, which depends on the interface language of the user, but more can be configured: see Page translation feature.

Utilisation des Webfonts
User can choose webfonts for a language from the Language settings -> Display settings. By default, the first font in that menu will be applied to the wiki. A user can change the font and it will be remembered across the pages. Optionally user can disable the font embedding too by selecting system font.

If the font is available in user's local system, font will not be downloaded from the mediawiki server. It will be taken from the user's computer. Otherwise, font will be downloaded from the server only once. ie when the user selects the font first time. Next time onwards, font will be taken from the local cache.

En spécifiant la famille de polices
Inside the wiki text YourText, webfonts extension will check whether the font is available with the extension, if so it will download it to the client. So the reader will not face any difficulty in reading the text even if the font specified is not available in their computer.

En spécifiant la langue
Inside the wiki text YourText, webfonts extension will check whether any font is available for the given language with the extension, if so it will download it to the client. So the reader will not face any difficulty in reading the text even if the font specified is not available in their computer. If there are multiple fonts for the language, the default font will be used. If default font is not preferred, use the font-family approach to specify the font. If the tag has both lang and font-family definitions, font-family get precedence.

Exemple:

𒄖𒉈𒅁𒌨𒅎

fournit le texte présenté en cunéiforme en utilisant la police Akkadian

𒄖𒉈𒅁𒌨𒅎

Voir aussi

 * Sélecteur de Langue Universel
 * Sélecteur de Langue Universel/Framework d'architecture des interactions
 * Sélecteur de Langue Universel/Architecture technique
 * Détails techniques des fonctions des polices web du Sélecteur Universel de Langue