2010-03-08 16:01:16 +00:00
|
|
|
<?php
|
|
|
|
|
2010-03-30 09:58:23 +00:00
|
|
|
function commentaires_siren($content){
|
2010-05-27 09:41:20 +00:00
|
|
|
$pattern = '/(.*?)<siren>([0-9]{3})(?: )?([0-9]{3})(?: )?([0-9]{3})<\/siren>(.*?)/i';
|
2010-04-19 07:07:03 +00:00
|
|
|
$replace = '$1<a href=/?page=identite&siret=$2$3$4>$2 $3 $4</a>$5';
|
2010-03-30 09:58:23 +00:00
|
|
|
$output = preg_replace($pattern, $replace, $content);
|
|
|
|
return $output;
|
|
|
|
}
|
|
|
|
|
2010-04-01 08:51:39 +00:00
|
|
|
function commentaires_liste($content){
|
2010-07-08 08:46:04 +00:00
|
|
|
$output = $content;
|
2010-07-02 07:19:16 +00:00
|
|
|
$pattern = '/(.*?)<li([:|\=|\+|-]?)>(.*)/i';
|
2010-07-07 13:25:46 +00:00
|
|
|
$pattern_all = '/<li([:|\=|\+|-]?)>(.*)(?:<br\/>)/isU';
|
|
|
|
preg_match_all($pattern_all, $content, $listes);
|
|
|
|
if ( isset($listes[0]) && count($listes[0])>0 ){
|
2010-08-17 07:55:20 +00:00
|
|
|
//FB::log($listes, 'listes');
|
2010-07-08 08:46:04 +00:00
|
|
|
|
2010-07-07 13:25:46 +00:00
|
|
|
foreach ( $listes[0] as $index => $elementR ){
|
|
|
|
$output = commentaires_liste_replace($elementR, $listes[2][$index],
|
|
|
|
$listes[1][$index], $output);
|
2010-08-17 07:55:20 +00:00
|
|
|
//FB::log($output, 'output');
|
2010-07-07 13:25:46 +00:00
|
|
|
}
|
|
|
|
} elseif ( preg_match($pattern, $content, $matches) ){
|
2010-08-17 07:55:20 +00:00
|
|
|
//FB::log($content, 'liste');
|
2010-04-01 08:51:39 +00:00
|
|
|
switch($matches[2]){
|
|
|
|
case '+':
|
2010-07-07 13:25:46 +00:00
|
|
|
$replace = '$1<span class="plus">$3</span>';
|
2010-04-01 08:51:39 +00:00
|
|
|
break;
|
|
|
|
case '-':
|
2010-07-07 13:25:46 +00:00
|
|
|
$replace = '$1<span class="moins">$3</span>';
|
2010-04-01 08:51:39 +00:00
|
|
|
break;
|
2010-04-16 16:00:15 +00:00
|
|
|
case '=':
|
2010-04-16 16:44:44 +00:00
|
|
|
$replace = '$1<image style="vertical-align:middle;" src="./img/li-egale.gif">$3';
|
2010-04-16 16:00:15 +00:00
|
|
|
break;
|
2010-07-02 07:19:16 +00:00
|
|
|
case ':':
|
|
|
|
$replace = '$1<span>$3</span>';
|
|
|
|
break;
|
2010-04-01 08:51:39 +00:00
|
|
|
default:
|
2010-07-07 13:25:46 +00:00
|
|
|
$replace = '$1<span class="point">$3</span>';
|
2010-04-01 08:51:39 +00:00
|
|
|
break;
|
|
|
|
}
|
2010-07-07 13:25:46 +00:00
|
|
|
$output = preg_replace($pattern, $replace, $content);
|
2010-04-01 08:51:39 +00:00
|
|
|
}
|
|
|
|
return $output;
|
|
|
|
}
|
|
|
|
|
2010-07-07 13:25:46 +00:00
|
|
|
function commentaires_liste_replace($elementR, $element, $type, $content){
|
|
|
|
switch ( $type ){
|
|
|
|
case '+':
|
|
|
|
$replace = '<span class="plus">'.$element.'</span><br/>';
|
|
|
|
break;
|
|
|
|
case '-':
|
|
|
|
$replace = '<span class="moins">'.$element.'</span><br/>';
|
|
|
|
break;
|
|
|
|
case '=':
|
|
|
|
$replace = '<image style="vertical-align:middle;" src="./img/li-egale.gif">'.$matches[2].'<br/>';
|
|
|
|
break;
|
|
|
|
case ':':
|
|
|
|
$replace = '<span>'.$element.'</span><br/>';
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
$replace = '<span class="point">'.$element.'</span><br/>';
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
$output = str_replace($elementR, $replace, $content);
|
|
|
|
return $output;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2010-04-01 08:51:39 +00:00
|
|
|
function commentaires_image($content){
|
2010-04-01 09:50:47 +00:00
|
|
|
$pattern = '/IMAGE\((.*?)\)/i';
|
|
|
|
preg_match($pattern, $content, $matches);
|
2010-04-02 14:29:37 +00:00
|
|
|
$replace = '<img src="./img/commentaires/'.strtolower($matches[1]).'"/>';
|
2010-04-01 09:50:47 +00:00
|
|
|
$output = str_replace($matches[0], $replace, $content);
|
|
|
|
return $output;
|
2010-04-01 08:51:39 +00:00
|
|
|
}
|
|
|
|
|
2010-03-30 09:58:23 +00:00
|
|
|
function commentaires_lien($content){
|
|
|
|
$path = array(
|
2010-10-29 08:12:29 +00:00
|
|
|
'pdf' => '/fichier/commentaires',
|
2010-04-15 14:24:35 +00:00
|
|
|
'html' => '',
|
2010-03-30 09:58:23 +00:00
|
|
|
);
|
2010-03-30 13:58:13 +00:00
|
|
|
$pattern = "/<lien='(.*?).(pdf|html|htm)'>(.*?)<\/lien>/i";
|
2010-03-30 09:58:23 +00:00
|
|
|
preg_match($pattern, $content, $matches);
|
|
|
|
if(count($matches)>0){
|
|
|
|
switch($matches[2]){
|
|
|
|
case 'pdf':
|
2010-03-30 10:17:20 +00:00
|
|
|
$content = str_replace(
|
|
|
|
$matches[0],
|
|
|
|
"<a href='".$path['pdf']."/".$matches[1].".".
|
|
|
|
$matches[2]."' target='_blank'>".
|
|
|
|
$matches[3]."</a>",
|
|
|
|
$content);
|
2010-03-30 09:58:23 +00:00
|
|
|
break;
|
2010-03-30 13:58:13 +00:00
|
|
|
case 'htm':
|
|
|
|
case 'html':
|
|
|
|
$content = str_replace(
|
|
|
|
$matches[0],
|
2010-04-15 14:24:35 +00:00
|
|
|
"<a href='".$path['html'].$matches[1].".".
|
2010-03-30 13:58:13 +00:00
|
|
|
$matches[2]."' target='_blank'>".
|
|
|
|
$matches[3]."</a>",
|
|
|
|
$content);
|
|
|
|
break;
|
2010-03-30 09:58:23 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
return $content;
|
|
|
|
}
|
2010-03-08 16:01:16 +00:00
|
|
|
|
2010-06-15 14:38:21 +00:00
|
|
|
function commentaires_graphique_couleur($content){
|
2010-06-21 17:02:19 +00:00
|
|
|
$graphCouleurs = array();
|
2010-06-15 14:38:21 +00:00
|
|
|
//Association des couleurs Nom => code Hexa
|
|
|
|
$assocNomCouleurs = array(
|
2010-06-21 17:02:19 +00:00
|
|
|
'BLA' => 0xFFFFFF,
|
|
|
|
'BLA1' => 0xFFFAFA,
|
|
|
|
'BLA2' => 0xF0FFFF,
|
|
|
|
'BLA3' => 0xFFFFF0,
|
|
|
|
'BLE' => 0x0000FF,
|
|
|
|
'BLE1' => 0x00BFFF,
|
|
|
|
'BLE2' => 0x00008B,
|
|
|
|
'BLE3' => 0x87F0FA,
|
2010-12-10 15:14:54 +00:00
|
|
|
'JAU' => 0xFFF000,
|
2010-06-21 17:02:19 +00:00
|
|
|
'JAU1' => 0xFFEFD5,
|
|
|
|
'JAU2' => 0xFFA500,
|
|
|
|
'JAU3' => 0xFFFFE0,
|
|
|
|
'LUM' => 0xADFF2F,
|
|
|
|
'LUM1' => 0x00FFFF,
|
|
|
|
'LUM2' => 0xFF00FF,
|
|
|
|
'LUM3' => 0xF0FFF0,
|
|
|
|
'MAR' => 0xD2691E,
|
|
|
|
'MAR1' => 0xF4A460,
|
|
|
|
'MAR2' => 0x8B4513,
|
|
|
|
'MAR3' => 0xF5DEB3,
|
|
|
|
'MET' => 0xFFD700,
|
|
|
|
'MET1' => 0xFFF8DC,
|
|
|
|
'MET2' => 0xC0C0C0,
|
|
|
|
'MET3' => 0xFDF5E6,
|
|
|
|
'NOI' => 0x000000,
|
|
|
|
'NOI1' => 0x808080,
|
|
|
|
'NOI2' => 0x2F4F4F,
|
|
|
|
'NOI3' => 0xDCDCDC,
|
|
|
|
'ROU' => 0xFF0000,
|
|
|
|
'ROU1' => 0xFF7F50,
|
|
|
|
'ROU2' => 0xB22222,
|
|
|
|
'ROU3' => 0xFFDAB9,
|
|
|
|
'VER' => 0x228B22,
|
|
|
|
'VER1' => 0x66CDAA,
|
|
|
|
'VER2' => 0x066400,
|
|
|
|
'VER3' => 0x98FB98,
|
|
|
|
'VIO' => 0xC71585,
|
|
|
|
'VIO1' => 0xEE82EE,
|
|
|
|
'VIO2' => 0x8B008B,
|
|
|
|
'VIO3' => 0xFFF0F5,
|
2010-06-15 14:38:21 +00:00
|
|
|
);
|
2010-06-21 17:02:19 +00:00
|
|
|
$pattern = '/COULEUR\((.*)\)/i';
|
|
|
|
///Detection couleur
|
2010-06-15 14:38:21 +00:00
|
|
|
if ( preg_match($pattern, $content, $matches) ) {
|
2010-09-20 10:30:56 +00:00
|
|
|
//FB::log($content, 'DETECTION Couleurs');
|
2010-06-21 17:02:19 +00:00
|
|
|
$listeCouleurs = $matches[1];
|
|
|
|
//Récupération des couleurs
|
|
|
|
$pattern = '/([a-z0-9]{3,4})/i';
|
|
|
|
if ( preg_match_all($pattern, $listeCouleurs, $matches) ) {
|
2010-07-02 07:19:16 +00:00
|
|
|
//FB::log($matches, 'matches');
|
2010-06-21 17:02:19 +00:00
|
|
|
$nbCouleurs = count($matches[1]);
|
2010-09-06 07:06:52 +00:00
|
|
|
for($i=0;$i<$nbCouleurs;$i++){
|
2010-06-21 17:02:19 +00:00
|
|
|
$graphCouleurs[] = $assocNomCouleurs[$matches[1][$i]];
|
|
|
|
}
|
2010-06-15 14:38:21 +00:00
|
|
|
}
|
|
|
|
}
|
2010-09-20 10:30:56 +00:00
|
|
|
//FB::log($graphCouleurs,' DETECTION : graphCouleurs');
|
2010-06-15 14:38:21 +00:00
|
|
|
return $graphCouleurs;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2011-03-31 15:02:48 +00:00
|
|
|
function commentaires_graphique($content)
|
|
|
|
{
|
|
|
|
global $siret, $siren, $idEntreprise; //FB::log($content, 'G');
|
|
|
|
$pattern = '/\[GRAPHIQUE id=(.*?) titre=\'(.*?)\',(.*)\]/';
|
2010-06-04 08:58:26 +00:00
|
|
|
if( preg_match($pattern, $content, $matches) ){
|
2010-07-07 13:25:46 +00:00
|
|
|
//FB::log($matches,'graphique');
|
2010-06-04 08:58:26 +00:00
|
|
|
$image_id = $matches[1];
|
|
|
|
$titre = $matches[2];
|
|
|
|
//Génération id/nom fichier graphique
|
|
|
|
if (($siret*1)==0 || ($siren*1)<100){
|
|
|
|
$id = 'gcomment-'.$idEntreprise.'-'.$image_id;
|
|
|
|
}else{
|
|
|
|
$id = 'gcomment-'.$siret.'-'.$image_id;
|
|
|
|
}
|
|
|
|
|
|
|
|
//Determine le type du graphique
|
|
|
|
$type = '';
|
|
|
|
$typePattern = array(
|
2011-03-31 15:02:48 +00:00
|
|
|
'projection' => '/(R\[.*\]#H,.*_Y#L)/',
|
|
|
|
'stacked' => '/((R\[.*\]#HS,?){1,};?){1,}/',
|
|
|
|
'histo' => '/(Rs?\[.*\]#[H|L],?){1,}/',
|
|
|
|
'radar' => '/(R\[.*\]#R,?){1,}/',
|
2010-06-04 08:58:26 +00:00
|
|
|
);
|
|
|
|
foreach($typePattern as $type => $pattern){
|
|
|
|
if (preg_match($pattern,$matches[3], $match_type)>0){
|
2010-07-07 13:25:46 +00:00
|
|
|
//FB::log($match_type, $type);
|
2010-06-04 08:58:26 +00:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
2010-09-20 10:30:56 +00:00
|
|
|
|
2011-03-31 15:02:48 +00:00
|
|
|
//FB::log($type, 'Graphique');
|
2010-09-20 10:30:56 +00:00
|
|
|
|
2010-06-04 08:58:26 +00:00
|
|
|
switch($type){
|
|
|
|
case 'histo':
|
|
|
|
$image_file = commentaires_graph_histo($id, $titre, $matches[3]);
|
|
|
|
break;
|
|
|
|
case 'radar':
|
2010-06-15 14:38:21 +00:00
|
|
|
$image_file = commentaires_graph_radar($id, $titre, $matches[3]);
|
2010-06-04 08:58:26 +00:00
|
|
|
break;
|
|
|
|
case 'stacked':
|
|
|
|
$image_file = commentaires_graph_stacked($id, $titre, $matches[3]);
|
|
|
|
break;
|
2010-06-15 14:38:21 +00:00
|
|
|
case 'projection':
|
2010-07-02 13:00:48 +00:00
|
|
|
$image_file = commentaires_graph_histo($id, $titre, $matches[3]);
|
2010-06-15 14:38:21 +00:00
|
|
|
break;
|
2010-06-04 08:58:26 +00:00
|
|
|
default:
|
2010-06-15 14:38:21 +00:00
|
|
|
$image_file = 'Erreur';
|
2010-06-04 08:58:26 +00:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
//Le fichier image existe
|
2011-02-21 14:01:29 +00:00
|
|
|
if( file_exists(PATH_SITE.'/cache/pages/imgcache/'.$image_file) ){
|
2010-06-04 08:58:26 +00:00
|
|
|
$content = str_replace(
|
|
|
|
$matches[0],
|
2011-02-21 15:06:17 +00:00
|
|
|
'<img src="./fichier/imgcache/'.$image_file.'" />',
|
2010-06-04 08:58:26 +00:00
|
|
|
$content);
|
|
|
|
}else{
|
|
|
|
$content = str_replace(
|
|
|
|
$matches[0],
|
|
|
|
'Erreur génération graphique',
|
|
|
|
$content);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return $content;
|
|
|
|
}
|
|
|
|
|
2010-06-08 17:34:17 +00:00
|
|
|
function commentaires_graph_stacked($id, $titre, $strRatios) {
|
2010-06-15 14:38:21 +00:00
|
|
|
global $bilansInfos, $ratiosEntrep, $ratiosSecteur, $ratiosInfos,
|
|
|
|
$graphCouleurs;
|
2011-02-21 14:01:29 +00:00
|
|
|
$path = PATH_SITE.'/cache/pages/imgcache/';
|
2010-08-03 15:56:45 +00:00
|
|
|
$file = $id.'.png';
|
|
|
|
if( cache_graph($path.$file) ){
|
|
|
|
$output = $file;
|
2010-06-15 14:38:21 +00:00
|
|
|
} else {
|
2010-09-06 07:06:52 +00:00
|
|
|
$couleurs = array();
|
2010-08-03 15:56:45 +00:00
|
|
|
if(count($graphCouleurs)>0){
|
|
|
|
$couleurs = $graphCouleurs;
|
|
|
|
} else {
|
|
|
|
$couleurs = array(
|
|
|
|
0xaaaaff,
|
|
|
|
0x6666ff,
|
|
|
|
0x3cb371, /*medium sea green*/
|
|
|
|
0xff8080,
|
|
|
|
0x000000, /*noir*/
|
|
|
|
/*0x80ff80,*/
|
|
|
|
0xffe4c4, /*abricot*/
|
|
|
|
0xbc8f8f, /*rosy brown*/
|
|
|
|
0xc0c0c0, /*silver*/
|
|
|
|
0xfffff0, /*ivoire*/
|
|
|
|
/*0xf0ffff, /*azure*/
|
|
|
|
0xff7f50, /*coral*/
|
|
|
|
0xa0522d, /*marron*/
|
|
|
|
0xffd700, /*gold*/
|
|
|
|
0x8866ff,
|
|
|
|
0x0000cd, /*blue*/
|
|
|
|
0xee82e2, /*violet*/
|
|
|
|
);
|
|
|
|
}
|
2010-06-08 17:34:17 +00:00
|
|
|
|
2010-08-03 15:56:45 +00:00
|
|
|
//Tri des bilans
|
|
|
|
foreach ($bilansInfos as $key => $row) {
|
|
|
|
$bilansInfos[$key]['cle'] = $key;
|
|
|
|
$date[$key] = $row['dateCloture'];
|
|
|
|
$duree[$key] = $row['duree'];
|
|
|
|
$devise[$key] = $row['devise'];
|
|
|
|
$unite[$key] = $row['unite'];
|
|
|
|
$cle[$key] = $row['cle'];
|
|
|
|
}
|
|
|
|
array_multisort(
|
|
|
|
$date, SORT_DESC,
|
|
|
|
$duree, SORT_DESC,
|
|
|
|
$devise, SORT_DESC,
|
|
|
|
$unite, SORT_DESC,
|
|
|
|
$cle, SORT_DESC,
|
|
|
|
$bilansInfos);
|
2010-06-08 17:34:17 +00:00
|
|
|
|
2010-08-03 15:56:45 +00:00
|
|
|
$index = $bilansInfos[0]['cle'];
|
|
|
|
$dateCloture = substr($bilansInfos[0]['dateCloture'],0,4);
|
2010-06-08 17:34:17 +00:00
|
|
|
|
2010-08-03 15:56:45 +00:00
|
|
|
//Génération du graphique
|
|
|
|
require_once 'phpchartdir/phpchartdir.php';
|
|
|
|
$c = new XYChart(548, 300);
|
|
|
|
$c->addTitle($titre, 'times.ttf', 10);
|
|
|
|
$c->setPlotArea(70, 30, 200, 200);
|
|
|
|
$legendObj = $c->addLegend2(300, 50, -2, "times.ttf", 9);
|
|
|
|
$legendObj->setBackground(Transparent, Transparent);
|
|
|
|
$labels = array($dateCloture);
|
|
|
|
$c->xAxis->setLabels($labels);
|
|
|
|
$layer = $c->addBarLayer2(Stack);
|
|
|
|
$layer->setBorderColor(Transparent, softLighting(Left));
|
|
|
|
$cpt_couleur = 0;
|
|
|
|
$pattern = '/(Rs?)\[(.*)]#.{1}/';
|
|
|
|
$ratios = explode(';', $strRatios);
|
|
|
|
$div = 1;
|
|
|
|
foreach ( $ratios as $indexGroup => $groupRatios ){
|
|
|
|
$stackRatios = explode(',', $groupRatios);
|
|
|
|
$layer->addDataGroup('Group'.$indexGroup);
|
|
|
|
//Analyse pour unité correcte
|
|
|
|
foreach ( $stackRatios as $ratio ){
|
|
|
|
preg_match($pattern, $ratio, $matches);
|
|
|
|
$value = $ratiosEntrep[$index]['r'.$matches[2]];
|
|
|
|
if ( !isset($dUnite) ) {
|
|
|
|
$dUnite = $ratiosInfos['r'.$matches[2]]['unite'];
|
|
|
|
}
|
|
|
|
if ( $dUnite == 'EUR' ){
|
|
|
|
if ( $div<1000000 && abs($value)/1000000>0 ){
|
|
|
|
$dUnite = 'M EUR';
|
|
|
|
$div = 1000000;
|
|
|
|
} elseif ( $div<1000 && abs($value)/1000>0 ){
|
|
|
|
$dUnite = 'K EUR';
|
|
|
|
$div = 1000;
|
|
|
|
}
|
2010-07-12 13:04:00 +00:00
|
|
|
}
|
|
|
|
}
|
2010-08-03 15:56:45 +00:00
|
|
|
//Assignation valeur
|
|
|
|
foreach ( $stackRatios as $ratio ){
|
|
|
|
preg_match($pattern, $ratio, $matches);
|
|
|
|
$value = $ratiosEntrep[$index]['r'.$matches[2]]/$div;
|
2010-09-06 07:06:52 +00:00
|
|
|
FB::log($couleurs[$cpt_couleur], 'Couleur r'.$matches[2]);
|
2010-08-03 15:56:45 +00:00
|
|
|
$titre = htmlspecialchars_decode(
|
|
|
|
$ratiosInfos['r'.$matches[2]]['libelle'],ENT_QUOTES);
|
2010-09-06 07:06:52 +00:00
|
|
|
|
|
|
|
|
2010-08-03 15:56:45 +00:00
|
|
|
$layer->addDataSet(array($value), $couleurs[$cpt_couleur], $titre);
|
|
|
|
$cpt_couleur++;
|
|
|
|
if($cpt_couleur>=count($couleurs)) { $cpt_couleur=0; }
|
|
|
|
}
|
2010-07-12 13:04:00 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2010-08-03 15:56:45 +00:00
|
|
|
if ( !isset($dUnite) ) { $dUnite = 'EUR'; }
|
|
|
|
$layer->setBarGap(0.2, 0);
|
|
|
|
$c->yAxis->setAutoScale(0.2);
|
|
|
|
$c->yAxis->setTitle($dUnite);
|
|
|
|
$c->yAxis->setWidth(2);
|
|
|
|
$c->xAxis->setTitle('Années');
|
|
|
|
$c->xAxis->setWidth(2);
|
|
|
|
$c->xAxis->setLabels($labelsX);
|
|
|
|
if ( $c->makeChart($path.$file) === true ){
|
|
|
|
$output = $file;
|
|
|
|
} else {
|
|
|
|
$output = false;
|
|
|
|
}
|
2010-06-08 17:34:17 +00:00
|
|
|
}
|
|
|
|
return $output;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2010-06-04 08:58:26 +00:00
|
|
|
function commentaires_graph_histo($id, $titre, $strRatios){
|
2010-07-05 12:49:54 +00:00
|
|
|
global $graphCouleurs, $bilansInfos, $ratiosEntrep, $ratiosSecteur,
|
2010-07-12 13:04:00 +00:00
|
|
|
$tabProjection, $ratiosInfos;
|
2011-02-21 14:01:29 +00:00
|
|
|
$path = PATH_SITE.'/cache/pages/imgcache/';
|
2010-08-03 15:56:45 +00:00
|
|
|
$file = $id.'.png';
|
2010-09-20 12:25:25 +00:00
|
|
|
if( cache_graph($path.$file) ){
|
2010-08-03 15:56:45 +00:00
|
|
|
$output = $file;
|
2010-06-15 14:38:21 +00:00
|
|
|
} else {
|
2010-08-03 15:56:45 +00:00
|
|
|
//Gestion des couleurs
|
|
|
|
if(count($graphCouleurs)>0){
|
|
|
|
$couleurs = $graphCouleurs;
|
|
|
|
} else {
|
|
|
|
$couleurs = array(0xff8080, 0x80ff80, 0x8080ff);
|
|
|
|
}
|
|
|
|
$ratios = explode(',', $strRatios);
|
|
|
|
$data = array();
|
|
|
|
$dataInfos = array();
|
|
|
|
$nbRatio = 0;
|
|
|
|
//Détection des ratios
|
|
|
|
$patternR = '/(Rs?)\[(.*)]#(.{1})/';
|
|
|
|
$patternP = '/(.*)_Y#(.{1})/';
|
|
|
|
foreach ( $ratios as $ratio ) {
|
|
|
|
//Ratios secteur et entreprise
|
|
|
|
if( preg_match($patternR, $ratio, $matches) ){
|
|
|
|
$typeRatio = $matches[1];
|
|
|
|
$numRatio = $matches[2];
|
|
|
|
$titreRatio = commentaires_graph_lib($numRatio);
|
|
|
|
$unite = $ratiosInfos['r'.$numRatio]['unite'];
|
|
|
|
$div = 1;
|
|
|
|
switch ( $typeRatio ){
|
|
|
|
case 'R' :
|
|
|
|
$titreRatio.= ' - Entreprise';
|
|
|
|
$tabRatio = $ratiosEntrep;
|
|
|
|
break;
|
|
|
|
case 'Rs' :
|
|
|
|
$titreRatio.= ' - Secteur';
|
|
|
|
$tabRatio = $ratiosSecteur;
|
|
|
|
break;
|
|
|
|
}
|
2010-07-05 12:49:54 +00:00
|
|
|
|
2010-08-03 15:56:45 +00:00
|
|
|
//Informations données
|
|
|
|
$dataInfos[$nbRatio] = array(
|
|
|
|
'titre' => $titreRatio,
|
|
|
|
'style' => $matches[3],
|
|
|
|
);
|
2010-07-05 12:49:54 +00:00
|
|
|
|
2010-08-03 15:56:45 +00:00
|
|
|
//Assignation données
|
|
|
|
$xPrec = 0;
|
|
|
|
foreach ( $tabRatio as $key => $valRatio ){
|
2010-09-20 12:25:25 +00:00
|
|
|
$index = (int)substr($bilansInfos[$key]['dateCloture'],0,4);
|
2010-08-03 15:56:45 +00:00
|
|
|
($xPrec != 0) ? $diff = $xPrec-$index : $diff = 1;
|
2010-09-20 10:30:56 +00:00
|
|
|
if ($diff != 0){
|
2010-08-03 15:56:45 +00:00
|
|
|
$data[$index][$nbRatio] = $valRatio['r'.$numRatio];
|
|
|
|
if ( $unite == 'EUR' ){
|
|
|
|
if ( $div<1000000 && abs($valRatio['r'.$numRatio])/1000000>0 ){
|
|
|
|
$unite = 'M EUR';
|
|
|
|
$div = 1000000;
|
|
|
|
} elseif ( $div<1000 && abs($valRatio['r'.$numRatio])/1000>0 ){
|
|
|
|
$unite = 'K EUR';
|
|
|
|
$div = 1000;
|
|
|
|
}
|
2010-07-12 13:04:00 +00:00
|
|
|
}
|
|
|
|
}
|
2010-08-03 15:56:45 +00:00
|
|
|
$xPrec = $index;
|
2010-07-02 13:00:48 +00:00
|
|
|
}
|
2010-08-03 15:56:45 +00:00
|
|
|
$nbRatio++;
|
|
|
|
//Ratios de projection
|
|
|
|
} elseif ( preg_match($patternP, $ratio, $matches) ){
|
2010-03-08 16:01:16 +00:00
|
|
|
|
2010-08-03 15:56:45 +00:00
|
|
|
$titreRatio = $matches[1];
|
|
|
|
$dataInfos[$nbRatio] = array(
|
|
|
|
'titre' => $titreRatio.' - Projection',
|
|
|
|
'style' => $matches[2],
|
|
|
|
);
|
|
|
|
$tabRatio = $tabProjection[$titreRatio.'_Y'];
|
|
|
|
krsort($tabRatio);
|
|
|
|
foreach ( $tabRatio as $key => $valRatio ){
|
|
|
|
$index = (int)substr($key,0,4);
|
|
|
|
$data[$index][$nbRatio] = $valRatio;
|
|
|
|
}
|
|
|
|
$nbRatio++;
|
2010-07-05 12:49:54 +00:00
|
|
|
}
|
2010-07-02 13:00:48 +00:00
|
|
|
}
|
2010-08-03 15:56:45 +00:00
|
|
|
if ( !isset($unite) ) { $unite = 'EUR'; }
|
|
|
|
//FB::log($data, 'data');
|
|
|
|
//Graphique
|
|
|
|
require_once 'phpchartdir/phpchartdir.php';
|
|
|
|
if ( count($data)<=1 ){
|
|
|
|
$output = false;
|
|
|
|
} else {
|
|
|
|
ksort($data);
|
|
|
|
$labelsX = array_keys($data);
|
|
|
|
$valuesY = array();
|
|
|
|
for ( $i = 0; $i < $nbRatio ; $i++ ){
|
|
|
|
foreach ( $data as $values ){
|
|
|
|
$valuesY[$i][] = isset($values[$i]) ? (int)$values[$i]/$div : 0;
|
|
|
|
}
|
2010-03-08 16:01:16 +00:00
|
|
|
}
|
2010-08-03 15:56:45 +00:00
|
|
|
//Génération du graphique
|
|
|
|
$c = new XYChart(548, 350);
|
|
|
|
$c->addTitle($titre, 'times.ttf', 10);
|
|
|
|
$c->yAxis->setTitle($unite);
|
|
|
|
$c->yAxis->setWidth(2);
|
|
|
|
$c->xAxis->setTitle('Années');
|
|
|
|
$c->xAxis->setWidth(2);
|
|
|
|
$c->xAxis->setLabels($labelsX);
|
|
|
|
$legendObj = $c->addLegend2(25, 25, -2, "times.ttf", 9);
|
|
|
|
$legendObj->setBackground(Transparent, Transparent);
|
|
|
|
$c->setPlotArea(110, 90, 300, 200);
|
|
|
|
//Application layer pour line
|
|
|
|
$lineLayer = $c->addLineLayer2(Side);
|
|
|
|
$lineLayer->setBorderColor(Transparent, softLighting(Left));
|
|
|
|
$lineLayer->setLineWidth(2);
|
|
|
|
//Application layer pour bar
|
|
|
|
$barLayer = $c->addBarLayer2(Side);
|
|
|
|
$barLayer->setBorderColor(Transparent, softLighting(Left));
|
|
|
|
for ( $i = 0; $i < $nbRatio ; $i++ ){
|
|
|
|
//FB::log($couleurs[$i], 'Couleur');
|
|
|
|
if ( $dataInfos[$i]['style'] == 'H' ){
|
|
|
|
$barLayer->addDataSet($valuesY[$i], $couleurs[$i], $dataInfos[$i]['titre']);
|
|
|
|
} else if ( $dataInfos[$i]['style'] == 'L' ){
|
|
|
|
$dataSetObj = $lineLayer->addDataSet($valuesY[$i], $couleurs[$i], $dataInfos[$i]['titre']);
|
|
|
|
$dataSetObj->setDataSymbol(SquareSymbol, 7);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if( $c->makeChart($path.$file) === true ){
|
|
|
|
$output = $file;
|
|
|
|
} else {
|
|
|
|
$output = false;
|
2010-06-28 10:12:36 +00:00
|
|
|
}
|
2010-03-08 16:01:16 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
return $output;
|
|
|
|
}
|
2010-06-04 08:58:26 +00:00
|
|
|
|
2010-06-28 10:12:36 +00:00
|
|
|
function commentaires_graph_radar($id, $titre, $strRatios) {
|
|
|
|
global $graphCouleurs;
|
2011-02-21 14:01:29 +00:00
|
|
|
$path = PATH_SITE.'/cache/pages/imgcache/';
|
2010-08-03 15:56:45 +00:00
|
|
|
$file = $id.'.png';
|
2010-09-20 12:25:25 +00:00
|
|
|
if( cache_graph($path.$file) && 0 ){
|
2010-08-03 15:56:45 +00:00
|
|
|
$output = $file;
|
2010-06-28 10:12:36 +00:00
|
|
|
} else {
|
2010-08-03 15:56:45 +00:00
|
|
|
if(count($graphCouleurs)>0){
|
|
|
|
$couleurs = $graphCouleurs;
|
|
|
|
} else {
|
|
|
|
$couleurs = array(0x9999ff);
|
2010-06-04 08:58:26 +00:00
|
|
|
}
|
2010-08-03 15:56:45 +00:00
|
|
|
//FB::log($couleurs, 'RADAR-couleur');
|
|
|
|
$ratios = explode(',', $strRatios);
|
|
|
|
$data = array();
|
|
|
|
$pattern = '/(Rs?)\[(.*)]#(.{1})/';
|
|
|
|
foreach($ratios as $ratio){
|
|
|
|
if( preg_match($pattern, $ratio, $matches) ){
|
|
|
|
$typeRatio = $matches[1];
|
|
|
|
$numRatio = $matches[2];
|
|
|
|
$titreRatio = commentaires_graph_lib($numRatio);
|
|
|
|
$supPattern = '/\(.*?\)/';
|
|
|
|
$titreRatio = preg_replace($supPattern, '', $titreRatio);
|
|
|
|
$supPattern = '/[ ]/';
|
|
|
|
$titreRatio = preg_replace($supPattern, '<*br*>', $titreRatio);
|
|
|
|
$data['y'][] = array(
|
|
|
|
'titre' => $titreRatio,
|
|
|
|
'data' => commentaires_graph_y($typeRatio, $numRatio),
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
$data['x'] = commentaires_graph_x();
|
2010-06-04 08:58:26 +00:00
|
|
|
|
2010-08-03 15:56:45 +00:00
|
|
|
//Graphique
|
|
|
|
require_once 'phpchartdir/phpchartdir.php';
|
|
|
|
if(count($data)<=1){
|
|
|
|
$output = 0;
|
|
|
|
}else{
|
|
|
|
//Tri des données
|
|
|
|
foreach($data['y'] as $yKey => $y){
|
|
|
|
$i = 0;
|
|
|
|
foreach($y['data'] as $val){
|
|
|
|
$dataTri[$data['x'][$i]] = $val;
|
|
|
|
$i++;
|
|
|
|
}
|
|
|
|
ksort($dataTri);
|
|
|
|
$data['y'][$yKey]['data'] = array_values($dataTri);
|
|
|
|
}
|
|
|
|
sort($data['x']);
|
|
|
|
foreach($data['y'] as $val){
|
|
|
|
$num = count($val['data'])-1;
|
|
|
|
$gdata[] = $val['data'][$num];
|
|
|
|
$labels[] = $val['titre'];
|
2010-06-04 08:58:26 +00:00
|
|
|
}
|
|
|
|
}
|
2010-09-20 12:25:25 +00:00
|
|
|
FB::log($gdata, 'DATA');
|
|
|
|
|
2010-08-03 15:56:45 +00:00
|
|
|
$c = new PolarChart(548, 480);
|
|
|
|
$c->setPlotArea(270, 240, 150);
|
|
|
|
$c->addAreaLayer($gdata, $couleurs[0]);
|
|
|
|
$c->angularAxis->setLabels($labels);
|
|
|
|
if( $c->makeChart($path.$file) === true ){
|
|
|
|
$output = $file;
|
|
|
|
} else {
|
|
|
|
$output = false;
|
2010-06-04 08:58:26 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
return $output;
|
|
|
|
}
|
|
|
|
|
|
|
|
function commentaires_graph_lib($numRatio){
|
|
|
|
global $ratiosInfos;
|
|
|
|
return htmlspecialchars_decode(
|
|
|
|
$ratiosInfos['r'.$numRatio]['libelle'],
|
|
|
|
ENT_QUOTES);
|
|
|
|
}
|
|
|
|
|
2010-07-02 13:00:48 +00:00
|
|
|
function commentaires_graphp_x($ratio){
|
|
|
|
global $tabProjection;
|
|
|
|
$output = array();
|
|
|
|
$tabRatio = $tabProjection[$ratio.'_Y'];
|
|
|
|
krsort($tabRatio);
|
|
|
|
foreach($tabRatio as $key => $val){
|
|
|
|
$output[] = (int)substr($key,0,4);
|
|
|
|
}
|
|
|
|
return $output;
|
|
|
|
}
|
|
|
|
|
2010-07-05 12:49:54 +00:00
|
|
|
function dateBilanAAAA($value){
|
|
|
|
return (int)substr($value, 0, 4);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2010-06-04 08:58:26 +00:00
|
|
|
function commentaires_graph_x(){
|
|
|
|
global $bilansInfos;
|
|
|
|
$output = array();
|
|
|
|
foreach($bilansInfos as $bilan){
|
|
|
|
$output[] = $bilan['dateCloture'];
|
|
|
|
}
|
|
|
|
return $output;
|
|
|
|
}
|
|
|
|
|
2010-07-02 13:00:48 +00:00
|
|
|
|
2010-06-04 08:58:26 +00:00
|
|
|
function commentaires_graph_y($typeRatio, $numRatio){
|
2010-07-02 13:00:48 +00:00
|
|
|
global $ratiosEntrep, $ratiosSecteur, $tabProjection;
|
|
|
|
switch ($typeRatio) {
|
2010-06-04 08:58:26 +00:00
|
|
|
case 'R' : $tabRatio = $ratiosEntrep; break;
|
|
|
|
case 'Rs' : $tabRatio = $ratiosSecteur; break;
|
2010-07-02 13:00:48 +00:00
|
|
|
case 'projection' : $tabRatio = $tabProjection; break;
|
2010-06-04 08:58:26 +00:00
|
|
|
}
|
|
|
|
$output = array();
|
2010-07-02 13:00:48 +00:00
|
|
|
if ($typeRatio != 'projection') {
|
|
|
|
foreach($tabRatio as $key => $val){
|
2010-09-20 12:25:25 +00:00
|
|
|
$value = $val['r'.$numRatio];
|
|
|
|
if (is_numeric($value)) {
|
|
|
|
$output[$key] = $value;
|
|
|
|
} elseif (is_string($value) && substr($value,0,1)=='>') {
|
|
|
|
$output[$key] = (int) substr($value,1);
|
|
|
|
}
|
2010-07-02 13:00:48 +00:00
|
|
|
}
|
|
|
|
} else {
|
|
|
|
$tabRatio = $tabRatio[$numRatio.'_Y'];
|
|
|
|
krsort($tabRatio);
|
|
|
|
foreach($tabRatio as $val){
|
|
|
|
$output[] = $val;
|
|
|
|
}
|
2010-06-04 08:58:26 +00:00
|
|
|
}
|
|
|
|
return $output;
|
|
|
|
}
|