404 lines
14 KiB
JavaScript
404 lines
14 KiB
JavaScript
// 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 currnet 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;
|
|
|