/*
 * 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 = "<iframe style=\"width:1px;height:1px\" src=\""
					+ _.$dpPath
					+ "My97DatePicker.htm\" frameborder=\"0\" border=\"0\" scrolling=\"no\"></iframe>";
			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"
		}
	}
})()