e44a7e37b6
git-svn-id: https://semanticscuttle.svn.sourceforge.net/svnroot/semanticscuttle/trunk@151 b3834d28-1941-0410-a4f8-b48e95affb8f
312 lines
8.3 KiB
JavaScript
312 lines
8.3 KiB
JavaScript
if(!dojo._hasResource["dojox.date.php"]){ //_hasResource checks added by build. Do not use _hasResource directly in your code.
|
|
dojo._hasResource["dojox.date.php"] = true;
|
|
dojo.provide("dojox.date.php");
|
|
dojo.require("dojo.date");
|
|
dojo.require("dojox.string.tokenize");
|
|
|
|
dojox.date.php.format = function(/*Date*/ date, /*String*/ format){
|
|
// summary: Get a formatted string for a given date object
|
|
var df = new dojox.date.php.DateFormat(format);
|
|
return df.format(date);
|
|
}
|
|
|
|
dojox.date.php.DateFormat = function(/*String*/ format){
|
|
// summary: Format the internal date object
|
|
if(!this.regex){
|
|
var keys = [];
|
|
for(var key in this.constructor.prototype){
|
|
if(dojo.isString(key) && key.length == 1 && dojo.isFunction(this[key])){
|
|
keys.push(key);
|
|
}
|
|
}
|
|
this.constructor.prototype.regex = new RegExp("(?:(\\\\.)|([" + keys.join("") + "]))", "g");
|
|
}
|
|
|
|
var replacements = [];
|
|
|
|
this.tokens = dojox.string.tokenize(format, this.regex, function(escape, token, i){
|
|
if(token){
|
|
replacements.push([i, token]);
|
|
return token;
|
|
}
|
|
if(escape){
|
|
return escape.charAt(1);
|
|
}
|
|
});
|
|
|
|
this.replacements = replacements;
|
|
}
|
|
dojo.extend(dojox.date.php.DateFormat, {
|
|
weekdays: ["Sunday", "Monday", "Tuesday", "Wednesday", "Thursday", "Friday", "Saturday"],
|
|
weekdays_3: ["Sun", "Mon", "Tue", "Wed", "Thu", "Fri", "Sat"],
|
|
months: ["January", "February", "March", "April", "May", "June", "July", "August", "September", "October", "November", "December"],
|
|
months_3: ["Jan", "Feb", "Mar", "Apr", "May", "Jun", "Jul", "Aug", "Sep", "Oct", "Nov", "Dec"],
|
|
monthdays: [31,28,31,30,31,30,31,31,30,31,30,31],
|
|
|
|
format: function(/*Date*/ date){
|
|
this.date = date;
|
|
for(var i = 0, replacement; replacement = this.replacements[i]; i++){
|
|
this.tokens[replacement[0]] = this[replacement[1]]();
|
|
}
|
|
return this.tokens.join("");
|
|
},
|
|
|
|
// Day
|
|
|
|
d: function(){
|
|
// summary: Day of the month, 2 digits with leading zeros
|
|
var j = this.j();
|
|
return (j.length == 1) ? "0" + j : j;
|
|
},
|
|
|
|
D: function(){
|
|
// summary: A textual representation of a day, three letters
|
|
return this.weekdays_3[this.date.getDay()];
|
|
},
|
|
|
|
j: function(){
|
|
// summary: Day of the month without leading zeros
|
|
return this.date.getDate() + "";
|
|
},
|
|
|
|
l: function(){
|
|
// summary: A full textual representation of the day of the week
|
|
return this.weekdays[this.date.getDay()];
|
|
},
|
|
|
|
N: function(){
|
|
// summary: ISO-8601 numeric representation of the day of the week (added in PHP 5.1.0)
|
|
var w = this.w();
|
|
return (!w) ? 7 : w;
|
|
},
|
|
|
|
S: function(){
|
|
// summary: English ordinal suffix for the day of the month, 2 characters
|
|
switch(this.date.getDate()){
|
|
case 11: case 12: case 13: return "th";
|
|
case 1: case 21: case 31: return "st";
|
|
case 2: case 22: return "nd";
|
|
case 3: case 23: return "rd";
|
|
default: return "th";
|
|
}
|
|
},
|
|
|
|
w: function(){
|
|
// summary: Numeric representation of the day of the week
|
|
return this.date.getDay() + "";
|
|
},
|
|
|
|
z: function(){
|
|
// summary: The day of the year (starting from 0)
|
|
var millis = this.date.getTime() - new Date(this.date.getFullYear(), 0, 1).getTime();
|
|
return Math.floor(millis/86400000) + "";
|
|
},
|
|
|
|
// Week
|
|
|
|
W: function(){
|
|
// summary: ISO-8601 week number of year, weeks starting on Monday (added in PHP 4.1.0)
|
|
var week;
|
|
var jan1_w = new Date(this.date.getFullYear(), 0, 1).getDay() + 1;
|
|
var w = this.date.getDay() + 1;
|
|
var z = parseInt(this.z());
|
|
|
|
if(z <= (8 - jan1_w) && jan1_w > 4){
|
|
var last_year = new Date(this.date.getFullYear() - 1, this.date.getMonth(), this.date.getDate());
|
|
if(jan1_w == 5 || (jan1_w == 6 && dojo.date.isLeapYear(last_year))){
|
|
week = 53;
|
|
}else{
|
|
week = 52;
|
|
}
|
|
}else{
|
|
var i;
|
|
if(Boolean(this.L())){
|
|
i = 366;
|
|
}else{
|
|
i = 365;
|
|
}
|
|
if((i - z) < (4 - w)){
|
|
week = 1;
|
|
}else{
|
|
var j = z + (7 - w) + (jan1_w - 1);
|
|
week = Math.ceil(j / 7);
|
|
if(jan1_w > 4){
|
|
--week;
|
|
}
|
|
}
|
|
}
|
|
|
|
return week;
|
|
},
|
|
|
|
// Month
|
|
|
|
F: function(){
|
|
// summary: A full textual representation of a month, such as January or March
|
|
return this.months[this.date.getMonth()];
|
|
},
|
|
|
|
m: function(){
|
|
// summary: Numeric representation of a month, with leading zeros
|
|
var n = this.n();
|
|
return (n.length == 1) ? "0" + n : n;
|
|
},
|
|
|
|
M: function(){
|
|
// summary: A short textual representation of a month, three letters
|
|
return this.months_3[this.date.getMonth()];
|
|
},
|
|
|
|
n: function(){
|
|
// summary: Numeric representation of a month, without leading zeros
|
|
return this.date.getMonth() + 1 + "";
|
|
},
|
|
|
|
t: function(){
|
|
// summary: Number of days in the given month
|
|
return (Boolean(this.L()) && this.date.getMonth() == 1) ? 29 : this.monthdays[this.getMonth()];
|
|
},
|
|
|
|
// Year
|
|
|
|
L: function(){
|
|
// summary: Whether it's a leap year
|
|
return (dojo.date.isLeapYear(this.date)) ? "1" : "0";
|
|
},
|
|
|
|
o: function(){
|
|
// summary:
|
|
// ISO-8601 year number. This has the same value as Y, except that if
|
|
// the ISO week number (W) belongs to the previous or next year, that year is used instead. (added in PHP 5.1.0)
|
|
// TODO: Figure out what this means
|
|
},
|
|
|
|
Y: function(){
|
|
// summary: A full numeric representation of a year, 4 digits
|
|
return this.date.getFullYear() + "";
|
|
},
|
|
|
|
y: function(){
|
|
// summary: A two digit representation of a year
|
|
return this.Y().slice(-2);
|
|
},
|
|
|
|
// Time
|
|
|
|
a: function(){
|
|
// summary: Lowercase Ante meridiem and Post meridiem
|
|
return this.date.getHours() >= 12 ? "pm" : "am";
|
|
},
|
|
|
|
b: function(){
|
|
// summary: Uppercase Ante meridiem and Post meridiem
|
|
return this.a().toUpperCase();
|
|
},
|
|
|
|
B: function(){
|
|
// summary:
|
|
// Swatch Internet time
|
|
// A day is 1,000 beats. All time is measured from GMT + 1
|
|
var off = this.date.getTimezoneOffset() + 60;
|
|
var secs = (this.date.getHours() * 3600) + (this.date.getMinutes() * 60) + this.getSeconds() + (off * 60);
|
|
var beat = Math.abs(Math.floor(secs / 86.4) % 1000) + "";
|
|
while(beat.length < 2) beat = "0" + beat;
|
|
return beat;
|
|
},
|
|
|
|
g: function(){
|
|
// summary: 12-hour format of an hour without leading zeros
|
|
return (this.date.getHours() > 12) ? this.date.getHours() - 12 + "" : this.date.getHours() + "";
|
|
},
|
|
|
|
G: function(){
|
|
// summary: 24-hour format of an hour without leading zeros
|
|
return this.date.getHours() + "";
|
|
},
|
|
|
|
h: function(){
|
|
// summary: 12-hour format of an hour with leading zeros
|
|
var g = this.g();
|
|
return (g.length == 1) ? "0" + g : g;
|
|
},
|
|
|
|
H: function(){
|
|
// summary: 24-hour format of an hour with leading zeros
|
|
var G = this.G();
|
|
return (G.length == 1) ? "0" + G : G;
|
|
},
|
|
|
|
i: function(){
|
|
// summary: Minutes with leading zeros
|
|
var mins = this.date.getMinutes() + "";
|
|
return (mins.length == 1) ? "0" + mins : mins;
|
|
},
|
|
|
|
s: function(){
|
|
// summary: Seconds, with leading zeros
|
|
var secs = this.date.getSeconds() + "";
|
|
return (secs.length == 1) ? "0" + secs : secs;
|
|
},
|
|
|
|
// Timezone
|
|
|
|
e: function(){
|
|
// summary: Timezone identifier (added in PHP 5.1.0)
|
|
return dojo.date.getTimezoneName(this.date);
|
|
},
|
|
|
|
I: function(){
|
|
// summary: Whether or not the date is in daylight saving time
|
|
// TODO: Can dojo.date do this?
|
|
},
|
|
|
|
O: function(){
|
|
// summary: Difference to Greenwich time (GMT) in hours
|
|
var off = Math.abs(this.date.getTimezoneOffset());
|
|
var hours = Math.floor(off / 60) + "";
|
|
var mins = (off % 60) + "";
|
|
if(hours.length == 1) hours = "0" + hours;
|
|
if(mins.length == 1) hours = "0" + mins;
|
|
return ((this.date.getTimezoneOffset() < 0) ? "+" : "-") + hours + mins;
|
|
},
|
|
|
|
P: function(){
|
|
// summary: Difference to Greenwich time (GMT) with colon between hours and minutes (added in PHP 5.1.3)
|
|
var O = this.O();
|
|
return O.substring(0, 2) + ":" + O.substring(2, 4);
|
|
},
|
|
|
|
T: function(){
|
|
// summary: Timezone abbreviation
|
|
|
|
// Guess...
|
|
return this.e().substring(0, 3);
|
|
},
|
|
|
|
Z: function(){
|
|
// summary:
|
|
// Timezone offset in seconds. The offset for timezones west of UTC is always negative,
|
|
// and for those east of UTC is always positive.
|
|
return this.date.getTimezoneOffset() * -60;
|
|
},
|
|
|
|
// Full Date/Time
|
|
|
|
c: function(){
|
|
// summary: ISO 8601 date (added in PHP 5)
|
|
return this.Y() + "-" + this.m() + "-" + this.d() + "T" + this.h() + ":" + this.i() + ":" + this.s() + this.P();
|
|
},
|
|
|
|
r: function(){
|
|
// summary: RFC 2822 formatted date
|
|
return this.D() + ", " + this.d() + " " + this.M() + " " + this.Y() + " " + this.H() + ":" + this.i() + ":" + this.s() + " " + this.O();
|
|
},
|
|
|
|
U: function(){
|
|
// summary: Seconds since the Unix Epoch (January 1 1970 00:00:00 GMT)
|
|
return Math.floor(this.date.getTime() / 1000);
|
|
}
|
|
|
|
});
|
|
|
|
}
|