function validatePrompt (Ctrl, PromptStr) {alert (PromptStr)
        Ctrl.focus(); return;}
		
function testMail(form) {
        Ctrl = form.email;
        if (Ctrl.value.search(/[a-z0-9_.-A-Z]*@[a-z-]{3,}[.][a-z]{2,}/)==-1){
				validatePrompt (Ctrl, "Entrez un e-mail valide !!")
                return (false);} else return (true);}

function testNom(form) { Ctrl = form.nom;
        if (Ctrl.value.search(/[a-z-A-Z]{4,}/)==-1) {validatePrompt (Ctrl, "Mettez votre nom !!")
                return (false);}
       else return (true);}

function testTel(form) {
        Ctrl = form.tel; if (Ctrl.value.search(/[0-9]{10,}/)==-1) {
                validatePrompt (Ctrl, "Mettez votre numéro de telephonne !!")
                return (false);} else return (true);}

function testUrl(form) {
        Ctrl = form.url; if (Ctrl.value.search(/[http:]\/\/[a-z0-9_.-A-Z]{4,}/)==-1) {
                validatePrompt (Ctrl, "L'Url doit être préfixé de http://  et doit contenir au moins 4 caractères!!")
                return (false);} else return (true);}
function testTexte(form) { Ctrl = form.texte;
        if (Ctrl.value.search(/[a-z-A-Z]{4,}/)==-1) {validatePrompt (Ctrl, "Vous devez taper un message !!")
                return (false);}
       else return (true);}
function testSujet(form) { Ctrl = form.sujet;
        if (Ctrl.value.search(/[a-z-A-Z]{4,}/)==-1) {validatePrompt (Ctrl, "Vous devez taper un sujet !!")
                return (false);}
       else return (true);}
function testProvenance(form) {
        Ctrl = form.siteAppellant;
        if (Ctrl.value=='0'){
				validatePrompt (Ctrl, "Selectionnez un site!!")
                return (false);} else return (true);}	   

function testChecked(form)
{ var aumoins=0;
    for (i = 0; i < form.elements.length; i++) {
        if (document.form.elements[i].checked) aumoins++;
    }
	if (aumoins>0){document.form.nbCasino.value=aumoins;
	return true;}
	else{		alert("Veuillez selectionner au moins un élément.");
	 	return false;}
}
function testCheckedBanniere(form)
{ var aumoins=0;
    for (i = 0; i < form.elements.length; i++) {
        if (document.form.elements[i].checked) aumoins++;
    }
	if (aumoins>0){document.form.nbBanniere.value=aumoins;
	return true;}
	else{		alert("Veuillez selectionner au moins un élément.");
	 	return false;}
}

function submitSansTest (form,val)  {  	  
document.form.actionSupprime.value=val;
       form.submit();
	  }	   
	   				
function runSubmit (form)  { 
 	  if (!testMail(form)) return;
       form.submit();
	  }
function submitPartenaire (form)  { 
 	  if (!testNom(form)) return;
	  if (!testUrl(form)) return;
	  if (!testMail(form)) return;
       form.submit();
	  }	  
function submitContact (form)  {  	 
	  if (!testTexte(form)) return;
	  if (!testMail(form)) return;
       form.submit();
	  }	
	  
function submitAfficheBanniere (form)  {  	
       form.submit();
	  }		   	  
function submitNewsLetter (form)  {  
	  //if (!testChecked(form)) return;	 
	  if (!testProvenance(form)) return;	 
	  if (!testSujet(form)) return;	 
	  if (!testTexte(form)) return;	 
       form.submit();
	  }
function submitdeleteBanniere (form)  {  
	  if (!testCheckedBanniere(form)) return;	 
       form.submit();
	  }	  		   	  
