/trunk/client/integrateur_wikini/bibliotheque/iw_admin_wikini.fonct.php |
---|
New file |
0,0 → 1,227 |
<?php |
/*vim: set expandtab tabstop=4 shiftwidth=4: */ |
// +------------------------------------------------------------------------------------------------------+ |
// | PHP version 4.1 | |
// +------------------------------------------------------------------------------------------------------+ |
// | Copyright (C) 2004 Tela Botanica (accueil@tela-botanica.org) | |
// +------------------------------------------------------------------------------------------------------+ |
// | This library is free software; you can redistribute it and/or | |
// | modify it under the terms of the GNU Lesser General Public | |
// | License as published by the Free Software Foundation; either | |
// | version 2.1 of the License, or (at your option) any later version. | |
// | | |
// | This library 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 | |
// | Lesser General Public License for more details. | |
// | | |
// | You should have received a copy of the GNU Lesser General Public | |
// | License along with this library; if not, write to the Free Software | |
// | Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA | |
// +------------------------------------------------------------------------------------------------------+ |
// CVS : $Id: iw_admin_wikini.fonct.php,v 1.1 2005-11-14 10:14:30 ddelon Exp $ |
/** |
* Application gérant les Wikini associe à Papyrus |
* |
* Cette application permet de gérer les parametre des wikini associés à l'ensemble d'un papyrus |
* TODO : Gestion mise a jour wakka.config.php !!!!! |
* TODO : afficher les utilisations par les menus. |
* TODO : synchronisation FTP ? .... : creation, suppression, liste (renommer ???) |
* TODO : chemin vers le wikini ... (non, calcul en fonction du code alpha) , mais controles ? Pas dans un |
* premier temps ... |
* TODO : installation des wikini (tables présentes etc, et gestion ... (suppression ...) |
* TODO : un wiki par défaut pour chaque papyrus, ce wiki sert de modèle |
* |
*@package Admin_Wikini |
//Auteur original : |
*@author David Delon <david.delon@clapas.net> |
*@copyright Tela-Botanica 2000-2005 |
*@version $Revision: 1.1 $ |
// +------------------------------------------------------------------------------------------------------+ |
*/ |
// +------------------------------------------------------------------------------------------------------+ |
// | ENTÊTE du PROGRAMME | |
// +------------------------------------------------------------------------------------------------------+ |
/** Inclusion du fichier de configuration de cette application.*/ |
require_once 'client/integrateur_wikini/configuration/adwi_configuration.inc.php'; |
//Utilisation de la bibliothèque PEAR NET_URL |
/** Inclusion de la bibliothèque PEAR de conception de formulaire.*/ |
require_once ADWI_CHEMIN_BIBLIOTHEQUE_PEAR.'HTML/QuickForm.php'; |
require_once ADWI_CHEMIN_BIBLIOTHEQUE_PEAR.'HTML/QuickForm/select.php'; |
/** Inclusion de l'API de fonctions gérant les erreurs sql.*/ |
require_once ADWI_CHEMIN_BIBLIOTHEQUE_API.'debogage/BOG_sql.fonct.php'; |
/** Inclusion des fonctions de manipulation du sql. |
* Permet la récupération d'un nouvel identifiant d'une table.*/ |
require_once ADWI_CHEMIN_BIBLIOTHEQUE_API.'sql/SQL_manipulation.fonct.php'; |
require_once ADWI_CHEMIN_BIBLIOTHEQUE_API.'html/HTML_TableFragmenteur.php' ; |
require_once ADWI_CHEMIN_BIBLIOTHEQUE.'adwi_wikini.fonct.php'; |
require_once ADWI_CHEMIN_BIBLIOTHEQUE.'adwi_HTML_formulaireWikini.class.php' ; |
// Inclusion des fichiers de traduction de l'appli ADME dePapyrus |
if (file_exists(ADWI_CHEMIN_LANGUE.'adwi_langue_'.$GLOBALS['_GEN_commun']['i18n'].'.inc.php')) { |
/** Inclusion du fichier de traduction suite à la transaction avec le navigateur.*/ |
require_once ADWI_CHEMIN_LANGUE.'adwi_langue_'.$GLOBALS['_GEN_commun']['i18n'].'.inc.php'; |
} else { |
/** Inclusion du fichier de traduction par défaut.*/ |
require_once ADWI_CHEMIN_LANGUE.'adwi_langue_'.ADWI_I18N_DEFAUT.'.inc.php'; |
} |
// +------------------------------------------------------------------------------------------------------+ |
// | CORPS du PROGRAMME | |
// +------------------------------------------------------------------------------------------------------+ |
function admin_afficherContenuCorpsHTML() { |
return admin_afficherContenuCorps(); |
} |
function admin_afficherContenuCorps() |
{ |
/* Gestion de Deux "écrans" et des actions associées : liste des Wikini en base de donnees et ajout-modification |
* d'un Wikini |
*/ |
$db = &$GLOBALS['_GEN_commun']['pear_db'] ; |
$url = $GLOBALS['_GEN_commun']['url'] ; |
$auth = &$GLOBALS['_GEN_commun']['pear_auth'] ; |
isset ($GLOBALS['action']) ? '' : $GLOBALS['action'] = '' ; // On déclare action si elle n'existe pas |
if (!$auth->getAuth()) { |
return 'Identifiez-vous' ; |
} |
// Le lien pour une nouvelle entrée |
$res = '<a href="'.$url->getURL().'&action=nouveau">'.ADWI_AJOUTER.'</a>'."\n<br />" ; |
// traitement de la suppression |
if (isset ($GLOBALS['action']) && $GLOBALS['action'] == 'supprimer') adwi_supprimer_wikini($GLOBALS['id_wikini'], $db) ; |
// traitement de l'ajout et de la modification de la ligne selectionnée |
if (isset ($GLOBALS['action']) || isset ($GLOBALS['id_wikini'])) { |
$formulaire = new HTML_formulaireWikini('formulaire_wikini', '', str_replace ('&', '&', $url->getURL())) ; |
$formulaire->construitFormulaire($url) ; |
// C'est une demande d'ajout : Affichage du masque de saisie et ajout d'un champs caché avec action=nouveau_v |
if ($GLOBALS['action'] == 'nouveau') { |
$formulaire->addElement ('hidden', 'action', 'nouveau_v') ; |
return $formulaire->toHTML() ; |
} |
// C'est une demande de modification : Affichage du masque de saisie et ajout d'un champs caché avec action=modifier_v |
if (isset ($GLOBALS['id_wikini']) && $GLOBALS['action'] != 'modifier_v' && $GLOBALS['action'] != 'supprimer') { |
$formulaire->addElement ('hidden', 'action', 'modifier_v') ; |
$formulaire->addElement ('hidden', 'id_wikini', $GLOBALS['id_wikini']) ; |
$formulaire->setDefaults(adwi_valeurs_par_defaut($GLOBALS['id_wikini'], $db)) ; |
return $formulaire->toHTML() ; |
} |
// Enregistrement de la modification et retour à la liste |
if ($GLOBALS['action'] == 'modifier_v') { |
if ($formulaire->validate()) { |
mise_a_jour ($formulaire->getSubmitValues(), $db) ; |
} |
} |
// Enregistrement de l'ajout et retour à la liste |
if ($GLOBALS['action'] == 'nouveau_v') { |
if ($formulaire->validate()) { |
insertion ($formulaire->getSubmitValues(), $db) ; |
} |
} |
} |
// Comportement par défaut |
// requete sur la table gen_wikini pour affichage de la liste des Wikini |
$requete = "select gewi_id_wikini, gewi_code_alpha_wikini, gewi_page from gen_wikini" ; |
$resultat = $db->query ($requete) ; |
if (DB::isError ($resultat)) { |
$GLOBALS['_GEN_commun']['debogage_erreur']->gererErreur(E_USER_WARNING, "Echec de la requete : $requete<br />".$resultat->getMessage(), |
__FILE__, __LINE__, 'admin_wikini') ; |
return ; |
} |
$liste = new HTML_TableFragmenteur () ; |
$liste->construireEntete(array (ADWI_NOM_WIKINI, ADWI_PAGE, ADWI_MODIFIER, ADWI_SUPPRIMER,ADWI_VISITER)) ; |
$tableau_wikini = array() ; |
while ($ligne = $resultat->fetchRow()) { |
$url->addQueryString ('id_wikini', $ligne[0]) ; |
array_push ($tableau_wikini, array ($ligne[1]."\n", // Première colonne, le nom de l'application |
$ligne[2]."\n", // Deuxieme colonne, la page par defaut |
'<a href="'.$url->getURL().'">'.ADWI_MODIFIER.'</a>'."\n", |
'<a href="'.$url->getURL().'&action=supprimer" onclick="javascript:return confirm (\''.ADWI_SUPPRIMER.' ?\');">'.ADWI_SUPPRIMER.'</a>'."\n", |
'<a href="'.ADWI_CHEMIN_WIKINI.$ligne[1].'">'.ADWI_VISITER.'</a>'."\n" |
)); |
} |
$liste->construireListe($tableau_wikini) ; |
$res .= $liste->toHTML(); |
return $res ; |
} |
// +------------------------------------------------------------------------------------------------------+ |
// | PIED du PROGRAMME | |
// +------------------------------------------------------------------------------------------------------+ |
/* +--Fin du code ----------------------------------------------------------------------------------------+ |
* |
* $Log: not supported by cvs2svn $ |
* Revision 1.7 2005/10/21 20:55:06 ddelon |
* todo wikini |
* |
* Revision 1.6 2005/09/30 07:48:35 ddelon |
* Projet Wikini |
* |
* Revision 1.5 2005/09/09 09:37:17 ddelon |
* Integrateur Wikini et administration des Wikini |
* |
* Revision 1.4 2005/09/06 08:35:36 ddelon |
* Integrateur Wikini et administration des Wikini |
* |
* Revision 1.3 2005/09/02 11:29:25 ddelon |
* Integrateur Wikini et administration des Wikini |
* |
* Revision 1.2 2005/08/31 17:34:52 ddelon |
* Integrateur Wikini et administration des Wikini |
* |
* Revision 1.1 2005/08/25 08:59:12 ddelon |
* Integrateur Wikini et administration des Wikini |
* |
* Revision 1.4 2005/03/09 10:46:17 jpm |
* Changement d'un nom de fichier. |
* |
* Revision 1.3 2005/03/09 10:40:26 alex |
* version initiale |
* |
* Revision 1.2 2005/02/28 10:32:59 jpm |
* Changement de nom de dossier. |
* |
* Revision 1.1 2004/12/13 18:07:19 alex |
* version initiale |
* |
* |
* +-- Fin du code ----------------------------------------------------------------------------------------+ |
*/ |
?> |
/trunk/client/integrateur_wikini/bibliotheque/gestion_wikini.class.php |
---|
19,7 → 19,7 |
// | License along with this library; if not, write to the Free Software | |
// | Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA | |
// +------------------------------------------------------------------------------------------------------+ |
// CVS : $Id: gestion_wikini.class.php,v 1.3 2005-11-02 13:46:37 ddelon Exp $ |
// CVS : $Id: gestion_wikini.class.php,v 1.4 2005-11-14 10:14:30 ddelon Exp $ |
/** |
* Application projet |
* |
31,7 → 31,7 |
//Autres auteurs : |
*@author Aucun |
*@copyright Tela-Botanica 2000-2004 |
*@version $Revision: 1.3 $ |
*@version $Revision: 1.4 $ |
// +------------------------------------------------------------------------------------------------------+ |
*/ |
137,7 → 137,7 |
"KEY idx_signuptime (signuptime)". |
") TYPE=MyISAM"); |
$this->_db->query("insert into ".$prefixe."pages set tag = 'PagePrincipale', body = '".mysql_escape_string("===== Bienvenue ! sur le Wikini de ce groupe de travail =====\nCliquer sur le lien \"Editer cette page\" au bas de la page pour rédiger.\n\n----\n\n\n\n\n\n\n----\n===== Pages utiles =====\n -[[TableauDeBord Tableau de bord de ce Wikini]]\n -[[ReglesDeFormatage Règles de formatage]]\n -[[BacASable Bac à sable]]")."', owner = 'WikiNiInstaller', user = 'WikiNiInstaller', time = now(), latest = 'Y'"); |
$this->_db->query("insert into ".$prefixe."pages set tag = 'PagePrincipale', body = '".mysql_escape_string("===== Bienvenue sur le Wikini de ce groupe de travail =====\nCliquer sur le lien \"Modifier cette page\" au bas de la page pour rédiger.\n\n----\n\n\n\n\n\n\n----\n===== Pages utiles =====\n -[[TableauDeBord Tableau de bord de ce Wikini]]\n -[[ReglesDeFormatage Règles de formatage]]\n -[[BacASable Bac à sable]]")."', owner = 'WikiNiInstaller', user = 'WikiNiInstaller', time = now(), latest = 'Y'"); |
$this->_db->query("insert into ".$prefixe."pages set tag = 'DerniersChangements', body = '** Retour : ** [[TableauDeBord Tableau de bord]]\n----\n{{RecentChanges}}', owner = 'WikiNiInstaller', user = 'WikiNiInstaller', time = now(), latest = 'Y'"); |
$this->_db->query("insert into ".$prefixe."pages set tag = 'DerniersCommentaires', body = '** Retour : ** [[TableauDeBord Tableau de bord]]\n----\n{{RecentlyCommented}}', owner = 'WikiNiInstaller', user = 'WikiNiInstaller', time = now(), latest = 'Y'"); |
$this->_db->query("insert into ".$prefixe."pages set tag = 'ParametresUtilisateur', body = '** Retour : ** [[PagePrincipale page principale]]\n----\n** Note : ** L\'idéal pour la création d\'un nom Wiki est d\'accoler son prénom et son nom de cette façon : \"PrenomNom\". \n----\n==== Mes paramètres ====\n\n{{UserSettings}}\n\n----\n', owner = 'WikiNiInstaller', user = 'WikiNiInstaller', time = now(), latest = 'Y'"); |
151,9 → 151,8 |
$this->_db->query("insert into ".$prefixe."pages set tag = 'IndexDesPages', body = '**Retour : ** [[TableauDeBord tableau de bord]]\n----\n=== Liste des pages : ===\n\n{{ListPages}}', owner = 'WikiNiInstaller', user = 'WikiNiInstaller', time = now(), latest = 'Y'"); |
$this->_db->query("insert into ".$prefixe."pages set tag = 'IndexAlphabetiqueDesPages', body = '**Retour : ** [[TableauDeBord tableau de bord]]\n----\n=== Liste des pages par ordre alphabétique : ===\n\n{{pageindex}}', owner = 'WikiNiInstaller', user = 'WikiNiInstaller', time = now(), latest = 'Y'"); |
$this->_db->query("insert into ".$prefixe."pages set tag = 'DerniersChangementsRSS', body = '**Retour : ** [[TableauDeBord tableau de bord]]\n----\nCette page renvoie au fils RSS des derniers changement. Pour savoir comment l\'utiliser voir la page \"\"<a href=\"http://www.wikini.net/wakka.php?wiki=WikiniEtLesFluxRSS\" target=\"_blank\" title=\"Wikini et les flux RSS\">Wikini et les flux RSS</a>\"\".\n\n\"\"<!--\n\n{{recentchangesrss/link=\"DerniersChangements\"}}\n\n-->\"\"', owner = 'WikiNiInstaller', user = 'WikiNiInstaller', time = now(), latest = 'Y'"); |
$this->_db->query("insert into ".$prefixe."pages set tag = 'ListeInterWiki', body = '**Retour : ** [[TableauDeBord tableau de bord]]\n----\n=== Liste des distributions wiki : ===\n\n{{interwikilist}}', owner = 'WikiNiInstaller', user = 'WikiNiInstaller', time = now(), latest = 'Y'"); |
$this->_db->query("insert into ".$prefixe."pages set tag = 'BacASable', body = '** Retour : ** [[PagePrincipale Page pincipale]]\n----\nUtilisez cette page pour faire vos tests !', owner = 'WikiNiInstaller', user = 'WikiNiInstaller', time = now(), latest = 'Y'"); |
$this->_db->query("insert into ".$prefixe."pages set tag = 'TableauDeBord', body = '** Retour : ** [[PagePrincipale Page Principale]]\n----\n===== Tableau de bord =====\n\n - Listes des utilisateurs : [[ListeUtilisateurs par ordre de création ]] ou [[ListeUtilisateursInverse par ordre inverse de création ]].\n\n - [[DerniersChangements Dernières modifications sur les pages]]\n - [[DerniersCommentaires Dernières modifications sur les commentaires]]\n\n\n - [[PagesOrphelines Pages orphelines]]\n - [[PagesACreer Pages à créer]]\n\n - [[RechercheTexte Recherche texte]]\n\n - [[PlanDuSite Plan du site]]\n - [[IndexDesPages Index des pages avec noms des propriétaires]]\n - [[IndexAlphabetiqueDesPages Index des pages par classement alphabétique]]\n\n - [[DerniersChangementsRSS La page permettant le flux RSS]]\n\n - [[ListeInterWiki Liste des wiki existants ]]\n----\n==== 5 derniers comptes utilisateurs ====\n{{Listusers last=\"5\"}}\n\n==== 5 dernières pages modifiées ====\n{{recentchanges max=\"5\"}}\n----', owner = 'WikiNiInstaller', user = 'WikiNiInstaller', time = now(), latest = 'Y'"); |
$this->_db->query("insert into ".$prefixe."pages set tag = 'TableauDeBord', body = '** Retour : ** [[PagePrincipale Page Principale]]\n----\n===== Tableau de bord =====\n\n - Listes des utilisateurs : [[ListeUtilisateurs par ordre de création ]] ou [[ListeUtilisateursInverse par ordre inverse de création ]].\n\n - [[DerniersChangements Dernières modifications sur les pages]]\n - [[DerniersCommentaires Dernières modifications sur les commentaires]]\n\n\n - [[PagesOrphelines Pages orphelines]]\n - [[PagesACreer Pages à créer]]\n\n - [[RechercheTexte Recherche texte]]\n\n - [[PlanDuSite Plan du site]]\n - [[IndexDesPages Index des pages avec noms des propriétaires]]\n - [[IndexAlphabetiqueDesPages Index des pages par classement alphabétique]]\n\n - [[DerniersChangementsRSS La page permettant le flux RSS]]\n\n----\n==== 5 derniers comptes utilisateurs ====\n{{Listusers last=\"5\"}}\n\n==== 5 dernières pages modifiées ====\n{{recentchanges max=\"5\"}}\n----', owner = 'WikiNiInstaller', user = 'WikiNiInstaller', time = now(), latest = 'Y'"); |
$this->_db->query("insert into ".$prefixe."pages set tag = 'NomWiki', body = '** Retour : ** [[PagePrincipale Page Principale]]\n----\nUn NomWiki est un nom qui est écrit \"\"CommeCela\"\".\n\nUn NomWiki est transformé automatiquement en lien. Si la page correspondante n\'existe pas, un \'?\' est affiché à côté du mot.', owner = 'WikiNiInstaller', user = 'WikiNiInstaller', time = now(), latest = 'Y'"); |
} // end of member function creation_tables |
/trunk/client/integrateur_wikini/admin_wikini.php |
---|
1,5 → 1,5 |
<?php |
/*vim: set expandtab tabstop=4 shiftwidth=4: */ |
/*vim: set expandtab tabstop=4 shiftwidth=4: */ |
// +------------------------------------------------------------------------------------------------------+ |
// | PHP version 4.1 | |
// +------------------------------------------------------------------------------------------------------+ |
19,24 → 19,15 |
// | License along with this library; if not, write to the Free Software | |
// | Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA | |
// +------------------------------------------------------------------------------------------------------+ |
// CVS : $Id: admin_wikini.php,v 1.7 2005-10-21 20:55:06 ddelon Exp $ |
// CVS : $Id: admin_wikini.php,v 1.8 2005-11-14 10:14:30 ddelon Exp $ |
/** |
* Application gérant les Wikini associe à Papyrus |
* |
* Cette application permet de gérer les parametre des wikini associés à l'ensemble d'un papyrus |
* TODO : Gestion mise a jour wakka.config.php !!!!! |
* TODO : afficher les utilisations par les menus. |
* TODO : synchronisation FTP ? .... : creation, suppression, liste (renommer ???) |
* TODO : chemin vers le wikini ... (non, calcul en fonction du code alpha) , mais controles ? Pas dans un |
* premier temps ... |
* TODO : installation des wikini (tables présentes etc, et gestion ... (suppression ...) |
* TODO : un wiki par défaut pour chaque papyrus, ce wiki sert de modèle |
* |
*@package Admin_Wikini |
//Auteur original : |
*@author David Delon <david.delon@clapas.net> |
*@copyright Tela-Botanica 2000-2005 |
*@version $Revision: 1.7 $ |
*@version $Revision: 1.8 $ |
// +------------------------------------------------------------------------------------------------------+ |
*/ |
44,141 → 35,20 |
// +------------------------------------------------------------------------------------------------------+ |
// | ENTÊTE du PROGRAMME | |
// +------------------------------------------------------------------------------------------------------+ |
/** Inclusion du fichier de configuration de cette application.*/ |
require_once 'client/integrateur_wikini/configuration/adwi_configuration.inc.php'; |
//Utilisation de la bibliothèque PEAR NET_URL |
/** Inclusion des fonctions de cette application.*/ |
require_once 'client/integrateur_wikini/bibliotheque/iw_admin_wikini.fonct.php'; |
/** Inclusion de la bibliothèque PEAR de conception de formulaire.*/ |
require_once ADWI_CHEMIN_BIBLIOTHEQUE_PEAR.'HTML/QuickForm.php'; |
require_once ADWI_CHEMIN_BIBLIOTHEQUE_PEAR.'HTML/QuickForm/select.php'; |
/** Inclusion de l'API de fonctions gérant les erreurs sql.*/ |
require_once ADWI_CHEMIN_BIBLIOTHEQUE_API.'debogage/BOG_sql.fonct.php'; |
/** Inclusion des fonctions de manipulation du sql. |
* Permet la récupération d'un nouvel identifiant d'une table.*/ |
require_once ADWI_CHEMIN_BIBLIOTHEQUE_API.'sql/SQL_manipulation.fonct.php'; |
require_once ADWI_CHEMIN_BIBLIOTHEQUE_API.'html/HTML_TableFragmenteur.php' ; |
require_once ADWI_CHEMIN_BIBLIOTHEQUE.'adwi_wikini.fonct.php'; |
require_once ADWI_CHEMIN_BIBLIOTHEQUE.'adwi_HTML_formulaireWikini.class.php' ; |
// Inclusion des fichiers de traduction de l'appli ADME dePapyrus |
if (file_exists(ADWI_CHEMIN_LANGUE.'adwi_langue_'.$GLOBALS['_GEN_commun']['i18n'].'.inc.php')) { |
/** Inclusion du fichier de traduction suite à la transaction avec le navigateur.*/ |
require_once ADWI_CHEMIN_LANGUE.'adwi_langue_'.$GLOBALS['_GEN_commun']['i18n'].'.inc.php'; |
} else { |
/** Inclusion du fichier de traduction par défaut.*/ |
require_once ADWI_CHEMIN_LANGUE.'adwi_langue_'.ADWI_I18N_DEFAUT.'.inc.php'; |
} |
// +------------------------------------------------------------------------------------------------------+ |
// | CORPS du PROGRAMME | |
// +------------------------------------------------------------------------------------------------------+ |
function afficherContenuCorpsHTML() { |
return afficherContenuCorps(); |
return admin_afficherContenuCorpsHTML(); |
} |
function afficherContenuCorps() |
{ |
/* Gestion de Deux "écrans" et des actions associées : liste des Wikini en base de donnees et ajout-modification |
* d'un Wikini |
*/ |
$db = &$GLOBALS['_GEN_commun']['pear_db'] ; |
$url = $GLOBALS['_GEN_commun']['url'] ; |
$auth = &$GLOBALS['_GEN_commun']['pear_auth'] ; |
isset ($GLOBALS['action']) ? '' : $GLOBALS['action'] = '' ; // On déclare action si elle n'existe pas |
if (!$auth->getAuth()) { |
return 'Identifiez-vous' ; |
} |
// Le lien pour une nouvelle entrée |
$res = '<a href="'.$url->getURL().'&action=nouveau">'.ADWI_AJOUTER.'</a>'."\n<br />" ; |
// traitement de la suppression |
if (isset ($GLOBALS['action']) && $GLOBALS['action'] == 'supprimer') adwi_supprimer_wikini($GLOBALS['id_wikini'], $db) ; |
// traitement de l'ajout et de la modification de la ligne selectionnée |
if (isset ($GLOBALS['action']) || isset ($GLOBALS['id_wikini'])) { |
$formulaire = new HTML_formulaireWikini('formulaire_wikini', '', str_replace ('&', '&', $url->getURL())) ; |
$formulaire->construitFormulaire($url) ; |
// C'est une demande d'ajout : Affichage du masque de saisie et ajout d'un champs caché avec action=nouveau_v |
if ($GLOBALS['action'] == 'nouveau') { |
$formulaire->addElement ('hidden', 'action', 'nouveau_v') ; |
return $formulaire->toHTML() ; |
} |
// C'est une demande de modification : Affichage du masque de saisie et ajout d'un champs caché avec action=modifier_v |
if (isset ($GLOBALS['id_wikini']) && $GLOBALS['action'] != 'modifier_v' && $GLOBALS['action'] != 'supprimer') { |
$formulaire->addElement ('hidden', 'action', 'modifier_v') ; |
$formulaire->addElement ('hidden', 'id_wikini', $GLOBALS['id_wikini']) ; |
$formulaire->setDefaults(adwi_valeurs_par_defaut($GLOBALS['id_wikini'], $db)) ; |
return $formulaire->toHTML() ; |
} |
// Enregistrement de la modification et retour à la liste |
if ($GLOBALS['action'] == 'modifier_v') { |
if ($formulaire->validate()) { |
mise_a_jour ($formulaire->getSubmitValues(), $db) ; |
} |
} |
// Enregistrement de l'ajout et retour à la liste |
if ($GLOBALS['action'] == 'nouveau_v') { |
if ($formulaire->validate()) { |
insertion ($formulaire->getSubmitValues(), $db) ; |
} |
} |
} |
// Comportement par défaut |
// requete sur la table gen_wikini pour affichage de la liste des Wikini |
$requete = "select gewi_id_wikini, gewi_code_alpha_wikini, gewi_page from gen_wikini" ; |
$resultat = $db->query ($requete) ; |
if (DB::isError ($resultat)) { |
$GLOBALS['_GEN_commun']['debogage_erreur']->gererErreur(E_USER_WARNING, "Echec de la requete : $requete<br />".$resultat->getMessage(), |
__FILE__, __LINE__, 'admin_wikini') ; |
return ; |
} |
$liste = new HTML_TableFragmenteur () ; |
$liste->construireEntete(array (ADWI_NOM_WIKINI, ADWI_PAGE, ADWI_MODIFIER, ADWI_SUPPRIMER,ADWI_VISITER)) ; |
$tableau_wikini = array() ; |
while ($ligne = $resultat->fetchRow()) { |
$url->addQueryString ('id_wikini', $ligne[0]) ; |
array_push ($tableau_wikini, array ($ligne[1]."\n", // Première colonne, le nom de l'application |
$ligne[2]."\n", // Deuxieme colonne, la page par defaut |
'<a href="'.$url->getURL().'">'.ADWI_MODIFIER.'</a>'."\n", |
'<a href="'.$url->getURL().'&action=supprimer" onclick="javascript:return confirm (\''.ADWI_SUPPRIMER.' ?\');">'.ADWI_SUPPRIMER.'</a>'."\n", |
'<a href="'.ADWI_CHEMIN_WIKINI.$ligne[1].'">'.ADWI_VISITER.'</a>'."\n" |
)); |
} |
$liste->construireListe($tableau_wikini) ; |
$res .= $liste->toHTML(); |
return $res ; |
}// Fin de la fonction afficherContenuCorps() |
return admin_afficherContenuCorps(); |
} |
// +------------------------------------------------------------------------------------------------------+ |
// | PIED du PROGRAMME | |
// +------------------------------------------------------------------------------------------------------+ |
188,6 → 58,9 |
/* +--Fin du code ----------------------------------------------------------------------------------------+ |
* |
* $Log: not supported by cvs2svn $ |
* Revision 1.7 2005/10/21 20:55:06 ddelon |
* todo wikini |
* |
* Revision 1.6 2005/09/30 07:48:35 ddelon |
* Projet Wikini |
* |
/trunk/client/projet/fonctions/SQL_manipulation.fonct.php |
---|
File deleted |
\ No newline at end of file |
/trunk/client/projet/langues/pro_langue_fr.inc.php |
---|
10,7 → 10,7 |
* | Auteur : Alexandre Granier <alexandre@tela-botanica.org> | |
* +-----------------------------------------------------------------------+ |
* $Id: pro_langue_fr.inc.php,v 1.7 2005-10-20 10:28:25 ddelon Exp $ |
* $Id: pro_langue_fr.inc.php,v 1.8 2005-11-14 10:14:30 ddelon Exp $ |
*/ |
158,8 → 158,8 |
// ========== Partie concernant les wikini =========================================== |
define ('PROJET_CREER_WIKI', 'Créer un wikini') ; |
define ('PROJET_ASSOCIER_WIKI', 'Associer un wikini'); |
define ('PROJET_CREER_WIKI', 'Gestion Wikinis') ; |
define ('PROJET_ASSOCIER_WIKI', 'Associer un Wikini'); |
define ('PROJET_WIKI_ASSOCIE', 'Espace de rédaction collaborative') ; |
define ("PROJET_WIKINI_POSSEDE", "Ce projet possède un espace wikini") ; |
define ("PROJET_WIKINI_ALLER", "Aller sur le wikini") ; |
195,7 → 195,7 |
define ('PROJET_TOUS_LES_PROJETS', 'Les autres projets du réseau') ; |
define ("PROJET_NOMBRE_EN_COURS" ,"Nombre de projets en cours") ; |
define ('PROJET_INSCRIT_AUCUN_PROJET', 'Vous n\'êtes inscrit à aucun projet<br /> |
- <a href="http://testv4.tela-botanica.org/papyrus.php?menu=158">Qu\'est-ce qu\'un projet ?</a><br /> |
- <a href="http://testv4.tela-botanica.org/papyrus.php?menu=158">Qu\'est-ce qu\'un projet ?</a><br /> |
Le réseau Tela Botanica est organisé autour de projets, discussions ou |
échanges liés à la botanique. Vous pouvez y participer en vous |
inscrivant.') ; |
/trunk/client/projet/configuration/projet.config.inc.php |
---|
1,5 → 1,5 |
<?php |
/*vim: set expandtab tabstop=4 shiftwidth=4: */ |
/*vim: set expandtab tabstop=4 shiftwidth=4: */ |
// +------------------------------------------------------------------------------------------------------+ |
// | PHP version 4.1 | |
// +------------------------------------------------------------------------------------------------------+ |
19,7 → 19,7 |
// | License along with this library; if not, write to the Free Software | |
// | Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA | |
// +------------------------------------------------------------------------------------------------------+ |
// CVS : $Id: projet.config.inc.php,v 1.2 2005-10-20 10:28:25 ddelon Exp $ |
// CVS : $Id: projet.config.inc.php,v 1.3 2005-11-14 10:14:30 ddelon Exp $ |
/** |
* Application projet, fichier de configuration |
* |
31,7 → 31,7 |
//Autres auteurs : |
*@author Aucun |
*@copyright Tela-Botanica 2000-2004 |
*@version $Revision: 1.2 $ |
*@version $Revision: 1.3 $ |
// +------------------------------------------------------------------------------------------------------+ |
*/ |
48,12 → 48,14 |
/** |
//==================================== LES CHEMINS ================================= |
* Constantes définissant les chemins d'accé au différents fichiers inclus dans les |
* Constantes définissant les chemins d'accé au différents fichiers inclus dans les |
* applications. |
//================================================================================== |
*/ |
define("PROJET_CHEMIN_APPLI",'client/projet/');//le chemin vers l'application courante |
define ('PROJET_CHEMIN_API_ARBRE', 'api/arbre/') ; |
/** Chemin vers la bibliothèque API.*/ |
define('PROJET_CHEMIN_BIBLIOTHEQUE_API', GEN_CHEMIN_API); |
define ("PROJET_CHEMIN_ICONES", PROJET_CHEMIN_APPLI."icones/") ; |
define("PROJET_CHEMIN_CLASSES", PROJET_CHEMIN_APPLI.'classes/');//le chemin vers les fichiers propre à GSITE |
define ("PROJET_CHEMIN_FONCTIONS", PROJET_CHEMIN_APPLI.'fonctions/') ; |
88,7 → 90,7 |
/** |
//==================================== CONSTANTES ================================== |
* Constantes des chemins associés aux wikinis |
* Constantes des chemins associés aux wikinis |
//================================================================================== |
*/ |
132,11 → 134,15 |
*/ |
define ('PROJET_UTILISE_TYPE', false) ; |
define ('PROJET_UTILISE_HIERARCHIE', false) ; |
define ('PROJET_LISTE_RESUME',true); |
/* +--Fin du code ----------------------------------------------------------------------------------------+ |
* |
* $Log: not supported by cvs2svn $ |
* Revision 1.2 2005/10/20 10:28:25 ddelon |
* Wikini complet dans l'intégrateur Wikini |
* |
* Revision 1.1 2005/09/27 12:50:28 ddelon |
* Projet configuration |
* |
/trunk/client/projet/classes/projet.class.php |
---|
1,5 → 1,5 |
<?php |
/*vim: set expandtab tabstop=4 shiftwidth=4: */ |
/*vim: set expandtab tabstop=4 shiftwidth=4: */ |
// +------------------------------------------------------------------------------------------------------+ |
// | PHP version 4.1 | |
// +------------------------------------------------------------------------------------------------------+ |
19,7 → 19,7 |
// | License along with this library; if not, write to the Free Software | |
// | Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA | |
// +------------------------------------------------------------------------------------------------------+ |
// CVS : $Id: projet.class.php,v 1.5 2005-10-14 08:50:37 alexandre_tb Exp $ |
// CVS : $Id: projet.class.php,v 1.6 2005-11-14 10:14:30 ddelon Exp $ |
/** |
* Application projet |
* |
31,7 → 31,7 |
//Autres auteurs : |
*@author Aucun |
*@copyright Tela-Botanica 2000-2004 |
*@version $Revision: 1.5 $ |
*@version $Revision: 1.6 $ |
// +------------------------------------------------------------------------------------------------------+ |
*/ |
42,7 → 42,8 |
include_once PROJET_CHEMIN_CLASSES.'document.class.php' ; |
include_once PROJET_CHEMIN_CLASSES.'liste_discussion.class.php' ; |
include_once PROJET_CHEMIN_FONCTIONS.'SQL_manipulation.fonct.php' ; |
/* Permet la récupération d'un nouvel identifiant d'une table.*/ |
require_once PROJET_CHEMIN_BIBLIOTHEQUE_API.'sql/SQL_manipulation.fonct.php'; |
include_once 'Mail.php' ; |
// +------------------------------------------------------------------------------------------------------+ |
54,7 → 55,7 |
/** |
* class projet |
* |
* |
*/ |
class projet |
{ |
72,7 → 73,7 |
/** Compositions: */ |
/*** Attributes: ***/ |
/** |
* L'identifiant du projet. |
* @access private |
144,8 → 145,8 |
var $_type; |
/** |
* |
* PHP5 |
* |
* PHP5 |
* @return projet |
* @access public |
*/ |
152,12 → 153,12 |
function __construct( &$dbObject, $id_projet = "") |
{ |
$this->projet($dbObject, $id_projet); |
} // end of member function __construct |
/** |
* |
* |
* |
* @param DB dbObject Un objet PEAR:DB |
* @param int id_projet On passe un identifiant de projet au constructeur. Cela lui permet de faire une |
* première requête pour les infos de bases comme le titre, le description etc. |
174,7 → 175,7 |
die ("Echec de la requete<br />".$resultat->getMessage()."<br />".$resultat->getDebugInfo()) ; |
} |
$ligne = $resultat->fetchRow (DB_FETCHMODE_OBJECT) ; |
// Affectations dans les propriétés |
$this->_id_projet = $ligne->p_id ; |
$this->_titre = $ligne->p_titre ; |
186,7 → 187,7 |
$this->_type = $ligne->p_type ; |
// On récupère le nom du répertoire |
$this->_nom_repertoire = $ligne->p_nom_repertoire ; |
// on regarde si on a à faire au projet racine |
if (PROJET_UTILISE_HIERARCHIE) { |
$requete = 'select ph_id_projet_pere, ph_id_projet_fils from projet_hierarchie where ph_id_projet_fils='.$this->_id_projet ; |
204,11 → 205,11 |
} // end of member function projet |
/** |
* |
* |
* |
* @param DB dbObject Un objet PEAR:DB |
* @param int id_projet On passe un identifiant de projet au constructeur. |
* @return bool |
* @return bool |
* @access public |
*/ |
function projetExiste( &$dbObject, $id_projet) |
224,11 → 225,11 |
} |
} |
} // end of member function projet |
/** |
* |
* |
* @param int id_projet |
* |
* @param int id_projet |
* @return string |
* @access public |
*/ |
236,10 → 237,10 |
{ |
return $this->_titre ; |
} // end of member function getTitre |
/** |
* |
* |
* |
* @return string |
* @access public |
*/ |
260,8 → 261,8 |
} // end of member function getId |
/** |
* |
* |
* |
* @return string |
* @access public |
*/ |
271,8 → 272,8 |
} // end of member function getDescription |
/** |
* |
* |
* |
* @return string |
* @access public |
*/ |
303,7 → 304,7 |
if ($resultat->numRows()) { |
$ligne = $resultat->fetchRow (DB_FETCHMODE_OBJECT) ; |
$this->_listes_associes[] = new liste_discussion($ligne->pl_id_liste, $this->_db) ; |
} |
} // end of member function getListesAssociees |
332,7 → 333,7 |
* (cliquable)" |
* |
* @param visibilite visibilite Si visibilite est à prive, tous les fichiers sont renvoyés ainsi qu'une entrée |
* pour indiquer la visibilité du document. |
* pour indiquer la visibilité du document. |
* @return Array |
* @access public |
*/ |
347,10 → 348,10 |
die ("Echec de la requete<br />".$resultat->getMessage()."<br />".$resultat->getDebugInfo()) ; |
} |
$tableau_document = array() ; |
// Un compteur |
$i = 0 ; |
while ($ligne = $resultat->fetchRow (DB_FETCHMODE_OBJECT)) { |
array_push ($tableau_document, new document ($ligne->pd_id, &$this->_db, $chemin, $chemin_icones)) ; |
} |
374,11 → 375,11 |
die ("Echec de la requete<br />".$resultat->getMessage()."<br />".$resultat->getDebugInfo()) ; |
} |
$tableau_document = array() ; |
while ($ligne = $resultat->fetchRow (DB_FETCHMODE_OBJECT)) { |
array_push ($tableau_document, new document ($ligne->pd_id, $this->_db)); |
} |
return $tableau_document ; |
} // end of member function getListeRepertoireHierarchisee |
458,7 → 459,7 |
*/ |
function __destruct( ) |
{ |
} // end of member function __destruct |
/** |
470,7 → 471,7 |
*/ |
function supprimer( ) |
{ |
} // end of member function supprimer |
/** |
502,14 → 503,14 |
', p_wikini="'.$tableau_de_valeur['projet_wikini'].'", p_nom_repertoire="'.$nom_repertoire.'", p_resume="'.$tableau_de_valeur['projet_resume']. |
'", p_type='.$tableau_de_valeur['projet_type'] ; |
$resultat = $this->_db->query ($requete) ; |
if (DB::isError($resultat)) { |
die ("Echec de la requete<br />".$resultat->getMessage()."<br />".$resultat->getDebugInfo()) ; |
} |
// On affecte à l'objet projet son identifiant |
$this->_id_projet = $id ; |
//insertion dans projet_hiérarchie |
if (PROJET_UTILISE_HIERARCHIE) { |
$requete = 'insert into projet_hierarchie set ph_id_projet_pere='.$tableau_de_valeur['projet_asso']. |
542,15 → 543,15 |
if (DB::isError($resultat)) { |
die ("Echec de la requete<br />".$resultat->getMessage()."<br />".$resultat->getDebugInfo()) ; |
} |
if (PROJET_UTILISE_HIERARCHIE) { |
// suppression dans projet_hierarchie |
$requete = 'delete from projet_hierarchie where ph_id_projet_fils='.$this->_id_projet ; |
$resultat = $this->_db->query ($requete) ; |
//insertion dans projet_hiérarchie |
$requete = 'insert into projet_hierarchie set ph_id_projet_pere='.$tableau_de_valeur['projet_asso']. |
', ph_id_projet_fils='.$this->_id_projet ; |
$resultat = $this->_db->query ($requete) ; |
577,9 → 578,9 |
/** |
* |
* |
* @param string code_sql |
* |
* @param string code_sql |
* @return bool |
* @access public |
*/ |
591,13 → 592,13 |
$msg = 'La suppression du répertoire n\'a pas fonctionné' ; |
} |
// A ajouter la suppression des documents associés |
// La suppression des évènements associés |
// Le projet lui-même |
$requete = "delete from projet where p_id=".$this->_id_projet ; |
$resultat = $this->_db->query ($requete) ; |
if (PROJET_UTILISE_HIERARCHIE) { |
$requete = "delete from projet_hierarchie where ph_id_projet_fils=".$this->_id_projet ; |
$resultat = $this->_db->query ($requete) ; |
669,7 → 670,7 |
$nom .= 1 ; |
} |
return $nom ; |
} // end of member function genereNomRepertoire |
/** |
771,7 → 772,7 |
} |
return $tableau_resultat ; |
} // end of member function getHierarchie |
/** |
* Renvoie l'identifiant du pere du projet courrant. |
* |
/trunk/client/projet/classes/projetControleur.class.php |
---|
1,5 → 1,5 |
<?php |
/*vim: set expandtab tabstop=4 shiftwidth=4: */ |
/*vim: set expandtab tabstop=4 shiftwidth=4: */ |
// +------------------------------------------------------------------------------------------------------+ |
// | PHP version 4.1 | |
// +------------------------------------------------------------------------------------------------------+ |
20,7 → 20,7 |
// | Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA | |
// +------------------------------------------------------------------------------------------------------+ |
// CVS : $Id: projetControleur.class.php,v 1.16 2005-10-25 13:48:27 alexandre_tb Exp $ |
// CVS : $Id: projetControleur.class.php,v 1.17 2005-11-14 10:14:30 ddelon Exp $ |
/** |
* Application projet |
33,7 → 33,7 |
//Autres auteurs : |
*@author Aucun |
*@copyright Tela-Botanica 2000-2004 |
*@version $Revision: 1.16 $ |
*@version $Revision: 1.17 $ |
// +------------------------------------------------------------------------------------------------------+ |
*/ |
144,13 → 144,13 |
* @access private |
*/ |
var $_auth; |
/** |
* |
* |
* @access private |
*/ |
var $_url; |
/** |
* L'identifiant du projet sur lequel on travaille. Dans l'action par défaut, cet |
* attribut n'a pas de valeur. |
183,7 → 183,7 |
* Valeurs possibles: 0, 1, 2, 3 ... |
* @access private |
*/ |
var $_type ; |
/** |
* Le tableau des projets à ne pas afficher, ni dans l'arbre, ni dans les listes |
190,13 → 190,13 |
* @access private |
*/ |
var $_projet_exclu = array(); |
/** |
* parametre indiquant le type d'inscription possible |
* @access private |
*/ |
var $_prive = 0 ; |
/** |
* Méthode principale de la classe. Elle permet d'appeler les méthodes du modules |
* projet en fonction de l'action. |
210,7 → 210,7 |
if ($this->_action == '') { |
return $this->messageErreur(PROJETCONTROLEUR_ACTION_INVALIDE) ; |
} |
// Si il n'y a pas d'action mais un projet, on transmet par défaut l'action PROJET_VOIR |
if ($this->_id_projet != "" && $this->_action == PROJET_DEFAUT) { |
$this->_action = PROJET_ACTION_VOIR_RESUME ; |
224,7 → 224,7 |
} |
$retour = '' ; |
if (!defined('PROJET_MENU_AFFICHER_CONTENU_CORPS')) $retour = $this->menuGeneral() ; |
switch ($this->_action) { |
case PROJET_DEFAUT : |
$retour .= $this->mesProjets() ; |
291,7 → 291,7 |
$this->_action = PROJET_ACTION_VOIR_RESUME ; |
break ; |
case PROJET_ACTION_S_INSCRIRE : $retour .= $this->inscriptionProjet() ; |
break ; |
case PROJET_ACTION_DESINSCRIPTION_PROJET : $retour .= $this->desinscriptionProjet() ; |
break ; |
318,7 → 318,7 |
case PROJET_ACTION_REFERENCER_LISTE_V : $retour .= $this->referencerListeExterneValidation() ; |
$this->_action = PROJET_ACTION_VOIR_RESUME ; |
break ; |
} |
if (!is_int($this->_action)) { |
if (file_exists(PROJET_CHEMIN_APPLI.'actions/'.$this->_action.'.php')) { |
342,7 → 342,7 |
} // end of member function setAction |
/** |
* Constructeur. |
* Constructeur. |
* |
* @return void |
* @access public |
357,7 → 357,7 |
$this->_url = $urlObjet ; |
} |
} // end of member function projetControleur |
/** |
* Renvoie la liste des projets auquel participe la personne logguée, avec son |
* statut et un lien vers l'action pour gérer le projet. |
371,7 → 371,7 |
include_once PROJET_CHEMIN_CLASSES.'statut_liste.class.php' ; |
include_once PROJET_CHEMIN_CLASSES.'inscription_liste.class.php' ; |
$participant = new participe ($this->_db) ; |
if (PROJET_UTILISE_TYPE && $this->_type != '') { |
$projetListe = projet::getProjetDuType($this->_type, $this->_db) ; |
if ($this->_presentation == 'arbre')array_push ($projetListe, projet::getProjetRacine($this->_db)) ; |
384,8 → 384,8 |
// On inclue un fichier local |
if (file_exists(PROJET_CHEMIN_APPLI.'langues/pro_langues_fr.local.inc.php')) |
include_once PROJET_CHEMIN_APPLI.'langues/pro_langues_fr.local.inc.php' ; |
return $res .= PROJET_PAS_DE_LISTE; |
} |
return $res .= PROJET_PAS_DE_LISTE; |
} |
// Si certain projet sont à exclure, on les exclu |
$projet_a_exclure = array() ; |
if (count($this->_projet_exclu)) { |
396,14 → 396,14 |
} |
} |
foreach ($projet_a_exclure as $valeur) unset ($projetListe[$valeur]) ; |
// Les entêtes des tableaux |
$tableau_label_statut_action = array (PROJET_GERER, PROJET_GERER, PROJET_GERER_FICHIER, PROJET_VOIR_FICHIER, "---") ; |
$auth = $this->_auth->getAuth() ; // Pour raccourcir le code |
$id_u = $this->_auth->getAuthData(PROJET_CHAMPS_ID) ; // -------------- |
// Si la présentation est par arbre |
// TODO : Organiser différemment les présentations |
// En utilisant des templates |
414,36 → 414,36 |
$intensite_feuille = '' ; $longueur_branche = '' ; |
$arbre = new arbre() ; |
// recherche du projet principal |
$cime=''; |
foreach ($projetListe as $projet) { |
$this->_url->addQueryString (PROJET_VARIABLE_ID_PROJET, $projet->getId()) ; |
$this->_url->addQueryString(PROJET_VARIABLE_ACTION, PROJET_ACTION_VOIR_PARTICIPANT) ; |
$lien_feuille = $this->_url->getURL() ; |
$this->_url->removeQueryString(PROJET_VARIABLE_ACTION) ; |
if ($projet->isRacine()) { |
$cime = $arbre->cime($projet->getTitre(), $this->_url->getURL(), $projet->getNombreInscrits(), $lien_feuille, '') ; |
} else { |
$arbre->addBranche($projet->getTitre(), $this->_url->getURL(), $projet->getNombreInscrits(), |
$arbre->addBranche($projet->getTitre(), $this->_url->getURL(), $projet->getNombreInscrits(), |
$lien_feuille, $lien_feuille, $intensite_feuille, $longueur_branche) ; |
} |
} |
return $titre.'<table>'.$cime.$arbre->affBranche().$arbre->affRacine().'</table>'; |
} |
// Présentation par liste |
$titre = '<h1>'.PROJET_LISTE.'</h1>'."\n" ; |
// On inclue un fichier local |
if (file_exists(PROJET_CHEMIN_APPLI.'langues/pro_langues_fr.local.inc.php')) |
include_once PROJET_CHEMIN_APPLI.'langues/pro_langues_fr.local.inc.php' ; |
// On vérifie si l'utilisateur participe à des projets |
if ($auth) { |
$utilisateur_liste = new inscription_liste($this->_db) ; |
// On teste ici s'il y a une mise à jour de statut |
if (isset($_POST['statut'])) { |
456,14 → 456,14 |
$utilisateur_liste->modifierTypeInscription($projet->_listes_associes[0],$annuaire, $_POST['statut']) ; |
} |
if (count($participant->getIdProjetsStatuts($id_u))) { |
$HTML_projetListe = new HTML_listeProjet(true) ; |
$entete_liste = array($auth ? PROJET_VOUS_PARTICIPEZ : PROJET_LISTE) ; |
if ($auth) array_push ($entete_liste, PROJET_SE_DESINSCRIRE, PROJET_LISTE_DE_DISCUSSION) ; |
$tableau_resultat = array () ; |
$HTML_projetListe->construitEntete ($entete_liste) ; |
// On construit $tableau_resultat avec une ligne par projet contenant un tableau (titre, statut_nom, id_statut, id_projet) |
483,7 → 483,7 |
//if ($statut == '') $statut = 0 ; |
} |
} |
$this->_url->addQueryString (PROJET_VARIABLE_ID_PROJET, $projet->getId()) ; |
$ligne_tableau = array ($projet->getId(), $projet->getResume(), |
'<a href="'.$this->_url->getURL().'">'.$projet->getTitre().'</a>' |
503,8 → 503,8 |
$statut = '' ; |
} |
$HTML_projetListe->construitListe ($tableau_resultat, $tableau_statut) ; |
if ($HTML_projetListe->getRowCount() > 1) { |
$res .= '<p>'.PROJET_PARTICIPER.'</p>'; |
$res .= $HTML_projetListe->toHTML() ; |
537,20 → 537,20 |
if ($projetNonParticipantListe[$i]->getType() != $this->_type) array_push ($projet_a_exclure, $i) ; |
} |
} |
foreach ($projet_a_exclure as $valeur) { |
unset ($projetNonParticipantListe[$valeur]) ; |
} |
$HTML_projetNonParticipantListe = new HTML_listeProjet(true) ; |
$entete_liste = array (PROJET_LISTE) ; |
array_push ($entete_liste, PROJET_S_INSCRIRE) ; |
$HTML_projetNonParticipantListe->construitEntete($entete_liste) ; |
$liste_projet = array() ; |
// La liste |
foreach ($projetNonParticipantListe as $projet) { |
$this->_url->addQueryString(PROJET_VARIABLE_ID_PROJET, $projet->getId()) ; |
$ligne_projet = array ($projet->getResume(), |
558,7 → 558,7 |
) ; |
$this->_url->addQueryString (PROJET_VARIABLE_ACTION, PROJET_ACTION_S_INSCRIRE) ; |
array_push ($ligne_projet, '<a href="'.$this->_url->getURL().'">'.PROJET_S_INSCRIRE.'</a>') ; |
$this->_url->removeQueryString(PROJET_VARIABLE_ACTION); |
array_push ($liste_projet, $ligne_projet) ; |
} |
570,7 → 570,7 |
$HTML_projetNonParticipantListe = new HTML_listeProjet(true) ; |
$entete_liste = array (PROJET_LISTE) ; |
$HTML_projetNonParticipantListe->construitEntete($entete_liste) ; |
$liste_projet = array() ; |
// La liste |
foreach ($projetNonParticipantListe as $projet) { |
578,7 → 578,7 |
$ligne_projet = array ( $projet->getResume(), |
'<a href="'.$this->_url->getURL().'">'.$projet->getTitre().'</a>', // le nom du projet |
) ; |
$this->_url->removeQueryString(PROJET_VARIABLE_ACTION); |
array_push ($liste_projet, $ligne_projet) ; |
} |
667,7 → 667,7 |
// L'action modifier les propriétés du projet |
$this->_url->addQueryString(PROJET_VARIABLE_ACTION, PROJET_MODIFIER_DESCRIPTION) ; |
$res .= "<li><a href=\"".$this->_url->getURL()."\">".PROJET_MODIFIER_PROPRIETES."</a></li>\n" ; |
if ($projet->avoirListe()) { |
$this->_url->addQueryString(PROJET_VARIABLE_ACTION, PROJET_ACTION_SUPPRIMER_LISTE) ; |
$texte_liste = PROJET_SUPPRIMER_LISTE ; |
681,12 → 681,20 |
$res .= '<li><a href="'.$this->_url->getURL().'"'.$onclic.'>'.$texte_liste.'</a></li>'."\n" ; |
$this->_url->addQueryString(PROJET_VARIABLE_ACTION, PROJET_ACTION_REFERENCER_LISTE) ; |
$res .= '<li><a href="'.$this->_url->getURL().'">'.PROJET_REFERENCER_LISTE.'</a></li>'."\n" ; |
// L'action gérer les utilisateurs |
$this->_url->addQueryString(PROJET_VARIABLE_ACTION, PROJET_ACTION_VOIR_PARTICIPANT) ; |
$res .= "<li><a href=\"".$this->_url->getURL()."\">".PROJET_GESTION_UTILISATEUR."</a></li>\n" ; |
// L'action créer un wikini |
// L'action Gerer les wikis |
/* |
* client/integrateur_wikini/admin_wikini.php |
*/ |
$this->_url->addQueryString(PROJET_VARIABLE_ACTION, PROJET_ACTION_CREER_WIKI) ; |
$res .= "<li><a href=\"".$this->_url->getURL()."\">".PROJET_CREER_WIKI."</a></li>\n" ; |
/* |
if (!$projet->getWikini()) { |
$this->_url->addQueryString(PROJET_VARIABLE_ACTION, PROJET_ACTION_CREER_WIKI) ; |
$res .= "<li><a href=\"".$this->_url->getURL()."\">".PROJET_CREER_WIKI."</a></li>\n" ; |
694,16 → 702,17 |
$this->_url->addQueryString(PROJET_VARIABLE_ACTION, PROJET_ACTION_SUPPRIMER_WIKI) ; |
$res .= '<li><a href="'.$this->_url->getURL().'" onclick="javascript:return confirm(\''.PROJET_WIKINI_SUPPRIMER.' ?\')">'.PROJET_WIKINI_SUPPRIMER."</a></li>\n" ; |
} |
*/ |
// L'action choisir un wikini |
$this->_url->addQueryString(PROJET_VARIABLE_ACTION, PROJET_ACTION_ASSOCIER_WIKI) ; |
$res .= "<li><a href=\"".$this->_url->getURL()."\">".PROJET_ASSOCIER_WIKI."</a></li>\n" ; |
} |
// L'action se désinscrire du projet |
$this->_url->addQueryString(PROJET_VARIABLE_ACTION, PROJET_ACTION_DESINSCRIPTION_PROJET) ; |
$res .= "<li><a href=\"".$this->_url->getURL()."\">".PROJET_SE_DESINSCRIRE."</a></li>\n" ; |
// L'action "Mettre un fichier en ligne" |
$this->_url->addQueryString(PROJET_VARIABLE_ACTION, PROJET_NOUVEAU_FICHIER) ; |
$res .= "<li><a href=\"".$this->_url->getURL()."\">".PROJET_METTRE_FICHIER."</a></li>\n" ; |
711,15 → 720,15 |
// L'action créer un répertoire |
$this->_url->addQueryString(PROJET_VARIABLE_ACTION, PROJET_NOUVEAU_REPERTOIRE) ; |
$res .= "<li><a href=\"".$this->_url->getURL()."\">".PROJET_CREER_REP."</a></li>\n" ; |
if ($projet->avoirListe()) { |
// On vérifie si l'utilisateur est inscrit ou non à la liste et on ajoute le lien |
//$projet->getListesAssociees(); |
include_once PROJET_CHEMIN_CLASSES.'inscription_liste.class.php'; |
foreach ($projet->_listes_associes as $info_liste) { |
$inscription_liste = new inscription_liste($this->_db) ; |
if ($inscription_liste->getStatutInscrit($info_liste->getId(), $this->_auth) == 0) { |
$action_inscription = PROJET_ACTION_INSCRIPTION_LISTE ; |
736,7 → 745,7 |
$res .= $label_inscription.'</a></li> '; |
} |
} |
$res .= '</ul>' ; |
} else if ($auth && !$this->_prive){ |
// L'action s'inscrire du projet |
744,7 → 753,7 |
$res .= "<li><a href=\"".$this->_url->getURL()."\">".PROJET_S_INSCRIRE_AU_PROJET."</a></li>\n" ; |
} |
} |
$res .= "</div>\n" ; |
return $res ; |
} // end of member function menuGeneral |
795,7 → 804,7 |
$formulaire_projet = new HTML_formulaireProjet('formulaire_projet', 'post', str_replace ('&', '&', $this->_url->getURL())) ; |
$formulaire_projet->construitFormulaire(projet::getTousLesProjets($this->_db)) ; |
if ($formulaire_projet->validate()) { |
$projet = new projet ($this->_db) ; |
$projet->setCheminRepertoire (PROJET_CHEMIN_FICHIER) ; |
if (!$projet->enregistrerSQL($formulaire_projet->getSubmitValues())) { |
851,7 → 860,7 |
$formulaire_document = new HTML_formulaireDocument('formulaire_document', 'post',preg_replace ("/&/", "&", $this->_url->getURL())) ; |
$formulaire_document->construitFormulaire($action) ; |
if ($action == PROJET_ACTION_MODIFIER) { |
$document = new document($this->_id_document, $this->_db, PROJET_CHEMIN_FICHIER, PROJET_CHEMIN_ICONES) ; |
// On affecte dans un tableau les valeurs de chaque champs du formulaire avec le nom de chaque élément de formulaire |
// voir HTML_formulaireDocument |
858,8 → 867,8 |
$valeurs_par_defaut = array ('document_nom' => $document->getNomLong(), |
'document_description' => $document->getDescription(), |
'document_visibilite' => $document->getVisibilite()) ; |
// On rajoute un champs caché avec l'identifiant du document |
// On rajoute un champs caché avec l'identifiant du document |
$formulaire_document->addElement ('hidden', 'id_document', $this->_id_document) ; |
$formulaire_document->setDefaults($valeurs_par_defaut) ; |
} else { |
868,7 → 877,7 |
return $res.$formulaire_document->toHTML() ; |
} // end of member function nouveauFichier |
/** |
* Présente un formulaire pour déplacer un fichier |
* |
877,11 → 886,11 |
function fichierCouper() { |
include_once PROJET_CHEMIN_CLASSES.'projet.class.php' ; |
$projet = new projet ($this->_db, $this->_id_projet) ; |
$res = '<h1>'.PROJET_PROJET.' : '.$projet->getTitre().'</h1>' ; |
$document = new document($this->_id_document, $this->_db, PROJET_CHEMIN_FICHIER) ; |
// On traite le cas où l'on vient de déplacer un fichier |
if (isset ($_POST['projet_repertoire'])) { |
if (!$document -> deplace ($_POST['projet_repertoire'], $projet->getNomRepertoire())) { |
echo 'echec du déplacement' ; |
954,18 → 963,18 |
// avant d'appeler la méthode enregistrerSQL, il faut indiquer l'identifiant du projet et l'identifiant du propriétaire |
$document->setIdProjet ($this->_id_projet) ; |
$document->setIdProprietaire ($this->_auth->getAuthData (PROJET_CHAMPS_ID)) ; |
// On passe aussi le numéro de répertoire s'il existe |
if ($this->_id_repertoire != '') $document->setIdRepertoire($this->_id_repertoire) ; |
$chemin_upload = $document->calculeCheminUploaded($projet->getNomRepertoire()) ; |
if (!$document->upload (PROJET_CHEMIN_FICHIER.$projet->getNomRepertoire().'/'.$chemin_upload)) { |
echo 'Echec de l\'upload' ; |
trigger_error('echec d\'upload !', E_USER_ERROR) ; |
} |
$document->enregistrerSQL($formulaire_document->getSubmitValues(), $projet->getNomRepertoire().'/'.$chemin_upload) ; |
// On ajoute une information de session |
$_SESSION['formulaire_document'] = 'valide'; |
1010,26 → 1019,26 |
{ |
// création de l'objet projet courant |
$projet = new projet ($this->_db, $this->_id_projet) ; |
$this->_url->addQueryString (PROJET_VARIABLE_ACTION, PROJET_NOUVEAU_FICHIER_V) ; |
$formulaire_repertoire = new HTML_formulaireDocument('formulaire_repertoire', 'post',preg_replace ("/&/", "&", $this->_url->getURL())) ; |
$formulaire_repertoire->setType ('repertoire') ; |
$formulaire_repertoire->construitFormulaire() ; |
if ($formulaire_repertoire->validate()) { |
// Création d'un objet |
// Création d'un objet |
$document = new document ("", $this->_db) ; |
// avant d'appeler la méthode enregistrerSQL, il faut indiquer l'identifiant du projet et l'identifiant du propriétaire |
$document->setIdProjet ($this->_id_projet) ; |
$document->setIdProprietaire ($this->_auth->getAuthData (PROJET_CHAMPS_ID)) ; |
// On passe aussi le numéro de répertoire s'il existe |
if ($this->_id_repertoire != '') $document->setIdRepertoire($this->_id_repertoire) ; |
$lien = $document->enregistrerSQL($formulaire_repertoire->getSubmitValues(), $projet->getNomRepertoire()) ; |
// La création du répertoire sur le disque, chemin / nom_repertoire_projet / id_repertoire |
if (!mkdir (PROJET_CHEMIN_FICHIER.$lien)) { |
$document->suppressionSQL() ; |
return $this->messageErreur(PROJETCONTROLEUR_ERREUR_CREATION_REPERTOIRE).'<br />'.PROJET_CHEMIN_FICHIER.$lien ; |
} |
1049,7 → 1058,7 |
function setIdProjet( $id_projet ) |
{ |
$this->_id_projet = $id_projet ; |
} // end of member function setIdProjet |
/** |
1063,26 → 1072,26 |
$res = '' ; |
// création de l'objet projet courant |
$projet = new projet ($this->_db, $this->_id_projet) ; |
// récupération de la liste des documents associés |
$liste_documents = $projet->getListesDocuments(PROJET_CHEMIN_FICHIER, PROJET_CHEMIN_ICONES) ; |
// création de la vue liste de document, on nettoie l'url |
$this->_url->removeQueryString(PROJET_VARIABLE_ACTION) ; |
include_once PROJET_CHEMIN_CLASSES.'HTML_listeDocuments.class.php' ; |
$vue_liste_document = new HTML_listeDocuments($this->_url, false, $this->_id_repertoire) ; |
// réglage de paramètres de la vue |
$vue_liste_document->setAction (array ("couper" => PROJET_ACTION_COUPER, "modifier" => PROJET_ACTION_MODIFIER, "supprimer" => PROJET_SUPPRESSION_FICHIER)) ; |
$vue_liste_document->setCheminIcones(PROJET_CHEMIN_ICONES) ; |
$tableau_navigation = document::getCheminIdRepertoire($this->_id_repertoire, $this->_db) ; |
$vue_liste_document->setCheminNavigation ($tableau_navigation) ; |
// vérification des droits de l'utilisateur |
$entete_liste = array (PROJET_FICHIERS_NOM, PROJET_FICHIERS_TAILLE, PROJET_FICHIERS_CREE_LE) ; |
if ($this->_auth->getAuth()) { |
$participant = new participe($this->_db) ; |
$id_u = $this->_auth->getAuthData(PROJET_CHAMPS_ID) ; |
1091,16 → 1100,16 |
$isAdm = participe::isAdministrateur($this->_auth->getAuthData(PROJET_CHAMPS_ID), $this->_db) ; |
if ($isAdm) $droits = PROJET_DROIT_ADMINISTRATEUR ; |
if ($isAdm) $isCoord = true ; |
$statut = participe::getStatutSurProjetCourant ($this->_auth->getAuthData(PROJET_CHAMPS_ID), $this->_id_projet, $this->_db) ; |
// si participant, on ajoute le champs visibilite |
if ($statut !='' || $isAdm) { |
array_push ($entete_liste, PROJET_FICHIERS_VISIBILITE) ; |
} |
// si chef de projet ou si propriétaire d'au moins 1 document |
$proprietaire_un_document = false ; |
foreach ($liste_documents as $document) { |
if ($this->_auth->getAuthData(PROJET_CHAMPS_ID) == $document) { |
$proprietaire_un_document = true ; |
1114,10 → 1123,10 |
$droits = PROJET_DROIT_AUCUN ; |
} |
if (!isset($droits)) $droits = PROJET_DROIT_AUCUN ; |
$vue_liste_document->construitEntete($entete_liste) ; |
$vue_liste_document->construitListe ($liste_documents, $droits) ; |
$wiki_res = '' ; |
// Les wikinis associés au projet |
if ($projet->getWikini()) { |
1132,20 → 1141,20 |
} |
// On charge les listes de discussion du projet |
// Pour le moment seul ezmlm est supportée |
$projet->getListesAssociees(); |
$sortie_liste = '' ; |
if ($projet->avoirListe()) { |
foreach ($projet->_listes_associes as $info_liste) { |
$liste = new ezmlm_php() ; |
// Paramétrage de la liste |
$liste->listdir = PROJET_CHEMIN_LISTES.$info_liste->getDomaine().'/'.$info_liste->getNom(); |
$liste->listname = $info_liste->getNom() ; |
$liste->listdomain = $info_liste->getDomaine(); |
if (isset ($GLOBALS['action']) && $GLOBALS['action'] != '') { |
$liste->set_action($GLOBALS['action']) ; |
$liste->set_actionargs($GLOBALS['actionargs']) ; |
1156,7 → 1165,7 |
$liste->sendbody = false; |
$liste->sendfooters = false; |
$liste->forcehref = $this->_url->getURL() ; |
ob_start() ; |
print '<span class="heading">Liste <strong>' . $info_liste->getAdresseEnvoi() ; |
print "</strong></span><br />\n"; |
1188,7 → 1197,7 |
// On appelle la fonction qui affiche un fichier |
$show_msg->display($liste->actionargs[0] . "/" . $liste->actionargs[1]); |
break; |
case "list_info": |
$info = new ezmlm_listinfo(); |
if (!$info) return 'Les fichiers de la liste ne sont pas visible sur le serveur' ; |
1196,7 → 1205,7 |
$info->listdir = $liste->listdir ; |
$info->listname = $info_liste->getNom(); |
$info->listdomain = $info_liste->getDomaine() ; |
if (!$info->display()) { |
echo 'Pas de message dans cette liste' ; |
} |
1225,7 → 1234,7 |
} else { |
$sortie_liste = '<div>'.PROJET_PAS_DE_LISTE.'</div>'."\n" ; |
} |
$res .= "<h1>".$projet->getTitre()."</h1>" ; |
$res .= '<div>'.$projet->getDescription().'</div>'."\n" ; |
$res .= '<h2>'.PROJET_WIKI_ASSOCIE.'</h2>' ; |
1234,11 → 1243,11 |
$res .= $vue_liste_document->toHTML() ; |
$res .= '<h2>'.PROJET_LISTES_ASSOCIEES.'</h2>'."\n" ; |
$res .= $sortie_liste ; |
include_once PROJET_CHEMIN_CLASSES.'liste_externe.class.php' ; |
$listes_ext = new liste_externe ($this->_db) ; |
$tableau_liste = $listes_ext->getListesAssociees($this->_id_projet) ; |
if (count ($tableau_liste) != 0) { |
$res .= '<h2>'.PROJET_LISTES_EXTERNES_ASSOCIEES.'</h2>'."\n" ; |
for ($i = 0; $i < count ($tableau_liste); $i++) { |
1285,7 → 1294,7 |
/** |
* Permet d'indiquer au controleur sur quel document on travaille. |
* |
* @param int id_document |
* @param int id_document |
* @return void |
* @access public |
*/ |
1380,23 → 1389,23 |
$formulaire_liste = new HTML_formulaireListe('formulaire_liste', 'post', preg_replace ("/&/", "&", $this->_url->getURL())) ; |
$formulaire_liste->construitFormulaire() ; |
if ($formulaire_liste->validate()) { |
// création de l'objet liste_discussion |
// création de l'objet liste_discussion |
$liste = new liste_discussion('', $this->_db) ; |
// On vérifie que le nom de la liste soit unique |
if (liste_discussion::verifieDoubleListe($formulaire_liste->getSubmitValue('nom_liste').'@'. |
$formulaire_liste->getSubmitValue('domaine_liste'), $this->_db)) { |
// On rajoute la liste dans la base |
// On rajoute la liste dans la base |
$liste->enregistrerSQL($formulaire_liste->getSubmitValues()) ; |
// On la relie au projet |
$projet = new projet ($this->_db, $this->_id_projet) ; |
$projet->ajouterListe($liste) ; |
// Création de la liste |
$resultat_creation = file_get_contents (PROJET_SERVEUR_VPOPMAIL.'/creation_liste.php?domaine='. |
$liste->getDomaine().'&liste='.$liste->getNom().'¶metres=aBiud') ; |
// Ajout du modérateur |
$resultat_ajout_moderateur = file_get_contents (PROJET_SERVEUR_VPOPMAIL.'/ajout_moderateur.php?domaine='. |
$liste->getDomaine().'&liste='.$liste->getNom().'&mail='.$this->_auth->getUserName()) ; |
1408,12 → 1417,12 |
return PROJET_MESSAGE_LISTE_DOUBLE.$formulaire_liste->toHTML() ; |
} |
return $resultat_creation.$resultat_ajout_moderateur.$resultat_ajout_utilisateur; |
} else { |
return $formulaire_liste->toHTML() ; |
} |
} // end of member function nouvelleListeValidation |
/** |
* Supprime la liste de discussion associée au projet |
* |
1424,19 → 1433,19 |
{ |
$projet = new projet($this->_db, $this->_id_projet) ; |
$projet->getListesAssociees() ; |
// ajouter un commande de suppression |
$commande = new commande_serveur(PROJET_CHEMIN_APPLI.'script_cron/ezmlm.sh') ; |
if (PEAR::isError($commande)) { |
echo $commande->getMessage() ; |
} |
// Suppression des listes synchronisés |
$commande_supression_3 = 'rm -rf '.PROJET_CHEMIN_LISTES.$projet->_listes_associes[0]->getDomaine(). |
'/'.$projet->_listes_associes[0]->getNom() ; |
$commande->ajouterCommande($commande_supression_3) ; |
$resultat_suppression = file_get_contents(PROJET_SERVEUR_VPOPMAIL.'/suppression_liste.php?domaine='. |
$projet->_listes_associes[0]->getDomaine().'&liste='.$projet->_listes_associes[0]->getNom()) ; |
$projet->supprimerListe($projet->_listes_associes[0]) ; |
1445,8 → 1454,8 |
/** |
* |
* |
* |
* @param string presentation Pour affecter une présentation au projet |
* @return void |
* @access public |
1457,8 → 1466,8 |
} // end of member function setPresentation |
/** |
* |
* |
* |
* @param string type Pour affecter un type au projet |
* @return void |
* @access public |
1482,13 → 1491,13 |
$titre = '<h1>'.$projet->getTitre().'</h1>'."\n" ; |
$titre .= '<h2>'.PROJET_LISTE_PARTICIPANT.'</h2>'."\n" ; |
$participants = new participe($this->_db) ; |
// On teste ici s'il y a une mise à jour de statut |
if (isset($_POST['statut'])) { |
// $_GET['id_utilisateur'] et $_GET['statut'] proviennent du formulaire voir HTML_listeParticipants |
$participants->setStatut($_POST['statut'], $_GET['id_utilisateur'], $this->_id_projet) ; |
} |
// Ce qui suit doit être amélioré pour sortir la requête sur l'annuaire |
// On teste s'il y a un ajout d'utilisateur voir HTML_listeParticipants |
if (isset($_POST['mail_utilisateur'])) { |
1504,7 → 1513,7 |
$participants->setStatut(3, $ligne[PROJET_CHAMPS_ID], $this->_id_projet) ; |
} |
} |
if ($this->_auth->getAuth()) { |
$statut = participe::getStatutSurProjetCourant($this->_auth->getAuthData(PROJET_CHAMPS_ID), $this->_id_projet, $this->_db) ; |
if ($statut == 2) $droits = PROJET_DROIT_CONTRIBUTEUR ; |
1517,7 → 1526,7 |
$HTML_listeParticipants->setURL($this->_url) ; |
// Construction de l'entete |
$entete = array (PROJET_NOM, PROJET_PRENOM) ; |
if ($this->_auth->getAuth()) { |
array_push ($entete, PROJET_MAIL) ; |
} else { |
1526,11 → 1535,11 |
$info_utilisateur = $participants->getInscrits($this->_id_projet, $droits) ; |
array_push ($entete, PROJET_DATE_INSCRIPTION) ; |
$HTML_listeParticipants->construitEntete($entete) ; |
$HTML_listeParticipants->construitListe($info_utilisateur, statut::getTousLesStatuts(PROJET_STATUT_SAUF_ADM_COORD, $this->_db)) ; |
$res = $HTML_listeParticipants->toHTML() ; |
if ($statut < 2) { |
$res .= PROJET_NOUVEAU_UTILISATEUR_LAIUS ; |
$res .= '<form action="'.$this->_url->getURL().'" method="post">'."\n" ; |
1545,7 → 1554,7 |
$res .= '<p>'.PROJET_TEXTE_NON_IDENTIFIE.'</p>'."\n" ; |
} |
return $titre.$res ; |
} // end of member function voirParticipants |
/** |
1557,13 → 1566,13 |
function inscriptionProjet( ) |
{ |
include_once PROJET_CHEMIN_CLASSES.'HTML_formulaireInscriptionProjet.class.php' ; |
$projet = new projet ($this->_db, $this->_id_projet) ; |
// Si le projet n'a pas de liste, on inscrit directement |
if (isset ($this->_id_projet)) { |
$participant = new participe($this->_db) ; |
if (!$projet->avoirListe()) { |
$participant->setStatut(2, $this->_auth->getAuthData (PROJET_CHAMPS_ID), $this->_id_projet) ; |
return $this->mesProjets() ; |
1582,7 → 1591,7 |
$projet->_listes_associes[0], |
$_POST['radio_inscription_liste']) ; |
} |
if ($this->_presentation != 'arbre') { |
return $this->mesProjets() ; |
} else { |
1649,7 → 1658,7 |
{ |
include_once PROJET_CHEMIN_CLASSES.'participe.class.php' ; |
$participant = new participe($this->_db) ; |
// Le statut 4 désinscrit l'utilisateur, dans la méthode setStatut |
$participant->setStatut(4, $this->_auth->getAuthData (PROJET_CHAMPS_ID), $this->_id_projet) ; |
$projet = new projet ($this->_db, $this->_id_projet) ; |
1677,12 → 1686,13 |
*/ |
function formulaireWiki( ) |
{ |
$res = '<h1>'.PROJET_CREER_WIKI.'</h1>'."\n" ; |
include_once PROJET_CHEMIN_CLASSES.'HTML_formulaireCreationWikini.class.php' ; |
$this->_url->addQueryString(PROJET_VARIABLE_ACTION, PROJET_ACTION_CREER_WIKI_V) ; |
$HTML_formulaireCreationWikini = new HTML_formulaireCreationWikini('formulaire_wikini', 'post', str_replace('&', '&', $this->_url->getURL())) ; |
$HTML_formulaireCreationWikini->construitFormulaire() ; |
return $res.$HTML_formulaireCreationWikini->toHTML() ; |
require_once 'client/integrateur_wikini/bibliotheque/iw_admin_wikini.fonct.php'; |
$this->_url->addQueryString ('act', PROJET_ACTION_CREER_WIKI) ; |
$res =admin_afficherContenuCorps(); |
return $res; |
} // end of member function formulaireWiki |
1689,14 → 1699,14 |
function associerWiki( ) |
{ |
$res = '<h1>'.PROJET_ASSOCIER_WIKI.'</h1>'."\n" ; |
$db = &$GLOBALS['_GEN_commun']['pear_db'] ; |
$db = &$GLOBALS['_GEN_commun']['pear_db'] ; |
$res=''; |
// Comportement par défaut |
// requete sur la table gen_wikini pour affichage de la liste des Wikini |
// requete sur la table gen_wikini pour affichage de la liste des Wikini |
$requete = "select gewi_id_wikini, gewi_code_alpha_wikini, gewi_page from gen_wikini" ; |
$resultat = $db->query ($requete) ; |
if (DB::isError ($resultat)) { |
$GLOBALS['_GEN_commun']['debogage_erreur']->gererErreur(E_USER_WARNING, "Echec de la requete : $requete<br />".$resultat->getMessage(), |
1703,13 → 1713,13 |
__FILE__, __LINE__, 'admin_wikini') ; |
return ; |
} |
$liste = new HTML_TableFragmenteur () ; |
$liste->construireEntete(array (PROJET_NOM_WIKINI,PROJET_PAGE_WIKINI, PROJET_SELECTIONNER_WIKINI)) ; |
$tableau_wikini = array() ; |
while ($ligne = $resultat->fetchRow()) { |
$this->_url->addQueryString ('id_wikini', $ligne[0]) ; |
array_push ($tableau_wikini, array ($ligne[1]."\n", // Première colonne, le nom de l'application |
1720,38 → 1730,11 |
$liste->construireListe($tableau_wikini) ; |
$res .= $liste->toHTML(); |
return $res ; |
} // end of member function formulaireWiki |
/** |
* Génère un wiki, à partir de la classe gestion wiki |
* |
* @return void |
* @access public |
*/ |
function creationWiki( ) |
{ |
include_once PROJET_CHEMIN_CLASSES.'HTML_formulaireCreationWikini.class.php' ; |
$this->_url->addQueryString(PROJET_VARIABLE_ACTION, PROJET_ACTION_CREER_WIKI_V) ; |
$HTML_formulaireCreationWikini = new HTML_formulaireCreationWikini('formulaire_wikini', 'post', str_replace('&', '&', $this->_url->getURL())) ; |
$HTML_formulaireCreationWikini->construitFormulaire() ; |
if ($HTML_formulaireCreationWikini->validate()) { |
include_once PROJET_CHEMIN_CLASSES.'gestion_wikini.class.php' ; |
// On crée une nouvelle connexion avec les paramètres spécifiques aux wikinis |
$connexion_bd = DB::connect('mysql://'.PROJET_UTILISATEUR_WIKINI.':'.PROJET_MDP_WIKINI.'@'.PROJET_HOTE_WIKINI.'/'.PROJET_DB_WIKINI) ; |
$gerantWikini = new gestion_wikini($connexion_bd) ; |
$gerantWikini->creation_tables(strtolower($HTML_formulaireCreationWikini->getSubmitValue('nom_wikini'))) ; |
// On crée un objet avec le projet courant |
$projet = new projet($this->_db, $this->_id_projet) ; |
$projet->majNomWikini($HTML_formulaireCreationWikini->getSubmitValue('nom_wikini')); |
} else { |
return $HTML_formulaireCreationWikini->toHTML() ; |
} |
} // end of member function creationWiki |
/** |
* Associe un wiki au projet courant |
1761,8 → 1744,8 |
*/ |
function associationWiki( ) { |
if (isset($_GET['id_wikini'])) { |
$db = &$GLOBALS['_GEN_commun']['pear_db'] ; |
$requete = "select gewi_code_alpha_wikini from gen_wikini where gewi_id_wikini = ".$_GET['id_wikini'] ; |
1772,12 → 1755,12 |
__FILE__, __LINE__, 'admin_wikini') ; |
return ; |
} |
$ligne = $resultat->fetchRow(); |
$projet = new projet($this->_db, $this->_id_projet) ; |
$projet->majNomWikini($ligne[0]); |
} |
} |
/** |
1834,7 → 1817,7 |
include_once PROJET_CHEMIN_CLASSES.'HTML_formulaireListeExterne.class.php' ; |
$HTML_formulaireListeExterne = new HTML_formulaireListeExterne('formulaire_liste_externe', 'post', str_replace('&', '&', $this->_url->getURL())) ; |
$HTML_formulaireListeExterne->construitFormulaire($liste_externe->getListeNom()) ; |
$liste_externe->enregistrerSQL($HTML_formulaireListeExterne->getSubmitValues(), $this->_id_projet) ; |
} // end of member function referencerListeExterneValidation |