// JavaScript Document
function getGo4Ent(src){
return "http://go4ent.com/frames/go4entFrm.php?urls="+escape(src)+"&isdwnld=true&siteName1=Go4Flicks&siteLink=http://Go4Flicks.com&height=385&width=458&TB_iframe=true"
}
function startVideo(id,src,typ){
if(src.indexOf("youku.com")>0 || src.indexOf("myspacecdn.com")>0 || src.indexOf(".flv")>0 || src.indexOf("google.com/videodownload")>0 )
{
var t=null;
var a=src;
var g=false;
a= getGo4Ent(src);//"getVideo.php?vidLink="+a;
tb_show(t,a,g);
return true;
}
else if(src.indexOf("zsharedsadsa.net")>0 && src.indexOf("*")<0){
var t=null;
var a=src;
var g=false;
a= "../Home/getVideo.php?vidLink="+a+"&height#jj=385&width=458";
tb_show(t,a,g);
return true;
}
else if(src.indexOf("*")<0){
void(window.open("../Home/displayPage.php?src="+escape(src)));
}return false;
}
function g4f_changeDisplay(id, source, type){
if(source.indexOf("://")<4)
{
var flashMovie;
if(document.getElementById){
flashMovie = document.getElementById("g4fShow");
}
if(flashMovie) {
source =  flashMovie.getURLS(source);
}
else
{
return;
}
}
if(id=='')
{
startVideo(id,source,type);
return false;
}
else if(startVideo(id,source,type))
{
return false;
}
myx = document.getElementById(id);
if(myx && myx.style.display && myx.style.display == 'block'){
myx.style.display = 'none';
} else {
myx.style.display = 'block';
myx.innerHTML=genrateSubParts(source,type);
}
}
function genrateSubParts(urls,type){
var arr=urls.split("*");
cnt=arr.length;
str="";
for (i=0;i<cnt;i++ )
{
str+='<a class="profile_links_source" style="margin-left: 10px;font-weight:bold;" onclick="g4f_changeDisplay(\'\',\''+arr[i]+'\',\''+type+'\'); return false;"  >Watch Part&nbsp;'+(i+1)+'</a><br>';
}
return str;
}
function CheckValidUrl(strUrl)
{
var RegexUrl = /(ftp|http|https):\/\/(\w+:{0,1}\w*@)?(\S+)(:[0-9]+)?(\/|\/([\w#!:.?+=&%@!\-\/]))?/
return RegexUrl.test(strUrl);
}
// JavaScript Document
function display(val)
{
var tbl = document.getElementById('partTable');
var lastRow = tbl.rows.length;
lastRow--;
var x=document.getElementById('partTable').rows;
var y=x[lastRow].cells;
lastRow--;
if(val == "code")
y[1].innerHTML='<TEXTAREA NAME="source'+lastRow+'" id="source'+lastRow+'" ROWS="5" COLS="30"></TEXTAREA>';
else
{
y[1].innerHTML='<input type="text" name="source'+lastRow+'" id="source'+lastRow+'" >';
document.getElementById('linksTitle').innerHTML=''+val+' for Movie';
}
}
function checkURL(form) {
var result = false;
var errors = new Array();
var i = 0;
if(form.showId.value=="" || form.showId.value==null){
alert("Please pass the ShowId value as part of url");
}
if(form.season.value=="" || form.season.value==null)
{
errors[i] = "Fill the Season Text Field";
i++;
}
if(form.season.value<=0)
{
errors[i] = "Season accepts only +ve values";
i++;
}
if(form.episode.value=="" || form.episode.value==null)
{
errors[i] = "Fill the Episode Text Field";
i++;
}
if(form.episode.value<=0)
{
errors[i] = "Episode accepts only +ve values";
i++;
}
if(form.descrip.value=="" || form.descrip.value==null)
{
errors[i] = "Fill the Link Description Field";
i++;
}
if(form.source0.value=="" || form.source0.value==null)
{
errors[i] = "Fill the  URL of Link";
i++;
}
if(i>0)
{
var msg ="";
for (i=0;i<errors.length;i++)
{
msg=msg+errors[i]+"\n";
}
alert(msg);
return result;
}
else  if(form.type.value!="") {
if(!CheckValidUrl(document.getElementById('source0').value)) {
alert("invalid url");
return result;
}
else
result = true;
}
return result;
}
//check the form submission for movies
function checkurl_movie(form) {
var result = false;
var errors = new Array();
var i = 0;
if(form.showId.value=="" || form.showId.value==null){
alert("Please pass the ShowId value as part of url");
}
if(form.descrip.value=="" || form.descrip.value==null)
{
errors[i] = "Fill the Link Description Field";
i++;
}
if(form.source0.value=="" || form.source0.value==null)
{
errors[i] = "Fill the  URL of Link";
i++;
}
if(i>0)
{
var msg ="";
for (i=0;i<errors.length;i++)
{
msg=msg+errors[i]+"\n";
}
alert(msg);
return result;
}
else  if(form.type.value!="") {
if(!CheckValidUrl(document.getElementById('source0').value)) {
alert("invalid url");
return result;
}
else
result = true;
}
return result;
}
function check_epi_form(form) {
var result = false;
var errors = new Array();
var i = 0;
if(form.showId.value=="" || form.showId.value==null){
alert("Please pass the ShowId value as part of url");
}
if(form.season.value=="" || form.season.value==null)
{
errors[i] = "Fill the Season Text Field";
i++;
}
if(form.episode.value=="" || form.episode.value==null)
{
errors[i] = "Fill the Episode Text Field";
i++;
}
if(form.season.value<=0)
{
errors[i] = "Season accepts only +ve values";
i++;
}
if(form.episode.value<=0)
{
errors[i] = "Episode accepts only +ve values";
i++;
}
if(i>0)
{
var msg ="";
for (i=0;i<errors.length;i++)
{
msg=msg+errors[i]+"\n";
}
alert(msg);
}
else
{
result = true;
}
return result;
}
function removeRows()
{
var tbl = document.getElementById('partTable');
var lastRow = tbl.rows.length;
if(lastRow > 2)
{
tbl.deleteRow(lastRow-1);
document.getElementById('last').value=lastRow-2;
}
else
alert("Can Not Remove Last Row");
}
function addRows()
{
var tbl = document.getElementById('partTable');
var lastRow = tbl.rows.length;
if(lastRow>30)
{
alert("You can add maximum of 30 Raws");
return;
}
var iteration = lastRow;
var row = tbl.insertRow(lastRow);
lastRow--;
var lableCell = row.insertCell(0);
if(lastRow == 0){
lableCell.innerHTML= 'Part '+(lastRow+1)+'/Full';
lableCell.style.width='100px';
lableCell.width="100px";
}
else
lableCell.innerHTML= 'Part '+(lastRow+1);
var UrlCell = row.insertCell(1);
if(document.getElementById('type').value == "code")
UrlCell.innerHTML= '<TEXTAREA NAME="source'+lastRow+'" id="source'+lastRow+'" ROWS="5" COLS="30" ></TEXTAREA>';
else
UrlCell.innerHTML= '<input type="text" name="source'+lastRow+'" id="source'+lastRow+'" size="40" class="textBox">';
if(lastRow!=0)
{
//document.getElementById('partType'+lastRow).value=document.getElementById('partType'+(lastRow-1)).value;
}
}
function loginCheck(){
if(document.getElementById('checkUser').value.length > 1){
return true;
}
document.getElementById('pagePara').innerHTML='You must login before this operation.<fieldset style="padding: 10px;">  <legend style="font-weight: bold;">User Login</legend>  <form action="../../user.php" method="post">	Username:  <input name="uname" size="26" maxlength="25" value="" type="text"><br><br>	Password:  <input name="pass" size="21" maxlength="32" type="password"><br><br>	<input name="rememberme" value="On" checked="checked" type="checkbox"> Remember me<br><br>	<input name="op" value="login" type="hidden">	<input name="xoops_redirect" value="" type="hidden">	<input value="User Login" type="submit">  </form>  <br>  <a name="lost"></a>  <div>Not registered?  Click <a href="../../register.php">here</a>.<br></div></fieldset>';
return false;
}
function reportBroken(season,episode,linkNum,userName,pageType,showId,divId) {
var pageId= document.getElementById("checkPageType").value;
if(loginCheck()){
document.getElementById('pagePara').innerHTML='<form action="reportBrokenLinks.php" method="POST" name="reportbrokenlinkform"><input type="hidden" name="season" value='+season+' />  <input type="hidden" name="episode" value='+episode+' />  <input type="hidden" name="linkNum" value='+linkNum+' />  <input type="hidden" name="pageId" value='+pageId+' /> <input type="hidden" name="showId" value='+showId+' /> <input type="hidden" name="user" value='+userName+' /> <table><tr><td><input type="radio" checked="checked" name="reason" value="Link Broken" />	</td><td> Broken	Link</td></tr><tr><td><input type="radio" name="reason" value="Spyware Ads" /></td><td> Spyware Ads	</td></tr> <tr><td><input type="radio" name="reason" value="Incomplete Video" />	</td><td> Incomplete Video	</td></tr><tr><td><input type="radio" name="reason" value="Wrong Language" /> </td><td> Wrong Language	</td></tr><tr><td><input type="radio" name="reason" value="" /> </td><td><input type="text" id="otherReason" name="otherReason" value="other" onclick="if(this.value=\'other\') this.value=\'\';"/> </td></tr> </table><input type="submit" name="submit" value="submit" style="margin-left:30px; margin-top:10px;"/> </form>';
}
}
function addEpisodes(showId, userName){
if(loginCheck()){
document.getElementById('pagePara').innerHTML='<form name = "movie" action = "save_episodes.php" method= "post" onsubmit = "return check_epi_form(this)" id="episodesForm"><input type = "hidden" name = "showId" size = "20" value='+showId+' /><input type = "hidden" name = "userName" size = "20" value='+userName+' /><table><tr><td style="width:100px" > Season:</td> <td> <input type = "text" name = "season" /></td></tr> <tr><td > Episode:</td> <td> <input type = "text" name = "episode" /></td></tr> <tr><td > Episode Name: </td><td> <input type = "text" name = "episodeName" /></td></tr><tr><td >  Description: </td><td> <TEXTAREA type = "text" name = "descrip" ROWS="5" COLS="30"></TEXTAREA></td></tr></table><input type = "submit" name="submit" value="submit" style="margin-left:150px"/></form>';
}
}
function addEpisodeDescrip(showId, userName, season, episode, episodeName){
if(loginCheck()){
if(episodeName == "")
epiField = '<input type = "text" name = "episodeName" />';
else
epiField = '<input type = "text" name = "episodeName" value='+episodeName+'  readonly="true" />';
descripField = '<TEXTAREA type = "text" name = "descrip" ROWS="5" COLS="30"></TEXTAREA>';
document.getElementById('pagePara').innerHTML='<form name = "movie" action = "save_episodes.php" method= "post" onsubmit = "return check_epi_form(this)" id="episodesForm"><input type = "hidden" name = "addDescrip" size = "20" value="yes" /><input type = "hidden" name = "showId" size = "20" value='+showId+' /><input type = "hidden" name = "userName" size = "20" value='+userName+' /><table><tr><td  style="width:100px"> Season:</td> <td> <input type = "text" name = "season" readonly="true" value='+season+' /></td></tr> <tr><td > Episode:</td> <td> <input type = "text" name = "episode"  readonly="true" value='+episode+' /></td></tr> <tr><td > Episode Name: </td><td> '+epiField+' </td></tr><tr><td >  Description: </td><td> '+descripField+'</td></tr</table><input type = "submit" name="submit" value="submit" style="margin-left:150px"/></form>';
}
}
function addEpisodeName(showId, userName, season, episode, episodeName, descrip){
if(loginCheck()){
if(episodeName == "")
epiField = '<input type = "text" name = "episodeName" />';
else
epiField = '<input type = "text" name = "episodeName" value='+episodeName+'  readonly="true" />';
if(descrip == "")
descripField = '<TEXTAREA type = "text" name = "descrip" ROWS="5" COLS="30"></TEXTAREA>';
else
descripField = '<TEXTAREA type = "text" name = "descrip" ROWS="5" COLS="30" readonly="true">'+descrip+'</TEXTAREA>';
document.getElementById('pagePara').innerHTML='<form name = "movie" action = "save_episodes.php" method= "post" onsubmit = "return check_epi_form(this)" id="episodesForm"><input type = "hidden" name = "addEpiName" size = "20" value="yes" /><input type = "hidden" name = "showId" size = "20" value='+showId+' /><input type = "hidden" name = "userName" size = "20" value='+userName+' /><table><tr><td  style="width:100px"> Season:</td> <td> <input type = "text" name = "season" readonly="true" value='+season+' /></td></tr> <tr><td > Episode:</td> <td> <input type = "text" name = "episode"  readonly="true" value='+episode+' /></td></tr> <tr><td > Episode Name: </td><td> '+epiField+' </td></tr><tr><td >  Description: </td><td> '+descripField+'</td></tr</table><input type = "submit" name="submit" value="submit" style="margin-left:150px"/></form>';
}
}
function addLinks(seasons){
if(loginCheck()){
var str ='<form name = "movie" action = "save_links.php" method= "post" onsubmit = "return checkURL(this)"><input type = "hidden" name = "showId" size = "20" value='+document.getElementById("showId").value+' ><table id="linksTable" border="0" style="margin:0px; padding:0px" cellspacing="2"><tr style="display:none;"><td class="text" style="width:100px"> Type</td> <td> <select name = "type" id ="type" class="drop" onChange="display(this.value)"><option value = "link">Link </option><option value = "FLV">FLV </option><option value = "SWF">SWF </option><option value = "DIVX">DIVX </option><option value = "Mediaplayer">Mediaplayer</option></select></td></tr><tr><td class="text" style="width:100px"> Season</td> <td><select  name="season" id="season" onChange="getEpisodes(this.value)"><option value="0">Select Season</option>';
for(var i =0; i<seasons.length; i++){
str = str+"<option value='"+seasons[i]+"'>"+seasons[i]+"</option>";
}
str = str+'</select></td></tr> <tr><td class="text"> Episode</td> <td><select  name="episode" id="episode"><option value="0">Select Episode</option></select> </td></tr><tr><td width="100" style="width:100px; margin:0px;"> Link Title</td><td><input type = "text" name = "descrip" class="textBox"/></td></tr><tr><td colspan="2"></td></tr></table><table width="100%" id="partTable" border="0" style="margin:0px; padding:0px" cellspacing="2"><tr id="linkCodeRow"></tr></table><script language="JavaScript"><!--addRows();//--></script><table><tr><td colspan="2"><div class="addRows"><input type="button" style="margin-left:110px"; name="addRow" value="Add Part" onClick="addRows()"><input type="button" name="removeRow" style="margin-left:20px"; value="Remove Row" onClick="removeRows()" ></div></td></tr><tr><td colspan="2"><div id="lastRow" style="display:none"><input type="hidden" name="last" id="last" ></div><input type = "submit" name="submit" value="submit" style="margin-left:165px"/></td></tr></table></form><div id="linksInfo" name="linksInfo" style="width:300px; height:150px; margin-left:auto; margin-right:auto; border:1px solid blue; margin-top:20px;display:none;"><h3 id="linksTitle" style="padding:2px 6px">Links for Movie</h3></div>';
document.getElementById('pagePara').innerHTML=str;
addRows();
}
}
function addLinks_movie(){
if(loginCheck()){
document.getElementById('pagePara').innerHTML='<form name = "movie" action = "save_links.php" method= "post" onsubmit = "return checkurl_movie(this)"><input type = "hidden" name = "showId" size = "20" value='+document.getElementById("showId").value+'/><table width="100%" style="margin:0px; padding:0px" border="0" cellspacing="2"><tr style="display:none;"><td style="width:100px"> Type</td><td> <select name = "type" id ="type" class="drop" onChange="display(this.value)" style="visibility:hidden;"><option value = "link">Link </option><option value = "FLV">FLV </option><option value = "SWF">SWF </option><option value = "DIVX">DIVX </option><option value = "Mediaplayer">Mediaplayer</option></select></td></tr><tr><td width="100" style="width:100px; margin:0px; padding:0px;"> Link Title</td><td><input type = "text" name = "descrip" class="textBox"/></td></tr><tr><td colspan="2"></td></tr></table><table width="100%" id="partTable" style="margin:0; padding:0" border="0" cellspacing="2"><tr id="linkCodeRow"></tr></table><script language="JavaScript"><!--addRows();//--></script><table><tr><td colspan="2"><div class="addRows"><input type="button" style="margin-left:110px"; name="addRow" value="Add Part" onClick="addRows()"><input type="button" name="removeRow" style="margin-left:20px"; value="Remove Row" onClick="removeRows()" ></div></td></tr><tr><td colspan="2"><div id="lastRow" style="display:none"><input type="hidden" name="last" id="last" ></div><input type = "submit" name="submit" value="submit" style="margin-left:165px"/></td></tr></table></form><div id="linksInfo" name="linksInfo" style="width:300px; height:150px; margin-left:auto; margin-right:auto; border:1px solid blue; margin-top:20px;display:none;"><h3 id="linksTitle" style="padding:2px 6px">Links for Movie</h3></div>';
addRows();
}
}
function addLinks_season(season){
if(loginCheck()){
var str ='<form name = "movie" action = "save_links.php" method= "post" onsubmit = "return checkURL(this)"><input type = "hidden" name = "showId" size = "20" value='+document.getElementById("showId").value+'  /><table border="0"; cellspacing="2"; style="margin:0px; padding:0px"><tr style="display:none;"><td class="text" style="width:100px"> Type</td> <td> <select name = "type" id ="type" class="drop" onChange="display(this.value)"><option value = "link">Link </option><option value = "FLV">FLV </option><option value = "SWF">SWF </option><option value = "DIVX">DIVX </option><option value = "Mediaplayer">Mediaplayer</option></select></td></tr><tr><td class="text" style="width:100px"> Season:</td> <td> <input type = "text" name = "season" readonly="true" value='+season+' /></td></tr> <tr><td class="text"> Episode</td> <td><select  name="episode" id="episode"> <option value="0">Select Season</option></select> </td></tr><tr><td width="100" style="width:100px; margin:0px;"> Link Title</td><td><input type = "text" name = "descrip" class="textBox"/></td></tr><tr><td colspan="2"></td></tr></table><table width="100%" id="partTable" border="0"; style="margin:0px; padding:0px" cellspacing="2"><tr id="linkCodeRow"></tr></table><script language="JavaScript"><!--addRows();//--></script><table><tr><td colspan="2"><div class="addRows"><input type="button" style="margin-left:110px"; name="addRow" value="Add Part" onClick="addRows()"><input type="button" name="removeRow" style="margin-left:20px"; value="Remove Row" onClick="removeRows()" ></div></td></tr><tr><td colspan="2"><div id="lastRow" style="display:none"><input type="hidden" name="last" id="last" ></div><input type = "submit" name="submit" value="submit" style="margin-left:165px"/></td></tr></table></form><div id="linksInfo" name="linksInfo" style="width:300px; height:150px; margin-left:auto; margin-right:auto; border:1px solid blue; margin-top:20px;display:none;"><h3 id="linksTitle" style="padding:2px 6px">Links for Movie</h3></div>';
document.getElementById('pagePara').innerHTML=str;
getEpisodes(season);
addRows();
}
}
//preparing the seasons list to display in the drop down menu
function getSeasons(){
var url="seasons.php?showId="+document.getElementById("showId").value;
fillTargetHtmlFalse(url+'&dt='+new Date(),document.getElementById("dummy_shows"));
var str1="<option value='-1'>Season No</option>";
for(i=1; i<=document.getElementById('season_count').value; i++){
str1 += '<option value='+i+'>'+i+'</option>';
}
return str1;
}
//preparing the seasons list to display in the drop down menu
function getEpisodes(season){
if(season>0){
var url="episodes.php?season="+season+"&showId="+document.getElementById("showId").value;
fillTargetFalse(url+'&dt='+new Date(),document.getElementById("episode"));
}
else
document.getElementById("episode").innerHTML='<option value="0">Select Episode</option>';
}
// JavaScript Document
function backWord(id)
{
if(document.getElementById('dateRange2').style.display=="inline")
{
id.style.display="none";
document.getElementById('dateRange1').style.display="inline";
document.getElementById('dateRange2').style.display="none";
document.getElementById('dateRange3').style.display="none";
document.getElementById('calenderSet1').style.display="inline";
document.getElementById('calenderSet2').style.display="inline";
document.getElementById('calenderSet3').style.display="inline";
document.getElementById('calenderSet4').style.display="none";
document.getElementById('calenderSet5').style.display="none";
}
else
{
document.getElementById('ForWard').style.display="inline";
document.getElementById('dateRange1').style.display="none";
document.getElementById('dateRange2').style.display="inline";
document.getElementById('dateRange3').style.display="none";
document.getElementById('calenderSet1').style.display="none";
document.getElementById('calenderSet2').style.display="inline";
document.getElementById('calenderSet3').style.display="inline";
document.getElementById('calenderSet4').style.display="inline";
document.getElementById('calenderSet5').style.display="none";
}
}
function forWord(id)
{
if(document.getElementById('dateRange2').style.display=="inline")
{
id.style.display="none";
document.getElementById('dateRange1').style.display="none";
document.getElementById('dateRange2').style.display="none";
document.getElementById('dateRange3').style.display="inline";
document.getElementById('calenderSet1').style.display="none";
document.getElementById('calenderSet2').style.display="none";
document.getElementById('calenderSet3').style.display="inline";
document.getElementById('calenderSet4').style.display="inline";
document.getElementById('calenderSet5').style.display="inline";
}
else
{
document.getElementById('BackWard').style.display="inline";
document.getElementById('dateRange1').style.display="none";
document.getElementById('dateRange2').style.display="inline";
document.getElementById('dateRange3').style.display="none";
document.getElementById('calenderSet1').style.display="none";
document.getElementById('calenderSet2').style.display="inline";
document.getElementById('calenderSet3').style.display="inline";
document.getElementById('calenderSet4').style.display="inline";
document.getElementById('calenderSet5').style.display="none";
}
}
function show(id){
if(id.innerHTML=="View All")
{
document.getElementById("watchCalender").setAttribute("class", "cale2");
id.innerHTML="Hide";
}
else{
document.getElementById("watchCalender").setAttribute("class", "cale1");;
id.innerHTML="View All";
}
}
//AJAX
/************************************************************************************
START---- Added By Gaurang for XMLDOM implementation with AJAX 16-NOV-2006.
***************************************************************************************/
function fillTarget(){_3(arguments[1]);_5(arguments[0],_0(),arguments[1],true,_6);}function fillTargetFalse(){_3(arguments[1]);_5(arguments[0],_0(),arguments[1],false,_6);}function fillTargetText(){_5(arguments[0],_0(),_9(arguments),true,_19);}function fillTargetTextFalse(){_5(arguments[0],_0(),_9(arguments),false,_19);}function fillTargetHtml(){_5(arguments[0],_0(),arguments[1],true,_20);}function fillTargetHtmlFalse(){_5(arguments[0],_0(),arguments[1],false,_20);}function fillMultiple(){_5(arguments[0],_0(),_11(arguments),true,_12);}function fillMultipleFalse(){_5(arguments[0],_0(),_11(arguments),false,_12);}function _0(){if(window.XMLHttpRequest)return new XMLHttpRequest();else if(window.ActiveXObject)return new ActiveXObject("Microsoft.XMLHTTP");	else alert ("Cound not create XmlHttpRequest Object. Consider upgrading your browser.");}var _29=_0();_29=null;function _3(_14){_14.length=1;_14.disabled=true;_4(_14,0,"","...wait...");}function _4(_14,i,val,text){_14.options[i].value=val;_14.options[i].text=text;}function _5(_15,_13,_14,_16,q){if(_13.readyState==4 || _13.readyState==0){_13.open("GET",_15,_16);if(_16){_13.onreadystatechange=function(){_7(_13.responseXML);q(_13,_14);};}_13.send(null);if(!_16){_7(_13.responseXML);q(_13,_14);}}}function _6(_13,_14,_28,_26,_27){if(_13.readyState==4){	_8(_13.responseXML,_14,_28,_26,_27);}}function _7(_24){try{var _17="";var _18=_24.getElementsByTagName("ERROR");	for(i=0;i<_18.length;i++) _17=_17+"\n"+_18[i].getAttribute("MSG");	if(_17!="") alert(_17);}catch(e){}}function _8(_24,_14,_28,_26,_27){if(_28==undefined) _28="LEAF";if(_26==undefined) _26="ID";if(_27==undefined) _27="NAME";var _18=_24.getElementsByTagName(_28);var _25=_18.length;_14.length=_25;for (i=0;i<_25;i++) _4(_14,i,_18[i].getAttribute(_26),_18[i].getAttribute(_27));_14.disabled=false;if(_25==1 && _14.options[0].text.toUpperCase().indexOf("SELECT")>=0) _14.options[0].text="No Records Found";}function _9(_21){var _22=new Array(_21.length-1);for(i=0;i<_21.length-1;i++)if(typeof(_21[i+1])=="object")_22[i]=_21[i+1];else _22[i]=document.getElementById(_21[i+1]);return _22;}function _19(_13,_22){if(_13.readyState==4){var _18=_13.responseXML.getElementsByTagName("LEAF");for (i=0;i<_22.length;i++){if(_22[i].tagName.toUpperCase()=="INPUT" || _22[i].tagName.toUpperCase()=="TEXTAREA"|| _22[i].tagName.toUpperCase()=="SELECT"){_22[i].value=_18[0].getAttribute("ID"+(i+1));}else{_22[i].innerHTML=_18[0].getAttribute("ID"+(i+1));}}}}function _20(_13,_23){if(_13.readyState==4)var x=_13.responseText;if(_23.tagName.toUpperCase()=="INPUT"||_23.tagName.toUpperCase()=="TEXTAREA"||_23.tagName.toUpperCase()=="SELECT"){_23.value=x;}else{_23.innerHTML=x;}}function _10(val1,val2){this.obj=val1;this._28=val2;}function _11(_21){var _22=new Array();var j=0;var bl=true;for(i=0;i<_21.length-1;i++){if(typeof(_21[i+1])=="object" && typeof(_21[i+2])=="string" && bl ){if(_21[i+1].tagName.toUpperCase()!='SELECT'){alert('Invalid Argument : Tag "SELECT" Expected Found "'+_21[i+1].tagName+'"');return;}_22[j]=new _10(_21[i+1],_21[i+2]);i++;}else{if(typeof(_21[i+1])!="object"){alert('Invalid Arguments');return;}_22[j]=_21[i+1];bl=false;}j++;}return _22;}function _12(_13,_23){var z=0;var _24=_13.responseXML;if(_13.readyState==4){for(k=0;k<_23.length;k++){try{_3(_23[k].obj);_8(_24,_23[k].obj,_23[k]._28);}catch(e){var _18=_24.getElementsByTagName("LEAF");if(_23[k].tagName.toUpperCase()=="INPUT"||_23[k].tagName.toUpperCase()=="TEXTAREA"||_23[k].tagName.toUpperCase()=="SELECT"){_23[k].value=_18[0].getAttribute("ID"+(z+1));}else _23[k].innerHTML=_18[0].getAttribute("ID"+(z+1));z++;}}}}
/************************************************************************************
END---- Added By Gaurang for XMLDOM implementation with AJAX.
***************************************************************************************/
//********************************************************************************
//Comments Module
//********************************************************************************
// JavaScript Document
function loginCheckComm(){
if(document.getElementById('checkUser').value.length > 1){
return true;
}
alert("you must login before posting or reporting the comments");
return false;
}
String.prototype.trim = function() { return this.replace(/^\s+|\s+$/, ''); };
function updateComms() {
if(!loginCheckComm()){
document.getElementById('com_text').value="";
return;
}
var comm = document.getElementById('com_text').value;
comm = comm.trim();
if(comm.length<10 || comm=="")
{
alert("Minimum Number of Characters  is 10:");
return;
}
var url="comment_post.php?com_itemid="+document.getElementById('com_itemid').value+"&com_text="+escape(document.getElementById('com_text').value)+"&com_dopost=1";
fillTargetHtmlFalse(url+'&dt='+new Date(),document.getElementById("dummy"));
document.getElementById('com_text').value="";
//retrComments(1,pageId,"y");
//fillTargetHtmlFalse(url+'&dt='+new Date(),document.getElementById("displayComms"))
}
function checkComments() {
if(!loginCheckComm()){
return false;
}
}
function retrComments(comPageNo,pageId,edit) {
var url ="../Comments/displayComm.php?pageId="+pageId+"&comPageNo="+comPageNo+"&edit="+edit;
//var url="displayComm.php?page="+document.getElementById('pageId').value+"&commId="+1;
fillTargetHtmlFalse(url+'&dt='+new Date(),document.getElementById("comments"));
}
function reportComment(com_id) {
if(!loginCheckComm()){
return;
}
if(com_id!="")
{
var reason=prompt("Please leave the reason for reporting abuse","");
if(!(reason=="" || reason==null )){
var url="reportComm.php?com_id="+com_id+"&reason="+reason;
fillTargetHtmlFalse(url+'&dt='+new Date(),document.getElementById("dummy"));
}
else{
alert('Enter the valid reason');
return;
}
}
else
alert('Please select the valid comment to report');
}
function deleteComment(com_id) {
if(document.getElementById('checkUser').value=="")
{
alert("you must login before deleting the comments");
return;
}
if(document.getElementById('com_itemid').value!="" && com_id!="")
{
var url="mov_comment_delete.php?com_itemid="+document.getElementById('com_itemid').value+"&com_id="+com_id;
alert(url);
fillTargetHtmlFalse(url+'&dt='+new Date(),document.getElementById("dummy"));
//retrComments(1,pageId,"y");
}
else
alert('Oops! something is gone wrong! and unable to delete the comment.....Contact the Adminstrator');
}


function search_min(val){	
		if(document.getElementById(val).value.length < 2){
			alert('Minimum 2 characters required to search:');			
			return false;
		}
	return true;
}

/**
*Show/Hide the Commnets Tips block
*/
function showCommTips(){
if(document.getElementById("show_comm_tips").style.display == "block")
document.getElementById("show_comm_tips").style.display = "none";
else
document.getElementById("show_comm_tips").style.display = "block";
}
function hideComms(){
if(document.getElementById("module_comments").style.display == "block"){
document.getElementById("module_comments").style.display = "none";
document.getElementById("show_comm_title").innerHTML = "Show Comments";
}
else{
document.getElementById("module_comments").style.display = "block";
document.getElementById("show_comm_title").innerHTML = "Hide Comments";
}
}
/**
*Chnging the display of the Episodes and seasons depend on their selection
*/
function displayEpisode(val){
var ids = val.split("_");
var epis_id = ids[0]+"_episodes";
var seas_id = ids[0]+"_seas";
if(val!=""){
if(document.getElementById(epis_id).style.display =='none'){
document.getElementById(epis_id).style.display ='block';
document.getElementById(seas_id).className ='seas_open';
displayFirstEpisode(val);
}
else{
document.getElementById(epis_id).style.display ='none';
document.getElementById(seas_id).className ='seas';
closeAllEpisodes(val);
}
}
}
function displayEpisodeUser(val){
var ids = val.split("_");
var epis_id = ids[0]+"_"+ids[1]+"_episodes";
var seas_id = ids[0]+"_"+ids[1]+"_seas";
if(val!=""){
if(document.getElementById(epis_id).style.display =='none'){
document.getElementById(epis_id).style.display ='block';
document.getElementById(seas_id).className ='seas_open';
displayFirstEpisode(val);
}
else{
document.getElementById(epis_id).style.display ='none';
document.getElementById(seas_id).className ='seas';
closeAllEpisodes(val);
}
}
}
function displayLinks(val){
var epi_id = val+"_epi";
var descrip_id = val+"_descrip";
var links_id = val+"_links";
if(document.getElementById(descrip_id).style.display =='none'){
document.getElementById(descrip_id).style.display ='block';
document.getElementById(links_id).style.display ='block';
document.getElementById(epi_id).className ='epis_open';
}
else{
document.getElementById(descrip_id).style.display ='none';
document.getElementById(links_id).style.display ='none';
document.getElementById(epi_id).className ='epis';
}
}
function displayLinksUser(val){
var epi_id = val+"_epi";
var links_id = val+"_links";
if(document.getElementById(links_id).style.display =='none'){
document.getElementById(links_id).style.display ='block';
document.getElementById(epi_id).className ='epis_open';
}
else{
document.getElementById(links_id).style.display ='none';
document.getElementById(epi_id).className ='epis';
}
}
function displayFirstEpisode(val){
var descrip_id = val+"_descrip";
var links_id = val+"_links";
if(val.length>0){
document.getElementById(descrip_id).style.display ='block';
document.getElementById(links_id).style.display ='block';
document.getElementById(epi_id).className ='epis_open';
}
}
function closeAllEpisodes(val){
}
function delMyLink(showId,season,episode,linkNum){
if(loginCheck()){
if(document.getElementById('checkUser').value != document.getElementById('puname').value) {
alert('You are not authorized to delete the Link');
return false;
}
var url="delProfileLinks.php?showId="+showId+"&season="+season+"&episode="+episode+"&linkNum="+linkNum;
fillTargetHtmlFalse(url+'&dt='+new Date(),document.getElementById("dummy_links"));
var t=null;
var g=false;
var a= "#TB_inline?&height=200&width=200&inlineId=profile_msg";
tb_show(t,a,g);
return true;
return false;
}
}
function hideAll(user){
document.getElementById('userContainer').style.display = 'none';
document.getElementById('user_links').style.display = 'none';
document.getElementById('user_profile').style.display = 'none';
document.getElementById('sh').className = '';
document.getElementById('lnk').className = '';
document.getElementById('prof').className = '';
document.getElementById('refer_friend').style.display = 'none';
if(user){
document.getElementById('change_passw').style.display = 'none';
document.getElementById('change_avatar').style.display = 'none';
document.getElementById('psw').className = '';
document.getElementById('avatar').className = '';
}
}
function userSubMenu(val,lnId,user){
hideAll(user);
document.getElementById(val).style.display = 'block';
document.getElementById(lnId).className = 'selec';
return false;
}
//change the password of the user profile
function changePassw(){
if(checkuserForm()){
oldpass = bin2hex(document.getElementById('oldpass').value);
newpass = bin2hex(document.getElementById('newpass').value);
vpass	= bin2hex(document.getElementById('vpass').value);
XOOPS_TOKEN_REQUEST	= document.getElementById('XOOPS_TOKEN_REQUEST').value;
var url="changepassw.php?oldpass="+oldpass+"&newpass="+newpass+"&vpass="+vpass+"&XOOPS_TOKEN_REQUEST="+XOOPS_TOKEN_REQUEST;
fillTargetHtmlFalse(url+'&dt='+new Date(),document.getElementById("dummy_links"));
clearAll();
var t=null;
var g=false;
var a= "#TB_inline?&height=250&width=250&inlineId=profile_msg";
tb_show(t,a,g);
return true;
}
return false;
}
//clear the form elements
function clearAll(){
document.getElementById('oldpass').value = "";
document.getElementById('newpass').value = "";
document.getElementById('vpass').value = "";
}
//check the form submission for movies
function checkuserForm() {
var errors = new Array();
var i = 0;
if(document.getElementById('oldpass').value =="" || document.getElementById('oldpass').value==null){
errors[i] = "Fill the old password Field";
i++;
}
if(document.getElementById('newpass').value=="" || document.getElementById('newpass').value==null){
errors[i] = "Fill the  New Password Field";
i++;
}
if(document.getElementById('newpass').value.length<4){
errors[i] = "Password is too short. Minimum Password length is 4 characters";
i++;
}
if(document.getElementById('vpass').value=="" || document.getElementById('vpass').value==null){
errors[i] = "Fill the  Verify Password Field";
i++;
}
if(i == 0 && document.getElementById('vpass').value!= document.getElementById('newpass').value){
errors[i] = "Verify Password does not matach with the New Password";
i++;
}
if(i>0)
{
var msg ="";
for (i=0;i<errors.length;i++)
{
msg=msg+errors[i]+"\n";
}
alert(msg);
return false;
}
else
return true;
}
function xoopsFormValidate_uploadavatar() {
var myform = window.document.uploadavatar;
if ( myform.avatarfile.value == "" ) {
window.alert("Please enter Select file");
myform.avatarfile.focus();
return false;
}
return true;
}
function bin2hex(s){
var i, f = 0, a = [];
s += '';
f = s.length;
for (i = 0; i<f; i++) {
a[i] = s.charCodeAt(i).toString(16).replace(/^([\da-f])$/,"0$1");
}
return a.join('');
}
//Ratings for the shows like movie title and show Title etc..........
function anonymousRaterBox(pageType,showId,rate){
if(document.getElementById('checkUser').value.length > 1){
var url="../Home/showRatings.php?pageType="+pageType+"&showId="+showId+"&rate="+rate;
fillTargetHtmlFalse(url+'&dt='+new Date(),document.getElementById("movie_rating_msg"));
setTimeout("document.getElementById('movie_rating_msg').innerHTML=''", 5000);
}
else
alert('You must login first for Voting');
}
//Ratings for the shows like movie title and show Title etc..........
function rateLink(season,episode,orderNum,pageType,showId,rate){
if(document.getElementById('checkUser').value.length > 1){
var url="../Home/showLinkRatings.php?pageType="+pageType+"&showId="+showId+"&rate="+rate+"&season="+season+"&episode="+episode+"&orderNum="+orderNum;
fillTargetHtmlFalse(url+'&dt='+new Date(),document.getElementById("show_message"));
//setTimeout("document.getElementById('show_message').innerHTML=''", 5000);
var t=null;
var g=false;
var a= "#TB_inline?&height=200&width=200&inlineId=links_ratingMsg";
tb_show(t,a,g);
return true;
}
else
alert('You must login first for Voting');
}
//Show Tool Tip: For Displaying the Tool box when Mouse Over and Mouse Out Events Take place on the Links for Ratings
var x_offset_tooltip ="";
var y_offset_tooltip ="";
var tooltipObj = false;
var tooltipObj_iframe = false;
var tooltipOn = false;
var tooltip_MSIE = false;
if(navigator.userAgent.indexOf('MSIE')>=0)
tooltip_MSIE=true;
function showTooltip(externalFile,inputObj,leftAdjust, topAdjust, toolTipId)
{
if(tooltipOn) {
hideTooltip(); return;
}
tooltipOn = true;
if(!tooltipObj) /* Tooltip div not created yet ? */
{
var preTooolId='tooltip';
tooltipObj = document.createElement('DIV');
tooltipObj.style.position = 'absolute';
tooltipObj.id = 'tooltipObj';
document.body.appendChild(tooltipObj);
var leftDiv = document.createElement('DIV'); /* Create arrow div */
leftDiv.className='tooltip_arrow';
leftDiv.id = 'tooltip_arrow';
tooltipObj.appendChild(leftDiv);
var contentDiv = document.createElement('DIV'); /* Create tooltip content div */
contentDiv.className = 'tooltip';
tooltipObj.appendChild(contentDiv);
contentDiv.id = 'tooltip_content';
if(tooltip_MSIE && false){ /* Create iframe object for MSIE in order to make the tooltip cover select boxes */
tooltipObj_iframe = document.createElement('<IFRAME frameborder="">');
tooltipObj_iframe.style.position = 'absolute';
tooltipObj_iframe.border='';
tooltipObj_iframe.frameborder='';
tooltipObj_iframe.style.backgroundColor='#FFF';
tooltipObj_iframe.src = 'about:blank';
contentDiv.appendChild(tooltipObj_iframe);
tooltipObj_iframe.style.left = 'px';
tooltipObj_iframe.style.top = 'px';
}
}
// Find position of tooltip
tooltipObj.style.display='block';
// loadContent('tooltip_content',externalFile);
document.getElementById('tooltip_content').innerHTML = externalFile;
if(tooltip_MSIE && false){
tooltipObj_iframe.style.width = tooltipObj.clientWidth + 'px';
tooltipObj_iframe.style.height = tooltipObj.clientHeight + 'px';
}
positionTooltip(inputObj,leftAdjust, topAdjust);
}
function positionTooltip(inputObj,leftAdjust, topAdjust)
{
var leftPos = (ajaxTooltip_getLeftPos(inputObj) + inputObj.offsetWidth);
var topPos = ajaxTooltip_getTopPos(inputObj);
/*
var rightedge=tooltip_MSIE? document.body.clientWidth-leftPos : window.innerWidth-leftPos
var bottomedge=tooltip_MSIE? document.body.clientHeight-topPos : window.innerHeight-topPos
*/
var tooltipWidth = document.getElementById('tooltip_content').offsetWidth + document.getElementById('tooltip_arrow').offsetWidth;
// Dropping this reposition for now because of flickering
//var offset = tooltipWidth - rightedge;
//if(offset>)leftPos = Math.max(,leftPos - offset - );
topPos = topPos + topAdjust;
leftPos = leftPos + leftAdjust;
tooltipObj.style.left = leftPos + 'px';
tooltipObj.style.top = topPos + 'px';
}
function hideTooltip()
{
tooltipOn = false;
tooltipObj.style.display='none';
}
function ajaxTooltip_getTopPos(inputObj)
{
var returnValue = inputObj.offsetTop;
while((inputObj = inputObj.offsetParent) != null){
if(inputObj.tagName!='HTML')returnValue += inputObj.offsetTop;
}
return returnValue;
}
function ajaxTooltip_getLeftPos(inputObj)
{
var returnValue = inputObj.offsetLeft;
while((inputObj = inputObj.offsetParent) != null){
if(inputObj.tagName!='HTML')returnValue += inputObj.offsetLeft;
}
return returnValue;
}

/* Start of spry validation script from adobe.com*/
var Spry;
if (!Spry) Spry = {};
if (!Spry.Widget) Spry.Widget = {};
Spry.Widget.ValidationSelect = function(element, opts)
{
this.init(element);
Spry.Widget.Utils.setOptions(this, opts);
// set validateOn flags
var validateOn = ['submit'].concat(this.validateOn || []);
validateOn = validateOn.join(",");
this.validateOn = 0 | (validateOn.indexOf('submit') != -1 ? Spry.Widget.ValidationSelect.ONSUBMIT : 0);
this.validateOn = this.validateOn | (validateOn.indexOf('blur') != -1 ? Spry.Widget.ValidationSelect.ONBLUR : 0);
this.validateOn = this.validateOn | (validateOn.indexOf('change') != -1 ? Spry.Widget.ValidationSelect.ONCHANGE : 0);
// Unfortunately in some browsers like Safari, the Stylesheets our
// page depends on may not have been loaded at the time we are called.
// This means we have to defer attaching our behaviors until after the
// onload event fires, since some of our behaviors rely on dimensions
// specified in the CSS.
if (Spry.Widget.ValidationSelect.onloadDidFire)
this.attachBehaviors();
else
Spry.Widget.ValidationSelect.loadQueue.push(this);
};
Spry.Widget.ValidationSelect.ONCHANGE = 1;
Spry.Widget.ValidationSelect.ONBLUR = 2;
Spry.Widget.ValidationSelect.ONSUBMIT = 4;
Spry.Widget.ValidationSelect.prototype.init = function(element)
{
this.element = this.getElement(element);
this.selectElement = null;
this.form = null;
this.event_handlers = [];
// this.element can be either the container (<span>)
// or the <select> element, when no error messages are used.
this.requiredClass = "selectRequiredState";
this.invalidClass = "selectInvalidState";
this.focusClass = "selectFocusState";
this.validClass = "selectValidState";
this.emptyValue = "";
this.invalidValue = null;
this.isRequired = true;
this.validateOn = ["submit"];  // change, blur, submit
// flag used to avoid cascade validation when both
// onChange and onBlur events are used to trigger validation
this.validatedByOnChangeEvent = false;
};
Spry.Widget.ValidationSelect.prototype.destroy = function() {
for (var i=0; i<this.event_handlers.length; i++) {
Spry.Widget.Utils.removeEventListener(this.event_handlers[i][0], this.event_handlers[i][1], this.event_handlers[i][2], false);
}
try { delete this.element; } catch(err) {}
try { delete this.selectElement; } catch(err) {}
try { delete this.form; } catch(err) {}
try { delete this.event_handlers; } catch(err) {}
var q = Spry.Widget.Form.onSubmitWidgetQueue;
var qlen = q.length;
for (var i = 0; i < qlen; i++) {
if (q[i] == this) {
q.splice(i, 1);
break;
}
}
};
Spry.Widget.ValidationSelect.onloadDidFire = false;
Spry.Widget.ValidationSelect.loadQueue = [];
Spry.Widget.ValidationSelect.prototype.getElement = function(ele)
{
if (ele && typeof ele == "string")
return document.getElementById(ele);
return ele;
};
Spry.Widget.ValidationSelect.processLoadQueue = function(handler)
{
Spry.Widget.ValidationSelect.onloadDidFire = true;
var q = Spry.Widget.ValidationSelect.loadQueue;
var qlen = q.length;
for (var i = 0; i < qlen; i++)
q[i].attachBehaviors();
};
Spry.Widget.ValidationSelect.addLoadListener = function(handler)
{
if (typeof window.addEventListener != 'undefined')
window.addEventListener('load', handler, false);
else if (typeof document.addEventListener != 'undefined')
document.addEventListener('load', handler, false);
else if (typeof window.attachEvent != 'undefined')
window.attachEvent('onload', handler);
};
Spry.Widget.ValidationSelect.addLoadListener(Spry.Widget.ValidationSelect.processLoadQueue);
Spry.Widget.ValidationSelect.addLoadListener(function(){
Spry.Widget.Utils.addEventListener(window, "unload", Spry.Widget.Form.destroyAll, false);
});
Spry.Widget.ValidationSelect.prototype.attachBehaviors = function()
{
// find the SELECT element inside current container
if (this.element.nodeName == "SELECT") {
this.selectElement = this.element;
} else {
this.selectElement = Spry.Widget.Utils.getFirstChildWithNodeNameAtAnyLevel(this.element, "SELECT");
}
if (this.selectElement) {
var self = this;
this.event_handlers = [];
// focus
// attach on beforeactivate instead of focus for IE 7 (to overcome this bug: setting a class name, closes the select)
var focusEventName = "focus";
if (navigator.userAgent.toLowerCase().indexOf("msie 7.") != -1) {
focusEventName = "beforeactivate";
}
this.event_handlers.push([this.selectElement, focusEventName, function(e) { if (self.isDisabled()) return true; return self.onFocus(e); }]);
// blur
this.event_handlers.push([this.selectElement, "blur", function(e) { if (self.isDisabled()) return true; return self.onBlur(e); }]);
// change
if (this.validateOn & Spry.Widget.ValidationSelect.ONCHANGE) {
this.event_handlers.push([this.selectElement, "change", function(e) { if (self.isDisabled()) return true; return self.onChange(e); }]);
this.event_handlers.push([this.selectElement, "keypress", function(e) { if (self.isDisabled()) return true; return self.onChange(e); }]);
}
for (var i=0; i<this.event_handlers.length; i++) {
Spry.Widget.Utils.addEventListener(this.event_handlers[i][0], this.event_handlers[i][1], this.event_handlers[i][2], false);
}
// submit
this.form = Spry.Widget.Utils.getFirstParentWithNodeName(this.selectElement, "FORM");
if (this.form) {
// if no "onSubmit" handler has been attached to the current form, attach one
if (!this.form.attachedSubmitHandler && !this.form.onsubmit) {
this.form.onsubmit = function(e) { e = e || event; return Spry.Widget.Form.onSubmit(e, e.srcElement || e.currentTarget) };
this.form.attachedSubmitHandler = true;
}
if (!this.form.attachedResetHandler) {
Spry.Widget.Utils.addEventListener(this.form, "reset", function(e) { e = e || event; return Spry.Widget.Form.onReset(e, e.srcElement || e.currentTarget) }, false);
this.form.attachedResetHandler = true;
}
// add the currrent widget to the "onSubmit" check queue;
Spry.Widget.Form.onSubmitWidgetQueue.push(this);
}
}
};
Spry.Widget.ValidationSelect.prototype.addClassName = function(ele, className)
{
if (!ele || !className || (ele.className && ele.className.search(new RegExp("\\b" + className + "\\b")) != -1))
return;
ele.className += (ele.className ? " " : "") + className;
};
Spry.Widget.ValidationSelect.prototype.removeClassName = function(ele, className)
{
if (!ele || !className || (ele.className && ele.className.search(new RegExp("\\b" + className + "\\b")) == -1))
return;
ele.className = ele.className.replace(new RegExp("\\s*\\b" + className + "\\b", "g"), "");
};
Spry.Widget.ValidationSelect.prototype.onFocus = function(e)
{
this.hasFocus = true;
this.validatedByOnChangeEvent = false;
this.addClassName(this.element, this.focusClass);
};
Spry.Widget.ValidationSelect.prototype.onBlur = function(e)
{
this.hasFocus = false;
var doValidation = false;
if (this.validateOn & Spry.Widget.ValidationSelect.ONBLUR)
doValidation = true;
if (doValidation && !this.validatedByOnChangeEvent)
this.validate();
this.removeClassName(this.element, this.focusClass);
};
Spry.Widget.ValidationSelect.prototype.onChange = function(e)
{
this.hasFocus = false;
this.validate();
this.validatedByOnChangeEvent = true;
};
Spry.Widget.ValidationSelect.prototype.reset = function() {
this.removeClassName(this.element, this.requiredClass);
this.removeClassName(this.element, this.invalidClass);
this.removeClassName(this.element, this.validClass);
};
Spry.Widget.ValidationSelect.prototype.validate = function() {
this.removeClassName(this.element, this.requiredClass);
this.removeClassName(this.element, this.invalidClass);
this.removeClassName(this.element, this.validClass);
// check isRequired
if (this.isRequired) {
// there are no options, or no option has been selected
if (this.selectElement.options.length == 0 || this.selectElement.selectedIndex == -1) {
this.addClassName(this.element, this.requiredClass);
return false;
}
// the current selected option has no "value" attribute
// when no value is set, browsers implement different behaviour for the value property
// IE: value = blank string ("")
// FF, Opera: value = option text
if (this.selectElement.options[this.selectElement.selectedIndex].getAttribute("value") == null) {
this.addClassName(this.element, this.requiredClass);
return false;
}
// the current selected option has blank string ("") value
if (this.selectElement.options[this.selectElement.selectedIndex].value == this.emptyValue) {
this.addClassName(this.element, this.requiredClass);
return false;
}
// the current selected option has "disabled" attribute
// IE 6 allows to select such options
if (this.selectElement.options[this.selectElement.selectedIndex].disabled) {
this.addClassName(this.element, this.requiredClass);
return false;
}
}
if (this.invalidValue) {
if (this.selectElement.options.length > 0 &&
this.selectElement.selectedIndex != -1 &&
this.selectElement.options[this.selectElement.selectedIndex].value == this.invalidValue) {
this.addClassName(this.element, this.invalidClass);
return false;
}
}
this.addClassName(this.element, this.validClass);
return true;
}
Spry.Widget.ValidationSelect.prototype.isDisabled = function() {
return this.selectElement.disabled;
}
//////////////////////////////////////////////////////////////////////
//
// Spry.Widget.Form - common for all widgets
//
//////////////////////////////////////////////////////////////////////
if (!Spry.Widget.Form) Spry.Widget.Form = {};
if (!Spry.Widget.Form.onSubmitWidgetQueue) Spry.Widget.Form.onSubmitWidgetQueue = [];
if (!Spry.Widget.Form.validate) {
Spry.Widget.Form.validate = function(vform) {
var isValid = true;
var isElementValid = true;
var q = Spry.Widget.Form.onSubmitWidgetQueue;
var qlen = q.length;
for (var i = 0; i < qlen; i++) {
if (!q[i].isDisabled() && q[i].form == vform) {
isElementValid = q[i].validate();
isValid = isElementValid && isValid;
}
}
return isValid;
}
};
if (!Spry.Widget.Form.onSubmit) {
Spry.Widget.Form.onSubmit = function(e, form)
{
if (Spry.Widget.Form.validate(form) == false) {
return false;
}
return true;
};
};
if (!Spry.Widget.Form.onReset) {
Spry.Widget.Form.onReset = function(e, vform)
{
var q = Spry.Widget.Form.onSubmitWidgetQueue;
var qlen = q.length;
for (var i = 0; i < qlen; i++) {
if (!q[i].isDisabled() && q[i].form == vform && typeof(q[i].reset) == 'function') {
q[i].reset();
}
}
return true;
};
};
if (!Spry.Widget.Form.destroy) {
Spry.Widget.Form.destroy = function(form)
{
var q = Spry.Widget.Form.onSubmitWidgetQueue;
for (var i = 0; i < Spry.Widget.Form.onSubmitWidgetQueue.length; i++) {
if (q[i].form == form && typeof(q[i].destroy) == 'function') {
q[i].destroy();
i--;
}
}
}
};
if (!Spry.Widget.Form.destroyAll) {
Spry.Widget.Form.destroyAll = function()
{
var q = Spry.Widget.Form.onSubmitWidgetQueue;
for (var i = 0; i < Spry.Widget.Form.onSubmitWidgetQueue.length; i++) {
if (typeof(q[i].destroy) == 'function') {
q[i].destroy();
i--;
}
}
}
};
//////////////////////////////////////////////////////////////////////
//
// Spry.Widget.Utils
//
//////////////////////////////////////////////////////////////////////
if (!Spry.Widget.Utils)	Spry.Widget.Utils = {};
Spry.Widget.Utils.setOptions = function(obj, optionsObj, ignoreUndefinedProps)
{
if (!optionsObj)
return;
for (var optionName in optionsObj)
{
if (ignoreUndefinedProps && optionsObj[optionName] == undefined)
continue;
obj[optionName] = optionsObj[optionName];
}
};
Spry.Widget.Utils.getFirstChildWithNodeNameAtAnyLevel = function(node, nodeName)
{
var elements  = node.getElementsByTagName(nodeName);
if (elements) {
return elements[0];
}
return null;
};
Spry.Widget.Utils.getFirstParentWithNodeName = function(node, nodeName)
{
while (node.parentNode
&& node.parentNode.nodeName.toLowerCase() != nodeName.toLowerCase()
&& node.parentNode.nodeName != 'BODY') {
node = node.parentNode;
}
if (node.parentNode && node.parentNode.nodeName.toLowerCase() == nodeName.toLowerCase()) {
return node.parentNode;
} else {
return null;
}
};
Spry.Widget.Utils.destroyWidgets = function (container)
{
if (typeof container == 'string') {
container = document.getElementById(container);
}
var q = Spry.Widget.Form.onSubmitWidgetQueue;
for (var i = 0; i < Spry.Widget.Form.onSubmitWidgetQueue.length; i++) {
if (typeof(q[i].destroy) == 'function' && Spry.Widget.Utils.contains(container, q[i].element)) {
q[i].destroy();
i--;
}
}
};
Spry.Widget.Utils.contains = function (who, what)
{
if (typeof who.contains == 'object') {
return what && who && (who == what || who.contains(what));
} else {
var el = what;
while(el) {
if (el == who) {
return true;
}
el = el.parentNode;
}
return false;
}
};
Spry.Widget.Utils.addEventListener = function(element, eventType, handler, capture)
{
try
{
if (element.addEventListener)
element.addEventListener(eventType, handler, capture);
else if (element.attachEvent)
element.attachEvent("on" + eventType, handler, capture);
}
catch (e) {}
};
Spry.Widget.Utils.removeEventListener = function(element, eventType, handler, capture)
{
try
{
if (element.removeEventListener)
element.removeEventListener(eventType, handler, capture);
else if (element.detachEvent)
element.detachEvent("on" + eventType, handler, capture);
}
catch (e) {}
};
/* SpryValidationTextarea.js - Revision: Spry Preview Release 1.4 */
// Copyright (c) 2006. Adobe Systems Incorporated.
// All rights reserved.
//
// Redistribution and use in source and binary forms, with or without
// modification, are permitted provided that the following conditions are met:
//
//   * Redistributions of source code must retain the above copyright notice,
//	 this list of conditions and the following disclaimer.
//   * Redistributions in binary form must reproduce the above copyright notice,
//	 this list of conditions and the following disclaimer in the documentation
//	 and/or other materials provided with the distribution.
//   * Neither the name of Adobe Systems Incorporated nor the names of its
//	 contributors may be used to endorse or promote products derived from this
//	 software without specific prior written permission.
//
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
// AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
// IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
// ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
// LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
// CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
// SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
// INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
// CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
// ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
// POSSIBILITY OF SUCH DAMAGE.
var Spry;
if (!Spry) Spry = {};
if (!Spry.Widget) Spry.Widget = {};
Spry.Widget.BrowserSniff = function() {
var b = navigator.appName.toString();
var up = navigator.platform.toString();
var ua = navigator.userAgent.toString();
this.mozilla = this.ie = this.opera = r = false;
var re_opera = /Opera.([0-9\.]*)/i;
var re_msie = /MSIE.([0-9\.]*)/i;
var re_gecko = /gecko/i;
var re_safari = /safari\/([\d\.]*)/i;
if (ua.match(re_opera)) {
r = ua.match(re_opera);
this.opera = true;
this.version = parseFloat(r[1]);
} else if (ua.match(re_msie)) {
r = ua.match(re_msie);
this.ie = true;
this.version = parseFloat(r[1]);
} else if (ua.match(re_safari)) {
this.safari = true;
this.version = 1.4;
} else if (ua.match(re_gecko)) {
var re_gecko_version = /rv:\s*([0-9\.]+)/i;
r = ua.match(re_gecko_version);
this.mozilla = true;
this.version = parseFloat(r[1]);
}
this.windows = this.mac = this.linux = false;
this.Platform = ua.match(/windows/i) ? "windows" :
(ua.match(/linux/i) ? "linux" :
(ua.match(/mac/i) ? "mac" :
ua.match(/unix/i)? "unix" : "unknown"));
this[this.Platform] = true;
this.v = this.version;
if (this.safari && this.mac && this.mozilla) {
this.mozilla = false;
}
};
Spry.is = new Spry.Widget.BrowserSniff();
Spry.Widget.ValidationTextarea = function(element, options){
options = options || {};
this.flags = {locked: false};
this.options = {};
this.element = element;
this.init(element);
if (!this.isBrowserSupported()){
return;
}
options.useCharacterMasking = Spry.Widget.Utils.firstValid(options.useCharacterMasking, true);
options.hint = Spry.Widget.Utils.firstValid(options.hint, '');
options.isRequired = Spry.Widget.Utils.firstValid(options.isRequired, true);
Spry.Widget.Utils.setOptions(this, options);
Spry.Widget.Utils.setOptions(this.options, options);
//make sure we validate at least on submit
var validateOn = ['submit'].concat(Spry.Widget.Utils.firstValid(this.options.validateOn, []));
validateOn = validateOn.join(",");
this.validateOn = 0;
this.validateOn = this.validateOn | (validateOn.indexOf('submit') != -1 ? Spry.Widget.ValidationTextarea.ONSUBMIT : 0);
this.validateOn = this.validateOn | (validateOn.indexOf('blur') != -1 ? Spry.Widget.ValidationTextarea.ONBLUR : 0);
this.validateOn = this.validateOn | (validateOn.indexOf('change') != -1 ? Spry.Widget.ValidationTextarea.ONCHANGE : 0);
if (Spry.Widget.ValidationTextarea.onloadDidFire){
this.attachBehaviors();
}else{
Spry.Widget.ValidationTextarea.loadQueue.push(this);
}
};
Spry.Widget.ValidationTextarea.ONCHANGE = 1;
Spry.Widget.ValidationTextarea.ONBLUR = 2;
Spry.Widget.ValidationTextarea.ONSUBMIT = 4;
Spry.Widget.ValidationTextarea.INITIAL = 'Initial';
Spry.Widget.ValidationTextarea.REQUIRED = 'Required';
Spry.Widget.ValidationTextarea.INVALID = 'Invalid Format';
Spry.Widget.ValidationTextarea.MINIMUM = 'Minimum Number of Chars Not Met';
Spry.Widget.ValidationTextarea.MAXIMUM = 'Maximum Number of Chars Exceeded';
Spry.Widget.ValidationTextarea.VALID = 'Valid';
Spry.Widget.ValidationTextarea.prototype.init = function(element)
{
this.element = this.getElement(element);
this.event_handlers = [];
this.requiredClass = "textareaRequiredState";
this.invalidCharsMaxClass = "textareaMaxCharsState";
this.invalidCharsMinClass = "textareaMinCharsState";
this.validClass = "textareaValidState";
this.focusClass = "textareaFocusState";
this.textareaFlashClass = "textareaFlashState";
this.isMaxInvalid = false;
this.isMinInvalid = false;
this.isRequireInvalid = false;
this.safariClicked = false;
this.state = Spry.Widget.ValidationTextarea.INITIAL;
};
Spry.Widget.ValidationTextarea.prototype.destroy = function() {
for (var i=0; i<this.event_handlers.length; i++) {
Spry.Widget.Utils.removeEventListener(this.event_handlers[i][0], this.event_handlers[i][1], this.event_handlers[i][2], false);
}
try { delete this.element; } catch(err) {}
try { delete this.input; } catch(err) {}
try { delete this.counterEl; } catch(err) {}
try { delete this.form; } catch(err) {}
try { delete this.event_handlers; } catch(err) {}
try { this.cursorPosition.destroy(); } catch(err) {}
try { delete this.cursorPosition; } catch(err) {}
try { this.initialCursor.destroy(); } catch(err) {}
try { delete this.initialCursor; } catch(err) {}
var q = Spry.Widget.Form.onSubmitWidgetQueue;
var qlen = q.length;
for (var i = 0; i < qlen; i++) {
if (q[i] == this) {
q.splice(i, 1);
break;
}
}
};
Spry.Widget.ValidationTextarea.prototype.isDisabled = function() {
return this.input && (this.input.disabled || this.input.readOnly) || !this.input;
};
Spry.Widget.ValidationTextarea.prototype.getElement = function(ele)
{
if (ele && typeof ele == "string")
return document.getElementById(ele);
return ele;
};
Spry.Widget.ValidationTextarea.addLoadListener = function(handler){
if (typeof window.addEventListener != 'undefined'){
window.addEventListener('load', handler, false);
}else if (typeof document.addEventListener != 'undefined'){
document.addEventListener('load', handler, false);
}else if (typeof window.attachEvent != 'undefined'){
window.attachEvent('onload', handler);
}
};
Spry.Widget.ValidationTextarea.processLoadQueue = function(handler){
Spry.Widget.ValidationTextarea.onloadDidFire = true;
var q = Spry.Widget.ValidationTextarea.loadQueue;
var qlen = q.length;
for (var i = 0; i < qlen; i++){
q[i].attachBehaviors();
}
};
Spry.Widget.ValidationTextarea.onloadDidFire = false;
Spry.Widget.ValidationTextarea.loadQueue = [];
Spry.Widget.ValidationTextarea.addLoadListener(Spry.Widget.ValidationTextarea.processLoadQueue);
Spry.Widget.ValidationTextarea.addLoadListener(function(){
Spry.Widget.Utils.addEventListener(window, "unload", Spry.Widget.Form.destroyAll, false);
});
Spry.Widget.ValidationTextarea.prototype.isBrowserSupported = function()
{
return Spry.is.ie && Spry.is.v >= 5 && Spry.is.windows
||
Spry.is.mozilla && Spry.is.v >= 1.4
||
Spry.is.safari
||
Spry.is.opera && Spry.is.v >= 9;
};
/*
* register our input to different event notifiers
*
*/
Spry.Widget.ValidationTextarea.prototype.attachBehaviors = function()
{
if (this.element){
if (this.element.nodeName == "TEXTAREA") {
this.input = this.element;
} else {
this.input = Spry.Widget.Utils.getFirstChildWithNodeNameAtAnyLevel(this.element, "TEXTAREA");
}
}
if (this.options && this.options.counterType && (this.options.counterType == 'chars_count' || this.options.counterType == 'chars_remaining')){
this.counterEl = document.getElementById(this.options.counterId);
this.counterChar();
}
if (this.input) {
this.input.setAttribute("AutoComplete", "off");
this.putHint();
this.cursorPosition = new Spry.Widget.SelectionDescriptor(this.input);
var self = this;
this.event_handlers = [];
//attach the pattern related event handlers (to stop invalid keys)
if (this.useCharacterMasking) {
if (Spry.is.ie){
this.event_handlers.push([this.input, "propertychange", function(e) { return self.onKeyEvent(e || event); }]);
this.event_handlers.push([this.input, "drop", function(e) { return self.onDrop (e || event); }]);
this.event_handlers.push([this.input, "keypress", function(e) { return self.onKeyPress(e || event); }]);
} else{
this.event_handlers.push([this.input, "keydown", function(e) { return self.onKeyDown(e); }]);
this.event_handlers.push([this.input, "keypress", function(e) { return self.safariKeyPress(e); }]);
this.event_handlers.push([this.input, "keyup", function(e) { return self.safariValidate(e); }]);
if (Spry.is.safari){
this.event_handlers.push([this.input, "mouseup", function(e) { return self.safariMouseUp(e); }]);
this.event_handlers.push([this.input, "mousedown", function(e) { return self.safariMouseDown(e); }]);
} else {
//Firefox bug: 355219
//this.event_handlers.push([this.input, "input", function(e) { self.onKeyEvent(e); return true;}]);
this.event_handlers.push([this.input, "dragdrop", function(e) { return self.onKeyEvent(e); }]);
this.event_handlers.push([this.input, "dragenter", function(e) { self.removeHint(); return self.onKeyDown(e); }]);
this.event_handlers.push([this.input, "dragexit", function(e) { return self.putHint(); }]);
}
}
// we need to save an initial state in case of invalid input
this.event_handlers.push([this.input, "keydown", function(e) {return self.onKeyDown(e || event); }]);
}
this.event_handlers.push([this.input, "focus", function(e) { return self.onFocus(e || event); }]);
this.event_handlers.push([this.input, "mousedown", function(e) { return self.onMouseDown(e || event); }]);
this.event_handlers.push([this.input, "blur", function(e) { return self.onBlur(e || event); }]);
if (this.validateOn & Spry.Widget.ValidationTextarea.ONCHANGE){
if (Spry.is.ie){
this.event_handlers.push([this.input, "propertychange", function(e) { return self.onChange(e || event); }]);
this.event_handlers.push([this.input, "drop", function(e) { return self.onChange(e || event); }]);
} else{
this.event_handlers.push([this.input, "keydown", function(e) { return self.onKeyDown(e); }]);
this.event_handlers.push([this.input, "keypress", function(e) { return self.safariChangeKeyPress(e); }]);
this.event_handlers.push([this.input, "keyup", function(e) { return self.safariChangeValidate(e); }]);
if (Spry.is.safari){
this.event_handlers.push([this.input, "mouseup", function(e) { return self.safariChangeMouseUp(e); }]);
this.event_handlers.push([this.input, "mousedown", function(e) { return self.safariMouseDown(e); }]);
} else {
// Firefox bug: 355219
//this.event_handlers.push([this.input, "input", function(e) { return self.onChange(e); }]);
this.event_handlers.push([this.input, "dragdrop", function(e) {return self.onChange(e); }]);
this.event_handlers.push([this.input, "dragenter", function(e) { self.removeHint(); return self.onKeyDown(e); }]);
this.event_handlers.push([this.input, "dragexit", function(e) { return self.putHint(); }]);
}
}
}
// The counter should be called directly when no enforcement or change restrictions exists
if (! (this.validateOn & Spry.Widget.ValidationTextarea.ONCHANGE) && !this.useCharacterMasking){
if (Spry.is.ie){
this.event_handlers.push([this.input, "propertychange", function(e) { return self.counterChar(); }]);
this.event_handlers.push([this.input, "drop", function(e) { return self.counterChar(); }]);
} else{
this.event_handlers.push([this.input, "keypress", function(e) { return self.counterChar(); }]);
this.event_handlers.push([this.input, "keyup", function(e) { return self.counterChar(); }]);
if (Spry.is.safari){
this.event_handlers.push([this.input, "mouseup", function(e) { return self.counterChar(); }]);
} else {
// Firefox bug: 355219
//this.event_handlers.push([this.input, "input", function(e) { return self.onChange(e); }]);
this.event_handlers.push([this.input, "dragdrop", function(e) {return self.counterChar(); }]);
}
}
}
for (var i=0; i<this.event_handlers.length; i++) {
Spry.Widget.Utils.addEventListener(this.event_handlers[i][0], this.event_handlers[i][1], this.event_handlers[i][2], false);
}
this.form = Spry.Widget.Utils.getFirstParentWithNodeName(this.input, "FORM");
if (this.form) {
if (!this.form.attachedSubmitHandler && !this.form.onsubmit) {
this.form.onsubmit = function(e) { e = e || event; return Spry.Widget.Form.onSubmit(e, e.srcElement || e.currentTarget) };
this.form.attachedSubmitHandler = true;
}
if (!this.form.attachedResetHandler) {
Spry.Widget.Utils.addEventListener(this.form, "reset", function(e) { e = e || event; return Spry.Widget.Form.onReset(e, e.srcElement || e.currentTarget) }, false);
this.form.attachedResetHandler = true;
}
// add the currrent widget to the "onSubmit" check queue;
Spry.Widget.Form.onSubmitWidgetQueue.push(this);
}
}
this.saveState();
};
Spry.Widget.ValidationTextarea.prototype.onTyping = function(e){
if (this.input.disabled == true || this.input.readOnly == true){
return;
}
if (!this.initialCursor){
this.initialCursor = this.cursorPosition;
}
// on IE a stack overflow appears
if (this.flags.locked){
return true;
}
var val = this.input.value;
var ret = true;
if (this.flags.hintOn){
return true;
}
if (e && this.input && this.options && this.options.maxChars > 0 && ret){
if ( val.length > this.options.maxChars  &&
((!Spry.Widget.Utils.isSpecialKey(e) && this.cursorPosition.start == this.cursorPosition.end) ||
(Spry.Widget.Utils.isSpecialKey(e) && val != this.initialValue) ||
this.cursorPosition.start != this.cursorPosition.end)
){
// cut the extra chars and display error
this.flags.locked = true;
var initial = this.initialValue;
var start = this.initialCursor.start;
var end = this.initialCursor.end;
if (initial.length && this.initialCursor.end < initial.length) {
// we try to behave more like maxlength textfield
var tmp = end - start + this.options.maxChars - initial.length;
var newValue = initial.substring(0, start) + val.substring(start, start+tmp) + initial.substring(end, initial.length < this.options.maxChars ? initial.length:this.options.maxChars);
end = start + tmp;
}else{
var newValue = val.substring(0, this.options.maxChars);
end = start = this.options.maxChars;
}
if (Spry.is.ie) {
this.input.innerText = newValue;
} else {
this.input.value = newValue;
}
this.redTextFlash();
this.cursorPosition.moveTo(end, end);
this.flags.locked = false;
ret = false;
} else{
this.setState(Spry.Widget.ValidationTextarea.VALID);
this.isMaxInvalid = false;
}
}
this.counterChar();
return ret;
};
Spry.Widget.ValidationTextarea.prototype.validateMinRequired = function(val){
var oldInvalid = false;
if (typeof this.notFireMinYet == 'undefined'){
this.notFireMinYet = false;
}else{
oldInvalid = true;
this.notFireMinYet = true;
}
if (this.onBlurOn){
this.notFireMinYet = true;
}else if (!this.onKeyEventOn){
this.notFireMinYet = true;
}
if (this.input && this.options && this.options.isRequired){
if (val.length > 0 && this.isRequireInvalid && (!this.hint || (this.hint && !this.flags.hintOn) || (this.hint && val != this.hint))){
this.switchClassName(this.validClass);
this.setState(Spry.Widget.ValidationTextarea.VALID);
this.isRequireInvalid = false;
}else if ((val.length == 0 || !(!this.hint || (this.hint && !this.flags.hintOn) || (this.hint && val != this.hint))) && (!this.isRequireInvalid || oldInvalid)){
if (this.notFireMinYet || Spry.is.ie){
this.switchClassName(this.requiredClass);
this.setState(Spry.Widget.ValidationTextarea.REQUIRED);
}
this.isRequireInvalid = true;
this.isMinInvalid = false;
}
}
if (this.input && this.options && this.options.minChars > 0 && !this.isRequireInvalid){
if (val.length >= this.options.minChars && (!this.hint || (this.hint && !this.flags.hintOn) || (this.hint && val != this.hint)) && this.isMinInvalid){
this.switchClassName(this.validClass);
this.setState(Spry.Widget.ValidationTextarea.VALID);
this.isMinInvalid = false;
}else if ( (val.length < this.options.minChars || (this.hint && val == this.hint && this.flags.hintOn)) && !this.isMinInvalid){
this.switchClassName(this.invalidCharsMinClass);
this.setState(Spry.Widget.ValidationTextarea.MINIMUM);
this.isMinInvalid = true;
}
}
};
Spry.Widget.ValidationTextarea.prototype.counterChar = function(){
if (!this.counterEl || !this.options || !this.options.counterType || (this.options.counterType != 'chars_remaining' && this.options.counterType != 'chars_count')){
return;
}
if (this.options.counterType == 'chars_remaining') {
if (this.options.maxChars > 0){
if (this.flags.hintOn){
this.setCounterElementValue(this.options.maxChars);
} else {
if (this.options.maxChars > this.input.value.length){
this.setCounterElementValue(this.options.maxChars - this.input.value.length);
}else{
this.setCounterElementValue(0);
}
}
}
} else {
if (this.flags.hintOn){
this.setCounterElementValue(0);
} else {
if (this.useCharacterMasking && typeof this.options.maxChars != 'undefined' && this.options.maxChars < this.input.value.length){
this.setCounterElementValue(this.options.maxChars);
} else {
this.setCounterElementValue(this.input.value.length);
}
}
}
};
Spry.Widget.ValidationTextarea.prototype.setCounterElementValue = function(val){
if ( this.counterEl.nodeName.toLowerCase() != 'input' &&
this.counterEl.nodeName.toLowerCase() != 'textarea' &&
this.counterEl.nodeName.toLowerCase() != 'select' &&
this.counterEl.nodeName.toLowerCase() != 'img'){
this.counterEl.innerHTML = val;
}
};
Spry.Widget.ValidationTextarea.prototype.reset = function() {
this.removeHint();
this.removeClassName(this.requiredClass);
this.removeClassName(this.invalidCharsMinClass);
this.removeClassName(this.invalidCharsMaxClass);
this.removeClassName(this.validClass);
this.setState(Spry.Widget.ValidationTextarea.INITIAL);
var self = this;
setTimeout(function() {self.putHint();self.counterChar();}, 10);
};
Spry.Widget.ValidationTextarea.prototype.validate = function(){
if (this.input.disabled == true || this.input.readOnly == true){
return true;
}
var val = this.input.value;
this.validateMinRequired(val);
var ret = !this.isMinInvalid && !this.isRequireInvalid;
if (ret && this.options.maxChars > 0 && !this.useCharacterMasking){
if (val.length <= this.options.maxChars || (this.hint && this.hint == val && this.flags.hintOn))	{
this.switchClassName(this.validClass);
this.setState(Spry.Widget.ValidationTextarea.VALID);
this.isMaxInvalid = false;
}else{
this.switchClassName(this.invalidCharsMaxClass);
this.setState(Spry.Widget.ValidationTextarea.MAXIMUM);
this.isMaxInvalid = true;
}
}
ret = ret && !this.isMaxInvalid;
if (ret) {
this.switchClassName(this.validClass);
}
this.counterChar();
return ret;
};
Spry.Widget.ValidationTextarea.prototype.setState = function(newstate){
this.state = newstate;
};
Spry.Widget.ValidationTextarea.prototype.getState = function(){
return this.state;
};
Spry.Widget.ValidationTextarea.prototype.removeHint = function()
{
if (this.flags.hintOn) {
this.flags.locked = true;
this.input.value = "";
this.flags.locked = false;
this.flags.hintOn = false;
}
};
Spry.Widget.ValidationTextarea.prototype.putHint = function()
{
if(this.hint && this.input.value == "") {
this.flags.hintOn = true;
this.input.value = this.hint;
}
};
Spry.Widget.ValidationTextarea.prototype.redTextFlash = function()
{
var self = this;
this.addClassName(this.textareaFlashClass);
setTimeout(function() {
self.removeClassName(self.textareaFlashClass)
}, 200);
};
Spry.Widget.ValidationTextarea.prototype.onKeyPress = function(e)
{
//ENTER has length 2 on IE Windows, so will exceed maxLength on proximity
if (Spry.is.ie && Spry.is.windows && e.keyCode == 13) {
if ( (this.initialCursor.length + this.options.maxChars - this.input.value.length) < 2) {
Spry.Widget.Utils.stopEvent(e);
return false;
}
}
};
Spry.Widget.ValidationTextarea.prototype.onKeyDown = function(e)
{
this.saveState();
this.keyCode = e.keyCode;
return true;
};
/*
* hadle for the max chars restrictions
* if key pressed or the input text is invalid it returns false
*
*/
Spry.Widget.ValidationTextarea.prototype.onKeyEvent = function(e){
// on IE we look only for this input value changes
if (e.type == 'propertychange' && e.propertyName != 'value'){
return true;
}
var allow = this.onTyping(e);
if (!allow){
Spry.Widget.Utils.stopEvent(e);
}
//return allow;
};
/*
* handle for the min or required value
* if the input text is invalid it returns false
*
*/
Spry.Widget.ValidationTextarea.prototype.onChange = function(e){
if (Spry.is.ie && e && e.type == 'propertychange' && e.propertyName != 'value') {
return true;
}
if (this.flags.drop) {
//delay this if it's a drop operation
var self = this;
setTimeout(function() {
self.flags.drop = false;
self.onChange(null);
}, 0);
return true;
}
if (this.flags.hintOn) {
return true;
}
this.onKeyEventOn = true;
var answer = this.validate();
this.onKeyEventOn = false;
return answer;
};
Spry.Widget.ValidationTextarea.prototype.onMouseDown = function(e)
{
if (this.flags.active) {
//mousedown fires before focus
//avoid double saveState on first focus by mousedown by checking if the control has focus
//do nothing if it's not focused because saveState will be called onfocus
this.saveState();
}
};
Spry.Widget.ValidationTextarea.prototype.onDrop = function(e)
{
//mark that a drop operation is in progress to avoid race conditions with event handlers for other events
//especially onchange and onfocus
this.flags.drop = true;
this.removeHint();
if (Spry.is.ie) {
var rng = document.body.createTextRange();
rng.moveToPoint(e.x, e.y);
rng.select();
}
this.saveState();
this.flags.active = true;
this.addClassName(this.focusClass);
};
Spry.Widget.ValidationTextarea.prototype.onFocus = function(e)
{
if (this.flags.drop) {
return;
}
this.removeHint();
this.saveState();
this.flags.active = true;
this.addClassName(this.focusClass);
};
Spry.Widget.ValidationTextarea.prototype.onBlur = function(e){
this.removeClassName(this.focusClass);
if (this.validateOn & Spry.Widget.ValidationTextarea.ONBLUR) {
this.onBlurOn = true;
this.validate();
this.onBlurOn = false;
}
this.flags.active = false;
var self = this;
setTimeout(function() {self.putHint();}, 10);
};
Spry.Widget.ValidationTextarea.prototype.safariMouseDown = function(e){
this.safariClicked = true;
};
Spry.Widget.ValidationTextarea.prototype.safariChangeMouseUp = function(e){
if (!this.safariClicked){
this.onKeyDown(e);
return this.safariChangeValidate(e, false);
}else{
this.safariClicked = false;
return true;
}
};
Spry.Widget.ValidationTextarea.prototype.safariMouseUp = function(e){
if (!this.safariClicked){
this.onKeyDown(e);
return this.safariValidate(e, false);
}else{
this.safariClicked = false;
return true;
}
};
Spry.Widget.ValidationTextarea.prototype.safariKeyPress = function(e){
this.safariFlag = new Date();
return this.safariValidate(e, true);
};
Spry.Widget.ValidationTextarea.prototype.safariValidate = function(e, recall)
{
if (e.keyCode && Spry.Widget.Utils.isSpecialKey(e) && e.keyCode != 8 && e.keyCode != 46){
return true;
}
var answer = this.onTyping(e);
// the answer to this is not yet final - we schedule another closing check
if (new Date() - this.safariFlag < 1000 && recall){
var self = this;
setTimeout(function(){self.safariValidate(e, false);}, 1000);
}
return answer;
};
Spry.Widget.ValidationTextarea.prototype.safariChangeKeyPress = function(e){
this.safariChangeFlag = new Date();
return this.safariChangeValidate(e, true);
};
Spry.Widget.ValidationTextarea.prototype.safariChangeValidate = function(e, recall){
if(e.keyCode && Spry.Widget.Utils.isSpecialKey(e) && e.keyCode != 8 && e.keyCode != 46){
return true;
}
var answer = this.onChange(e);
// the answer to this is not yet final - we schedule another closing check
if (new Date() - this.safariChangeFlag < 1000 && recall){
var self = this;
setTimeout(function(){ self.safariChangeValidate(e, false);}, 1000 - new Date() + this.safariChangeFlag);
}
return answer;
};
/*
* save an initial state of the input to restore if the value is invalid
*
*/
Spry.Widget.ValidationTextarea.prototype.saveState = function(e){
// we don't need this initial value that is already invalid
if (this.options.maxChars > 0 && this.input.value.length > this.options.maxChars){
return;
}
this.cursorPosition.update();
if (!this.flags.hintOn){
this.initialValue = this.input.value;
}else{
this.initialValue = '';
}
this.initialCursor = this.cursorPosition;
return true;
};
Spry.Widget.ValidationTextarea.prototype.checkClassName = function(ele, className){
if (!ele || !className){
return false;
}
if (typeof ele == 'string' ) {
ele = document.getElementById(ele);
if (!ele){
return false;
}
}
if (!ele.className){
ele.className = ' ';
}
return ele;
};
Spry.Widget.ValidationTextarea.prototype.switchClassName = function (className){
var classes = [this.invalidCharsMaxClass, this.validClass, this.requiredClass, this.invalidCharsMinClass];
var self = this;
for (var k in classes){
if (classes[k] != className){
this.removeClassName(classes[k]);
}
}
this.addClassName(className);
};
Spry.Widget.ValidationTextarea.prototype.addClassName = function(clssName){
var ele = this.checkClassName(this.element, clssName);
if (!ele || ele.className.search(new RegExp("\\b" + clssName + "\\b")) != -1){
return;
}
this.element.className += ' ' + clssName;
};
Spry.Widget.ValidationTextarea.prototype.removeClassName = function(className){
var ele = this.checkClassName(this.element, className);
if (!ele){
return;
}
ele.className = ele.className.replace(new RegExp("\\s*\\b" + className + "\\b", "g"), '');
};
/**
* SelectionDescriptor is a wrapper for input type text selection methods and properties
* as implemented by various  browsers
*/
Spry.Widget.SelectionDescriptor = function (element)
{
this.element = element;
this.update();
};
Spry.Widget.SelectionDescriptor.prototype.update = function()
{
if (Spry.is.ie && Spry.is.windows) {
if (this.element.nodeName == "TEXTAREA") {
var range = this.element.ownerDocument.selection.createRange();
if (range.parentElement() == this.element){
var range_all = this.element.ownerDocument.body.createTextRange();
range_all.moveToElementText(this.element);
for (var sel_start = 0; range_all.compareEndPoints('StartToStart', range) < 0; sel_start ++){
range_all.moveStart('character', 1);
}
this.start = sel_start;
// create a selection of the whole this.element
range_all = this.element.ownerDocument.body.createTextRange();
range_all.moveToElementText(this.element);
for (var sel_end = 0; range_all.compareEndPoints('StartToEnd', range) < 0; sel_end++){
range_all.moveStart('character', 1);
}
this.end = sel_end;
this.length = this.end - this.start;
// get selected and surrounding text
this.text = range.text;
}
} else if (this.element.nodeName == "INPUT"){
this.range = this.element.ownerDocument.selection.createRange();
this.length = this.range.text.length;
var clone = this.range.duplicate();
this.start = -clone.moveStart("character", -10000);
clone = this.range.duplicate();
clone.collapse(false);
this.end = -clone.moveStart("character", -10000);
this.text = this.range.text;
}
} else {
var tmp = this.element;
var selectionStart = 0;
var selectionEnd = 0;
try { selectionStart = tmp.selectionStart; } catch(err) {}
try { selectionEnd = tmp.selectionEnd; } catch(err) {}
if (Spry.is.safari) {
if (selectionStart == 2147483647) {
selectionStart = 0;
}
if (selectionEnd == 2147483647) {
selectionEnd = 0;
}
}
this.start = selectionStart;
this.end = selectionEnd;
this.length = selectionEnd - selectionStart;
this.text = this.element.value.substring(selectionStart, selectionEnd);
}
};
Spry.Widget.SelectionDescriptor.prototype.destroy = function() {
try { delete this.range} catch(err) {}
try { delete this.element} catch(err) {}
};
Spry.Widget.SelectionDescriptor.prototype.moveTo = function(start, end)
{
if (Spry.is.ie && Spry.is.windows) {
if (this.element.nodeName == "TEXTAREA") {
var ta_range = this.element.createTextRange();
this.range = this.element.createTextRange();
this.range.move("character", start);
this.range.moveEnd("character", end - start);
var c1 = this.range.compareEndPoints("StartToStart", ta_range);
if (c1 < 0) {
this.range.setEndPoint("StartToStart", ta_range);
}
var c2 = this.range.compareEndPoints("EndToEnd", ta_range);
if (c2 > 0) {
this.range.setEndPoint("EndToEnd", ta_range);
}
} else if (this.element.nodeName == "INPUT"){
this.range = this.element.ownerDocument.selection.createRange();
this.range.move("character", -10000);
this.start = this.range.moveStart("character", start);
this.end = this.start + this.range.moveEnd("character", end - start);
}
this.range.select();
} else {
this.start = start;
try { this.element.selectionStart = start; } catch(err) {}
this.end = end;
try { this.element.selectionEnd = end; } catch(err) {}
}
this.ignore = true;
this.update();
};
//////////////////////////////////////////////////////////////////////
//
// Spry.Widget.Form - common for all widgets
//
//////////////////////////////////////////////////////////////////////
if (!Spry.Widget.Form) Spry.Widget.Form = {};
if (!Spry.Widget.Form.onSubmitWidgetQueue) Spry.Widget.Form.onSubmitWidgetQueue = [];
if (!Spry.Widget.Form.validate) {
Spry.Widget.Form.validate = function(vform) {
var isValid = true;
var isElementValid = true;
var q = Spry.Widget.Form.onSubmitWidgetQueue;
var qlen = q.length;
for (var i = 0; i < qlen; i++) {
if (!q[i].isDisabled() && q[i].form == vform) {
isElementValid = q[i].validate();
isValid = isElementValid && isValid;
}
}
return isValid;
}
};
if (!Spry.Widget.Form.onSubmit) {
Spry.Widget.Form.onSubmit = function(e, form)
{
if (Spry.Widget.Form.validate(form) == false) {
return false;
}
return true;
};
};
if (!Spry.Widget.Form.onReset) {
Spry.Widget.Form.onReset = function(e, vform)
{
var q = Spry.Widget.Form.onSubmitWidgetQueue;
var qlen = q.length;
for (var i = 0; i < qlen; i++) {
if (!q[i].isDisabled() && q[i].form == vform && typeof(q[i].reset) == 'function') {
q[i].reset();
}
}
return true;
};
};
if (!Spry.Widget.Form.destroy) {
Spry.Widget.Form.destroy = function(form)
{
var q = Spry.Widget.Form.onSubmitWidgetQueue;
for (var i = 0; i < Spry.Widget.Form.onSubmitWidgetQueue.length; i++) {
if (q[i].form == form && typeof(q[i].destroy) == 'function') {
q[i].destroy();
i--;
}
}
}
};
if (!Spry.Widget.Form.destroyAll) {
Spry.Widget.Form.destroyAll = function()
{
var q = Spry.Widget.Form.onSubmitWidgetQueue;
for (var i = 0; i < Spry.Widget.Form.onSubmitWidgetQueue.length; i++) {
if (typeof(q[i].destroy) == 'function') {
q[i].destroy();
i--;
}
}
}
};
//////////////////////////////////////////////////////////////////////
//
// Spry.Widget.Utils
//
//////////////////////////////////////////////////////////////////////
if (!Spry.Widget.Utils)	Spry.Widget.Utils = {};
Spry.Widget.Utils.setOptions = function(obj, optionsObj, ignoreUndefinedProps)
{
if (!optionsObj)
return;
for (var optionName in optionsObj)
{
if (ignoreUndefinedProps && optionsObj[optionName] == undefined)
continue;
obj[optionName] = optionsObj[optionName];
}
};
Spry.Widget.Utils.firstValid = function() {
var ret = null;
for(var i=0; i<Spry.Widget.Utils.firstValid.arguments.length; i++) {
if (typeof(Spry.Widget.Utils.firstValid.arguments[i]) != 'undefined') {
ret = Spry.Widget.Utils.firstValid.arguments[i];
break;
}
}
return ret;
};
Spry.Widget.Utils.specialSafariNavKeys = ",63232,63233,63234,63235,63272,63273,63275,63276,63277,63289,";
Spry.Widget.Utils.specialCharacters = ",8,9,16,17,18,20,27,33,34,35,36,37,38,39,40,45,46,91,92,93,144,192,63232,";
Spry.Widget.Utils.specialCharacters += Spry.Widget.Utils.specialSafariNavKeys;
Spry.Widget.Utils.isSpecialKey = function (ev) {
return Spry.Widget.Utils.specialCharacters.indexOf("," + ev.keyCode + ",") != -1;
};
Spry.Widget.Utils.getFirstChildWithNodeNameAtAnyLevel = function(node, nodeName) {
var elements  = node.getElementsByTagName(nodeName);
if (elements) {
return elements[0];
}
return null;
};
Spry.Widget.Utils.getFirstParentWithNodeName = function(node, nodeName)
{
while (node.parentNode
&& node.parentNode.nodeName.toLowerCase() != nodeName.toLowerCase()
&& node.parentNode.nodeName != 'BODY') {
node = node.parentNode;
}
if (node.parentNode && node.parentNode.nodeName.toLowerCase() == nodeName.toLowerCase()) {
return node.parentNode;
} else {
return null;
}
};
Spry.Widget.Utils.destroyWidgets = function (container)
{
if (typeof container == 'string') {
container = document.getElementById(container);
}
var q = Spry.Widget.Form.onSubmitWidgetQueue;
for (var i = 0; i < Spry.Widget.Form.onSubmitWidgetQueue.length; i++) {
if (typeof(q[i].destroy) == 'function' && Spry.Widget.Utils.contains(container, q[i].element)) {
q[i].destroy();
i--;
}
}
};
Spry.Widget.Utils.contains = function (who, what)
{
if (typeof who.contains == 'object') {
return what && who && (who == what || who.contains(what));
} else {
var el = what;
while(el) {
if (el == who) {
return true;
}
el = el.parentNode;
}
return false;
}
};
Spry.Widget.Utils.addEventListener = function(element, eventType, handler, capture)
{
try
{
if (element.addEventListener)
element.addEventListener(eventType, handler, capture);
else if (element.attachEvent)
element.attachEvent("on" + eventType, handler, capture);
}
catch (e) {}
};
Spry.Widget.Utils.removeEventListener = function(element, eventType, handler, capture)
{
try
{
if (element.removeEventListener)
element.removeEventListener(eventType, handler, capture);
else if (element.detachEvent)
element.detachEvent("on" + eventType, handler, capture);
}
catch (e) {}
};
Spry.Widget.Utils.stopEvent = function(ev)
{
try
{
this.stopPropagation(ev);
this.preventDefault(ev);
}
catch (e) {}
};
/**
* Stops event propagation
* @param {Event} ev the event
*/
Spry.Widget.Utils.stopPropagation = function(ev)
{
if (ev.stopPropagation)
{
ev.stopPropagation();
}
else
{
ev.cancelBubble = true;
}
};
/**
* Prevents the default behavior of the event
* @param {Event} ev the event
*/
Spry.Widget.Utils.preventDefault = function(ev)
{
if (ev.preventDefault)
{
ev.preventDefault();
}
else
{
ev.returnValue = false;
}
};
/* SpryValidationTextField.js - Revision: Spry Preview Release 1.4 */
// Copyright (c) 2006. Adobe Systems Incorporated.
// All rights reserved.
//
// Redistribution and use in source and binary forms, with or without
// modification, are permitted provided that the following conditions are met:
//
//   * Redistributions of source code must retain the above copyright notice,
//	 this list of conditions and the following disclaimer.
//   * Redistributions in binary form must reproduce the above copyright notice,
//	 this list of conditions and the following disclaimer in the documentation
//	 and/or other materials provided with the distribution.
//   * Neither the name of Adobe Systems Incorporated nor the names of its
//	 contributors may be used to endorse or promote products derived from this
//	 software without specific prior written permission.
//
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
// AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
// IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
// ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
// LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
// CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
// SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
// INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
// CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
// ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
// POSSIBILITY OF SUCH DAMAGE.
var Spry;
if (!Spry) Spry = {};
if (!Spry.Widget) Spry.Widget = {};
Spry.Widget.BrowserSniff = function() {
var b = navigator.appName.toString();
var up = navigator.platform.toString();
var ua = navigator.userAgent.toString();
this.mozilla = this.ie = this.opera = r = false;
var re_opera = /Opera.([0-9\.]*)/i;
var re_msie = /MSIE.([0-9\.]*)/i;
var re_gecko = /gecko/i;
var re_safari = /safari\/([\d\.]*)/i;
if (ua.match(re_opera)) {
r = ua.match(re_opera);
this.opera = true;
this.version = parseFloat(r[1]);
} else if (ua.match(re_msie)) {
r = ua.match(re_msie);
this.ie = true;
this.version = parseFloat(r[1]);
} else if (ua.match(re_safari)) {
this.safari = true;
this.version = 1.4;
} else if (ua.match(re_gecko)) {
var re_gecko_version = /rv:\s*([0-9\.]+)/i;
r = ua.match(re_gecko_version);
this.mozilla = true;
this.version = parseFloat(r[1]);
}
this.windows = this.mac = this.linux = false;
this.Platform = ua.match(/windows/i) ? "windows" :
(ua.match(/linux/i) ? "linux" :
(ua.match(/mac/i) ? "mac" :
ua.match(/unix/i)? "unix" : "unknown"));
this[this.Platform] = true;
this.v = this.version;
if (this.safari && this.mac && this.mozilla) {
this.mozilla = false;
}
};
Spry.is = new Spry.Widget.BrowserSniff();
Spry.Widget.ValidationTextField = function(element, type, options)
{
type = Spry.Widget.Utils.firstValid(type, "none");
if (typeof type != 'string') {
return;
}
if (typeof Spry.Widget.ValidationTextField.ValidationDescriptors[type] == 'undefined') {
return;
}
options = Spry.Widget.Utils.firstValid(options, {});
this.type = type;
if (!this.isBrowserSupported()) {
//disable character masking and pattern behaviors for low level browsers
options.useCharacterMasking = false;
}
this.init(element, options);
//make sure we validate at least on submit
var validateOn = ['submit'].concat(Spry.Widget.Utils.firstValid(this.options.validateOn, []));
validateOn = validateOn.join(",");
this.validateOn = 0;
this.validateOn = this.validateOn | (validateOn.indexOf('submit') != -1 ? Spry.Widget.ValidationTextField.ONSUBMIT : 0);
this.validateOn = this.validateOn | (validateOn.indexOf('blur') != -1 ? Spry.Widget.ValidationTextField.ONBLUR : 0);
this.validateOn = this.validateOn | (validateOn.indexOf('change') != -1 ? Spry.Widget.ValidationTextField.ONCHANGE : 0);
if (Spry.Widget.ValidationTextField.onloadDidFire)
this.attachBehaviors();
else
Spry.Widget.ValidationTextField.loadQueue.push(this);
};
Spry.Widget.ValidationTextField.ONCHANGE = 1;
Spry.Widget.ValidationTextField.ONBLUR = 2;
Spry.Widget.ValidationTextField.ONSUBMIT = 4;
Spry.Widget.ValidationTextField.ERROR_REQUIRED = 1;
Spry.Widget.ValidationTextField.ERROR_FORMAT = 2;
Spry.Widget.ValidationTextField.ERROR_RANGE_MIN = 4;
Spry.Widget.ValidationTextField.ERROR_RANGE_MAX = 8;
Spry.Widget.ValidationTextField.ERROR_CHARS_MIN = 16;
Spry.Widget.ValidationTextField.ERROR_CHARS_MAX = 32;
/* validation parameters:
*  - characterMasking : prevent typing of characters not matching an regular expression
*  - regExpFilter : additional regular expression to disalow typing of characters
*	(like the "-" sign in the middle of the value); use for partial matching of the currently typed value;
* 	the typed value must match regExpFilter at any moment
*  - pattern : enforce character on each position inside a pattern (AX0?)
*  - validation : function performing logic validation; return false if failed and the typedValue value on success
*  - minValue, maxValue : range validation; check if typedValue inside the specified range
*  - minChars, maxChars : value length validation; at least/at most number of characters
* */
Spry.Widget.ValidationTextField.ValidationDescriptors = {
'none': {
},
'custom': {
},
'integer': {
characterMasking: /[\-\+\d]/,
regExpFilter: /^[\-\+]?\d*$/,
validation: function(value, options) {
if (value == '' || value == '-' || value == '+') {
return false;
}
var regExp = /^[\-\+]?\d*$/;
if (!regExp.test(value)) {
return false;
}
options = options || {allowNegative:false};
var ret = parseInt(value, 10);
if (!isNaN(ret)) {
var allowNegative = true;
if (typeof options.allowNegative != 'undefined' && options.allowNegative == false) {
allowNegative = false;
}
if (!allowNegative && value < 0) {
ret = false;
}
} else {
ret = false;
}
return ret;
}
},
'real': {
characterMasking: /[\d\.,\-\+e]/i,
regExpFilter: /^[\-\+]?\d(?:|\.,\d{0,2})|(?:|e{0,1}[\-\+]?\d{0,})$/i,
validation: function (value, options) {
var regExp = /^[\+\-]?[0-9]+([\.,][0-9]+)?([eE]{0,1}[\-\+]?[0-9]+)?$/;
if (!regExp.test(value)) {
return false;
}
var ret = parseFloat(value);
if (isNaN(ret)) {
ret = false;
}
return ret;
}
},
'currency': {
formats: {
'dot_comma': {
characterMasking: /[\d\.\,\-\+\$]/,
regExpFilter: /^[\-\+]?(?:[\d\.]*)+(|\,\d{0,2})$/,
validation: function(value, options) {
var ret = false;
//2 or no digits after the comma
if (/^(\-|\+)?\d{1,3}(?:\.\d{3})*(?:\,\d{2}|)$/.test(value) || /^(\-|\+)?\d+(?:\,\d{2}|)$/.test(value)) {
value = value.toString().replace(/\./gi, '').replace(/\,/, '.');
ret = parseFloat(value);
}
return ret;
}
},
'comma_dot': {
characterMasking: /[\d\.\,\-\+\$]/,
regExpFilter: /^[\-\+]?(?:[\d\,]*)+(|\.\d{0,2})$/,
validation: function(value, options) {
var ret = false;
//2 or no digits after the comma
if (/^(\-|\+)?\d{1,3}(?:\,\d{3})*(?:\.\d{2}|)$/.test(value) || /^(\-|\+)?\d+(?:\.\d{2}|)$/.test(value)) {
value = value.toString().replace(/\,/gi, '');
ret = parseFloat(value);
}
return ret;
}
}
}
},
'email': {
characterMasking: /[^\s]/,
validation: function(value, options) {
var rx = /^[\w\.-]+@[\w\.-]+\.\w+$/i;
return rx.test(value);
}
},
'date': {
validation: function(value, options) {
var formatRegExp = /^([mdy]+)[\.\-\/\\\s]+([mdy]+)[\.\-\/\\\s]+([mdy]+)$/i;
var valueRegExp = this.dateValidationPattern;
var formatGroups = options.format.match(formatRegExp);
var valueGroups = value.match(valueRegExp);
if (formatGroups !== null && valueGroups !== null) {
var dayIndex = -1;
var monthIndex = -1;
var yearIndex = -1;
for (var i=1; i<formatGroups.length; i++) {
switch (formatGroups[i].toLowerCase()) {
case "dd":
dayIndex = i;
break;
case "mm":
monthIndex = i;
break;
case "yy":
case "yyyy":
yearIndex = i;
break;
}
}
if (dayIndex != -1 && monthIndex != -1 && yearIndex != -1) {
var maxDay = -1;
var theDay = parseInt(valueGroups[dayIndex], 10);
var theMonth = parseInt(valueGroups[monthIndex], 10);
var theYear = parseInt(valueGroups[yearIndex], 10);
// Check month value to be between 1..12
if (theMonth < 1 || theMonth > 12) {
return false;
}
// Calculate the maxDay according to the current month
switch (theMonth) {
case 1:	// January
case 3: // March
case 5: // May
case 7: // July
case 8: // August
case 10: // October
case 12: // December
maxDay = 31;
break;
case 4:	// April
case 6: // Juna
case 9: // September
case 11: // November
maxDay = 30;
break;
case 2: // February
if ((parseInt(theYear/4, 10) * 4 == theYear) && (parseInt(theYear/100, 10) * 100 != theYear)) {
maxDay = 29;
} else {
maxDay = 28;
}
break;
}
// Check day value to be between 1..maxDay
if (theDay < 1 || theDay > maxDay) {
return false;
}
// If successfull we'll return the date object
return (new Date(theYear, theMonth, theDay));
}
} else {
return false;
}
}
},
'time': {
validation: function(value, options) {
//	HH:MM:SS T
var formatRegExp = /([hmst]+)/gi;
var valueRegExp = /(\d+|AM?|PM?)/gi;
var formatGroups = options.format.match(formatRegExp);
var valueGroups = value.match(valueRegExp);
//mast match and have same length
if (formatGroups !== null && valueGroups !== null) {
if (formatGroups.length != valueGroups.length) {
return false;
}
var hourIndex = -1;
var minuteIndex = -1;
var secondIndex = -1;
//T is AM or PM
var tIndex = -1;
var theHour = 0, theMinute = 0, theSecond = 0, theT = 'AM';
for (var i=0; i<formatGroups.length; i++) {
switch (formatGroups[i].toLowerCase()) {
case "hh":
hourIndex = i;
break;
case "mm":
minuteIndex = i;
break;
case "ss":
secondIndex = i;
break;
case "t":
case "tt":
tIndex = i;
break;
}
}
if (hourIndex != -1) {
var theHour = parseInt(valueGroups[hourIndex], 10);
if (isNaN(theHour) || theHour > (formatGroups[hourIndex] == 'HH' ? 23 : 12 )) {
return false;
}
}
if (minuteIndex != -1) {
var theMinute = parseInt(valueGroups[minuteIndex], 10);
if (isNaN(theMinute) || theMinute > 59) {
return false;
}
}
if (secondIndex != -1) {
var theSecond = parseInt(valueGroups[secondIndex], 10);
if (isNaN(theSecond) || theSecond > 59) {
return false;
}
}
if (tIndex != -1) {
var theT = valueGroups[tIndex].toUpperCase();
if (
formatGroups[tIndex].toUpperCase() == 'TT' && !/^a|pm$/i.test(theT) ||
formatGroups[tIndex].toUpperCase() == 'T' && !/^a|p$/i.test(theT)
) {
return false;
}
}
var date = new Date(2000, 0, 1, theHour + (theT.charAt(0) == 'P'?12:0), theMinute, theSecond);
return date;
} else {
return false;
}
}
},
'credit_card': {
characterMasking: /\d/,
validation: function(value, options) {
var regExp = null;
options.format = options.format || 'ALL';
switch (options.format.toUpperCase()) {
case 'ALL': regExp = /^[3-6]{1}[0-9]{12,15}$/; break;
case 'VISA': regExp = /^4[0-9]{12,15}$/; break;
case 'MASTERCARD': regExp = /^5[1-5]{1}[0-9]{14}$/; break;
case 'AMEX': regExp = /^3(4|7){1}[0-9]{13}$/; break;
case 'DISCOVER': regExp = /^6011[0-9]{12}$/; break;
case 'DINERSCLUB': regExp = /^3((0[0-5]{1}[0-9]{11})|(6[0-9]{12})|(8[0-9]{12}))$/; break;
}
if (!regExp.test(value)) {
return false;
}
var digits = [];
var j = 1, digit = '';
for (var i = value.length - 1; i >= 0; i--) {
if ((j%2) == 0) {
digit = parseInt(value.charAt(i), 10) * 2;
digits[digits.length] = digit.toString().charAt(0);
if (digit.toString().length == 2) {
digits[digits.length] = digit.toString().charAt(1);
}
} else {
digit = value.charAt(i);
digits[digits.length] = digit;
}
j++;
}
var sum = 0;
for(i=0; i < digits.length; i++ ) {
sum += parseInt(digits[i], 10);
}
if ((sum%10) == 0) {
return true;
}
return false;
}
},
'zip_code': {
formats: {
'zip_us9': {
pattern:'00000-0000'
},
'zip_us5': {
pattern:'00000'
},
'zip_uk': {
characterMasking: /[\dA-Z\s]/,
validation: function(value, options) {
//check one of the following masks
// AN NAA, ANA NAA, ANN NAA, AAN NAA, AANA NAA, AANN NAA
return /^[A-Z]{1,2}\d[\dA-Z]?\s?\d[A-Z]{2}$/.test(value);
}
},
'zip_canada': {
characterMasking: /[\dA-Z\s]/,
pattern: 'A0A 0A0'
},
'zip_custom': {}
}
},
'phone_number': {
formats: {
//US phone number; 10 digits
'phone_us': {
pattern:'(000) 000-0000'
},
'phone_custom': {}
}
},
'social_security_number': {
pattern:'000-00-0000'
},
'ip': {
characterMaskingFormats: {
'ipv4': /[\d\.]/i,
'ipv6_ipv4': /[\d\.\:A-F\/]/i,
'ipv6': /[\d\.\:A-F\/]/i
},
validation: function (value, options) {
return Spry.Widget.ValidationTextField.validateIP(value, options.format);
}
},
'url': {
characterMasking: /[^\s]/,
validation: function(value, options) {
//fix for ?ID=223429 and ?ID=223387
/* the following regexp matches components of an URI as specified in http://tools.ietf.org/html/rfc3986#page-51 page 51, Appendix B.
scheme	= $2
authority = $4
path	  = $5
query	 = $7
fragment  = $9
*/
var URI_spliter = /^(([^:\/?#]+):)?(\/\/([^\/?#]*))?([^?#]*)(\?([^#]*))?(#(.*))?/;
var parts = value.match(URI_spliter);
if (parts && parts[4]) {
//encode each component of the domain name using Punycode encoding scheme: http://tools.ietf.org/html/rfc3492
var host  = parts[4].split(".");
var punyencoded = '';
for (var i=0; i<host.length; i++) {
punyencoded = Spry.Widget.Utils.punycode_encode(host[i], 64);
if (!punyencoded) {
return false;
} else {
if (punyencoded != (host[i] + "-")) {
host[i] = 'xn--' + punyencoded;
}
}
}
host = host .join(".");
//the encoded domain name is replaced into the original URL to be validated again later as URL
value = value.replace(URI_spliter, "$1//" + host + "$5$6$8");
}
//fix for ?ID=223358 and ?ID=223594
//the following validates an URL using ABNF rules as defined in http://tools.ietf.org/html/rfc3986 , Appendix A., page 49
//except host which is extracted by match[1] and validated separately
/*
* userinfo=	(?:(?:[a-z0-9\-\._~\!\$\&\'\(\)\*\+\,\;\=:]|%[0-9a-f]{2,2})*\@)?
* host=	(?:((?:(?:[a-z0-9][a-z0-9\-]*[a-z0-9]|[a-z0-9])\.)*(?:[a-z][a-z0-9\-]*[a-z0-9]|[a-z])|(?:\[[^\]]*\]))
* pathname=	(?:\/(?:[a-z0-9\-\._~\!\$\&\'\(\)\*\+\,\;\=\:\@]|%[0-9a-f]{2,2})*)*
* query=	(?:\?(?:[a-z0-9\-\._~\!\$\&\'\(\)\*\+\,\;\=\:\@\/\?]|%[0-9a-f]{2,2})*)?
* anchor=	(?:\#(?:[a-z0-9\-\._~\!\$\&\'\(\)\*\+\,\;\=\:\@\/\?]|%[0-9a-f]{2,2})*)?
*/
var regExp = /^(?:https?|ftp)\:\/\/(?:(?:[a-z0-9\-\._~\!\$\&\'\(\)\*\+\,\;\=:]|%[0-9a-f]{2,2})*\@)?(?:((?:(?:[a-z0-9][a-z0-9\-]*[a-z0-9]|[a-z0-9])\.)*(?:[a-z][a-z0-9\-]*[a-z0-9]|[a-z])|(?:\[[^\]]*\]))(?:\:[0-9]*)?)(?:\/(?:[a-z0-9\-\._~\!\$\&\'\(\)\*\+\,\;\=\:\@]|%[0-9a-f]{2,2})*)*(?:\?(?:[a-z0-9\-\._~\!\$\&\'\(\)\*\+\,\;\=\:\@\/\?]|%[0-9a-f]{2,2})*)?(?:\#(?:[a-z0-9\-\._~\!\$\&\'\(\)\*\+\,\;\=\:\@\/\?]|%[0-9a-f]{2,2})*)?$/i;
var valid = value.match(regExp);
if (valid) {
//extract the  address from URL
var address = valid[1];
if (address) {
if (address == '[]') {
return false;
}
var first = address.charAt(0);
var last = address.charAt(address.length - 1);
if (first == '[' && last != ']' || first != '[' && last == ']') {
return false;
} else if (first == '[' && last == ']') {
//IPv6 address or IPv4 enclosed in square brackets
address = address.replace(/^\[|\]$/gi, '');
return Spry.Widget.ValidationTextField.validateIP(address, 'ipv6_ipv4');
} else {
if (/[^0-9\.]/.test(address)) {
return true;
} else {
//check if hostname is all digits and dots and then check for IPv4
return Spry.Widget.ValidationTextField.validateIP(address, 'ipv4');
}
}
} else {
return true;
}
} else {
return false;
}
}
}
};
/*
2.2.1. Preferred
x:x:x:x:x:x:x:x, where the 'x's are the hexadecimal values of the eight 16-bit pieces of the address.
Examples:
FEDC:BA98:7654:3210:FEDC:BA98:7654:3210
1080:0:0:0:8:800:200C:417A
Note that it is not necessary to write the leading zeros in an
individual field, but there must be at least one numeral in every
field (except for the case described in 2.2.2.).
2.2.2. Compressed
The use of "::" indicates multiple groups of 16-bits of zeros.
The "::" can only appear once in an address.  The "::" can also be
used to compress the leading and/or trailing zeros in an address.
1080:0:0:0:8:800:200C:417A --> 1080::8:800:200C:417A
FF01:0:0:0:0:0:0:101 --> FF01::101
0:0:0:0:0:0:0:1 --> ::1
0:0:0:0:0:0:0:0 --> ::
2.5.4 IPv6 Addresses with Embedded IPv4 Addresses
IPv4-compatible IPv6 address (tunnel IPv6 packets over IPv4 routing infrastructures)
::0:129.144.52.38
IPv4-mapped IPv6 address (represent the addresses of IPv4-only nodes as IPv6 addresses)
::ffff:129.144.52.38
The text representation of IPv6 addresses and prefixes in Augmented BNF (Backus-Naur Form) [ABNF] for reference purposes.
[ABNF http://tools.ietf.org/html/rfc2234]
IPv6address = hexpart [ ":" IPv4address ]
IPv4address = 1*3DIGIT "." 1*3DIGIT "." 1*3DIGIT "." 1*3DIGIT
IPv6prefix  = hexpart "/" 1*2DIGIT
hexpart = hexseq | hexseq "::" [ hexseq ] | "::" [ hexseq ]
hexseq  = hex4 *( ":" hex4)
hex4	= 1*4HEXDIG
*/
Spry.Widget.ValidationTextField.validateIP = function (value, format)
{
var validIPv6Addresses = [
//preferred
/^(?:[a-f0-9]{1,4}:){7}[a-f0-9]{1,4}(?:\/\d{1,3})?$/i,
//various compressed
/^[a-f0-9]{0,4}::(?:\/\d{1,3})?$/i,
/^:(?::[a-f0-9]{1,4}){1,6}(?:\/\d{1,3})?$/i,
/^(?:[a-f0-9]{1,4}:){1,6}:(?:\/\d{1,3})?$/i,
/^(?:[a-f0-9]{1,4}:)(?::[a-f0-9]{1,4}){1,6}(?:\/\d{1,3})?$/i,
/^(?:[a-f0-9]{1,4}:){2}(?::[a-f0-9]{1,4}){1,5}(?:\/\d{1,3})?$/i,
/^(?:[a-f0-9]{1,4}:){3}(?::[a-f0-9]{1,4}){1,4}(?:\/\d{1,3})?$/i,
/^(?:[a-f0-9]{1,4}:){4}(?::[a-f0-9]{1,4}){1,3}(?:\/\d{1,3})?$/i,
/^(?:[a-f0-9]{1,4}:){5}(?::[a-f0-9]{1,4}){1,2}(?:\/\d{1,3})?$/i,
/^(?:[a-f0-9]{1,4}:){6}(?::[a-f0-9]{1,4})(?:\/\d{1,3})?$/i,
//IPv6 mixes with IPv4
/^(?:[a-f0-9]{1,4}:){6}(?:\d{1,3}\.){3}\d{1,3}(?:\/\d{1,3})?$/i,
/^:(?::[a-f0-9]{1,4}){0,4}:(?:\d{1,3}\.){3}\d{1,3}(?:\/\d{1,3})?$/i,
/^(?:[a-f0-9]{1,4}:){1,5}:(?:\d{1,3}\.){3}\d{1,3}(?:\/\d{1,3})?$/i,
/^(?:[a-f0-9]{1,4}:)(?::[a-f0-9]{1,4}){1,4}:(?:\d{1,3}\.){3}\d{1,3}(?:\/\d{1,3})?$/i,
/^(?:[a-f0-9]{1,4}:){2}(?::[a-f0-9]{1,4}){1,3}:(?:\d{1,3}\.){3}\d{1,3}(?:\/\d{1,3})?$/i,
/^(?:[a-f0-9]{1,4}:){3}(?::[a-f0-9]{1,4}){1,2}:(?:\d{1,3}\.){3}\d{1,3}(?:\/\d{1,3})?$/i,
/^(?:[a-f0-9]{1,4}:){4}(?::[a-f0-9]{1,4}):(?:\d{1,3}\.){3}\d{1,3}(?:\/\d{1,3})?$/i
];
var validIPv4Addresses = [
//IPv4
/^(\d{1,3}\.){3}\d{1,3}$/i
];
var validAddresses = [];
if (format == 'ipv6' || format == 'ipv6_ipv4') {
validAddresses = validAddresses.concat(validIPv6Addresses);
}
if (format == 'ipv4' || format == 'ipv6_ipv4') {
validAddresses = validAddresses.concat(validIPv4Addresses);
}
var ret = false;
for (var i=0; i<validAddresses.length; i++) {
if (validAddresses[i].test(value)) {
ret = true;
break;
}
}
if (ret && value.indexOf(".") != -1) {
//if address contains IPv4 fragment, it must be valid; all 4 groups must be less than 256
var ipv4 = value.match(/:?(?:\d{1,3}\.){3}\d{1,3}/i);
if(!ipv4) {
return false;
}
ipv4 = ipv4[0].replace(/^:/, '');
var pieces = ipv4.split('.');
if (pieces.length != 4) {
return false;
}
var regExp = /^[\-\+]?\d*$/;
for (var i=0; i< pieces.length; i++) {
if (pieces[i] == '') {
return false;
}
var piece = parseInt(pieces[i], 10);
if (isNaN(piece) || piece > 255 || !regExp.test(pieces[i]) || pieces[i].length>3 || /^0{2,3}$/.test(pieces[i])) {
return false;
}
}
}
if (ret && value.indexOf("/") != -1) {
// if prefix-length is specified must be in [1-128]
var prefLen = value.match(/\/\d{1,3}$/);
if (!prefLen) return false;
var prefLenVal = parseInt(prefLen[0].replace(/^\//,''), 10);
if (isNaN(prefLenVal) || prefLenVal > 128 || prefLenVal < 1) {
return false;
}
}
return ret;
};
Spry.Widget.ValidationTextField.onloadDidFire = false;
Spry.Widget.ValidationTextField.loadQueue = [];
Spry.Widget.ValidationTextField.prototype.isBrowserSupported = function()
{
return Spry.is.ie && Spry.is.v >= 5 && Spry.is.windows
||
Spry.is.mozilla && Spry.is.v >= 1.4
||
Spry.is.safari
||
Spry.is.opera && Spry.is.v >= 9;
};
Spry.Widget.ValidationTextField.prototype.init = function(element, options)
{
this.element = this.getElement(element);
this.errors = 0;
this.flags = {locked: false};
this.options = {};
this.event_handlers = [];
this.validClass = "textfieldValidState";
this.focusClass = "textfieldFocusState";
this.requiredClass = "textfieldRequiredState";
this.invalidFormatClass = "textfieldInvalidFormatState";
this.invalidRangeMinClass = "textfieldMinValueState";
this.invalidRangeMaxClass = "textfieldMaxValueState";
this.invalidCharsMinClass = "textfieldMinCharsState";
this.invalidCharsMaxClass = "textfieldMaxCharsState";
this.textfieldFlashTextClass = "textfieldFlashText";
if (Spry.is.safari) {
this.flags.lastKeyPressedTimeStamp = 0;
}
switch (this.type) {
case 'phone_number':options.format = Spry.Widget.Utils.firstValid(options.format, 'phone_us');break;
case 'currency':options.format = Spry.Widget.Utils.firstValid(options.format, 'comma_dot');break;
case 'zip_code':options.format = Spry.Widget.Utils.firstValid(options.format, 'zip_us5');break;
case 'date':
options.format = Spry.Widget.Utils.firstValid(options.format, 'mm/dd/yy');
break;
case 'time':
options.format = Spry.Widget.Utils.firstValid(options.format, 'HH:mm');
options.pattern = options.format.replace(/[hms]/gi, "0").replace(/TT/gi, 'AM').replace(/T/gi, 'A');
break;
case 'ip':
options.format = Spry.Widget.Utils.firstValid(options.format, 'ipv4');
options.characterMasking = Spry.Widget.ValidationTextField.ValidationDescriptors[this.type].characterMaskingFormats[options.format];
break;
}
//retrieve the validation type descriptor to be used with this instance (base on type and format)
//widgets may have different validations depending on format (like zip_code with formats)
var validationDescriptor = {};
if (options.format && Spry.Widget.ValidationTextField.ValidationDescriptors[this.type].formats) {
if (Spry.Widget.ValidationTextField.ValidationDescriptors[this.type].formats[options.format]) {
Spry.Widget.Utils.setOptions(validationDescriptor, Spry.Widget.ValidationTextField.ValidationDescriptors[this.type].formats[options.format]);
}
} else {
Spry.Widget.Utils.setOptions(validationDescriptor, Spry.Widget.ValidationTextField.ValidationDescriptors[this.type]);
}
//set default values for some parameters which were not aspecified
options.useCharacterMasking = Spry.Widget.Utils.firstValid(options.useCharacterMasking, false);
options.hint = Spry.Widget.Utils.firstValid(options.hint, '');
options.isRequired = Spry.Widget.Utils.firstValid(options.isRequired, true);
//set widget validation parameters
//get values from validation type descriptor
//use the user specified values, if defined
options.characterMasking = Spry.Widget.Utils.firstValid(options.characterMasking, validationDescriptor.characterMasking);
options.regExpFilter = Spry.Widget.Utils.firstValid(options.regExpFilter, validationDescriptor.regExpFilter);
options.pattern = Spry.Widget.Utils.firstValid(options.pattern, validationDescriptor.pattern);
options.validation = Spry.Widget.Utils.firstValid(options.validation, validationDescriptor.validation);
if (typeof options.validation == 'string') {
options.validation = eval(options.validation);
}
options.minValue = Spry.Widget.Utils.firstValid(options.minValue, validationDescriptor.minValue);
options.maxValue = Spry.Widget.Utils.firstValid(options.maxValue, validationDescriptor.maxValue);
options.minChars = Spry.Widget.Utils.firstValid(options.minChars, validationDescriptor.minChars);
options.maxChars = Spry.Widget.Utils.firstValid(options.maxChars, validationDescriptor.maxChars);
Spry.Widget.Utils.setOptions(this, options);
Spry.Widget.Utils.setOptions(this.options, options);
};
Spry.Widget.ValidationTextField.prototype.destroy = function() {
for (var i=0; i<this.event_handlers.length; i++) {
Spry.Widget.Utils.removeEventListener(this.event_handlers[i][0], this.event_handlers[i][1], this.event_handlers[i][2], false);
}
try { delete this.element; } catch(err) {}
try { delete this.input; } catch(err) {}
try { delete this.form; } catch(err) {}
try { delete this.event_handlers; } catch(err) {}
try { this.selection.destroy(); } catch(err) {}
try { delete this.selection; } catch(err) {}
var q = Spry.Widget.Form.onSubmitWidgetQueue;
var qlen = q.length;
for (var i = 0; i < qlen; i++) {
if (q[i] == this) {
q.splice(i, 1);
break;
}
}
};
Spry.Widget.ValidationTextField.prototype.attachBehaviors = function()
{
if (this.element) {
if (this.element.nodeName == "INPUT") {
this.input = this.element;
} else {
this.input = Spry.Widget.Utils.getFirstChildWithNodeNameAtAnyLevel(this.element, "INPUT");
}
}
if (this.input) {
if (this.maxChars) {
this.input.removeAttribute("maxLength");
}
this.putHint();
this.compilePattern();
if (this.type == 'date') {
this.compileDatePattern();
}
this.input.setAttribute("AutoComplete", "off");
this.selection = new Spry.Widget.SelectionDescriptor(this.input);
this.oldValue = this.input.value;
var self = this;
this.event_handlers = [];
this.event_handlers.push([this.input, "keydown", function(e) { if (self.isDisabled()) return true; return self.onKeyDown(e || event); }]);
this.event_handlers.push([this.input, "keypress", function(e) { if (self.isDisabled()) return true; return self.onKeyPress(e || event); }]);
if (Spry.is.opera) {
this.event_handlers.push([this.input, "keyup", function(e) { if (self.isDisabled()) return true; return self.onKeyUp(e || event); }]);
}
this.event_handlers.push([this.input, "focus", function(e) { if (self.isDisabled()) return true; return self.onFocus(e || event); }]);
this.event_handlers.push([this.input, "blur", function(e) { if (self.isDisabled()) return true; return self.onBlur(e || event); }]);
this.event_handlers.push([this.input, "mousedown", function(e) { if (self.isDisabled()) return true; return self.onMouseDown(e || event); }]);
var changeEvent =
Spry.is.mozilla || Spry.is.opera || Spry.is.safari?"input":
Spry.is.ie?"propertychange":
"change";
this.event_handlers.push([this.input, changeEvent, function(e) { if (self.isDisabled()) return true; return self.onChange(e || event); }]);
if (Spry.is.mozilla || Spry.is.safari) {
//oninput event on mozilla does not fire ondragdrop
this.event_handlers.push([this.input, "dragdrop", function(e) { if (self.isDisabled()) return true; self.removeHint();return self.onChange(e || event); }]);
} else if (Spry.is.ie){
//ondrop&onpropertychange crash on IE
this.event_handlers.push([this.input, "drop", function(e) { if (self.isDisabled()) return true; return self.onDrop(e || event); }]);
}
for (var i=0; i<this.event_handlers.length; i++) {
Spry.Widget.Utils.addEventListener(this.event_handlers[i][0], this.event_handlers[i][1], this.event_handlers[i][2], false);
}
// submit
this.form = Spry.Widget.Utils.getFirstParentWithNodeName(this.input, "FORM");
if (this.form) {
// if no "onSubmit" handler has been attached to the current form, attach one
if (!this.form.attachedSubmitHandler && !this.form.onsubmit) {
this.form.onsubmit = function(e) { e = e || event; return Spry.Widget.Form.onSubmit(e, e.srcElement || e.currentTarget) };
this.form.attachedSubmitHandler = true;
}
if (!this.form.attachedResetHandler) {
Spry.Widget.Utils.addEventListener(this.form, "reset", function(e) { e = e || event; return Spry.Widget.Form.onReset(e, e.srcElement || e.currentTarget) }, false);
this.form.attachedResetHandler = true;
}
// add the currrent widget to the "onSubmit" check queue;
Spry.Widget.Form.onSubmitWidgetQueue.push(this);
}
}
};
Spry.Widget.ValidationTextField.prototype.isDisabled = function() {
return this.input && (this.input.disabled || this.input.readOnly) || !this.input;
};
Spry.Widget.ValidationTextField.prototype.getElement = function(ele)
{
if (ele && typeof ele == "string")
return document.getElementById(ele);
return ele;
};
Spry.Widget.ValidationTextField.addLoadListener = function(handler)
{
if (typeof window.addEventListener != 'undefined')
window.addEventListener('load', handler, false);
else if (typeof document.addEventListener != 'undefined')
document.addEventListener('load', handler, false);
else if (typeof window.attachEvent != 'undefined')
window.attachEvent('onload', handler);
};
Spry.Widget.ValidationTextField.processLoadQueue = function(handler)
{
Spry.Widget.ValidationTextField.onloadDidFire = true;
var q = Spry.Widget.ValidationTextField.loadQueue;
var qlen = q.length;
for (var i = 0; i < qlen; i++)
q[i].attachBehaviors();
};
Spry.Widget.ValidationTextField.addLoadListener(Spry.Widget.ValidationTextField.processLoadQueue);
Spry.Widget.ValidationTextField.addLoadListener(function(){
Spry.Widget.Utils.addEventListener(window, "unload", Spry.Widget.Form.destroyAll, false);
});
Spry.Widget.ValidationTextField.prototype.setValue = function(newValue) {
this.flags.locked = true;
this.input.value = newValue;
this.flags.locked = false;
this.oldValue = newValue;
if (!Spry.is.ie) {
this.onChange();
}
};
/**
* save the state of the input (selection and value) so we can revert to it
* should call this just before modifying the input value
*/
Spry.Widget.ValidationTextField.prototype.saveState = function()
{
this.oldValue = this.input.value;
this.selection.update();
};
Spry.Widget.ValidationTextField.prototype.revertState = function(revertValue)
{
if (revertValue != this.input.value) {
this.input.readOnly = true;
this.input.value = revertValue;
this.input.readOnly = false;
if (Spry.is.safari && this.flags.active) {
this.input.focus();
}
}
this.selection.moveTo(this.selection.start, this.selection.end);
this.redTextFlash();
};
Spry.Widget.ValidationTextField.prototype.removeHint = function()
{
if (this.flags.hintOn) {
this.input.value = "";
this.flags.hintOn = false;
}
};
Spry.Widget.ValidationTextField.prototype.putHint = function()
{
if(this.hint && this.input && this.input.type == "text" && this.input.value == "") {
this.flags.hintOn = true;
this.input.value = this.hint;
}
};
Spry.Widget.ValidationTextField.prototype.redTextFlash = function()
{
var self = this;
this.addClassName(this.element, this.textfieldFlashTextClass);
setTimeout(function() {
self.removeClassName(self.element, self.textfieldFlashTextClass)
}, 100);
};
Spry.Widget.ValidationTextField.prototype.doValidations = function(testValue, revertValue)
{
if (this.isDisabled()) return false;
if (this.flags.locked) {
return false;
}
if (testValue.length == 0 && !this.isRequired) {
this.errors = 0;
return false;
}
this.flags.locked = true;
var mustRevert = false;
var continueValidations = true;
if (!this.options.isRequired && testValue.length == 0) {
continueValidations = false;
}
var errors = 0;
var fixedValue = testValue;
//characterMasking - test if all characters are valid with the characterMasking (keyboard filter)
if (this.useCharacterMasking && this.characterMasking) {
for(var i=0; i<testValue.length; i++) {
if (!this.characterMasking.test(testValue.charAt(i))) {
errors = errors | Spry.Widget.ValidationTextField.ERROR_FORMAT;
fixedValue = revertValue;
mustRevert = true;
break;
}
}
}
//regExpFilter - character mask positioning (additional mask to restrict some characters only in some position)
if (!mustRevert && this.useCharacterMasking && this.regExpFilter) {
if (!this.regExpFilter.test(fixedValue)) {
errors = errors | Spry.Widget.ValidationTextField.ERROR_FORMAT;
mustRevert = true;
}
}
//pattern - testValue matches the pattern so far
if (!mustRevert && this.pattern) {
var currentRegExp = this.patternToRegExp(testValue.length);
if (!currentRegExp.test(testValue)) {
errors = errors | Spry.Widget.ValidationTextField.ERROR_FORMAT;
mustRevert = true;
} else if (this.patternLength != testValue.length) {
//testValue matches pattern so far, but it's not ok if it does not have the proper length
//do not revert, but should show the error
errors = errors | Spry.Widget.ValidationTextField.ERROR_FORMAT;
}
}
if (fixedValue == '') {
errors = errors | Spry.Widget.ValidationTextField.ERROR_REQUIRED;
}
if (!mustRevert && this.pattern && this.useCharacterMasking) {
var n = this.getAutoComplete(testValue.length);
if (n) {
fixedValue += n;
}
}
if(!mustRevert && this.minChars !== null  && continueValidations) {
if (testValue.length < this.minChars) {
errors = errors | Spry.Widget.ValidationTextField.ERROR_CHARS_MIN;
continueValidations = false;
}
}
if(!mustRevert && this.maxChars !== null && continueValidations) {
if (testValue.length > this.maxChars) {
errors = errors | Spry.Widget.ValidationTextField.ERROR_CHARS_MAX;
continueValidations = false;
}
}
//validation - testValue passes widget validation function
if (!mustRevert && this.validation && continueValidations) {
var value = this.validation(fixedValue, this.options);
if (false === value) {
errors = errors | Spry.Widget.ValidationTextField.ERROR_FORMAT;
continueValidations = false;
} else {
this.typedValue = value;
}
}
if(!mustRevert && this.validation && this.minValue !== null && continueValidations) {
var minValue = this.validation(this.minValue, this.options);
if (minValue !== false) {
if (this.typedValue < minValue) {
errors = errors | Spry.Widget.ValidationTextField.ERROR_RANGE_MIN;
continueValidations = false;
}
}
}
if(!mustRevert && this.validation && this.maxValue !== null && continueValidations) {
var maxValue = this.validation(this.maxValue, this.options);
if (maxValue !== false) {
if( this.typedValue > maxValue) {
errors = errors | Spry.Widget.ValidationTextField.ERROR_RANGE_MAX;
continueValidations = false;
}
}
}
//an invalid value was tested; must make sure it does not get inside the input
if (this.useCharacterMasking && mustRevert) {
this.revertState(revertValue);
}
this.errors = errors;
this.fixedValue = fixedValue;
this.flags.locked = false;
return mustRevert;
};
Spry.Widget.ValidationTextField.prototype.onChange = function(e)
{
if (Spry.is.opera && this.flags.operaRevertOnKeyUp) {
return true;
}
if (Spry.is.ie && e && e.propertyName != 'value') {
return true;
}
if (this.flags.drop) {
//delay this if it's a drop operation
var self = this;
setTimeout(function() {
self.flags.drop = false;
self.onChange(null);
}, 0);
return;
}
if (this.flags.hintOn) {
return true;
}
if (this.keyCode == 8 || this.keyCode == 46 ) {
var mustRevert = this.doValidations(this.input.value, this.input.value);
this.oldValue = this.input.value;
if ((mustRevert || this.errors) && this.validateOn & Spry.Widget.ValidationTextField.ONCHANGE) {
var self = this;
setTimeout(function() {self.validate();}, 0);
return true;
}
}
var mustRevert = this.doValidations(this.input.value, this.oldValue);
if ((!mustRevert || this.errors) && this.validateOn & Spry.Widget.ValidationTextField.ONCHANGE) {
var self = this;
setTimeout(function() {self.validate();}, 0);
}
return true;
};
Spry.Widget.ValidationTextField.prototype.onKeyUp = function(e) {
if (this.flags.operaRevertOnKeyUp) {
this.setValue(this.oldValue);
Spry.Widget.Utils.stopEvent(e);
this.selection.moveTo(this.selection.start, this.selection.start);
this.flags.operaRevertOnKeyUp = false;
return false;
}
if (this.flags.operaPasteOperation) {
window.clearInterval(this.flags.operaPasteOperation);
this.flags.operaPasteOperation = null;
}
};
Spry.Widget.ValidationTextField.prototype.operaPasteMonitor = function() {
if (this.input.value != this.oldValue) {
var mustRevert = this.doValidations(this.input.value, this.input.value);
if (mustRevert) {
this.setValue(this.oldValue);
this.selection.moveTo(this.selection.start, this.selection.start);
} else {
this.onChange();
}
}
};
Spry.Widget.ValidationTextField.prototype.compileDatePattern = function ()
{
var dateValidationPatternString = "";
var groupPatterns = [];
var fullGroupPatterns = [];
var autocompleteCharacters = [];
var formatRegExp = /^([mdy]+)([\.\-\/\\\s]+)([mdy]+)([\.\-\/\\\s]+)([mdy]+)$/i;
var formatGroups = this.options.format.match(formatRegExp);
if (formatGroups !== null) {
for (var i=1; i<formatGroups.length; i++) {
switch (formatGroups[i].toLowerCase()) {
case "dd":
groupPatterns[i-1] = "\\d{1,2}";
fullGroupPatterns[i-1] = "\\d\\d";
dateValidationPatternString += "(" + groupPatterns[i-1] + ")";
autocompleteCharacters[i-1] = null;
break;
case "mm":
groupPatterns[i-1] = "\\d{1,2}";
fullGroupPatterns[i-1] = "\\d\\d";
dateValidationPatternString += "(" + groupPatterns[i-1] + ")";
autocompleteCharacters[i-1] = null;
break;
case "yy":
groupPatterns[i-1] = "\\d{1,2}";
fullGroupPatterns[i-1] = "\\d\\d";
dateValidationPatternString += "(\\d\\d)";
autocompleteCharacters[i-1] = null;
break;
case "yyyy":
groupPatterns[i-1] = "\\d{1,4}";
fullGroupPatterns[i-1] = "\\d\\d\\d\\d";
dateValidationPatternString += "(\\d\\d\\d\\d)";
autocompleteCharacters[i-1] = null;
break;
default:
groupPatterns[i-1] = fullGroupPatterns[i-1] = Spry.Widget.ValidationTextField.regExpFromChars(formatGroups[i]);
dateValidationPatternString += "["+ groupPatterns[i-1] + "]";
autocompleteCharacters[i-1] = formatGroups[i];
}
}
}
this.dateValidationPattern = new RegExp("^" + dateValidationPatternString + "$" , "")
this.dateAutocompleteCharacters = autocompleteCharacters;
this.dateGroupPatterns = groupPatterns;
this.dateFullGroupPatterns = fullGroupPatterns;
this.lastDateGroup = formatGroups.length-2;
}
Spry.Widget.ValidationTextField.prototype.getRegExpForGroup = function (group)
{
var ret = '^';
for (var j = 0; j <= group; j++) ret += this.dateGroupPatterns[j];
ret += '$';
return new RegExp(ret, "");
}
Spry.Widget.ValidationTextField.prototype.getRegExpForFullGroup = function (group)
{
var ret = '^';
for (var j = 0; j < group; j++) ret += this.dateGroupPatterns[j];
ret += this.dateFullGroupPatterns[group];
return new RegExp(ret, "");
}
Spry.Widget.ValidationTextField.prototype.getDateGroup = function(value, pos)
{
if (pos == 0) return 0;
var test_value = value.substring(0, pos);
for (var i=0; i <= this.lastDateGroup; i++)
if (this.getRegExpForGroup(i).test(test_value)) return i;
return -1;
};
Spry.Widget.ValidationTextField.prototype.isDateGroupFull = function(value, group)
{
return this.getRegExpForFullGroup(group).test(value);
}
Spry.Widget.ValidationTextField.prototype.isValueValid = function(value, pos, group)
{
var test_value = value.substring(0, pos);
return this.getRegExpForGroup(group).test(test_value);
}
Spry.Widget.ValidationTextField.prototype.isPositionAtEndOfGroup = function (value, pos, group)
{
var test_value = value.substring(0, pos);
return this.getRegExpForFullGroup(group).test(test_value);
}
Spry.Widget.ValidationTextField.prototype.nextDateDelimiterExists = function (value, pos, group)
{
var autocomplete = this.dateAutocompleteCharacters[group+1];
if (value.length < pos  + autocomplete.length)
return false;
else
{
var test_value = value.substring(pos, pos+autocomplete.length);
if (test_value == autocomplete)
return true;
}
return false;
}
Spry.Widget.ValidationTextField.prototype.onKeyPress = function(e)
{
if (this.flags.skp) {
this.flags.skp = false;
Spry.Widget.Utils.stopEvent(e);
return false;
}
if (e.ctrlKey || e.metaKey || !this.useCharacterMasking) {
return true;
}
/*
if (Spry.is.safari) {
if ( (e.timeStamp - this.flags.lastKeyPressedTimeStamp)<10 ) {
return true;
}
this.flags.lastKeyPressedTimeStamp = e.timeStamp;
}
*/
if (Spry.is.opera && this.flags.operaRevertOnKeyUp) {
Spry.Widget.Utils.stopEvent(e);
return false;
}
if (this.keyCode == 8 || this.keyCode == 46) {
var mr = this.doValidations(this.input.value, this.input.value);
if (mr) {
return true;
}
}
var pressed = Spry.Widget.Utils.getCharacterFromEvent(e);
if (pressed && this.characterMasking) {
if (!this.characterMasking.test(pressed)) {
Spry.Widget.Utils.stopEvent(e);
this.redTextFlash();
return false;
}
}
if(pressed && this.pattern) {
var currentPatternChar = this.patternCharacters[this.selection.start];
if (/[ax]/i.test(currentPatternChar)) {
//convert the entered character to the pattern character case
if (currentPatternChar.toLowerCase() == currentPatternChar) {
pressed = pressed.toLowerCase();
} else {
pressed = pressed.toUpperCase();
}
}
var autocomplete = this.getAutoComplete(this.selection.start);
if (this.selection.start == this.oldValue.length) {
if (this.oldValue.length < this.patternLength) {
if (autocomplete) {
Spry.Widget.Utils.stopEvent(e);
var futureValue = this.oldValue.substring(0, this.selection.start) + autocomplete + pressed;
var mustRevert = this.doValidations(futureValue, this.oldValue);
if (!mustRevert) {
this.setValue(this.fixedValue);
this.selection.moveTo(this.fixedValue.length, this.fixedValue.length);
} else {
this.setValue(this.oldValue.substring(0, this.selection.start) + autocomplete);
this.selection.moveTo(this.selection.start + autocomplete.length, this.selection.start + autocomplete.length);
}
return false;
}
} else {
Spry.Widget.Utils.stopEvent(e);
this.setValue(this.input.value);
return false;
}
} else if (autocomplete) {
Spry.Widget.Utils.stopEvent(e);
this.selection.moveTo(this.selection.start + autocomplete.length, this.selection.start + autocomplete.length);
return false;
}
Spry.Widget.Utils.stopEvent(e);
var futureValue = this.oldValue.substring(0, this.selection.start) + pressed + this.oldValue.substring(this.selection.start + 1);
var mustRevert = this.doValidations(futureValue, this.oldValue);
if (!mustRevert) {
autocomplete = this.getAutoComplete(this.selection.start + 1);
this.setValue(this.fixedValue);
this.selection.moveTo(this.selection.start + 1 + autocomplete.length, this.selection.start + 1 + autocomplete.length);
} else {
this.selection.moveTo(this.selection.start, this.selection.start);
}
return false;
}
if (pressed && this.type == 'date' && this.useCharacterMasking)
{
var group = this.getDateGroup(this.oldValue, this.selection.start);
if (group != -1) {
Spry.Widget.Utils.stopEvent(e);
if ( (group % 2) !=0 )
group ++;
if (this.isDateGroupFull(this.oldValue, group))
{
if(this.isPositionAtEndOfGroup(this.oldValue, this.selection.start, group))
{
if(group == this.lastDateGroup)
{
this.redTextFlash(); return false;
}
else
{
// add or jump over autocomplete delimiter
var autocomplete = this.dateAutocompleteCharacters[group+1];
if (this.nextDateDelimiterExists(this.oldValue, this.selection.start, group))
{
var autocomplete = this.dateAutocompleteCharacters[group+1];
this.selection.moveTo(this.selection.start + autocomplete.length, this.selection.start + autocomplete.length);
if (pressed == autocomplete)
return false;
if (this.isDateGroupFull(this.oldValue, group+2))
// need to overwrite first char in the next digit group
futureValue = this.oldValue.substring(0, this.selection.start) + pressed + this.oldValue.substring(this.selection.start + 1);
else
futureValue = this.oldValue.substring(0, this.selection.start) + pressed + this.oldValue.substring(this.selection.start);
if (!this.isValueValid(futureValue, this.selection.start + 1, group +2 ))
{
this.redTextFlash(); return false;
}
else
{
this.setValue (futureValue);
this.selection.moveTo(this.selection.start + 1, this.selection.start + 1);
}
return false;
}
else
{
var autocomplete = this.dateAutocompleteCharacters[group+1];
var insertedValue = autocomplete + pressed;
futureValue = this.oldValue.substring(0, this.selection.start) + insertedValue + this.oldValue.substring(this.selection.start);
if (!this.isValueValid(futureValue, this.selection.start + insertedValue.length, group +2 ))
{
// block this type
insertedValue = autocomplete;
futureValue = this.oldValue.substring(0, this.selection.start) + insertedValue + this.oldValue.substring(this.selection.start);
this.setValue (futureValue);
this.selection.moveTo(this.selection.start + insertedValue.length, this.selection.start + insertedValue.length);
this.redTextFlash(); return false;
}
else
{
this.setValue (futureValue);
this.selection.moveTo(this.selection.start + insertedValue.length, this.selection.start + insertedValue.length);
return false;
}
}
}
}
else
{
// it's not the end of the full digits group
// overwrite
var movePosition = 1;
futureValue = this.oldValue.substring(0, this.selection.start) + pressed + this.oldValue.substring(this.selection.start + 1);
if (!this.isValueValid(futureValue, this.selection.start + 1, group))
{
this.redTextFlash(); return false;
}
else
{
if(this.isPositionAtEndOfGroup(futureValue, this.selection.start+1, group))
{
if (group != this.lastDateGroup)
{
if (this.nextDateDelimiterExists(futureValue, this.selection.start + 1, group))
{
var autocomplete = this.dateAutocompleteCharacters[group+1];
movePosition = 1 + autocomplete.length;
}
else
{
var autocomplete = this.dateAutocompleteCharacters[group+1];
futureValue = this.oldValue.substring(0, this.selection.start) + pressed + autocomplete + this.oldValue.substring(this.selection.start + 1);
movePosition = 1 + autocomplete.length;
}
}
}
this.setValue (futureValue);
this.selection.moveTo(this.selection.start + movePosition, this.selection.start + movePosition);
return false;
}
}
}
else
{
// date group is not full
// insert
futureValue = this.oldValue.substring(0, this.selection.start) + pressed + this.oldValue.substring(this.selection.start);
var movePosition = 1;
if (!this.isValueValid(futureValue, this.selection.start + 1, group) && !this.isValueValid(futureValue, this.selection.start + 1, group+1))
{
this.redTextFlash(); return false;
}
else
{
var autocomplete = this.dateAutocompleteCharacters[group+1];
if (pressed == autocomplete)
{
if (this.nextDateDelimiterExists(this.oldValue, this.selection.start, group))
{
futureValue = this.oldValue;
movePosition = 1;
}
}
else
{
if(this.isPositionAtEndOfGroup(futureValue, this.selection.start+1, group))
{
if (group != this.lastDateGroup)
{
if (this.nextDateDelimiterExists(futureValue, this.selection.start + 1, group))
{
var autocomplete = this.dateAutocompleteCharacters[group+1];
movePosition = 1 + autocomplete.length;
}
else
{
var autocomplete = this.dateAutocompleteCharacters[group+1];
futureValue = this.oldValue.substring(0, this.selection.start) + pressed + autocomplete + this.oldValue.substring(this.selection.start + 1);
movePosition = 1 + autocomplete.length;
}
}
}
}
this.setValue (futureValue);
this.selection.moveTo(this.selection.start + movePosition, this.selection.start + movePosition);
return false;
}
}
}
return false;
}
};
Spry.Widget.ValidationTextField.prototype.onKeyDown = function(e)
{
this.saveState();
this.keyCode = e.keyCode;
if (Spry.is.opera) {
if (this.flags.operaPasteOperation) {
window.clearInterval(this.flags.operaPasteOperation);
this.flags.operaPasteOperation = null;
}
if (e.ctrlKey) {
var pressed = Spry.Widget.Utils.getCharacterFromEvent(e);
if (pressed && 'vx'.indexOf(pressed.toLowerCase()) != -1) {
var self = this;
this.flags.operaPasteOperation = window.setInterval(function() { self.operaPasteMonitor();}, 1);
return true;
}
}
}
if (this.keyCode != 8 && this.keyCode != 46 && Spry.Widget.Utils.isSpecialKey(e)) {
return true;
}
if (this.keyCode == 8 || this.keyCode == 46 ) {
var mr = this.doValidations(this.input.value, this.input.value);
if (mr) {
return true;
}
}
//DELETE
if (this.useCharacterMasking && this.pattern && this.keyCode == 46) {
if (e.ctrlKey) {
//delete from selection until end
this.setValue(this.input.value.substring(0, this.selection.start));
} else if (this.selection.end == this.input.value.length || this.selection.start == this.input.value.length-1){
//allow key if selection is at end (will delete selection)
return true;
} else {
this.flags.operaRevertOnKeyUp = true;
}
if (Spry.is.mozilla && Spry.is.mac) {
this.flags.skp = true;
}
Spry.Widget.Utils.stopEvent(e);
return false;
}
//BACKSPACE
if (this.useCharacterMasking && this.pattern && !e.ctrlKey && this.keyCode == 8) {
if (this.selection.start == this.input.value.length) {
//delete with BACKSPACE from the end of the input value only
var n = this.getAutoComplete(this.selection.start, -1);
this.setValue(this.input.value.substring(0, this.input.value.length - (Spry.is.opera?0:1) - n.length));
if (Spry.is.opera) {
//cant stop the event on Opera, we'll just preserve the selection so delete will act on it
this.selection.start = this.selection.start - 1 - n.length;
this.selection.end = this.selection.end - 1 - n.length;
}
} else if (this.selection.end == this.input.value.length){
//allow BACKSPACE if selection is at end (will delete selection)
return true;
} else {
this.flags.operaRevertOnKeyUp = true;
}
if (Spry.is.mozilla && Spry.is.mac) {
this.flags.skp = true;
}
Spry.Widget.Utils.stopEvent(e);
return false;
}
return true;
};
Spry.Widget.ValidationTextField.prototype.onMouseDown = function(e)
{
if (this.flags.active) {
//mousedown fires before focus
//avoid double saveState on first focus by mousedown by checking if the control has focus
//do nothing if it's not focused because saveState will be called onfocus
this.saveState();
}
};
Spry.Widget.ValidationTextField.prototype.onDrop = function(e)
{
//mark that a drop operation is in progress to avoid race conditions with event handlers for other events
//especially onchange and onfocus
this.flags.drop = true;
this.removeHint();
this.saveState();
this.flags.active = true;
this.addClassName(this.element, this.focusClass);
};
Spry.Widget.ValidationTextField.prototype.onFocus = function(e)
{
if (this.flags.drop) {
return;
}
this.removeHint();
if (this.pattern && this.useCharacterMasking) {
var autocomplete = this.getAutoComplete(this.selection.start);
this.setValue(this.input.value + autocomplete);
this.selection.moveTo(this.input.value.length, this.input.value.length);
}
this.saveState();
this.flags.active = true;
this.addClassName(this.element, this.focusClass);
};
Spry.Widget.ValidationTextField.prototype.onBlur = function(e)
{
this.flags.active = false;
this.removeClassName(this.element, this.focusClass);
var mustRevert = this.doValidations(this.input.value, this.input.value);
if (this.validateOn & Spry.Widget.ValidationTextField.ONBLUR) {
this.validate();
}
var self = this;
setTimeout(function() {self.putHint();}, 10);
return true;
};
Spry.Widget.ValidationTextField.prototype.compilePattern = function() {
if (!this.pattern) {
return;
}
var compiled = [];
var regexps = [];
var patternCharacters = [];
var idx = 0;
var c = '', p = '';
for (var i=0; i<this.pattern.length; i++) {
c = this.pattern.charAt(i);
if (p == '\\') {
if (/[0ABXY\?]/i.test(c)) {
regexps[idx - 1] = c;
} else {
regexps[idx - 1] = Spry.Widget.ValidationTextField.regExpFromChars(c);
}
compiled[idx - 1] = c;
patternCharacters[idx - 1] = null;
p = '';
continue;
}
regexps[idx] = Spry.Widget.ValidationTextField.regExpFromChars(c);
if (/[0ABXY\?]/i.test(c)) {
compiled[idx] = null;
patternCharacters[idx] = c;
} else if (c == '\\') {
compiled[idx] = c;
patternCharacters[idx] = '\\';
} else {
compiled[idx] = c;
patternCharacters[idx] = null;
}
idx++;
p = c;
}
this.autoCompleteCharacters = compiled;
this.compiledPattern = regexps;
this.patternCharacters = patternCharacters;
this.patternLength = compiled.length;
};
Spry.Widget.ValidationTextField.prototype.getAutoComplete = function(from, direction) {
if (direction == -1) {
var n = '', m = '';
while(from && (n = this.getAutoComplete(--from) )) {
m = n;
}
return m;
}
var ret = '', c = '';
for (var i=from; i<this.autoCompleteCharacters.length; i++) {
c = this.autoCompleteCharacters[i];
if (c) {
ret += c;
} else {
break;
}
}
return ret;
};
Spry.Widget.ValidationTextField.regExpFromChars = function (string) {
//string contains pattern characters
var ret = '', character = '';
for (var i = 0; i<string.length; i++) {
character = string.charAt(i);
switch (character) {
case '0': ret += '\\d';break;
case 'A': ret += '[A-Z]';break;
//	case 'A': ret += '[\u0041-\u005A\u0061-\u007A\u0100-\u017E\u0180-\u0233\u0391-\u03CE\u0410-\u044F\u05D0-\u05EA\u0621-\u063A\u0641-\u064A\u0661-\u06D3\u06F1-\u06FE]';break;
case 'a': ret += '[a-z]';break;
//	case 'a': ret += '[\u0080-\u00FF]';break;
case 'B': case 'b': ret += '[a-zA-Z]';break;
case 'x': ret += '[0-9a-z]';break;
case 'X': ret += '[0-9A-Z]';break;
case 'Y': case 'y': ret += '[0-9a-zA-Z]';break;
case '?': ret += '.';break;
case '1':case '2':case '3':case '4':case '5':case '6':case '7':case '8':case '9':
ret += character;
break;
case 'c': case 'C': case 'e': case 'E': case 'f': case 'F':case 'r':case 'd': case 'D':case 'n':case 's':case 'S':case 'w':case 'W':case 't':case 'v':
ret += character;
break;
default: ret += '\\' + character;
}
}
return ret;
};
Spry.Widget.ValidationTextField.prototype.patternToRegExp = function(len) {
var ret = '^';
var end = Math.min(this.compiledPattern.length, len);
for (var i=0; i < end; i++) {
ret += this.compiledPattern[i];
}
ret += '$';
ret = new RegExp(ret, "");
return ret;
};
Spry.Widget.ValidationTextField.prototype.reset = function() {
this.removeHint();
this.oldValue = this.input.defaultValue;
this.removeClassName(this.element, this.requiredClass);
this.removeClassName(this.element, this.invalidFormatClass);
this.removeClassName(this.element, this.invalidRangeMinClass);
this.removeClassName(this.element, this.invalidRangeMaxClass);
this.removeClassName(this.element, this.invalidCharsMinClass);
this.removeClassName(this.element, this.invalidCharsMaxClass);
this.removeClassName(this.element, this.validClass);
var self = this;
setTimeout(function() {self.putHint();}, 10);
};
Spry.Widget.ValidationTextField.prototype.validate = function() {
this.removeClassName(this.element, this.requiredClass);
this.removeClassName(this.element, this.invalidFormatClass);
this.removeClassName(this.element, this.invalidRangeMinClass);
this.removeClassName(this.element, this.invalidRangeMaxClass);
this.removeClassName(this.element, this.invalidCharsMinClass);
this.removeClassName(this.element, this.invalidCharsMaxClass);
this.removeClassName(this.element, this.validClass);
//possible states: required, format, rangeMin, rangeMax, charsMin, charsMax
if (this.validateOn & Spry.Widget.ValidationTextField.ONSUBMIT) {
this.removeHint();
this.doValidations(this.input.value, this.input.value);
if(!this.flags.active) {
var self = this;
setTimeout(function() {self.putHint();}, 10);
}
}
if (this.isRequired && this.errors & Spry.Widget.ValidationTextField.ERROR_REQUIRED) {
this.addClassName(this.element, this.requiredClass);
return false;
}
if (this.errors & Spry.Widget.ValidationTextField.ERROR_FORMAT) {
this.addClassName(this.element, this.invalidFormatClass);
return false;
}
if (this.errors & Spry.Widget.ValidationTextField.ERROR_RANGE_MIN) {
this.addClassName(this.element, this.invalidRangeMinClass);
return false;
}
if (this.errors & Spry.Widget.ValidationTextField.ERROR_RANGE_MAX) {
this.addClassName(this.element, this.invalidRangeMaxClass);
return false;
}
if (this.errors & Spry.Widget.ValidationTextField.ERROR_CHARS_MIN) {
this.addClassName(this.element, this.invalidCharsMinClass);
return false;
}
if (this.errors & Spry.Widget.ValidationTextField.ERROR_CHARS_MAX) {
this.addClassName(this.element, this.invalidCharsMaxClass);
return false;
}
this.addClassName(this.element, this.validClass);
return true;
}
Spry.Widget.ValidationTextField.prototype.addClassName = function(ele, className)
{
if (!ele || !className || (ele.className && ele.className.search(new RegExp("\\b" + className + "\\b")) != -1))
return;
ele.className += (ele.className ? " " : "") + className;
};
Spry.Widget.ValidationTextField.prototype.removeClassName = function(ele, className)
{
if (!ele || !className || (ele.className && ele.className.search(new RegExp("\\b" + className + "\\b")) == -1))
return;
ele.className = ele.className.replace(new RegExp("\\s*\\b" + className + "\\b", "g"), "");
};
/**
* SelectionDescriptor is a wrapper for input type text selection methods and properties
* as implemented by various  browsers
*/
Spry.Widget.SelectionDescriptor = function (element)
{
this.element = element;
this.update();
};
Spry.Widget.SelectionDescriptor.prototype.update = function()
{
if (Spry.is.ie && Spry.is.windows) {
if (this.element.nodeName == "TEXTAREA") {
var range = this.element.ownerDocument.selection.createRange();
if (range.parentElement() == this.element){
var range_all = this.element.ownerDocument.body.createTextRange();
range_all.moveToElementText(this.element);
for (var sel_start = 0; range_all.compareEndPoints('StartToStart', range) < 0; sel_start ++){
range_all.moveStart('character', 1);
}
this.start = sel_start;
// create a selection of the whole this.element
range_all = this.element.ownerDocument.body.createTextRange();
range_all.moveToElementText(this.element);
for (var sel_end = 0; range_all.compareEndPoints('StartToEnd', range) < 0; sel_end++){
range_all.moveStart('character', 1);
}
this.end = sel_end;
this.length = this.end - this.start;
// get selected and surrounding text
this.text = range.text;
}
} else if (this.element.nodeName == "INPUT"){
this.range = this.element.ownerDocument.selection.createRange();
this.length = this.range.text.length;
var clone = this.range.duplicate();
this.start = -clone.moveStart("character", -10000);
clone = this.range.duplicate();
clone.collapse(false);
this.end = -clone.moveStart("character", -10000);
this.text = this.range.text;
}
} else {
var tmp = this.element;
var selectionStart = 0;
var selectionEnd = 0;
try { selectionStart = tmp.selectionStart;} catch(err) {}
try { selectionEnd = tmp.selectionEnd;} catch(err) {}
if (Spry.is.safari) {
if (selectionStart == 2147483647) {
selectionStart = 0;
}
if (selectionEnd == 2147483647) {
selectionEnd = 0;
}
}
this.start = selectionStart;
this.end = selectionEnd;
this.length = selectionEnd - selectionStart;
this.text = this.element.value.substring(selectionStart, selectionEnd);
}
};
Spry.Widget.SelectionDescriptor.prototype.destroy = function() {
try { delete this.range} catch(err) {}
try { delete this.element} catch(err) {}
};
Spry.Widget.SelectionDescriptor.prototype.move = function(amount)
{
if (Spry.is.ie && Spry.is.windows) {
this.range.move("character", amount);
this.range.select();
} else {
try { this.element.selectionStart++;}catch(err) {}
}
this.update();
};
Spry.Widget.SelectionDescriptor.prototype.moveTo = function(start, end)
{
if (Spry.is.ie && Spry.is.windows) {
if (this.element.nodeName == "TEXTAREA") {
var ta_range = this.element.createTextRange();
this.range = this.element.createTextRange();
this.range.move("character", start);
this.range.moveEnd("character", end - start);
var c1 = this.range.compareEndPoints("StartToStart", ta_range);
if (c1 < 0) {
this.range.setEndPoint("StartToStart", ta_range);
}
var c2 = this.range.compareEndPoints("EndToEnd", ta_range);
if (c2 > 0) {
this.range.setEndPoint("EndToEnd", ta_range);
}
} else if (this.element.nodeName == "INPUT"){
this.range = this.element.ownerDocument.selection.createRange();
this.range.move("character", -10000);
this.start = this.range.moveStart("character", start);
this.end = this.start + this.range.moveEnd("character", end - start);
}
this.range.select();
} else {
this.start = start;
try { this.element.selectionStart = start;} catch(err) {}
this.end = end;
try { this.element.selectionEnd = end;} catch(err) {}
}
this.ignore = true;
this.update();
};
Spry.Widget.SelectionDescriptor.prototype.moveEnd = function(amount)
{
if (Spry.is.ie && Spry.is.windows) {
this.range.moveEnd("character", amount);
this.range.select();
} else {
try { this.element.selectionEnd++;} catch(err) {}
}
this.update();
};
Spry.Widget.SelectionDescriptor.prototype.collapse = function(begin)
{
if (Spry.is.ie && Spry.is.windows) {
this.range = this.element.ownerDocument.selection.createRange();
this.range.collapse(begin);
this.range.select();
} else {
if (begin) {
try { this.element.selectionEnd = this.element.selectionStart;} catch(err) {}
} else {
try { this.element.selectionStart = this.element.selectionEnd;} catch(err) {}
}
}
this.update();
};
//////////////////////////////////////////////////////////////////////
//
// Spry.Widget.Form - common for all widgets
//
//////////////////////////////////////////////////////////////////////
if (!Spry.Widget.Form) Spry.Widget.Form = {};
if (!Spry.Widget.Form.onSubmitWidgetQueue) Spry.Widget.Form.onSubmitWidgetQueue = [];
if (!Spry.Widget.Form.validate) {
Spry.Widget.Form.validate = function(vform) {
var isValid = true;
var isElementValid = true;
var q = Spry.Widget.Form.onSubmitWidgetQueue;
var qlen = q.length;
for (var i = 0; i < qlen; i++) {
if (!q[i].isDisabled() && q[i].form == vform) {
isElementValid = q[i].validate();
isValid = isElementValid && isValid;
}
}
return isValid;
}
};
if (!Spry.Widget.Form.onSubmit) {
Spry.Widget.Form.onSubmit = function(e, form)
{
if (Spry.Widget.Form.validate(form) == false) {
return false;
}
return true;
};
};
if (!Spry.Widget.Form.onReset) {
Spry.Widget.Form.onReset = function(e, vform)
{
var q = Spry.Widget.Form.onSubmitWidgetQueue;
var qlen = q.length;
for (var i = 0; i < qlen; i++) {
if (!q[i].isDisabled() && q[i].form == vform && typeof(q[i].reset) == 'function') {
q[i].reset();
}
}
return true;
};
};
if (!Spry.Widget.Form.destroy) {
Spry.Widget.Form.destroy = function(form)
{
var q = Spry.Widget.Form.onSubmitWidgetQueue;
for (var i = 0; i < Spry.Widget.Form.onSubmitWidgetQueue.length; i++) {
if (q[i].form == form && typeof(q[i].destroy) == 'function') {
q[i].destroy();
i--;
}
}
}
};
if (!Spry.Widget.Form.destroyAll) {
Spry.Widget.Form.destroyAll = function()
{
var q = Spry.Widget.Form.onSubmitWidgetQueue;
for (var i = 0; i < Spry.Widget.Form.onSubmitWidgetQueue.length; i++) {
if (typeof(q[i].destroy) == 'function') {
q[i].destroy();
i--;
}
}
}
};
//////////////////////////////////////////////////////////////////////
//
// Spry.Widget.Utils
//
//////////////////////////////////////////////////////////////////////
if (!Spry.Widget.Utils)	Spry.Widget.Utils = {};
Spry.Widget.Utils.punycode_constants = {
base : 36, tmin : 1, tmax : 26, skew : 38, damp : 700,
initial_bias : 72, initial_n : 0x80, delimiter : 0x2D,
maxint : 2<<26-1
};
Spry.Widget.Utils.punycode_encode_digit = function (d) {
return String.fromCharCode(d + 22 + 75 * (d < 26));
};
Spry.Widget.Utils.punycode_adapt = function (delta, numpoints, firsttime) {
delta = firsttime ? delta / this.punycode_constants.damp : delta >> 1;
delta += delta / numpoints;
for (var k = 0; delta > ((this.punycode_constants.base - this.punycode_constants.tmin) * this.punycode_constants.tmax) / 2; k += this.punycode_constants.base) {
delta /= this.punycode_constants.base - this.punycode_constants.tmin;
}
return k + (this.punycode_constants.base - this.punycode_constants.tmin + 1) * delta / (delta + this.punycode_constants.skew);
};
/**
* returns a 	Punicode representation of a UTF-8 string
* adapted from http://tools.ietf.org/html/rfc3492
*/
Spry.Widget.Utils.punycode_encode = function (input, max_out) {
var inputc = input.split("");
input = [];
for(var i=0; i<inputc.length; i++) {
input.push(inputc[i].charCodeAt(0));
}
var output = '';
var h, b, j, m, q, k, t;
var input_len = input.length;
var n = this.punycode_constants.initial_n;
var delta = 0;
var bias = this.punycode_constants.initial_bias;
var out = 0;
for (j = 0; j < input_len; j++) {
if (input[j] < 128) {
if (max_out - out < 2) {
return false;
}
output += String.fromCharCode(input[j]);
out++;
}
}
h = b = out;
if (b > 0) {
output += String.fromCharCode(this.punycode_constants.delimiter);
out++;
}
while (h < input_len)	{
for (m = this.punycode_constants.maxint, j = 0; j < input_len; j++) {
if (input[j] >= n && input[j] < m) {
m = input[j];
}
}
if (m - n > (this.punycode_constants.maxint - delta) / (h + 1)) {
return false;
}
delta += (m - n) * (h + 1);
n = m;
for (j = 0; j < input_len; j++) {
if (input[j] < n ) {
if (++delta == 0) {
return false;
}
}
if (input[j] == n) {
for (q = delta, k = this.punycode_constants.base;; k += this.punycode_constants.base) {
if (out >= max_out) {
return false;
}
t = k <= bias ? this.punycode_constants.tmin : k >= bias + this.punycode_constants.tmax ? this.punycode_constants.tmax : k - bias;
if (q < t) {
break;
}
output += this.punycode_encode_digit(t + (q - t) % (this.punycode_constants.base - t));
out++;
q = (q - t) / (this.punycode_constants.base - t);
}
output += this.punycode_encode_digit(q);
out++;
bias = this.punycode_adapt(delta, h + 1, h == b);
delta = 0;
h++;
}
}
delta++, n++;
}
return output;
};
Spry.Widget.Utils.setOptions = function(obj, optionsObj, ignoreUndefinedProps)
{
if (!optionsObj)
return;
for (var optionName in optionsObj)
{
if (ignoreUndefinedProps && optionsObj[optionName] == undefined)
continue;
obj[optionName] = optionsObj[optionName];
}
};
Spry.Widget.Utils.firstValid = function() {
var ret = null;
for(var i=0; i<Spry.Widget.Utils.firstValid.arguments.length; i++) {
if (typeof(Spry.Widget.Utils.firstValid.arguments[i]) != 'undefined') {
ret = Spry.Widget.Utils.firstValid.arguments[i];
break;
}
}
return ret;
};
Spry.Widget.Utils.specialCharacters = ",8,9,16,17,18,20,27,33,34,35,36,37,38,40,45,144,192,63232,";
Spry.Widget.Utils.specialSafariNavKeys = "63232,63233,63234,63235,63272,63273,63275,63276,63277,63289,";
Spry.Widget.Utils.specialNotSafariCharacters = "39,46,91,92,93,";
Spry.Widget.Utils.specialCharacters += Spry.Widget.Utils.specialSafariNavKeys;
if (!Spry.is.safari) {
Spry.Widget.Utils.specialCharacters += Spry.Widget.Utils.specialNotSafariCharacters;
}
Spry.Widget.Utils.isSpecialKey = function (ev) {
return Spry.Widget.Utils.specialCharacters.indexOf("," + ev.keyCode + ",") != -1;
};
Spry.Widget.Utils.getCharacterFromEvent = function(e){
var keyDown = e.type == "keydown";
var code = null;
var character = null;
if(Spry.is.mozilla && !keyDown){
if(e.charCode){
character = String.fromCharCode(e.charCode);
} else {
code = e.keyCode;
}
} else {
code = e.keyCode || e.which;
if (code != 13) {
character = String.fromCharCode(code);
}
}
if (Spry.is.safari) {
if (keyDown) {
code = e.keyCode || e.which;
character = String.fromCharCode(code);
} else {
code = e.keyCode || e.which;
if (Spry.Widget.Utils.specialCharacters.indexOf("," + code + ",") != -1) {
character = null;
} else {
character = String.fromCharCode(code);
}
}
}
if(Spry.is.opera) {
if (Spry.Widget.Utils.specialCharacters.indexOf("," + code + ",") != -1) {
character = null;
} else {
character = String.fromCharCode(code);
}
}
return character;
};
Spry.Widget.Utils.getFirstChildWithNodeNameAtAnyLevel = function(node, nodeName)
{
var elements  = node.getElementsByTagName(nodeName);
if (elements) {
return elements[0];
}
return null;
};
Spry.Widget.Utils.getFirstParentWithNodeName = function(node, nodeName)
{
while (node.parentNode
&& node.parentNode.nodeName.toLowerCase() != nodeName.toLowerCase()
&& node.parentNode.nodeName != 'BODY') {
node = node.parentNode;
}
if (node.parentNode && node.parentNode.nodeName.toLowerCase() == nodeName.toLowerCase()) {
return node.parentNode;
} else {
return null;
}
};
Spry.Widget.Utils.destroyWidgets = function (container)
{
if (typeof container == 'string') {
container = document.getElementById(container);
}
var q = Spry.Widget.Form.onSubmitWidgetQueue;
for (var i = 0; i < Spry.Widget.Form.onSubmitWidgetQueue.length; i++) {
if (typeof(q[i].destroy) == 'function' && Spry.Widget.Utils.contains(container, q[i].element)) {
q[i].destroy();
i--;
}
}
};
Spry.Widget.Utils.contains = function (who, what)
{
if (typeof who.contains == 'object') {
return what && who && (who == what || who.contains(what));
} else {
var el = what;
while(el) {
if (el == who) {
return true;
}
el = el.parentNode;
}
return false;
}
};
Spry.Widget.Utils.addEventListener = function(element, eventType, handler, capture)
{
try
{
if (element.addEventListener)
element.addEventListener(eventType, handler, capture);
else if (element.attachEvent)
element.attachEvent("on" + eventType, handler, capture);
}
catch (e) {}
};
Spry.Widget.Utils.removeEventListener = function(element, eventType, handler, capture)
{
try
{
if (element.removeEventListener)
element.removeEventListener(eventType, handler, capture);
else if (element.detachEvent)
element.detachEvent("on" + eventType, handler, capture);
}
catch (e) {}
};
Spry.Widget.Utils.stopEvent = function(ev)
{
try
{
this.stopPropagation(ev);
this.preventDefault(ev);
}
catch (e) {}
};
/**
* Stops event propagation
* @param {Event} ev the event
*/
Spry.Widget.Utils.stopPropagation = function(ev)
{
if (ev.stopPropagation)
{
ev.stopPropagation();
}
else
{
ev.cancelBubble = true;
}
};
/**
* Prevents the default behavior of the event
* @param {Event} ev the event
*/
Spry.Widget.Utils.preventDefault = function(ev)
{
if (ev.preventDefault)
{
ev.preventDefault();
}
else
{
ev.returnValue = false;
}
};

/* Start SWF OBject Script*/
if(typeof deconcept=="undefined"){var deconcept=new Object();}
if(typeof deconcept.util=="undefined"){deconcept.util=new Object();}
if(typeof deconcept.SWFObjectUtil=="undefined"){deconcept.SWFObjectUtil=new Object();}
deconcept.SWFObject=function(_1,id,w,h,_5,c,_7,_8,_9,_a,_b){if(!document.getElementById){return;}
this.DETECT_KEY=_b?_b:"detectflash";
this.skipDetect=deconcept.util.getRequestParameter(this.DETECT_KEY);
this.params=new Object();
this.variables=new Object();
this.attributes=new Array();
if(_1){this.setAttribute("swf",_1);}
if(id){this.setAttribute("id",id);}
if(w){this.setAttribute("width",w);}
if(h){this.setAttribute("height",h);}
if(_5){this.setAttribute("version",new deconcept.PlayerVersion(_5.toString().split(".")));}
this.installedVer=deconcept.SWFObjectUtil.getPlayerVersion();
if(c){this.addParam("bgcolor",c);}
var q=_8?_8:"high";
this.addParam("quality",q);
this.setAttribute("useExpressInstall",_7);
this.setAttribute("doExpressInstall",false);
var _d=(_9)?_9:window.location;
this.setAttribute("xiRedirectUrl",_d);
this.setAttribute("redirectUrl","");
if(_a){this.setAttribute("redirectUrl",_a);}};
deconcept.SWFObject.prototype={setAttribute:function(_e,_f){
this.attributes[_e]=_f;
},getAttribute:function(_10){
return this.attributes[_10];
},addParam:function(_11,_12){
this.params[_11]=_12;
},getParams:function(){
return this.params;
},addVariable:function(_13,_14){
this.variables[_13]=_14;
},getVariable:function(_15){
return this.variables[_15];
},getVariables:function(){
return this.variables;
},getVariablePairs:function(){
var _16=new Array();
var key;
var _18=this.getVariables();
for(key in _18){_16.push(key+"="+_18[key]);}
return _16;},getSWFHTML:function(){var _19="";
if(navigator.plugins&&navigator.mimeTypes&&navigator.mimeTypes.length){
if(this.getAttribute("doExpressInstall")){
this.addVariable("MMplayerType","PlugIn");}
_19="<embed type=\"application/x-shockwave-flash\" src=\""+this.getAttribute("swf")+"\" width=\""+this.getAttribute("width")+"\" height=\""+this.getAttribute("height")+"\"";
_19+=" id=\""+this.getAttribute("id")+"\" name=\""+this.getAttribute("id")+"\" ";
var _1a=this.getParams();
for(var key in _1a){_19+=[key]+"=\""+_1a[key]+"\" ";}
var _1c=this.getVariablePairs().join("&");
if(_1c.length>0){_19+="flashvars=\""+_1c+"\"";}_19+="/>";
}else{if(this.getAttribute("doExpressInstall")){this.addVariable("MMplayerType","ActiveX");}
_19="<object id=\""+this.getAttribute("id")+"\" classid=\"clsid:D27CDB6E-AE6D-11cf-96B8-444553540000\" width=\""+this.getAttribute("width")+"\" height=\""+this.getAttribute("height")+"\">";
_19+="<param name=\"movie\" value=\""+this.getAttribute("swf")+"\" />";
var _1d=this.getParams();
for(var key in _1d){_19+="<param name=\""+key+"\" value=\""+_1d[key]+"\" />";}
var _1f=this.getVariablePairs().join("&");
if(_1f.length>0){_19+="<param name=\"flashvars\" value=\""+_1f+"\" />";}_19+="</object>";}
return _19;
},write:function(_20){
if(this.getAttribute("useExpressInstall")){
var _21=new deconcept.PlayerVersion([6,0,65]);
if(this.installedVer.versionIsValid(_21)&&!this.installedVer.versionIsValid(this.getAttribute("version"))){
this.setAttribute("doExpressInstall",true);
this.addVariable("MMredirectURL",escape(this.getAttribute("xiRedirectUrl")));
document.title=document.title.slice(0,47)+" - Flash Player Installation";
this.addVariable("MMdoctitle",document.title);}}
if(this.skipDetect||this.getAttribute("doExpressInstall")||this.installedVer.versionIsValid(this.getAttribute("version"))){
var n=(typeof _20=="string")?document.getElementById(_20):_20;
n.innerHTML=this.getSWFHTML();return true;
}else{if(this.getAttribute("redirectUrl")!=""){document.location.replace(this.getAttribute("redirectUrl"));}}
return false;}};
deconcept.SWFObjectUtil.getPlayerVersion=function(){
var _23=new deconcept.PlayerVersion([0,0,0]);
if(navigator.plugins&&navigator.mimeTypes.length){
var x=navigator.plugins["Shockwave Flash"];
if(x&&x.description){_23=new deconcept.PlayerVersion(x.description.replace(/([a-zA-Z]|\s)+/,"").replace(/(\s+r|\s+b[0-9]+)/,".").split("."));}
}else{try{var axo=new ActiveXObject("ShockwaveFlash.ShockwaveFlash.7");}
catch(e){try{var axo=new ActiveXObject("ShockwaveFlash.ShockwaveFlash.6");
_23=new deconcept.PlayerVersion([6,0,21]);axo.AllowScriptAccess="always";}
catch(e){if(_23.major==6){return _23;}}try{axo=new ActiveXObject("ShockwaveFlash.ShockwaveFlash");}
catch(e){}}if(axo!=null){_23=new deconcept.PlayerVersion(axo.GetVariable("$version").split(" ")[1].split(","));}}
return _23;};
deconcept.PlayerVersion=function(_27){
this.major=_27[0]!=null?parseInt(_27[0]):0;
this.minor=_27[1]!=null?parseInt(_27[1]):0;
this.rev=_27[2]!=null?parseInt(_27[2]):0;
};
deconcept.PlayerVersion.prototype.versionIsValid=function(fv){
if(this.major<fv.major){return false;}
if(this.major>fv.major){return true;}
if(this.minor<fv.minor){return false;}
if(this.minor>fv.minor){return true;}
if(this.rev<fv.rev){
return false;
}return true;};
deconcept.util={getRequestParameter:function(_29){
var q=document.location.search||document.location.hash;
if(q){var _2b=q.substring(1).split("&");
for(var i=0;i<_2b.length;i++){
if(_2b[i].substring(0,_2b[i].indexOf("="))==_29){
return _2b[i].substring((_2b[i].indexOf("=")+1));}}}
return "";}};
deconcept.SWFObjectUtil.cleanupSWFs=function(){if(window.opera||!document.all){return;}
var _2d=document.getElementsByTagName("OBJECT");
for(var i=0;i<_2d.length;i++){_2d[i].style.display="none";for(var x in _2d[i]){
if(typeof _2d[i][x]=="function"){_2d[i][x]=function(){};}}}};
deconcept.SWFObjectUtil.prepUnload=function(){__flash_unloadHandler=function(){};
__flash_savedUnloadHandler=function(){};
if(typeof window.onunload=="function"){
var _30=window.onunload;
window.onunload=function(){
deconcept.SWFObjectUtil.cleanupSWFs();_30();};
}else{window.onunload=deconcept.SWFObjectUtil.cleanupSWFs;}};
if(typeof window.onbeforeunload=="function"){
var oldBeforeUnload=window.onbeforeunload;
window.onbeforeunload=function(){
deconcept.SWFObjectUtil.prepUnload();
oldBeforeUnload();};
}else{window.onbeforeunload=deconcept.SWFObjectUtil.prepUnload;}
if(Array.prototype.push==null){
Array.prototype.push=function(_31){
this[this.length]=_31;
return this.length;};}
var getQueryParamValue=deconcept.util.getRequestParameter;
var FlashObject=deconcept.SWFObject;
var SWFObject=deconcept.SWFObject;
/*End SWF OBject Script*/




  function addContacts()
	{
 	var tbl = document.getElementById('refer_contacts');
 	var lastRow = tbl.rows.length;
 	if(lastRow>30)
 		{
		alert("You can add maximum of 30 Rows");
 			return;
 		}
 	var iteration = lastRow;
 	var row = tbl.insertRow(lastRow);
 	lastRow--;
 	var nameCell  = row.insertCell(0);
	var nameField  = row.insertCell(1);
	var emailCell = row.insertCell(2);
	var emailField = row.insertCell(3);


		nameCell.innerHTML= 'Name';
		emailCell.innerHTML= 'Email';
		nameCell.style.width='30px';
		nameCell.style.height='25px';
		nameCell.style.lineHeight='22px';
		nameCell.width="30px";
		nameCell.height="25px";
		emailCell.style.width='30px';
		emailCell.width="30px";
		emailCell.height="25px";
		emailCell.style.height='25px';
		emailCell.style.lineHeight='22px';

		nameCell.style.textAlign='right';
		emailCell.style.textAlign='right';

	nameField.innerHTML= '<input type="text" name="name'+lastRow+'" id="name'+lastRow+'" size="30" style="margin:0px 10px;" class="textfield">';
	emailField.innerHTML= '<input type="text" name="email'+lastRow+'" id="email'+lastRow+'" size="30" style="margin-left:10px" class="textfield">';
	nameField.width="150px";
	emailField.width="200px";
	document.getElementById('last').value=lastRow;
	}

function removeContacts()
	{
	var tbl = document.getElementById('refer_contacts');
	var lastRow = tbl.rows.length;
		if(lastRow > 2)
		{
		tbl.deleteRow(lastRow-1);
		document.getElementById('last').value=lastRow-2;
		}
		else
		alert("Can Not Remove Last Row");
	}

