*/ class LSattr_html_select_list extends LSattr_html{ function addToForm (&$form,$idForm) { return $form -> addElement('select', $this -> name, $this -> config['label'],$this -> getPossibleValues()); } /** * Retourne un tableau des valeurs possibles de la liste * * @author Benjamin Renard * * @retval array Tableau associatif des valeurs possible de la liste avec en clé * la valeur des balises option et en valeur ce qui sera affiché. */ function getPossibleValues() { $retInfos = array(); if (isset($this -> config['possible_values'])) { foreach($this -> config['possible_values'] as $val_name => $val) { if($val_name=='OTHER_OBJECT') { //~ print_r($val); if ((!isset($val['object_type'])) || (!isset($val['value_attribute']))) { $GLOBALS['LSerror'] -> addErrorCode(102,$this -> name); break; } $obj = new $val['object_type'](); if($val['scope']) { $param=array('scope' => $this -> config['possible_values']['scope']); } else { $param=array(); } $list = $obj -> listObjects($val['filter'],$this -> config['possible_values']['basedn'],$param); if(($val['value_attribute']=='dn')||($val['value_attribute']=='%{dn}')) { for($i=0;$i dn]=$list[$i] -> getDisplayValue($val['display_attribute']); } } else { for($i=0;$i attrs[$val['value_attribute']] -> getValue()]=$list[$i] -> getDisplayValue($val['display_attribute']); } } } else { $retInfos[$val_name]=$val; } } } return $retInfos; } } ?>