Class LocaleUtils


  • public class LocaleUtils
    extends Object
    A set of methods for retrieving and converting locale specific strings and numbers.
    Author:
    Jive Software
    • Method Detail

      • localeCodeToLocale

        public static Locale localeCodeToLocale​(String localeCode)
        Converts a locale string like "en", "en_US" or "en_US_win" to a Java locale object. If the conversion fails, null is returned.
        Parameters:
        localeCode - the locale code for a Java locale. See the Locale class for more details.
        Returns:
        The Java Locale that matches the locale code, or null.
      • getTimeZoneList

        public static String[][] getTimeZoneList()
        Returns a list of all available time zone's as a String [][]. The first entry in each list item is the timeZoneID, and the second is the display name.

        The list of time zones attempts to be inclusive of all of the worlds zones while being as concise as possible. For "en" language locales the name is a friendly english name. For non-"en" language locales the standard JDK name is used for the given Locale. The GMT+/- time is also included for readability.

        Returns:
        a list of time zones, as a tuple of the zime zone ID, and its display name.
      • getTimeZoneName

        public static String getTimeZoneName​(String zoneID,
                                             Locale locale)
        Returns the display name for a time zone. The display name is the name specified by the Java TimeZone class for non-"en" locales or a friendly english name for "en", with the addition of the GMT offset for human readability.
        Parameters:
        zoneID - the time zone to get the name for.
        locale - the locale to use.
        Returns:
        the display name for the time zone.
      • getResourceBundle

        public static ResourceBundle getResourceBundle​(String baseName,
                                                       Locale locale)
        Returns the specified resource bundle, which is a properties file that aids in localization of skins. This method is handy since it uses the class loader that other Jive classes are loaded from (hence, it can load bundles that are stored in jive.jar).
        Parameters:
        baseName - the name of the resource bundle to load.
        locale - the desired Locale.
        Returns:
        the specified resource bundle, if it exists.
      • getLocalizedString

        public static String getLocalizedString​(String key)
        Returns an internationalized string loaded from a resource bundle. The locale used will be the locale specified by JiveGlobals.getLocale().
        Parameters:
        key - the key to use for retrieving the string from the appropriate resource bundle.
        Returns:
        the localized string.
      • getLocalizedString

        public static String getLocalizedString​(String key,
                                                Locale locale)
        Returns an internationalized string loaded from a resource bundle using the passed in Locale.
        Parameters:
        key - the key to use for retrieving the string from the appropriate resource bundle.
        locale - the locale to use for retrieving the appropriate locale-specific string.
        Returns:
        the localized string.
      • getLocalizedString

        public static String getLocalizedString​(String key,
                                                List<?> arguments)
        Returns an internationalized string loaded from a resource bundle using the locale specified by JiveGlobals.getLocale() substituting the passed in arguments. Substitution is handled using the MessageFormat class.
        Parameters:
        key - the key to use for retrieving the string from the appropriate resource bundle.
        arguments - a list of objects to use which are formatted, then inserted into the pattern at the appropriate places.
        Returns:
        the localized string.
      • getLocalizedString

        public static String getLocalizedString​(String key,
                                                String pluginName)
        Returns an internationalized string loaded from a resource bundle from the passed in plugin. If the plugin name is null, the key will be looked up using the standard resource bundle.
        Parameters:
        key - the key to use for retrieving the string from the appropriate resource bundle.
        pluginName - the name of the plugin to load the require resource bundle from.
        Returns:
        the localized string.
      • getLocalizedString

        public static String getLocalizedString​(String key,
                                                String pluginName,
                                                List arguments)
        Returns an internationalized string loaded from a resource bundle from the passed in plugin. If the plugin name is null, the key will be looked up using the standard resource bundle.
        Parameters:
        key - the key to use for retrieving the string from the appropriate resource bundle.
        pluginName - the name of the plugin to load the require resource bundle from.
        arguments - a list of objects to use which are formatted, then inserted into the pattern at the appropriate places.
        Returns:
        the localized string.
      • getLocalizedString

        public static String getLocalizedString​(String key,
                                                String pluginName,
                                                List<?> arguments,
                                                Locale locale,
                                                boolean fallback)
        Returns an internationalized string loaded from a resource bundle from the passed in plugin, using the passed in Locale. If the plugin name is null, the key will be looked up using the standard resource bundle. If the locale is null, the Jive Global locale will be used.
        Parameters:
        key - the key to use for retrieving the string from the appropriate resource bundle.
        pluginName - the name of the plugin to load the require resource bundle from.
        arguments - a list of objects to use which are formatted, then inserted into the pattern at the appropriate places.
        locale - the locale to use for retrieving the appropriate locale-specific string.
        fallback - if true, the global locale used by Openfire will be used if the requested locale is not available)
        Returns:
        the localized string.
      • getPluginResourceBundle

        public static ResourceBundle getPluginResourceBundle​(String pluginName)
                                                      throws Exception
        Retrieve the ResourceBundle that is used with this plugin.
        Parameters:
        pluginName - the name of the plugin.
        Returns:
        the ResourceBundle used with this plugin.
        Throws:
        Exception - thrown if an exception occurs.
      • getLocalizedString

        public static String getLocalizedString​(String key,
                                                Locale locale,
                                                List arguments,
                                                ResourceBundle bundle)
        Returns an internationalized string loaded from a resource bundle using the passed in Locale substituting the passed in arguments. Substitution is handled using the MessageFormat class.
        Parameters:
        key - the key to use for retrieving the string from the appropriate resource bundle.
        locale - the locale to use for retrieving the appropriate locale-specific string.
        arguments - a list of objects to use which are formatted, then inserted into the pattern at the appropriate places.
        bundle - The resource bundle from which to return the localized string.
        Returns:
        the localized string.
      • getLocalizedNumber

        public static String getLocalizedNumber​(long number)
        Returns an internationalized String representation of the number using the default locale.
        Parameters:
        number - the number to format.
        Returns:
        an internationalized String representation of the number.
      • getLocalizedNumber

        public static String getLocalizedNumber​(long number,
                                                Locale locale)
        Returns an internationalized String representation of the number using the specified locale.
        Parameters:
        number - the number to format.
        locale - the locale to use for formatting.
        Returns:
        an internationalized String representation of the number.
      • getLocalizedNumber

        public static String getLocalizedNumber​(double number)
        Returns an internationalized String representation of the number using the default locale.
        Parameters:
        number - the number to format.
        Returns:
        an internationalized String representation of the number.
      • getLocalizedNumber

        public static String getLocalizedNumber​(double number,
                                                Locale locale)
        Returns an internationalized String representation of the number using the specified locale.
        Parameters:
        number - the number to format.
        locale - the locale to use for formatting.
        Returns:
        an internationalized String representation of the number.