Subversion Repositories eFlore/Applications.cel

Rev

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;
        }
}