Created
December 17, 2008 19:15
-
-
Save brianjlandau/37173 to your computer and use it in GitHub Desktop.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
/* | |
DatePicker v4.4 by frequency-decoder.com | |
- This is a revised version that works with jQuery 1.2.6 as I found the original didn't work properly. | |
Released under a creative commons Attribution-ShareAlike 2.5 license (http://creativecommons.org/licenses/by-sa/2.5/) | |
Please credit frequency-decoder in any derivative work - thanks. | |
You are free: | |
* to copy, distribute, display, and perform the work | |
* to make derivative works | |
* to make commercial use of the work | |
Under the following conditions: | |
by Attribution. | |
-------------- | |
You must attribute the work in the manner specified by the author or licensor. | |
sa | |
-- | |
Share Alike. If you alter, transform, or build upon this work, you may distribute the resulting work only under a license identical to this one. | |
* For any reuse or distribution, you must make clear to others the license terms of this work. | |
* Any of these conditions can be waived if you get permission from the copyright holder. | |
*/ | |
var datePickerController; | |
(function() { | |
// Defaults should the locale file not load | |
datePicker.months = ["January","February","March","April","May","June","July","August","September","October","November","December"]; | |
datePicker.fullDay = ["Monday","Tuesday","Wednesday","Thursday","Friday","Saturday","Sunday"]; | |
datePicker.titles = ["Previous month","Next month","Previous year","Next year", "Today", "Show Calendar"]; | |
datePicker.getDaysPerMonth = function(nMonth, nYear) { | |
nMonth = (nMonth + 12) % 12; | |
return (((0 == (nYear%4)) && ((0 != (nYear%100)) || (0 == (nYear%400)))) && nMonth == 1) ? 29: [31,28,31,30,31,30,31,31,30,31,30,31][nMonth]; | |
}; | |
function datePicker(options) { | |
this.defaults = {}; | |
for(opt in options) { this[opt] = this.defaults[opt] = options[opt]; }; | |
this.date = new Date(); | |
this.yearinc = 1; | |
this.timer = null; | |
this.pause = 1000; | |
this.timerSet = false; | |
this.fadeTimer = null; | |
this.interval = new Date(); | |
this.firstDayOfWeek = this.defaults.firstDayOfWeek = this.dayInc = this.monthInc = this.yearInc = this.opacity = this.opacityTo = 0; | |
this.dateSet = null; | |
this.visible = false; | |
this.disabledDates = []; | |
this.enabledDates = []; | |
this.nbsp = String.fromCharCode( 160 ); | |
var o = this; | |
o.events = { | |
onblur:function(e) { | |
o.removeKeyboardEvents(); | |
}, | |
onfocus:function(e) { | |
o.addKeyboardEvents(); | |
}, | |
onkeydown: function (e) { | |
o.stopTimer(); | |
if(!o.visible) return false; | |
if(e == null) e = document.parentWindow.event; | |
var kc = e.keyCode ? e.keyCode : e.charCode; | |
if( kc == 13 ) { | |
// close (return) | |
var td = document.getElementById(o.id + "-date-picker-hover"); | |
if(!td || td.className.search(/out-of-range|day-disabled/) != -1) return o.killEvent(e); | |
o.returnFormattedDate(); | |
o.hide(); | |
return o.killEvent(e); | |
} else if(kc == 27) { | |
// close (esc) | |
o.hide(); | |
return o.killEvent(e); | |
} else if(kc == 32 || kc == 0) { | |
// today (space) | |
o.date = new Date(); | |
o.updateTable(); | |
return o.killEvent(e); | |
}; | |
// Internet Explorer fires the keydown event faster than the JavaScript engine can | |
// update the interface. The following attempts to fix this. | |
/*@cc_on | |
@if(@_win32) | |
if(new Date().getTime() - o.interval.getTime() < 100) return o.killEvent(e); | |
o.interval = new Date(); | |
@end | |
@*/ | |
if ((kc > 49 && kc < 56) || (kc > 97 && kc < 104)) { | |
if (kc > 96) kc -= (96-48); | |
kc -= 49; | |
o.firstDayOfWeek = (o.firstDayOfWeek + kc) % 7; | |
o.updateTable(); | |
return o.killEvent(e); | |
}; | |
if ( kc < 37 || kc > 40 ) return true; | |
var d = new Date( o.date ).valueOf(); | |
if ( kc == 37 ) { | |
// ctrl + left = previous month | |
if( e.ctrlKey ) { | |
d = new Date( o.date ); | |
d.setDate( Math.min(d.getDate(), datePicker.getDaysPerMonth(d.getMonth() - 1,d.getFullYear())) ); | |
d.setMonth( d.getMonth() - 1 ); | |
} else { | |
d = new Date( o.date.getFullYear(), o.date.getMonth(), o.date.getDate() - 1 ); | |
}; | |
} else if ( kc == 39 ) { | |
// ctrl + right = next month | |
if( e.ctrlKey ) { | |
d = new Date( o.date ); | |
d.setDate( Math.min(d.getDate(), datePicker.getDaysPerMonth(d.getMonth() + 1,d.getFullYear())) ); | |
d.setMonth( d.getMonth() + 1 ); | |
} else { | |
d = new Date( o.date.getFullYear(), o.date.getMonth(), o.date.getDate() + 1 ); | |
}; | |
} else if ( kc == 38 ) { | |
// ctrl + up = next year | |
if( e.ctrlKey ) { | |
d = new Date( o.date ); | |
d.setDate( Math.min(d.getDate(), datePicker.getDaysPerMonth(d.getMonth(),d.getFullYear() + 1)) ); | |
d.setFullYear( d.getFullYear() + 1 ); | |
} else { | |
d = new Date( o.date.getFullYear(), o.date.getMonth(), o.date.getDate() - 7 ); | |
}; | |
} else if ( kc == 40 ) { | |
// ctrl + down = prev year | |
if( e.ctrlKey ) { | |
d = new Date( o.date ); | |
d.setDate( Math.min(d.getDate(), datePicker.getDaysPerMonth(d.getMonth(),d.getFullYear() - 1)) ); | |
d.setFullYear( d.getFullYear() - 1 ); | |
} else { | |
d = new Date( o.date.getFullYear(), o.date.getMonth(), o.date.getDate() + 7 ); | |
}; | |
}; | |
var tmpDate = new Date(d); | |
if(o.outOfRange(tmpDate)) return o.killEvent(e); | |
var cacheDate = new Date(o.date); | |
o.date = tmpDate; | |
if(cacheDate.getFullYear() != o.date.getFullYear() || cacheDate.getMonth() != o.date.getMonth()) o.updateTable(); | |
else { | |
o.disableTodayButton(); | |
var tds = o.table.getElementsByTagName('td'); | |
var txt; | |
var start = o.date.getDate() - 6; | |
if(start < 0) start = 0; | |
for(var i = start, td; td = tds[i]; i++) { | |
txt = Number(td.firstChild.nodeValue); | |
if(isNaN(txt) || txt != o.date.getDate()) continue; | |
o.removeHighlight(); | |
td.id = o.id + "-date-picker-hover"; | |
td.className = td.className.replace(/date-picker-hover/g, "") + " date-picker-hover"; | |
}; | |
}; | |
return o.killEvent(e); | |
}, | |
gotoToday: function(e) { | |
o.date = new Date(); | |
o.updateTable(); | |
return o.killEvent(e); | |
}, | |
onmousedown: function(e) { | |
if ( e == null ) e = document.parentWindow.event; | |
var el = e.target != null ? e.target : e.srcElement; | |
var found = false; | |
while(el.parentNode) { | |
if(el.id && (el.id == "fd-"+o.id || el.id == "fd-but-"+o.id)) { | |
found = true; | |
break; | |
}; | |
try { | |
el = el.parentNode; | |
} catch(err) { | |
break; | |
}; | |
}; | |
if(found) return true; | |
o.stopTimer(); | |
datePickerController.hideAll(); | |
}, | |
onmouseover: function(e) { | |
o.stopTimer(); | |
var txt = this.firstChild.nodeValue; | |
if(this.className == "out-of-range" || txt.search(/^[\d]+$/) == -1) return; | |
o.removeHighlight(); | |
this.id = o.id+"-date-picker-hover"; | |
this.className = this.className.replace(/date-picker-hover/g, "") + " date-picker-hover"; | |
o.date.setDate(this.firstChild.nodeValue); | |
o.disableTodayButton(); | |
}, | |
onclick: function(e) { | |
if(o.opacity != o.opacityTo || this.className.search(/out-of-range|day-disabled/) != -1) return false; | |
if ( e == null ) e = document.parentWindow.event; | |
var el = e.target != null ? e.target : e.srcElement; | |
while ( el.nodeType != 1 ) el = el.parentNode; | |
var d = new Date( o.date ); | |
var txt = el.firstChild.data; | |
if(txt.search(/^[\d]+$/) == -1) return; | |
var n = Number( txt ); | |
if(isNaN(n)) { return true; }; | |
d.setDate( n ); | |
o.date = d; | |
o.returnFormattedDate(); | |
if(!o.staticPos) o.hide(); | |
o.stopTimer(); | |
return o.killEvent(e); | |
}, | |
incDec: function(e) { | |
if ( e == null ) e = document.parentWindow.event; | |
var el = e.target != null ? e.target : e.srcElement; | |
if(el && el.className && el.className.search('fd-disabled') != -1) { return false; } | |
datePickerController.addEvent(document, "mouseup", o.events.clearTimer); | |
o.timerInc = 800; | |
o.dayInc = arguments[1]; | |
o.yearInc = arguments[2]; | |
o.monthInc = arguments[3]; | |
o.timerSet = true; | |
o.updateTable(); | |
return true; | |
}, | |
clearTimer: function(e) { | |
o.stopTimer(); | |
o.timerInc = 1000; | |
o.yearInc = 0; | |
o.monthInc = 0; | |
o.dayInc = 0; | |
datePickerController.removeEvent(document, "mouseup", o.events.clearTimer); | |
} | |
}; | |
o.stopTimer = function() { | |
o.timerSet = false; | |
window.clearTimeout(o.timer); | |
}; | |
o.removeHighlight = function() { | |
if(document.getElementById(o.id+"-date-picker-hover")) { | |
document.getElementById(o.id+"-date-picker-hover").className = document.getElementById(o.id+"-date-picker-hover").className.replace("date-picker-hover", ""); | |
document.getElementById(o.id+"-date-picker-hover").id = ""; | |
}; | |
}; | |
o.reset = function() { | |
for(def in o.defaults) { o[def] = o.defaults[def]; }; | |
}; | |
o.setOpacity = function(op) { | |
o.div.style.opacity = op/100; | |
o.div.style.filter = 'alpha(opacity=' + op + ')'; | |
o.opacity = op; | |
}; | |
o.fade = function() { | |
window.clearTimeout(o.fadeTimer); | |
o.fadeTimer = null; | |
delete(o.fadeTimer); | |
var diff = Math.round(o.opacity + ((o.opacityTo - o.opacity) / 4)); | |
o.setOpacity(diff); | |
if(Math.abs(o.opacityTo - diff) > 3 && !o.noTransparency) { | |
o.fadeTimer = window.setTimeout(o.fade, 50); | |
} else { | |
o.setOpacity(o.opacityTo); | |
if(o.opacityTo == 0) { | |
o.div.style.display = "none"; | |
o.visible = false; | |
} else { | |
o.visible = true; | |
}; | |
}; | |
}; | |
o.killEvent = function(e) { | |
e = e || document.parentWindow.event; | |
if(e.stopPropagation) { | |
e.stopPropagation(); | |
e.preventDefault(); | |
}; | |
/*@cc_on | |
@if(@_win32) | |
e.cancelBubble = true; | |
e.returnValue = false; | |
@end | |
@*/ | |
return false; | |
}; | |
o.getElem = function() { | |
return document.getElementById(o.id.replace(/^fd-/, '')) || false; | |
}; | |
o.setRangeLow = function(range) { | |
if(String(range).search(/^(\d\d?\d\d)(0[1-9]|1[012])(0[1-9]|[12][0-9]|3[01])$/) == -1) range = ''; | |
o.low = o.defaults.low = range; | |
if(o.staticPos) o.updateTable(true); | |
}; | |
o.setRangeHigh = function(range) { | |
if(String(range).search(/^(\d\d?\d\d)(0[1-9]|1[012])(0[1-9]|[12][0-9]|3[01])$/) == -1) range = ''; | |
o.high = o.defaults.high = range; | |
if(o.staticPos) o.updateTable(true); | |
}; | |
o.setDisabledDays = function(dayArray) { | |
o.disableDays = o.defaults.disableDays = dayArray; | |
if(o.staticPos) o.updateTable(true); | |
}; | |
o.setDisabledDates = function(dateArray) { | |
var fin = []; | |
for(var i = dateArray.length; i-- ;) { | |
if(dateArray[i].match(/^(\d\d\d\d|\*\*\*\*)(0[1-9]|1[012]|\*\*)(0[1-9]|[12][0-9]|3[01])$/) != -1) fin[fin.length] = dateArray[i]; | |
}; | |
if(fin.length) { | |
o.disabledDates = fin; | |
o.enabledDates = []; | |
if(o.staticPos) o.updateTable(true); | |
}; | |
}; | |
o.setEnabledDates = function(dateArray) { | |
var fin = []; | |
for(var i = dateArray.length; i-- ;) { | |
if(dateArray[i].match(/^(\d\d\d\d|\*\*\*\*)(0[1-9]|1[012]|\*\*)(0[1-9]|[12][0-9]|3[01]|\*\*)$/) != -1 && dateArray[i] != "********") fin[fin.length] = dateArray[i]; | |
}; | |
if(fin.length) { | |
o.disabledDates = []; | |
o.enabledDates = fin; | |
if(o.staticPos) o.updateTable(true); | |
}; | |
}; | |
o.getDisabledDates = function(y, m) { | |
if(o.enabledDates.length) return o.getEnabledDates(y, m); | |
var obj = {}; | |
var d = datePicker.getDaysPerMonth(m - 1, y); | |
m = m < 10 ? "0" + String(m) : m; | |
for(var i = o.disabledDates.length; i-- ;) { | |
var tmp = o.disabledDates[i].replace("****", y).replace("**", m); | |
if(tmp < Number(String(y)+m+"01") || tmp > Number(y+String(m)+d)) continue; | |
obj[tmp] = 1; | |
}; | |
return obj; | |
}; | |
o.getEnabledDates = function(y, m) { | |
var obj = {}; | |
var d = datePicker.getDaysPerMonth(m - 1, y); | |
m = m < 10 ? "0" + String(m) : m; | |
var day,tmp,de,me,ye,disabled; | |
for(var dd = 1; dd <= d; dd++) { | |
day = dd < 10 ? "0" + String(dd) : dd; | |
disabled = true; | |
for(var i = o.enabledDates.length; i-- ;) { | |
tmp = o.enabledDates[i]; | |
ye = String(o.enabledDates[i]).substr(0,4); | |
me = String(o.enabledDates[i]).substr(4,2); | |
de = String(o.enabledDates[i]).substr(6,2); | |
if(ye == y && me == m && de == day) { | |
disabled = false; | |
break; | |
} | |
if(ye == "****" || me == "**" || de == "**") { | |
if(ye == "****") tmp = tmp.replace(/^\*\*\*\*/, y); | |
if(me == "**") tmp = tmp = tmp.substr(0,4) + String(m) + tmp.substr(6,2); | |
if(de == "**") tmp = tmp.replace(/\*\*/, day); | |
if(tmp == String(y + String(m) + day)) { | |
disabled = false; | |
break; | |
}; | |
}; | |
}; | |
if(disabled) obj[String(y + String(m) + day)] = 1; | |
}; | |
return obj; | |
}; | |
o.setFirstDayOfWeek = function(e) { | |
if ( e == null ) e = document.parentWindow.event; | |
var elem = e.target != null ? e.target : e.srcElement; | |
if(elem.tagName.toLowerCase() != "th") { | |
while(elem.tagName.toLowerCase() != "th") elem = elem.parentNode; | |
}; | |
var cnt = 0; | |
while(elem.previousSibling) { | |
elem = elem.previousSibling; | |
if(elem.tagName.toLowerCase() == "th") cnt++; | |
}; | |
o.firstDayOfWeek = (o.firstDayOfWeek + cnt) % 7; | |
o.updateTableHeaders(); | |
return o.killEvent(e); | |
}; | |
o.truePosition = function(element) { | |
var pos = o.cumulativeOffset(element); | |
if(window.opera) { return pos; } | |
var iebody = (document.compatMode && document.compatMode != "BackCompat")? document.documentElement : document.body; | |
var dsocleft = document.all ? iebody.scrollLeft : window.pageXOffset; | |
var dsoctop = document.all ? iebody.scrollTop : window.pageYOffset; | |
var posReal = o.realOffset(element); | |
return [pos[0] - posReal[0] + dsocleft, pos[1] - posReal[1] + dsoctop]; | |
}; | |
o.realOffset = function(element) { | |
var t = 0, l = 0; | |
do { | |
t += element.scrollTop || 0; | |
l += element.scrollLeft || 0; | |
element = element.parentNode; | |
} while (element); | |
return [l, t]; | |
}; | |
o.cumulativeOffset = function(element) { | |
var t = 0, l = 0; | |
do { | |
t += element.offsetTop || 0; | |
l += element.offsetLeft || 0; | |
element = element.offsetParent; | |
} while (element); | |
return [l, t]; | |
}; | |
o.resize = function() { | |
if(!o.created || !o.getElem()) return; | |
o.div.style.visibility = "hidden"; | |
if(!o.staticPos) { o.div.style.left = o.div.style.top = "0px"; } | |
o.div.style.display = "block"; | |
var osh = o.div.offsetHeight; | |
var osw = o.div.offsetWidth; | |
o.div.style.visibility = "visible"; | |
o.div.style.display = "none"; | |
if(!o.staticPos) { | |
var elem = document.getElementById('fd-but-' + o.id); | |
var pos = o.truePosition(elem); | |
var trueBody = (document.compatMode && document.compatMode!="BackCompat") ? document.documentElement : document.body; | |
var scrollTop = window.devicePixelRatio || window.opera ? 0 : trueBody.scrollTop; | |
var scrollLeft = window.devicePixelRatio || window.opera ? 0 : trueBody.scrollLeft; | |
if(parseInt(trueBody.clientWidth+scrollLeft) < parseInt(osw+pos[0])) { | |
o.div.style.left = Math.abs(parseInt((trueBody.clientWidth+scrollLeft) - osw)) + "px"; | |
} else { | |
o.div.style.left = pos[0] + "px"; | |
}; | |
if(parseInt(trueBody.clientHeight+scrollTop) < parseInt(osh+pos[1]+elem.offsetHeight+2)) { | |
o.div.style.top = Math.abs(parseInt(pos[1] - (osh + 2))) + "px"; | |
} else { | |
o.div.style.top = Math.abs(parseInt(pos[1] + elem.offsetHeight + 2)) + "px"; | |
}; | |
}; | |
/*@cc_on | |
@if(@_jscript_version <= 5.6) | |
if(o.staticPos) return; | |
o.iePopUp.style.top = o.div.style.top; | |
o.iePopUp.style.left = o.div.style.left; | |
o.iePopUp.style.width = osw + "px"; | |
o.iePopUp.style.height = (osh - 2) + "px"; | |
@end | |
@*/ | |
}; | |
o.equaliseDates = function() { | |
var clearDayFound = false; | |
var tmpDate; | |
for(var i = o.low; i <= o.high; i++) { | |
tmpDate = String(i); | |
if(!o.disableDays[new Date(tmpDate.substr(0,4), tmpDate.substr(6,2), tmpDate.substr(4,2)).getDay() - 1]) { | |
clearDayFound = true; | |
break; | |
}; | |
}; | |
if(!clearDayFound) o.disableDays = o.defaults.disableDays = [0,0,0,0,0,0,0]; | |
}; | |
o.outOfRange = function(tmpDate) { | |
if(!o.low && !o.high) return false; | |
var level = false; | |
if(!tmpDate) { | |
level = true; | |
tmpDate = o.date; | |
}; | |
var d = (tmpDate.getDate() < 10) ? "0" + tmpDate.getDate() : tmpDate.getDate(); | |
var m = ((tmpDate.getMonth() + 1) < 10) ? "0" + (tmpDate.getMonth() + 1) : tmpDate.getMonth() + 1; | |
var y = tmpDate.getFullYear(); | |
var dt = String(y)+String(m)+String(d); | |
if(o.low && parseInt(dt) < parseInt(o.low)) { | |
if(!level) return true; | |
o.date = new Date(o.low.substr(0,4), o.low.substr(4,2)-1, o.low.substr(6,2), 5, 0, 0); | |
return false; | |
}; | |
if(o.high && parseInt(dt) > parseInt(o.high)) { | |
if(!level) return true; | |
o.date = new Date( o.high.substr(0,4), o.high.substr(4,2)-1, o.high.substr(6,2), 5, 0, 0); | |
}; | |
return false; | |
}; | |
o.createButton = function() { | |
if(o.staticPos) { return; }; | |
var but; | |
if(!document.getElementById("fd-but-" + o.id)) { | |
var inp = o.getElem(); | |
but = document.createElement('a'); | |
but.href = "#"; | |
var span = document.createElement('span'); | |
span.appendChild(document.createTextNode(String.fromCharCode( 160 ))); | |
but.className = "date-picker-control"; | |
but.title = (typeof(fdLocale) == "object" && options.locale && fdLocale.titles.length > 5) ? fdLocale.titles[5] : ""; | |
but.id = "fd-but-" + o.id; | |
but.appendChild(span); | |
if(inp.nextSibling) { | |
inp.parentNode.insertBefore(but, inp.nextSibling); | |
} else { | |
inp.parentNode.appendChild(but); | |
}; | |
} else { | |
but = document.getElementById("fd-but-" + o.id); | |
}; | |
but.onclick = but.onpress = function(e) { | |
e = e || window.event; | |
var inpId = this.id.replace('fd-but-',''); | |
try { | |
var dp = datePickerController.getDatePicker(inpId); | |
} catch(err) { return false; }; | |
if(e.type == "press") { | |
var kc = e.keyCode != null ? e.keyCode : e.charCode; | |
if(kc != 13) { return true; }; | |
if(dp.visible) { | |
hideAll(); | |
return false; | |
}; | |
}; | |
if(!dp.visible) { | |
datePickerController.hideAll(inpId); | |
dp.show(); | |
} else { | |
datePickerController.hideAll(); | |
}; | |
return false; | |
}; | |
but = null; | |
}; | |
o.create = function() { | |
function createTH(details) { | |
var th = document.createElement('th'); | |
if(details.thClassName) th.className = details.thClassName; | |
if(details.colspan) { | |
/*@cc_on | |
/*@if (@_win32) | |
th.setAttribute('colSpan',details.colspan); | |
@else @*/ | |
th.setAttribute('colspan',details.colspan); | |
/*@end | |
@*/ | |
}; | |
/*@cc_on | |
/*@if (@_win32) | |
th.unselectable = "on"; | |
/*@end@*/ | |
return th; | |
}; | |
function createThAndButton(tr, obj) { | |
for(var i = 0, details; details = obj[i]; i++) { | |
var th = createTH(details); | |
tr.appendChild(th); | |
var but = document.createElement('span'); | |
but.className = details.className; | |
but.id = o.id + details.id; | |
but.appendChild(document.createTextNode(details.text)); | |
but.title = details.title || ""; | |
if(details.onmousedown) but.onmousedown = details.onmousedown; | |
if(details.onclick) but.onclick = details.onclick; | |
if(details.onmouseout) but.onmouseout = details.onmouseout; | |
th.appendChild(but); | |
}; | |
}; | |
/*@cc_on | |
@if(@_jscript_version <= 5.6) | |
if(!document.getElementById("iePopUpHack")) { | |
o.iePopUp = document.createElement('iframe'); | |
o.iePopUp.src = "javascript:'<html></html>';"; | |
o.iePopUp.setAttribute('className','iehack'); | |
o.iePopUp.scrolling="no"; | |
o.iePopUp.frameBorder="0"; | |
o.iePopUp.name = o.iePopUp.id = "iePopUpHack"; | |
document.body.appendChild(o.iePopUp); | |
} else { | |
o.iePopUp = document.getElementById("iePopUpHack"); | |
}; | |
@end | |
@*/ | |
if(typeof(fdLocale) == "object" && o.locale) { | |
datePicker.titles = fdLocale.titles; | |
datePicker.months = fdLocale.months; | |
datePicker.fullDay = fdLocale.fullDay; | |
// Optional parameters | |
if(fdLocale.dayAbbr) datePicker.dayAbbr = fdLocale.dayAbbr; | |
if(fdLocale.firstDayOfWeek) o.firstDayOfWeek = o.defaults.firstDayOfWeek = fdLocale.firstDayOfWeek; | |
}; | |
o.div = document.createElement('div'); | |
o.div.style.zIndex = 9999; | |
o.div.id = "fd-"+o.id; | |
o.div.className = "datePicker"; | |
if(!o.staticPos) { | |
document.getElementsByTagName('body')[0].appendChild(o.div); | |
} else { | |
elem = o.getElem(); | |
if(!elem) { | |
o.div = null; | |
return; | |
}; | |
o.div.className += " staticDP"; | |
o.div.setAttribute("tabIndex", "0"); | |
o.div.onfocus = o.events.onfocus; | |
o.div.onblur = o.events.onblur; | |
elem.parentNode.insertBefore(o.div, elem.nextSibling); | |
if(o.hideInput && elem.type && elem.type == "text") elem.setAttribute("type", "hidden"); | |
}; | |
//var nbsp = String.fromCharCode( 160 ); | |
var tr, row, col, tableHead, tableBody; | |
o.table = document.createElement('table'); | |
o.div.appendChild( o.table ); | |
tableHead = document.createElement('thead'); | |
o.table.appendChild( tableHead ); | |
tr = document.createElement('tr'); | |
tableHead.appendChild(tr); | |
// Title Bar | |
o.titleBar = createTH({thClassName:"date-picker-title", colspan:7}); | |
tr.appendChild( o.titleBar ); | |
tr = null; | |
var span = document.createElement('span'); | |
span.className = "month-display"; | |
o.titleBar.appendChild(span); | |
span = document.createElement('span'); | |
span.className = "year-display"; | |
o.titleBar.appendChild(span); | |
span = null; | |
tr = document.createElement('tr'); | |
tableHead.appendChild(tr); | |
createThAndButton(tr, [{className:"prev-but", id:"-prev-year-but", text:"\u00AB", title:datePicker.titles[2], onmousedown:function(e) { o.events.incDec(e,0,-1,0); }, onmouseout:o.events.clearTimer },{className:"prev-but", id:"-prev-month-but", text:"\u2039", title:datePicker.titles[0], onmousedown:function(e) { o.events.incDec(e,0,0,-1); }, onmouseout:o.events.clearTimer },{colspan:3, className:"today-but", id:"-today-but", text:datePicker.titles.length > 4 ? datePicker.titles[4] : "Today", onclick:o.events.gotoToday},{className:"next-but", id:"-next-month-but", text:"\u203A", title:datePicker.titles[1], onmousedown:function(e) { o.events.incDec(e,0,0,1); }, onmouseout:o.events.clearTimer },{className:"next-but", id:"-next-year-but", text:"\u00BB", title:datePicker.titles[3], onmousedown:function(e) { o.events.incDec(e,0,1,0); }, onmouseout:o.events.clearTimer }]); | |
tableBody = document.createElement('tbody'); | |
o.table.appendChild( tableBody ); | |
for(var rows = 0; rows < 7; rows++) { | |
row = document.createElement('tr'); | |
if(rows != 0) tableBody.appendChild(row); | |
else tableHead.appendChild(row); | |
for(var cols = 0; cols < 7; cols++) { | |
col = (rows == 0) ? document.createElement('th') : document.createElement('td'); | |
row.appendChild(col); | |
if(rows != 0) { | |
col.appendChild(document.createTextNode(o.nbsp)); | |
col.onmouseover = o.events.onmouseover; | |
col.onclick = o.events.onclick; | |
} else { | |
col.className = "date-picker-day-header"; | |
col.scope = "col"; | |
}; | |
col = null; | |
}; | |
row = null; | |
}; | |
// Table headers | |
var but; | |
var ths = o.table.getElementsByTagName('thead')[0].getElementsByTagName('tr')[2].getElementsByTagName('th'); | |
for ( var y = 0; y < 7; y++ ) { | |
if(y > 0) { | |
but = document.createElement("span"); | |
but.className = "fd-day-header"; | |
but.onclick = ths[y].onclick = o.setFirstDayOfWeek; | |
but.appendChild(document.createTextNode(o.nbsp)); | |
ths[y].appendChild(but); | |
but = null; | |
} else { | |
ths[y].appendChild(document.createTextNode(o.nbsp)); | |
}; | |
}; | |
o.ths = o.table.getElementsByTagName('thead')[0].getElementsByTagName('tr')[2].getElementsByTagName('th'); | |
o.trs = o.table.getElementsByTagName('tbody')[0].getElementsByTagName('tr'); | |
o.updateTableHeaders(); | |
tableBody = tableHead = tr = createThAndButton = createTH = null; | |
if(o.low && o.high && (o.high - o.low < 7)) { o.equaliseDates(); }; | |
o.created = true; | |
if(o.staticPos) { | |
var yyN = document.getElementById(o.id); | |
datePickerController.addEvent(yyN, "change", o.changeHandler); | |
if(o.splitDate) { | |
var mmN = document.getElementById(o.id+'-mm'); | |
var ddN = document.getElementById(o.id+'-dd'); | |
datePickerController.addEvent(mmN, "change", o.changeHandler); | |
datePickerController.addEvent(ddN, "change", o.changeHandler); | |
}; | |
o.show(); | |
} else { | |
o.createButton(); | |
o.resize(); | |
o.fade(); | |
}; | |
}; | |
o.changeHandler = function() { | |
o.setDateFromInput(); | |
o.updateTable(); | |
}; | |
o.setDateFromInput = function() { | |
function m2c(val) { | |
return String(val).length < 2 ? "00".substring(0, 2 - String(val).length) + String(val) : val; | |
}; | |
o.dateSet = null; | |
var elem = o.getElem(); | |
if(!elem) return; | |
if(!o.splitDate) { | |
var date = datePickerController.dateFormat(elem.value, o.format.search(/m-d-y/i) != -1); | |
} else { | |
var mmN = document.getElementById(o.id+'-mm'); | |
var ddN = document.getElementById(o.id+'-dd'); | |
var tm = parseInt(mmN.tagName.toLowerCase() == "input" ? mmN.value : mmN.options[mmN.selectedIndex].value, 10); | |
var td = parseInt(ddN.tagName.toLowerCase() == "input" ? ddN.value : ddN.options[ddN.selectedIndex].value, 10); | |
var ty = parseInt(elem.tagName.toLowerCase() == "input" ? elem.value : elem.options[elem.selectedIndex || 0].value, 10); | |
var date = datePickerController.dateFormat(tm + "/" + td + "/" + ty, true); | |
}; | |
var badDate = false; | |
if(!date) { | |
badDate = true; | |
date = String(new Date().getFullYear()) + m2c(new Date().getMonth()+1) + m2c(new Date().getDate()); | |
}; | |
var d,m,y; | |
y = Number(date.substr(0, 4)); | |
m = Number(date.substr(4, 2)) - 1; | |
d = Number(date.substr(6, 2)); | |
var dpm = datePicker.getDaysPerMonth(m, y); | |
if(d > dpm) d = dpm; | |
if(new Date(y, m, d) == 'Invalid Date' || new Date(y, m, d) == 'NaN') { | |
badDate = true; | |
o.date = new Date(); | |
o.date.setHours(5); | |
return; | |
}; | |
o.date = new Date(y, m, d); | |
o.date.setHours(5); | |
if(!badDate) o.dateSet = new Date(o.date); | |
m2c = null; | |
}; | |
o.setSelectIndex = function(elem, indx) { | |
var len = elem.options.length; | |
indx = Number(indx); | |
for(var opt = 0; opt < len; opt++) { | |
if(elem.options[opt].value == indx) { | |
elem.selectedIndex = opt; | |
return; | |
}; | |
}; | |
}; | |
o.returnFormattedDate = function() { | |
var elem = o.getElem(); | |
if(!elem) return; | |
var d = (o.date.getDate() < 10) ? "0" + o.date.getDate() : o.date.getDate(); | |
var m = ((o.date.getMonth() + 1) < 10) ? "0" + (o.date.getMonth() + 1) : o.date.getMonth() + 1; | |
var yyyy = o.date.getFullYear(); | |
var disabledDates = o.getDisabledDates(yyyy, m); | |
var weekDay = ( o.date.getDay() + 6 ) % 7; | |
if(!(o.disableDays[weekDay] || String(yyyy)+m+d in disabledDates)) { | |
if(o.splitDate) { | |
var ddE = document.getElementById(o.id+"-dd"); | |
var mmE = document.getElementById(o.id+"-mm"); | |
if(ddE.tagName.toLowerCase() == "input") { ddE.value = d; } | |
else { o.setSelectIndex(ddE, d); /*ddE.selectedIndex = d - 1;*/ }; | |
if(mmE.tagName.toLowerCase() == "input") { mmE.value = m; } | |
else { o.setSelectIndex(mmE, m); /*mmE.selectedIndex = m - 1;*/ }; | |
if(elem.tagName.toLowerCase() == "input") elem.value = yyyy; | |
else { | |
o.setSelectIndex(elem, yyyy); /* | |
for(var opt = 0; opt < elem.options.length; opt++) { | |
if(elem.options[opt].value == yyyy) { | |
elem.selectedIndex = opt; | |
break; | |
}; | |
}; | |
*/ | |
}; | |
} else { | |
elem.value = o.format.replace('y',yyyy).replace('m',m).replace('d',d).replace(/-/g,o.divider); | |
}; | |
if(!elem.type || elem.type && elem.type != "hidden"){ elem.focus(); } | |
if(o.staticPos) { | |
o.dateSet = new Date( o.date ); | |
o.updateTable(); | |
}; | |
// Programmatically fire the onchange event | |
if(document.createEvent) { | |
var onchangeEvent = document.createEvent('HTMLEvents'); | |
onchangeEvent.initEvent('change', true, false); | |
elem.dispatchEvent(onchangeEvent); | |
} else if(document.createEventObject) { | |
elem.fireEvent('onchange'); | |
}; | |
}; | |
}; | |
o.disableTodayButton = function() { | |
var today = new Date(); | |
document.getElementById(o.id + "-today-but").className = document.getElementById(o.id + "-today-but").className.replace("fd-disabled", ""); | |
if(o.outOfRange(today) || (o.date.getDate() == today.getDate() && o.date.getMonth() == today.getMonth() && o.date.getFullYear() == today.getFullYear())) { | |
document.getElementById(o.id + "-today-but").className += " fd-disabled"; | |
document.getElementById(o.id + "-today-but").onclick = null; | |
} else { | |
document.getElementById(o.id + "-today-but").onclick = o.events.gotoToday; | |
}; | |
}; | |
o.updateTableHeaders = function() { | |
var d, but; | |
var ths = o.ths; | |
for ( var y = 0; y < 7; y++ ) { | |
d = (o.firstDayOfWeek + y) % 7; | |
ths[y].title = datePicker.fullDay[d]; | |
if(y > 0) { | |
but = ths[y].getElementsByTagName("span")[0]; | |
but.removeChild(but.firstChild); | |
but.appendChild(document.createTextNode(datePicker.dayAbbr ? datePicker.dayAbbr[d] : datePicker.fullDay[d].charAt(0))); | |
but.title = datePicker.fullDay[d]; | |
but = null; | |
} else { | |
ths[y].removeChild(ths[y].firstChild); | |
ths[y].appendChild(document.createTextNode(datePicker.dayAbbr ? datePicker.dayAbbr[d] : datePicker.fullDay[d].charAt(0))); | |
}; | |
}; | |
o.updateTable(); | |
}; | |
o.updateTable = function(noCallback) { | |
if(o.timerSet) { | |
var d = new Date(o.date); | |
d.setDate( Math.min(d.getDate()+o.dayInc, datePicker.getDaysPerMonth(d.getMonth()+o.monthInc,d.getFullYear()+o.yearInc)) ); | |
d.setMonth( d.getMonth() + o.monthInc ); | |
d.setFullYear( d.getFullYear() + o.yearInc ); | |
o.date = d; | |
}; | |
if(!noCallback && "onupdate" in datePickerController && typeof(datePickerController.onupdate) == "function") datePickerController.onupdate(o); | |
o.outOfRange(); | |
o.disableTodayButton(); | |
// Set the tmpDate to the second day of this month (to avoid daylight savings time madness on Windows) | |
var tmpDate = new Date( o.date.getFullYear(), o.date.getMonth(), 2 ); | |
tmpDate.setHours(5); | |
var tdm = tmpDate.getMonth(); | |
var tdy = tmpDate.getFullYear(); | |
// Do the disableDates for this year and month | |
var disabledDates = o.getDisabledDates(o.date.getFullYear(), o.date.getMonth() + 1); | |
var today = new Date(); | |
// Previous buttons out of range | |
var b = document.getElementById(o.id + "-prev-year-but"); | |
b.className = b.className.replace("fd-disabled", ""); | |
if(o.outOfRange(new Date((tdy - 1), Number(tdm), datePicker.getDaysPerMonth(Number(tdm), tdy-1)))) { | |
b.className += " fd-disabled"; | |
if(o.yearInc == -1) o.stopTimer(); | |
}; | |
b = document.getElementById(o.id + "-prev-month-but"); | |
b.className = b.className.replace("fd-disabled", ""); | |
if(o.outOfRange(new Date(tdy, (Number(tdm) - 1), datePicker.getDaysPerMonth(Number(tdm)-1, tdy)))) { | |
b.className += " fd-disabled"; | |
if(o.monthInc == -1) o.stopTimer(); | |
}; | |
// Next buttons out of range | |
b = document.getElementById(o.id + "-next-year-but"); | |
b.className = b.className.replace("fd-disabled", ""); | |
if(o.outOfRange(new Date((tdy + 1), Number(tdm), 1))) { | |
b.className += " fd-disabled"; | |
if(o.yearInc == 1) o.stopTimer(); | |
}; | |
b = document.getElementById(o.id + "-next-month-but"); | |
b.className = b.className.replace("fd-disabled", ""); | |
if(o.outOfRange(new Date(tdy, Number(tdm) + 1, 1))) { | |
b.className += " fd-disabled"; | |
if(o.monthInc == 1) o.stopTimer(); | |
}; | |
b = null; | |
var cd = o.date.getDate(); | |
var cm = o.date.getMonth(); | |
var cy = o.date.getFullYear(); | |
// Title Bar | |
var span = o.titleBar.getElementsByTagName("span"); | |
while(span[0].firstChild) span[0].removeChild(span[0].firstChild); | |
while(span[1].firstChild) span[1].removeChild(span[1].firstChild); | |
span[0].appendChild(document.createTextNode(datePicker.months[cm] + o.nbsp)); | |
span[1].appendChild(document.createTextNode(cy)); | |
tmpDate.setDate( 1 ); | |
var dt, cName, td, tds, i; | |
var weekDay = ( tmpDate.getDay() + 6 ) % 7; | |
var firstColIndex = (( (weekDay - o.firstDayOfWeek) + 7 ) % 7) - 1; | |
var dpm = datePicker.getDaysPerMonth(cm, cy); | |
var todayD = today.getDate(); | |
var todayM = today.getMonth(); | |
var todayY = today.getFullYear(); | |
var c = "class"; | |
/*@cc_on | |
@if(@_win32) | |
c = "className"; | |
@end | |
@*/ | |
var stub = String(tdy) + (String(tdm+1).length < 2 ? "0" + (tdm+1) : tdm+1); | |
for(var row = 0; row < 6; row++) { | |
tds = o.trs[row].getElementsByTagName('td'); | |
for(var col = 0; col < 7; col++) { | |
td = tds[col]; | |
td.removeChild(td.firstChild); | |
td.setAttribute("id", ""); | |
td.setAttribute("title", ""); | |
i = (row * 7) + col; | |
if(i > firstColIndex && i <= (firstColIndex + dpm)) { | |
dt = i - firstColIndex; | |
tmpDate.setDate(dt); | |
td.appendChild(document.createTextNode(dt)); | |
if(o.outOfRange(tmpDate)) { | |
td.setAttribute(c, "out-of-range"); | |
} else { | |
cName = []; | |
weekDay = ( tmpDate.getDay() + 6 ) % 7; | |
if(dt == todayD && tdm == todayM && tdy == todayY) { | |
cName.push("date-picker-today"); | |
}; | |
if(o.dateSet != null && o.dateSet.getDate() == dt && o.dateSet.getMonth() == tdm && o.dateSet.getFullYear() == tdy) { | |
cName.push("date-picker-selected-date"); | |
}; | |
if(o.disableDays[weekDay] || stub + String(dt < 10 ? "0" + dt : dt) in disabledDates) { | |
cName.push("day-disabled"); | |
} else if(o.highlightDays[weekDay]) { | |
cName.push("date-picker-highlight"); | |
}; | |
if(cd == dt) { | |
td.setAttribute("id", o.id + "-date-picker-hover"); | |
cName.push("date-picker-hover"); | |
}; | |
cName.push("dm-" + dt + '-' + (tdm + 1) + " " + " dmy-" + dt + '-' + (tdm + 1) + '-' + tdy); | |
td.setAttribute(c, cName.join(' ')); | |
td.setAttribute("title", datePicker.months[cm] + o.nbsp + dt + "," + o.nbsp + cy); | |
}; | |
} else { | |
td.appendChild(document.createTextNode(o.nbsp)); | |
td.setAttribute(c, "date-picker-unused"); | |
}; | |
}; | |
}; | |
if(o.timerSet) { | |
o.timerInc = 50 + Math.round(((o.timerInc - 50) / 1.8)); | |
o.timer = window.setTimeout(o.updateTable, o.timerInc); | |
}; | |
}; | |
o.addKeyboardEvents = function() { | |
datePickerController.addEvent(document, "keypress", o.events.onkeydown); | |
/*@cc_on | |
@if(@_win32) | |
datePickerController.removeEvent(document, "keypress", o.events.onkeydown); | |
datePickerController.addEvent(document, "keydown", o.events.onkeydown); | |
@end | |
@*/ | |
if(window.devicePixelRatio) { | |
datePickerController.removeEvent(document, "keypress", o.events.onkeydown); | |
datePickerController.addEvent(document, "keydown", o.events.onkeydown); | |
}; | |
}; | |
o.removeKeyboardEvents =function() { | |
datePickerController.removeEvent(document, "keypress", o.events.onkeydown); | |
datePickerController.removeEvent(document, "keydown", o.events.onkeydown); | |
}; | |
o.show = function() { | |
var elem = o.getElem(); | |
if(!elem || o.visible || elem.disabled) return; | |
o.reset(); | |
o.setDateFromInput(); | |
o.updateTable(); | |
if(!o.staticPos) o.resize(); | |
datePickerController.addEvent(o.staticPos ? o.table : document, "mousedown", o.events.onmousedown); | |
if(!o.staticPos) { o.addKeyboardEvents(); }; | |
o.opacityTo = o.noTransparency ? 99 : 90; | |
o.div.style.display = "block"; | |
/*@cc_on | |
@if(@_jscript_version <= 5.6) | |
if(!o.staticPos) o.iePopUp.style.display = "block"; | |
@end | |
@*/ | |
o.fade(); | |
o.visible = true; | |
}; | |
o.hide = function() { | |
if(!o.visible) return; | |
o.stopTimer(); | |
if(o.staticPos) return; | |
datePickerController.removeEvent(document, "mousedown", o.events.onmousedown); | |
datePickerController.removeEvent(document, "mouseup", o.events.clearTimer); | |
o.removeKeyboardEvents(); | |
/*@cc_on | |
@if(@_jscript_version <= 5.6) | |
o.iePopUp.style.display = "none"; | |
@end | |
@*/ | |
o.opacityTo = 0; | |
o.fade(); | |
o.visible = false; | |
var elem = o.getElem(); | |
if(!elem.type || elem.type && elem.type != "hidden") { elem.focus(); }; | |
}; | |
o.destroy = function() { | |
// Cleanup for Internet Explorer | |
datePickerController.removeEvent(o.staticPos ? o.table : document, "mousedown", o.events.onmousedown); | |
datePickerController.removeEvent(document, "mouseup", o.events.clearTimer); | |
o.removeKeyboardEvents(); | |
if(o.staticPos) { | |
var yyN = document.getElementById(o.id); | |
datePickerController.removeEvent(yyN, "change", o.changeHandler); | |
if(o.splitDate) { | |
var mmN = document.getElementById(o.id+'-mm'); | |
var ddN = document.getElementById(o.id+'-dd'); | |
datePickerController.removeEvent(mmN, "change", o.changeHandler); | |
datePickerController.removeEvent(ddN, "change", o.changeHandler); | |
}; | |
o.div.onfocus = o.div.onblur = null; | |
}; | |
var ths = o.table.getElementsByTagName("th"); | |
for(var i = 0, th; th = ths[i]; i++) { | |
th.onmouseover = th.onmouseout = th.onmousedown = th.onclick = null; | |
}; | |
var tds = o.table.getElementsByTagName("td"); | |
for(var i = 0, td; td = tds[i]; i++) { | |
td.onmouseover = td.onclick = null; | |
}; | |
var butts = o.table.getElementsByTagName("span"); | |
for(var i = 0, butt; butt = butts[i]; i++) { | |
butt.onmousedown = butt.onclick = butt.onkeypress = null; | |
}; | |
o.ths = o.trs = null; | |
clearTimeout(o.fadeTimer); | |
clearTimeout(o.timer); | |
o.fadeTimer = o.timer = null; | |
/*@cc_on | |
@if(@_jscript_version <= 5.6) | |
o.iePopUp = null; | |
@end | |
@*/ | |
if(!o.staticPos && document.getElementById(o.id.replace(/^fd-/, 'fd-but-'))) { | |
var butt = document.getElementById(o.id.replace(/^fd-/, 'fd-but-')); | |
butt.onclick = butt.onpress = null; | |
}; | |
if(o.div && o.div.parentNode) { | |
o.div.parentNode.removeChild(o.div); | |
}; | |
o.titleBar = o.table = o.div = null; | |
o = null; | |
}; | |
o.create(); | |
}; | |
datePickerController = { | |
datePickers: {}, | |
uniqueId: 0, | |
addEvent: function(obj, type, fn) { | |
if( obj.attachEvent ) { | |
obj["e"+type+fn] = fn; | |
obj[type+fn] = function(){obj["e"+type+fn]( window.event );}; | |
obj.attachEvent( "on"+type, obj[type+fn] ); | |
} else { | |
obj.addEventListener( type, fn, true ); | |
}; | |
}, | |
removeEvent: function(obj, type, fn) { | |
try { | |
if( obj.detachEvent ) { | |
obj.detachEvent( "on"+type, obj[type+fn] ); | |
obj[type+fn] = null; | |
} else { | |
obj.removeEventListener( type, fn, true ); | |
}; | |
} catch(err) {}; | |
}, | |
hideAll: function(exception) { | |
var dp; | |
for(dp in datePickerController.datePickers) { | |
if(!datePickerController.datePickers[dp].created || datePickerController.datePickers[dp].staticPos) continue; | |
if(exception && exception == datePickerController.datePickers[dp].id) { continue; }; | |
if(document.getElementById(datePickerController.datePickers[dp].id)) { datePickerController.datePickers[dp].hide(); }; | |
}; | |
}, | |
cleanUp: function() { | |
var dp; | |
for(dp in datePickerController.datePickers) { | |
if(!document.getElementById(datePickerController.datePickers[dp].id)) { | |
if(!datePickerController.datePickers[dp].created) continue; | |
datePickerController.datePickers[dp].destroy(); | |
datePickerController.datePickers[dp] = null; | |
delete datePickerController.datePickers[dp]; | |
}; | |
}; | |
}, | |
destroy: function() { | |
for(dp in datePickerController.datePickers) { | |
if(!datePickerController.datePickers[dp].created) continue; | |
datePickerController.datePickers[dp].destroy(); | |
datePickerController.datePickers[dp] = null; | |
delete datePickerController.datePickers[dp]; | |
}; | |
datePickerController.datePickers = null; | |
/*@cc_on | |
@if(@_jscript_version <= 5.6) | |
if(document.getElementById("iePopUpHack")) { | |
document.body.removeChild(document.getElementById("iePopUpHack")); | |
}; | |
@end | |
@*/ | |
datePicker.script = null; | |
datePickerController.removeEvent(window, 'load', datePickerController.create); | |
datePickerController.removeEvent(window, 'unload', datePickerController.destroy); | |
}, | |
dateFormat: function(dateIn, favourMDY) { | |
var dateTest = [ | |
{ regExp:/^(0?[1-9]|[12][0-9]|3[01])([- \/.])(0?[1-9]|1[012])([- \/.])((\d\d)?\d\d)$/, d:1, m:3, y:5 }, // dmy | |
{ regExp:/^(0?[1-9]|1[012])([- \/.])(0?[1-9]|[12][0-9]|3[01])([- \/.])((\d\d)?\d\d)$/, d:3, m:1, y:5 }, // mdy | |
{ regExp:/^(\d\d\d\d)([- \/.])(0?[1-9]|1[012])([- \/.])(0?[1-9]|[12][0-9]|3[01])$/, d:5, m:3, y:1 } // ymd | |
]; | |
var start; | |
var cnt = 0; | |
while(cnt < 3) { | |
start = (cnt + (favourMDY ? 4 : 3)) % 3; | |
if(dateIn.match(dateTest[start].regExp)) { | |
res = dateIn.match(dateTest[start].regExp); | |
y = res[dateTest[start].y]; | |
m = res[dateTest[start].m]; | |
d = res[dateTest[start].d]; | |
if(m.length == 1) m = "0" + m; | |
if(d.length == 1) d = "0" + d; | |
if(y.length != 4) y = (parseInt(y) < 50) ? '20' + y : '19' + y; | |
return String(y)+m+d; | |
}; | |
cnt++; | |
}; | |
return 0; | |
}, | |
joinNodeLists: function() { | |
if(!arguments.length) { return []; } | |
var nodeList = []; | |
for (var i = 0; i < arguments.length; i++) { | |
for (var j = 0, item; item = arguments[i][j]; j++) { | |
nodeList[nodeList.length] = item; | |
}; | |
}; | |
return nodeList; | |
}, | |
addDatePicker: function(inpId, options) { | |
if(!(inpId in datePickerController.datePickers)) { | |
datePickerController.datePickers[inpId] = new datePicker(options); | |
}; | |
}, | |
getDatePicker: function(inpId) { | |
if(!(inpId in datePickerController.datePickers)) { throw "No datePicker has been created for the form element with an id of '" + inpId.toString() + "'"; }; | |
return datePickerController.datePickers[inpId]; | |
}, | |
grepRangeLimits: function(sel) { | |
var range = []; | |
for(var i = 0; i < sel.options.length; i++) { | |
if(sel.options[i].value.search(/^\d\d\d\d$/) == -1) { continue; }; | |
if(!range[0] || Number(sel.options[i].value) < range[0]) { range[0] = Number(sel.options[i].value); }; | |
if(!range[1] || Number(sel.options[i].value) > range[1]) { range[1] = Number(sel.options[i].value); }; | |
}; | |
return range; | |
}, | |
create: function(inp) { | |
if(!(typeof document.createElement != "undefined" && typeof document.documentElement != "undefined" && typeof document.documentElement.offsetWidth == "number")) return; | |
var inputs = (inp && inp.tagName) ? [inp] : datePickerController.joinNodeLists(document.getElementsByTagName('input'), document.getElementsByTagName('select')); | |
var regExp1 = /disable-days-([1-7]){1,6}/g; // the days to disable | |
var regExp2 = /no-transparency/g; // do not use transparency effects | |
var regExp3 = /highlight-days-([1-7]){1,7}/g; // the days to highlight in red | |
var regExp4 = /range-low-(\d\d\d\d-\d\d-\d\d)/g; // the lowest selectable date | |
var regExp5 = /range-high-(\d\d\d\d-\d\d-\d\d)/g; // the highest selectable date | |
var regExp6 = /format-(d-m-y|m-d-y|y-m-d)/g; // the input/output date format | |
var regExp7 = /divider-(dot|slash|space|dash)/g; // the character used to divide the date | |
var regExp8 = /no-locale/g; // do not attempt to detect the browser language | |
var regExp9 = /no-fade/g; // always show the datepicker | |
var regExp10 = /hide-input/g; // hide the input | |
for(var i=0, inp; inp = inputs[i]; i++) { | |
if(inp.className && (inp.className.search(regExp6) != -1 || inp.className.search(/split-date/) != -1) && ((inp.tagName.toLowerCase() == "input" && (inp.type == "text" || inp.type == "hidden")) || inp.tagName.toLowerCase() == "select")) { | |
if(inp.id && document.getElementById('fd-'+inp.id)) { continue; }; | |
if(!inp.id) { inp.id = "fdDatePicker-" + datePickerController.uniqueId++; }; | |
var options = { | |
id:inp.id, | |
low:"", | |
high:"", | |
divider:"/", | |
format:"d-m-y", | |
highlightDays:[0,0,0,0,0,1,1], | |
disableDays:[0,0,0,0,0,0,0], | |
locale:inp.className.search(regExp8) == -1, | |
splitDate:0, | |
noTransparency:inp.className.search(regExp2) != -1, | |
staticPos:inp.className.search(regExp9) != -1, | |
hideInput:inp.className.search(regExp10) != -1 | |
}; | |
if(!options.staticPos) { | |
options.hideInput = false; | |
} else { | |
options.noTransparency = true; | |
}; | |
// Split the date into three parts ? | |
if(inp.className.search(/split-date/) != -1) { | |
if(document.getElementById(inp.id+'-dd') && document.getElementById(inp.id+'-mm') && document.getElementById(inp.id+'-dd').tagName.search(/input|select/i) != -1 && document.getElementById(inp.id+'-mm').tagName.search(/input|select/i) != -1) { | |
options.splitDate = 1; | |
}; | |
}; | |
// Date format(variations of d-m-y) | |
if(inp.className.search(regExp6) != -1) { | |
options.format = inp.className.match(regExp6)[0].replace('format-',''); | |
}; | |
// What divider to use, a "/", "-", "." or " " | |
if(inp.className.search(regExp7) != -1) { | |
var dividers = { dot:".", space:" ", dash:"-", slash:"/" }; | |
options.divider = (inp.className.search(regExp7) != -1 && inp.className.match(regExp7)[0].replace('divider-','') in dividers) ? dividers[inp.className.match(regExp7)[0].replace('divider-','')] : "/"; | |
}; | |
// The days to highlight | |
if(inp.className.search(regExp3) != -1) { | |
var tmp = inp.className.match(regExp3)[0].replace(/highlight-days-/, ''); | |
options.highlightDays = [0,0,0,0,0,0,0]; | |
for(var j = 0; j < tmp.length; j++) { | |
options.highlightDays[tmp.charAt(j) - 1] = 1; | |
}; | |
}; | |
// The days to disable | |
if(inp.className.search(regExp1) != -1) { | |
var tmp = inp.className.match(regExp1)[0].replace(/disable-days-/, ''); | |
options.disableDays = [0,0,0,0,0,0,0]; | |
for(var j = 0; j < tmp.length; j++) { | |
options.disableDays[tmp.charAt(j) - 1] = 1; | |
}; | |
}; | |
// The lower limit | |
if(inp.className.search(/range-low-today/i) != -1) { | |
options.low = datePickerController.dateFormat((new Date().getMonth() + 1) + "/" + new Date().getDate() + "/" + new Date().getFullYear(), true); | |
} else if(inp.className.search(regExp4) != -1) { | |
options.low = datePickerController.dateFormat(inp.className.match(regExp4)[0].replace(/range-low-/, ''), false); | |
if(!options.low) { | |
options.low = ''; | |
}; | |
}; | |
// The higher limit | |
if(inp.className.search(/range-high-today/i) != -1 && inp.className.search(/range-low-today/i) == -1) { | |
options.high = datePickerController.dateFormat((new Date().getMonth() + 1) + "/" + new Date().getDate() + "/" + new Date().getFullYear(), true); | |
} else if(inp.className.search(regExp5) != -1) { | |
options.high = datePickerController.dateFormat(inp.className.match(regExp5)[0].replace(/range-high-/, ''), false); | |
if(!options.high) { | |
options.high = ''; | |
}; | |
}; | |
// Always round lower & higher limits if a selectList involved | |
if(inp.tagName.search(/select/i) != -1) { | |
var range = datePickerController.grepRangeLimits(inp); | |
options.low = options.low ? range[0] + String(options.low).substr(4,4) : datePickerController.dateFormat(range[0] + "/01/01"); | |
options.high = options.high ? range[1] + String(options.low).substr(4,4) : datePickerController.dateFormat(range[1] + "/12/31"); | |
}; | |
datePickerController.addDatePicker(inp.id, options); | |
}; | |
}; | |
} | |
}; | |
})(); | |
datePickerController.addEvent(window, 'load', datePickerController.create); | |
datePickerController.addEvent(window, 'unload', datePickerController.destroy); | |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Hi im using this plugin, how can I disabled today for picking?
Thank you in advanced