Et pourquoi pas Twig ?
Mon choix s’est d’abord porté sur Twig, qui existe en autonome en principe.
J’ai dû m’en détourner pour les raisons suivantes :
-
La toute dernière version (3.x) ne supporte plus l’extensions d’internalisation mais requiert
symfony/twig-bridge
pour le tagtrans
. Or,symfony/twig-bridge
. Il n’y a pas de documentation pour l’intégration dans un projet sans Symfony -
Ces extensions d’internationalisation reposent sur
gettext
.gettext
est une solution très préformante, cependant :-
Il n’y a pas d’outil gratuit qui permette une extraction des chaînes de caractères :
-
Poedit est certainement une très bonne solution mais l’extraction des chaînes d’un fichier Twig requiert la licence pro.
-
Toute autre solution est vouée à générée les pages de Twig en fichier PHP et utiliser
xgettext
. Malheureusement, on perd le fichier d’origine.
-
-
Les fichiers de traduction sont mis en cache par le serveur. La mise à jour d’un fichier compilé (i.e.
.mo
) peut requérir un redémarrage. -
Le comportement est différent entre Windows et Linux. Par exemple, Windows ne définit la constante
LC_MESSAGES
, ce qui impose de forcer la locale pourLC_ALL
ce qui peut avoir des conséquences importantes (dans la gestion des nombres, etc.). -
Il faut que la locale soit présente sur le serveur, ce qui est rédhibitoire pour un serveur partagé.
-
Le sauveur ?
Pour toute ces raisons, je me suis donc intéressé au projet BladeOne, une implémentation autonome et légère de Blade. Elle supporte un module d’internationalisation intégré au moteur : BladeOneLang.
Il est clair que la gestion des traductions ne pourrait convenir à un projet d’envergure mais pour un projet sans Framework comme le mien, c’est parfait !
Installation
L’installation se fait le plus simplement du monde grâce à composer
:
composer require eftec/bladeone
Il existe d’autres méthodes documentées dans le README.
Il faut ensuite prévoir la création de 3 répertoires :
cache
-
Pour le cache
views
-
Pour les vues
Utilisation
Cet exemple ultrasimple va se décomposer en 3 fichiers :
-
La vue
-
La traduction
-
Le fichier PHP exécuté
Commençons par la vue. BladeOneLang définit 3 méthodes pour aider à la traduction :
- @_e
-
Va rechercher la chaîne à partir de la clé
- @_ef
-
Va permettre d’avoir des paramètres
- @_n
-
Va permettre de mettre au pluriel
L’exemple ci-dessous est un exemple de remplacement :
<h1>Translation</h1>
Hat:<br>
@_e('Hat')<br><br>
<hr>
Trust this site always :<br>
@_e('Trust this site always')<br><br>
<hr>
'%s is a nice cat' with '{{$variable1}}' :<br>
@_ef('%s is a nice cat', $variable1)<br><br>
La traduction se fait simplement dans un tableau associatif. Le tableau statique BladeOne::$dictionary
sera utilisé pour la traduction :
<?php
use eftec\bladeone\BladeOne;
BladeOne::$dictionary=array(
'Hat'=>'Chapeau',
'Cat'=>'Chat',
'%s is a nice cat'=>'%s est un bon chat',
"Trust this site always" => "Toujours faire confiance à ce site",
"Deny" => "Refuser"
);
Finalement, le bout de code d’exécution :
<?php
require "vendor/autoload.php";
Use eftec\bladeone\BladeOne;
$views = __DIR__ . '/views';
$cache = __DIR__ . '/cache';
$blade = new BladeOne($views,$cache,BladeOne::MODE_AUTO); (1)
$lang='fr'; // try es,jp or fr
include './locales/'.$lang.'.php'; (2)
$blade->missingLog='./missingkey.txt'; // (optional) if a traduction is missing the it will be saved here.
echo $blade->run("translation",array("variable1"=>"value1")); (3)
1 | Initialisation du moteur avec les répertoires de cache et de vue. |
2 | Chargement du dictionnaire (statique) pour les traductions |
3 | Génération du contenu à partir de la vue |
Un petit coup de php -S localhost:8000
, on saute sur http://localhost:8000/translation.php et voilà :
Conclusion
BladeOne n’est probablement pas le projet du siècle mais propose une réponse simple et élégante pour celui ou celle qui ne veut pas s’imposer un framework complet mais souhaite tout de même séparer la vue du reste de l’application tout en conservant des capacités d’internationalisation.
Ce projet offre des avantages comme :
-
L’indépendance par rapport aux locales du serveur
-
L’indépendance par rapport au système d’exploitation du serveur
-
La rapidité et flexibilité de Blade
A conserver en tête donc pour des petits projets requérant de l’internationalisation.