Subversion Repositories Applications.papyrus

Rev

Details | Last modification | View Log | RSS feed

Rev Author Line No. Line
562 ddelon 1
<?php
448 ddelon 2
/*vim: set expandtab tabstop=4 shiftwidth=4: */
3
// +------------------------------------------------------------------------------------------------------+
4
// | PHP version 4.1                                                                                      |
5
// +------------------------------------------------------------------------------------------------------+
6
// | Copyright (C) 2004 Tela Botanica (accueil@tela-botanica.org)                                         |
7
// +------------------------------------------------------------------------------------------------------+
8
// | This library is free software; you can redistribute it and/or                                        |
9
// | modify it under the terms of the GNU General Public                                                  |
10
// | License as published by the Free Software Foundation; either                                         |
11
// | version 2.1 of the License, or (at your option) any later version.                                   |
12
// |                                                                                                      |
13
// | This library is distributed in the hope that it will be useful,                                      |
14
// | but WITHOUT ANY WARRANTY; without even the implied warranty of                                       |
15
// | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU                                    |
16
// | General Public License for more details.                                                             |
17
// |                                                                                                      |
18
// | You should have received a copy of the GNU General Public                                            |
19
// | License along with this library; if not, write to the Free Software                                  |
20
// | Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA                            |
21
// +------------------------------------------------------------------------------------------------------+
1859 alexandre_ 22
// CVS : $Id: participants.php,v 1.8 2008-08-25 15:02:49 alexandre_tb Exp $
448 ddelon 23
/**
24
* Application projet
25
*
26
* Action participants
27
*
28
*@package projet
29
//Auteur original :
30
*@author        Alexandre Granier <alexandre@tela-botanica.org>
31
//Autres auteurs :
32
*@author        Aucun
33
*@copyright     Tela-Botanica 2000-2005
1859 alexandre_ 34
*@version       $Revision: 1.8 $
448 ddelon 35
// +------------------------------------------------------------------------------------------------------+
36
*/
37
 
38
// +------------------------------------------------------------------------------------------------------+
39
// |                                            ENTETE du PROGRAMME                                       |
40
// +------------------------------------------------------------------------------------------------------+
41
 
42
// RAPPEL IMPORTANT
1859 alexandre_ 43
// On se situe dans la methode run() de la classe projetControleur
448 ddelon 44
//
45
 
562 ddelon 46
include_once PROJET_CHEMIN_CLASSES.'HTML_listeParticipants.class.php' ;
474 alexandre_ 47
 
448 ddelon 48
$res = '' ;
1859 alexandre_ 49
$pair = true;
50
$loggue = $this->_auth->getAuth();
51
$url = $this->_url->getURL();
52
 
1336 neiluj 53
include_once PROJET_CHEMIN_CLASSES.'participe.class.php' ;
54
include_once PROJET_CHEMIN_CLASSES.'projet.class.php' ;
448 ddelon 55
$projet = new projet ($this->_db, $this->_id_projet) ;
1859 alexandre_ 56
//$retour .= '<h1>'.PROJET_PROJET.' : '.$projet->getTitre()."</h1>" ;
448 ddelon 57
$titre = '<h2>'.PROJET_LISTE_PARTICIPANT.'</h2>'."\n" ;
58
$participants = new participe($this->_db) ;
59
 
