mirror of
https://gitlab.easter-eggs.com/ee/ldapsaisie.git
synced 2024-11-30 05:34:49 +01:00
160 lines
5.2 KiB
PHP
160 lines
5.2 KiB
PHP
<?php
|
|
/*******************************************************************************
|
|
* Copyright (C) 2007 Easter-eggs
|
|
* http://ldapsaisie.labs.libre-entreprise.org
|
|
*
|
|
* Author: See AUTHORS file in top-level directory.
|
|
*
|
|
* This program is free software; you can redistribute it and/or
|
|
* modify it under the terms of the GNU General Public License version 2
|
|
* as published by the Free Software Foundation.
|
|
*
|
|
* This program is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License
|
|
* along with this program; if not, write to the Free Software
|
|
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
|
|
|
******************************************************************************/
|
|
|
|
|
|
/**
|
|
* Element select d'un formulaire pour LdapSaisie
|
|
*
|
|
* Cette classe définis les éléments select des formulaires.
|
|
* Elle étant la classe basic LSformElement.
|
|
*
|
|
* @author Benjamin Renard <brenard@easter-eggs.com>
|
|
*/
|
|
|
|
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){
|
|
$GLOBALS['LSsession'] -> addCssFile('LSformElement_select_object.css');
|
|
if ($refresh) {
|
|
$this -> values = $this -> getValuesFromSession();
|
|
}
|
|
$return = $this -> getLabelInfos();
|
|
|
|
if (!$this -> isFreeze()) {
|
|
$GLOBALS['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')
|
|
)
|
|
);
|
|
|
|
$GLOBALS['LSsession'] -> addHelpInfos (
|
|
'LSformElement_select_object',
|
|
array(
|
|
'searchAdd' => _("Ajout rapide"),
|
|
'add' => _("Afficher le module de recherche avancée et de sélection."),
|
|
'delete' => _("Supprimer")
|
|
)
|
|
);
|
|
|
|
$GLOBALS['LSsession'] -> addJSscript('LSformElement_select_object_field.js');
|
|
$GLOBALS['LSsession'] -> addJSscript('LSformElement_select_object.js');
|
|
$GLOBALS['LSsession'] -> addJSscript('LSform.js');
|
|
$GLOBALS['LSsession'] -> addJSscript('LSselect.js');
|
|
$GLOBALS['LSsession'] -> addCssFile('LSselect.css');
|
|
$GLOBALS['LSsession'] -> addJSscript('LSsmoothbox.js');
|
|
$GLOBALS['LSsession'] -> addCssFile('LSsmoothbox.css');
|
|
$GLOBALS['LSsession'] -> addJSscript('LSconfirmBox.js');
|
|
$GLOBALS['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 <brenard@easter-eggs.com>
|
|
*
|
|
* @param[in] [<b>required</b>] 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 -> displayValue) Les objets trouvés
|
|
*/
|
|
function searchAdd ($pattern) {
|
|
if (is_array($this -> params['selectable_object'])) {
|
|
if ($GLOBALS['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;
|
|
}
|
|
}
|
|
else {
|
|
$GLOBALS['LSerror'] -> addErrorCode(1004,$this -> params['selectable_object']['object_type']);
|
|
}
|
|
}
|
|
return array();
|
|
}
|
|
}
|
|
|
|
?>
|