Une page d’accueil dans la bonne langue pour chaque visiteur

Avec la généralisation des problématiques de gestion de contenus multi langues, il devient difficile de réussir à proposer aux visiteurs un contenu cohérent (pour eux) et susceptible de les intéresser.

La première chose à faire lorsque l’on dispose d’un contenu en plusieurs langues est tant que possible de proposer à chaque nouveau visiteur la version la plus appropriée.

En général, si je suis un utilisateur français et que j’arrive
sur un site qui dispose de plusieurs versions linguistiques, dont une française, je serais heureux qu’on me propose celle-ci par défaut.

La méthode proposée ici s’applique bien sûr dans les grandes lignes à tout type de site, et donc en particulier aux sites gérés avec SPIP.

Un mécanisme éprouvé

Pour présenter la solution que je propose, je m’appuie sur une expérience concrête que je mène depuis des années pour mon site phpHeaven.

phpHeaven en anglais
phpHeaven en français

Voici les quelques règles qui y sont appliquées pour optimiser la satisfaction du visiteur :

  1. Un utilisateur dont le navigateur est configuré avec le français comme
    langue préférée arrive pour la première fois sur phpHeaven, il arrive
    directement sur la version française du site.
  2. Un utilisateur dont le navigateur est configuré avec l’anglais comme
    langue préférée arrive directement sur la version anglaise du site.
  3. Un utilisateur dont le navigateur est configuré avec l’allemand comme
    langue préférée et l’anglais comme seconde langue arrive directement
    sur la version anglaise du site.
  4. Un utilisateur qui n’a aucune configuration de langue mais a installé
    une version française de IE arrive directement sur la version
    française.
  5. Une fois sur le site, a tout moment, il est possible de passer d’une version à une autre.
  6. Un utilisateur qui autorise les cookies aura par défaut la version
    qu’il a consulté la dernière fois qu’il est venu, quelle que soit sa
    configuration de navigateur.

A propos de ce dernier point, en voici la logique : mes browsers sont configurés avec l’anglais comme langue principale et le français comme seconde langue. La plupart des sites multilingues sont anglophones, et les versions traduites qu’ils proposent sont souvent déplorables, donc je préfère la version d’origine. Par contre, sur mon site bilingue phpHeaven, je consulte plutôt la partie francophone, grace à un cookie placé par phpLang.

Surtout ne pas réinventer la roue

En fait, c’est historiquement le système que j’ai développé pour le
site phpHeaven, que j’ai ensuite diffusé sous le nom phpLang, puis
appliqué dans phpMyChat, et qui a été appliqué par un des développeurs
de ce dernier, Loïc Chapeau, dans phpMyAdmin.

Tant d’utilisations qui font que ce tout petit script est largement éprouvé fonctionnellement et techniquement, et n’est donc pas à réinventer.

D’accord, mais comment ça marche ?

Entrons enfin dans le vif du sujet, avec l’adaptation faite pour gérer le contenu bilingue (Français et Anglais) du SPIP de phpHeaven.

Sur phpHeaven, j’ai donc mon script index.php qui fait juste appel à phpLang :

index.php

<?php
require_once 'phpLang.inc.php';
?>

phpLang s’occupe alors de détecter lequel de index.fr.php et index.en.php est le plus approprié pour l’utilisateur, et en fait l’inclusion.

index.en.php redirige en fait vers en.html qui est intercepté par une rewrite rule Apache pour servir finalement secteur.php3?id_rubrique=1, et de même avec la version française :

index.en.php

<?php
header('Location: http://'.$_SERVER['HTTP_HOST'].'/en.html');
?>

httpd.conf ou .htaccess

RewriteRule ^(.*)en.html$ $1secteur.php3?id_rubrique=1 [QSA]
RewriteRule ^(.*)fr.html$ $1secteur.php3?id_rubrique=2 [QSA]

J’ai ainsi un secteur d’identifiant 1 avec les contenus en anglais et un secteur d’identifiant 2 avec les contenus en français.

Il n’y a que très peu de textes d’interface en dehors des contenus d’articles, donc je fais la différence entre anglais et français directement dans les squelettes via du PHP qui teste la valeur de #ID_SECTEUR.

Voici par exemple comment afficher différemment une date selon la langue :

