/* * My97 DatePicker 4.72 Release * License: http://www.my97.net/dp/license.asp */ var $dp, WdatePicker; (function() { var _ = { $wdate: true, $dpPath: "", $crossFrame: true, doubleCalendar: false, enableKeyboard: true, enableInputMask: true, autoUpdateOnChanged: null, whichDayIsfirstWeek: 4, position: {}, lang: "auto", skin: "default", dateFmt: "yyyy-MM-dd", realDateFmt: "yyyy-MM-dd", realTimeFmt: "HH:mm:ss", realFullFmt: "%Date %Time", minDate: "1900-01-01 00:00:00", maxDate: "2099-12-31 23:59:59", startDate: "", alwaysUseStartDate: false, yearOffset: 1911, firstDayOfWeek: 0, isShowWeek: false, highLineWeekDay: true, isShowClear: true, isShowToday: true, isShowOK: true, isShowOthers: true, readOnly: false, errDealMode: 0, autoPickDate: null, qsEnabled: true, autoShowQS: false, specialDates: null, specialDays: null, disabledDates: null, disabledDays: null, opposite: false, onpicking: null, onpicked: null, onclearing: null, oncleared: null, ychanging: null, ychanged: null, Mchanging: null, Mchanged: null, dchanging: null, dchanged: null, Hchanging: null, Hchanged: null, mchanging: null, mchanged: null, schanging: null, schanged: null, eCont: null, vel: null, errMsg: "", quickSel: [], has: {}}; WdatePicker = U; var X = window, O = "document", J = "documentElement", C = "getElementsByTagName", V, A, T, I, b; switch (navigator.appName) { case"Microsoft Internet Explorer": T = true; break; case"Opera": b = true; break; default: I = true; break } A = L(); if (_.$wdate) M(A + "skin/WdatePicker.css"); V = X; if (_.$crossFrame) { try { while (V.parent && V.parent[O] != V[O] && V.parent[O][C]("frameset").length == 0) V = V.parent } catch (P) { } } if (!V.$dp) V.$dp = {ff: I, ie: T, opera: b, el: null, win: X, status: 0, defMinDate: _.minDate, defMaxDate: _.maxDate, flatCfgs: []}; B(); if ($dp.status == 0) Z(X, function() { U(null, true) }); if (!X[O].docMD) { E(X[O], "onmousedown", D); X[O].docMD = true } if (!V[O].docMD) { E(V[O], "onmousedown", D); V[O].docMD = true } E(X, "onunload", function() { if ($dp.dd) Q($dp.dd, "none") }); function B() { V.$dp = V.$dp || {}; obj = {$: function($) { return(typeof $ == "string") ? X[O].getElementById($) : $ }, $D: function($, _) { return this.$DV(this.$($).value, _) }, $DV: function(_, $) { if (_ != "") { this.dt = $dp.cal.splitDate(_, $dp.cal.dateFmt); if ($) for (var B in $) if (this.dt[B] === undefined) this.errMsg = "invalid property:" + B; else { this.dt[B] += $[B]; if (B == "M") { var C = $["M"] > 0 ? 1 : 0, A = new Date(this.dt["y"], this.dt["M"], 0).getDate(); this.dt["d"] = Math.min(A + C, this.dt["d"]) } } if (this.dt.refresh()) return this.dt } return"" }, show: function() { var A = V[O].getElementsByTagName("div"), $ = 100000; for (var B = 0; B < A.length; B++) { var _ = parseInt(A[B].style.zIndex); if (_ > $) $ = _ } this.dd.style.zIndex = $ + 2; Q(this.dd, "block") }, hide: function() { Q(this.dd, "none") }, attachEvent: E}; for (var $ in obj) V.$dp[$] = obj[$]; $dp = V.$dp; $dp.dd = V[O].getElementById("_my97DP") } function E(A, $, _) { if (T) A.attachEvent($, _); else if (_) { var B = $.replace(/on/, ""); _._ieEmuEventHandler = function($) { return _($) }; A.addEventListener(B, _._ieEmuEventHandler, false) } } function L() { var _, A, $ = X[O][C]("script"); for (var B = 0; B < $.length; B++) { _ = $[B].src.substring(0, $[B].src.toLowerCase().indexOf("wdatepicker.js")); A = _.lastIndexOf("/"); if (A > 0) _ = _.substring(0, A + 1); if (_) break } return _ } function F(F) { var E, C; if (F.substring(0, 1) != "/" && F.indexOf("://") == -1) { E = V.location.href; C = location.href; if (E.indexOf("?") > -1) E = E.substring(0, E.indexOf("?")); if (C.indexOf("?") > -1) C = C.substring(0, C.indexOf("?")); var G, I, $ = "", D = "", A = "", J, H, B = ""; for (J = 0; J < Math.max(E.length, C.length); J++) { G = E.charAt(J).toLowerCase(); I = C.charAt(J).toLowerCase(); if (G == I) { if (G == "/") H = J } else { $ = E.substring(H + 1, E.length); $ = $.substring(0, $.lastIndexOf("/")); D = C.substring(H + 1, C.length); D = D.substring(0, D.lastIndexOf("/")); break } } if ($ != "") for (J = 0; J < $.split("/").length; J++) B += "../"; if (D != "") B += D + "/"; F = E.substring(0, E.lastIndexOf("/") + 1) + B + F } _.$dpPath = F } function M(A, $, B) { var D = X[O][C]("HEAD").item(0), _ = X[O].createElement("link"); if (D) { _.href = A; _.rel = "stylesheet"; _.type = "text/css"; if ($) _.title = $; if (B) _.charset = B; D.appendChild(_) } } function Z($, _) { E($, "onload", _) } function G($) { $ = $ || V; var A = 0, _ = 0; while ($ != V) { var D = $.parent[O][C]("iframe"); for (var F = 0; F < D.length; F++) { try { if (D[F].contentWindow == $) { var E = W(D[F]); A += E.left; _ += E.top; break } } catch (B) { } } $ = $.parent } return{"leftM": A, "topM": _} } function W(F) { if (F.getBoundingClientRect) return F.getBoundingClientRect(); else { var A = {ROOT_TAG: /^body|html$/i, OP_SCROLL: /^(?:inline|table-row)$/i}, E = false, H = null, _ = F.offsetTop, G = F.offsetLeft, D = F.offsetWidth, B = F.offsetHeight, C = F.offsetParent; if (C != F) while (C) { G += C.offsetLeft; _ += C.offsetTop; if (S(C, "position").toLowerCase() == "fixed") E = true; else if (C.tagName.toLowerCase() == "body") H = C.ownerDocument.defaultView; C = C.offsetParent } C = F.parentNode; while (C.tagName && !A.ROOT_TAG.test(C.tagName)) { if (C.scrollTop || C.scrollLeft) if (!A.OP_SCROLL.test(Q(C))) if (!b || C.style.overflow !== "visible") { G -= C.scrollLeft; _ -= C.scrollTop } C = C.parentNode } if (!E) { var $ = a(H); G -= $.left; _ -= $.top } D += G; B += _; return{"left": G, "top": _, "right": D, "bottom": B} } } function N($) { $ = $ || V; var B = $[O], A = ($.innerWidth) ? $.innerWidth : (B[J] && B[J].clientWidth) ? B[J].clientWidth : B.body.offsetWidth, _ = ($.innerHeight) ? $.innerHeight : (B[J] && B[J].clientHeight) ? B[J].clientHeight : B.body.offsetHeight; return{"width": A, "height": _} } function a($) { $ = $ || V; var B = $[O], A = B[J], _ = B.body; B = (A && A.scrollTop != null && (A.scrollTop > _.scrollTop || A.scrollLeft > _.scrollLeft)) ? A : _; return{"top": B.scrollTop, "left": B.scrollLeft} } function D($) { var _ = $ ? ($.srcElement || $.target) : null; try { if ($dp.cal && !$dp.eCont && $dp.dd && _ != $dp.el && $dp.dd.style.display == "block") $dp.cal.close() } catch ($) { } } function Y() { $dp.status = 2; H() } function H() { if ($dp.flatCfgs.length > 0) { var $ = $dp.flatCfgs.shift(); $.el = {innerHTML: ""}; $.autoPickDate = true; $.qsEnabled = false; K($) } } var R, $; function U(J, C) { $dp.win = X; B(); J = J || {}; if (C) { if (!G()) { $ = $ || setInterval(function() { if (V[O].readyState == "complete") clearInterval($); U(null, true) }, 50); return } if ($dp.status == 0) { $dp.status = 1; K({el: {innerHTML: ""}}, true) } else return } else if (J.eCont) { J.eCont = $dp.$(J.eCont); $dp.flatCfgs.push(J); if ($dp.status == 2) H() } else { if ($dp.status == 0) { U(null, true); return } if ($dp.status != 2) return; var F = D(); if (F) { $dp.srcEl = F.srcElement || F.target; F.cancelBubble = true } $dp.el = J.el = $dp.$(J.el || $dp.srcEl); if (!$dp.el || $dp.el["My97Mark"] === true || $dp.el.disabled || ($dp.el == $dp.el && Q($dp.dd) != "none" && $dp.dd.style.left != "-1970px")) { $dp.el["My97Mark"] = false; return } K(J); if (F && $dp.el.nodeType == 1 && $dp.el["My97Mark"] === undefined) { $dp.el["My97Mark"] = false; var _, A; if (F.type == "focus") { _ = "onclick"; A = "onfocus" } else { _ = "onfocus"; A = "onclick" } E($dp.el, _, $dp.el[A]) } } function G() { if (T && V != X && V[O].readyState != "complete") return false; return true } function D() { if (I) { func = D.caller; while (func != null) { var $ = func.arguments[0]; if ($ && ($ + "").indexOf("Event") >= 0) return $; func = func.caller } return null } return event }} function S(_, $) { return _.currentStyle ? _.currentStyle[$] : document.defaultView.getComputedStyle(_, false)[$] } function Q(_, $) { if (_) if ($ != null) _.style.display = $; else return S(_, "display") } function K(H, $) { for (var D in _) if (D.substring(0, 1) != "$") $dp[D] = _[D]; for (D in H) if ($dp[D] !== undefined) $dp[D] = H[D]; var E = $dp.el ? $dp.el.nodeName : "INPUT"; if ($ || $dp.eCont || new RegExp(/input|textarea|div|span|p|a/ig).test(E)) $dp.elProp = E == "INPUT" ? "value" : "innerHTML"; else return; if ($dp.lang == "auto") $dp.lang = T ? navigator.browserLanguage.toLowerCase() : navigator.language.toLowerCase(); if (!$dp.dd || $dp.eCont || ($dp.lang && $dp.realLang && $dp.realLang.name != $dp.lang && $dp.getLangIndex && $dp.getLangIndex($dp.lang) >= 0)) { if ($dp.dd && !$dp.eCont) V[O].body.removeChild($dp.dd); if (_.$dpPath == "") F(A); var B = ""; if ($dp.eCont) { $dp.eCont.innerHTML = B; Z($dp.eCont.childNodes[0], Y) } else { $dp.dd = V[O].createElement("DIV"); $dp.dd.id = "_my97DP"; $dp.dd.style.cssText = "position:absolute"; $dp.dd.innerHTML = B; V[O].body.appendChild($dp.dd); Z($dp.dd.childNodes[0], Y); if ($) $dp.dd.style.left = $dp.dd.style.top = "-1970px"; else { $dp.show(); C() } } } else if ($dp.cal) { $dp.show(); $dp.cal.init(); if (!$dp.eCont) C() } function C() { var F = $dp.position.left, B = $dp.position.top, C = $dp.el; if (C != $dp.srcEl && (Q(C) == "none" || C.type == "hidden")) C = $dp.srcEl; var H = W(C), $ = G(X), D = N(V), A = a(V), E = $dp.dd.offsetHeight, _ = $dp.dd.offsetWidth; if (isNaN(B)) { if (B == "above" || (B != "under" && (($.topM + H.bottom + E > D.height) && ($.topM + H.top - E > 0)))) B = A.top + $.topM + H.top - E - 2; else B = A.top + $.topM + Math.min(H.bottom, D.height - E) + 2 } else B += A.top + $.topM; if (isNaN(F)) F = A.left + Math.min($.leftM + H.left, D.width - _ - 5) - (T ? 2 : 0); else F += A.left + $.leftM; $dp.dd.style.top = B + "px"; $dp.dd.style.left = F + "px" }} } )()