123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507 |
- define("dojox/date/hebrew/locale", ["dojo/main", "dojo/date", "dojo/i18n", "dojo/regexp", "dojo/string", "./Date", "./numerals", "dojo/i18n!dojo/cldr/nls/hebrew"],
- function(dojo, dd, i18n, regexp, string, hebrewDate, numerals){
- dojo.getObject("date.hebrew.locale", true, dojox);
- dojo.experimental("dojox.date.hebrew.locale");
- //Load the bundles containing localization information for
- // names and formats
- dojo.requireLocalization("dojo.cldr", "hebrew");
- // Format a pattern without literals
- function formatPattern(dateObject, bundle, locale, fullYear, pattern){
- return pattern.replace(/([a-z])\1*/ig, function(match){
- var s, pad;
- var c = match.charAt(0);
- var l = match.length;
- var widthList = ["abbr", "wide", "narrow"];
-
- switch(c){
- case 'y':
- if(locale.match(/^he(?:-.+)?$/)){
- s = numerals.getYearHebrewLetters(dateObject.getFullYear());
- }else{
- s = String(dateObject.getFullYear());
- }
- break;
- case 'M':
- var m = dateObject.getMonth();
- if(l<3){
- if(!dateObject.isLeapYear(dateObject.getFullYear()) && m>5){m--;}
- if(locale.match(/^he(?:-.+)?$/)){
- s = numerals.getMonthHebrewLetters(m);
- }else{
- s = m+1; pad = true;
- }
- }else{
- var monthNames = dojox.date.hebrew.locale.getNames('months',widthList[l-3], 'format', locale, dateObject);
- s = monthNames[m];
- }
- break;
- case 'd':
- if(locale.match(/^he(?:-.+)?$/)){
- s = dateObject.getDateLocalized(locale);
- }else{
- s = dateObject.getDate(); pad = true;
- }
- break;
- case 'E':
- var d = dateObject.getDay();
- if(l<3){
- s = d+1; pad = true;
- }else{
- var propD = ["days", "format", widthList[l-3]].join("-");
- s = bundle[propD][d];
- }
- break;
- case 'a':
- var timePeriod = (dateObject.getHours() < 12) ? 'am' : 'pm';
- s = bundle['dayPeriods-format-wide-' + timePeriod];
- break;
- case 'h':
- case 'H':
- case 'K':
- case 'k':
- var h = dateObject.getHours();
- // strange choices in the date format make it impossible to write this succinctly
- switch (c){
- case 'h': // 1-12
- s = (h % 12) || 12;
- break;
- case 'H': // 0-23
- s = h;
- break;
- case 'K': // 0-11
- s = (h % 12);
- break;
- case 'k': // 1-24
- s = h || 24;
- break;
- }
- pad = true;
- break;
- case 'm':
- s = dateObject.getMinutes(); pad = true;
- break;
- case 's':
- s = dateObject.getSeconds(); pad = true;
- break;
- case 'S':
- s = Math.round(dateObject.getMilliseconds() * Math.pow(10, l-3)); pad = true;
- break;
- case 'z':
- s = "";
- break;
- default:
- throw new Error("dojox.date.hebrew.locale.formatPattern: invalid pattern char: "+pattern);
- }
- if(pad){ s = string.pad(s, l); }
- return s;
- });
- }
-
- dojox.date.hebrew.locale.format = function(/*hebrew.Date*/dateObject, /*object?*/options){
- // based on and similar to dojo.date.locale.format
- //summary:
- // Format a Date object as a String, using settings.
- //
- // description:
- // Create a string from a hebrew.Date object using a known pattern.
- // By default, this method formats both date and time from dateObject.
- // Default formatting lengths is 'short'
- //
- // dateObject:
- // the date and/or time to be formatted. If a time only is formatted,
- // the values in the year, month, and day fields are irrelevant. The
- // opposite is true when formatting only dates.
- options = options || {};
- var locale = i18n.normalizeLocale(options.locale);
- var formatLength = options.formatLength || 'short';
- var bundle = dojox.date.hebrew.locale._getHebrewBundle(locale);
- var str = [];
- var sauce = dojo.hitch(this, formatPattern, dateObject, bundle, locale, options.fullYear);
- if(options.selector == "year"){
- var year = dateObject.getFullYear();
- return locale.match(/^he(?:-.+)?$/) ?
- numerals.getYearHebrewLetters(year) : year;
- }
- if(options.selector != "time"){
- var datePattern = options.datePattern || bundle["dateFormat-"+formatLength];
- if(datePattern){str.push(_processPattern(datePattern, sauce));}
- }
- if(options.selector != "date"){
- var timePattern = options.timePattern || bundle["timeFormat-"+formatLength];
- if(timePattern){str.push(_processPattern(timePattern, sauce));}
- }
- var result = str.join(" "); //TODO: use locale-specific pattern to assemble date + time
- return result; // String
- };
- dojox.date.hebrew.locale.regexp = function(/*object?*/options){
- // based on and similar to dojo.date.locale.regexp
- // summary:
- // Builds the regular needed to parse a hebrew.Date
- return dojox.date.hebrew.locale._parseInfo(options).regexp; // String
- };
- dojox.date.hebrew.locale._parseInfo = function(/*oblect?*/options){
- /* based on and similar to dojo.date.locale._parseInfo */
- options = options || {};
- var locale = i18n.normalizeLocale(options.locale);
- var bundle = dojox.date.hebrew.locale._getHebrewBundle(locale);
- var formatLength = options.formatLength || 'short';
- var datePattern = options.datePattern || bundle["dateFormat-" + formatLength];
- var timePattern = options.timePattern || bundle["timeFormat-" + formatLength];
- var pattern;
- if(options.selector == 'date'){
- pattern = datePattern;
- }else if(options.selector == 'time'){
- pattern = timePattern;
- }else{
- pattern = (timePattern === undefined) ? datePattern : datePattern + ' ' + timePattern; //hebrew resource file does not contain time patterns - a bug?
- }
- var tokens = [];
-
- var re = _processPattern(pattern, dojo.hitch(this, _buildDateTimeRE, tokens, bundle, options));
- return {regexp: re, tokens: tokens, bundle: bundle};
- };
- dojox.date.hebrew.locale.parse = function(/*String*/value, /*Object?*/options){
- // based on and similar to dojo.date.locale.parse
- // summary: This function parse string date value according to options
- // example:
- // | var dateHebrew = dojox.date.hebrew.locale.parse('11/10/5740', {datePattern:'dd/MM/yy', selector:'date'});
- // | in Hebrew locale string for parsing contains Hebrew Numerals
- // |
- // | options = {datePattern:'dd MMMM yy', selector:'date'};
- // |
- // | y - year
- // | M, MM - short month
- // | MMM, MMMM - long month
- // | d - date
- // | a - am, pm
- // | E, EE, EEE, EEEE - week day
- // |
- // | h, H, k, K, m, s, S, - time format
-
- value = value.replace(/[\u200E\u200F\u202A-\u202E]/g, ""); //remove special chars
- if(!options){options={};}
- var info = dojox.date.hebrew.locale._parseInfo(options);
-
- var tokens = info.tokens, bundle = info.bundle;
- var re = new RegExp("^" + info.regexp + "$");
-
- var match = re.exec(value);
- var locale = i18n.normalizeLocale(options.locale);
- if(!match){ return null; } // null
-
- var date, date1;
-
- //var result = [1970,0,1,0,0,0,0]; //
- var result = [5730,3,23,0,0,0,0]; // hebrew date for [1970,0,1,0,0,0,0] used in gregorian locale
- var amPm = "";
- var mLength = 0;
- var widthList = ["abbr", "wide", "narrow"];
- var valid = dojo.every(match, function(v, i){
- if(!i){return true;}
- var token=tokens[i-1];
- var l=token.length;
- switch(token.charAt(0)){
- case 'y':
- if(locale.match(/^he(?:-.+)?$/)){
- result[0] = numerals.parseYearHebrewLetters(v);
- }else{
- result[0] = Number(v);
- }
- break;
- case 'M':
- //if it is short format, month is one letter or two letter with "geresh"
- if(l>2){
- //we do not know here if the year is leap or not
- var months = dojox.date.hebrew.locale.getNames('months', widthList[l-3], 'format', locale, new hebrewDate(5769, 1, 1)),
- leapmonths = dojox.date.hebrew.locale.getNames('months', widthList[l-3], 'format', locale, new hebrewDate(5768, 1, 1));
- if(!options.strict){
- //Tolerate abbreviating period in month part
- //Case-insensitive comparison
- v = v.replace(".","").toLowerCase();
- months = dojo.map(months, function(s){ return s ? s.replace(".","").toLowerCase() : s; } );
- leapmonths = dojo.map(leapmonths, function(s){ return s ? s.replace(".","").toLowerCase() : s; } );
- }
- var monthName = v;
- v = dojo.indexOf(months, monthName);
- if(v == -1){
- v = dojo.indexOf(leapmonths, monthName);
- if(v == -1){
- //console.debug("dojox.date.hebrew.locale.parse: Could not parse month name: second " + v +"'.");
- return false;
- }
- }
- mLength = l;
- }else{
- if(locale.match(/^he(?:-.+)?$/)){
- v = numerals.parseMonthHebrewLetters(v);
- }else{
- v--;
- }
- }
- result[1] = Number(v);
- break;
- case 'D':
- result[1] = 0;
- // fallthrough...
- case 'd':
- if(locale.match(/^he(?:-.+)?$/)){
- result[2] = numerals.parseDayHebrewLetters(v);
- }else{
- result[2] = Number(v);
- }
- break;
- case 'a': //am/pm
- var am = options.am || bundle['dayPeriods-format-wide-am'],
- pm = options.pm || bundle['dayPeriods-format-wide-pm'];
- if(!options.strict){
- var period = /\./g;
- v = v.replace(period,'').toLowerCase();
- am = am.replace(period,'').toLowerCase();
- pm = pm.replace(period,'').toLowerCase();
- }
- if(options.strict && v != am && v != pm){
- return false;
- }
- // we might not have seen the hours field yet, so store the state and apply hour change later
- amPm = (v == pm) ? 'p' : (v == am) ? 'a' : '';
- break;
- case 'K': //hour (1-24)
- if(v == 24){ v = 0; }
- // fallthrough...
- case 'h': //hour (1-12)
- case 'H': //hour (0-23)
- case 'k': //hour (0-11)
- //in the 12-hour case, adjusting for am/pm requires the 'a' part
- //which could come before or after the hour, so we will adjust later
- result[3] = Number(v);
- break;
- case 'm': //minutes
- result[4] = Number(v);
- break;
- case 's': //seconds
- result[5] = Number(v);
- break;
- case 'S': //milliseconds
- result[6] = Number(v);
- }
- return true;
- });
- var hours = +result[3];
- if(amPm === 'p' && hours < 12){
- result[3] = hours + 12; //e.g., 3pm -> 15
- }else if(amPm === 'a' && hours == 12){
- result[3] = 0; //12am -> 0
- }
- var dateObject = new hebrewDate(result[0], result[1], result[2], result[3], result[4], result[5], result[6]); // hebrew.Date
- //for non leap year, the index of the short month start from adar should be increased by 1
- if(mLength < 3 && result[1] >= 5 && !dateObject.isLeapYear(dateObject.getFullYear())){
- dateObject.setMonth(result[1]+1);
- }
- return dateObject; // hebrew.Date
- };
- function _processPattern(pattern, applyPattern, applyLiteral, applyAll){
- //summary: Process a pattern with literals in it
- // Break up on single quotes, treat every other one as a literal, except '' which becomes '
- var identity = function(x){return x;};
- applyPattern = applyPattern || identity;
- applyLiteral = applyLiteral || identity;
- applyAll = applyAll || identity;
- //split on single quotes (which escape literals in date format strings)
- //but preserve escaped single quotes (e.g., o''clock)
- var chunks = pattern.match(/(''|[^'])+/g);
- var literal = pattern.charAt(0) == "'";
- dojo.forEach(chunks, function(chunk, i){
- if(!chunk){
- chunks[i]='';
- }else{
- chunks[i]=(literal ? applyLiteral : applyPattern)(chunk);
- literal = !literal;
- }
- });
- return applyAll(chunks.join(''));
- }
- function _buildDateTimeRE (tokens, bundle, options, pattern){
- // based on and similar to dojo.date.locale._buildDateTimeRE
- //
-
- pattern = regexp.escapeString(pattern);
- var locale = i18n.normalizeLocale(options.locale);
-
- return pattern.replace(/([a-z])\1*/ig, function(match){
- // Build a simple regexp. Avoid captures, which would ruin the tokens list
- var s;
- var c = match.charAt(0);
- var l = match.length;
- var p2 = '', p3 = '';
- if(options.strict){
- if(l > 1){ p2 = '0' + '{'+(l-1)+'}'; }
- if(l > 2){ p3 = '0' + '{'+(l-2)+'}'; }
- }else{
- p2 = '0?'; p3 = '0{0,2}';
- }
- switch(c){
- case 'y':
- s = '\\S+';
- break;
- case 'M':
- if(locale.match('^he(?:-.+)?$')){
- s = (l>2) ? '\\S+ ?\\S+' : '\\S{1,4}';
- }else{
- s = (l>2) ? '\\S+ ?\\S+' : p2+'[1-9]|1[0-2]';
- }
- break;
- case 'd':
- if(locale.match('^he(?:-.+)?$')){
- s = '\\S[\'\"\'\u05F3]{1,2}\\S?';
- }else{
- s = '[12]\\d|'+p2+'[1-9]|30';
- }
- break;
- case 'E':
- if(locale.match('^he(?:-.+)?$')){
- s = (l>3) ? '\\S+ ?\\S+' : '\\S';
- }else{
- s = '\\S+';
- }
- break;
- case 'h': //hour (1-12)
- s = p2+'[1-9]|1[0-2]';
- break;
- case 'k': //hour (0-11)
- s = p2+'\\d|1[01]';
- break;
- case 'H': //hour (0-23)
- s = p2+'\\d|1\\d|2[0-3]';
- break;
- case 'K': //hour (1-24)
- s = p2+'[1-9]|1\\d|2[0-4]';
- break;
- case 'm':
- case 's':
- s = p2+'\\d|[0-5]\\d';
- break;
- case 'S':
- s = '\\d{'+l+'}';
- break;
- case 'a':
- var am = options.am || bundle['dayPeriods-format-wide-am'],
- pm = options.pm || bundle['dayPeriods-format-wide-pm'];
- if(options.strict){
- s = am + '|' + pm;
- }else{
- s = am + '|' + pm;
- if(am != am.toLowerCase()){ s += '|' + am.toLowerCase(); }
- if(pm != pm.toLowerCase()){ s += '|' + pm.toLowerCase(); }
- }
- break;
- default:
- s = ".*";
- }
- if(tokens){ tokens.push(match); }
- return "(" + s + ")"; // add capture
- }).replace(/[\xa0 ]/g, "[\\s\\xa0]"); // normalize whitespace. Need explicit handling of \xa0 for IE. */
- }
- var _customFormats = [];
- dojox.date.hebrew.locale.addCustomFormats = function(/*String*/packageName, /*String*/bundleName){
- // summary:
- // Add a reference to a bundle containing localized custom formats to be
- // used by date/time formatting and parsing routines.
- //
- // description:
- // The user may add custom localized formats where the bundle has properties following the
- // same naming convention used by dojo.cldr: `dateFormat-xxxx` / `timeFormat-xxxx`
- // The pattern string should match the format used by the CLDR.
- // See dojo.date.locale.format() for details.
- // The resources must be loaded by dojo.requireLocalization() prior to use
- _customFormats.push({pkg:packageName,name:bundleName});
- };
- dojox.date.hebrew.locale._getHebrewBundle = function(/*String*/locale){
- var hebrew = {};
- dojo.forEach(_customFormats, function(desc){
- var bundle = i18n.getLocalization(desc.pkg, desc.name, locale);
- hebrew = dojo.mixin(hebrew, bundle);
- }, this);
- return hebrew; /*Object*/
- };
- dojox.date.hebrew.locale.addCustomFormats("dojo.cldr","hebrew");
- dojox.date.hebrew.locale.getNames = function(/*String*/item, /*String*/type, /*String?*/context, /*String?*/locale, /*dojox.date.hebrew.Date?*/date){
- // summary:
- // Used to get localized strings from dojo.cldr for day or month names.
- //
- // item:
- // 'months' || 'days'
- // type:
- // 'wide' || 'narrow' || 'abbr' (e.g. "Monday", "Mon", or "M" respectively, in English)
- // use:
- // 'standAlone' || 'format' (default)
- // locale:
- // override locale used to find the names
- // date:
- // required for item=months to determine leap month name
- //
- // using var monthNames = dojox.date.hebrew.locale.getNames('months', 'wide', 'format', 'he', new hebrewDate(5768, 2, 12));
- var label,
- lookup = dojox.date.hebrew.locale._getHebrewBundle(locale),
- props = [item, context, type];
- if(context == 'standAlone'){
- var key = props.join('-');
- label = lookup[key];
- // Fall back to 'format' flavor of name
- if(label[0] == 1){ label = undefined; } // kludge, in the absence of real aliasing support in dojo.cldr
- }
- props[1] = 'format';
-
- // return by copy so changes won't be made accidentally to the in-memory model
- var result = (label || lookup[props.join('-')]).concat();
- if(item == "months"){
- if(date.isLeapYear(date.getFullYear())){
- // Adar I (6th position in the array) will be used.
- // Substitute the leap month Adar II for the regular Adar (7th position)
- props.push("leap");
- result[6] = lookup[props.join('-')];
- }else{
- // Remove Adar I but leave an empty position in the array
- delete result[5];
- }
- }
- return result; /*Array*/
- };
- return dojox.date.hebrew.locale;
- });
|