164 lines
4 KiB
JavaScript
164 lines
4 KiB
JavaScript
/**
|
|
* CLDR JavaScript Library v@VERSION
|
|
* http://jquery.com/
|
|
*
|
|
* Copyright 2013 Rafael Xavier de Souza
|
|
* Released under the MIT license
|
|
* http://jquery.org/license
|
|
*
|
|
* Date: @DATE
|
|
*/
|
|
/*!
|
|
* CLDR JavaScript Library v@VERSION @DATE MIT license © Rafael Xavier
|
|
* http://git.io/h4lmVg
|
|
*/
|
|
(function( factory ) {
|
|
|
|
if ( typeof define === "function" && define.amd ) {
|
|
// AMD.
|
|
define( [ "../cldr" ], factory );
|
|
} else if ( typeof module === "object" && typeof module.exports === "object" ) {
|
|
// Node. CommonJS.
|
|
module.exports = factory( require( "../cldr" ) );
|
|
} else {
|
|
// Global
|
|
factory( Cldr );
|
|
}
|
|
|
|
}(function( Cldr ) {
|
|
|
|
// Build optimization hack to avoid duplicating functions across modules.
|
|
var coreLoad = Cldr._coreLoad;
|
|
var jsonMerge = Cldr._jsonMerge;
|
|
var pathNormalize = Cldr._pathNormalize;
|
|
var resourceGet = Cldr._resourceGet;
|
|
var validatePresence = Cldr._validatePresence;
|
|
var validateTypePath = Cldr._validateTypePath;
|
|
|
|
|
|
|
|
var bundleParentLookup = function( Cldr, locale ) {
|
|
var normalizedPath, parent;
|
|
|
|
if ( locale === "root" ) {
|
|
return;
|
|
}
|
|
|
|
// First, try to find parent on supplemental data.
|
|
normalizedPath = pathNormalize( [ "supplemental/parentLocales/parentLocale", locale ] );
|
|
parent = resourceGet( Cldr._resolved, normalizedPath ) || resourceGet( Cldr._raw, normalizedPath );
|
|
if ( parent ) {
|
|
return parent;
|
|
}
|
|
|
|
// Or truncate locale.
|
|
parent = locale.substr( 0, locale.lastIndexOf( Cldr.localeSep ) );
|
|
if ( !parent ) {
|
|
return "root";
|
|
}
|
|
|
|
return parent;
|
|
};
|
|
|
|
|
|
|
|
|
|
// @path: normalized path
|
|
var resourceSet = function( data, path, value ) {
|
|
var i,
|
|
node = data,
|
|
length = path.length;
|
|
|
|
for ( i = 0; i < length - 1; i++ ) {
|
|
if ( !node[ path[ i ] ] ) {
|
|
node[ path[ i ] ] = {};
|
|
}
|
|
node = node[ path[ i ] ];
|
|
}
|
|
node[ path[ i ] ] = value;
|
|
};
|
|
|
|
|
|
var itemLookup = (function() {
|
|
|
|
var lookup;
|
|
|
|
lookup = function( Cldr, locale, path, attributes, childLocale ) {
|
|
var normalizedPath, parent, value;
|
|
|
|
// 1: Finish recursion
|
|
// 2: Avoid infinite loop
|
|
if ( typeof locale === "undefined" /* 1 */ || locale === childLocale /* 2 */ ) {
|
|
return;
|
|
}
|
|
|
|
// Resolve path
|
|
normalizedPath = pathNormalize( path, attributes );
|
|
|
|
// Check resolved (cached) data first
|
|
// 1: Due to #16, never use the cached resolved non-leaf nodes. It may not
|
|
// represent its leafs in its entirety.
|
|
value = resourceGet( Cldr._resolved, normalizedPath );
|
|
if ( value !== undefined && typeof value !== "object" /* 1 */ ) {
|
|
return value;
|
|
}
|
|
|
|
// Check raw data
|
|
value = resourceGet( Cldr._raw, normalizedPath );
|
|
|
|
if ( value === undefined ) {
|
|
// Or, lookup at parent locale
|
|
parent = bundleParentLookup( Cldr, locale );
|
|
value = lookup( Cldr, parent, path, jsonMerge( attributes, { bundle: parent }), locale );
|
|
}
|
|
|
|
if ( value !== undefined ) {
|
|
// Set resolved (cached)
|
|
resourceSet( Cldr._resolved, normalizedPath, value );
|
|
}
|
|
|
|
return value;
|
|
};
|
|
|
|
return lookup;
|
|
|
|
}());
|
|
|
|
|
|
Cldr._raw = {};
|
|
|
|
/**
|
|
* Cldr.load( json [, json, ...] )
|
|
*
|
|
* @json [JSON] CLDR data or [Array] Array of @json's.
|
|
*
|
|
* Load resolved or unresolved cldr data.
|
|
* Overwrite Cldr.load().
|
|
*/
|
|
Cldr.load = function() {
|
|
Cldr._raw = coreLoad( Cldr, Cldr._raw, arguments );
|
|
};
|
|
|
|
/**
|
|
* Overwrite Cldr.prototype.get().
|
|
*/
|
|
Cldr.prototype.get = function( path ) {
|
|
validatePresence( path, "path" );
|
|
validateTypePath( path, "path" );
|
|
|
|
// 1: use bundle as locale on item lookup for simplification purposes, because no other extended subtag is used anyway on bundle parent lookup.
|
|
// 2: during init(), this method is called, but bundle is yet not defined. Use "" as a workaround in this very specific scenario.
|
|
return itemLookup( Cldr, this.attributes && this.attributes.bundle /* 1 */ || "" /* 2 */, path, this.attributes );
|
|
};
|
|
|
|
// In case cldr/unresolved is loaded after cldr/event, we trigger its overloads again. Because, .get is overwritten in here.
|
|
if ( Cldr._eventInit ) {
|
|
Cldr._eventInit();
|
|
}
|
|
|
|
return Cldr;
|
|
|
|
|
|
|
|
define("cldr_unresolved", function(){});
|
|
}));
|