754 lines
32 KiB
PHP
754 lines
32 KiB
PHP
<?php
|
|
require_once 'common/dates.php';
|
|
require_once 'Scores/SessionEntreprise.php';
|
|
require_once 'Scores/Utilisateur.php';
|
|
require_once 'Scores/WsScores.php';
|
|
require_once 'Vendors/ChartDirector/phpchartdir.php';
|
|
require_once 'Vendors/ChartDirector/FinanceChart.php';
|
|
require_once 'Graphique/Graphique.lib.php';
|
|
require_once 'Finance/RatiosGraph.lib.php';
|
|
require_once 'Finance/Finance.lib.php';
|
|
require_once 'Finance/OtherFunctions.lib.php';
|
|
|
|
/**
|
|
* La Classe finance gére les actions concernant la partie element financiés du menu
|
|
*
|
|
* Les Bilans.
|
|
* La Synthese.
|
|
* Les Ratios.
|
|
* Les Etablissements bancaires.
|
|
* Les Liasses fiscales.
|
|
* Les cotations en bourses.
|
|
*
|
|
* @author Damien Lasserre
|
|
*
|
|
*/
|
|
class FinanceController extends Zend_Controller_Action
|
|
{
|
|
protected $siret = null;
|
|
protected $id = 0;
|
|
|
|
private $imageCachePath;
|
|
private $tableauBilanGraphique;
|
|
private $htmlBilan;
|
|
private $bilanReference;
|
|
|
|
public function init()
|
|
{
|
|
$request = $this->getRequest();
|
|
$this->siret = $request->getParam('siret');
|
|
$this->id = $request->getParam('id', 0);
|
|
$this->imageCachePath = APPLICATION_PATH . '/../cache/pages/imgcache/';
|
|
|
|
$this->view->headLink()->appendStylesheet('/themes/default/styles/finance.css', 'all');
|
|
$this->view->headScript()->appendFile('/themes/default/scripts/finance.js', 'text/javascript');
|
|
}
|
|
|
|
/* --------------------------------------------------------------------------------------------------- */
|
|
/* Fonction génériques */
|
|
/* ----------------------------------------------------------------------------------------------------*/
|
|
|
|
public function lignegraphAction()
|
|
{
|
|
$request = $this->getRequest();
|
|
$action = $request->getParam('actionName');
|
|
$OtherFunction = new OtherFunction();
|
|
|
|
|
|
switch ($action) {
|
|
case 'synthese':
|
|
$this->bilanReference = $OtherFunction->setSyntheseReference();
|
|
$id = $request->getParam('id');
|
|
$typeBilan = $request->getParam('typeBilan');
|
|
$parametres= array('bilanReference' => array($id => $this->bilanReference[$id]),
|
|
'siret' => $request->siret,
|
|
'otherView' => $request->getParam('idGraph'),
|
|
'typeBilan' => $typeBilan);
|
|
|
|
$this->view->assign('actionName', $action);
|
|
$this->view->assign('parametres', $parametres);
|
|
break;
|
|
}
|
|
$this->bilanReference = $OtherFunction->setSyntheseReference();
|
|
}
|
|
/* --------------------------------------------------------------------------------------------------- */
|
|
/* Gestion de la synthése avec les graphiques */
|
|
/* ----------------------------------------------------------------------------------------------------*/
|
|
|
|
/**
|
|
* @todo faire le setLog.
|
|
*
|
|
*/
|
|
public function rsyntheseAction()
|
|
{
|
|
$final = array();
|
|
$tabAnnee = array();
|
|
$OtherFunction = new OtherFunction();
|
|
$request = $this->getRequest();
|
|
$idsReference = $request->getParam('idsReference');
|
|
$autrePage = $this->getRequest()->getParam('apage');
|
|
//Récupération des informations
|
|
if (empty($autrePage)) {
|
|
$ws = new WsScores();
|
|
$synthese = $ws->getRatios(substr($request->getParam('siret'), 0, 9), 'synthese');
|
|
} else {
|
|
$synthese = $this->getRequest()->getParam('infos');
|
|
}
|
|
$this->bilanReference = $OtherFunction->setSyntheseReference();
|
|
$FinanceLib = new FinanceLib($this->siret, $this->id);
|
|
|
|
if(count($synthese->BilansInfos->item) > 0)
|
|
$FinanceLib->rsynthese($synthese, $idsReference, $tabAnnee, $final);
|
|
|
|
$this->view->assign('commentaires', $this->bilanReference);
|
|
$this->view->assign('annees', $tabAnnee);
|
|
$this->view->assign('synthese', $final);
|
|
}
|
|
|
|
|
|
/**
|
|
* cette fonction gére l'affichage des données pour la synthése avec les différents graphiques.
|
|
* Il est possible de rajouter des champs dans le tableau bilanReference en respectant la synthaxe.
|
|
*/
|
|
public function syntheseAction()
|
|
{
|
|
$user = new Utilisateur();
|
|
if(!$user->checkPerm('INDISCORE2'))
|
|
$this->_forward('perms', 'error');
|
|
$request = $this->getRequest();
|
|
$bilan = array();
|
|
$exist = $request->getParam('bilanReference');
|
|
$autrePage = $this->getRequest()->getParam('apage');
|
|
//Récupération des informations
|
|
if (empty($autrePage)) {
|
|
$ws = new WsScores();
|
|
$synthese = $ws->getRatios(substr($request->getParam('siret'), 0, 9), 'synthese');
|
|
} else {
|
|
$synthese = $this->getRequest()->getParam('infos');
|
|
}
|
|
$RatiosGraph = new RatiosGraph($this->siret, $this->id);
|
|
$typeBilan = $this->getRequest()->getParam('typeBilan');
|
|
$OtherFunction = new OtherFunction();
|
|
$dateFunction = new WDate();
|
|
$FinanceLib = new FinanceLib($this->siret, $this->id);
|
|
$entreprise = new SessionEntreprise($this->siret, $this->id);
|
|
$graphique = new Graphique($this->imageCachePath);
|
|
|
|
if(empty($typeBilan))$typeBilan = 'N';
|
|
// Dans le cas ou ont veut des id(s) spécifique(s).
|
|
if(empty($exist)){
|
|
$this->bilanReference = $OtherFunction->setSyntheseReference();
|
|
$bilanReference = $this->bilanReference;}
|
|
else $bilanReference = $request->getParam('bilanReference');
|
|
if(isset($synthese->BilansInfos->item)) {
|
|
$bilan = $FinanceLib->synthese($synthese, $bilanReference, $typeBilan, $RatiosGraph);
|
|
$this->view->assign('typeBilan', $typeBilan);
|
|
$this->view->assign('synthese', $bilan);
|
|
$this->view->assign('nameForGraphique', $bilanReference);
|
|
$this->view->assign('affFormNormal', $OtherFunction->array_key_existValeur($synthese->BilansInfos->item, 'typeBilan', 'N'));
|
|
$this->view->assign('affFormConsolide', $OtherFunction->array_key_existValeur($synthese->BilansInfos->item, 'typeBilan', 'C'));
|
|
if(empty($this->bilanReference))
|
|
$this->view->assign('otherView', $request->getParam('otherView'));
|
|
if(!empty($bilan))
|
|
$graphique->GraphiqueLineXY(
|
|
$RatiosGraph->GraphiqueSyntheseAnalyse($synthese->BilansInfos->item, $typeBilan, $this->siret));
|
|
} else
|
|
$this->view->assign('nothing', true);
|
|
$this->view->assign('idSC', $this->id);
|
|
$this->view->assign('raisonSociale', $entreprise->getRaisonSociale());
|
|
$this->view->assign('siret', $this->siret);
|
|
$this->view->assign('siren', substr($this->siret, 0, 9));
|
|
$this->view->assign('dateFunction', $dateFunction);
|
|
$this->view->assign('AutrePage', $request->getParam('apage'));
|
|
}
|
|
|
|
/* --------------------------------------------------------------------------------------------------- */
|
|
/* Gestion des bilans ACTIF/PASSIF/CR */
|
|
/* ----------------------------------------------------------------------------------------------------*/
|
|
|
|
/**
|
|
* Permet d'afficher la version imprimable d'un graphique de ligne des bilans.
|
|
* Passages des infos par url + protection htmlentites et url_encode.
|
|
*
|
|
* Enter description here ...
|
|
*/
|
|
public function onelinebilanAction()
|
|
{
|
|
$request = $this->getRequest();
|
|
$datas = $request->getParam('data');
|
|
$dates = $request->getParam('dates');
|
|
$name = $request->getParam('name');
|
|
$image = $request->getParam('image');
|
|
$siret = $request->getParam('siret');
|
|
$id = $request->getParam('id');
|
|
$entreprise = new SessionEntreprise($this->siret, $this->id);
|
|
|
|
$datas = explode('|', $datas);
|
|
$dates = explode('|', $dates);
|
|
|
|
$this->view->assign('idSC', $this->id);
|
|
$this->view->assign('siret', $this->siret);
|
|
$this->view->assign('raisonSociale', $entreprise->getRaisonSociale());
|
|
$this->view->assign('image',$image);
|
|
$this->view->assign('datas', $datas);
|
|
$this->view->assign('dates', $dates);
|
|
$this->view->assign('name', $name);
|
|
}
|
|
|
|
/**
|
|
* Fonction qui affiche les bilan (actif, passif, SIG).
|
|
* Le principe est d'utiliser le mapping de données.
|
|
*
|
|
*/
|
|
public function bilanAction()
|
|
{
|
|
$user = new Utilisateur();
|
|
if(!$user->checkPerm('INDISCORE3'))
|
|
$this->_forward('perms', 'error');
|
|
$actif = array();
|
|
$passif = array();
|
|
$SIG = array();
|
|
$date = array();
|
|
$duree = EOF;
|
|
$request = $this->getRequest();
|
|
$listeBilan = array('actif', 'passif', 'sig');
|
|
$persoActif = $request->getParam('referenceActif');
|
|
$persoPassif = $request->getParam('referencePassif');
|
|
$persoSig = $request->getParam('referenceSig');
|
|
$OtherFunction = new OtherFunction();
|
|
$autrePage = $this->getRequest()->getParam('apage');
|
|
//Récupération des informations
|
|
if (empty($autrePage)) {
|
|
$ws = new WsScores();
|
|
$bilan = $ws->getRatios(substr($this->siret, 0, 9), 'ratios');
|
|
} else {
|
|
$bilan = $this->getRequest()->getParam('infos');
|
|
}
|
|
$dateFunction = new WDate();
|
|
$FinanceLib = new FinanceLib($this->siret, $this->id);
|
|
//$bilan = array();
|
|
$typeBilan = ($this->getRequest()->isPost())?$this->getRequest()->getParam('typeBilan'):'N';
|
|
$entreprise = new SessionEntreprise($this->siret, $this->id);
|
|
|
|
if (isset($bilan->BilansInfos->item)) {
|
|
$referenceActif = $OtherFunction->referenceBilan('actif');
|
|
$referencePassif = $OtherFunction->referenceBilan('passif');
|
|
$referenceSIG = $OtherFunction->referenceBilan('sig');
|
|
|
|
$FinanceLib->constructElementForBilan($bilan, $referenceActif, $actif, $date, $duree, $typeBilan);
|
|
$FinanceLib->constructElementForBilan($bilan, $referencePassif, $passif, $date, $duree, $typeBilan);
|
|
$FinanceLib->constructElementForBilan($bilan, $referenceSIG, $SIG, $date, $duree, $typeBilan);
|
|
|
|
$this->view->assign('referenceactif', $referenceActif);
|
|
$this->view->assign('dateFunction', $dateFunction);
|
|
$this->view->assign('referencepassif', $referencePassif);
|
|
$this->view->assign('referencesig', $referenceSIG);
|
|
$this->view->assign('listeBilan', $listeBilan);
|
|
$this->view->assign('date', $date);
|
|
$this->view->assign('duree', $duree);
|
|
$this->view->assign('actif', $actif);
|
|
$this->view->assign('passif', $passif);
|
|
$this->view->assign('sig', $SIG);
|
|
$this->view->assign('isChecked', 'checked="check"');
|
|
$this->view->assign('isNotChecked', 'false');
|
|
}
|
|
$this->view->assign('dateFunction', $dateFunction);
|
|
$this->view->assign('siret', $this->siret);
|
|
$this->view->assign('typeBilan', $typeBilan);
|
|
$this->view->assign('siren', substr($this->siret, 0, 9));
|
|
$this->view->assign('raisonSociale', $entreprise->getRaisonSociale());
|
|
$this->view->assign('AutrePage', $request->getParam('apage'));
|
|
|
|
}
|
|
|
|
/**
|
|
* Permet de construire le graphique Actif
|
|
* les parametre viennent de $this->getRequest();
|
|
*/
|
|
public function actifgraphAction()
|
|
{
|
|
$RatioGraph = new RatiosGraph($this->getRequest()->getParam('siret'), $this->getRequest()->getParam('id'));
|
|
$data = $this->getRequest()->getParam('valeur');
|
|
$i = $this->getRequest()->getParam('i');
|
|
$filename = $this->getRequest()->getParam('siren');
|
|
$date = $this->getRequest()->getParam('date');
|
|
$count = $this->getRequest()->getParam('count');
|
|
$labels = array('Immo. incorporelles', 'Immo. corporelles',
|
|
'Immo. financières', 'Stock et encours',
|
|
'Créances Clients', 'Autres créances',
|
|
'Trésorerie Active'
|
|
);
|
|
$retour = $RatioGraph->GraphiqueBilan('actif', $data, $i, $filename, $date, $count, $labels);
|
|
|
|
$this->view->assign('file', $retour->file);
|
|
$this->view->assign('chartID', $retour->chartID);
|
|
$this->view->assign('imageMap', $retour->imageMap);
|
|
$this->view->assign('i', 'actif'.$retour->i);
|
|
$this->view->assign('hide', $retour->hide);
|
|
|
|
$this->render('printgraphbilan');
|
|
}
|
|
|
|
/**
|
|
* Permet de construire le graphique Passif
|
|
* les parametre viennent de $this->getRequest();
|
|
*/
|
|
public function passifgraphAction()
|
|
{
|
|
$RatioGraph = new RatiosGraph($this->getRequest()->getParam('siret'), $this->getRequest()->getParam('id'));
|
|
$data = $this->getRequest()->getParam('valeur');
|
|
$i = $this->getRequest()->getParam('i');
|
|
$filename = $this->getRequest()->getParam('siren');
|
|
$date = $this->getRequest()->getParam('date');
|
|
$count = $this->getRequest()->getParam('count');
|
|
$labels = array('Fonds propres',
|
|
'Provisions Risques',
|
|
'Compte Courant',
|
|
'Dettes Financières',
|
|
'Dettes Fournisseurs',
|
|
'Dettes fiscales',
|
|
'Autres Dettes',
|
|
'Trésorerie Passive'
|
|
);
|
|
$retour = $RatioGraph->GraphiqueBilan('passif', $data, $i, $filename, $date, $count, $labels);
|
|
|
|
$this->view->assign('file', $retour->file);
|
|
$this->view->assign('chartID', $retour->chartID);
|
|
$this->view->assign('imageMap', $retour->imageMap);
|
|
$this->view->assign('i', 'passif'.$retour->i);
|
|
$this->view->assign('hide', $retour->hide);
|
|
|
|
$this->render('printgraphbilan');
|
|
}
|
|
|
|
/**
|
|
* Construit le graphique SIG
|
|
* les parametre viennent de $this->getRequest();
|
|
*/
|
|
public function siggraphAction()
|
|
{
|
|
$RatioGraph = new RatiosGraph($this->getRequest()->getParam('siret'), $this->getRequest()->getParam('id'));
|
|
$data = $this->getRequest()->getParam('valeur');
|
|
$i = $this->getRequest()->getParam('i');
|
|
$filename = $this->getRequest()->getParam('siren');
|
|
$date = $this->getRequest()->getParam('date');
|
|
$count = $this->getRequest()->getParam('count');
|
|
$labels = array('Achats de marchandises.',
|
|
'Autres achats externes',
|
|
'Charges de fonctionnement',
|
|
'Amortissement et provisions',
|
|
'Perte financière',
|
|
'Impôts sociétés',
|
|
'RÉSULTAT NET',
|
|
);
|
|
$retour = $RatioGraph->GraphiqueBilan('sig', $data, $i, $filename, $date, $count, $labels);
|
|
|
|
$this->view->assign('file', $retour->file);
|
|
$this->view->assign('chartID', $retour->chartID);
|
|
$this->view->assign('imageMap', $retour->imageMap);
|
|
$this->view->assign('i', 'sig'.$retour->i);
|
|
$this->view->assign('hide', $retour->hide);
|
|
|
|
$this->render('printgraphbilan');
|
|
}
|
|
|
|
|
|
/**
|
|
* Construit et format les données puis envoie les info a la vue.
|
|
* Fonction mére.
|
|
*/
|
|
public function linebilanAction()
|
|
{
|
|
$tb = array();
|
|
$OtherFunction = new OtherFunction();
|
|
$type = $this->getRequest()->getParam('type');
|
|
$Graphdate = $this->getRequest()->getParam('Graphdate');
|
|
$partial = $this->getRequest()->getParam('data');
|
|
$reference = $this->getRequest()->getParam('reference');
|
|
$referenceForeach = $this->getRequest()->getParam('referenceForeach');
|
|
$sig = $this->getRequest()->getParam('sig');
|
|
$siren = $this->getRequest()->getParam('siren');
|
|
$html = '';
|
|
$FinanceLib= new FinanceLib($this->siret, $this->id);
|
|
|
|
foreach ($referenceForeach as $id => $valeur) {
|
|
$this->htmlBilan .= $FinanceLib->LineBilan($this->tableauBilanGraphique, $this->_helper, $id, $Graphdate, $partial, $reference, $valeur,
|
|
'/finance/printgraph/idGraph/bilan-'.$this->siret.'-'.$id.'.png',$siren , $sig);
|
|
if($this->tableauBilanGraphique)$tb[] = $this->tableauBilanGraphique;
|
|
}
|
|
$this->view->assign('type', $type);
|
|
$this->view->assign('html', $this->htmlBilan);
|
|
$this->view->assign('valeur', $OtherFunction->formatElementGraphiquebilan($tb));
|
|
$this->view->assign('Graphdate', $Graphdate);
|
|
$this->view->assign('siret', $this->siret);
|
|
$this->view->assign('id', $this->id);
|
|
}
|
|
|
|
/* --------------------------------------------------------------------------------------------------- */
|
|
/* Gestion des ratios avec les graphiques */
|
|
/* ----------------------------------------------------------------------------------------------------*/
|
|
|
|
public function onelineratiosAction()
|
|
{
|
|
$request = $this->getRequest();
|
|
$siret = $request->getParam('siret');
|
|
$nom = $request->getParam('nom');
|
|
$dates = $request->getParam('dates');
|
|
$entre = $request->getParam('entreprise');
|
|
$secteur = $request->getParam('secteur');
|
|
$unite = $request->getParam('unite');
|
|
$position = $request->getParam('position');
|
|
$graphique = $request->getParam('graphique');
|
|
$entreprise = new SessionEntreprise($this->siret, $this->id);
|
|
|
|
$this->view->assign('siret', $this->siret);
|
|
$this->view->assign('id', $this->id);
|
|
$this->view->assign('siren', substr($this->siret, 0, 9));
|
|
$this->view->assign('raisonSociale', $entreprise->getRaisonSociale());
|
|
$this->view->assign('dates', $dates);
|
|
$this->view->assign('entreprise', $entre);
|
|
$this->view->assign('secteur', $secteur);
|
|
$this->view->assign('nom', urldecode($nom));
|
|
$this->view->assign('unite', urldecode($unite));
|
|
$this->view->assign('position', $position);
|
|
$this->view->assign('graphique', $graphique);
|
|
}
|
|
|
|
/**
|
|
* Permet d'afficher les elements par block avec un titre.
|
|
*
|
|
* @param Le tableau de reference des ID a afficher $tableau
|
|
* @param Le nom du block en traitement $name
|
|
* @param Les elements de Ratios $element
|
|
* @param L'adresse de la variable $html
|
|
* @param l'object ratio $ratios
|
|
* @param la date du block $date
|
|
*/
|
|
protected function printElementRatio($tableau, $name, $element, &$html, $ratios, $date, $type)
|
|
{
|
|
$FinanceLib = new FinanceLib($this->siret, $this->id);
|
|
$RatioGraph = new RatiosGraph($this->siret, $this->id);
|
|
$OtherFunction = new OtherFunction();
|
|
|
|
foreach($tableau[$name] as $row => $val) {
|
|
if ($row == $element->id) {
|
|
foreach ($ratios->RatiosInfos->item as $item) {
|
|
if ($item->id == $element->id) {
|
|
foreach ($ratios->RatiosSecteur->item as $Secteur) {
|
|
if (substr($date, 0, 4) == $Secteur->annee) {
|
|
foreach ($Secteur->liste->item as $liste) {
|
|
if ($item->id == $liste->id) {
|
|
$RatioGraph->createGraphique($ratios, $liste->id, $item->unite, $type);
|
|
$html .= '<tr class="ratiosTr">';
|
|
$html .= '<td class="tooltip" style="cursor:help;" title="'.$item->commentaires.'"><span id="help">'.$item->libelle.'</span></td>';
|
|
$html .= '<td class="right">'.$OtherFunction->parseUnite($item->unite, $element->val).' '.$item->unite.'</td>';
|
|
$html .= '<td class="right">'.$OtherFunction->parseUnite($item->unite, $liste->val).' '.$item->unite.'</td>';
|
|
$html .= '<td align="center">';
|
|
$html .= '<a href="'.
|
|
$this->view->url(array('controller' => 'finance',
|
|
'action' => 'onelineratios',
|
|
'siret' => $this->siret,
|
|
'nom' => urlencode($item->libelle),
|
|
'entreprise' => $OtherFunction->parseUnite($item->unite, $element->val),
|
|
'secteur' => $OtherFunction->parseUnite($item->unite, $liste->val),
|
|
'unite' => urlencode($item->unite),
|
|
'graphique' => 'ratios'.'-'.substr($this->siret, 0, 9).'-'.$liste->id.'-'.$type.'.png',
|
|
'position' => $FinanceLib->compareValeur($element->val, $liste->val, $val, true))).'" name="'.$item->libelle.'" class="rTip" rel="'.$this->view->url(array('controller' => 'finance',
|
|
'action' => 'printgraph',
|
|
'idGraph' => 'ratios'.'-'.substr($this->siret, 0, 9).'-'.$liste->id.'-'.$type.'.png')).'" >'.$FinanceLib->compareValeur($element->val, $liste->val, $val).'</a>';
|
|
$html .= '</td>';
|
|
$html .= '</tr>';
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Apelle la view avec la balise image, j'ai désactivé le layout pour un affichage spécial.
|
|
*/
|
|
public function printgraphAction()
|
|
{
|
|
$this->_helper->layout()->disableLayout();
|
|
$filename = $this->getRequest()->getParam('idGraph');
|
|
$this->view->assign('filename', $filename);
|
|
}
|
|
|
|
/**
|
|
* Gestion de l'affichage des ratios.
|
|
*/
|
|
public function ratiosAction()
|
|
{
|
|
/**
|
|
* Ont ajoute de nouveaux ratios a cette endroit
|
|
* @var unknown_type
|
|
*/
|
|
$user = new Utilisateur();
|
|
if(!$user->checkPerm('INDISCORE3'))
|
|
$this->_forward('perms', 'error');
|
|
$tableau = array(
|
|
'EQUILIBRE FINANCIER' => array('r233' => '>', 'r234' => '>', 'r237' => '>', 'r238' => '>', 'r239' => '>', 'r240' => '>'),
|
|
'PROFITABILITE' => array('r262' => '>', 'r263' => '>', 'r264' => '>', 'r265' => '>', 'r266' => '>'),
|
|
'LIQUIDITE' => array('r250' => '>', 'r251' => '>', 'r252' => '>'),
|
|
'ENDETTEMENT' => array('r244' => '<', 'r247' => '<', 'r248' => '<'),
|
|
'PRODUCTIVITE' => array('r271' => '>', 'r278' => '<', 'r279' => '<', 'r281' => '<', 'r261' => '>', 'r267' => '>')
|
|
);
|
|
$tab = array();
|
|
$siret = $this->getRequest()->getParam('siret');
|
|
$id = $this->getRequest()->getParam('id');
|
|
$i = 0;
|
|
$i_view = 0;
|
|
$listeDate = array();
|
|
$request = $this->getRequest();
|
|
$html = '';
|
|
$autrePage = $this->getRequest()->getParam('apage');
|
|
//Récupération des informations
|
|
if (empty($autrePage)) {
|
|
$ws = new WsScores();
|
|
$ratios = $ws->getRatios(substr($this->siret, 0, 9), 'ratios');
|
|
} else {
|
|
$ratios = $this->getRequest()->getParam('infos');
|
|
}
|
|
$type = ($request->isPost())?$request->getParam('typeBilan'):'N';
|
|
$OtherFunction = new OtherFunction();
|
|
$dateFunction = new WDate();
|
|
$entreprise = new SessionEntreprise($this->siret, $this->id);
|
|
|
|
if(isset($ratios->BilansInfos->item)) {
|
|
$date = $OtherFunction->getSwitchFormRatios($ratios, $type, $request->getParam('Date'))->dateCloture;
|
|
foreach($ratios->BilansInfos->item as $elements) {
|
|
$tab[$elements->dateCloture][$elements->typeBilan] = $elements;
|
|
$i++;
|
|
}
|
|
|
|
foreach ($tab as $champDate => $valeur)
|
|
$listeDate[] = $champDate;
|
|
|
|
if (isset($date)) {
|
|
if (!empty($date)) {
|
|
foreach ($tableau as $name => $valeur) {
|
|
$html .= '<thead><tr class="subhead">
|
|
<td class="center italique">'.$name.'</td>
|
|
<td>Entreprise</td>
|
|
<td>Secteur</td>
|
|
<td>Position</td>
|
|
</tr></thead>';
|
|
$html.= '<tbody>';
|
|
foreach ($tab[$date][$type]->RatiosEntrep->item as $element)
|
|
self::printElementRatio($tableau, $name, $element, $html, $ratios, $date, $type);
|
|
$html.= '</tbody>';
|
|
}
|
|
}
|
|
}
|
|
$this->view->assign('typeBilan', $type);
|
|
$this->view->assign('Date', $date);
|
|
$this->view->assign('i', $i_view);
|
|
$this->view->assign('html', $html);
|
|
$this->view->assign('id', $id);
|
|
$this->view->assign('ratios', $tab);
|
|
}
|
|
|
|
/** Gestion de la vue **/
|
|
$this->view->assign('raisonSociale', $entreprise->getRaisonSociale());
|
|
$this->view->assign('siret', $siret);
|
|
$this->view->assign('naf', $entreprise->getNaf());
|
|
$this->view->assign('dateFunction', $dateFunction);
|
|
$this->view->assign('AutrePage', $request->getParam('apage'));
|
|
}
|
|
|
|
/* --------------------------------------------------------------------------------------------------- */
|
|
/* Gestion des liasses fiscales */
|
|
/* ----------------------------------------------------------------------------------------------------*/
|
|
|
|
/**
|
|
* Export d'une liasse au format XLS
|
|
*/
|
|
public function liassexlsAction()
|
|
{
|
|
//@todo : Gestion des unités dans l'export XLS
|
|
|
|
$this->_helper->layout()->disableLayout();
|
|
|
|
$request = $this->getRequest();
|
|
$unite = $request->getParam('unit', '€');
|
|
$type = $request->getParam('type', '');
|
|
$date = $request->getParam('date', '');
|
|
$entreprise = new SessionEntreprise($this->siret, $this->id);
|
|
|
|
switch($type)
|
|
{
|
|
case 'C':
|
|
case 'N':
|
|
$model = 'liasse_2050';
|
|
break;
|
|
case 'S':
|
|
$model = 'liasse_2033';
|
|
break;
|
|
}
|
|
|
|
$liasses = $this->ws->getBilan(substr($this->siret, 0, 9), $date, $type, '');
|
|
$data = array();
|
|
$data['DATE_CLOTURE'] = $liasses->DATE_CLOTURE;
|
|
$data['DATE_CLOTURE_PRE'] = $liasses->DATE_CLOTURE_PRE;
|
|
$data['DUREE_MOIS'] = $liasses->DUREE_MOIS;
|
|
$data['DUREE_MOIS_PRE'] = $liasses->DUREE_MOIS_PRE;
|
|
|
|
foreach ($liasses->POSTES->item as $element)
|
|
$data[$element->id] = $element->val;
|
|
|
|
$path = APPLICATION_PATH . '/../cache/liasse/';
|
|
$file = 'liasse-'.substr($this->siret, 0, 9).'-'.$this->id.'-'.$type.$date.'.xls';
|
|
|
|
require_once 'Finance/LiasseXLS.php';
|
|
$liasse = new LiasseXLS($model);
|
|
$liasse->dataModel(substr($this->siret, 0, 9), $entreprise->getRaisonSociale(), $data);
|
|
$liasse->dataFile($file);
|
|
|
|
if( file_exists($path.$file) ){
|
|
$ws = new WsScores();
|
|
$ws->setLog('liassexls', $siren, 0, '');
|
|
$this->view->assign('file', $file);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Affichage des liasses.
|
|
* @todo :
|
|
* ATTENTION LES BILANS SIMPLIFIES ONT ETE RETIRE ALORS QU'IL FAUT LES TRAITER
|
|
* NE PAS FAIRE COMME DANS LES RATIOS
|
|
*/
|
|
public function liasseAction()
|
|
{
|
|
$user = new Utilisateur();
|
|
if(!$user->checkPerm('INDISCORE2'))
|
|
$this->_forward('perms', 'error');
|
|
/** Les ancres pour les liens **/
|
|
$ancres = array(
|
|
'C' => array('actif', 'passif', 'compteDeResultat'),
|
|
'N' => array('actif', 'passif', 'compteDeResultat', 'immobilisations',
|
|
'amortissements', 'provisions', 'creancesDettes', 'affectation'),
|
|
'A' => array('actif', 'passif', 'compteDeResultat'),
|
|
'B' => array('actif', 'passif', 'compteDeResultat')
|
|
);
|
|
|
|
/** La liste des type de bilan existant **/
|
|
$liste = array (
|
|
'N' => array(),
|
|
'S' => array(),
|
|
'C' => array(),
|
|
'B' => array(),
|
|
'A' => array());
|
|
|
|
/** Le nom des type pour le select */
|
|
$type = array (
|
|
'A' => 'Assurance',
|
|
'B' => 'Banque',
|
|
'C' => 'Consolidé',
|
|
'S' => 'Simplifié',
|
|
'N' => ''
|
|
);
|
|
|
|
/** Liste des unités que l'ont proposent **/
|
|
$unit = array (
|
|
'€' => 1,
|
|
'K€' => 1000,
|
|
'M€' => 1000000
|
|
);
|
|
$liasse = array ();
|
|
$ws = new WsScores();
|
|
$request = $this->getRequest();
|
|
$siret = $this->getRequest()->getParam('siret');
|
|
$id = $this->getRequest()->getParam('id');
|
|
$listBilan = $ws->getListeBilans(substr($this->siret, 0, 9));
|
|
$date = ($request->isPost())? $request->getParam('date') :
|
|
$listBilan->result->item[0]->dateExercice.':'.$listBilan->result->item[0]->typeBilan;
|
|
$unite = ($request->isPost())?$request->getParam('unit'):'€';
|
|
$entreprise = new SessionEntreprise($this->siret, $this->id);
|
|
|
|
if($listBilan->nbReponses > 0) {
|
|
$dateFunction= new WDate();
|
|
|
|
foreach ($listBilan->result->item as $item)
|
|
$liste[$item->typeBilan][] = $item->dateExercice;
|
|
if (!empty($date)) {
|
|
$dateAndType = explode(':', $date);
|
|
$liasses = $ws->getBilan(substr($this->siret, 0, 9), $dateAndType[0], $dateAndType[1], true);
|
|
$this->view->assign('dateCloture', $liasses->DATE_CLOTURE);
|
|
$this->view->assign('dateCloturePre', $liasses->DATE_CLOTURE_PRE);
|
|
$this->view->assign('dureesMois', $liasses->DUREE_MOIS);
|
|
$this->view->assign('dureesMoisPre', $liasses->DUREE_MOIS_PRE);
|
|
foreach ($liasses->POSTES->item as $element)
|
|
$liasse[$element->id] =$element->val;
|
|
$this->view->assign('date', $dateAndType[0]);
|
|
$this->view->assign('champType', $dateAndType[1]);
|
|
$this->view->assign('liasse', $liasse);
|
|
|
|
//Gestion export de la liasse au format XLS
|
|
$user = new Utilisateur();
|
|
if (in_array($user->getIdClient(), array(1,86))
|
|
&& in_array($dateAndType[1],array('C', 'N', 'S')) ) {
|
|
$this->view->assign('exportxls', true); }}
|
|
$this->view->assign('dateFunction', $dateFunction);
|
|
$this->view->assign('ancres', $ancres);
|
|
$this->view->assign('liste', $liste);
|
|
$this->view->assign('id', $id);
|
|
$this->view->assign('type', $type);
|
|
$this->view->assign('unit', $unit);
|
|
}
|
|
/** Partie vue **/
|
|
$this->view->haveLiasse = ($listBilan->nbReponses > 0)?true:false;
|
|
$this->view->assign('raisonSociale', $entreprise->getRaisonSociale());
|
|
$this->view->assign('siren', substr($this->siret, 0, 9));
|
|
$this->view->assign('siret', $siret);
|
|
}
|
|
|
|
/* --------------------------------------------------------------------------------------------------- */
|
|
/* Gestion des bourses */
|
|
/* ----------------------------------------------------------------------------------------------------*/
|
|
|
|
/**
|
|
* Fonction qui gére la cotation en bourse.
|
|
*/
|
|
public function bourseAction()
|
|
{
|
|
$siren = substr($this->siret, 0, 9);
|
|
|
|
$sessionEntreprise = new SessionEntreprise($this->siret, $this->id);
|
|
|
|
$ws = new WsScores();
|
|
$InfosBourse = $ws->getInfosBourse($siren);
|
|
|
|
Zend_Registry::get('firebug')->info($InfosBourse);
|
|
|
|
$this->view->assign('InfosBourse', $InfosBourse);
|
|
|
|
$this->view->assign('id', $this->id);
|
|
$this->view->assign('siret', $this->siret);
|
|
$this->view->assign('raisonSociale', $sessionEntreprise->getRaisonSociale());
|
|
$this->view->assign('siren', $siren);
|
|
}
|
|
|
|
/**
|
|
* Fonction qui gére les etablissements bancaires.
|
|
*/
|
|
public function banqueAction()
|
|
{
|
|
$autrePage = $this->getRequest()->getParam('apage');
|
|
//Récupération des informations
|
|
if (empty($autrePage)) {
|
|
$ws = new WsScores();
|
|
$banque = $ws->getBanques(substr($this->siret, 0, 9));
|
|
} else {
|
|
$banque = $this->getRequest()->getParam('infos');
|
|
}
|
|
|
|
$entreprise = new SessionEntreprise($this->siret, $this->id);
|
|
$this->view->assign('banques', $banque->result->item);
|
|
$this->view->assign('raisonSociale', $entreprise->getRaisonSociale());
|
|
$this->view->assign('siren', substr($this->siret, 0, 9));
|
|
}
|
|
} |