Rev 2615 | Blame | Last modification | View Log | RSS feed
package org.tela_botanica.client.i18n;
import org.tela_botanica.client.modeles.objets.Configuration;
import com.google.gwt.i18n.client.Dictionary;
import java.lang.Exception;
/**
* Gère l'internationalisation
*/
public class Msg {
public static final String MESSAGE_INEXISTANT = "hoho c'est la merde";
/** langue en cours */
protected static String langue;
/** langue par défaut */
protected static String langueDefaut;
/** langues disponibles */
protected static String languesDisponibles;
/**
* Initialisation - à appeler une fois avant tout utilisation
* @return true si tout s'est bien passé, false sinon
*/
public static boolean init() {
// lire la config pour obtenir les langues
languesDisponibles = Configuration.getLanguesDisponibles();
// lire la config et charger la langue par défaut
langueDefaut = Configuration.getLangueDefaut();
// si la langue par défaut n'existe pas, on arrête tout
return setLangue(langueDefaut);
}
/**
* Initialisation - raccourci pour initialiser avec une langue
* @param langue la langue à définir jusqu'à nouvel ordre
* @return true si tout s'est bien passé, false sinon
*/
public static boolean init(String langue) {
boolean ok = false;
if (init()) {
ok = setLangue(langue);
}
return ok;
}
/**
* [Re]définit la langue en cours
* @param langue
* @return true si la langue a été correctement définie, false
* sinon (si la langue n'est pas disponible)
*/
public static boolean setLangue(String langue) {
boolean ok = false;
// contrôle cracra
if (languesDisponibles.indexOf(langue) != -1) { // on peut désactiver une langue même si le dictionnaire existe
String nomDictionnaire = "messages_" + langue;
try {
Dictionary.getDictionary(nomDictionnaire);
Msg.langue = langue;
ok = true;
} catch (Exception e) {}
}
return ok;
}
/**
* Retourne la langue actuellement définie; si on a essayé de définir
* une langue qui n'est pas disponible, retournera la langue par défaut
*
* @return la langue actuellement définie
*/
public static String getLangue() {
return langue;
}
/**
* @return la langue par défaut, définie dans la configuration
*/
public static String getLangueDefaut() {
return langueDefaut;
}
/**
* @return les langues disponibles, définies dans la configuration
*/
public static String getLanguesDisponibles() {
return languesDisponibles;
}
/**
* Retourne un message dans la langue en cours
* @param cle
* @return
*/
public static String get(String cle) {
return get(cle, langue);
}
/**
* Retourne un message paramétré dans la langue en cours
* @param cle
* @param[] params
* @return
*/
public static String get(String cle, String[] params) {
return get(cle, langue, params);
}
/**
* Retourne un message dans la langue demandée; s'il n'est pas trouvé, le cherche
* dans la langue par défaut; en cas d'échec, retourne un terme générique d'avertissement
* @param cle l'identifiant du message demandé
* @param langue la langue dans laquelle on souhaite l'obtenir
* @return le message dans la langue en cours s'il existe, sinon le
* message dans la langue par défaut s'il existe, sinon la
* chaîne définie dans Msg.MESSAGE_INEXISTANT
*/
public static String get(String cle, String langue) {
String nomDictionnaire = "messages_" + langue;
String message;
try {
message = Dictionary.getDictionary(nomDictionnaire).get(cle);
} catch (Exception e) {
try {
message = Dictionary.getDictionary("messages_" + langueDefaut).get(cle);
} catch (Exception me) {
message = Msg.MESSAGE_INEXISTANT;
}
}
return message;
}
/**
* Retourne un message paramétré dans la langue demandée
* @param cle
* @param langue
* @param[] params
* @return
*/
public static String get(String cle, String langue, String[] params) {
String message = get(cle, langue);
for (int i = 0; i < params.length; i++) {
message = message.replace("{"+i+"}", params[i]);
}
return message;
}
}