function submitinsertBanniere (form)  {  
	  //if (!testCheckedBanniere(form)) return;	 
	  var aumoins=0;
    for (i = 0; i < document.form.elements.length; i++) {
        if (document.form.elements[i].checked) aumoins++;
    }
	if (aumoins>0){document.form.nbBanniere.value=aumoins;
	form.submit();}
	else{		alert("Veuillez selectionner au moins un élément.");
	 	return false;}
       
	  }	  	  

	  var marked_row = new Array;
	  function setPointer(theRow, theRowNum, theAction, theDefaultColor, thePointerColor, theMarkColor)
{
    var theCells = null;

    // 1. Pointer and mark feature are disabled or the browser can't get the
    //    row -> exits
    if ((thePointerColor == '' && theMarkColor == '')
        || typeof(theRow.style) == 'undefined') {
        return false;
    }

    // 2. Gets the current row and exits if the browser can't get it
    if (typeof(document.getElementsByTagName) != 'undefined') {
        theCells = theRow.getElementsByTagName('td');
    }
    else if (typeof(theRow.cells) != 'undefined') {
        theCells = theRow.cells;
    }
    else {
        return false;
    }

    // 3. Gets the current color...
    var rowCellsCnt  = theCells.length;
    var domDetect    = null;
    var currentColor = null;
    var newColor     = null;
    // 3.1 ... with DOM compatible browsers except Opera that does not return
    //         valid values with "getAttribute"
    if (typeof(window.opera) == 'undefined'
        && typeof(theCells[0].getAttribute) != 'undefined') {
        currentColor = theCells[0].getAttribute('bgcolor');
        domDetect    = true;
    }
    // 3.2 ... with other browsers
    else {
        currentColor = theCells[0].style.backgroundColor;
        domDetect    = false;
    } // end 3

    // 3.3 ... Opera changes colors set via HTML to rgb(r,g,b) format so fix it
    if (currentColor.indexOf("rgb") >= 0)
    {
        var rgbStr = currentColor.slice(currentColor.indexOf('(') + 1,
                                     currentColor.indexOf(')'));
        var rgbValues = rgbStr.split(",");
        currentColor = "#";
        var hexChars = "0123456789ABCDEF";
        for (var i = 0; i < 3; i++)
        {
            var v = rgbValues[i].valueOf();
            currentColor += hexChars.charAt(v/16) + hexChars.charAt(v%16);
        }
    }

    // 4. Defines the new color
    // 4.1 Current color is the default one
    if (currentColor == ''
        || currentColor.toLowerCase() == theDefaultColor.toLowerCase()) {
        if (theAction == 'over' && thePointerColor != '') {
            newColor              = thePointerColor;
        }
        else if (theAction == 'click' && theMarkColor != '') {
            newColor              = theMarkColor;
            marked_row[theRowNum] = true;
            // Garvin: deactivated onclick marking of the checkbox because it's also executed
            // when an action (like edit/delete) on a single item is performed. Then the checkbox
            // would get deactived, even though we need it activated. Maybe there is a way
            // to detect if the row was clicked, and not an item therein...
            // document.getElementById('id_rows_to_delete' + theRowNum).checked = true;
        }
    }
    // 4.1.2 Current color is the pointer one
    else if (currentColor.toLowerCase() == thePointerColor.toLowerCase()
             && (typeof(marked_row[theRowNum]) == 'undefined' || !marked_row[theRowNum])) {
        if (theAction == 'out') {
            newColor              = theDefaultColor;
        }
        else if (theAction == 'click' && theMarkColor != '') {
            newColor              = theMarkColor;
            marked_row[theRowNum] = true;
            // document.getElementById('id_rows_to_delete' + theRowNum).checked = true;
        }
    }
    // 4.1.3 Current color is the marker one
    else if (currentColor.toLowerCase() == theMarkColor.toLowerCase()) {
        if (theAction == 'click') {
            newColor              = (thePointerColor != '')
                                  ? thePointerColor
                                  : theDefaultColor;
            marked_row[theRowNum] = (typeof(marked_row[theRowNum]) == 'undefined' || !marked_row[theRowNum])
                                  ? true
                                  : null;
            // document.getElementById('id_rows_to_delete' + theRowNum).checked = false;
        }
    } // end 4

    // 5. Sets the new color...
    if (newColor) {
        var c = null;
        // 5.1 ... with DOM compatible browsers except Opera
        if (domDetect) {
            for (c = 0; c < rowCellsCnt; c++) {
                theCells[c].setAttribute('bgcolor', newColor, 0);
            } // end for
        }
        // 5.2 ... with other browsers
        else {
            for (c = 0; c < rowCellsCnt; c++) {
                theCells[c].style.backgroundColor = newColor;
            }
        }
    } // end 5

    return true;
} // end of the 'setPointer()' function

