From 05948d8bcc76b2c61b133e114244901d239f02c6 Mon Sep 17 00:00:00 2001 From: Michael RICOIS Date: Wed, 16 Oct 2013 15:30:14 +0000 Subject: [PATCH] Move Finance Library and make it compatible with autoloading --- .../controllers/EvaluationController.php | 3 +- application/controllers/FinanceController.php | 24 +- .../controllers/JuridiqueController.php | 2 +- data/pages/themes/default/styles/main.css | 2 +- library/Evaluation/DomDocument2.lib.php | 12 - library/Finance/Finance.lib.php | 242 -------------- library/Finance/LiasseList.php | 12 - library/Finance/OtherFunctions.lib.php | 236 ------------- library/Finance/RatiosGraph.lib.php | 313 ------------------ library/Finance/synthese.lib.php | 233 ------------- library/{ => Scores}/Finance/Liasse.php | 2 +- .../Finance/Liasse/XLS.php} | 18 +- .../Liasse/models}/bdf_liasse_template.ini | 0 .../Liasse/models}/bdf_liasse_template.xls | Bin .../Finance/Liasse/models}/liasse_2033.ini | 0 .../Finance/Liasse/models}/liasse_2033.xls | Bin .../Liasse/models}/liasse_2033_ori.xls | Bin .../Finance/Liasse/models}/liasse_2050.ini | 0 .../Finance/Liasse/models}/liasse_2050.xls | Bin .../Liasse/models}/liasse_2050_ori.xls | Bin .../Finance/Ratios/Data.php} | 2 +- .../Finance/Ratios/Graph.php} | 50 +-- 22 files changed, 49 insertions(+), 1102 deletions(-) delete mode 100644 library/Evaluation/DomDocument2.lib.php delete mode 100644 library/Finance/Finance.lib.php delete mode 100644 library/Finance/LiasseList.php delete mode 100644 library/Finance/OtherFunctions.lib.php delete mode 100644 library/Finance/RatiosGraph.lib.php delete mode 100644 library/Finance/synthese.lib.php rename library/{ => Scores}/Finance/Liasse.php (99%) rename library/{Finance/LiasseXLS.php => Scores/Finance/Liasse/XLS.php} (95%) rename library/{Finance/liassexls => Scores/Finance/Liasse/models}/bdf_liasse_template.ini (100%) rename library/{Finance/liassexls => Scores/Finance/Liasse/models}/bdf_liasse_template.xls (100%) rename library/{Finance/liassexls => Scores/Finance/Liasse/models}/liasse_2033.ini (100%) rename library/{Finance/liassexls => Scores/Finance/Liasse/models}/liasse_2033.xls (100%) rename library/{Finance/liassexls => Scores/Finance/Liasse/models}/liasse_2033_ori.xls (100%) rename library/{Finance/liassexls => Scores/Finance/Liasse/models}/liasse_2050.ini (100%) rename library/{Finance/liassexls => Scores/Finance/Liasse/models}/liasse_2050.xls (100%) rename library/{Finance/liassexls => Scores/Finance/Liasse/models}/liasse_2050_ori.xls (100%) rename library/{Finance/RatiosData.php => Scores/Finance/Ratios/Data.php} (99%) rename library/{Finance/RatiosGraph.php => Scores/Finance/Ratios/Graph.php} (99%) diff --git a/application/controllers/EvaluationController.php b/application/controllers/EvaluationController.php index 39ffd74bf..302c17978 100644 --- a/application/controllers/EvaluationController.php +++ b/application/controllers/EvaluationController.php @@ -14,7 +14,6 @@ class EvaluationController extends Zend_Controller_Action require_once 'Scores/WsScores.php'; require_once 'Scores/SessionEntreprise.php'; require_once 'Scores/IdentiteEntreprise.php'; - require_once 'Finance/RatiosData.php'; } public function indexAction() @@ -136,7 +135,7 @@ class EvaluationController extends Zend_Controller_Action //Formattage des données $typeBilan = 'N'; - $ratiosData = new RatiosData($infos); + $ratiosData = new Scores_Finance_Ratios_Data($infos); $nbBilanN = $ratiosData->getNbBilan('N'); $nbBilanC = $ratiosData->getNbBilan('C'); diff --git a/application/controllers/FinanceController.php b/application/controllers/FinanceController.php index 83b7f5590..8ea0d7d5e 100644 --- a/application/controllers/FinanceController.php +++ b/application/controllers/FinanceController.php @@ -9,9 +9,6 @@ class FinanceController extends Zend_Controller_Action require_once 'common/dates.php'; require_once 'Scores/SessionEntreprise.php'; require_once 'Scores/WsScores.php'; - require_once 'Finance/Liasse.php'; - require_once 'Finance/RatiosData.php'; - require_once 'Finance/RatiosGraph.php'; $request = $this->getRequest(); $this->siret = $request->getParam('siret'); @@ -71,7 +68,7 @@ class FinanceController extends Zend_Controller_Action } //Formattage des données - $ratiosData = new RatiosData($infos); + $ratiosData = new Scores_Finance_Ratios_Data($infos); $nbBilanN = $ratiosData->getNbBilan('N'); $nbBilanC = $ratiosData->getNbBilan('C'); @@ -92,7 +89,7 @@ class FinanceController extends Zend_Controller_Action sort($annees); if (count($annees)>1){ //Générer les différents graphiques d'évolutions - $ratiosGraph = new RatiosGraph($this->siret, $this->id); + $ratiosGraph = new Scores_Finance_Ratios_Graph($this->siret, $this->id); $tabGraphEvol = array(); foreach($tabRatio as $idRatio => $infoRatio){ $dataGraphEvol = array(); @@ -220,7 +217,7 @@ class FinanceController extends Zend_Controller_Action $infos = $this->getRequest()->getParam('infos'); } - $ratiosData = new RatiosData($infos); + $ratiosData = new Scores_Finance_Ratios_Data($infos); $nbBilanN = $ratiosData->getNbBilan('N'); $nbBilanC = $ratiosData->getNbBilan('C'); @@ -234,7 +231,7 @@ class FinanceController extends Zend_Controller_Action $infosAnnee = $ratiosData->getBilansInfo($typeBilan); $annees = array_keys($infosAnnee); - $ratiosGraph = new RatiosGraph($this->siret, $this->id); + $ratiosGraph = new Scores_Finance_Ratios_Graph($this->siret, $this->id); $tabRatioActif = array( 'r59' => array( 'titre' => 'Actif Immobilisé Net', 'class' => 'subhead'), @@ -555,7 +552,7 @@ class FinanceController extends Zend_Controller_Action $tabRatio = array( $ratio => $tabRatio[$ratio] ); } - $ratiosData = new RatiosData($infos); + $ratiosData = new Scores_Finance_Ratios_Data($infos); $nbBilanN = $ratiosData->getNbBilan('N'); $nbBilanC = $ratiosData->getNbBilan('C'); @@ -567,7 +564,7 @@ class FinanceController extends Zend_Controller_Action if ($nbBilanN!=0 || $nbBilanC!=0) { //Génération Graphique evolution - $ratiosGraph = new RatiosGraph($this->siret, $this->id); + $ratiosGraph = new Scores_Finance_Ratios_Graph($this->siret, $this->id); $infosAnnee = $ratiosData->getBilansInfo($typeBilan); $annees = array_keys($infosAnnee); @@ -672,8 +669,7 @@ class FinanceController extends Zend_Controller_Action $path = $c->profil->path->files . '/'; $file = 'liasse-'.substr($this->siret, 0, 9).'-'.$this->id.'-'.$type.$date.'.xls'; - require_once 'Finance/LiasseXLS.php'; - $liasse = new LiasseXLS($model); + $liasse = new Scores_Finance_Liasse_XLS($model); $liasse->dataModel(substr($this->siret, 0, 9), $entreprise->getRaisonSociale(), $data); $liasse->dataFile($file); @@ -908,7 +904,7 @@ class FinanceController extends Zend_Controller_Action if ($infos === false) $this->_forward('soap', 'error'); - $infoLiasse = new Liasse($infos, $unite); + $infoLiasse = new Scores_Finance_Liasse($infos, $unite); $this->view->assign('dateCloture', $infoLiasse->getInfo('dateCloture')); $this->view->assign('dateCloturePre', $infoLiasse->getInfo('dateCloturePre')); $this->view->assign('dureesMois', $infoLiasse->getInfo('dureeMois')); @@ -1026,7 +1022,7 @@ class FinanceController extends Zend_Controller_Action $infos = $ws->getRatios($siren, 'ratios'); //Formattage des données - $ratiosData = new RatiosData($infos); + $ratiosData = new Scores_Finance_Ratios_Data($infos); $nbBilanN = $ratiosData->getNbBilan('N'); $nbBilanC = $ratiosData->getNbBilan('C'); @@ -1239,7 +1235,7 @@ class FinanceController extends Zend_Controller_Action $labels[] = substr($date, 0, 4); } - $graph = new RatiosGraph($this->siret, $this->id); + $graph = new Scores_Finance_Ratios_Graph($this->siret, $this->id); $image = $graph->flux($labels, $data, $typeBilan); if ( $image != false ){ $this->view->assign('graph', $image); diff --git a/application/controllers/JuridiqueController.php b/application/controllers/JuridiqueController.php index d917e48c7..1d3c32640 100644 --- a/application/controllers/JuridiqueController.php +++ b/application/controllers/JuridiqueController.php @@ -165,7 +165,7 @@ class JuridiqueController extends Zend_Controller_Action $this->renderScript('juridique/annonce.phtml'); } - //Affichage pour la liste des annonces + //Affichage pour la liste des annonces } else { $nbReponses = $infos->nbReponses; diff --git a/data/pages/themes/default/styles/main.css b/data/pages/themes/default/styles/main.css index 89a8d34b5..ddd972ccf 100644 --- a/data/pages/themes/default/styles/main.css +++ b/data/pages/themes/default/styles/main.css @@ -398,7 +398,7 @@ table { /* Main ----------------------------------*/ body{font-family: Verdana, Arial, sans-serif;font-size: 11px;text-align: center; /* pour corriger le bug de centrage IE */ } -#global {width:900px; margin:0 auto; text-align:left;} +#global {text-align:left;} #content {padding:0;margin:0;} #center {background-color:#fff;padding:5px 0;} #footer {clear:both;text-align:center;margin-top:15px;} diff --git a/library/Evaluation/DomDocument2.lib.php b/library/Evaluation/DomDocument2.lib.php deleted file mode 100644 index 4e5c763f3..000000000 --- a/library/Evaluation/DomDocument2.lib.php +++ /dev/null @@ -1,12 +0,0 @@ -getElementsByTagName($tagName); - foreach ($items as $item) { - return $item->nodeValue; - } - } - -} -?> \ No newline at end of file diff --git a/library/Finance/Finance.lib.php b/library/Finance/Finance.lib.php deleted file mode 100644 index ebd64cde1..000000000 --- a/library/Finance/Finance.lib.php +++ /dev/null @@ -1,242 +0,0 @@ -dateFunction = new WDate(); - $c = Zend_Registry::get('config'); - $this->graphique = new Graphique($c->profil->path->pages . '/imgcache/'); - $this->siret = $siret; - $this->idSC = $idSC; - } - - /** - */ - public function getRatiosValeur($date, $id, $type, $ratios) - { - $ratio = self::getRatios($ratios, 'entreprise'); - foreach($ratio[$date][$type] as $element) { - if ($element->id == $id) - return ($element->val); - } - } - - public function getRatios($ratios, $RatioType) - { - $retour = array(); - - foreach($ratios->BilansInfos->item as $item) { - if ($RatioType == 'entreprise') { - $retour[$item->dateCloture][$item->typeBilan] = $item->RatiosEntrep->item; - } else if($RatioType == 'secteur') { - echo ""; - } - } - return ($retour); - } - - public function rsynthese($synthese, $idsReference, &$tabAnnee, &$final) - { - $OtherFunction = new OtherFunction(); - - foreach ($synthese->BilansInfos->item as $item) { - $annee = substr($item->dateCloture, 0, 4); - if( $annee >= substr($synthese->BilansInfos->item[0]->dateCloture, 0, 4)-2) { - $tabAnnee[$this->dateFunction->dateT('Ymd', 'd/m/Y', $item->dateCloture)] = $item->duree; - foreach ($item->RatiosEntrep->item as $RatiosEntrep) { - foreach($idsReference as $id => $elements) { - if ($RatiosEntrep->id == $id) { - $final[$id.':'.$elements['titre']][$item->dateCloture] = - array('Valeur' => $RatiosEntrep->val/1000, - 'percent' => $OtherFunction->getReference($RatiosEntrep->val, $elements['total'], $annee, $synthese), 'id' => $id); - ksort($final[$id.':'.$elements['titre']]); - } - } - } - } - } - ksort($tabAnnee); - } - - public function synthese($synthese, $bilanReference, $typeBilan, $RatiosGraph) - { - $OtherFunction = new OtherFunction(); - $RatiosGraph = new RatiosGraph($this->siret, $this->idSC); - - foreach ($synthese->BilansInfos->item as $item) { - if ($item->typeBilan == $typeBilan) { - foreach ($item->RatiosEntrep->item as $RatiosEntrep) { - foreach ($bilanReference as $id => $params) { - if ($RatiosEntrep->id == $id) { - $bilan[$id]['name'] = $params['name']; - $bilan[$id]['unite'] = $params['unite']; - $bilan[$id]['commentaires'] = $params['commentaires']; - if (count($bilan[$id]['item']) <= 2) { - if (is_numeric($RatiosEntrep->val)) - $valeur = number_format(($RatiosEntrep->val / $params['operateur']), 0, '', ' '); - $bilan[$id]['item'][$item->dateCloture]['ValEntrep'] = $valeur;} - $this->graphique->GraphiqueLineXY($RatiosGraph->GraphiqueSyntheseLine($id, $synthese, - $item->typeBilan, $OtherFunction->maskNameImg('synthese', $this->siret, array($id,$item->typeBilan))), true); } } } - foreach ($item->RatiosEntrepEvol->item as $RatiosEntrepEvol) { - foreach ($bilanReference as $id => $params) { - if ($RatiosEntrepEvol->id == $params['evolution']) { - if (array_key_exists($item->dateCloture, $bilan[$id]['item'])) { - $bilan[$id]['item'][$item->dateCloture]['duree'] = $item->duree; - $bilan[$id]['item'][$item->dateCloture]['ValEntrepEvol'] = $RatiosEntrepEvol->val; } } } } - } - } - foreach ($bilan as $id => $val) - ksort($bilan[$id]['item']); - return ($bilan); - } - - public function constructElementForBilan($bilan, $tableauDeReference, &$type, &$date, &$duree, $typebilan) - { - foreach($bilan->BilansInfos->item as $element) { - if($element->typeBilan == $typebilan) - { - if($duree == EOF) - $duree = $element->duree; - if (@count($date) < 5) { - if(!in_array($element->dateCloture, $date)) - $date[] = $element->dateCloture; - } - foreach($element->RatiosEntrep->item as $item) { - foreach($tableauDeReference as $id => $valeur) { - if ($item->id == $id) { - if (count($type[$id]['item']) < 5) { - if ($item->val > 0) { - $type[$id]['item'][$element->dateCloture] = $item->val / 1000; - } - else - $type[$id]['item'][$element->dateCloture] = 'NS'; - } - } - } - } - } - } - foreach ($type as $id => $valeur) { - $type[$id]['item'] = array_reverse($valeur['item']); - } - $date = array_reverse($date); - } - - public function specialSIG($id, $element, $partial, $count) - { - $OtherFunction = new OtherFunction(); - - if($element != 'NS') { - if ($id == 'r101') - return $OtherFunction->Tb($element, $element) - $OtherFunction->Tb($partial['r122']['item'][$count], $partial['r101']['item'][$count]); - else if ($id == 'r122') - return $OtherFunction->Tb($element, $partial['r101']['item'][$count]) - $OtherFunction->Tb($partial['r130']['item'][$count], $partial['r101']['item'][$count]); - else if ($id == 'r130') - return $OtherFunction->Tb($element, $partial['r101']['item'][$count]) - $OtherFunction->Tb($partial['r140']['item'][$count], $partial['r101']['item'][$count]); - else if ($id == 'r140') - return $OtherFunction->Tb($element, $partial['r101']['item'][$count]) - $OtherFunction->Tb($partial['r150']['item'][$count], $partial['r101']['item'][$count]); - else if ($id == 'r150') - return $OtherFunction->Tb($element, $partial['r101']['item'][$count]) - $OtherFunction->Tb($partial['r170']['item'][$count], $partial['r101']['item'][$count]); - else if ($id == 'r170') - return $OtherFunction->Tb($element, $partial['r101']['item'][$count]) - $OtherFunction->Tb($partial['r199']['item'][$count], $partial['r101']['item'][$count]); - else if ($id == 'r199') - return $OtherFunction->Tb($element, $partial['r101']['item'][$count]); - } else - return (null); - } - - public function LineBilan(&$tableauBilanGraphique, $helper, $id, $Graphdate, $partial, $reference, $name, $url, $siren, $sig = false) - { - $i = 0; - $this->column = 0; - $GraphLine = array(); - $OtherFunction = new OtherFunction(); - $RatiosGraph = new RatiosGraph($this->siret, $this->idSC); - - /** Ont enregistre les données (premié temps) **/ - foreach($partial[$id]['item'] as $element) { - if($element != 'NS'){ $GraphLine[] = $number = $element; }else{$number = 0; $GraphLine[] = 0;}; - if($sig) { - $result = self::specialSIG($id, $element, $partial, $i); - if(is_numeric($result)) - $gr[] = ($result < 0)?0:$result; - } - else - if($OtherFunction->createlementForGraphique($id))$gr[] = $number; - } - ($gr != 0)?$tableauBilanGraphique = $gr:$tableauBilanGraphique = false; - - /** Ont affiche les données (deuxiéme temps) **/ - $html .= 'ifIsHead($id))?'class="subhead"':'class="bilanDatas"').'>'; - $html .= ''.$name.''; - foreach($partial[$id]['item'] as $element) { - $html .= '' . (($element != 'NS') ? number_format($element, 0, '', ' ') . ' K€':$element).''; - } - $html .= ''.$OtherFunction->Tb(end($partial[$id]['item']), end($partial[$reference]['item'])).''; - $image = $RatiosGraph->GraphiqueLineBilan($GraphLine, $RatiosGraph->maskNameImg('bilan', $this->siret, array($id)), $Graphdate); - $html .= ''; - $datas = implode('|', $GraphLine); - $dates = implode('|', $Graphdate); - $html .= ' - - '; - $html .= ''; - $html .= ''; - return ($html); - } - - public function compareValeur($valeurEnt, $valeurSec, $compare, $valeur = false) - { - $ecart = 1/100; - - if( $valeurSec=='NS' || $valeurEnt == 'NS' || $valeurSec==NULL || $valeurEnt==NULL) { - return ('-'); - } else if ($compare == '>') { - if (($valeurEnt + $ecart) > $valeurSec) { - if($valeur) - $return = 'bon'; - else $return = ''; - } elseif(($valeurSec - ($valeurSec * $ecart)) < $valeurEnt && ($valeurSec + ($valeurSec * $ecart)) > $valeurEnt) { - if($valeur) - $return = 'neutre'; - else $return = '-'; - } else { - if($valeur) - $return = 'mauvais'; - else $return = ''; - } - } else if ($compare == '<') { - if ($valeurEnt < $valeurSec) { - if($valeur) - $return = 'bon'; - else $return = ''; - } elseif( ($valeurSec - ($valeurSec * $ecart)) < $valeurEnt && ($valeurSec + ($valeurSec * $ecart)) > $valeurEnt) { - if($valeur) - $return = 'neutre'; - else $return = '-'; - } else { - if($valeur) - $return = 'mauvais'; - else $return = ''; - } - } - return ($return); - } -} \ No newline at end of file diff --git a/library/Finance/LiasseList.php b/library/Finance/LiasseList.php deleted file mode 100644 index a9403ed01..000000000 --- a/library/Finance/LiasseList.php +++ /dev/null @@ -1,12 +0,0 @@ - $val) { - if($arrayKey == $key) - if($val == $valeur) - return (true); - } - } - return (false); - } - - public function getReference($valeur, $reference, $annee, $synthese) - { - foreach ($synthese->BilansInfos->item as $item) { - if(substr($item->dateCloture, 0, 4) == $annee) { - foreach ($item->RatiosEntrep->item as $RatiosEntrep) { - if ($RatiosEntrep->id == $reference) { - return (round(($valeur/$RatiosEntrep->val)*100,2)); - } - } - } - } - } - - public function setSyntheseReference() - { - $bilanReference = array('r5' => array('evolution' => 'r6' , 'unite' => 'EUR', 'operateur' => 1000, 'name' => 'CHIFFRE D\'AFFAIRES', - 'commentaires' => 'Montant total des ventes hors taxe tant sur le territoire français que hors de France.'), - 'r7' => array('evolution' => 'r8' , 'unite' => 'EUR', 'operateur' => 1000, 'name' => 'RESULTAT COURANT AVANT IMPOTS', - 'commentaires' => 'Bénéfice ou perte constaté avant affectation des produits ou charges exceptionnelles, déduction des impôts et participation au bénéfice. Il est égal aux : - produits d\'exploitation (notamment les sommes reçues qui relèvent de l\'activité de l\'entreprise, soit les ventes de biens, prestations de services etc..) - + quotes-parts de résultats sur opérations faites en commun(par exemple, résultat des opérations faites par l\'intermédiaire d\'une société en participation) - + produits financiers (intérêts courus, gains de change, revenus tirés des comptes en banque) - - charges d\'exploitation - - quotes-parts de charges sur opérations en commun - - charges financières.)'), - 'r10' => array('evolution' => 'r11' , 'unite' => 'EUR', 'operateur' => 1000, 'name' => 'RESULTAT NET', - 'commentaires' => 'Le résultat net comptable correspond au bénéfice ou perte de la période, mesuré par la différence entre les produits et les charges (au sens comptable) de l\'exercice. Il s\'agit du résultat courant, corrigé du résultat exceptionnel, déduction faite de l\'impôt sur le résultat et de l\'éventuelle participation des salariés. Il mesure les ressources nettes restant à l\'entreprise à l\'issue de l\'exercice.'), - 'r18' => array('evolution' => 'r19' , 'unite' => 'EUR', 'operateur' => 1000, 'name' => 'FONDS PROPRES', - 'commentaires' => 'La situation nette ou Fonds propres ou bien encore, capitaux propres représentent l\'argent apporté par les actionnaires à la constitution de la société ou ultérieurement, ou laissés à la disposition de la société en tant que bénéfices non distribués sous forme de dividendes. Ils courent le risque total de l\'entreprise : si celle-ci va mal, ils ne seront pas rémunérés (aucun dividende ne sera versé) ; si elle dépose son bilan, les porteurs de capitaux propres ne seront remboursés qu\'après que les créanciers l\'aient été intégralement. Si elle va très bien au contraire, tous les profits leur reviennent.'), - 'r22' => array('evolution' => 'r23' , 'unite' => 'EUR', 'operateur' => 1000, 'name' => 'TOTAL BILAN', - 'commentaires' => 'Le total du bilan est la somme de tous les actifs ainsi que des passifs, il caractérise la taille de l\'entreprise. - Selon le décret n° 2008-1354 du 18 décembre 2008, les critères désormais retenus pour les besoins de l\'analyse statistique et économique sont les suivants : - La catégorie des micro entreprises est constituée des entreprises qui : - * d\'une part occupent moins de 10 personnes ; - * d\'autre part ont un chiffre d\'affaires annuel ou un total de bilan n\'excédant pas 2 millions d\'euros. - La catégorie des petites et moyennes entreprises (PME) est constituée des entreprises qui : - * d\'une part occupent moins de 250 personnes ; - * d\'autre part ont un chiffre d\'affaires annuel n\'excédant pas 50 millions d\'euros ou un total de bilan n\'excédant pas 43 millions d\'euros. - La catégorie des entreprises de taille intermédiaire (ETI) est constituée des entreprises qui n\'appartiennent pas à la catégorie des petites et moyennes entreprises, et qui : - * d\'une part occupent moins de 5 000 personnes ; - * d\'autre part ont un chiffre d\'affaires annuel n\'excédant pas 1 500 millions d\'euros ou un total de bilan n\'excédant pas 2 000 millions d\'euros. - La catégorie des grandes entreprises (GE) est constituée des entreprises qui ne sont pas classées dans les catégories précédentes.'), - 'r231' => array('evolution' => 'r235', 'unite' => 'EUR', 'operateur' => 1000, 'name' => 'FONDS DE ROULEMENT', - 'commentaires' => 'Le fonds de roulement représente la différence entre l\'actif à court terme et le passif à court terme (dont l\'échéance est de moins de douze mois). Un fonds de roulement positif indique qu\'une entreprise a suffisamment d\'actifs liquides pour régler ses dettes et engagements à court terme (12 mois). Dans certains cas particuliers, le FDR peut être négatif et l\'entreprise viable : GSA ou autre Hypermarchés par exemple. Cette situation devenant risquée en cas de baisse du CA.'), - 'r232' => array('evolution' => 'r236', 'unite' => 'EUR', 'operateur' => 1000, 'name' => 'BESOIN EN FONDS DE ROULEMENT', - 'commentaires' => 'Pour les comptables, le BFR correspond aux actifs d\'exploitation (hors immobilisations et actifs financiers) diminués du montant des dettes d\'exploitation (cad aux fonds indéfiniment mobilisés). Ainsi, une entreprise dont le BFR s\'élève à 15 % de son chiffre d\'affaires requiert un besoin permanent de trésorerie représentant 15 % de son activité uniquement pour assurer la pérennité de son cycle d\'exploitation. Plus le niveau de BFR est faible (ou bien plus sa rotation est forte), plus le dégagement de liquidités est important dès lors que les marges sont positives.'), - 'r249' => array('evolution' => 'r254', 'unite' => 'EUR', 'operateur' => 1000, 'name' => 'TRESORERIE', - 'commentaires' => 'Trésorerie nette (FR-BFR)'), - 'r24' => array('evolution' => 'r24' , 'unite' => 'Pers.', 'operateur' => 1, 'name' => 'EFFECTIF', - 'commentaires' => 'La définition exacte de l\'effectif peut varier selon les sources : - DADS : effectif salarié instantané au 30 juin ; - SIRENE : effectif salarié au 31 décembre n (ou au 1er janvier n+1) ; cet effectif fait l\'objet d\'une mise à jour « de masse » au premier semestre à partir des données DADS, l\'effectif d\'une entreprise est alors la somme des effectifs de ses établissements au 31 décembre; - SUSE-FICUS : moyenne annuelle de l\'effectif salarié. - Dans un bilan c\'est la moyenne de l\'effectif de l\'exercice.') - ); - return ($bilanReference); - } - - public function referenceBilan($reference) - { - switch ($reference) - { - case 'actif': - $reference = array('r59' => 'Actif Immobilisé Net','r51' => 'Incorporelles', - 'r52' => 'Corporelles', 'r53' => 'Financières', - 'r69' => 'Actif Circulant Net', 'r60' => 'Stock et encours', - 'r61' => 'Créances Clients', 'r62' => 'Autres Créances', - 'r63' => 'Trésorerie Active', 'r22' => 'TOTAL ACTIF' - ); - break; - case 'passif': - $reference = array('r79' => 'Ressources Propres', 'r70' => 'Fonds Propres', - 'r71' => 'Provisions Risques', 'r72' => 'Comptes Courants', - 'r90' => 'Ressources Externes', 'r83' => 'Dettes Financières', - 'r84' => 'Dettes Fournisseurs', 'r85' => 'Dettes Fiscales', - 'r86' => 'Autres Dettes', 'r87' => 'Trésorerie Passive', - 'r22' => 'TOTAL PASSIF' - ); - break; - case 'sig': - $reference = array('r101' => 'CHIFFRE D\'AFFAIRES HORS TAXE', 'r102' => '-Achat de marchandises, de matières premières', - 'r110' => 'MARGE COMMERCIALE', 'r111' => '+Production vendue', - 'r112' => '+Production immobilisée et stockée', - 'r120' => 'PRODUCTION DE L\'EXERCICE', - 'r121' => 'Variation de stock de marchandises et matières premières', - 'r122' => 'MARGE BRUTE', - 'r123' => '-Autres charges externes', - 'r130' => 'VALEUR AJOUTÉE', 'r132' => 'Charges de personnel', - 'r133' => '-Impôts, taxes & versements assimilés', 'r131' => '+Subventions d\'exploitation', - 'r140' => 'EXCÉDENT BRUT D\'EXPLOITATION (EBE)', 'r141' => '+Autres produits d\'exploitation', - 'r142' => '-Autres charges d\'exploitation', 'r143' => '+Reprise sur dotations & transferts de charges', - 'r144' => '+70% Loyer de crédit bail', 'r145' => '-Dotations d\'exploitation & provisions d\'exploitation', - 'r150' => 'RÉSULTAT D\'EXPLOITATION', 'r151' => '+Produits financiers', - 'r152' => '+30% Loyer de crédit bail', 'r153' => '+Charges financières', - 'r170' => 'RÉSULTAT COURANT AVANT IMPOTS', 'r171' => '+Produits exceptionnels', - 'r172' => '-Charges exceptionnelles', 'r181' => '-Impôts sur les bénéfices', - 'r182' => '-Participation salariale', - 'r199' => 'RÉSULTAT NET' - ); - break; - } - return ($reference); - } - - /*public function formatElementForGraphiqueBilan($bilan) - { - $tb = array(); - - foreach ($bilan as $id => $item) { - foreach($bilan[$id]['item'] as $element) { - $tb[] = round($element*100/$bilan[$id]['item'][key($bilan['r22']['item'])],2); - } - } - return ($tb); - }*/ - - public function Tb($element, $reference) - { - if($element != 'NS') { - if ($element != 0 and $reference != 0) { - return (round(($element * 100) / $reference, 2)); - } else { - return($element); - } - } - return (false); - } - - public function ifIsHead($id) - { - $head = array('r59', 'r69', 'r22','r79', 'r90', 'r101', - 'r110', 'r120', 'r122', 'r130', 'r140', - 'r150', 'r170', 'r199' - ); - - if (in_array($id, $head)) - return (true); - return (false); - } - - public function createlementForGraphique($id) - { - $element = array('r51', 'r52', 'r53', 'r60', 'r61', 'r62', 'r63', - 'r70', 'r71', 'r72', 'r83', 'r84', 'r85', 'r86', 'r87', - ''); - - if (in_array($id, $element)) - return (true); - return (false); - } - - public function formatElementGraphiquebilan($tb) - { - $valeur = array(); - $case = 0; - - for ($i =0; $i < count($tb); $i++) { - foreach ($tb as $tableau) { - while($case < count($tableau)) { - $valeur[$i][] = $tableau[$case]; - break; - } - } - $case++; - } - return ($valeur); - } - - public function parseUnite($unite, $valeur) - { - switch ($unite) - { - case 'EUR': - return (number_format((round($valeur)/1000), 0, '', ' ')); - case '%' : - return (round($valeur)); - case 'Jours': - return ($valeur); - default: - return ($valeur); - } - } - - public function getSwitchFormRatios($ratio, $type, $date = false) - { - $change = false; - - if(!$date) { - foreach($ratio->BilansInfos->item as $valeur) { - if ($valeur->typeBilan == $type) - return ($valeur); - } - } else { - foreach($ratio->BilansInfos->item as $valeur) { - if ($valeur->typeBilan == $type and $valeur->dateCloture == $date) - return ($valeur); - else - $change = true; - } - } - if($change) { - foreach($ratio->BilansInfos->item as $valeur) { - if ($valeur->typeBilan == $type) - return ($valeur); - } - } - } - -} \ No newline at end of file diff --git a/library/Finance/RatiosGraph.lib.php b/library/Finance/RatiosGraph.lib.php deleted file mode 100644 index d237fde8a..000000000 --- a/library/Finance/RatiosGraph.lib.php +++ /dev/null @@ -1,313 +0,0 @@ -siret = $siret; - $this->SCid = $SCid; - $c = Zend_Registry::get('config'); - $this->imageCachePath = $c->profil->path->pages . '/imgcache/'; - $this->graphique = new Graphique($this->imageCachePath); - } - - public function maskNameImg($action, $siret, $others = EOF) - { - - $name = $action.'-'.$siret; - if($others != EOF) { - foreach($others as $other) { - $name .= '-'.$other; - } - } - $name .= '.png'; - return ($name); - } - - public function getValFromKey($stdClass, $key) - { - foreach($stdClass as $element) { - if ($element->id == $key) - return ($element->val/1000); - } - } - - public function trieType($data, $idType) - { - $type = array(); - - foreach($data as $item) - { - if($item->typeBilan == 'N') - $type['N'][] = $item; - else if($item->typeBilan == 'C') - $type['C'][] = $item; - } - return ($type[$idType]); - } - - public function createAbscisseSynthese($synthese, $id, &$labelX, $type) - { - $dataX1 = array(); - - foreach ($synthese->BilansInfos->item as $item) { - if ($item->typeBilan == $type) { - $labelX[] = substr($item->dateCloture, 0, 4); - foreach ($item->RatiosEntrep->item as $RatiosEntrep) { - if ($RatiosEntrep->id == $id) { - if (is_numeric($RatiosEntrep->val)) - $dataX1[] = ($RatiosEntrep->val / 1000); - } - } - } - } - $labelX = array_reverse($labelX); - $dataX1 = array_reverse($dataX1); - return ($dataX1); - } - - public function GraphiqueSyntheseLine($id, $synthese, $type, $name) - { - $labelX = array(); - $parametres = new stdClass(); - $parametres->nom = $name; - $parametres->datas = array(self::createAbscisseSynthese($synthese,$id, $labelX, $type)); - $parametres->TitlesY = array(array("Keuros")); - $parametres->TitlesX = array(array("Années")); - $parametres->LineLayer = array("Entreprise"); - $parametres->labelsY = array(); - $parametres->labelsX = $labelX; - - return ($parametres); - } - - public function GraphiqueSyntheseAnalyse($data, $type, $siret) - { - - //Définition des valeurs pour le graph - $dataBFR = array(); - $dataFR = array(); - $dataCA = array(); - $BFR = array(); - $i = 0; - $nbAnnees = 0; - $data = self::trieType($data, $type); - - //Tri des données par date et par ordre croissant - foreach ($data as $key => $row) { $date[$key] = $row->dateCloture; } - array_multisort($date, SORT_ASC, $data); - if(count($data)>5) - $data = array_slice($data, count($data)-5, null, true); - - //Parcourir les années - foreach($data as $item) { - $anneeFin = substr($item->dateCloture,0,4); - $moisFin = substr($item->dateCloture,4,2); - $jourFin = substr($item->dateCloture,6,2); - //Calcul de la date de début - $dateDebut = date("Ymd", mktime(0, 0, 0, $moisFin-$item->duree, $jourFin, $anneeFin)); - $anneeDebut = substr($dateDebut,0,4); - $moisDebut = substr($dateDebut,4,2); - $jourDebut = substr($dateDebut,6,2); - //Affectation des abscisses - $dataBFR['x'][$i] = $dataFR['x'][$i] = $dataCA['x'][$i] = $dataEBE['x'][$i] = chartTime((int)$anneeDebut, (int)$moisDebut, (int)$jourDebut); - $dataBFR['x'][$i+1] = $dataFR['x'][$i+1] = $dataCA['x'][$i+1] = $dataEBE['x'][$i+1] = chartTime((int)$anneeFin, (int)$moisFin, (int)$jourFin); - //Affectation des ordonnées - $dataBFR['y'][$i] = $dataBFR['y'][$i+1] = self::getValFromKey($item->RatiosEntrep->item, 'r236'); - $dataFR['y'][$i] = $dataFR['y'][$i+1] = self::getValFromKey($item->RatiosEntrep->item, 'r235'); - $dataCA['y'][$i] = $dataCA['y'][$i+1] = self::getValFromKey($item->RatiosEntrep->item, 'r6'); - $dataEBE['y'][$i] = $dataEBE['y'][$i+1] = self::getValFromKey($item->RatiosEntrep->item, 'r146'); - $i+=2; - } - - $parametres = new stdClass(); - $parametres->nom = self::maskNameImg('synthese', $this->siret, array('graphiqueSynthses', $type)); - $parametres->width = 660; - $parametres->height = 350; - $parametres->bgColor = 0xcccccc; - $parametres->edgeColor = 0x000000; - $parametres->raisedEffect = 1; - $parametres->addTitle = array("Synthèse *", "timesbi.ttf", 15, 0x000000); - $parametres->addText = array(array(60, 320, "* Elements financier rapportés à 12 mois")); - $parametres->setPlotArea = array(100, 80, 500, 200, 0xffffff, -1, -1, 0xcccccc, 0xcccccc); - $parametres->TitlesY = array(array("KEUROS","timesbi.ttf", 10)); - $parametres->TitlesX = array(array("<*block,valign=absmiddle*>Années<*/*>")); - $parametres->yAxisWidth = 2; - $parametres->xAxisWidth = 2; - $parametres->legendeParams = array(55, 30, false, "times.ttf", 9); - $parametres->addStepLineLayer = array('layer1' => array($dataFR['y'], 0x0000ff, "FONDS DE ROULEMENT", $dataFR['x']), - 'layer0' => array($dataBFR['y'], 0xff0000, "BESOIN EN FONDS DE ROULEMENT", $dataBFR['x']), - 'layer2' => array($dataCA['y'], 0x00ff00, "CHIFFRE D'AFFAIRES", $dataCA['x']), - 'layer3' => array($dataEBE['y'], 0x000000, "EXCEDENT BRUT D'EXPLOITATION", $dataEBE['x']) - ); - $parametres->dashLineColor = 'layer3'; - $parametres->addInterLineLayer = array('layer0:layer1' => array(0xff0000, Transparent), - 'layer0:layer1' => array(Transparent, 0x8044ff44) - ); - return ($parametres); - } - - public function selectTitleGraphique($type) - { - switch($type) { - case 'actif' : - return ('Composition de l\'actif au : '); - case 'passif': - return ('Composition du passif au : '); - case 'sig' : - return ('Sole Intermédiaire de Gestion au : '); - } - } - - public function GraphiqueBilan($type, $data, $i, $filename, $date, $count, $labels) - { - $parametres = new stdClass(); - $parametres->nom = self::maskNameImg('bilan', $this->siret, array($i, 'graph', $type)); - $parametres->title->texte = self::selectTitleGraphique($type).' '.$date; - $parametres->datas = $data; - $parametres->labels = $labels; - $parametres->makeSession = 'chart_'.$type.$i; - $retour = $this->graphique->GraphiquePieChart($parametres, true); - - $parametres->retour->file = $parametres->nom; - $parametres->retour->chartID = $retour->chartId; - $parametres->retour->imageMap = $retour->imageMap; - $parametres->retour->i = $type.$i; - $parametres->retour->hide = $i; - ($i == $count)?$parametres->retour->hide = false : $parametres->retour->hide = true; - return ($parametres->retour); - } - - public function GraphiqueLineBilan($data, $name, $date) - { - $parametres = new stdClass(); - $parametres->nom = $name; - $parametres->datas = array($data); - $parametres->TitlesY = array(array("Keuros")); - $parametres->TitlesX = array(array("Années")); - $parametres->LineLayer = array("Entreprise"); - $parametres->labelsY = array(); - $parametres->labelsX = $date; - - $this->graphique->GraphiqueLineXY($parametres, true); - return($parametres->nom); - } - - public function initTableau($tableau) - { - $i = 0; - - foreach($tableau as $date => $valeur){ - $tableau[$i] = $valeur; - unset($tableau[$date]); - $i++; - } - return ($tableau); - } - - public function countTypeBilan($ratios, $typeBilan) - { - $type = 0; - - foreach($ratios->BilansInfos->item as $item) { - if($item->typeBilan == $typeBilan) - $type++; - } - return ($type); - } - - protected function setUnite($valeur, $unite) - { - switch ($unite) { - case 'EUR': - return ($valeur = $valeur / 1000); - default: - return ($valeur); - } - } - - public function createAbscisse($type, $unite, $ratio, $id, $typeBilan = 'N', &$labelX = null, $nbResult = 5) - { - $i = 0; - - $dataX = array(); - if ($type == 'RatiosEntrep') { - foreach ($ratio->BilansInfos->item as $element) { - if($element->typeBilan == $typeBilan) { - if ($i >= self::countTypeBilan($ratio, $typeBilan)) - break; - if (is_array($labelX)) - $labelX[] = substr($element->dateCloture, 0, 4); - foreach ($element->RatiosEntrep->item as $ratioEntre) { - if ($ratioEntre->id == $id) { - $dataX[substr($element->dateCloture, 0, 4)] = self::setUnite($ratioEntre->val, $unite);$i++;} } } } } - if ($type == 'RatiosSecteur') { - foreach ($ratio->RatiosSecteur->item as $element) { - if($i >= self::countTypeBilan($ratio, $typeBilan)) - break; - foreach($element->liste->item as $item) { - if ($item->id == $id) { - $dataX[$element->annee] = self::setUnite($item->val, $unite);$i++; } } } } - if (is_array($labelX)) sort($labelX); - ksort($dataX); - $dataX = self::initTableau($dataX); - return ($dataX); - } - - public function createGraphique($ratio, $id, $unite, $type) - { - $Annees = array(); - $parametres = new stdClass(); - $parametres->nom = self::maskNameImg('ratios', substr($this->siret, 0, 9), array($id,$type)); - $parametres->datas = array(self::createAbscisse('RatiosEntrep', $unite, $ratio, $id, $type, $Annees), - self::createAbscisse('RatiosSecteur', $unite, $ratio, $id, $type)); - $parametres->TitlesY = array(array($unite)); - $parametres->TitlesX = array(array("Années")); - $parametres->colorLegende->Secteur = 0x008C00; - $parametres->colorLegende->Entreprise = 0x0000ff; - $parametres->LineLayer = array("Entreprise", "Secteur"); - $parametres->labelsY = array(); - $parametres->labelsX = $Annees; - - return ($this->graphique->GraphiqueLineXY($parametres, true)); - } - - public function bourseGraphique($filename) - { - $file = $filename.'.png'; - $noOfDays = 30; - $extraDays = 30; - $rantable = new RanTable(9, 6, $noOfDays + $extraDays); - $rantable->setDateCol(0, chartTime(2002, 9, 4), 86400, true); - $rantable->setHLOCCols(1, 100, -5, 5); - $rantable->setCol(5, 50000000, 250000000); - - $timeStamps = $rantable->getCol(0); // Les date - $highData = $rantable->getCol(1); // les données les plus hautes - $lowData = $rantable->getCol(2); // Les données les plus basses - $openData = $rantable->getCol(3); // Les donnée d'ouverture - $closeData = $rantable->getCol(4); // Les donnée de fermeture - $volData = $rantable->getCol(5); // Volume de data - - $parametres = new stdClass(); - $parametres->nom = $file; - $parametres->makeSession = "chart1"; - $parametres->timeStamps = $timeStamps; - $parametres->highData = $highData; - $parametres->lowData = $lowData; - $parametres->openData = $openData; - $parametres->closeData = $closeData; - $parametres->volData = $volData; - $parametres->extraDays = $extraDays; - - $retour = $this->graphique->GraphiqueFinance($parametres, true); - return (''.$retour->imageMap.''); - } -} \ No newline at end of file diff --git a/library/Finance/synthese.lib.php b/library/Finance/synthese.lib.php deleted file mode 100644 index 2448d7465..000000000 --- a/library/Finance/synthese.lib.php +++ /dev/null @@ -1,233 +0,0 @@ - array('title' => 'CHIFFRE D\'AFFAIRES', 'div' => 1000, 'unit' => ' K€', 'evolution' => 'r6' ), - 'r7' => array('title' => 'RESULTAT COURANT AVANT IMPOTS', 'div' => 1000, 'unit' => ' K€', 'evolution' => 'r8' ), - 'r10' => array('title' => 'RESULTAT NET', 'div' => 1000, 'unit' => ' K€', 'evolution' => 'r11' ), - 'r18' => array('title' => 'FONDS PROPRES', 'div' => 1000, 'unit' => ' K€', 'evolution' => 'r19' ), - 'r22' => array('title' => 'TOTAL BILAN', 'div' => 1000, 'unit' => ' K€', 'evolution' => 'r23' ), - 'r231' => array('title' => 'FONDS DE ROULEMENT', 'div' => 1000, 'unit' => ' K€', 'evolution' => 'r235'), - 'r232' => array('title' => 'BESOIN EN FONDS DE ROULEMENT', 'div' => 1000, 'unit' => ' K€', 'evolution' => 'r236'), - 'r249' => array('title' => 'TRESORERIE', 'div' => 1000, 'unit' => ' K€', 'evolution' => 'r254'), - 'r24' => array('title' => 'EFFECTIF', 'div' => 1, 'unit' => ' Pers.', 'evolution' => 'r24' ) - ); - protected $datas = array(); - protected $structure = array(); - - private $resultats; - private $evolutionsArray; - - /** - * Merci de passer l'objet a ce niveau : BilansInfos->item - * - * @param unknown_type $resultats - */ - public function __construct($resultats, $evolutions) - { - $this->resultats = $resultats; - $this->evolutionsArray = $evolutions; - } - - /** - * A utiliser avec précaution ! - * - * format : 'id' => array(title => '', div => '', unit => '', evolution => '') - * @param Array $element - */ - public function addInRatioTab($id, $element) - { - $tab = array($id => $element); - $copy = $this->tabRatio; - - $this->tabRatio = array_merge($copy, $tab); - } - - public function constructStructure() - { - self::constructBaseLibele(); - foreach ($this->datas as $libele => $title) { - foreach ($this->resultats as $item) - foreach ($item as $row) { - foreach($row as $champ => $valeur) { - if ($champ == 'dateCloture'){ - $date = $valeur; - self::constructBaseDate($libele, $valeur); - } - if ($champ == 'typeBilan') - { - self::constructBaseType($libele, $date, $valeur); - } - } - } - } - print_r($this->datas); - } - - /** - * Construction du premier etage Libeler - */ - private function constructBaseLibele() - { - foreach ($this->tabRatio as $libel => $valeur) { - $this->datas[$valeur['title']] = array(); - } - } - - /** - * Construction du deuxieme etage Dates - * - * @param $libeler precedent $libele - * @param date courente $date - */ - private function constructBaseDate($libel, $date) - { - if(!array_key_exists($date, $this->datas)) { - $this->datas[$libel][$date] = array(); - } - } - - /** - * Construction du troisieme etage Type - * - * @param libele precedent $libele - * @param date precedente $date - * @param type en cours $type - */ - private function constructBaseType($libele, $date, $type) - { - foreach ($this->resultats as $row) { - foreach($row as $champ => $valeur) { - if ($champ == 'dateCloture') { - if ($valeur == $date) { - $this->datas[$libele][$valeur][$type] = array(); - } - } - } - } - } - - /** - * Construction du quatrieme etage Items - * - * @param libele precedent $libele - * @param date precedente $date - * @param type precedent $type - * @param item precedent $item - * @param id de l'item dans le tabRatio $id - * @param id evolution dans tabRatio $idEvol - */ - private function constructBaseItem($libele, $date, $type, $item, $id, $idEvol) - { - if ($item->id == $id) { - $var = new stdClass(); - $var->val = $item->val; - foreach ($this->evolutionsArray as $evol) { - if ($evol->id == $idEvol) - $var->evolution = $item->val; - } - $this->datas[$libele][$date][$type] = $var; - } - } -} - -Class Synthese -{ - /** - * Type du bilan N, C, A, S, B - * - * N : Normal - * C : Consolidé - * A : Assurance - * B : Banque - * S : Simplifié - * - * Ont garde une priorité sur les bilan de type S donc les type N deviennent type S ! - * Donc il n'y a pas de type N dans la vue. - * - * @var unknown_type - */ - protected $typeBilan = array( - 'N', 'C', 'A', 'B' - ); - - /** - * Les données correctement formaté par FormatData - * - * @var unknown_type - */ - protected $datas; - - /** - * Les parametres courrant de l'objet - * - * @var unknown_type - */ - protected $currentTypeBilan; - protected $currentDate; - - public function __construct($resultats, $evolutions) { - $this->data = new FormatDatas($resultats, $evolutions); - $this->data->constructStructure(); - } - - /** - * Permet de retourner des elements du tableau - * peut egalement savoir si l'element existe dans le tableau - * - * @param unknown_type $id - * @param unknown_type (existe, title, div, unit, evolution) - */ - public function getElementInSynthese($id, $action) - { - foreach ($this->tabRatio as $name => $element) { - if ($name == $id) { - switch ($action){ - case 'exist': - return (true); - case 'title': - return($element['title']); - case 'div': - return ($element['div']); - case 'unit': - return ($element['unit']); - case 'evolution': - return ($element['evolution']); - default: - return ($element); - } - } - } - return (false); - } - - /** - * Permet de switcher entre les bilans - * - * @param unknown_type $type - */ - protected function selectTypeBilan($type) - { - foreach($this->typeBilan as $typeBilan) { - if ($typeBilan == $type) - $this->currentTypeBilan = $type; - } - } - - /** - * Permet de selectionnez d'autre dates. - * - * @param unknown_type $date - */ - protected function selectDateBilan($date) - { - $this->currentDate = $date; - } - -} \ No newline at end of file diff --git a/library/Finance/Liasse.php b/library/Scores/Finance/Liasse.php similarity index 99% rename from library/Finance/Liasse.php rename to library/Scores/Finance/Liasse.php index ca2b50c0b..19a47296e 100644 --- a/library/Finance/Liasse.php +++ b/library/Scores/Finance/Liasse.php @@ -1,5 +1,5 @@ mode = $mode; } - + public function dataModel($siren, $raisonSociale, $values) { switch($this->modele) @@ -80,7 +80,7 @@ class LiasseXLS } //Association - $dataAssoc = parse_ini_file(realpath(dirname(__FILE__)).'/liassexls/'.$this->modele.'.ini', true); + $dataAssoc = parse_ini_file(realpath(dirname(__FILE__)).'/models/'.$this->modele.'.ini', true); $assoc = array(); foreach($dataAssoc as $sheet => $dataCell) { @@ -92,11 +92,11 @@ class LiasseXLS $this->assoc = $assoc; $this->values = $values; } - + public function dataFile($file) { require_once 'Vendors/phpexcel/PHPExcel.php'; - $objPHPexcel = PHPExcel_IOFactory::load(realpath(dirname(__FILE__)).'/liassexls/'.$this->modele.'.xls'); + $objPHPexcel = PHPExcel_IOFactory::load(realpath(dirname(__FILE__)).'/models/'.$this->modele.'.xls'); foreach( $this->assoc as $key => $position ) { $sheet = $position[0]; @@ -119,8 +119,8 @@ class LiasseXLS $objWriter = PHPExcel_IOFactory::createWriter($objPHPexcel, $this->mode); $objWriter->save($this->path.'/'.$file); } - - - + + + } ?> \ No newline at end of file diff --git a/library/Finance/liassexls/bdf_liasse_template.ini b/library/Scores/Finance/Liasse/models/bdf_liasse_template.ini similarity index 100% rename from library/Finance/liassexls/bdf_liasse_template.ini rename to library/Scores/Finance/Liasse/models/bdf_liasse_template.ini diff --git a/library/Finance/liassexls/bdf_liasse_template.xls b/library/Scores/Finance/Liasse/models/bdf_liasse_template.xls similarity index 100% rename from library/Finance/liassexls/bdf_liasse_template.xls rename to library/Scores/Finance/Liasse/models/bdf_liasse_template.xls diff --git a/library/Finance/liassexls/liasse_2033.ini b/library/Scores/Finance/Liasse/models/liasse_2033.ini similarity index 100% rename from library/Finance/liassexls/liasse_2033.ini rename to library/Scores/Finance/Liasse/models/liasse_2033.ini diff --git a/library/Finance/liassexls/liasse_2033.xls b/library/Scores/Finance/Liasse/models/liasse_2033.xls similarity index 100% rename from library/Finance/liassexls/liasse_2033.xls rename to library/Scores/Finance/Liasse/models/liasse_2033.xls diff --git a/library/Finance/liassexls/liasse_2033_ori.xls b/library/Scores/Finance/Liasse/models/liasse_2033_ori.xls similarity index 100% rename from library/Finance/liassexls/liasse_2033_ori.xls rename to library/Scores/Finance/Liasse/models/liasse_2033_ori.xls diff --git a/library/Finance/liassexls/liasse_2050.ini b/library/Scores/Finance/Liasse/models/liasse_2050.ini similarity index 100% rename from library/Finance/liassexls/liasse_2050.ini rename to library/Scores/Finance/Liasse/models/liasse_2050.ini diff --git a/library/Finance/liassexls/liasse_2050.xls b/library/Scores/Finance/Liasse/models/liasse_2050.xls similarity index 100% rename from library/Finance/liassexls/liasse_2050.xls rename to library/Scores/Finance/Liasse/models/liasse_2050.xls diff --git a/library/Finance/liassexls/liasse_2050_ori.xls b/library/Scores/Finance/Liasse/models/liasse_2050_ori.xls similarity index 100% rename from library/Finance/liassexls/liasse_2050_ori.xls rename to library/Scores/Finance/Liasse/models/liasse_2050_ori.xls diff --git a/library/Finance/RatiosData.php b/library/Scores/Finance/Ratios/Data.php similarity index 99% rename from library/Finance/RatiosData.php rename to library/Scores/Finance/Ratios/Data.php index a99674fdb..089582e82 100644 --- a/library/Finance/RatiosData.php +++ b/library/Scores/Finance/Ratios/Data.php @@ -1,5 +1,5 @@ siret = $siret; $this->id = $id; } - + /** * Enregistre le graphique bilan passif sous forme d'image. * @param array $data @@ -101,7 +101,7 @@ class RatiosGraph $c->setStartAngle(135); $c->setData($data, $labels); $c->set3D(20); - + if($c->makeChart($this->path.$file) === TRUE){ $return = $file; }else{ @@ -110,7 +110,7 @@ class RatiosGraph } return $return; } - + /** * Enregistre le graphique bilan actif sous forme d'image. * @param array $data @@ -157,8 +157,8 @@ class RatiosGraph } return $return; } - - + + public function ratiosgraph($ratio, $data) { $file = 'ratiosgraph-'.$this->siret.'-'.$this->id.'-'.$ratio.'.png'; @@ -203,7 +203,7 @@ class RatiosGraph } return $return; } - + public function syntheseGraphEvol($data, $ratio, $unite) { $file = 'syntheseEvol-'.$this->siret.'-'.$this->id.'-'.$ratio.'.png'; @@ -247,12 +247,12 @@ class RatiosGraph } return $return; } - + public function syntheseGraphLineCompare($data, $typeBilan) { $file = 'synthese-linecompare-'.$this->siret.'-'.$this->id.'-'.$typeBilan.'.png'; $cache = new Cache(); - + if( $cache->exist($this->path.$file) ){ $return = $this->path.$file; } else { @@ -261,7 +261,7 @@ class RatiosGraph $date[$key] = $row['date']; } array_multisort($date, SORT_ASC, $data); - + //Définition des valeurs pour le graph $dataBFR = array(); $dataFR = array(); @@ -287,7 +287,7 @@ class RatiosGraph $dataEBE['y'][$i] = $dataEBE['y'][$i+1] = $item['r146']; $i+=2; } - + $c = new XYChart(665, 350, 0xcccccc, 0x000000, 1); $c->addTitle("Synthèse *", "timesbi.ttf", 15, 0x000000); $c->addText(60, 320, "* Elements financier rapportés à 12 mois" ); @@ -296,38 +296,38 @@ class RatiosGraph $c->xAxis->setTitle( "<*block,valign=absmiddle*>Années<*/*>"); $c->xAxis->setWidth(2); $c->yAxis->setWidth(2); - + // Add a legend box at (55, 32) (top of the chart) with horizontal layout. Use 9 pts // Arial Bold font. Set the background and border color to Transparent. $legendObj = $c->addLegend(55, 30, false, "times.ttf", 9); $legendObj->setBackground(Transparent); - + // Add a blue (0000ff) step line layer to the chart and set the line width to 2 pixels $layer1 = $c->addStepLineLayer($dataFR['y'], 0x0000ff, "FONDS DE ROULEMENT"); $layer1->setXData($dataFR['x']); $layer1->setLineWidth(2); - + // Add a red (ff0000) step line layer to the chart and set the line width to 2 pixels $layer0 = $c->addStepLineLayer($dataBFR['y'], 0xff0000, "BESOIN EN FONDS DE ROULEMENT"); $layer0->setXData($dataBFR['x']); $layer0->setLineWidth(2); - + // Add a green (00ff00) step line layer to the chart and set the line width to 2 pixels $layer2 = $c->addStepLineLayer($dataCA['y'], 0x00ff00, "CHIFFRE D'AFFAIRES"); $layer2->setXData($dataCA['x']); $layer2->setLineWidth(2); - + // Add a black (000000) step line layer style dash to the chart and set the line width to 2 pixels $layer3 = $c->addStepLineLayer($dataEBE['y'], $c->dashLineColor(0x000000, DashLine), "EXCEDENT BRUT D'EXPLOITATION"); $layer3->setXData($dataEBE['x']); $layer3->setLineWidth(2); - + # If the FR line gets above the BFR line, color to area between the lines red (ff0000) $c->addInterLineLayer($layer0->getLine(0), $layer1->getLine(0), 0xff0000, Transparent); - + # If the FR line gets below the lower BFR line, color to area between the lines light green (8099ff99) $c->addInterLineLayer($layer0->getLine(0), $layer1->getLine(0), Transparent, 0x8044ff44); - + if($c->makeChart($this->path.$file) === TRUE){ $return = $this->path.$file; }else{ @@ -336,7 +336,7 @@ class RatiosGraph } return $return; } - + /** * Génére l'histogramme flux de trésorerie * @param array $labels @@ -349,14 +349,14 @@ class RatiosGraph $couleur = array(0xff8080, 0x80ff80, 0x8080ff); $file = 'flux-'.$this->siret.'-'.$this->id.'-'.$typeBilan.'.png'; $cache = new Cache(); - + if( $cache->exist($this->path.$file) ){ $return = $this->path.$file; } else { if (count($data)<=1) { $return = 0; } else { - + $c = new XYChart(600, 300); $c->setPlotArea(100, 70, 300, 200); $legendObj = $c->addLegend(100, 20, false, "times.ttf", 9); @@ -380,5 +380,5 @@ class RatiosGraph } return $return; } - + } \ No newline at end of file