|
|
|
@ -1,10 +1,10 @@
|
|
|
|
|
/*
|
|
|
|
|
* jQuery timepicker addon
|
|
|
|
|
* By: Trent Richardson [http://trentrichardson.com]
|
|
|
|
|
* Version 0.9.7-dev
|
|
|
|
|
* Last Modified: 07/23/2011
|
|
|
|
|
* Version 0.9.9
|
|
|
|
|
* Last Modified: 02/05/2012
|
|
|
|
|
*
|
|
|
|
|
* Copyright 2011 Trent Richardson
|
|
|
|
|
* Copyright 2012 Trent Richardson
|
|
|
|
|
* Dual licensed under the MIT and GPL licenses.
|
|
|
|
|
* http://trentrichardson.com/Impromptu/GPL-LICENSE.txt
|
|
|
|
|
* http://trentrichardson.com/Impromptu/MIT-LICENSE.txt
|
|
|
|
@ -12,15 +12,15 @@
|
|
|
|
|
* HERES THE CSS:
|
|
|
|
|
* .ui-timepicker-div .ui-widget-header { margin-bottom: 8px; }
|
|
|
|
|
* .ui-timepicker-div dl { text-align: left; }
|
|
|
|
|
* .ui-timepicker-div dl dt { height: 25px; }
|
|
|
|
|
* .ui-timepicker-div dl dd { margin: -25px 10px 10px 65px; }
|
|
|
|
|
* .ui-timepicker-div dl dt { height: 25px; margin-bottom: -25px; }
|
|
|
|
|
* .ui-timepicker-div dl dd { margin: 0 10px 10px 65px; }
|
|
|
|
|
* .ui-timepicker-div td { font-size: 90%; }
|
|
|
|
|
* .ui-tpicker-grid-label { background: none; border: none; margin: 0; padding: 0; }
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
(function($) {
|
|
|
|
|
|
|
|
|
|
$.extend($.ui, { timepicker: { version: "0.9.7" } });
|
|
|
|
|
$.extend($.ui, { timepicker: { version: "0.9.9" } });
|
|
|
|
|
|
|
|
|
|
/* Time picker manager.
|
|
|
|
|
Use the singleton instance of this class, $.timepicker, to interact with the time picker.
|
|
|
|
@ -54,10 +54,10 @@ function Timepicker() {
|
|
|
|
|
showMillisec: false,
|
|
|
|
|
showTimezone: false,
|
|
|
|
|
showTime: true,
|
|
|
|
|
stepHour: 0.05,
|
|
|
|
|
stepMinute: 0.05,
|
|
|
|
|
stepSecond: 0.05,
|
|
|
|
|
stepMillisec: 0.5,
|
|
|
|
|
stepHour: 1,
|
|
|
|
|
stepMinute: 1,
|
|
|
|
|
stepSecond: 1,
|
|
|
|
|
stepMillisec: 1,
|
|
|
|
|
hour: 0,
|
|
|
|
|
minute: 0,
|
|
|
|
|
second: 0,
|
|
|
|
@ -83,10 +83,12 @@ function Timepicker() {
|
|
|
|
|
altFieldTimeOnly: true,
|
|
|
|
|
showTimepicker: true,
|
|
|
|
|
timezoneIso8609: false,
|
|
|
|
|
timezoneList: null
|
|
|
|
|
timezoneList: null,
|
|
|
|
|
addSliderAccess: false,
|
|
|
|
|
sliderAccessArgs: null
|
|
|
|
|
};
|
|
|
|
|
$.extend(this._defaults, this.regional['']);
|
|
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
$.extend(Timepicker.prototype, {
|
|
|
|
|
$input: null,
|
|
|
|
@ -145,7 +147,7 @@ $.extend(Timepicker.prototype, {
|
|
|
|
|
tp_inst._defaults = $.extend({}, this._defaults, inlineSettings, o, {
|
|
|
|
|
beforeShow: function(input, dp_inst) {
|
|
|
|
|
if ($.isFunction(o.beforeShow))
|
|
|
|
|
o.beforeShow(input, dp_inst, tp_inst);
|
|
|
|
|
return o.beforeShow(input, dp_inst, tp_inst);
|
|
|
|
|
},
|
|
|
|
|
onChangeMonthYear: function(year, month, dp_inst) {
|
|
|
|
|
// Update the time as well : this prevents the time from disappearing from the $input field.
|
|
|
|
@ -245,7 +247,7 @@ $.extend(Timepicker.prototype, {
|
|
|
|
|
var dp_dateFormat = $.datepicker._get(this.inst, 'dateFormat');
|
|
|
|
|
// escape special regex characters in the seperator
|
|
|
|
|
var specials = new RegExp("[.*+?|()\\[\\]{}\\\\]", "g");
|
|
|
|
|
regstr = '.{' + dp_dateFormat.length + ',}' + this._defaults.separator.replace(specials, "\\$&") + regstr;
|
|
|
|
|
regstr = '^.{' + dp_dateFormat.length + ',}?' + this._defaults.separator.replace(specials, "\\$&") + regstr;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
treg = timeString.match(new RegExp(regstr, 'i'));
|
|
|
|
@ -341,10 +343,10 @@ $.extend(Timepicker.prototype, {
|
|
|
|
|
// Added by Peter Medeiros:
|
|
|
|
|
// - Figure out what the hour/minute/second max should be based on the step values.
|
|
|
|
|
// - Example: if stepMinute is 15, then minMax is 45.
|
|
|
|
|
hourMax = (o.hourMax - ((o.hourMax - o.hourMin) % o.stepHour)).toFixed(0),
|
|
|
|
|
minMax = (o.minuteMax - ((o.minuteMax - o.minuteMin) % o.stepMinute)).toFixed(0),
|
|
|
|
|
secMax = (o.secondMax - ((o.secondMax - o.secondMin) % o.stepSecond)).toFixed(0),
|
|
|
|
|
millisecMax = (o.millisecMax - ((o.millisecMax - o.millisecMin) % o.stepMillisec)).toFixed(0),
|
|
|
|
|
hourMax = parseInt((o.hourMax - ((o.hourMax - o.hourMin) % o.stepHour)) ,10),
|
|
|
|
|
minMax = parseInt((o.minuteMax - ((o.minuteMax - o.minuteMin) % o.stepMinute)) ,10),
|
|
|
|
|
secMax = parseInt((o.secondMax - ((o.secondMax - o.secondMin) % o.stepSecond)) ,10),
|
|
|
|
|
millisecMax = parseInt((o.millisecMax - ((o.millisecMax - o.millisecMin) % o.stepMillisec)) ,10),
|
|
|
|
|
dp_id = this.inst.id.toString().replace(/([^A-Za-z0-9_])/g, '');
|
|
|
|
|
|
|
|
|
|
// Prevent displaying twice
|
|
|
|
@ -365,10 +367,10 @@ $.extend(Timepicker.prototype, {
|
|
|
|
|
size;
|
|
|
|
|
|
|
|
|
|
// Hours
|
|
|
|
|
html += '<dd class="ui_tpicker_hour"><div id="ui_tpicker_hour_' + dp_id + '"' +
|
|
|
|
|
((o.showHour) ? '' : noDisplay) + '></div>';
|
|
|
|
|
if (o.showHour && o.hourGrid > 0) {
|
|
|
|
|
html += '<dd class="ui_tpicker_hour">' +
|
|
|
|
|
'<div id="ui_tpicker_hour_' + dp_id + '"' + ((o.showHour) ? '' : noDisplay) + '></div>' +
|
|
|
|
|
'<div style="padding-left: 1px"><table class="ui-tpicker-grid-label"><tr>';
|
|
|
|
|
html += '<div style="padding-left: 1px"><table class="ui-tpicker-grid-label"><tr>';
|
|
|
|
|
|
|
|
|
|
for (var h = o.hourMin; h <= hourMax; h += parseInt(o.hourGrid,10)) {
|
|
|
|
|
hourGridSize++;
|
|
|
|
@ -382,70 +384,63 @@ $.extend(Timepicker.prototype, {
|
|
|
|
|
html += '<td>' + tmph + '</td>';
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
html += '</tr></table></div>' +
|
|
|
|
|
'</dd>';
|
|
|
|
|
} else html += '<dd class="ui_tpicker_hour" id="ui_tpicker_hour_' + dp_id + '"' +
|
|
|
|
|
((o.showHour) ? '' : noDisplay) + '></dd>';
|
|
|
|
|
|
|
|
|
|
html += '<dt class="ui_tpicker_minute_label" id="ui_tpicker_minute_label_' + dp_id + '"' +
|
|
|
|
|
((o.showMinute) ? '' : noDisplay) + '>' + o.minuteText + '</dt>';
|
|
|
|
|
html += '</tr></table></div>';
|
|
|
|
|
}
|
|
|
|
|
html += '</dd>';
|
|
|
|
|
|
|
|
|
|
// Minutes
|
|
|
|
|
html += '<dt class="ui_tpicker_minute_label" id="ui_tpicker_minute_label_' + dp_id + '"' +
|
|
|
|
|
((o.showMinute) ? '' : noDisplay) + '>' + o.minuteText + '</dt>'+
|
|
|
|
|
'<dd class="ui_tpicker_minute"><div id="ui_tpicker_minute_' + dp_id + '"' +
|
|
|
|
|
((o.showMinute) ? '' : noDisplay) + '></div>';
|
|
|
|
|
|
|
|
|
|
if (o.showMinute && o.minuteGrid > 0) {
|
|
|
|
|
html += '<dd class="ui_tpicker_minute ui_tpicker_minute_' + o.minuteGrid + '">' +
|
|
|
|
|
'<div id="ui_tpicker_minute_' + dp_id + '"' +
|
|
|
|
|
((o.showMinute) ? '' : noDisplay) + '></div>' +
|
|
|
|
|
'<div style="padding-left: 1px"><table class="ui-tpicker-grid-label"><tr>';
|
|
|
|
|
html += '<div style="padding-left: 1px"><table class="ui-tpicker-grid-label"><tr>';
|
|
|
|
|
|
|
|
|
|
for (var m = o.minuteMin; m <= minMax; m += parseInt(o.minuteGrid,10)) {
|
|
|
|
|
minuteGridSize++;
|
|
|
|
|
html += '<td>' + ((m < 10) ? '0' : '') + m + '</td>';
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
html += '</tr></table></div>' +
|
|
|
|
|
'</dd>';
|
|
|
|
|
} else html += '<dd class="ui_tpicker_minute" id="ui_tpicker_minute_' + dp_id + '"' +
|
|
|
|
|
((o.showMinute) ? '' : noDisplay) + '></dd>';
|
|
|
|
|
html += '</tr></table></div>';
|
|
|
|
|
}
|
|
|
|
|
html += '</dd>';
|
|
|
|
|
|
|
|
|
|
// Seconds
|
|
|
|
|
html += '<dt class="ui_tpicker_second_label" id="ui_tpicker_second_label_' + dp_id + '"' +
|
|
|
|
|
((o.showSecond) ? '' : noDisplay) + '>' + o.secondText + '</dt>';
|
|
|
|
|
((o.showSecond) ? '' : noDisplay) + '>' + o.secondText + '</dt>'+
|
|
|
|
|
'<dd class="ui_tpicker_second"><div id="ui_tpicker_second_' + dp_id + '"'+
|
|
|
|
|
((o.showSecond) ? '' : noDisplay) + '></div>';
|
|
|
|
|
|
|
|
|
|
if (o.showSecond && o.secondGrid > 0) {
|
|
|
|
|
html += '<dd class="ui_tpicker_second ui_tpicker_second_' + o.secondGrid + '">' +
|
|
|
|
|
'<div id="ui_tpicker_second_' + dp_id + '"' +
|
|
|
|
|
((o.showSecond) ? '' : noDisplay) + '></div>' +
|
|
|
|
|
'<div style="padding-left: 1px"><table><tr>';
|
|
|
|
|
html += '<div style="padding-left: 1px"><table><tr>';
|
|
|
|
|
|
|
|
|
|
for (var s = o.secondMin; s <= secMax; s += parseInt(o.secondGrid,10)) {
|
|
|
|
|
secondGridSize++;
|
|
|
|
|
html += '<td>' + ((s < 10) ? '0' : '') + s + '</td>';
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
html += '</tr></table></div>' +
|
|
|
|
|
'</dd>';
|
|
|
|
|
} else html += '<dd class="ui_tpicker_second" id="ui_tpicker_second_' + dp_id + '"' +
|
|
|
|
|
((o.showSecond) ? '' : noDisplay) + '></dd>';
|
|
|
|
|
html += '</tr></table></div>';
|
|
|
|
|
}
|
|
|
|
|
html += '</dd>';
|
|
|
|
|
|
|
|
|
|
// Milliseconds
|
|
|
|
|
html += '<dt class="ui_tpicker_millisec_label" id="ui_tpicker_millisec_label_' + dp_id + '"' +
|
|
|
|
|
((o.showMillisec) ? '' : noDisplay) + '>' + o.millisecText + '</dt>';
|
|
|
|
|
((o.showMillisec) ? '' : noDisplay) + '>' + o.millisecText + '</dt>'+
|
|
|
|
|
'<dd class="ui_tpicker_millisec"><div id="ui_tpicker_millisec_' + dp_id + '"'+
|
|
|
|
|
((o.showMillisec) ? '' : noDisplay) + '></div>';
|
|
|
|
|
|
|
|
|
|
if (o.showMillisec && o.millisecGrid > 0) {
|
|
|
|
|
html += '<dd class="ui_tpicker_millisec ui_tpicker_millisec_' + o.millisecGrid + '">' +
|
|
|
|
|
'<div id="ui_tpicker_millisec_' + dp_id + '"' +
|
|
|
|
|
((o.showMillisec) ? '' : noDisplay) + '></div>' +
|
|
|
|
|
'<div style="padding-left: 1px"><table><tr>';
|
|
|
|
|
html += '<div style="padding-left: 1px"><table><tr>';
|
|
|
|
|
|
|
|
|
|
for (var l = o.millisecMin; l <= millisecMax; l += parseInt(o.millisecGrid,10)) {
|
|
|
|
|
millisecGridSize++;
|
|
|
|
|
html += '<td>' + ((l < 10) ? '0' : '') + s + '</td>';
|
|
|
|
|
html += '<td>' + ((l < 10) ? '0' : '') + l + '</td>';
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
html += '</tr></table></div>' +
|
|
|
|
|
'</dd>';
|
|
|
|
|
} else html += '<dd class="ui_tpicker_millisec" id="ui_tpicker_millisec_' + dp_id + '"' +
|
|
|
|
|
((o.showMillisec) ? '' : noDisplay) + '></dd>';
|
|
|
|
|
html += '</tr></table></div>';
|
|
|
|
|
}
|
|
|
|
|
html += '</dd>';
|
|
|
|
|
|
|
|
|
|
// Timezone
|
|
|
|
|
html += '<dt class="ui_tpicker_timezone_label" id="ui_tpicker_timezone_label_' + dp_id + '"' +
|
|
|
|
@ -477,6 +472,7 @@ $.extend(Timepicker.prototype, {
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Updated by Peter Medeiros:
|
|
|
|
|
// - Pass in Event and UI instance into slide function
|
|
|
|
|
this.minute_slider = $tp.find('#ui_tpicker_minute_'+ dp_id).slider({
|
|
|
|
@ -486,7 +482,6 @@ $.extend(Timepicker.prototype, {
|
|
|
|
|
max: minMax,
|
|
|
|
|
step: o.stepMinute,
|
|
|
|
|
slide: function(event, ui) {
|
|
|
|
|
// update the global minute slider instance value with the current slider value
|
|
|
|
|
tp_inst.minute_slider.slider( "option", "value", ui.value);
|
|
|
|
|
tp_inst._onTimeChange();
|
|
|
|
|
}
|
|
|
|
@ -639,6 +634,32 @@ $.extend(Timepicker.prototype, {
|
|
|
|
|
this.minute_slider.bind('slidestop',onSelectDelegate);
|
|
|
|
|
this.second_slider.bind('slidestop',onSelectDelegate);
|
|
|
|
|
this.millisec_slider.bind('slidestop',onSelectDelegate);
|
|
|
|
|
|
|
|
|
|
// slideAccess integration: http://trentrichardson.com/2011/11/11/jquery-ui-sliders-and-touch-accessibility/
|
|
|
|
|
if (this._defaults.addSliderAccess){
|
|
|
|
|
var sliderAccessArgs = this._defaults.sliderAccessArgs;
|
|
|
|
|
setTimeout(function(){ // fix for inline mode
|
|
|
|
|
if($tp.find('.ui-slider-access').length == 0){
|
|
|
|
|
$tp.find('.ui-slider:visible').sliderAccess(sliderAccessArgs);
|
|
|
|
|
|
|
|
|
|
// fix any grids since sliders are shorter
|
|
|
|
|
var sliderAccessWidth = $tp.find('.ui-slider-access:eq(0)').outerWidth(true);
|
|
|
|
|
if(sliderAccessWidth){
|
|
|
|
|
$tp.find('table:visible').each(function(){
|
|
|
|
|
var $g = $(this),
|
|
|
|
|
oldWidth = $g.outerWidth(),
|
|
|
|
|
oldMarginLeft = $g.css('marginLeft').toString().replace('%',''),
|
|
|
|
|
newWidth = oldWidth - sliderAccessWidth,
|
|
|
|
|
newMarginLeft = ((oldMarginLeft * newWidth)/oldWidth) + '%';
|
|
|
|
|
|
|
|
|
|
$g.css({ width: newWidth, marginLeft: newMarginLeft });
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
},0);
|
|
|
|
|
}
|
|
|
|
|
// end slideAccess integration
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
|
|
|
|
@ -732,10 +753,10 @@ $.extend(Timepicker.prototype, {
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if(adjustSliders !== undefined && adjustSliders === true){
|
|
|
|
|
var hourMax = (this._defaults.hourMax - ((this._defaults.hourMax - this._defaults.hourMin) % this._defaults.stepHour)).toFixed(0),
|
|
|
|
|
minMax = (this._defaults.minuteMax - ((this._defaults.minuteMax - this._defaults.minuteMin) % this._defaults.stepMinute)).toFixed(0),
|
|
|
|
|
secMax = (this._defaults.secondMax - ((this._defaults.secondMax - this._defaults.secondMin) % this._defaults.stepSecond)).toFixed(0),
|
|
|
|
|
millisecMax = (this._defaults.millisecMax - ((this._defaults.millisecMax - this._defaults.millisecMin) % this._defaults.stepMillisec)).toFixed(0);
|
|
|
|
|
var hourMax = parseInt((this._defaults.hourMax - ((this._defaults.hourMax - this._defaults.hourMin) % this._defaults.stepHour)) ,10),
|
|
|
|
|
minMax = parseInt((this._defaults.minuteMax - ((this._defaults.minuteMax - this._defaults.minuteMin) % this._defaults.stepMinute)) ,10),
|
|
|
|
|
secMax = parseInt((this._defaults.secondMax - ((this._defaults.secondMax - this._defaults.secondMin) % this._defaults.stepSecond)) ,10),
|
|
|
|
|
millisecMax = parseInt((this._defaults.millisecMax - ((this._defaults.millisecMax - this._defaults.millisecMin) % this._defaults.stepMillisec)) ,10);
|
|
|
|
|
|
|
|
|
|
if(this.hour_slider)
|
|
|
|
|
this.hour_slider.slider("option", { min: this._defaults.hourMin, max: hourMax }).slider('value', this.hour);
|
|
|
|
@ -797,7 +818,8 @@ $.extend(Timepicker.prototype, {
|
|
|
|
|
}
|
|
|
|
|
if (o.ampm) this.ampm = ampm;
|
|
|
|
|
|
|
|
|
|
this._formatTime();
|
|
|
|
|
//this._formatTime();
|
|
|
|
|
this.formattedTime = $.datepicker.formatTime(this._defaults.timeFormat, this, this._defaults);
|
|
|
|
|
if (this.$timeObj) this.$timeObj.text(this.formattedTime + o.timeSuffix);
|
|
|
|
|
this.timeDefined = true;
|
|
|
|
|
if (hasChanged) this._updateDateTime();
|
|
|
|
@ -816,41 +838,14 @@ $.extend(Timepicker.prototype, {
|
|
|
|
|
},
|
|
|
|
|
|
|
|
|
|
//########################################################################
|
|
|
|
|
// format the time all pretty...
|
|
|
|
|
// left for any backwards compatibility
|
|
|
|
|
//########################################################################
|
|
|
|
|
_formatTime: function(time, format, ampm) {
|
|
|
|
|
if (ampm == undefined) ampm = this._defaults.ampm;
|
|
|
|
|
_formatTime: function(time, format) {
|
|
|
|
|
time = time || { hour: this.hour, minute: this.minute, second: this.second, millisec: this.millisec, ampm: this.ampm, timezone: this.timezone };
|
|
|
|
|
var tmptime = (format || this._defaults.timeFormat).toString();
|
|
|
|
|
|
|
|
|
|
var hour = parseInt(time.hour, 10);
|
|
|
|
|
if (ampm) {
|
|
|
|
|
if (!$.inArray(time.ampm.toUpperCase(), this.amNames) !== -1)
|
|
|
|
|
hour = hour % 12;
|
|
|
|
|
if (hour === 0)
|
|
|
|
|
hour = 12;
|
|
|
|
|
}
|
|
|
|
|
tmptime = tmptime.replace(/(?:hh?|mm?|ss?|[tT]{1,2}|[lz])/g, function(match) {
|
|
|
|
|
switch (match.toLowerCase()) {
|
|
|
|
|
case 'hh': return ('0' + hour).slice(-2);
|
|
|
|
|
case 'h': return hour;
|
|
|
|
|
case 'mm': return ('0' + time.minute).slice(-2);
|
|
|
|
|
case 'm': return time.minute;
|
|
|
|
|
case 'ss': return ('0' + time.second).slice(-2);
|
|
|
|
|
case 's': return time.second;
|
|
|
|
|
case 'l': return ('00' + time.millisec).slice(-3);
|
|
|
|
|
case 'z': return time.timezone;
|
|
|
|
|
case 't': case 'tt':
|
|
|
|
|
if (ampm) {
|
|
|
|
|
var _ampm = time.ampm;
|
|
|
|
|
if (match.length == 1)
|
|
|
|
|
_ampm = _ampm.charAt(0);
|
|
|
|
|
return match.charAt(0) == 'T' ? _ampm.toUpperCase() : _ampm.toLowerCase();
|
|
|
|
|
}
|
|
|
|
|
return '';
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
tmptime = $.datepicker.formatTime(tmptime, time, this._defaults);
|
|
|
|
|
|
|
|
|
|
if (arguments.length) return tmptime;
|
|
|
|
|
else this.formattedTime = tmptime;
|
|
|
|
|
},
|
|
|
|
@ -859,8 +854,8 @@ $.extend(Timepicker.prototype, {
|
|
|
|
|
// update our input with the new date time..
|
|
|
|
|
//########################################################################
|
|
|
|
|
_updateDateTime: function(dp_inst) {
|
|
|
|
|
dp_inst = this.inst || dp_inst,
|
|
|
|
|
dt = new Date(dp_inst.selectedYear, dp_inst.selectedMonth, dp_inst.selectedDay),
|
|
|
|
|
dp_inst = this.inst || dp_inst;
|
|
|
|
|
var dt = $.datepicker._daylightSavingAdjust(new Date(dp_inst.selectedYear, dp_inst.selectedMonth, dp_inst.selectedDay)),
|
|
|
|
|
dateFmt = $.datepicker._get(dp_inst, 'dateFormat'),
|
|
|
|
|
formatCfg = $.datepicker._getFormatConfig(dp_inst),
|
|
|
|
|
timeAvailable = dt !== null && this.timeDefined;
|
|
|
|
@ -934,6 +929,54 @@ $.fn.extend({
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
//########################################################################
|
|
|
|
|
// format the time all pretty...
|
|
|
|
|
// format = string format of the time
|
|
|
|
|
// time = a {}, not a Date() for timezones
|
|
|
|
|
// options = essentially the regional[].. amNames, pmNames, ampm
|
|
|
|
|
//########################################################################
|
|
|
|
|
$.datepicker.formatTime = function(format, time, options) {
|
|
|
|
|
options = options || {};
|
|
|
|
|
options = $.extend($.timepicker._defaults, options);
|
|
|
|
|
time = $.extend({hour:0, minute:0, second:0, millisec:0, timezone:'+0000'}, time);
|
|
|
|
|
|
|
|
|
|
var tmptime = format;
|
|
|
|
|
var ampmName = options['amNames'][0];
|
|
|
|
|
|
|
|
|
|
var hour = parseInt(time.hour, 10);
|
|
|
|
|
if (options.ampm) {
|
|
|
|
|
if (hour > 11){
|
|
|
|
|
ampmName = options['pmNames'][0];
|
|
|
|
|
if(hour > 12)
|
|
|
|
|
hour = hour % 12;
|
|
|
|
|
}
|
|
|
|
|
if (hour === 0)
|
|
|
|
|
hour = 12;
|
|
|
|
|
}
|
|
|
|
|
tmptime = tmptime.replace(/(?:hh?|mm?|ss?|[tT]{1,2}|[lz])/g, function(match) {
|
|
|
|
|
switch (match.toLowerCase()) {
|
|
|
|
|
case 'hh': return ('0' + hour).slice(-2);
|
|
|
|
|
case 'h': return hour;
|
|
|
|
|
case 'mm': return ('0' + time.minute).slice(-2);
|
|
|
|
|
case 'm': return time.minute;
|
|
|
|
|
case 'ss': return ('0' + time.second).slice(-2);
|
|
|
|
|
case 's': return time.second;
|
|
|
|
|
case 'l': return ('00' + time.millisec).slice(-3);
|
|
|
|
|
case 'z': return time.timezone;
|
|
|
|
|
case 't': case 'tt':
|
|
|
|
|
if (options.ampm) {
|
|
|
|
|
if (match.length == 1)
|
|
|
|
|
ampmName = ampmName.charAt(0);
|
|
|
|
|
return match.charAt(0) == 'T' ? ampmName.toUpperCase() : ampmName.toLowerCase();
|
|
|
|
|
}
|
|
|
|
|
return '';
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
tmptime = $.trim(tmptime);
|
|
|
|
|
return tmptime;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//########################################################################
|
|
|
|
|
// the bad hack :/ override datepicker so it doesnt close on select
|
|
|
|
|
// inspired: http://stackoverflow.com/questions/1252512/jquery-datepicker-prevent-closing-picker-when-clicking-a-date/1762378#1762378
|
|
|
|
@ -1048,11 +1091,11 @@ $.datepicker._gotoToday = function(id) {
|
|
|
|
|
this._base_gotoToday(id);
|
|
|
|
|
var now = new Date();
|
|
|
|
|
var tp_inst = this._get(inst, 'timepicker');
|
|
|
|
|
if (tp_inst._defaults.showTimezone && tp_inst.timezone_select) {
|
|
|
|
|
if (tp_inst && tp_inst._defaults.showTimezone && tp_inst.timezone_select) {
|
|
|
|
|
var tzoffset = now.getTimezoneOffset(); // If +0100, returns -60
|
|
|
|
|
var tzsign = tzoffset > 0 ? '-' : '+';
|
|
|
|
|
tzoffset = Math.abs(tzoffset);
|
|
|
|
|
var tzmin = tzoffset % 60
|
|
|
|
|
var tzmin = tzoffset % 60;
|
|
|
|
|
tzoffset = tzsign + ('0' + (tzoffset - tzmin) / 60).slice(-2) + ('0' + tzmin).slice(-2);
|
|
|
|
|
if (tp_inst._defaults.timezoneIso8609)
|
|
|
|
|
tzoffset = tzoffset.substring(0, 3) + ':' + tzoffset.substring(3);
|
|
|
|
@ -1186,10 +1229,15 @@ $.datepicker.parseDate = function(format, value, settings) {
|
|
|
|
|
try {
|
|
|
|
|
date = this._base_parseDate(format, value, settings);
|
|
|
|
|
} catch (err) {
|
|
|
|
|
// Hack! The error message ends with a colon, a space, and
|
|
|
|
|
// the "extra" characters. We rely on that instead of
|
|
|
|
|
// attempting to perfectly reproduce the parsing algorithm.
|
|
|
|
|
date = this._base_parseDate(format, value.substring(0,value.length-(err.length-err.indexOf(':')-2)), settings);
|
|
|
|
|
if (err.indexOf(":") >= 0) {
|
|
|
|
|
// Hack! The error message ends with a colon, a space, and
|
|
|
|
|
// the "extra" characters. We rely on that instead of
|
|
|
|
|
// attempting to perfectly reproduce the parsing algorithm.
|
|
|
|
|
date = this._base_parseDate(format, value.substring(0,value.length-(err.length-err.indexOf(':')-2)), settings);
|
|
|
|
|
} else {
|
|
|
|
|
// The underlying error was not related to the time
|
|
|
|
|
throw err;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
return date;
|
|
|
|
|
};
|
|
|
|
@ -1204,11 +1252,11 @@ $.datepicker._formatDate = function(inst, day, month, year){
|
|
|
|
|
{
|
|
|
|
|
if(day)
|
|
|
|
|
var b = this._base_formatDate(inst, day, month, year);
|
|
|
|
|
tp_inst._updateDateTime();
|
|
|
|
|
tp_inst._updateDateTime(inst);
|
|
|
|
|
return tp_inst.$input.val();
|
|
|
|
|
}
|
|
|
|
|
return this._base_formatDate(inst);
|
|
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
//#######################################################################################
|
|
|
|
|
// override options setter to add time to maxDate(Time) and minDate(Time). MaxDate
|
|
|
|
@ -1255,7 +1303,9 @@ $.datepicker._optionDatepicker = function(target, name, value) {
|
|
|
|
|
else if (onselect)
|
|
|
|
|
tp_inst._defaults.onSelect=onselect;
|
|
|
|
|
}
|
|
|
|
|
this._base_optionDatepicker(target, name, value);
|
|
|
|
|
if (value === undefined)
|
|
|
|
|
return this._base_optionDatepicker(target, name);
|
|
|
|
|
return this._base_optionDatepicker(target, name, value);
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
//#######################################################################################
|
|
|
|
@ -1267,10 +1317,10 @@ function extendRemove(target, props) {
|
|
|
|
|
if (props[name] === null || props[name] === undefined)
|
|
|
|
|
target[name] = props[name];
|
|
|
|
|
return target;
|
|
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
$.timepicker = new Timepicker(); // singleton instance
|
|
|
|
|
$.timepicker.version = "0.9.7";
|
|
|
|
|
$.timepicker.version = "0.9.9";
|
|
|
|
|
|
|
|
|
|
})(jQuery);
|
|
|
|
|
|
|
|
|
|