1471 alexandre_ 60
// On teste ici s'il y a une mise a jour de statut
448 ddelon 61
if (isset($_REQUEST['statut'])) {
62
    $participants->setStatut($_REQUEST['statut'], $_GET['id_utilisateur'], $this->_id_projet) ;
63
    $projet->getListesAssociees() ;
64
    if ($projet->avoirListe()) {
65
        include_once PROJET_CHEMIN_CLASSES.'annuaire.class.php' ;
66
        $annuaire = new annuaire($this->_db, array('identifiant' => PROJET_CHAMPS_ID, 'mail' => PROJET_CHAMPS_MAIL, 'table' => PROJET_ANNUAIRE)) ;
67
        $annuaire->setId($_GET['id_utilisateur']) ;
68
        include_once PROJET_CHEMIN_CLASSES.'inscription_liste.class.php' ;
69
        $desinscription= new inscription_liste($this->_db) ;
70
        $desinscription->desinscrireUtilisateur($annuaire, $projet->_listes_associes[0]) ;
71
    }
72
}
1859 alexandre_ 73
// On teste ici s'il y a une mise a jour de l inscription a la liste
74
if (isset($_POST['inscription_liste'])) {
75
    $projet->getListesAssociees();
76
    include_once PROJET_CHEMIN_CLASSES.'annuaire.class.php' ;
77
    $annuaire = new annuaire($this->_db, array('identifiant' => PROJET_CHAMPS_ID, 'mail' => PROJET_CHAMPS_MAIL, 'table' => PROJET_ANNUAIRE)) ;
78
    $annuaire->setId($_GET['id_utilisateur']) ;
79
    include_once PROJET_CHEMIN_CLASSES.'inscription_liste.class.php' ;
80
    $inscription= new inscription_liste($this->_db) ;
81
    if ($_POST['inscription_liste'] == 1) {
82
    	$inscription->inscrireUtilisateur($annuaire, $projet->_listes_associes[0], 2) ; // 2 est le statut d inscription normale
83
    } else {
84
    	$inscription->desinscrireUtilisateur($annuaire, $projet->_listes_associes[0]) ;
85
    }
86
}
1471 alexandre_ 87
// Ce qui suit doit etre ameliore pour sortir la requete sur l'annuaire
448 ddelon 88
// On teste s'il y a un ajout d'utilisateur voir HTML_listeParticipants
89
if (isset($_POST['mail_utilisateur'])) {
90
    $requete = 'select '.PROJET_CHAMPS_ID.' from '.PROJET_ANNUAIRE.' where '.PROJET_CHAMPS_MAIL.'="'.$_POST['mail_utilisateur'].'"';
91
    $resultat = $this->_db->query ($requete) ;
92
    if (DB::isError ($resultat)) {
93
        die ('Echec de la requete : '.$requete.'<br />'.$resultat->getMessage()) ;
94
    }
95
    if (!$resultat->numRows()) {
96
        $msg = PROJET_MAIL_ABSENT;
97
    } else {
98
        $ligne = $resultat->fetchRow(DB_FETCHMODE_ASSOC) ;
99
        // Le statut 2 est le statut participant
1859 alexandre_ 100
 
448 ddelon 101
        $participants->setStatut(2, $ligne[PROJET_CHAMPS_ID], $this->_id_projet) ;
102
    }
103
}
104
 
