Rev 609 | Blame | Compare with Previous | Last modification | View Log | RSS feed
<?php
/*vim: set expandtab tabstop=4 shiftwidth=4: */
// +------------------------------------------------------------------------------------------------------+
// | PHP version 5.1 |
// +------------------------------------------------------------------------------------------------------+
// | Copyright (C) 2006 Tela Botanica (accueil@tela-botanica.org) |
// +------------------------------------------------------------------------------------------------------+
// | Ce logiciel est un programme informatique servant à gérer du contenu et des applications web. | |
// | |
// | Ce logiciel est régi par la licence CeCILL soumise au droit français et respectant les principes de |
// | diffusion des logiciels libres. Vous pouvez utiliser, modifier et/ou redistribuer ce programme sous |
// | les conditions de la licence CeCILL telle que diffusée par le CEA, le CNRS et l'INRIA sur le site |
// | "http://www.cecill.info". |
// | |
// | En contrepartie de l'accessibilité au code source et des droits de copie, de modification et de |
// | redistribution accordés par cette licence, il n'est offert aux utilisateurs qu'une garantie limitée. |
// | Pour les mêmes raisons, seule une responsabilité restreinte pèse sur l'auteur du programme, le |
// | titulaire des droits patrimoniaux et les concédants successifs. |
// | |
// | A cet égard l'attention de l'utilisateur est attirée sur les risques associés au chargement, à |
// | l'utilisation, à la modification et/ou au développement et à la reproduction du logiciel par |
// | l'utilisateur étant donné sa spécificité de logiciel libre, qui peut le rendre complexe à manipuler |
// | et qui le réserve donc à des développeurs et des professionnels avertis possédant des connaissances |
// | informatiques approfondies. Les utilisateurs sont donc invités à charger et tester l'adéquation |
// | du logiciel à leurs besoins dans des conditions permettant d'assurer la sécurité de leurs systèmes |
// | et ou de leurs données et, plus généralement, à l'utiliser et l'exploiter dans les mêmes conditions |
// | de sécurité. |
// | |
// | Le fait que vous puissiez accéder à cet en-tête signifie que vous avez pris connaissance de la |
// | licence CeCILL, et que vous en avez accepté les termes. |
// +------------------------------------------------------------------------------------------------------+
// CVS : $Id: categorie.php,v 1.5 2006/12/12 13:32:00 jp_milcent Exp $
/**
* Applette : Stat Distribution
*
* Retourne les statistiques de distribution des inscrits à Tela Botanica sous différentes formes.
*
*@package Applette
*@subpackage stat_distribution
//Auteur original :
*@author Jean-Pascal MILCENT <jpm@tela-botanica.org>
//Autres auteurs :
*@author Aucun
*@copyright Tela-Botanica 2000-2007
*@version $Revision$ $Date$
// +------------------------------------------------------------------------------------------------------+
*/
// +------------------------------------------------------------------------------------------------------+
// | ENTÊTE du PROGRAMME |
// +------------------------------------------------------------------------------------------------------+
$GLOBALS['_GEN_commun']['info_applette_nom_fonction'] = 'afficherStatDistribution';
$GLOBALS['_GEN_commun']['info_applette_balise'] = '\{\{[Ss]tatDistribution(?:\s*(?:(format="[^"]+")|(niveau="[^"]+")|))+\s*\}\}';//;
// --------------------------------------------------------------------------------------------------------
//Utilisation de la bibliothèque Papyrus pap_meta.fonct.php inclue par Papyrus
//Utilisation de la bibliothèque PEAR NET_URL inclue par Papyrus
/** Inclusion du fichier de configuration de cette application.*/
require_once GEN_CHEMIN_CLIENT.'stat_distribution'.GEN_SEP.'configuration'.GEN_SEP.'stdi_configuration.inc.php';
// Inclusion des fichiers de traduction de l'applette CATEG de Papyrus
if (file_exists(STDI_CHEMIN_LANGUE.'stdi_langue_'.$GLOBALS['_GEN_commun']['i18n'].'.inc.php')) {
/** Inclusion du fichier de traduction suite à la transaction avec le navigateur.*/
require_once STDI_CHEMIN_LANGUE.'stdi_langue_'.$GLOBALS['_GEN_commun']['i18n'].'.inc.php';
} else {
/** Inclusion du fichier de traduction par défaut.*/
require_once STDI_CHEMIN_LANGUE.'stdi_langue_'.STDI_I18N_DEFAUT.'.inc.php';
}
// +------------------------------------------------------------------------------------------------------+
// | CORPS du PROGRAMME |
// +------------------------------------------------------------------------------------------------------+
// En attendant de pouvoir utiliser le nouveaux système d'appllet de la branche principale de Papyrus
function afficherContenuCorps()
{
$tab_applette_arguments[1] = 'format='.$GLOBALS['_GEN_commun']['info_application']->format;
$tab_applette_arguments[2] = 'niveau='.$GLOBALS['_GEN_commun']['info_application']->niveau;
return afficherStatDistribution($tab_applette_arguments, $GLOBALS['_GEN_commun']);
}
/** Fonction afficherStatDistribution() - Retourne les stats de distribution.
*
* Cette fonction Retourne les statistiques de distribution des inscrits à Tela Botanica sous différentes formes.
*
* @param array contient les arguments de la fonction.
* @param array tableau global de Papyrus.
* @return string HTML les stats de distribution.
*/
function afficherStatDistribution($tab_applette_arguments, $_GEN_commun)
{
// Initialisation des variables
$sortie = '';
//+----------------------------------------------------------------------------------------------------------------+
// Gestion des arguments
$tab_arguments = $tab_applette_arguments;
unset($tab_arguments[0]);
foreach($tab_arguments as $argument) {
$tab_parametres = explode('=', $argument);
$options[$tab_parametres[0]] = trim($tab_parametres[1], '"');
}
//+----------------------------------------------------------------------------------------------------------------+
// Gestion des erreurs de paramètrage
$GLOBALS['_STAT_DISTRIBUTION_']['erreur'] = '';
if (!isset($options['format'])) {
$GLOBALS['_STAT_DISTRIBUTION_']['erreur'] = STDI_LG_ERREUR_FORMAT;
}
if (!isset($options['niveau'])) {
$GLOBALS['_STAT_DISTRIBUTION_']['erreur'] = STDI_LG_ERREUR_NIVEAU;
}
//+----------------------------------------------------------------------------------------------------------------+
// Récupération des données
switch ($options['niveau']) {
case 'europe' :
$tab_legende_fr = array();
$tab_legende_ss_fr = array();
$tab_donnees_fr = array() ;
$tab_donnees_ss_fr = array() ;
$total_autre = 0;
$requete = 'SELECT CP_ID_Pays, CP_Intitule_pays, COUNT(CP_ID_Pays) AS nbre '.
'FROM annuaire_tela, carto_PAYS '.
'WHERE U_COUNTRY = CP_ID_Pays '.
'AND CP_ID_Continent = 4 '.
'GROUP BY CP_ID_Pays '.
'ORDER BY nbre DESC';
$GLOBALS['_STAT_DISTRIBUTION_']['titre'] = 'Répartition des inscrits à Tela Botanica en Europe';
break;
case 'monde' :
$requete = 'SELECT CC_ID_Continent, CC_Intitule_continent, COUNT(CC_ID_Continent) AS nbre '.
'FROM annuaire_tela, carto_PAYS, carto_CONTINENT '.
'WHERE U_COUNTRY = CP_ID_Pays '.
'AND CP_ID_Continent = CC_ID_Continent '.
'GROUP BY CC_ID_Continent ';
$GLOBALS['_STAT_DISTRIBUTION_']['titre'] = 'Répartition des inscrits à Tela Botanica dans le monde';
break;
}
$resultat = $GLOBALS['db']->query($requete) ;
while ($ligne = $resultat->fetchRow(DB_FETCHMODE_OBJECT)) {
switch ($options['niveau']) {
case 'europe' :
$id = $ligne->CP_ID_Pays;
$legende_libelle = $ligne->CP_Intitule_pays.' (%1.2f%%)';
$libelle = $ligne->CP_Intitule_pays.' ['.$id.']';
$nbre = $ligne->nbre;
if ($id != 'fr' && $id != 'FR') {
$tab_donnees_ss_fr[] = $nbre;
$tab_legende_ss_fr[] = $legende_libelle;
$total_autre += $nbre;
$tab_donnees_fr[1] += $nbre;
$tab_legende_fr[1] = 'Autres pays européens (%1.2f%%)';
} else {
$tab_donnees_fr[0] = $nbre;
$tab_legende_fr[0] = $legende_libelle;
}
break;
case 'monde' :
$id = $ligne->CC_ID_Continent;
$legende_libelle = '['.$id.'] '.$ligne->CC_Intitule_continent.' (%1.2f%%)';
$libelle = $ligne->CC_Intitule_continent.' ['.$id.']';
$nbre = $ligne->nbre;
$tab_donnees[$id] = $ligne->nbre;
if (!isset($legende[$id])) {
$tab_legende[$id] = $legende_libelle;
}
break;
}
$GLOBALS['_STAT_DISTRIBUTION_']['tab_donnees'][$id]['libelle'] = $libelle;
$GLOBALS['_STAT_DISTRIBUTION_']['tab_donnees'][$id]['nombre'] = $nbre;
$total += $nbre;
}
foreach ($GLOBALS['_STAT_DISTRIBUTION_']['tab_donnees'] as $id => $val) {
$GLOBALS['_STAT_DISTRIBUTION_']['tab_donnees'][$id]['pourcentage'] = round($val['nombre']/$total*100, 2).' %';
}
//+----------------------------------------------------------------------------------------------------------------+
// Extrait les variables et les ajoutes à l'espace de noms local
// Gestion des squelettes
extract($GLOBALS['_STAT_DISTRIBUTION_']);
// Démarre le buffer
ob_start();
// Inclusion du fichier
include(STDI_CHEMIN_SQUELETTE.STDI_SQUELETTE_LISTE);
// Récupérer le contenu du buffer
$sortie = ob_get_contents();
// Arrête et détruit le buffer
ob_end_clean();
//+----------------------------------------------------------------------------------------------------------------+
// Sortie
return $sortie;
}
// +------------------------------------------------------------------------------------------------------+
// | LISTE DES FONCTIONS |
// +------------------------------------------------------------------------------------------------------+
/* +--Fin du code ----------------------------------------------------------------------------------------+
*
* $Log$
*
* +-- Fin du code ----------------------------------------------------------------------------------------+
*/
?>