<?php
if (#ID_SECTEUR == 1) {
	echo '[(#DATE|mois)]/[(#DATE|jour)]/[(#DATE|annee)]';
} else {
	echo '[(#DATE|jour)]/[(#DATE|mois)]/[(#DATE|annee)]';
}
?>

OK, ça marche, mais maintenant je voudrais bien avoir de jolis drapeaux pour changer de langue ...

Pour gérer l’affichage des drapeaux de la langue alternative, et potentiellement de plusieurs langues alternatives, de simples boucles suffisent si l’on applique les principes suivants :

-  le code de langue est indiqué dans le descriptif du secteur
-  le nom de la langue est indiqué dans le texte du secteur
-  le drapeau de la langue est mis en logo du secteur

Voici ainsi les boucles à utiliser pour afficher les drapeaux de sélection de langue(s) alternative(s) :

<BOUCLE_cette_langue(RUBRIQUES) {id_parent=0} {id_secteur} {doublons}></BOUCLE_cette_langue>
<BOUCLE_autres_langues(RUBRIQUES) {id_parent=0} {doublons}>
  <a href="/index.php?phpLang=#DESCRIPTIF">
  <img src="IMG/[(#LOGO_RUBRIQUE|fichier)]" align="absmiddle" border="0" /></a>
  <a href="/index.php?phpLang=#DESCRIPTIF">#TEXTE</a>
</BOUCLE_autres_langues>

Ces boucles doivent être placées au sein de la boucle principale du squelette, puisqu’elles utilisent l’identifiant du secteur courant pour déterminer la langue courante.

Notez que pour afficher tous les drapeaux, y compris celui de la langue courante, il suffit de supprimer la première boucle dont l’objectif unique est en effet de supprimer cette langue courante.

Discussion

