blob: 5763b4ed7a6e4a1f56281d8ef0e3896a796bad5f [file] [log] [blame]
// Copyright 2006 The Closure Library Authors. All Rights Reserved.
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS-IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
/**
* @fileoverview Functions for dealing with Date formatting & Parsing,
* County and language name, TimeZone list.
* @suppress {deprecated} Use goog.i18n instead.
*/
/**
* Namespace for locale related functions.
*/
goog.provide('goog.locale');
goog.require('goog.locale.nativeNameConstants');
/**
* Set currnet locale to the specified one.
* @param {string} localeName Locale name string. We are following the usage
* in CLDR, but can make a few compromise for existing name compatibility.
*/
goog.locale.setLocale = function(localeName) {
// it is common to see people use '-' as locale part separator, normalize it.
localeName = localeName.replace(/-/g, '_');
goog.locale.activeLocale_ = localeName;
};
/**
* Retrieve the current locale
* @return {string} Current locale name string.
* @deprecated Use goog.LOCALE and goog.i18n instead.
*/
goog.locale.getLocale = function() {
if (!goog.locale.activeLocale_) {
goog.locale.activeLocale_ = 'en';
}
return goog.locale.activeLocale_;
};
// Couple of constants to represent predefined Date/Time format type.
/**
* Enum of resources that can be registered.
* @enum {string}
*/
goog.locale.Resource = {
DATE_TIME_CONSTANTS: 'DateTimeConstants',
NUMBER_FORMAT_CONSTANTS: 'NumberFormatConstants',
TIME_ZONE_CONSTANTS: 'TimeZoneConstants',
LOCAL_NAME_CONSTANTS: 'LocaleNameConstants',
TIME_ZONE_SELECTED_IDS: 'TimeZoneSelectedIds',
TIME_ZONE_SELECTED_SHORT_NAMES: 'TimeZoneSelectedShortNames',
TIME_ZONE_SELECTED_LONG_NAMES: 'TimeZoneSelectedLongNames',
TIME_ZONE_ALL_LONG_NAMES: 'TimeZoneAllLongNames'
};
// BCP 47 language code:
//
// LanguageCode := LanguageSubtag
// ("-" ScriptSubtag)?
// ("-" RegionSubtag)?
// ("-" VariantSubtag)?
// ("@" Keyword "=" Value ("," Keyword "=" Value)* )?
//
// e.g. en-Latn-GB
//
// NOTICE:
// No special format checking is performed. If you pass a none valid
// language code as parameter to the following functions,
// you might get an unexpected result.
/**
* Returns the language-subtag of the given language code.
*
* @param {string} languageCode Language code to extract language subtag from.
* @return {string} Language subtag (in lowercase).
*/
goog.locale.getLanguageSubTag = function(languageCode) {
var result = languageCode.match(/^\w{2,3}([-_]|$)/);
return result ? result[0].replace(/[_-]/g, '') : '';
};
/**
* Returns the region-sub-tag of the given language code.
*
* @param {string} languageCode Language code to extract region subtag from.
* @return {string} Region sub-tag (in uppercase).
*/
goog.locale.getRegionSubTag = function(languageCode) {
var result = languageCode.match(/[-_]([a-zA-Z]{2}|\d{3})([-_]|$)/);
return result ? result[0].replace(/[_-]/g, '') : '';
};
/**
* Returns the script subtag of the locale with the first alphabet in uppercase
* and the rest 3 characters in lower case.
*
* @param {string} languageCode Language Code to extract script subtag from.
* @return {string} Script subtag.
*/
goog.locale.getScriptSubTag = function(languageCode) {
var result = languageCode.split(/[-_]/g);
return result.length > 1 && result[1].match(/^[a-zA-Z]{4}$/) ?
result[1] : '';
};
/**
* Returns the variant-sub-tag of the given language code.
*
* @param {string} languageCode Language code to extract variant subtag from.
* @return {string} Variant sub-tag.
*/
goog.locale.getVariantSubTag = function(languageCode) {
var result = languageCode.match(/[-_]([a-z]{2,})/);
return result ? result[1] : '';
};
/**
* Returns the country name of the provided language code in its native
* language.
*
* This method depends on goog.locale.nativeNameConstants available from
* nativenameconstants.js. User of this method has to add dependency to this.
*
* @param {string} countryCode Code to lookup the country name for.
*
* @return {string} Country name for the provided language code.
*/
goog.locale.getNativeCountryName = function(countryCode) {
var key = goog.locale.getLanguageSubTag(countryCode) + '_' +
goog.locale.getRegionSubTag(countryCode);
return key in goog.locale.nativeNameConstants['COUNTRY'] ?
goog.locale.nativeNameConstants['COUNTRY'][key] : countryCode;
};
/**
* Returns the localized country name for the provided language code in the
* current or provided locale symbols set.
*
* This method depends on goog.locale.LocaleNameConstants__<locale> available
* from http://go/js_locale_data. User of this method has to add dependency to
* this.
*
* @param {string} languageCode Language code to lookup the country name for.
* @param {Object=} opt_localeSymbols If omitted the current locale symbol
* set is used.
*
* @return {string} Localized country name.
*/
goog.locale.getLocalizedCountryName = function(languageCode,
opt_localeSymbols) {
if (!opt_localeSymbols) {
opt_localeSymbols = goog.locale.getResource('LocaleNameConstants',
goog.locale.getLocale());
}
var code = goog.locale.getRegionSubTag(languageCode);
return code in opt_localeSymbols['COUNTRY'] ?
opt_localeSymbols['COUNTRY'][code] : languageCode;
};
/**
* Returns the language name of the provided language code in its native
* language.
*
* This method depends on goog.locale.nativeNameConstants available from
* nativenameconstants.js. User of this method has to add dependency to this.
*
* @param {string} languageCode Language code to lookup the language name for.
*
* @return {string} Language name for the provided language code.
*/
goog.locale.getNativeLanguageName = function(languageCode) {
if (languageCode in goog.locale.nativeNameConstants['LANGUAGE'])
return goog.locale.nativeNameConstants['LANGUAGE'][languageCode];
var code = goog.locale.getLanguageSubTag(languageCode);
return code in goog.locale.nativeNameConstants['LANGUAGE'] ?
goog.locale.nativeNameConstants['LANGUAGE'][code] : languageCode;
};
/**
* Returns the localized language name for the provided language code in
* the current or provided locale symbols set.
*
* This method depends on goog.locale.LocaleNameConstants__<locale> available
* from http://go/js_locale_data. User of this method has to add dependency to
* this.
*
* @param {string} languageCode Language code to lookup the language name for.
* @param {Object=} opt_localeSymbols locale symbol set if given.
*
* @return {string} Localized language name of the provided language code.
*/
goog.locale.getLocalizedLanguageName = function(languageCode,
opt_localeSymbols) {
if (!opt_localeSymbols) {
opt_localeSymbols = goog.locale.getResource('LocaleNameConstants',
goog.locale.getLocale());
}
if (languageCode in opt_localeSymbols['LANGUAGE'])
return opt_localeSymbols['LANGUAGE'][languageCode];
var code = goog.locale.getLanguageSubTag(languageCode);
return code in opt_localeSymbols['LANGUAGE'] ?
opt_localeSymbols['LANGUAGE'][code] : languageCode;
};
/**
* Register a resource object for certain locale.
* @param {Object} dataObj The resource object being registered.
* @param {goog.locale.Resource|string} resourceName String that represents
* the type of resource.
* @param {string} localeName Locale ID.
*/
goog.locale.registerResource = function(dataObj, resourceName, localeName) {
if (!goog.locale.resourceRegistry_[resourceName]) {
goog.locale.resourceRegistry_[resourceName] = {};
}
goog.locale.resourceRegistry_[resourceName][localeName] = dataObj;
// the first registered locale becomes active one. Usually there will be
// only one locale per js binary bundle.
if (!goog.locale.activeLocale_) {
goog.locale.activeLocale_ = localeName;
}
};
/**
* Returns true if the required resource has already been registered.
* @param {goog.locale.Resource|string} resourceName String that represents
* the type of resource.
* @param {string} localeName Locale ID.
* @return {boolean} Whether the required resource has already been registered.
*/
goog.locale.isResourceRegistered = function(resourceName, localeName) {
return resourceName in goog.locale.resourceRegistry_ &&
localeName in goog.locale.resourceRegistry_[resourceName];
};
/**
* This object maps (resourceName, localeName) to a resourceObj.
* @type {Object}
* @private
*/
goog.locale.resourceRegistry_ = {};
/**
* Registers the timezone constants object for a given locale name.
* @param {Object} dataObj The resource object.
* @param {string} localeName Locale ID.
* @deprecated Use goog.i18n.TimeZone, no longer need this.
*/
goog.locale.registerTimeZoneConstants = function(dataObj, localeName) {
goog.locale.registerResource(
dataObj, goog.locale.Resource.TIME_ZONE_CONSTANTS, localeName);
};
/**
* Registers the LocaleNameConstants constants object for a given locale name.
* @param {Object} dataObj The resource object.
* @param {string} localeName Locale ID.
*/
goog.locale.registerLocaleNameConstants = function(dataObj, localeName) {
goog.locale.registerResource(
dataObj, goog.locale.Resource.LOCAL_NAME_CONSTANTS, localeName);
};
/**
* Registers the TimeZoneSelectedIds constants object for a given locale name.
* @param {Object} dataObj The resource object.
* @param {string} localeName Locale ID.
*/
goog.locale.registerTimeZoneSelectedIds = function(dataObj, localeName) {
goog.locale.registerResource(
dataObj, goog.locale.Resource.TIME_ZONE_SELECTED_IDS, localeName);
};
/**
* Registers the TimeZoneSelectedShortNames constants object for a given
* locale name.
* @param {Object} dataObj The resource object.
* @param {string} localeName Locale ID.
*/
goog.locale.registerTimeZoneSelectedShortNames = function(dataObj, localeName) {
goog.locale.registerResource(
dataObj, goog.locale.Resource.TIME_ZONE_SELECTED_SHORT_NAMES, localeName);
};
/**
* Registers the TimeZoneSelectedLongNames constants object for a given locale
* name.
* @param {Object} dataObj The resource object.
* @param {string} localeName Locale ID.
*/
goog.locale.registerTimeZoneSelectedLongNames = function(dataObj, localeName) {
goog.locale.registerResource(
dataObj, goog.locale.Resource.TIME_ZONE_SELECTED_LONG_NAMES, localeName);
};
/**
* Registers the TimeZoneAllLongNames constants object for a given locale name.
* @param {Object} dataObj The resource object.
* @param {string} localeName Locale ID.
*/
goog.locale.registerTimeZoneAllLongNames = function(dataObj, localeName) {
goog.locale.registerResource(
dataObj, goog.locale.Resource.TIME_ZONE_ALL_LONG_NAMES, localeName);
};
/**
* Retrieve specified resource for certain locale.
* @param {string} resourceName String that represents the type of resource.
* @param {string=} opt_locale Locale ID, if not given, current locale
* will be assumed.
* @return {Object|undefined} The resource object that hold all the resource
* data, or undefined if not available.
*/
goog.locale.getResource = function(resourceName, opt_locale) {
var locale = opt_locale ? opt_locale : goog.locale.getLocale();
if (!(resourceName in goog.locale.resourceRegistry_)) {
return undefined;
}
return goog.locale.resourceRegistry_[resourceName][locale];
};
/**
* Retrieve specified resource for certain locale with fallback. For example,
* request of 'zh_CN' will be resolved in following order: zh_CN, zh, en.
* If none of the above succeeds, of if the resource as indicated by
* resourceName does not exist at all, undefined will be returned.
*
* @param {string} resourceName String that represents the type of resource.
* @param {string=} opt_locale locale ID, if not given, current locale
* will be assumed.
* @return {Object|undefined} The resource object for desired locale.
*/
goog.locale.getResourceWithFallback = function(resourceName, opt_locale) {
var locale = opt_locale ? opt_locale : goog.locale.getLocale();
if (!(resourceName in goog.locale.resourceRegistry_)) {
return undefined;
}
if (locale in goog.locale.resourceRegistry_[resourceName]) {
return goog.locale.resourceRegistry_[resourceName][locale];
}
// if locale has multiple parts (2 atmost in reality), fallback to base part.
var locale_parts = locale.split('_');
if (locale_parts.length > 1 &&
locale_parts[0] in goog.locale.resourceRegistry_[resourceName]) {
return goog.locale.resourceRegistry_[resourceName][locale_parts[0]];
}
// otherwise, fallback to 'en'
return goog.locale.resourceRegistry_[resourceName]['en'];
};
// Export global functions that are used by the date time constants files.
// See http://go/js_locale_data
var registerLocalNameConstants = goog.locale.registerLocaleNameConstants;
var registerTimeZoneSelectedIds = goog.locale.registerTimeZoneSelectedIds;
var registerTimeZoneSelectedShortNames =
goog.locale.registerTimeZoneSelectedShortNames;
var registerTimeZoneSelectedLongNames =
goog.locale.registerTimeZoneSelectedLongNames;
var registerTimeZoneAllLongNames = goog.locale.registerTimeZoneAllLongNames;