*/ class LSformElement_select_object extends LSformElement { var $fieldTemplate = 'LSformElement_select_object_field.tpl'; var $template = 'LSformElement_select_object.tpl'; /** * Retourn les infos d'affichage de l'élément * * Cette méthode retourne les informations d'affichage de l'élement * * @retval array */ function getDisplay($refresh=NULL){ LSsession :: addCssFile('LSformElement_select_object.css'); if ($refresh) { $this -> values = $this -> getValuesFromSession(); } $return = $this -> getLabelInfos(); if (!$this -> isFreeze()) { LSsession :: addJSconfigParam( $this -> name, array( 'object_type' => $this -> selectableObject, 'addBtn' => _('Modifier'), 'deleteBtns' => _('Supprimer'), 'multiple' => (($this -> params['multiple'])?1:0), 'noValueLabel' => _('Aucune valeur definie'), 'noResultLabel' => _('Aucun résultat') ) ); LSsession :: addHelpInfos ( 'LSformElement_select_object', array( 'searchAdd' => _("Ajout rapide"), 'add' => _("Afficher le module de recherche avancée et de sélection."), 'delete' => _("Supprimer") ) ); LSsession :: addJSscript('LSformElement_select_object_field.js'); LSsession :: addJSscript('LSformElement_select_object.js'); LSsession :: addJSscript('LSform.js'); LSsession :: addJSscript('LSselect.js'); LSsession :: addCssFile('LSselect.css'); LSsession :: addJSscript('LSsmoothbox.js'); LSsession :: addCssFile('LSsmoothbox.css'); LSsession :: addJSscript('LSconfirmBox.js'); LSsession :: addCssFile('LSconfirmBox.css'); } $return['html'] = $this -> fetchTemplate(NULL,array('selectableObject' => $this -> selectableObject)); return $return; } /* * Retourne les valeurs de l'objet à partir de la variable Session */ function getValuesFromSession() { return $this -> attr_html -> getValuesFromSession(); } /** * Défini le type d'objet sélectionnable * * @param[in] $object string Le type d'object * * @retval void **/ function setSelectableObject($object) { $this -> selectableObject = $object; } /** * Exporte les valeurs de l'élément * * @retval Array Les valeurs de l'élement */ function exportValues(){ $values = $this -> attr_html -> getValuesFromFormValues($this -> values); return $values; } /** * Définis la valeur de l'élément à partir des données * envoyées en POST du formulaire * * Cette méthode définis la valeur de l'élément à partir des données * envoyées en POST du formulaire. * * @author Benjamin Renard * * @param[in] [required] string or array La futur valeur de l'élément * * @retval boolean Retourne True */ function setValueFromPostData($data) { LSformElement::setValueFromPostData($data); $this -> values = $this -> attr_html -> refreshForm($this -> values,true); return true; } /** * Recherche les objets sélectionnables à partir du pattern fournis * * @param[in] $pattern Pattern de recherche * * @retval array(dn -> displayName) Les objets trouvés */ function searchAdd ($pattern) { if (is_array($this -> params['selectable_object'])) { if (LSsession :: loadLSobject($this -> params['selectable_object']['object_type'])) { $obj = new $this -> params['selectable_object']['object_type'](); $ret = $obj -> getSelectArray($pattern,NULL,$this -> params['selectable_object']['display_attribute']); if (is_array($ret)) { return $ret; } } } return array(); } } ?>