7 discussions

  • PhpHeaven n’étant plus en ligne, impossible de consulter le code source :(

    Répondre à ce message

  • Bonjour,

    ceci est une très vieille contrib, mais le plugin est quand même marqué fonctionnel pour spip2. (Je me suis dis que ça dois être un tout petit plugin tout simple mais tellement indispensable pour des sites multilingus !!) Et il est toujours en test.. il va probablement le rester ?

    Là j’ai un problème de compatibilité avec spip-listes, il y a un erreur sur le sommaire dès que j’active spip-liste :

    Fatal error : Call to undefined function spip_query_db() in /mon_chemin/mon_site_spip/plugins/spip-listes_1_9_3/inc/spiplistes_api_abstract_sql.php(59) : eval()’d code on line 2

    J’ai déjà eu ce même erreur dans d’autres situations, mais je ne me rappelle plus quand exactement (vais faire plus d’attention la prochaine fois) mais en tout cas toujours par rapport au plugin langues_préférés.

    Quelqu’un sais par où chercher le problème ou encore mieux : comment le résoudre ?

    merci d’avance
    joz

    Répondre à ce message

  • DeathMatser9

    Salut,

    Je veux faire un site où le sommaire affiche des bouts d’articles en français, anglais et arabe. pour le français et l’anglais l’affichage se passe sans problème. Par contre pour l’arabe les textes sont tous alignés à gauche au lieu que ça soit à droite. L’option internationalisation de SPIP m’a permis de résoudre ce problème pour les rubriques et les articles, mais pas pour le sommaire.

    Comment faire :’( ?

    Répondre à ce message

  • 3

    J’ai fait une autre contrib qui propose une autre solution à la même problématique, en utilisant la nouvelle balise #LANG de la 1.7. Les fonctionnalités ne sont pas exactement les mêmes :
    -  elle est un peu plus générale, car une seule boucle résoud toutes les langues (après, tout est géré dans l’espace privé),
    -  elle ne requiert pas d’avoir accès aux Rewrite rules d’Apache (je ne sais pas si beaucoup d’hébergeurs les autorisent dans le .htaccess)
    -  mais l’utilisation de phpLang dans celle ci-dessus a un avantage fonctionnel indéniable : la « mémoire » du choix de l’utilisatuer avec des cookies.

    Ce serait bien de réfléchir à un mix des deux.

    • Je présente ici la solution utilisée sur phpHeaven avec des rewrite rules, mais cela n’est pas du tout nécessaire !

    • Laurent Laville

      Pour toutes celles et ceux qui revaient d’un mixe des deux solutions.

      Venez lire mon article sur la page d’accueil multi-langues

      J’espère que Nicolas ne m’en voudra pas d’avoir repris une grande partie de son article ;-)
      Mais comme je le dis, il faudrait être fou pour réinventer ce que d’autres avant nous ont très bien fait !

    • Nicolas Hoizey

      J’espère que Nicolas ne m’en voudra pas d’avoir repris une grande partie de son article Mais comme je le dis, il faudrait être fou pour réinventer ce que d’autres avant nous ont très bien fait !

      Pas de problème, cela ne me gêne pas puisque tu cites de toute façon mon article.

      Par contre, je pense que ta solution est moins riche que l’utilisation de phpLang telle que je la présente au niveau de la détermination de la langue favorite de l’utilisateur, cf la doc de phpLang.

      Le mieux aurait sans doute été que j’écrive mon article sans la particularité des rewrite rules de phpHeaven, peut-être le ferais-je un jour ...

    Répondre à ce message

  • 1

    à l’aube de l’arrivée de la 1.7 de SPIP qui intègre en natif pas mal de choses concernant le multilinguisme, est-il envisagé de mettre à jour cet article (ou d’en faire un autre) pour préciser comment utiliser ce script avec une version 1.7 ?

    • En fait l’arrivée de la 1.7 ne change pas grand chose à la contrib ci-dessus : SPIP 1.7 apporte la notion de langues d’articles et de rubriques (et tout le traitement de la typographie qui va avec, y compris les langues de droite à gauche), les traductions d’articles, le multilingüisme des squelettes, etc.

      Mais, comme d’habitude, le comportement du site est à construire par le webmeste. Donc cette contrib garde toute sa pertinence, sans modif particulière.

    Répondre à ce message

  • 1
    vincent bray

    Bonjour,
    Merci pour ces précisions que personnellement j’attendais avec impatience.
    Où peut-on trouver le fichier phplang.inc.php spécifique à cette approche car d’après mes souvenirs de phplang, il y avait plusieurs possibilités de portage sur le fichier index.
    La source de l’ensemble des éléments serait évidemement un plus par rapport à l’article.
    Merci dorénavant pour cette contribution,
    Vincent

    Répondre à ce message

  • 1

    est-il prévu une intégration à la prochaine version de spip ?
    et si oui est-ce bien utile dans ce cas d’utiliser cette contrib ?

    si non, pourquoi ? vu la pertinence d’un tel outil ?

    • est-il prévu une intégration à la prochaine version de spip ?
      peut être, il faut poser la question sur la liste spip-dev...

      et si oui est-ce bien utile dans ce cas d’utiliser cette contrib ?
      en attendant si ça peut servir a qqn c’est utile

      si non, pourquoi ? vu la pertinence d’un tel outil ?
      ... spip-contrib ce n’est pas la liste des dévellopeurs...

      mais ce genre de message peut les réveiller ;-)

    Répondre à ce message

Ajouter un commentaire

Avant de faire part d’un problème sur un plugin X, merci de lire ce qui suit :

  • Désactiver tous les plugins que vous ne voulez pas tester afin de vous assurer que le bug vient bien du plugin X. Cela vous évitera d’écrire sur le forum d’une contribution qui n’est finalement pas en cause.
  • Cherchez et notez les numéros de version de tout ce qui est en place au moment du test :
    • version de SPIP, en bas de la partie privée
    • version du plugin testé et des éventuels plugins nécessités
    • version de PHP (exec=info en partie privée)
    • version de MySQL / SQLite
  • Si votre problème concerne la partie publique de votre site, donnez une URL où le bug est visible, pour que les gens puissent voir par eux-mêmes.
  • En cas de page blanche, merci d’activer l’affichage des erreurs, et d’indiquer ensuite l’erreur qui apparaît.

Merci d’avance pour les personnes qui vous aideront !

Par ailleurs, n’oubliez pas que les contributeurs et contributrices ont une vie en dehors de SPIP.

Qui êtes-vous ?
[Se connecter]

Pour afficher votre trombine avec votre message, enregistrez-la d’abord sur gravatar.com (gratuit et indolore) et n’oubliez pas d’indiquer votre adresse e-mail ici.

Ajoutez votre commentaire ici

Ce champ accepte les raccourcis SPIP {{gras}} {italique} -*liste [texte->url] <quote> <code> et le code HTML <q> <del> <ins>. Pour créer des paragraphes, laissez simplement des lignes vides.

Ajouter un document

Suivre les commentaires : RSS 2.0 | Atom