/**************************************************************
   
result.php by Milfson (milf@milfcz.com) 17.04.2004

Milfson added preselect(parameters...) to pre-populate dropdowns with default values.

Thanks for the code! - Brent.
 
***************************************************************/

// constants
var noValue = '-99';
// default values
var IDMake = noValue;
var IDModel = noValue;
var IDOptions = noValue;
//selects disabled true/false
var boolEnabled = true;

// globals
var curOption = new Array();
var isLoaded = new Array();

function initLists(){
  // initialize lists
  emptyList( 'lstProvincia' );
  emptyList( 'lstLocalidad');
  emptyList( 'lstBarrio' );
  jsrsExecute( 'select_rs.php', cbFillMake, 'makeList');
}

function preselect(idMake,idModel,idOptions,selectable){
  boolEnabled = selectable;
  IDMake = idMake;
  IDModel = idModel;
  IDOptions = idOptions;
  initLists();
}

function lstProvincia_onChange(){
  var val = this.options[this.selectedIndex].value;
    IDMake = val;
//    IDModel = noValue;
//    IDOptions = noValue;
    IDModel = 1;
    IDOptions = 1;
  if(val == noValue){
    selectOption( this.name, curOption[this.name] )
  } else {
    curOption[this.name] = val;
    // init dependent lists
    emptyList( 'lstLocalidad' );
    emptyList( 'lstBarrio');
    window.status = 'Cargando Localidades...';
    jsrsExecute( 'select_rs.php', cbFillModel, 'modelList', val);
  }  
}

function lstLocalidad_onChange(){

  var val = this.options[this.selectedIndex].value;
  if(val == noValue){
    selectOption( this.name, curOption[this.name] )
  } else {
    curOption[this.name] = val;
    emptyList( 'lstBarrio');
    window.status = 'Cargando Barrios...';
    jsrsExecute( 'select_rs.php', cbFillOptions, 'optionsList', val);
  }  
}

function lstBarrio_onChange(){
  var val = this.options[this.selectedIndex].value;
  IDOptions = val;
  if(val == noValue){
    selectOption( this.name, curOption[this.name] )
  } else {
    var msg = "Seleccionó: \n\n";
    msg += this.form.lstProvincia.options[this.form.lstProvincia.selectedIndex].text + "\n";
    msg += this.form.lstLocalidad.options[this.form.lstLocalidad.selectedIndex].text + "\n";
    msg += this.options[this.selectedIndex].text + "\n";
    //alert (msg);
    
    if(boolEnabled){
    document.getElementById('cmdSubmit').disabled="";
    document.getElementById('show').style.backgroundColor="#FFCC99";
    }
    
  }
}

function cbFillMake ( strMakes ){ 
  window.status = '';
  fillList( 'lstProvincia',  strMakes ); 
  if(IDMake != noValue){
    jsrsExecute( 'select_rs.php', cbFillModel, 'modelList', ''+IDMake+'');
  }
}

function cbFillModel ( strModels ){ 
  // callback for dependent listbox
  window.status = '';
  fillList( 'lstLocalidad',  strModels ); 
  if(IDModel != noValue){
    jsrsExecute( 'select_rs.php', cbFillOptions, 'optionsList', ''+IDModel+'');
  }
}

function cbFillOptions( strOptions ){ 
  // callback for dependent listbox
  window.status = '';
  fillList( 'lstBarrio', strOptions ); 
}

function fillList( listName, strOptions ){
  // fill any list with options
  emptyList( listName );
  
  // always insert selection prompt
  var lst = document.forms['QForm'][listName];
  lst.disabled = true;
  lst.options[0] = new Option('Seleccione', noValue);
  
  // options in form "value~displaytext|value~displaytext|..."
  var aOptionPairs = strOptions.split('|');
  for( var i = 0; i < aOptionPairs.length; i++ ){
    if (aOptionPairs[i].indexOf('~') != -1) {
      var aOptions = aOptionPairs[i].split('~');
      lst.options[i + 1] = new Option(aOptions[1], aOptions[0]);
    }  
  }
  switch(listName){
  	case 'lstProvincia':
		  ID = IDMake;
		break;
  	case 'lstLocalidad':
		  ID = IDModel;
		break;
	case 'lstBarrio':
		  ID = IDOptions;
		break;
	}
  // init to no value
  selectOption( listName, ID );
  isLoaded[listName] = true;
  lst.disabled = !boolEnabled;
  lst.onchange = eval( listName + "_onChange" );
  // eval( "document.forms['QForm']['" + listName + "'].onchange=" + listName + "_onChange;" );
}

function emptyList( listName ){
  var lst = document.forms['QForm'][listName];
  lst.options.length = 0;
  lst.onchange = null;
  lst.disabled = !boolEnabled;
  isLoaded[listName] = false;
  curOption[listName] = noValue;
}

function selectOption( listName, optionVal ){
  // set list selection to option based on value
  var lst = document.forms['QForm'][listName];
  for( var i = 0; i< lst.options.length; i++ ){
    if( lst.options[i].value == optionVal ){
      lst.selectedIndex = i;
      curOption[listName] = optionVal;
      return;
    }  
  }
}


