mirror of
https://github.com/jquery/jquery-ui.git
synced 2025-01-07 20:34:24 +00:00
Datepicker: Use Globalize 1.0.0
This commit is contained in:
parent
ff4bfd643d
commit
ffc8ab2710
@ -18,7 +18,24 @@
|
||||
$(function() {
|
||||
$( "#datepicker" ).datepicker();
|
||||
$( "#format" ).change(function() {
|
||||
$( "#datepicker" ).datepicker( "option", "dateFormat", $( this ).val() );
|
||||
var format;
|
||||
switch( $( this ).val() ) {
|
||||
case "short":
|
||||
$( "#datepicker" ).datepicker( "option", "dateFormat", {
|
||||
date: "short"
|
||||
});
|
||||
break;
|
||||
case "long":
|
||||
$( "#datepicker" ).datepicker( "option", "dateFormat", {
|
||||
date: "long"
|
||||
});
|
||||
break;
|
||||
case "iso":
|
||||
$( "#datepicker" ).datepicker( "option", "dateFormat", {
|
||||
pattern: "yyyy-MM-dd"
|
||||
});
|
||||
break;
|
||||
}
|
||||
});
|
||||
});
|
||||
</script>
|
||||
@ -29,9 +46,9 @@
|
||||
|
||||
<p>Format options:<br />
|
||||
<select id="format">
|
||||
<option value="d">Default - M/d/yyyy</option>
|
||||
<option value="D">Long - dddd, MMMM dd, yyyy</option>
|
||||
<option value="yyyy-MM-dd">ISO 8601 - yyyy-MM-dd</option>
|
||||
<option value="short">Short - M/d/yy in "en" locale</option>
|
||||
<option value="long">Long - MMMM d, y in "en" locale</option>
|
||||
<option value="iso">ISO 8601 - yyyy-MM-dd</option>
|
||||
</select>
|
||||
</p>
|
||||
|
||||
|
@ -6,8 +6,6 @@
|
||||
<link rel="stylesheet" href="../../themes/base/all.css">
|
||||
<script src="../../external/jquery/jquery.js"></script>
|
||||
<script src="../../external/globalize/globalize.js"></script>
|
||||
<script src="../../external/globalize/globalize.culture.de-DE.js"></script>
|
||||
<script src="../../external/globalize/globalize.culture.ja-JP.js"></script>
|
||||
<script src="../../external/date.js"></script>
|
||||
<script src="../../external/localization.js"></script>
|
||||
<script src="../../ui/core.js"></script>
|
||||
@ -18,11 +16,11 @@
|
||||
<link rel="stylesheet" href="../demos.css">
|
||||
<script>
|
||||
$(function() {
|
||||
Globalize.culture( "de-DE" );
|
||||
Globalize.locale( "de-DE" );
|
||||
$( "#datepicker" ).datepicker();
|
||||
$( "#locale" ).change(function() {
|
||||
// TODO refresh the current value to convert to the selected culture
|
||||
Globalize.culture( $(this).val() );
|
||||
// TODO refresh the current value to convert to the selected locale
|
||||
Globalize.locale( $(this).val() );
|
||||
});
|
||||
});
|
||||
</script>
|
||||
@ -32,7 +30,6 @@
|
||||
<p>Date: <input type="text" id="datepicker"/>
|
||||
<select id="locale">
|
||||
<option value="de-DE" selected>German (Deutsch)</option>
|
||||
<option value="ja-JP">Japanese (日本語</option>
|
||||
<option value="en">English</option>
|
||||
</select></p>
|
||||
|
||||
|
@ -17,8 +17,7 @@
|
||||
<script>
|
||||
$(function() {
|
||||
$( "#datepicker" ).datepicker({
|
||||
showWeek: true,
|
||||
firstDay: 1
|
||||
showWeek: true
|
||||
});
|
||||
});
|
||||
</script>
|
||||
@ -28,10 +27,9 @@
|
||||
<p>Date: <input type="text" id="datepicker"></p>
|
||||
|
||||
<div class="demo-description">
|
||||
<p>The datepicker can show the week of the year. The default calculation follows
|
||||
the ISO 8601 definition: the week starts on Monday, the first week of the year
|
||||
contains the first Thursday of the year. This means that some days from one
|
||||
year may be placed into weeks 'belonging' to another year.</p>
|
||||
<p>The datepicker can show the week of the year. The calculation follows
|
||||
<a href="http://www.unicode.org/reports/tr35 /tr35-dates.html#Date_Field_Symbol_Table">Unicode CLDR specification</a>.
|
||||
This means that some days from one year may be placed into weeks 'belonging' to another year.</p>
|
||||
</div>
|
||||
</body>
|
||||
</html>
|
||||
|
73
external/date.js
vendored
73
external/date.js
vendored
@ -6,25 +6,31 @@
|
||||
*/
|
||||
(function( $, undefined ) {
|
||||
|
||||
$.date = function( datestring, formatstring ) {
|
||||
//TODO: Need to refactor $.date to be a constructor, move the methods to a prototype.
|
||||
var calendar = Globalize.culture().calendar,
|
||||
format = formatstring ? formatstring : calendar.patterns.d,
|
||||
date = datestring ? Globalize.parseDate( datestring, format ) : new Date();
|
||||
var weekdays = [ "sun", "mon", "tue", "wed", "thu", "fri", "sat" ],
|
||||
weekdaysRev = {
|
||||
"sun": 0,
|
||||
"mon": 1,
|
||||
"tue": 2,
|
||||
"wed": 3,
|
||||
"thu": 4,
|
||||
"fri": 5,
|
||||
"sat": 6
|
||||
};
|
||||
|
||||
if ( !date ) {
|
||||
date = new Date();
|
||||
Globalize.locale( "en" );
|
||||
|
||||
$.date = function( date, globalFormat ) {
|
||||
//TODO: Need to refactor $.date to be a constructor, move the methods to a prototype.
|
||||
if ( typeof date === "string" && date.length ) {
|
||||
date = Globalize.parseDate( date, globalFormat );
|
||||
}
|
||||
|
||||
date = date || new Date();
|
||||
|
||||
return {
|
||||
refresh: function() {
|
||||
calendar = Globalize.culture().calendar;
|
||||
format = formatstring || calendar.patterns.d;
|
||||
return this;
|
||||
},
|
||||
setFormat: function( formatstring ) {
|
||||
if ( formatstring ) {
|
||||
format = formatstring;
|
||||
setFormat: function( format ) {
|
||||
if ( format ) {
|
||||
globalFormat = format;
|
||||
}
|
||||
return this;
|
||||
},
|
||||
@ -82,7 +88,7 @@ $.date = function( datestring, formatstring ) {
|
||||
return 32 - new Date( year, month, 32 ).getDate();
|
||||
},
|
||||
monthName: function() {
|
||||
return calendar.months.names[ date.getMonth() ];
|
||||
return Globalize.format( date, { pattern: "MMMM" } );
|
||||
},
|
||||
day: function() {
|
||||
return date.getDate();
|
||||
@ -101,10 +107,10 @@ $.date = function( datestring, formatstring ) {
|
||||
weekdays: function() {
|
||||
var result = [];
|
||||
for ( var dow = 0; dow < 7; dow++ ) {
|
||||
var day = ( dow + calendar.firstDay ) % 7;
|
||||
var day = ( dow + weekdaysRev[ Globalize.locale().supplemental.weekData.firstDay() ] ) % 7;
|
||||
result.push({
|
||||
shortname: calendar.days.namesShort[ day ],
|
||||
fullname: calendar.days.names[ day ]
|
||||
shortname: Globalize.locale().main([ "dates/calendars/gregorian/days/format/abbreviated", weekdays[ day ] ]),
|
||||
fullname: Globalize.locale().main([ "dates/calendars/gregorian/days/format/wide", weekdays[ day ] ]),
|
||||
});
|
||||
}
|
||||
return result;
|
||||
@ -113,12 +119,12 @@ $.date = function( datestring, formatstring ) {
|
||||
var result = [],
|
||||
today = $.date(),
|
||||
firstDayOfMonth = new Date( this.year(), date.getMonth(), 1 ).getDay(),
|
||||
leadDays = ( firstDayOfMonth - calendar.firstDay + 7 ) % 7,
|
||||
leadDays = ( firstDayOfMonth - weekdaysRev[ Globalize.locale().supplemental.weekData.firstDay() ] + 7 ) % 7,
|
||||
rows = Math.ceil( ( leadDays + this.daysInMonth() ) / 7 ),
|
||||
printDate = new Date( this.year(), date.getMonth(), 1 - leadDays );
|
||||
for ( var row = 0; row < rows; row++ ) {
|
||||
var week = result[ result.length ] = {
|
||||
number: this.iso8601Week( printDate ),
|
||||
number: Globalize.format( printDate, { pattern: "w" } ),
|
||||
days: []
|
||||
};
|
||||
for ( var dayx = 0; dayx < 7; dayx++ ) {
|
||||
@ -153,16 +159,6 @@ $.date = function( datestring, formatstring ) {
|
||||
result[ result.length - 1 ].last = true;
|
||||
return result;
|
||||
},
|
||||
iso8601Week: function(date) {
|
||||
var checkDate = new Date( date.getTime() );
|
||||
// Find Thursday of this week starting on Monday
|
||||
checkDate.setDate( checkDate.getDate() + 4 - ( checkDate.getDay() || 7 ) );
|
||||
var time = checkDate.getTime();
|
||||
// Compare with Jan 1
|
||||
checkDate.setMonth( 0 );
|
||||
checkDate.setDate( 1 );
|
||||
return Math.floor( Math.round( ( time - checkDate ) / 86400000) / 7 ) + 1;
|
||||
},
|
||||
select: function() {
|
||||
this.selected = this.clone();
|
||||
return this;
|
||||
@ -170,27 +166,20 @@ $.date = function( datestring, formatstring ) {
|
||||
clone: function() {
|
||||
return $.date( new Date(date.getFullYear(), date.getMonth(),
|
||||
date.getDate(), date.getHours(),
|
||||
date.getMinutes(), date.getSeconds()), formatstring );
|
||||
date.getMinutes(), date.getSeconds()), globalFormat );
|
||||
},
|
||||
// TODO compare year, month, day each for better performance
|
||||
equal: function( other ) {
|
||||
function format( date ) {
|
||||
return Globalize.format( date, "d" );
|
||||
return Globalize.format( date, { pattern: "yyyyMMdd" } );
|
||||
}
|
||||
return format( date ) === format( other );
|
||||
},
|
||||
date: function() {
|
||||
return date;
|
||||
},
|
||||
format: function( formatstring ) {
|
||||
return Globalize.format( date, formatstring ? formatstring : format );
|
||||
},
|
||||
calendar: function( newcalendar ) {
|
||||
if ( newcalendar ) {
|
||||
calendar = newcalendar;
|
||||
return this;
|
||||
}
|
||||
return calendar;
|
||||
format: function( format ) {
|
||||
return Globalize.format( date, format || globalFormat );
|
||||
}
|
||||
};
|
||||
};
|
||||
|
81
external/globalize/globalize.culture.de-DE.js
vendored
81
external/globalize/globalize.culture.de-DE.js
vendored
@ -1,81 +0,0 @@
|
||||
/*
|
||||
* Globalize Culture de-DE
|
||||
*
|
||||
* http://github.com/jquery/globalize
|
||||
*
|
||||
* Copyright Software Freedom Conservancy, Inc.
|
||||
* Dual licensed under the MIT or GPL Version 2 licenses.
|
||||
* http://jquery.org/license
|
||||
*
|
||||
* This file was generated by the Globalize Culture Generator
|
||||
* Translation: bugs found in this file need to be fixed in the generator
|
||||
*/
|
||||
|
||||
(function( window, undefined ) {
|
||||
|
||||
var Globalize;
|
||||
|
||||
if ( typeof require !== "undefined"
|
||||
&& typeof exports !== "undefined"
|
||||
&& typeof module !== "undefined" ) {
|
||||
// Assume CommonJS
|
||||
Globalize = require( "globalize" );
|
||||
} else {
|
||||
// Global variable
|
||||
Globalize = window.Globalize;
|
||||
}
|
||||
|
||||
Globalize.addCultureInfo( "de-DE", "default", {
|
||||
name: "de-DE",
|
||||
englishName: "German (Germany)",
|
||||
nativeName: "Deutsch (Deutschland)",
|
||||
language: "de",
|
||||
numberFormat: {
|
||||
",": ".",
|
||||
".": ",",
|
||||
NaN: "n. def.",
|
||||
negativeInfinity: "-unendlich",
|
||||
positiveInfinity: "+unendlich",
|
||||
percent: {
|
||||
pattern: ["-n%","n%"],
|
||||
",": ".",
|
||||
".": ","
|
||||
},
|
||||
currency: {
|
||||
pattern: ["-n $","n $"],
|
||||
",": ".",
|
||||
".": ",",
|
||||
symbol: "€"
|
||||
}
|
||||
},
|
||||
calendars: {
|
||||
standard: {
|
||||
"/": ".",
|
||||
firstDay: 1,
|
||||
days: {
|
||||
names: ["Sonntag","Montag","Dienstag","Mittwoch","Donnerstag","Freitag","Samstag"],
|
||||
namesAbbr: ["So","Mo","Di","Mi","Do","Fr","Sa"],
|
||||
namesShort: ["So","Mo","Di","Mi","Do","Fr","Sa"]
|
||||
},
|
||||
months: {
|
||||
names: ["Januar","Februar","März","April","Mai","Juni","Juli","August","September","Oktober","November","Dezember",""],
|
||||
namesAbbr: ["Jan","Feb","Mrz","Apr","Mai","Jun","Jul","Aug","Sep","Okt","Nov","Dez",""]
|
||||
},
|
||||
AM: null,
|
||||
PM: null,
|
||||
eras: [{"name":"n. Chr.","start":null,"offset":0}],
|
||||
patterns: {
|
||||
d: "dd.MM.yyyy",
|
||||
D: "dddd, d. MMMM yyyy",
|
||||
t: "HH:mm",
|
||||
T: "HH:mm:ss",
|
||||
f: "dddd, d. MMMM yyyy HH:mm",
|
||||
F: "dddd, d. MMMM yyyy HH:mm:ss",
|
||||
M: "dd MMMM",
|
||||
Y: "MMMM yyyy"
|
||||
}
|
||||
}
|
||||
}
|
||||
});
|
||||
|
||||
}( this ));
|
100
external/globalize/globalize.culture.ja-JP.js
vendored
100
external/globalize/globalize.culture.ja-JP.js
vendored
@ -1,100 +0,0 @@
|
||||
/*
|
||||
* Globalize Culture ja-JP
|
||||
*
|
||||
* http://github.com/jquery/globalize
|
||||
*
|
||||
* Copyright Software Freedom Conservancy, Inc.
|
||||
* Dual licensed under the MIT or GPL Version 2 licenses.
|
||||
* http://jquery.org/license
|
||||
*
|
||||
* This file was generated by the Globalize Culture Generator
|
||||
* Translation: bugs found in this file need to be fixed in the generator
|
||||
*/
|
||||
|
||||
(function( window, undefined ) {
|
||||
|
||||
var Globalize;
|
||||
|
||||
if ( typeof require !== "undefined"
|
||||
&& typeof exports !== "undefined"
|
||||
&& typeof module !== "undefined" ) {
|
||||
// Assume CommonJS
|
||||
Globalize = require( "globalize" );
|
||||
} else {
|
||||
// Global variable
|
||||
Globalize = window.Globalize;
|
||||
}
|
||||
|
||||
Globalize.addCultureInfo( "ja-JP", "default", {
|
||||
name: "ja-JP",
|
||||
englishName: "Japanese (Japan)",
|
||||
nativeName: "日本語 (日本)",
|
||||
language: "ja",
|
||||
numberFormat: {
|
||||
NaN: "NaN (非数値)",
|
||||
negativeInfinity: "-∞",
|
||||
positiveInfinity: "+∞",
|
||||
percent: {
|
||||
pattern: ["-n%","n%"]
|
||||
},
|
||||
currency: {
|
||||
pattern: ["-$n","$n"],
|
||||
decimals: 0,
|
||||
symbol: "¥"
|
||||
}
|
||||
},
|
||||
calendars: {
|
||||
standard: {
|
||||
days: {
|
||||
names: ["日曜日","月曜日","火曜日","水曜日","木曜日","金曜日","土曜日"],
|
||||
namesAbbr: ["日","月","火","水","木","金","土"],
|
||||
namesShort: ["日","月","火","水","木","金","土"]
|
||||
},
|
||||
months: {
|
||||
names: ["1月","2月","3月","4月","5月","6月","7月","8月","9月","10月","11月","12月",""],
|
||||
namesAbbr: ["1","2","3","4","5","6","7","8","9","10","11","12",""]
|
||||
},
|
||||
AM: ["午前","午前","午前"],
|
||||
PM: ["午後","午後","午後"],
|
||||
eras: [{"name":"西暦","start":null,"offset":0}],
|
||||
patterns: {
|
||||
d: "yyyy/MM/dd",
|
||||
D: "yyyy'年'M'月'd'日'",
|
||||
t: "H:mm",
|
||||
T: "H:mm:ss",
|
||||
f: "yyyy'年'M'月'd'日' H:mm",
|
||||
F: "yyyy'年'M'月'd'日' H:mm:ss",
|
||||
M: "M'月'd'日'",
|
||||
Y: "yyyy'年'M'月'"
|
||||
}
|
||||
},
|
||||
Japanese: {
|
||||
name: "Japanese",
|
||||
days: {
|
||||
names: ["日曜日","月曜日","火曜日","水曜日","木曜日","金曜日","土曜日"],
|
||||
namesAbbr: ["日","月","火","水","木","金","土"],
|
||||
namesShort: ["日","月","火","水","木","金","土"]
|
||||
},
|
||||
months: {
|
||||
names: ["1月","2月","3月","4月","5月","6月","7月","8月","9月","10月","11月","12月",""],
|
||||
namesAbbr: ["1","2","3","4","5","6","7","8","9","10","11","12",""]
|
||||
},
|
||||
AM: ["午前","午前","午前"],
|
||||
PM: ["午後","午後","午後"],
|
||||
eras: [{"name":"平成","start":null,"offset":1867},{"name":"昭和","start":-1812153600000,"offset":1911},{"name":"大正","start":-1357603200000,"offset":1925},{"name":"明治","start":60022080000,"offset":1988}],
|
||||
twoDigitYearMax: 99,
|
||||
patterns: {
|
||||
d: "gg y/M/d",
|
||||
D: "gg y'年'M'月'd'日'",
|
||||
t: "H:mm",
|
||||
T: "H:mm:ss",
|
||||
f: "gg y'年'M'月'd'日' H:mm",
|
||||
F: "gg y'年'M'月'd'日' H:mm:ss",
|
||||
M: "M'月'd'日'",
|
||||
Y: "gg y'年'M'月'"
|
||||
}
|
||||
}
|
||||
}
|
||||
});
|
||||
|
||||
}( this ));
|
3205
external/globalize/globalize.js
vendored
3205
external/globalize/globalize.js
vendored
File diff suppressed because it is too large
Load Diff
3549
external/localization.js
vendored
3549
external/localization.js
vendored
File diff suppressed because it is too large
Load Diff
@ -12,9 +12,9 @@
|
||||
<script>
|
||||
TestHelpers.loadResources({
|
||||
js: [
|
||||
"external/date.js",
|
||||
"external/globalize.js",
|
||||
"external/globalize.culture.de-DE.js"
|
||||
"external/localization.js",
|
||||
"external/date.js"
|
||||
]
|
||||
});
|
||||
</script>
|
||||
@ -37,4 +37,4 @@
|
||||
|
||||
</div>
|
||||
</body>
|
||||
</html>
|
||||
</html>
|
||||
|
@ -53,29 +53,28 @@ test("Date Adjustments - Leap Year Edge Cases", 1, function(){
|
||||
test("List days of Week", 2, function(){
|
||||
var date = $.date(),
|
||||
offset0 = [
|
||||
{ "fullname": "Sunday", "shortname": "Su" },
|
||||
{ "fullname": "Monday", "shortname": "Mo" },
|
||||
{ "fullname": "Tuesday", "shortname": "Tu" },
|
||||
{ "fullname": "Wednesday", "shortname": "We" },
|
||||
{ "fullname": "Thursday", "shortname": "Th" },
|
||||
{ "fullname": "Friday", "shortname": "Fr" },
|
||||
{ "fullname": "Saturday", "shortname": "Sa" }
|
||||
{ "fullname": "Sunday", "shortname": "Sun" },
|
||||
{ "fullname": "Monday", "shortname": "Mon" },
|
||||
{ "fullname": "Tuesday", "shortname": "Tue" },
|
||||
{ "fullname": "Wednesday", "shortname": "Wed" },
|
||||
{ "fullname": "Thursday", "shortname": "Thu" },
|
||||
{ "fullname": "Friday", "shortname": "Fri" },
|
||||
{ "fullname": "Saturday", "shortname": "Sat" }
|
||||
],
|
||||
offset1 = [
|
||||
{ "fullname": "Montag", "shortname": "Mo" },
|
||||
{ "fullname": "Dienstag", "shortname": "Di" },
|
||||
{ "fullname": "Mittwoch", "shortname": "Mi" },
|
||||
{ "fullname": "Donnerstag", "shortname": "Do" },
|
||||
{ "fullname": "Freitag", "shortname": "Fr" },
|
||||
{ "fullname": "Samstag", "shortname": "Sa" },
|
||||
{ "fullname": "Sonntag", "shortname": "So" }
|
||||
{ "fullname": "Montag", "shortname": "Mo." },
|
||||
{ "fullname": "Dienstag", "shortname": "Di." },
|
||||
{ "fullname": "Mittwoch", "shortname": "Mi." },
|
||||
{ "fullname": "Donnerstag", "shortname": "Do." },
|
||||
{ "fullname": "Freitag", "shortname": "Fr." },
|
||||
{ "fullname": "Samstag", "shortname": "Sa." },
|
||||
{ "fullname": "Sonntag", "shortname": "So." }
|
||||
];
|
||||
deepEqual(date.weekdays(), offset0, "Get weekdays with start of day on 0 (English)");
|
||||
Globalize.culture( "de-DE" );
|
||||
date.refresh();
|
||||
Globalize.locale( "de-DE" );
|
||||
deepEqual(date.weekdays(), offset1, "Get weekdays with start of day on 1 (Germany)");
|
||||
//Revert Globalize changes back to English
|
||||
Globalize.culture("en-EN");
|
||||
Globalize.locale( "en" );
|
||||
});
|
||||
|
||||
test("Leap Year Check", 8, function(){
|
||||
@ -101,10 +100,9 @@ test("Days in Month", 3, function(){
|
||||
test("Month Name", 2, function(){
|
||||
var date = $.date();
|
||||
equal(date.setMonth(3).monthName(), "April", "Month name return April (English)");
|
||||
Globalize.culture( "de-DE" );
|
||||
date.refresh();
|
||||
Globalize.locale( "de-DE" );
|
||||
equal(date.setMonth(2).monthName(), "März", "Month name return March (German)");
|
||||
Globalize.culture("en-EN");
|
||||
Globalize.locale( "en" );
|
||||
|
||||
});
|
||||
|
||||
@ -154,13 +152,6 @@ test( "Months", 5, function(){
|
||||
ok( firstMonth.month() === lastMonth.month() - 1 );
|
||||
});
|
||||
|
||||
test("iso8601Week", 2, function(){
|
||||
var date = $.date();
|
||||
//date.setFullDate(2012, 0, 8);
|
||||
equal(date.iso8601Week(new Date(2012, 0, 8)), 1, "Test first week is 1");
|
||||
equal(date.iso8601Week(new Date(2012, 11, 31)), 1, "Test last week is 1 in next year");
|
||||
});
|
||||
|
||||
test("Equal", 4, function(){
|
||||
var date = $.date();
|
||||
date.setFullDate(2012, 9, 16);
|
||||
@ -178,45 +169,8 @@ test("Date", 1, function(){
|
||||
test("Format", 4, function(){
|
||||
var date = $.date();
|
||||
date.setFullDate(2012, 9, 16);
|
||||
equal(date.format(), "10/16/2012", "Checking default US format");
|
||||
equal(date.format("yyyy/MM/dd"), "2012/10/16", "Checking yyyy/MM/dd format");
|
||||
equal(date.format("yy/dd/MM"), "12/16/10", "Checking yy/dd/MM format");
|
||||
equal(date.format("MMMM dd, yyyy"), "October 16, 2012", "Checking MMMM dd, yyyy format");
|
||||
});
|
||||
|
||||
test("Calendar", 3, function(){
|
||||
var date = $.date(),
|
||||
de_cal = {
|
||||
calendars: {
|
||||
standard: {
|
||||
"/": ".",
|
||||
firstDay: 1,
|
||||
days: {
|
||||
names: ["Sonntag","Montag","Dienstag","Mittwoch","Donnerstag","Freitag","Samstag"],
|
||||
namesAbbr: ["So","Mo","Di","Mi","Do","Fr","Sa"],
|
||||
namesShort: ["So","Mo","Di","Mi","Do","Fr","Sa"]
|
||||
},
|
||||
months: {
|
||||
names: ["Januar","Februar","März","April","Mai","Juni","Juli","August","September","Oktober","November","Dezember",""],
|
||||
namesAbbr: ["Jan","Feb","Mrz","Apr","Mai","Jun","Jul","Aug","Sep","Okt","Nov","Dez",""]
|
||||
},
|
||||
AM: null,
|
||||
PM: null,
|
||||
eras: [{"name":"n. Chr.","start":null,"offset":0}],
|
||||
patterns: {
|
||||
d: "dd.MM.yyyy",
|
||||
D: "dddd, d. MMMM yyyy",
|
||||
t: "HH:mm",
|
||||
T: "HH:mm:ss",
|
||||
f: "dddd, d. MMMM yyyy HH:mm",
|
||||
F: "dddd, d. MMMM yyyy HH:mm:ss",
|
||||
M: "dd MMMM",
|
||||
Y: "MMMM yyyy"
|
||||
}
|
||||
}
|
||||
}
|
||||
};
|
||||
ok(date.calendar(), "Calendar type returned");
|
||||
ok(date.calendar(de_cal), "Calendar type changed");
|
||||
deepEqual(date.calendar(), de_cal, "Calendar change verified");
|
||||
equal(date.format({ date: "short" }), "10/16/12", "Checking default US format");
|
||||
equal(date.format({ pattern: "yyyy/MM/dd" }), "2012/10/16", "Checking yyyy/MM/dd format");
|
||||
equal(date.format({ pattern: "yy/dd/MM" }), "12/16/10", "Checking yy/dd/MM format");
|
||||
equal(date.format({ pattern: "MMMM dd, yyyy" }), "October 16, 2012", "Checking MMMM dd, yyyy format");
|
||||
});
|
||||
|
@ -8,8 +8,8 @@
|
||||
<link rel="stylesheet" href="../../../external/qunit/qunit.css">
|
||||
<script src="../../../external/qunit/qunit.js"></script>
|
||||
<script src="../../../external/jquery-simulate/jquery.simulate.js"></script>
|
||||
<script src="../../../external/date.js"></script>
|
||||
<script src="../../../external/globalize/globalize.js"></script>
|
||||
<script src="../../../external/date.js"></script>
|
||||
<script src="../../../external/localization.js"></script>
|
||||
<script src="../testsuite.js"></script>
|
||||
<script>
|
||||
@ -21,10 +21,6 @@
|
||||
"ui/button.js",
|
||||
"ui/position.js",
|
||||
"ui/datepicker.js"
|
||||
/* TODO: Replace with Globalize cultures
|
||||
"ui/i18n/datepicker-fr.js",
|
||||
"ui/i18n/datepicker-he.js",
|
||||
"ui/i18n/datepicker-zh-CN.js"*/
|
||||
]
|
||||
});
|
||||
</script>
|
||||
|
@ -7,7 +7,7 @@ TestHelpers.testJshint( "datepicker" );
|
||||
test( "input's value determines starting date", function() {
|
||||
expect( 3 );
|
||||
|
||||
var input = $( "#datepicker" ).val( "1/1/2014" ).datepicker(),
|
||||
var input = $( "#datepicker" ).val( "1/1/14" ).datepicker(),
|
||||
picker = input.datepicker( "widget" );
|
||||
|
||||
input.datepicker( "open" );
|
||||
@ -228,19 +228,19 @@ test( "Keyboard handling", function() {
|
||||
TestHelpers.datepicker.equalsDate( input.datepicker( "valueAsDate" ), date, "Keystroke enter" );
|
||||
|
||||
// Enter = Select today's date by default
|
||||
input.val( "1/1/2014" ).datepicker( "open" )
|
||||
input.val( "1/1/14" ).datepicker( "open" )
|
||||
.simulate("keydown", { keyCode: $.ui.keyCode.ENTER });
|
||||
TestHelpers.datepicker.equalsDate( input.datepicker( "valueAsDate" ), new Date( 2014, 0, 1 ),
|
||||
"Keystroke enter - preset" );
|
||||
|
||||
// Control + Home = Change the calendar to the current month
|
||||
input.val( "1/1/2014" ).datepicker( "open" )
|
||||
input.val( "1/1/14" ).datepicker( "open" )
|
||||
.simulate( "keydown", { ctrlKey: true, keyCode: $.ui.keyCode.HOME })
|
||||
.simulate( "keydown", { keyCode: $.ui.keyCode.ENTER });
|
||||
TestHelpers.datepicker.equalsDate( input.datepicker( "valueAsDate" ), date, "Keystroke ctrl+home" );
|
||||
|
||||
// Control + End = Close the calendar and clear the input
|
||||
input.val( "1/1/2014" ).datepicker( "open" )
|
||||
input.val( "1/1/14" ).datepicker( "open" )
|
||||
.simulate( "keydown", { ctrlKey: true, keyCode: $.ui.keyCode.END });
|
||||
equal( input.val(), "", "Keystroke ctrl+end" );
|
||||
|
||||
@ -249,12 +249,12 @@ test( "Keyboard handling", function() {
|
||||
input.simulate( "keydown", { keyCode: $.ui.keyCode.ESCAPE });
|
||||
ok( !instance.isOpen, "escape closes the datepicker" );
|
||||
|
||||
input.val( "1/1/2014" ).datepicker( "open" )
|
||||
input.val( "1/1/14" ).datepicker( "open" )
|
||||
.simulate( "keydown", { keyCode: $.ui.keyCode.ESCAPE });
|
||||
TestHelpers.datepicker.equalsDate( input.datepicker( "valueAsDate" ), new Date( 2014, 0, 1 ),
|
||||
"Keystroke esc - preset" );
|
||||
|
||||
input.val( "1/1/2014" ).datepicker( "open" )
|
||||
input.val( "1/1/14" ).datepicker( "open" )
|
||||
.simulate( "keydown", { ctrlKey: true, keyCode: $.ui.keyCode.PAGE_UP })
|
||||
.simulate( "keydown", { keyCode: $.ui.keyCode.ESCAPE });
|
||||
TestHelpers.datepicker.equalsDate( input.datepicker( "valueAsDate" ), new Date( 2014, 0, 1 ),
|
||||
|
@ -69,16 +69,16 @@ test( "value", function() {
|
||||
picker = input.datepicker( "widget" ),
|
||||
inline = $( "#inline" ).datepicker();
|
||||
|
||||
input.datepicker( "value", "1/1/2014" );
|
||||
equal( input.val(), "1/1/2014", "input's value set" );
|
||||
input.datepicker( "value", "1/1/14" );
|
||||
equal( input.val(), "1/1/14", "input's value set" );
|
||||
ok( picker.find( "a[data-timestamp]:first" ).hasClass( "ui-state-focus" ),
|
||||
"first day marked as selected" );
|
||||
equal( input.datepicker( "value" ), "1/1/2014", "getter" );
|
||||
equal( input.datepicker( "value" ), "1/1/14", "getter" );
|
||||
|
||||
inline.datepicker( "value", "1/1/2014" );
|
||||
inline.datepicker( "value", "1/1/14" );
|
||||
ok( inline.find( "a[data-timestamp]:first" ).hasClass( "ui-state-focus" ),
|
||||
"first day marked as selected" );
|
||||
equal( inline.datepicker( "value" ), "1/1/2014", "getter" );
|
||||
equal( inline.datepicker( "value" ), "1/1/14", "getter" );
|
||||
|
||||
// TODO: Handle for invalid values.
|
||||
|
||||
@ -93,7 +93,7 @@ test( "valueAsDate", function() {
|
||||
inline = $( "#inline" ).datepicker();
|
||||
|
||||
input.datepicker( "valueAsDate", new Date( 2014, 0, 1 ) );
|
||||
equal( input.val(), "1/1/2014", "input's value set" );
|
||||
equal( input.val(), "1/1/14", "input's value set" );
|
||||
ok( picker.find( "a[data-timestamp]:first" ).hasClass( "ui-state-focus" ),
|
||||
"first day marked as selected" );
|
||||
TestHelpers.datepicker.equalsDate( input.datepicker( "valueAsDate" ),
|
||||
|
@ -42,16 +42,16 @@ test( "appendTo", function() {
|
||||
|
||||
test( "dateFormat", function() {
|
||||
expect( 2 );
|
||||
var input = $( "#datepicker" ).val( "1/1/2014" ).datepicker(),
|
||||
var input = $( "#datepicker" ).val( "1/1/14" ).datepicker(),
|
||||
picker = input.datepicker( "widget" ),
|
||||
firstDayLink = picker.find( "td[id]:first a" );
|
||||
|
||||
input.datepicker( "open" );
|
||||
firstDayLink.trigger( "mousedown" );
|
||||
equal( input.val(), "1/1/2014", "default formatting" );
|
||||
equal( input.val(), "1/1/14", "default formatting" );
|
||||
|
||||
input.datepicker( "option", "dateFormat", "D" );
|
||||
equal( input.val(), "Wednesday, January 01, 2014", "updated formatting" );
|
||||
input.datepicker( "option", "dateFormat", { date: "full" } );
|
||||
equal( input.val(), "Wednesday, January 1, 2014", "updated formatting" );
|
||||
|
||||
input.datepicker( "destroy" );
|
||||
});
|
||||
|
@ -58,6 +58,7 @@ $.widget( "ui.datepicker", {
|
||||
select: null
|
||||
},
|
||||
_create: function() {
|
||||
this.options.dateFormat = this.options.dateFormat || { date: "short" };
|
||||
this.date = $.date( null, this.options.dateFormat );
|
||||
|
||||
this.date.eachDay = this.options.eachDay;
|
||||
@ -309,8 +310,6 @@ $.widget( "ui.datepicker", {
|
||||
return element;
|
||||
},
|
||||
_createTmpl: function() {
|
||||
this.date.refresh();
|
||||
|
||||
this._createDatepicker();
|
||||
this.picker.find( "button" ).button();
|
||||
|
||||
@ -351,6 +350,7 @@ $.widget( "ui.datepicker", {
|
||||
i = 0;
|
||||
|
||||
for ( i; i < months.length; i++ ) {
|
||||
// TODO Shouldn't we pass date as a parameter to build* fns instead of setting this.date?
|
||||
this.date = months[ i ];
|
||||
headerClass = months[ i ].first ? "ui-corner-left" :
|
||||
months[ i ].last ? "ui-corner-right" : "";
|
||||
@ -384,7 +384,7 @@ $.widget( "ui.datepicker", {
|
||||
"</div>";
|
||||
},
|
||||
_buildPreviousLink: function() {
|
||||
var labels = Globalize.localize( "datepicker" );
|
||||
var labels = Globalize.translate( "datepicker" );
|
||||
return "<button class='ui-datepicker-prev ui-corner-all' " +
|
||||
"title='" + labels.prevText + "'>" +
|
||||
"<span class='ui-icon ui-icon-circle-triangle-w'>" +
|
||||
@ -393,7 +393,7 @@ $.widget( "ui.datepicker", {
|
||||
"</button>";
|
||||
},
|
||||
_buildNextLink: function() {
|
||||
var labels = Globalize.localize( "datepicker" );
|
||||
var labels = Globalize.translate( "datepicker" );
|
||||
return "<button class='ui-datepicker-next ui-corner-all' " +
|
||||
"title='" + labels.nextText + "'>" +
|
||||
"<span class='ui-icon ui-icon-circle-triangle-e'>" +
|
||||
@ -402,7 +402,7 @@ $.widget( "ui.datepicker", {
|
||||
"</button>";
|
||||
},
|
||||
_buildTitlebar: function() {
|
||||
var labels = Globalize.localize( "datepicker" );
|
||||
var labels = Globalize.translate( "datepicker" );
|
||||
return "<div role='header' id='" + this.id + "-title'>" +
|
||||
"<div id='" + this.id + "-month-lbl' class='ui-datepicker-title'>" +
|
||||
this._buildTitle() +
|
||||
@ -428,7 +428,7 @@ $.widget( "ui.datepicker", {
|
||||
_buildGridHeading: function() {
|
||||
var cells = "",
|
||||
i = 0,
|
||||
labels = Globalize.localize( "datepicker" );
|
||||
labels = Globalize.translate( "datepicker" );
|
||||
|
||||
if ( this.options.showWeek ) {
|
||||
cells += "<th class='ui-datepicker-week-col'>" + labels.weekHeader + "</th>";
|
||||
@ -448,10 +448,12 @@ $.widget( "ui.datepicker", {
|
||||
"</th>";
|
||||
},
|
||||
_buildGridBody: function() {
|
||||
var rows = "",
|
||||
i = 0;
|
||||
for ( i; i < this.date.days().length; i++ ) {
|
||||
rows += this._buildWeekRow( this.date.days()[i] );
|
||||
// this.date.days() is not cached, and it has O(n^2) complexity. It is run O(n) times. So, it equals O(n^3). Not good at all. Caching.
|
||||
var days = this.date.days(),
|
||||
i = 0,
|
||||
rows = "";
|
||||
for ( i; i < days.length; i++ ) {
|
||||
rows += this._buildWeekRow( days[i] );
|
||||
}
|
||||
return "<tbody role='presentation'>" + rows + "</tbody>";
|
||||
},
|
||||
@ -488,7 +490,7 @@ $.widget( "ui.datepicker", {
|
||||
_buildDayLink: function( day ) {
|
||||
var link,
|
||||
classes = [ "ui-state-default" ],
|
||||
labels = Globalize.localize( "datepicker" );
|
||||
labels = Globalize.translate( "datepicker" );
|
||||
|
||||
if ( day.date === this.date.day() ) {
|
||||
classes.push( "ui-state-focus" );
|
||||
@ -526,7 +528,7 @@ $.widget( "ui.datepicker", {
|
||||
day.date + "</span>";
|
||||
},
|
||||
_buildButtons: function() {
|
||||
var labels = Globalize.localize( "datepicker" );
|
||||
var labels = Globalize.translate( "datepicker" );
|
||||
return "<div class='ui-datepicker-buttonpane ui-widget-content'>" +
|
||||
"<button class='ui-datepicker-current'>" + labels.currentText + "</button>" +
|
||||
"<button class='ui-datepicker-close'>" + labels.closeText + "</button>" +
|
||||
@ -544,8 +546,6 @@ $.widget( "ui.datepicker", {
|
||||
refresh: function() {
|
||||
//determine which day gridcell to focus after refresh
|
||||
//TODO: Prevent disabled cells from being focused
|
||||
this.date.refresh();
|
||||
|
||||
if ( this.options.numberOfMonths === 1 ) {
|
||||
this.grid = $( this._buildGrid() );
|
||||
$( ".ui-datepicker-title", this.picker ).html( this._buildTitle() );
|
||||
|
Loading…
Reference in New Issue
Block a user