105
if ($this->_auth->getAuth()) {
106
    $statut = participe::getStatutSurProjetCourant($this->_auth->getAuthData(PROJET_CHAMPS_ID),  $this->_id_projet, $this->_db) ;
1471 alexandre_ 107
    if ($statut == 1) $droits = PROJET_DROIT_COORDINATEUR ;
448 ddelon 108
    if ($statut == 2) $droits = PROJET_DROIT_CONTRIBUTEUR ;
1471 alexandre_ 109
    if ($statut == 3) $droits = PROJET_DROIT_EN_ATTENTE;
1859 alexandre_ 110
    if ($statut == 4) {
111
    	$droits = PROJET_DROIT_AUCUN ;
112
    	$this->_url->addQueryString(PROJET_VARIABLE_ACTION, PROJET_ACTION_S_INSCRIRE);
113
    	$lien_inscription = $this->_url->getURL();
114
		$label_url_inscription = 'S\'inscrire &agrave; ce projet';
115
    }
448 ddelon 116
    if (participe::isAdministrateur($this->_auth->getAuthData(PROJET_CHAMPS_ID), $this->_db)) $droits = PROJET_DROIT_ADMINISTRATEUR  ;
1859 alexandre_ 117
 
118
    if ($droits <= PROJET_DROIT_COORDINATEUR || participe::isAdministrateur($this->_auth->getAuthData(PROJET_CHAMPS_ID), $this->_db)) {
119
 
120
        $res = PROJET_NOUVEAU_UTILISATEUR_LAIUS ;
121
        $res .= '<form action="'.$this->_url->getURL().'" method="post">'."\n" ;
122
        if (isset ($msg) && $msg != '') {
123
            $res .= '<div>'.$msg.'</div>' ;
124
        }
125
        $res .= '<input type="text" name="mail_utilisateur" size="32" />' ;
126
        $res .= '<input type="submit" value="'.PROJET_NOUVEAU_UTILISATEUR.'" />'."\n" ;
127
        $res .= '</form><br />'."\n" ;
128
    }
129
 
448 ddelon 130
    $HTML_listeParticipants = new HTML_listeParticipants(true) ;
131
    if ($droits <= PROJET_DROIT_COORDINATEUR) $HTML_listeParticipants->setModeModification() ;
132
    // Mise en place de l'url
133
    $this->_url->addQueryString (PROJET_VARIABLE_ACTION, PROJET_ACTION_VOIR_PARTICIPANT) ;
134
    $HTML_listeParticipants->setURL($this->_url) ;
135
    // Construction de l'entete
1471 alexandre_ 136
    $entete = array (PROJET_NOM, PROJET_PRENOM, PROJET_MAIL, PROJET_DATE_INSCRIPTION, PROJET_STATUT) ;
1859 alexandre_ 137
	if ($projet->avoirListe() && $droits <= PROJET_DROIT_CONTRIBUTEUR) array_push ($entete, PROJET_LISTE_DE_DISCUSSION);
1471 alexandre_ 138
    $info_utilisateur = $participants->getInscrits($this->_id_projet, $droits);
1859 alexandre_ 139
	$nombre_participants = count ($info_utilisateur);
448 ddelon 140
    $HTML_listeParticipants->construitEntete($entete) ;
1471 alexandre_ 141
    include_once PROJET_CHEMIN_CLASSES.'statut.class.php' ;
1859 alexandre_ 142
 
1471 alexandre_ 143
    if ($projet->avoirListe()) {
1859 alexandre_ 144
    	/** recuperation des abonnees a la liste */
145
    	include_once PROJET_CHEMIN_CLASSES.'ezmlmAccessObject.class.php';
146
 
147
    	$ezmlm = new ezmlmAccessObject('liste_abonnes', $projet->_listes_associes[0]->getDomaine(),
1471 alexandre_ 148
    			 $projet->_listes_associes[0]->getNom());
1859 alexandre_ 149
    	$ezmlm->load();
150
    	ob_start();
151
    	$tableau_mail = $ezmlm->parse();
152
    	$xml = ob_get_contents();
153
    	ob_end_clean();
154
    	for ($i = 0; $i < count ($info_utilisateur); $i++) {
155
    		$tableau_mail_utilisateur[$info_utilisateur[$i][3]] = $i;
156
    		$info_utilisateur[$i][6] = 0;  // Initialisation du tableau avec la valeur 0
157
    	}
158
 
159
    	foreach ($tableau_mail->children() as $email) {
160
    		$email = (string) $email;
161
    		if (isset($tableau_mail_utilisateur[$email])) {
162
    			$id = (int) $tableau_mail_utilisateur[$email];
163
    			$info_utilisateur[$id][6] = 1;
164
    		}
165
    	}
166
    	//trigger_error(print_r ($info_utilisateur, true));
167
 
1471 alexandre_ 168
    }
1859 alexandre_ 169
    $statuts = statut::getTousLesStatuts(PROJET_STATUT_SAUF_ADM, $this->_db);
170
    $statuts_inscription_liste[0] = 'non inscrit';
171
    $statuts_inscription_liste[1] = 'inscrit';
1471 alexandre_ 172
    $HTML_listeParticipants->construitListe($info_utilisateur, statut::getTousLesStatuts(PROJET_STATUT_SAUF_ADM, $this->_db), $projet) ;
448 ddelon 173
 
1859 alexandre_ 174
    $res .= $HTML_listeParticipants->toHTML() ;
448 ddelon 175
 
1859 alexandre_ 176
 
448 ddelon 177
} else {
1859 alexandre_ 178
    $droits = PROJET_DROIT_AUCUN ;
179
    GEN_stockerFichierScript('jquery', 'api/js/jquery/jquery.js');
180
	GEN_stockerFichierScript('animatedcollapse', 'api/js/jquery/animatedcollapse.js');
181
	GEN_stockerCodeScript('animatedcollapse.addDiv(\'projet_bloc_inscription\', \'fade=1, height="100px"\');' ."\n".
182
			'animatedcollapse.init();' ."\n");
183
	$lien_login = '#';
184
	$label_url_inscription = 'S\'inscrire &agrave; ce projet';
185
	$lien_inscription = 'javascript:animatedcollapse.toggle(\'projet_bloc_inscription\');';
448 ddelon 186
}
187
 
1859 alexandre_ 188
$GLOBALS['_PAPYRUS_']['rendu']['TITRE_PAGE'] = $projet->getTitre().' - '.PROJET_LISTE_PARTICIPANT;
189
//$retour .= $titre.$res.$xml; ;
448 ddelon 190
 
1859 alexandre_ 191
 
192
 
193
ob_start();
194
include_once PROJET_CHEMIN_APPLI.'/squelettes/participants.tpl.html';
195
$retour .= ob_get_contents();
196
ob_end_clean();
197
 
198
 
199
$this->_url->removeQueryString ('statut');
200
$this->_url->removeQueryString ('id_utilisateur');
201
$this->_url->addQueryString (PROJET_VARIABLE_ACTION, PROJET_ACTION_VOIR_PARTICIPANT) ;
202
$GLOBALS['url']->addQueryString (PROJET_VARIABLE_ACTION, PROJET_ACTION_VOIR_PARTICIPANT) ;
203
 
204
 
205
/* +--Fin du code ----------------------------------------------------------------------------------------+
206
*
207
* $Log: not supported by cvs2svn $
208
*
209
* +-- Fin du code ----------------------------------------------------------------------------------------+
210
*/
448 ddelon 211
?>