4000 lines
208 KiB
PHP
4000 lines
208 KiB
PHP
<?php
|
||
class SdMetier_Scoring_Base extends SdMetier_Scoring_Vars
|
||
{
|
||
/**
|
||
* Activation du debug
|
||
* @var boolean
|
||
*/
|
||
public $debug = false;
|
||
|
||
/**
|
||
* Enregistrement timer
|
||
* @var array
|
||
*/
|
||
protected $timer = null;
|
||
|
||
/**
|
||
* Connexion de la base de données
|
||
* @var object
|
||
*/
|
||
protected $db = null;
|
||
|
||
/**
|
||
* Identité depuis la méthode Insee::getIdentite
|
||
* @var array
|
||
*/
|
||
protected $companyIdentite;
|
||
|
||
/**
|
||
* Liste des annonces légales
|
||
* @var array
|
||
*/
|
||
protected $companyAnnonces;
|
||
|
||
/**
|
||
* Liste des bilans
|
||
* @var array
|
||
*/
|
||
protected $companyBilans;
|
||
|
||
/**
|
||
* Date de fin de recherche des événements AAAAMMJJ
|
||
* Envoyer cette date à toutes les méthodes
|
||
* @var string
|
||
*/
|
||
protected $companyEvenDateStop = null;
|
||
|
||
/**
|
||
* Cycle client pour les commentaires, 0 => aucun commentaire
|
||
* @var int
|
||
*/
|
||
protected $level = 0;
|
||
|
||
protected $nm;
|
||
protected $nmp;
|
||
protected $nmp2;
|
||
protected $nmp3;
|
||
protected $nmp4;
|
||
protected $regR;
|
||
protected $regRs;
|
||
|
||
protected $tabRegX;
|
||
|
||
protected $tabVariables;
|
||
protected $tabFormules;
|
||
protected $tabFormulesRatios;
|
||
protected $tva;
|
||
|
||
|
||
/**
|
||
*
|
||
*/
|
||
public function __construct($db = null)
|
||
{
|
||
if ( $db === null ) {
|
||
$this->db = new WDB();
|
||
}
|
||
|
||
// --- Initialisation tableau libellé des variables
|
||
$this->tabVariables = include __DIR__ . '/Data/Variables.php';
|
||
|
||
// --- Initialisation formules
|
||
$this->tabFormules = include __DIR__ . '/Data/Formules.php';
|
||
}
|
||
|
||
/**
|
||
* Défini une date limite de prise en compte des événements
|
||
* @param string $date AAAAMMJJ
|
||
*/
|
||
public function setEvenLimit($date)
|
||
{
|
||
$this->companyEvenDateStop = $date;
|
||
}
|
||
|
||
/**
|
||
* Défini le niveau des commentaires
|
||
* @param int $num
|
||
*/
|
||
public function setCommentLevel($num)
|
||
{
|
||
$this->level = $num;
|
||
}
|
||
|
||
public function injectAnnonces(){}
|
||
|
||
public function injectIdentite(){}
|
||
|
||
public function injectBilans(){}
|
||
|
||
/**
|
||
* Return the history of previous stored IndiScores on the companies
|
||
* @param string $siren
|
||
* Siren number of the company
|
||
* @return array
|
||
*/
|
||
public function getIndiscoreHisto($siren)
|
||
{
|
||
if (intval($siren) < 1000) return false;
|
||
|
||
$query="SELECT siren, actif, procol, naf, indiScore, indiScore20, encours, indiScoreDate, dateBilan, sourceModif, scoreSolv, scoreDir, scoreConf, scoreZ, scoreCH, scoreAfdcc1, scoreAfdcc2, scoreAfdcc2note, scoreAltman, scoreAltmanCote, scoreCCF, cs, csMoisMaj, csMoisFin, adresseDom, situFi, infoNote, noteStruct, noteFin, tendance, nbModifs, dateUpdate
|
||
FROM jo.scores_surveillance
|
||
WHERE siren=$siren
|
||
UNION SELECT siren, actif, procol, naf, indiScore, indiScore20, encours, indiScoreDate, dateBilan, sourceModif, scoreSolv, scoreDir, scoreConf, scoreZ, scoreCH, scoreAfdcc1, scoreAfdcc2, scoreAfdcc2note, scoreAltman, scoreAltmanCote, scoreCCF, cs, csMoisMaj, csMoisFin, adresseDom, situFi, infoNote, noteStruct, noteFin, tendance, nbModifs, dateUpdate
|
||
FROM historiques.scores_surveillance
|
||
WHERE siren=$siren
|
||
GROUP BY indiScoreDate
|
||
ORDER BY indiScoreDate DESC";
|
||
$iDb = new WDB();
|
||
$ret = $iDb->query($query);
|
||
$tabRet = array();
|
||
while( $ret = $iDb->fetch(MYSQL_ASSOC) ) {
|
||
$tabRet[]=array(
|
||
'siren' => $ret['siren'],
|
||
'actif' => $ret['actif'],
|
||
'procol' => $ret['procol'],
|
||
'naf' => $ret['naf'],
|
||
'indiScore' => $ret['indiScore'],
|
||
'indiScore20' => $ret['indiScore20'],
|
||
'encours' => $ret['encours'],
|
||
'indiScoreDate' => $ret['indiScoreDate'],
|
||
'dateBilan' => $ret['dateBilan'],
|
||
'sourceModif' => $ret['sourceModif'],
|
||
'scoreSolv' => $ret['scoreSolv'],
|
||
'scoreDir' => $ret['scoreDir'],
|
||
'scoreConf' => $ret['scoreConf'],
|
||
'scoreZ' => $ret['scoreZ'],
|
||
'scoreCH' => $ret['scoreCH'],
|
||
'scoreAfdcc1' => $ret['scoreAfdcc1'],
|
||
//'scoreAfdcc2' => $ret['scoreAfdcc2'],
|
||
'scoreAfdcc2note' => $ret['scoreAfdcc2note'],
|
||
'scoreAltman' => $ret['scoreAltman'],
|
||
'scoreAltmanCote' => $ret['scoreAltmanCote'],
|
||
'scoreCCF' => $ret['scoreCCF'],
|
||
'cs' => $ret['cs'],
|
||
'csMoisMaj' => $ret['csMoisMaj'],
|
||
'csMoisFin' => $ret['csMoisFin'],
|
||
'adresseDom' => $ret['adresseDom'],
|
||
'situFi' => $ret['situFi'],
|
||
'infoNote' => $ret['infoNote'],
|
||
'noteStruct' => $ret['noteStruct'],
|
||
'noteFin' => $ret['noteFin'],
|
||
'tendance' => $ret['tendance'],
|
||
'nbModifs' => $ret['nbModifs'],
|
||
'dateUpdate' => $ret['dateUpdate'],
|
||
);
|
||
}
|
||
return $tabRet;
|
||
}
|
||
|
||
/**
|
||
* Récupére les scores dans la table de cache scores_surveillance
|
||
* @param string $siren
|
||
* @return array
|
||
*/
|
||
public function getIndiscoreCache($siren)
|
||
{
|
||
if ($siren<1000) return false;
|
||
$query="SELECT siren, actif, procol, naf, indiScore, indiScore20, encours, indiScoreDate, dateBilan, sourceModif, scoreSolv, scoreDir, scoreConf, scoreZ, scoreCH, scoreAfdcc1, scoreAfdcc2, scoreAfdcc2note, scoreAltman, scoreAltmanCote, scoreCCF, cs, csMoisMaj, csMoisFin, adresseDom, situFi, infoNote, noteStruct, noteFin, tendance, nbModifs, dateUpdate
|
||
FROM jo.scores_surveillance
|
||
WHERE siren=$siren
|
||
ORDER BY indiScoreDate DESC";
|
||
$iDb = new WDB();
|
||
$ret = $iDb->query($query);
|
||
$tabRet = array();
|
||
while( $ret = $iDb->fetch(MYSQL_ASSOC) ) {
|
||
$tabRet[] = array (
|
||
'siren' => $ret['siren'],
|
||
'actif' => $ret['actif'],
|
||
'procol' => $ret['procol'],
|
||
'naf' => $ret['naf'],
|
||
'indiScore' => $ret['indiScore'],
|
||
'indiScore20' => $ret['indiScore20'],
|
||
'encours' => $ret['encours'],
|
||
'indiScoreDate' => $ret['indiScoreDate'],
|
||
'dateBilan' => $ret['dateBilan'],
|
||
'sourceModif' => $ret['sourceModif'],
|
||
'scoreSolv' => $ret['scoreSolv'],
|
||
'scoreDir' => $ret['scoreDir'],
|
||
'scoreConf' => $ret['scoreConf'],
|
||
'scoreZ' => $ret['scoreZ'],
|
||
'scoreCH' => $ret['scoreCH'],
|
||
'scoreAfdcc1' => $ret['scoreAfdcc1'],
|
||
//'scoreAfdcc2' => $ret['scoreAfdcc2'],
|
||
'scoreAfdcc2note' => $ret['scoreAfdcc2note'],
|
||
'scoreAltman' => $ret['scoreAltman'],
|
||
'scoreAltmanCote' => $ret['scoreAltmanCote'],
|
||
'scoreCCF' => $ret['scoreCCF'],
|
||
'cs' => $ret['cs'],
|
||
'csMoisMaj' => $ret['csMoisMaj'],
|
||
'csMoisFin' => $ret['csMoisFin'],
|
||
'adresseDom' => $ret['adresseDom'],
|
||
'situFi' => $ret['situFi'],
|
||
'infoNote' => $ret['infoNote'],
|
||
'noteStruct' => $ret['noteStruct'],
|
||
'noteFin' => $ret['noteFin'],
|
||
'tendance' => $ret['tendance'],
|
||
'nbModifs' => $ret['nbModifs'],
|
||
'dateUpdate' => $ret['dateUpdate'],
|
||
);
|
||
}
|
||
return $tabRet;
|
||
}
|
||
|
||
|
||
/**
|
||
* Return the medium indiscore on an activity sector
|
||
* @param string $naf5
|
||
* @return array
|
||
*/
|
||
public function getScoreSecteur($naf5)
|
||
{
|
||
if (len($naf)<>5) return false;
|
||
$tabTmp=$iDb->select('jo.scores_surveillance',
|
||
'naf, AVG(indiScore) AS score100moy, AVG(indiScore20) AS score20moy, AVG(encours) AS encoursMoy, MAX(indiScoreDate) AS lastScore, COUNT(siren) AS nbSiren',
|
||
"naf='$naf5' AND actif=1", false, MYSQL_ASSOC);
|
||
if ( count($tabTmp)>0 ) {
|
||
$tabTmp=$tabTmp[0];
|
||
return array(
|
||
'naf' => $tabTmp['naf'],
|
||
'score100moy' => $tabTmp['score100moy'],
|
||
'score20moy' => $tabTmp['score20moy'],
|
||
'encoursMoy' => $tabTmp['encoursMoy'],
|
||
'lastScore' => $tabTmp['lastScore'],
|
||
'nbScoresn' => $tabTmp['nbSiren']
|
||
);
|
||
}
|
||
|
||
return array();
|
||
}
|
||
|
||
/**
|
||
* Taux de tva
|
||
* @param string $date AAAAMM
|
||
* @return double
|
||
*/
|
||
public function getTxTva($date)
|
||
{
|
||
$tabTxTva = include __DIR__ . '/Data/Tva.php';
|
||
foreach ($tabTxTva as $ym => $v) {
|
||
if ($ym > $date) {
|
||
break;
|
||
}
|
||
$tva = $v;
|
||
}
|
||
return $tva;
|
||
}
|
||
|
||
/**
|
||
* Donne le taux de rendement des actions pour une année donnée
|
||
* @param unknown $annee
|
||
* @return unknown
|
||
*/
|
||
public function getTxRendement($annee)
|
||
{
|
||
$tabTxRendObli = include __DIR__ . '/Data/RendObli.php';
|
||
if ( isset($tabTxRendObli[$annee]) ) {
|
||
return $tabTxRendObli[$annee];
|
||
}
|
||
}
|
||
|
||
/**
|
||
* Formattage élément numéraire en texte
|
||
* @param number $nombre
|
||
* @param int $decimales
|
||
* @param string $sepDec
|
||
* @param string $sepMil
|
||
* @param string $unite
|
||
* @param string $signe
|
||
*/
|
||
public function number_format2($nombre, $decimales, $sepDec, $sepMil, $unite, $signe)
|
||
{
|
||
if (round($nombre,$decimales) == round($nombre)) {
|
||
$decimales = 0;
|
||
}
|
||
if ($signe == '+') {
|
||
if ($nombre > 0) {
|
||
return '+ '.number_format(abs($nombre),$decimales,$sepDec,$sepMil).' '.$unite;
|
||
} elseif ($nombre<0) {
|
||
return '- '.number_format(abs($nombre),$decimales,$sepDec,$sepMil).' '.$unite;
|
||
} else {
|
||
return number_format(abs($nombre),$decimales,$sepDec,$sepMil).' '.$unite;
|
||
}
|
||
} elseif ($signe=='!') {
|
||
return number_format(abs($nombre),$decimales,$sepDec,$sepMil).' '.$unite;
|
||
} else {
|
||
return number_format($nombre,$decimales,$sepDec,$sepMil).' '.$unite;
|
||
}
|
||
}
|
||
|
||
/**
|
||
* Formatte les entités Ratio en mode texte
|
||
* @param array $ratio
|
||
* @param string $id
|
||
* @param string $unite
|
||
* @param string $forceSigne
|
||
* @return string
|
||
*/
|
||
public function formatRatio($ratio, $id, $unite, $forceSigne='')
|
||
{
|
||
switch (trim(strtoupper($unite))) {
|
||
case 'EU':
|
||
case 'EUR':
|
||
if ($ratio[$id] >= 0 && $ratio[$id] < 5000 || $ratio[$id] > -5000 && $ratio[$id] <= 0) {
|
||
return number_format2($ratio[$id],0,',',' ','€', $forceSigne);
|
||
} elseif ($ratio[$id] <= -10000000 || $ratio[$id] >= 10000000) {
|
||
return number_format2($ratio[$id]/1000000,0,',',' ','M€', $forceSigne);
|
||
} else {
|
||
return number_format2($ratio[$id]/1000,0,',',' ','K€', $forceSigne);
|
||
}
|
||
break;
|
||
case '%':
|
||
if ($ratio[$id] >= 0 && $ratio[$id] < 10) {
|
||
return number_format2($ratio[$id],1,',',' ','%', $forceSigne);
|
||
} elseif ($ratio[$id] > -10 && $ratio[$id] < 0) {
|
||
return number_format2($ratio[$id],1,',',' ','%', $forceSigne);
|
||
} else {
|
||
return number_format2($ratio[$id],0,',',' ','%', $forceSigne);
|
||
}
|
||
break;
|
||
case 'AN':
|
||
if ($ratio[$id] >= -1 && $ratio[$id] <= 1) {
|
||
return number_format2($ratio[$id],0,',',' ','an', $forceSigne);
|
||
} else {
|
||
return number_format2($ratio[$id],0,',',' ','ans', $forceSigne);
|
||
}
|
||
break;
|
||
case 'JOURS':
|
||
if ($ratio[$id] < 0) {
|
||
$signe=-1;
|
||
} else {
|
||
$signe=1;
|
||
}
|
||
$vabsolue = abs($ratio[$id]);
|
||
$an = 0;
|
||
while ($vabsolue>360) {
|
||
$vabsolue = $vabsolue-360;
|
||
$an++;
|
||
}
|
||
if ($an>1) {
|
||
return number_format2($an*$signe,0,',',' ','ans', $forceSigne);
|
||
} elseif ($an == 1) {
|
||
return number_format2($an*$signe,0,',',' ','an', $forceSigne);
|
||
} elseif ($vabsolue <= 1) {
|
||
return number_format2($vabsolue*$signe,0,',',' ','jour', $forceSigne);
|
||
} else {
|
||
return number_format2($vabsolue*$signe,0,',',' ','jours', $forceSigne);
|
||
}
|
||
break;
|
||
case 'PERS':
|
||
return number_format2($ratio[$id],0,',',' ', 'salarié(s)', $forceSigne);
|
||
break;
|
||
case 'U':
|
||
return number_format2($ratio[$id],1,',',' ', '', $forceSigne);
|
||
break;
|
||
default:
|
||
break;
|
||
}
|
||
|
||
return $ratio[$id].' '.$unite;
|
||
}
|
||
|
||
/**
|
||
* Formattage des variables pour affichage
|
||
* @param string $var
|
||
* @param int $longeur
|
||
* @param string $fonction
|
||
* @return mixed
|
||
*/
|
||
public function formatValeur($var, $longeur=0, $fonction='')
|
||
{
|
||
$classWdate = new WDate();
|
||
$varValue = strtr($var, array('{'=>'','}'=>''));
|
||
$varLabel = strtr($varValue, array('$'=>''));
|
||
|
||
// --- Gestion des valeurs présentent dans un tableau de variables
|
||
if ( isset($this->tabVariables[$varLabel]) ) {
|
||
if ($longeur > 0) {
|
||
return $var;
|
||
} else {
|
||
// Tableau ZEMET
|
||
if ($varLabel == 'ZEMET') {
|
||
if (substr($this->DateNotice80,0,4) >= 2010) {
|
||
$tableZemet = 'ZEMET2010';
|
||
} else {
|
||
$tableZemet = 'ZEMET1994';
|
||
}
|
||
// Cette variable a un libellé associé
|
||
if (isset($this->tabVariables[$tableZemet][$this->RPET.$this->ZEMET]['art'])) {
|
||
return $this->tabVariables[$tableZemet][$this->RPET.$this->ZEMET]['art'];
|
||
} else {
|
||
return $this->tabVariables[$tableZemet][$this->RPET.$this->ZEMET]['lib'];
|
||
}
|
||
}
|
||
// Cette variable a un libellé associé
|
||
if (isset($this->tabVariables[$varLabel][$this->{$varValue}]['lib'])) {
|
||
return $this->tabVariables[$varLabel][$this->{$varValue}]['lib'];
|
||
} elseif (isset($this->tabVariables[$varLabel]['0'.$this->{$varValue}]['lib'])) {
|
||
return $this->tabVariables[$varLabel]['0'.$this->{$varValue}]['lib'];
|
||
}
|
||
}
|
||
}
|
||
// --- Formattage variable [...]DATE
|
||
elseif (preg_match('/DATE$/', $varLabel)) {
|
||
return preg_replace('/00\//','01/',
|
||
$classWdate->dateT('Ymd','d/m/Y', substr(str_replace('-','',$this->{$varValue}),0,8)));
|
||
}
|
||
// --- Formattage variable [...]DATEp[NNNN]
|
||
elseif (preg_match('/DATEp[0-9]{0,}$/', $varLabel)) {
|
||
return preg_replace('/00\//','01/',
|
||
$classWdate->dateT('Ymd','d/m/Y', substr(str_replace('-','',$this->{$varValue}),0,8)));
|
||
}
|
||
// --- Formattage variable [...]MMAA
|
||
elseif (preg_match('/MMAA$/', $varLabel)) {
|
||
return $classWdate->dateT('Y-m','M Y', $this->{$varValue});
|
||
}
|
||
// --- Formattage variable [...]_MT
|
||
elseif (preg_match('/_MT$/', $varLabel)) {
|
||
return number_format($this->{$varValue}, 2, ',', ' ').' €';
|
||
}
|
||
// --- Formattage variable [...]_NB
|
||
elseif (preg_match('/_NB$/', $varLabel)) {
|
||
return number_format($this->{$varValue}, 0, ',', ' ');
|
||
}
|
||
// --- Formattage variable [...]_EU
|
||
elseif (preg_match('/_EU$/', $varLabel)) {
|
||
if ($this->{$varValue}>=0 && $this->{$varValue}<10 || $this->{$varValue}>-10 && $this->{$varValue}<=0) {
|
||
return number_format($this->{$varValue}, 2, ',', ' ').' €';
|
||
} elseif ($this->{$varValue}>=10 && $this->{$varValue}<5000 || $this->{$varValue}>-5000 && $this->{$varValue}<=10) {
|
||
return number_format($strTmp,0,',',' ').' €';
|
||
} elseif ($this->{$varValue}<=-10000000 || $this->{$varValue}>=10000000) {
|
||
return number_format($this->{$varValue}/1000000, 0, ',', ' ').' M€';
|
||
} else {
|
||
return number_format($this->{$varValue}/1000, 0, ',', ' ').' K€';
|
||
}
|
||
}
|
||
// --- Formattage variable [...]_POURC
|
||
elseif (preg_match('/_POURC$/', $varLabel)) {
|
||
$strTmp = eval("return $varValue;");
|
||
if ($this->{$varValue}>=10 || $this->{$varValue}<=-10)
|
||
return number_format($this->{$varValue}, 0, ',', ' ').' %';
|
||
elseif ($this->{$varValue}>=1 || $this->{$varValue}<=-1)
|
||
return number_format($this->{$varValue}, 1, ',', ' ').' %';
|
||
else
|
||
return number_format($this->{$varValue}, 3, ',', ' ').' %';
|
||
}
|
||
// --- Formattage variable [...]CAPITAL
|
||
elseif (preg_match('/CAPITAL$/', $varLabel)) {
|
||
return number_format($this->CAPITAL, 0, ',', ' ').' €';
|
||
}
|
||
// --- Formattage variable [...]CAPITAL_PRE
|
||
elseif (preg_match('/CAPITAL_PRE$/', $varLabel)) {
|
||
return number_format($this->CAPITAL_PRE, 0, ',', ' ').' €';
|
||
}
|
||
// --- Formattage variable [...]CAPITAL_MTACTION
|
||
elseif (preg_match('/CAPITAL_MTACTION$/', $varLabel)) {
|
||
return number_format($this->CAPITAL_MTACTION, 0, ',', ' ').' €';
|
||
}
|
||
// --- Formattage variable [...]CAPITAL_NBACTION
|
||
elseif (preg_match('/CAPITAL_NBACTION$/', $varLabel)) {
|
||
return number_format($this->CAPITAL_NBACTION, 0, ',', ' ');
|
||
}
|
||
// --- Formattage variable CAESTIME
|
||
elseif (preg_match('/^CAESTIME$/', $varLabel)) {
|
||
return number_format($this->CAESTIME/1000,0,',',' ').' k€';
|
||
}
|
||
// --- Formattage variable CABIOUES
|
||
elseif (preg_match('/^CABIOUES$/', $varLabel)) {
|
||
return number_format($this->CABIOUES/1000,0,',',' ').' k€';
|
||
}
|
||
// --- Formattage variable [...]DIMMAT
|
||
elseif (preg_match('/DIMMAT$/', $varLabel)) {
|
||
return preg_replace('/00\//','01/',
|
||
$classWdate->dateT('Ymd','d/m/Y', substr(str_replace('-','',$this->DIMMAT),0,8)));
|
||
}
|
||
// --- Formattage variable [...]DCREN
|
||
elseif (preg_match('/DCREN$/',$varLabel)) {
|
||
return preg_replace('/00\//','01/',
|
||
$classWdate->dateT('Ymd','d/m/Y', substr(str_replace('-','',$this->DCREN),0,8)));
|
||
}
|
||
// --- Formattage variable [...]MARCHEVOL
|
||
elseif (preg_match('/MARCHEVOL$/', $varLabel))
|
||
{
|
||
if (abs($MARCHEVOL)>=5) return round($MARCHEVOL).' %';
|
||
else return number_format($MARCHEVOL,3,',',' ').' %';
|
||
}
|
||
// --- Formattage variable [...]MARCHEPART
|
||
elseif (preg_match('/MARCHEPART$/', $varLabel)) {
|
||
if (abs($this->MARCHEPART)>=5) {
|
||
return round($this->MARCHEPART).' %';
|
||
} else {
|
||
return number_format($this->MARCHEPART,3,',',' ').' %';
|
||
}
|
||
}
|
||
// --- Formattage variable [...]MARCHEPARTp
|
||
elseif (preg_match('/MARCHEPARTp$/', $varLabel)) {
|
||
if (abs($this->MARCHEPARTp)>=5) {
|
||
return round($this->MARCHEPARTp).' %';
|
||
} else {
|
||
return number_format($this->MARCHEPARTp,3,',',' ').' %';
|
||
}
|
||
}
|
||
// --- Formattage variable [...]MARCHEPARTEVOL
|
||
elseif (preg_match('/MARCHEPARTEVOL$/', $varLabel)) {
|
||
if (abs($this->MARCHEPARTEVOL) >= 5) {
|
||
return round($this->MARCHEPARTEVOL).' %';
|
||
} else {
|
||
return number_format($this->MARCHEPARTEVOL,3,',',' ').' %';
|
||
}
|
||
}
|
||
// --- Formattage variable [...]MARCHE
|
||
elseif (preg_match('/MARCHE$/', $varLabel)) {
|
||
if ($this->MARCHE < 10000) {
|
||
return number_format($MARCHE,0, ',', ' ').' €';
|
||
} elseif ($this->MARCHE < 1000000) {
|
||
return number_format($this->MARCHE / 1000, 0, ',', ' ').' K€';
|
||
} elseif ($this->MARCHE < 1000000000) {
|
||
return number_format($this->MARCHE / 1000000, 0, ',', ' ').' M€';
|
||
}else {
|
||
return number_format($this->MARCHE / 1000000000, 0, ',', ' ')." milliards d'€";
|
||
}
|
||
}
|
||
// --- Formattage variable [...]MARCHEp
|
||
elseif (preg_match('/MARCHEp$/', $varLabel)) {
|
||
if ($this->MARCHEp < 10000) {
|
||
return number_format($MARCHEp,0, ',', ' ').' €';
|
||
} elseif ($this->MARCHEp < 1000000) {
|
||
return number_format($this->MARCHEp / 1000, 0, ',', ' ').' K€';
|
||
} elseif ($this->MARCHEp < 1000000000) {
|
||
return number_format($this->MARCHEp / 1000000, 0, ',', ' ').' M€';
|
||
}else {
|
||
return number_format($this->MARCHEp / 1000000000, 0, ',', ' ')." milliards d'€";
|
||
}
|
||
}
|
||
// --- Formattage variable CA_Y[*]
|
||
elseif (preg_match('/^CA_Y\[(.*)\]/U', $varLabel, $matches2)) {
|
||
return number_format($this->CA_Y[$matches2[1]]/1000, 0, ',', ' ').' K€';
|
||
}
|
||
// --- Formattage variable RCAI_Y[*]
|
||
elseif (preg_match('/^RCAI_Y\[(.*)\]/U', $varLabel, $matches2)) {
|
||
return number_format($this->RCAI_Y[$matches2[1]]/1000, 0, ',', ' ').' K€';
|
||
}
|
||
// --- Formattage variable [...]_MT || [...]_TAUX
|
||
elseif (preg_match('/(_COEF|_TAUX)$/', $varLabel)) {
|
||
$strTmp=eval("return $varValue;");
|
||
return number_format($this->{$varValue}, 2, ',', '').' %';
|
||
}
|
||
// --- Formattage variable SIREN
|
||
elseif (preg_match('/^SIREN$/', $varLabel)) {
|
||
return sprintf("%09s", $this->SIREN);
|
||
}
|
||
// --- Formattage variable SIRET
|
||
elseif (preg_match('/^SIRET$/', $varLabel)) {
|
||
return sprintf("%09s", substr($this->SIRET,0,9)).' '.substr($this->SIRET,-5);
|
||
}
|
||
// --- Formattage variable SIRENMERE
|
||
elseif (preg_match('/^SIRENMERE$/', $varLabel)) {
|
||
return sprintf("%09s", $this->SIRENMERE);
|
||
}
|
||
// --- Formattage variable SIRETMERE
|
||
elseif (preg_match('/^SIRETMERE$/', $varLabel)) {
|
||
return sprintf("%09s", substr($this->SIRETMERE,0,9)).' '.substr($this->SIRETMERE,-5);
|
||
}
|
||
// --- Formattage variable SIRENFILLE
|
||
elseif (preg_match('/^SIRENFILLE$/', $varLabel)) {
|
||
return sprintf("%09s", $this->SIRENFILLE);
|
||
}
|
||
// --- Formattage variable SIRETFILLE
|
||
elseif (preg_match('/^SIRETFILLE$/', $varLabel)) {
|
||
return sprintf("%09s", substr($this->SIRETFILLE,0,9)).chr(160).substr($this->SIRETFILLE,-5);
|
||
}
|
||
// --- Formattage variable TVAINTRA
|
||
elseif (preg_match('/^TVAINTRA$/', $varLabel)) {
|
||
return substr($this->TVAINTRA,0,2).' '.substr($this->TVAINTRA,2,2).' '.substr($this->TVAINTRA,4);
|
||
}
|
||
// --- Formattage variable DELAIPAY
|
||
elseif (preg_match('/^DELAIPAY$/', $varLabel))
|
||
{
|
||
return number_format($this->DELAIPAY,0,',',' ').' jours';
|
||
}
|
||
// --- Formattage variable DELAIPAYp
|
||
elseif (preg_match('/^DELAIPAYp$/', $varLabel)) {
|
||
return number_format($this->DELAIPAYp,0,',',' ').' jours';
|
||
}
|
||
// --- Formattage variable SCOREDEFTAUX
|
||
elseif (preg_match('/^SCOREDEFTAUX$/', $varLabel)) {
|
||
if ($this->SCOREDEFTAUX >= 5) {
|
||
return round($this->SCOREDEFTAUX).' %';
|
||
}
|
||
else {
|
||
return number_format($this->SCOREDEFTAUX, 3, ',', ' ').' %';
|
||
}
|
||
}
|
||
// --- Formattage variable BILANANNEE
|
||
elseif (preg_match('/BILANANNEE$/', $varLabel)) {
|
||
return $this->BILANANNEE;
|
||
}
|
||
|
||
return $this->{$var};
|
||
}
|
||
|
||
/**
|
||
* Format value for display
|
||
* @param string $matches
|
||
*/
|
||
public function format($matches)
|
||
{
|
||
$strRetour='$'.$matches[1];
|
||
$strUnite='';
|
||
|
||
// --- Moyenne
|
||
if (preg_match("/\{MOY\(R\[(\d+)\],(\d+)\)/Ui", $strRetour, $matches2)) {
|
||
$tmpRatioId = $matches2[1]*1;
|
||
$tmpAnnees = $matches2[2]*1;
|
||
$valeur = $this->R[$tmpRatioId];
|
||
for($iMoy=0; $iMoy<$tmpAnnees; $iMoy++) {
|
||
if ($iMoy==1) $valeur+= $this->Rp[$tmpRatioId];
|
||
elseif ($iMoy==2) $valeur+= $this->Rp2[$tmpRatioId];
|
||
elseif ($iMoy==3) $valeur+= $this->Rp3[$tmpRatioId];
|
||
elseif ($iMoy==4) $valeur+= $this->Rp4[$tmpRatioId];
|
||
}
|
||
return formatRatio('', $valeur/$tmpAnnees, strtoupper($this->tabFormulesRatios[$tmpRatioId]['unite']));
|
||
}
|
||
// --- Graphique
|
||
elseif (preg_match('/\{GRAPH\((.*)\)\}/Ui', $strRetour, $matches2)) {
|
||
return $matches[1];
|
||
}
|
||
// --- Ratios
|
||
elseif (preg_match('/\$\{(\+|!|)(Rp4|Rp3|Rp2|Rp|Rs|Rsp|Rap|Ra|Rdiff|Revolp2|Revolp|Revol|R|regR)\[(\d+)\]\}/Ui', $strRetour, $matches2)) {
|
||
$tmpRatio = $matches2[2];
|
||
$tmpRatioId = $matches2[3]*1;
|
||
$unite = strtoupper($this->tabFormulesRatios[$tmpRatioId]['unite']);
|
||
if ($matches2[1]=='+') {
|
||
$forceSigne='+';
|
||
} elseif ($matches2[1]=='!') {
|
||
$forceSigne='!';
|
||
} else {
|
||
$forceSigne='';
|
||
}
|
||
if ($tmpRatio=='R') {
|
||
return formatRatio($this->R, $tmpRatioId, $unite, $forceSigne);
|
||
} elseif ($tmpRatio=='Rp') {
|
||
return formatRatio($this->Rp, $tmpRatioId, $unite, $forceSigne);
|
||
} elseif ($tmpRatio=='Rp2') {
|
||
return formatRatio($this->Rp2, $tmpRatioId, $unite, $forceSigne);
|
||
} elseif ($tmpRatio=='Rp3') {
|
||
return formatRatio($this->Rp3, $tmpRatioId, $unite, $forceSigne);
|
||
} elseif ($tmpRatio=='Rp4') {
|
||
return formatRatio($this->Rp4, $tmpRatioId, $unite, $forceSigne);
|
||
} elseif ($tmpRatio=='Ra') {
|
||
return formatRatio($this->Ra, $tmpRatioId, $unite, $forceSigne);
|
||
} elseif ($tmpRatio=='Rap') {
|
||
return formatRatio($this->Rap, $tmpRatioId, $unite, $forceSigne);
|
||
} elseif ($tmpRatio=='Rs') {
|
||
return formatRatio($this->Rs, $tmpRatioId, $unite, $forceSigne);
|
||
} elseif ($tmpRatio=='Rsp') {
|
||
return formatRatio($this->Rsp, $tmpRatioId, $unite, $forceSigne);
|
||
} elseif ($tmpRatio=='Rsp2') {
|
||
return formatRatio($this->Rsp2, $tmpRatioId, $unite, $forceSigne);
|
||
} elseif ($tmpRatio=='Rsp3') {
|
||
return formatRatio($this->Rsp3, $tmpRatioId, $unite, $forceSigne);
|
||
} elseif ($tmpRatio=='Rsp4') {
|
||
return formatRatio($this->Rsp4, $tmpRatioId, $unite, $forceSigne);
|
||
} elseif ($tmpRatio=='Revol') {
|
||
return formatRatio($this->Revol, $tmpRatioId, '%', $forceSigne);
|
||
} elseif ($tmpRatio=='Rdiff') {
|
||
return formatRatio($this->Rdiff, $tmpRatioId, $unite, $forceSigne);
|
||
} elseif ($tmpRatio=='Revolp') {
|
||
return formatRatio($this->Revolp, $tmpRatioId, '%', $forceSigne);
|
||
} elseif ($tmpRatio=='Revolp2') {
|
||
return formatRatio($this->Revolp2, $tmpRatioId, '%', $forceSigne);
|
||
} elseif ($tmpRatio=='Revolp3') {
|
||
return formatRatio($this->Revolp3, $tmpRatioId, '%', $forceSigne);
|
||
} elseif ($tmpRatio=='regR') {
|
||
return formatRatio($this->regR, $tmpRatioId, $unite, $forceSigne);
|
||
}
|
||
}
|
||
// --- Valeur
|
||
elseif (preg_match('/\$\{(.*)\((\d+)\)\}/Ui', $strRetour, $matches2)) {
|
||
$tmpVar = $matches2[1];
|
||
$tmpVarLen = $matches2[2]*1;
|
||
return $this->formatValeur('$'.$tmpVar, $tmpVarLen);
|
||
}
|
||
else {
|
||
return $this->formatValeur($strRetour);
|
||
}
|
||
|
||
return $strRetour.' '.$strUnite;
|
||
}
|
||
|
||
/**
|
||
* Projection
|
||
* @param unknown $valeur
|
||
* @param unknown $nbAnnees
|
||
*/
|
||
public function PROJEC($valeur, $nbAnnees)
|
||
{
|
||
$projec = new Metier_Scores_Projection();
|
||
$projec->tabRegX = $this->tabRegX;
|
||
$result = $projec->calc($valeur, $nbAnnees);
|
||
if ( $result !== false ) {
|
||
$this->Y = $projec->getY(); //@todo : ?????
|
||
$this->Yaff = $projec->getYaff();
|
||
$this->PROJECTAUX = $projec->getProjecTaux();
|
||
$this->PROJECCOEF = $projec->getProjecCoeff();
|
||
}
|
||
}
|
||
|
||
|
||
/**
|
||
* Compute the indiScore
|
||
* @param string $siren
|
||
* @param string $type
|
||
* "scores" ou "valo"
|
||
* @param string $sourceModif
|
||
*
|
||
*/
|
||
public function calculIndiScore($siren, $type = 'scores', $sourceModif='jour')
|
||
{
|
||
$timer = array('debutIndiscore'=>microtime(true));
|
||
if (strlen($siren)>9 || (substr(''.$siren,0,9)*1)<100 ) {
|
||
return false;
|
||
}
|
||
|
||
$this->NIVEAU = $cycleClient; // 1, 2, 3 ou 5 Niveau de version des commentaires
|
||
|
||
$iInsee = new Metier_Insee_MInsee($this->db);
|
||
if ($this->companyEvenDateStop !== null) {
|
||
$iInsee->setEvenLimit($this->companyEvenDateStop);
|
||
}
|
||
|
||
/**
|
||
* Récupération des informations identitaire
|
||
*/
|
||
if ($this->companyEvenDateStop === null) {
|
||
$tabIdentite = $iInsee->getIdentiteEntreprise($siren, $nic, 0, false, false);
|
||
} else {
|
||
$tabIdentite = $iInsee->getIdentiteEntrepriseHisto($siren);
|
||
}
|
||
|
||
$timer['identite']=microtime(true);
|
||
|
||
if (empty($tabIdentite)) {
|
||
debugLog('W', "Siren $siren non présent en base", __LINE__, __FILE__, __FUNCTION__, __CLASS__);
|
||
return false;
|
||
}
|
||
|
||
$this->tva = $this->getTxTva(date('Ym'));
|
||
|
||
if ( !in_array($type, array('scores', 'valo')) ) {
|
||
$type = 'scores';
|
||
}
|
||
|
||
$genereComment = false;
|
||
if ( in_array($this->NIVEAU, array(2, 3, 4, 5)) ) {
|
||
$genereComment = true;
|
||
}
|
||
|
||
$classWdate = new WDate();
|
||
|
||
//Initialisation tabFormules depuis le cache
|
||
$tabFormules = include __DIR__ . '/Data/Formules.php';
|
||
|
||
$this->tabFormulesRatios = array();
|
||
foreach ($tabFormules as $tmpFormule) {
|
||
$this->tabFormulesRatios[$tmpFormule['id']] = $tmpFormule;
|
||
$tabRatiosInfos[$tmpFormule['id']] = array('unite' => $tmpFormule['unite']);
|
||
}
|
||
|
||
$tabRatiosSecteurs = $tabRatios2 = $tabRatiosEvol = array();
|
||
|
||
$this->NIC = substr($tabIdentite['SiretSiege'],-5);
|
||
$this->SIREN = $siren;
|
||
$this->SIRET = $tabIdentite['SiretSiege'];
|
||
|
||
$this->ANNEE = date('Y')*1;
|
||
$this->ANNEEp3 = $this->ANNEE-3;
|
||
$this->ANNEEp2 = $this->ANNEE-2;
|
||
$this->ANNEEp = $this->ANNEE-1;
|
||
$this->ANNEE1 = $this->ANNEE+1;
|
||
$this->ANNEE2 = $this->ANNEE+2;
|
||
$this->ANNEE3 = $this->ANNEE+3;
|
||
$this->ANNEE4 = $this->ANNEE+4;
|
||
$this->ANNEE5 = $this->ANNEE+5;
|
||
|
||
$this->JOUR_DATE = date('Y-m-d');
|
||
$this->JOUR_HEURE = date('H:i');
|
||
|
||
/** Zones utilisées dans les calculs **/
|
||
$this->CALCUL1 = 0;
|
||
$this->CALCUL2 = 0;
|
||
$this->CALCUL3 = 0;
|
||
$this->CALCUL4 = 0;
|
||
$this->CALCUL5 = 0;
|
||
$this->CALCUL6 = 0;
|
||
$this->CALCUL7 = 0;
|
||
$this->CALCUL8 = 0;
|
||
$this->CALCUL9 = 0;
|
||
|
||
$this->ENQUETELIM = 6; // 6 mois de validités pour une note en provenance d'une enquête
|
||
$this->ENQUETEMAXI = 90; // Score Maximum / 100 en provenance d'une enquête
|
||
|
||
$tendance = '';
|
||
$naf = $tabIdentite['NafEnt'];
|
||
$this->APEETAB = $tabIdentite['NafEtab'];
|
||
$this->TRIBUNAL_ACTUEL = strtr($tabIdentite['TribunalLib'],array('TC '=>'Tribunal de Commerce de '));
|
||
$this->TRIBUNAL_CREATION = $this->TRIBUNAL_PROCOL='';
|
||
|
||
$nafLib = $tabIdentite['NafEntLib'];
|
||
$efftr = $tabIdentite['Effectif']*1;
|
||
$fj = $tabIdentite['FJ'];
|
||
|
||
// Société côtée en bourse
|
||
$this->SOCIETE_COTE=false;
|
||
$this->SOCIETE_COTE_MARCHE_MERE=''; /** @todo: Nom du marché de l'actionnaire côté **/
|
||
$this->SOCIETE_COTE_ISIN=$tabIdentite['Isin'];
|
||
if ($this->SOCIETE_COTE_ISIN<>'') {
|
||
$this->SOCIETE_COTE=true;
|
||
$this->SOCIETE_COTE_PLACE=$tabIdentite['Bourse']['placeCotation'];
|
||
$this->SOCIETE_COTE_MARCHE=$tabIdentite['Bourse']['marche'];
|
||
$this->SOCIETE_COTE_CAPITALISATION=$tabIdentite['Bourse']['capitalisation']; // Afficher en KE
|
||
$this->SOCIETE_COTE_COURS=$tabIdentite['Bourse']['derCoursCloture'];
|
||
$this->SOCIETE_COTE_COURS_DATE=$tabIdentite['Bourse']['derCoursDate'];
|
||
$this->SOCIETE_COTE_COURS_MIN=0;//@todo:$tabRet['Bourse']['derCoursDate'];
|
||
$this->SOCIETE_COTE_COURS_MAX=0;//@todo:$tabRet['Bourse']['derCoursDate'];
|
||
}
|
||
|
||
// Elements provenant du Notice 80 hors identité
|
||
$tabIden80 = $iInsee->getInfosNotice($siren, $NIC);
|
||
$timer['getInfosNotice'] = microtime(true);
|
||
$this->RECME = $tabIden80['insRECME'];
|
||
$this->ZEMET = $tabIden80['insZEMET'];
|
||
$this->RPET = $tabIden80['insRPET'];
|
||
$this->RPEN = $tabIden80['insRPEN'];
|
||
$this->DateNotice80 = $tabIden80['dateNotice'];
|
||
$depcomen = $tabIden80['insDEPCOMEN']*1;
|
||
$this->TU = $tabIden80['insTU'];
|
||
|
||
/**
|
||
* Différences INSEE/RNCS
|
||
*/
|
||
$iRncs = new Metier_Partenaires_MRncs($this->db);
|
||
$tabIdentiteRncs = $iRncs->getInfosEntrep($siren);
|
||
$this->ACTIFRNCS = $tabIdentiteRncs['actif'];
|
||
$this->ACTIFINSEE = $tabIdentite['Actif'];
|
||
|
||
$this->APEENT = $this->APEINSEE = $naf;
|
||
$this->APERNCS = $tabIdentiteRncs['nafEnt'];
|
||
if (strlen($this->APEENT)==5) $this->APE5 = $this->APEENT;
|
||
elseif (strlen($this->APEENT)==4) $this->APE4 = $this->APEENT;
|
||
else $this->APE5 = $this->APE4 = '';
|
||
|
||
$this->DIMMAT = $tabIdentiteRncs['dateImma'];
|
||
$this->DIMMAT_AA = substr($tabIdentiteRncs['dateImma'],0,4);
|
||
|
||
$this->FJURINSEE = $tabIdentite['FJ']*1;
|
||
$this->FJURINSEE1 = substr($this->FJURINSEE,0,1)*1;
|
||
if ($this->FJURINSEE1==0) $this->FJURINSEE1=substr($this->FJURINSEE,0,1)*1;
|
||
$this->FJURINSEE2 = substr($this->FJURINSEE,0,2)*1;
|
||
if ($this->FJURINSEE2==0) $this->FJURINSEE2=$this->FJURINSEE;
|
||
|
||
$this->FJURRNCS=$tabIdentiteRncs['cj']*1;
|
||
$this->FJURRNCS1=substr($this->FJURRNCS,0,1)*1;
|
||
if ($this->FJURRNCS1==0) $this->FFJURRNCS1=substr($this->FJURRNCS,0,1)*1;
|
||
$this->FJURRNCS2=substr($this->FJURRNCS,0,2)*1;
|
||
if ($this->FJURRNCS2==0) $this->FJURRNCS2=$this->FJURRNCS;
|
||
|
||
if (trim($tabIdentiteRncs['raisonSociale'])=='') $this->PRESENTRNCS=false;
|
||
else $this->PRESENTRNCS=true;
|
||
if ($tabIdentite['Source']*1<>2) $this->PRESENTINSEE=false;
|
||
else $this->PRESENTINSEE=true;
|
||
|
||
$this->NOMEN = trim(strtr($tabIdentite['Nom'],array('*'=>' ','/'=>' ')));
|
||
$this->ENSEIGNE = $tabIdentite['Enseigne'];
|
||
$this->ENTREP_ALT = $tabIdentite['GeoAlt']; // Altitude de l'établissement
|
||
$this->ACTIVNAT = $tabIdentite['NatureActivite'];
|
||
$this->AUXILT = $tabIdentite['Auxiliaire'];
|
||
$this->ORIGINE = $tabIdentite['OrigineCreation'];
|
||
$this->ACTISURF = $tabIdentite['ACTISURF'];
|
||
$this->EXPLEN = $tabIdentite['EXPLEN'];
|
||
$this->EXPLET = $tabIdentite['EXPLET'];
|
||
$this->LIEUACT = $tabIdentite['LIEUACT'];
|
||
$this->MODEN = $tabIdentite['MODEN'];
|
||
$this->MONOACT = $tabIdentite['MONOACT'];
|
||
$this->MONOREG = $tabIdentite['MONOREG'];
|
||
$this->PRODPART = $tabIdentite['PRODPART'];
|
||
|
||
// Saisonnalité de l'activité
|
||
if ($tabIdentite['Saisonnalite']==1) $this->SAISONAT='S';
|
||
else $this->SAISONAT='P';
|
||
$this->CAPITAL = $tabIdentite['Capital'];
|
||
$this->CAPITAL_NBACTION = $tabIdentite['CapitalNbActions'];
|
||
$this->CAPITAL_MTACTION = $tabIdentite['CapitalMtActions'];
|
||
if ($this->CAPITAL>0) {
|
||
switch ($tabIdentite['CapitalType']) {
|
||
case 'V': $this->CAPITAL_TYPE = 'variable'; break;
|
||
case 'S': $this->CAPITAL_TYPE = 'fixe'; break;
|
||
default: $this->CAPITAL_TYPE = ''; break;
|
||
}
|
||
} else $this->CAPITAL_TYPE = '';
|
||
|
||
$this->TCAEXP=$tabIdentite['TrancheCAexp'];
|
||
|
||
// Formes Juridique de l'entreprise
|
||
$this->FJUR=$this->FJUR4=$fj*1;
|
||
$this->FJUR1=substr($fj,0,1)*1;
|
||
if ($this->FJUR1==0) $this->FJUR1=substr($this->FJUR,0,1)*1;
|
||
$this->FJUR2=substr($fj,0,2)*1;
|
||
if ($this->FJUR2==0) $this->FJUR2=$this->FJUR;
|
||
|
||
$this->NBETEXPL=$tabIdentite['NbEtab'];
|
||
$this->REGIMP=$tabIdentite['REGIMP'];
|
||
|
||
if (strtoupper(substr($tabIdentite['AutreId'],0,1))=='W') $this->WALDEC=$tabIdentite['AutreId'];
|
||
else $this->WALDEC='';
|
||
|
||
// AGE en mois
|
||
if ($tabIdentite['DateCreaEt']>0 && $tabIdentite['DateCreaEt']<$tabIdentite['DateCreaEn'])
|
||
$dateCrea=$tabIdentite['DateCreaEt'];
|
||
elseif ($tabIdentite['DateCreaEn']>0)
|
||
$dateCrea=$tabIdentite['DateCreaEn'];
|
||
elseif (str_replace('-','',$this->DIMMAT)*1>19000101)
|
||
$dateCrea=str_replace('-','',$this->DIMMAT);
|
||
else {
|
||
$dateCrea=0;
|
||
}
|
||
$this->DCREN = $dateCrea;
|
||
$this->DCREN_AA = substr($dateCrea,0,4);
|
||
$this->AGE = $classWdate->nbMoisEntre($dateCrea, date('Ymd'));
|
||
|
||
// --- Liste des bilans
|
||
$tabBilan = $tabBil = $this->tabRegX = array();
|
||
$mBil = new Metier_Partenaires_MBilans($siren, $this->db);
|
||
if ($this->companyEvenDateStop !== null) {
|
||
$mBil->setEvenLimit($this->companyEvenDateStop);
|
||
}
|
||
$tabBilans = $mBil->listeBilans($accesDist);
|
||
$this->NBBILAN = count($tabBilans);
|
||
if ($this->NBBILAN > 0) {
|
||
|
||
$this->BILAN = $this->BILANp = $this->BILANp2 = $this->BILANp3 = $this->BILANp4 = 0;
|
||
|
||
// --- Postes des bilans
|
||
$i = 0;
|
||
foreach ($tabBilans as $millesime => $item) {
|
||
if ($i > 4) {
|
||
break;
|
||
}
|
||
if ( $item['typeBilan'] == 'N' ) {
|
||
$tabBilan[] = $mBil->getBilan(substr($millesime,-10), substr($millesime,0,1), '');
|
||
$i++;
|
||
} elseif ( $item['typeBilan'] == 'S' ) {
|
||
$tabN = $mBil->getBilan(substr($millesime,-10), substr($millesime,0,1), '');
|
||
$tabS = $mBil->bilanSimplifie2Normal($tabN);
|
||
$tabBilan[] = array_merge($tabN, $tabS);
|
||
$i++;
|
||
}
|
||
|
||
$this->tabRegX[] = $item['millesime'];
|
||
|
||
}
|
||
|
||
// --- Bilan le plus récent disponible
|
||
if (isset($tabBilan[0])) {
|
||
$this->EFFBILAN = $tabBilan[0]['YP'];
|
||
$this->nm = $nbMoisBilCumul = $tabBilan[0]['DUREE_MOIS'];
|
||
$this->BILANDATE = $tabBilan[0]['DATE_CLOTURE'];
|
||
$this->BILANDATEp = $tabBilan[0]['DATE_CLOTURE_PRE'];
|
||
if ($this->BILANDATEp == 0 && isset($tabBilan[1])) {
|
||
$this->BILANDATEp = $tabBilan[1]['DATE_CLOTURE'];
|
||
$this->BILANANNEEp = substr($this->BILANDATEp,0,4)*1;
|
||
}
|
||
$this->BILANANNEE = substr($this->BILANDATE,0,4)*1;
|
||
$this->nmp = $tabBilan[0]['DUREE_MOIS_PRE'];
|
||
if ($this->BILANANNEEp > 0) {
|
||
$this->BILANp = 1;
|
||
$nbMoisBilDate = $classWdate->nbMoisEntre($this->BILANDATEp, $this->BILANDATE);
|
||
$nbMoisBilCumul += $this->nmp;
|
||
}
|
||
}
|
||
|
||
// --- Elements des 5 bilans les plus récent
|
||
if (isset($tabBilan[2])) {
|
||
$this->BILANDATEp2 = $tabBilan[2]['DATE_CLOTURE'];
|
||
$this->BILANANNEEp2 = substr($this->BILANDATEp2,0,4)*1;
|
||
$this->nmp2=$tabBilan[2]['DUREE_MOIS'];
|
||
if ($this->BILANANNEEp2 > 0) {
|
||
$this->BILANp2 = 1;
|
||
$nbMoisBilDate = $classWdate->nbMoisEntre($this->BILANDATEp2, $this->BILANDATE);
|
||
$nbMoisBilCumul += $this->nmp2;
|
||
}
|
||
}
|
||
|
||
if (isset($tabBilan[3])) {
|
||
$this->BILANDATEp3 = $tabBilan[3]['DATE_CLOTURE'];
|
||
$this->BILANANNEEp3 = substr($this->BILANDATEp3,0,4)*1;
|
||
$this->nmp3 = $tabBilan[3]['DUREE_MOIS'];
|
||
if ($this->BILANANNEEp3 > 0) {
|
||
$this->BILANp3 = 1;
|
||
$nbMoisBilDate = $classWdate->nbMoisEntre($this->BILANDATEp3, $this->BILANDATE);
|
||
$nbMoisBilCumul += $this->nmp3;
|
||
}
|
||
}
|
||
|
||
if (isset($tabBilan[4])) {
|
||
$this->BILANDATEp4 = $tabBilan[4]['DATE_CLOTURE'];
|
||
$this->BILANANNEEp4 = substr($this->BILANDATEp4,0,4)*1;
|
||
$this->nmp4=$tabBilan[4]['DUREE_MOIS'];
|
||
if ($this->BILANANNEEp4 > 0) {
|
||
$this->BILANp4 = 1;
|
||
$nbMoisBilDate = $classWdate->nbMoisEntre($this->BILANDATEp4, $this->BILANDATE);
|
||
//$nbMoisBilCumul+=$this->nmp4;
|
||
}
|
||
}
|
||
|
||
// Liste des années de bilans ultérieurs
|
||
$this->BILANANNEE1 = $this->BILANANNEE + 1;
|
||
$this->BILANANNEE2 = $this->BILANANNEE + 2;
|
||
$this->BILANANNEE3 = $this->BILANANNEE + 3;
|
||
$this->BILANANNEE4 = $this->BILANANNEE + 4;
|
||
$this->BILANANNEE5 = $this->BILANANNEE + 5;
|
||
|
||
// --- Calcul des ratios
|
||
$mRatios = new Metier_Scores_MRatios();
|
||
$mRatios->setTrancheEffectif($efftr);
|
||
$tabRatios = $mRatios->calcul($tabBilan);
|
||
}
|
||
$timer['ratios']=microtime(true);
|
||
|
||
// Tableau des années de bilans
|
||
$tabAnnees = array();
|
||
// Tableau d'infos sur les bilans
|
||
$i2=0;
|
||
if (count($tabRatios)>0) {
|
||
foreach ($tabRatios as $i => $Ritem) {
|
||
|
||
if (substr($tabBilan[$i]['DATE_CLOTURE'],0,4) > 1900){
|
||
$tabAnnees[$i] = substr($tabBilan[$i]['DATE_CLOTURE'], 0, 4);
|
||
}
|
||
|
||
// Utilisation d'un index texte à cause du webservice
|
||
foreach ($Ritem as $Ridx => $Rmont) {
|
||
if ( ($tabBilan[$i]['CONSOLIDE']=='S' && isset($tabRatios[$i+1]) && ($tabBilan[$i+1]['CONSOLIDE']=='S'
|
||
|| ($tabBilan[$i+1]['CONSOLIDE']=='N' && $tabBilan[$i+1]['DATE_CLOTURE']!=$tabBilan[$i]['DATE_CLOTURE'])))
|
||
|| ($tabBilan[$i]['CONSOLIDE']=='N' && isset($tabRatios[$i+1]) && ($tabBilan[$i+1]['CONSOLIDE']=='N'
|
||
|| ($tabBilan[$i+1]['CONSOLIDE']=='S' && $tabBilan[$i+1]['DATE_CLOTURE']!=$tabBilan[$i]['DATE_CLOTURE']))) ) {
|
||
|
||
$Rmont = (($tabRatios[$i][$Ridx]-$tabRatios[$i+1][$Ridx])*100)/abs($tabRatios[$i+1][$Ridx]);
|
||
$Rdiffmont = $tabRatios[$i][$Ridx]-$tabRatios[$i+1][$Ridx];
|
||
|
||
} elseif ( ($tabBilan[$i]['CONSOLIDE']=='S'&&isset($tabRatios[$i+1])&&($tabBilan[$i+2]['CONSOLIDE']=='S'
|
||
|| ($tabBilan[$i+2]['CONSOLIDE']=='N'&&$tabBilan[$i+2]['DATE_CLOTURE']!=$tabBilan[$i]['DATE_CLOTURE'])))
|
||
|| ($tabBilan[$i]['CONSOLIDE']=='N'&&isset($tabRatios[$i+1])&&($tabBilan[$i+2]['CONSOLIDE']=='N'
|
||
|| ($tabBilan[$i+2]['CONSOLIDE']=='S'&&$tabBilan[$i+2]['DATE_CLOTURE']!=$tabBilan[$i]['DATE_CLOTURE']))) ) {
|
||
|
||
$Rmont = (($tabRatios[$i][$Ridx]-$tabRatios[$i+2][$Ridx])*100)/abs($tabRatios[$i+2][$Ridx]);
|
||
$Rdiffmont = $tabRatios[$i][$Ridx]-$tabRatios[$i+1][$Ridx];
|
||
|
||
} else {
|
||
$Rmont = 'NS';
|
||
$Rdiffmont = 'NS';
|
||
}
|
||
$tabRatiosEvol[$i2][$Ridx] = $Rmont;
|
||
$tabRatiosDiff[$i2][$Ridx] = $Rdiffmont;
|
||
}
|
||
$tabRatiosNew[$i2] = $tabRatios[$i];
|
||
if ($tabBilan[$i]['CONSOLIDE']!='C') $i2++;
|
||
}
|
||
|
||
$this->R = $tabRatiosNew[0];
|
||
$this->Rp = $tabRatiosNew[1]; // Ratios précédents N-1
|
||
$this->Rp2 = $tabRatiosNew[2]; // Ratios précédents N-2
|
||
$this->Rp3 = $tabRatiosNew[3]; // Ratios précédents N-3
|
||
$this->Rp4 = $tabRatiosNew[4]; // Ratios précédents N-4
|
||
|
||
$this->Rdiff = $tabRatiosDiff[0];
|
||
|
||
$this->Revol = $tabRatiosEvol[0];
|
||
$this->Revolp = $tabRatiosEvol[1];
|
||
$this->Revolp2 = $tabRatiosEvol[2];
|
||
$this->Revolp3 = $tabRatiosEvol[3];
|
||
|
||
}
|
||
$timer['anbilans']=microtime(true);
|
||
|
||
// Régression : Ratios
|
||
$iMax = count($this->tabRegX);
|
||
foreach ($tabFormules as $i2 => $Rtmp) {
|
||
for ( $i = 0 ; $i <= $iMax ; $i++ ) {
|
||
if ( isset($tabRatios[$i][$Rtmp['id']]) ) {
|
||
$this->regR[$Rtmp['id']][]=$tabRatios[$i][$Rtmp['id']];
|
||
} else {
|
||
if ( array_key_exists($i, $this->tabRegX) ) {
|
||
//unset($tabRegX[$i]);
|
||
}
|
||
}
|
||
if (isset($tabRatiosSecteurs[$i][$Rtmp['id']])) {
|
||
$this->regRs[$Rtmp['id']][]=$tabRatiosSecteurs[$i][$Rtmp['id']];
|
||
}
|
||
}
|
||
if ( is_array($this->regR) && array_key_exists($Rtmp['id'], $this->regR) ) {
|
||
$this->regR[$Rtmp['id']] = array_reverse($this->regR[$Rtmp['id']]);
|
||
}
|
||
|
||
if ( is_array($this->regRs) && array_key_exists($Rtmp['id'], $this->regRs) ) {
|
||
$this->regRs[$Rtmp['id']] = array_reverse($this->regRs[$Rtmp['id']]);
|
||
}
|
||
}
|
||
// On renverse les tableaux 2008, 2007, 2006... en 2006, 2007, 2008
|
||
$this->tabRegX = array_reverse($this->tabRegX);
|
||
|
||
$this->EFFECTIF=$this->R[24];
|
||
if ($this->EFFECTIF*1==0 && $efftr>0) $this->EFFECTIF=$efftr;
|
||
|
||
$this->CABILAN=$this->R[6];
|
||
|
||
// Ratios Secteur en fonction des dernières années de bilans
|
||
$this->MARCHE=$this->MARCHEp=$this->MARCHEVOL=$this->MARCHEPART=$this->MARCHEPARTp=$this->MARCHEPARTEVOL='';
|
||
$this->MARCHESAL=$this->MARCHESALp=$this->MARCHENBENT=$this->MARCHENBENTp='';
|
||
$tabRatiosSecteurs=$Rtot=array();
|
||
if (count($tabAnnees) > 0) {
|
||
if (strlen($naf)>4) $strNaf=" AND naf5='$naf' ";
|
||
else $strNaf=" AND naf4='$naf' ";
|
||
if (count($tabAnnees)>2) $strAnnees='AND annee BETWEEN '.$tabAnnees[2].' AND '.$tabAnnees[0];
|
||
elseif (count($tabAnnees)>1) $strAnnees='AND annee BETWEEN '.$tabAnnees[1].' AND '.$tabAnnees[0];
|
||
else $strAnnees='AND annee='.$tabAnnees[0];
|
||
|
||
$tabTmp = $this->db->select('jo.ratios_secteurs',
|
||
'annee, naf5, naf4, id, (montant/nombre) AS ratio, montant, nombre',
|
||
"1 $strNaf $strAnnees ORDER BY annee DESC, id ASC",
|
||
$this->debug, MYSQL_ASSOC);
|
||
|
||
$anneePre = $tabTmp[0]['annee'];
|
||
$iAn=0;
|
||
foreach ($tabTmp as $tabTmp2) {
|
||
if ($anneePre<>$tabTmp2['annee']){ $iAn++; }
|
||
$Ridx=$tabTmp2['id'];
|
||
if ($tabRatiosInfos[$Ridx]['unite']=='EUR'){
|
||
$montant=round($tabTmp2['ratio']*1000);
|
||
} else {
|
||
$montant=round($tabTmp2['ratio']);
|
||
}
|
||
// Gestion des bornes
|
||
if ($tabBorneMin[$Ridx]<>'' && $montant<$tabBorneMin[$Ridx]){
|
||
$montant='<'.$tabBorneMin[$Ridx];
|
||
} elseif ($tabBorneMax[$Ridx]<>'' && $montant>$tabBorneMax[$Ridx]){
|
||
$montant='>'.$tabBorneMax[$Ridx];
|
||
}
|
||
|
||
if (substr($montant,0,1)=='N' || substr($montant,0,1)=='<' || substr($montant,0,1)=='>'){
|
||
$tabRatiosSecteurs[$iAn][$Ridx]=$montant;
|
||
} else {
|
||
$tabRatiosSecteurs[$iAn][$Ridx]=round($montant,2);
|
||
}
|
||
|
||
$anneePre=$tabTmp2['annee'];
|
||
|
||
// Calcul des infos MARCHES
|
||
if (date('m')*1>6) // On est courant 2ème semestre
|
||
$anneeBaseMarche=-1;
|
||
else
|
||
$anneeBaseMarche=-2;
|
||
|
||
for ($iMarche=0; $iMarche<3; $iMarche++) {
|
||
$tmpCalc=($this->ANNEE-$iMarche+$anneeBaseMarche)*1;
|
||
if ($tmpCalc==$tabTmp2['annee']*1) {
|
||
switch ($Ridx*1) {
|
||
//$nb=$tabTmp2['nombre'];
|
||
//case 1: // CA France en M?
|
||
//case 3: // CA Export en M?
|
||
case 5: // CA Total en M?
|
||
$Rtot[$iMarche][0]=$tabTmp2['nombre']; // On ne calcul le nombre d'acteurs pour cette information qu'avec le CA total, information la + renseignée
|
||
case 7: // Résultat Net
|
||
$Rtot[$iMarche][$Ridx]=round($tabTmp2['montant']*1000); // En euro
|
||
break;
|
||
case 24:// Effectif
|
||
$Rtot[$iMarche][$Ridx]=round($tabTmp2['montant']);
|
||
break;
|
||
}
|
||
}
|
||
}
|
||
}
|
||
|
||
$this->MARCHE=$Rtot[0][5]; // Taille du marché en ME
|
||
$this->MARCHEp=$Rtot[1][5]; // Taille du marché précédent en ME
|
||
$this->MARCHEVOL=(($this->MARCHE-$this->MARCHEp)*100)/$this->MARCHEp; // % évolution du marche N/N-1
|
||
$this->MARCHEPART=$this->R[5]*100/$this->MARCHE; // Part de marche en %
|
||
$this->MARCHEPARTp=$this->Rp[5]*100/$this->MARCHEp; // Part de marche précédent en %
|
||
$this->MARCHEPARTEVOL=(($this->MARCHEPART-$this->MARCHEPARTp)*100)/$this->MARCHEPARTp; // % évolution de la part de marché N / N-1
|
||
$this->MARCHESAL=$Rtot[0][24]; // Nb salariés du marché
|
||
$this->MARCHESALp=$Rtot[1][24]; // Nb salariés du marché N-1
|
||
$this->MARCHENBENT=$Rtot[0][0]; // Nombre d'entités
|
||
$this->MARCHENBENTp=$Rtot[1][0]; // Nombre d'entités N-1
|
||
|
||
$this->Rs=$tabRatiosSecteurs[0];
|
||
$this->Rsp=$tabRatiosSecteurs[1];
|
||
$this->Rsp2=$tabRatiosSecteurs[2]; // Ratios secteurs précédents N-2
|
||
$this->Rsp3=$tabRatiosSecteurs[3]; // Ratios secteurs précédents N-3
|
||
$this->Rsp4=$tabRatiosSecteurs[4]; // Ratios secteurs précédents N-4
|
||
$timer['ratiosecteur']=microtime(true);
|
||
}
|
||
|
||
$timer['regression']=microtime(true);
|
||
|
||
// --- Détection fine de l'état de fermeture éventuel à l'INSEE
|
||
$where = "insSIREN=$siren AND insEVE IN ('400','410','420','425','MPF','MNP') ORDER BY insDATEVE DESC";
|
||
if ($this->companyEvenDateStop !== null) {
|
||
$where = "insSIREN=$siren AND insEVE IN ('400','410','420','425','MPF','MNP') AND idFlux < '".
|
||
$this->companyEvenDateStop."' ORDER BY insDATEVE DESC";
|
||
}
|
||
$tabTmp = $this->db->select('insee.insee_even', 'insEVE, insDATEVE', $where, $this->debug, MYSQL_ASSOC);
|
||
if (count($tabTmp)>0) {
|
||
$tabModif = $tabTmp[0];
|
||
$this->ETATINSEE_MMAA = substr($tabModif['insDATEVE'],0,7);
|
||
switch(''.$tabModif['insEVE']) {
|
||
// Suppression d'un double
|
||
case '400':
|
||
$this->ACTIFINSEE = false;
|
||
$this->ETATINSEE = 'SUPD';
|
||
break;
|
||
// Cessation juridique de l'entreprise
|
||
case '410':
|
||
if (!$this->ACTIFINSEE) {
|
||
$this->ETATINSEE='JURF';
|
||
}
|
||
break;
|
||
// Absence d'activité de l'entreprise (cessation économique de l.entreprise)
|
||
case '420':
|
||
// Absence d'activité d'une entreprise suite à une mise à jour au répertoire
|
||
case '425':
|
||
if (!$this->ACTIFINSEE) {
|
||
$this->ETATINSEE='ECOF';
|
||
}
|
||
break;
|
||
// Présumé Fermé
|
||
case 'MPF':
|
||
$this->ETATINSEE = 'PFER';
|
||
break;
|
||
// NPAI
|
||
case 'MNP':
|
||
$this->ETATINSEE = 'NPAI';
|
||
break;
|
||
}
|
||
}
|
||
|
||
/** Eléments provenant des évènements INSEE **/
|
||
$tabTmp = $this->db->select('insee.insee_even', 'COUNT(*) AS nb, MAX(insDATEVE) AS dateMaj',
|
||
"insSIREN=$siren", $this->debug, MYSQL_ASSOC);
|
||
$tabModif=$tabTmp[0];
|
||
$this->MODIFINSEE=$tabModif['nb'];
|
||
$this->MODIFINSEEDATE=$tabModif['dateMaj'];
|
||
if ($tabIdentite['DateMajINSEE']>=$this->MODIFINSEEDATE)
|
||
$this->MODIFINSEEDATE=$tabIdentite['DateMajINSEE'];
|
||
|
||
/** Eléments provenant des évènements RNCS **/
|
||
$tabTmp=$this->db->select('jo.rncs_modifs', 'COUNT(*) AS nb, MAX(flux) AS dateMaj',
|
||
"siren=$siren", $this->debug, MYSQL_ASSOC);
|
||
$tabModif=$tabTmp[0];
|
||
$this->MODIFRNCS=$tabModif['nb'];
|
||
$this->MODIFRNCSDATE=$tabModif['dateMaj'];
|
||
if ($tabIdentite['DateMajRCS']>=$this->MODIFRNCSDATE)
|
||
$this->MODIFRNCSDATE=$tabIdentite['DateMajRCS'];
|
||
|
||
/** $ANNONCEBOD **/
|
||
$this->ANNONCEBOD=$this->ANNONCEBODA=$this->ANNONCEBODB=$this->ANNONCEBODC=0;
|
||
$this->ANNONCECAC=$this->ANNONCECAP=$this->ANNONCECAPAUG=$this->ANNONCECAPAUGDIM=$this->ANNONCECAPDIM=$this->ANNONCECAPDIMAUG=$this->ANNONCECAPSIG=0;
|
||
$this->ANNONCECAC2=$this->ANNONCECAC3=0;
|
||
$this->ANNONCEADR=$this->ANNONCEDIR=$this->ANNONCEFJUR=0;
|
||
$this->ANNONCEADRDATE=$this->ANNONCECACDATE=$this->ANNONCEPCDATE=$this->ANNONCEPC_CESDATE=$this->ANNONCEPLANFINDATE='';
|
||
$this->ANNONCEPC_INT1=$this->ANNONCEPC_INT1_TIT=$this->ANNONCEPC_INT2=$this->ANNONCEPC_INT2_TIT='';
|
||
$this->ANNONCELJ=$this->ANNONCERJ=$this->ANNONCESV=$this->ANNONCEPUB=0;
|
||
|
||
$this->ANNONCEFUS=0;
|
||
$this->FUSIONPROJET=''; // Présence d'un projet de fusion, libellé du projet
|
||
$this->FUSIONPROJET_SIREN=''; // Siren concerné par le projet de fusion
|
||
$this->FUSIONPROJET_DATE=''; // Date du projet de fusion
|
||
$this->NOMFUSION='';
|
||
$this->CAPITAL_PRE=''; // Montant du capital Précédent
|
||
|
||
$this->ANNONCEHOM=0; // Nombre d'annonces d'homologation
|
||
$this->ANNONCEHOMDATE=''; // Date de la dernière parution d'annonces d'homologation
|
||
|
||
$this->ANNONCEPLAN=$this->ANNONCEPLANMODIFDATE=$this->ANNONCEPLANDATE=$this->PLAN=$this->PLANMODIF=$this->ANNONCEPC='';
|
||
$this->ANNONCEPC_OBS=false;
|
||
|
||
$this->ANNONCEOBJET='';
|
||
|
||
/** @todo : Prendre la date de changement d'état du dirigeant **/
|
||
$this->ANNONCEINTERDITDATE='';
|
||
|
||
$timer['even']=microtime(true);
|
||
|
||
/** Tableau des taux d'inflation et inflations moyennes **/
|
||
$tabInfla = include __DIR__ . '/Data/Infla.php';
|
||
if (is_array($tabInfla) && count($tabInfla) > 0) {
|
||
krsort($tabInfla);
|
||
$i = 0;
|
||
foreach ($tabInfla as $itemAnnee => $itemInfla) {
|
||
if ($i > 10) break;
|
||
if ($itemAnnee > $this->BILANANNEE) continue;
|
||
$this->INFLA[$itemAnnee] = $itemInfla;
|
||
if ($i==0) { $this->INFLATION = $itemInfla; }
|
||
elseif ($i==1) { $this->INFLA1 = $itemInfla; $this->INFLAMOY1 = ($this->INFLA1 + $this->INFLATION) / 2; }
|
||
elseif ($i==2) { $this->INFLA2 = $itemInfla; $this->INFLAMOY2 = ($this->INFLA2 + $this->INFLA1 + $this->INFLATION) / 3; }
|
||
elseif ($i==3) { $this->INFLAMOY3 = ($itemInfla + $this->INFLA2 + $this->INFLA1 + $this->INFLATION) / 4; }
|
||
$i++;
|
||
}
|
||
}
|
||
|
||
/** Divers éléments calculés **/
|
||
$iInsee->AnnoncesLegalesVisu = true;
|
||
$companyAnnonces = $iInsee->getAnnoncesLegales($siren);
|
||
$iInsee->AnnoncesLegalesVisu = false;
|
||
|
||
// Annonces de dépôt des comptes
|
||
$tabDepotCpt = $iInsee->annoncesFilter($companyAnnonces, 'C');
|
||
$nbDepotCpt = count($tabDepotCpt);
|
||
$nbMoisMax=0;
|
||
$this->ANNONCEBODCMANQDATE = false;
|
||
$this->ANNONCEBODCREGUL = true;
|
||
$this->BILANDERANNEE = 0;
|
||
$tabAnnBodc=array();
|
||
if($nbDepotCpt>0) {
|
||
foreach ($tabDepotCpt as $iDep=>$depot) {
|
||
if ($iDep==0) {
|
||
// On prend la dernière Annonce de dépot de comptes
|
||
$this->ANNONCEPUB=true;
|
||
|
||
$tabTmp=array();
|
||
foreach ($depot['evenements'] as $even) {
|
||
$tabTmp[]=$even['LibEven'];
|
||
}
|
||
// Libellé code Even de la plus récente annonce publiée peu importe la source
|
||
$this->ANNONCEDER=implode(', ', $tabTmp);
|
||
$this->ANNONCEDERDATE=$depot['DateParution'];
|
||
switch(substr($depot['BodaccCode'],0,1)) {
|
||
case 'B': $this->ANNONCEDERSOURCE='BODACC'; break;// INPI, Publication Régionale
|
||
case 'P': $this->ANNONCEDERSOURCE='RNCS'; break;
|
||
case 'G': $this->ANNONCEDERSOURCE='GREFFE DU TRIBUNAL'; break;
|
||
default: $this->ANNONCEDERSOURCE='JOURNAL REGIONAL'; break;
|
||
}
|
||
$this->ANNONCEDERTEXTE=$depot['texteAnnonce'];// INPI, Publication Régionale
|
||
|
||
// Date de l'annonce
|
||
$this->ANNONCEDATE=$depot['DateParution'];
|
||
$this->ANNONCEBODCDATE=$depot['DateParution'];
|
||
$this->BILANDERANNEE=date('Y', mktime(0, 0, 0, $classWdate->dateT('Y-m-d', 'm', $depot['dateEffet']), $classWdate->dateT('Y-m-d', 'd', $depot['dateEffet']), $classWdate->dateT('Y-m-d', 'Y', $depot['dateEffet'])+1));
|
||
$this->ANNONCEBODDATE=$depot['DateParution'];//dateEffet
|
||
if ($nbDepotCpt==1 && // 1 seul dépôt des comptes
|
||
abs($classWdate->nbMoisEntre(date('Y-m-d'), $dateCrea))<60) {// Entreprise de moins de 5 ans (60 mois)
|
||
$nbMoisMax=abs($classWdate->nbMoisEntre($dateCrea,$depot['dateEffet']));
|
||
}
|
||
} else {
|
||
if (abs($classWdate->nbMoisEntre($lastDepot, $depot['dateEffet']))>$nbMoisMax) {
|
||
$nbMoisMax=abs($classWdate->nbMoisEntre($lastDepot, $depot['dateEffet']));
|
||
if ($nbMoisMax>24 && $this->ANNONCEBODCMANQDATE==false) {
|
||
/** @todo Annomalie Bilans 1 mois sur 976320309
|
||
** $ANNONCEBODCREGUL 0 Pas de publication régulière des comptes
|
||
* 1 Régulier et 12 mois identiques
|
||
* 2 Régulier mais Présence de changements de date d'exercice
|
||
** $ANNONCEBODCMANQDATE Date de la dernière cloture manquante
|
||
** $ANNONCEBODCMANQ_AA Année de la dernière cloture manquante
|
||
** $NBBILANMANQUE Nombre d'années de bilans manquant
|
||
** $nmp=$tabBilan[0]['DUREE_MOIS_PRE'];
|
||
$nmp2=$tabBilan[2]['DUREE_MOIS'];
|
||
$nmp3=$tabBilan[3]['DUREE_MOIS'];
|
||
$nmp4
|
||
**/
|
||
$this->ANNONCEBODCMANQDATE=date('Y-m-d', mktime(0, 0, 0, $classWdate->dateT('Y-m-d', 'm', $depot['dateEffet']), $classWdate->dateT('Y-m-d', 'd', $depot['dateEffet']), $classWdate->dateT('Y-m-d', 'Y', $depot['dateEffet'])+1));
|
||
$this->ANNONCEBODCMANQ_AA=substr($this->ANNONCEBODCMANQDATE,0,4);
|
||
}
|
||
}
|
||
}
|
||
$lastDepot=$depot['dateEffet'];
|
||
$this->ANNONCEBOD++;
|
||
$this->ANNONCEBODC++;
|
||
}
|
||
}
|
||
|
||
// Publications régulieres et 12 mois identiques
|
||
if ( ($nbMoisBilDate+1) == $nbMoisBilCumul || $nbMoisBilDate == $nbMoisBilCumul || ($nbMoisBilDate-1)==$nbMoisBilCumul ) {
|
||
$this->ANNONCEBODCREGUL=1;
|
||
// Annonces BODACC de changement de date d'exercice
|
||
$tabDepotCpt = $iInsee->annoncesFilter($companyAnnonces, array(2303));
|
||
if (count($tabDepotCpt)>0) $this->ANNONCEBODCREGUL=2;
|
||
}
|
||
// Pas de publication régulière des comptes
|
||
else {
|
||
$this->ANNONCEBODCREGUL=0;
|
||
}
|
||
|
||
// Pas de Dernière année de bilan et on est en juillet passé
|
||
if ($this->BILANDERANNEE==0 && date('m')*1>6) {
|
||
$this->BILANDERANNEE=date('Y', mktime(0, 0, 0, date('m'), date('d'), date('Y')-1));
|
||
}
|
||
// Pas de Dernière année de bilan et on est au premier semestre
|
||
elseif ($this->BILANDERANNEE==0 && date('m')*1<=6) {
|
||
$this->BILANDERANNEE=date('Y', mktime(0, 0, 0, date('m'), date('d'), date('Y')-2));
|
||
}
|
||
|
||
// Annonces BODACC A
|
||
$tabDepotCpt = $iInsee->annoncesFilter($companyAnnonces, 'BODA');
|
||
$nbDepotA=count($tabDepotCpt);
|
||
if ($nbDepotA>0) {
|
||
foreach ($tabDepotCpt as $iDep=>$depot) {
|
||
if ($iDep==0) {
|
||
$this->ANNONCEBODADATE=$depot['DateParution'];
|
||
if ($classWdate->dateT('Y-m-d', 'Ymd',$this->ANNONCEBODADATE)>$classWdate->dateT('Y-m-d', 'Ymd',$this->ANNONCEBODDATE)) {
|
||
$this->ANNONCEBODDATE=$depot['DateParution'];
|
||
$tabTmp=array();
|
||
foreach ($depot['evenements'] as $even) {
|
||
$tabTmp[]=$even['LibEven'];
|
||
}
|
||
// Libellé code Even de la plus récente annonce publiée peu importe la source
|
||
$this->ANNONCEDER=implode(', ', $tabTmp);
|
||
$this->ANNONCEDERDATE=$depot['DateParution'];
|
||
switch(substr($depot['BodaccCode'],0,1)) {
|
||
case 'B': $this->ANNONCEDERSOURCE='BODACC'; break;// INPI, Publication Régionale
|
||
case 'P': $this->ANNONCEDERSOURCE='RNCS'; break;
|
||
case 'G': $this->ANNONCEDERSOURCE='GREFFE DU TRIBUNAL'; break;
|
||
default: $this->ANNONCEDERSOURCE='JOURNAL REGIONAL'; break;
|
||
}
|
||
$this->ANNONCEDERTEXTE=$depot['texteAnnonce'];// INPI, Publication Régionale
|
||
}
|
||
}
|
||
// La première annonce de Bodacc A étant cencée être celle de création
|
||
elseif ( ($iDep+1)==$nbDepotA ) {
|
||
$this->TRIBUNAL_CREATION=strtr($depot['Tribunal'],array('TC '=>'Tribunal de Commerce de '));
|
||
}
|
||
$this->ANNONCEBOD++;
|
||
$this->ANNONCEBODA++;
|
||
}
|
||
}
|
||
|
||
// Annonces BODACC B
|
||
$tabDepotCpt = $iInsee->annoncesFilter($companyAnnonces, 'BODB');
|
||
if (is_array($tabDepotCpt) && count($tabDepotCpt)>0){
|
||
foreach ($tabDepotCpt as $iDep=>$depot) {
|
||
if ($iDep==0) {
|
||
$this->ANNONCEBODBDATE=$depot['DateParution'];
|
||
if ($classWdate->dateT('Y-m-d', 'Ymd',$this->ANNONCEBODBDATE)>$classWdate->dateT('Y-m-d', 'Ymd',$this->ANNONCEBODDATE)) {
|
||
$this->ANNONCEBODDATE=$depot['DateParution'];
|
||
$tabTmp=array();
|
||
foreach ($depot['evenements'] as $even) {
|
||
$tabTmp[]=$even['LibEven'];
|
||
}
|
||
// Libellé code Even de la plus récente annonce publiée peu importe la source
|
||
$this->ANNONCEDER=implode(', ', $tabTmp);
|
||
$this->ANNONCEDERDATE=$depot['DateParution'];
|
||
switch(substr($depot['BodaccCode'],0,1)) {
|
||
case 'B': $this->ANNONCEDERSOURCE='BODACC'; break;// INPI, Publication Régionale
|
||
case 'P': $this->ANNONCEDERSOURCE='RNCS'; break;
|
||
case 'G': $this->ANNONCEDERSOURCE='GREFFE DU TRIBUNAL'; break;
|
||
default: $this->ANNONCEDERSOURCE='JOURNAL REGIONAL'; break;
|
||
}
|
||
$this->ANNONCEDERTEXTE=$depot['texteAnnonce'];// INPI, Publication Régionale
|
||
}
|
||
}
|
||
$this->ANNONCEBOD++;
|
||
$this->ANNONCEBODB++;
|
||
}
|
||
}
|
||
|
||
// Annonces BODACC Changement d'adresse
|
||
$tabDepotCpt = $iInsee->annoncesFilter($companyAnnonces, array(2300,2301,2901,2902,2903,2904));
|
||
if (is_array($tabDepotCpt) && count($tabDepotCpt)>0){
|
||
foreach ($tabDepotCpt as $iDep=>$depot) {
|
||
if ($iDep == 0) {
|
||
$this->ANNONCEADRDATE = $depot['DateParution'];
|
||
}
|
||
$this->ANNONCEADR++;
|
||
}
|
||
}
|
||
|
||
// Annonces BODACC Changement de dirigeant
|
||
$tabDepotCpt = $iInsee->annoncesFilter($companyAnnonces, array(2315));
|
||
if (is_array($tabDepotCpt) && count($tabDepotCpt)>0){
|
||
foreach ($tabDepotCpt as $iDep=>$depot) {
|
||
if ($iDep==0) {
|
||
$this->ANNONCEDIRDATE = $depot['DateParution'];
|
||
}
|
||
$this->ANNONCEDIR++;
|
||
if (preg_match('/Commissaire/iu', $depot['texteAnnonce'])) {
|
||
$this->ANNONCECAC++;
|
||
if ($this->ANNONCECAC == 1) {
|
||
$this->ANNONCECACDATE=$depot['DateParution'];
|
||
}
|
||
}
|
||
}
|
||
}
|
||
|
||
// Annonces BODACC Changement de FJur
|
||
$tabDepotCpt = $iInsee->annoncesFilter($companyAnnonces, array(2307));
|
||
if (is_array($tabDepotCpt) && count($tabDepotCpt)>0){
|
||
foreach ($tabDepotCpt as $iDep=>$depot) {
|
||
if ($iDep==0) {
|
||
$this->ANNONCEFJURDATE = $depot['DateParution'];
|
||
}
|
||
$this->FJUR_PRE='';
|
||
$this->ANNONCEFJUR++;
|
||
}
|
||
}
|
||
|
||
// Annonces BODACC Fusion/Absorptions
|
||
/**
|
||
* 2700 Fusion/Absorption (entitée absorbante)
|
||
* 2701 Fusion/Absorption (Entitée absorbante. Entité absorbée inconnue)
|
||
* 2702 Fusion/Absorption (Entitée absorbante. Entité absorbée mal SIRENEE)
|
||
* 2703 Fusion/Absorption (Entitée absorbante. Entité absorbée non SIRENEE)
|
||
* 2720 Fusion/Absorption (entitée absorbée)
|
||
* 2721 Fusion/Absorption (entitée absorbée non identifiée)
|
||
* 2725 Fusion/Absorption
|
||
*/
|
||
$tabDepotCpt = $iInsee->annoncesFilter($companyAnnonces, array(2700,2701,2702,2703,2710,2720,2721,2725,2726,2730,2740));
|
||
if (is_array($tabDepotCpt) && count($tabDepotCpt)>0){
|
||
foreach ($tabDepotCpt as $iDep=>$depot) {
|
||
if ($iDep == 0) {
|
||
$this->ANNONCEFUSDATE = $depot['DateParution'];
|
||
}
|
||
$this->ANNONCEFUS++;
|
||
foreach ($depot['evenements'] as $even) {
|
||
switch ($even['CodeEven']*1) {
|
||
case 2710: // Projet de fusion (entitée absorbante)
|
||
case 2726: // Projet de Fusion/Absorption
|
||
case 2730: // Projet de fusion (entitée absorbée)
|
||
$this->FUSIONPROJET_DATE=$depot['dateJugement']; // Date du projet de fusion
|
||
$this->FUSIONPROJET=$depot['complement']; // Présence d'un projet de fusion, libellé du projet
|
||
$this->FUSIONPROJET_SIREN='';
|
||
if (preg_match_all("/((?:[0-9]{9,9})|(?:[0-9]{3,3} [0-9]{3,3} [0-9]{3,3})|(?:[0-9]{3,3}\.[0-9]{3,3}\.[0-9]{3,3})|(?:[0-9]{3,3}-[0-9]{3,3}-[0-9]{3,3}))/", $this->FUSIONPROJET, $matches)) {
|
||
foreach ($matches[1] as $this->FUSIONPROJET_SIREN) {
|
||
$this->FUSIONPROJET_SIREN=strtr($this->FUSIONPROJET_SIREN, array('.'=>'','-'=>'', ' '=>''));
|
||
if (!$iInsee->valideSiren($this->FUSIONPROJET_SIREN)) {
|
||
$this->FUSIONPROJET_SIREN=0;
|
||
} else {
|
||
break;
|
||
}
|
||
}
|
||
}
|
||
if ($this->FUSIONPROJET_SIREN*1<100) $this->FUSIONPROJET_SIREN='';
|
||
break;
|
||
}
|
||
}
|
||
}
|
||
}
|
||
|
||
// Annonces BODACC Changement de capital
|
||
$annCapPre=0;
|
||
$tabDepotCpt = $iInsee->annoncesFilter($companyAnnonces, array(2100,2101,2102));
|
||
$tabDepotCpt = array_reverse($tabDepotCpt);
|
||
$this->CAPITAL_PRE = 0;
|
||
if (is_array($tabDepotCpt) && count($tabDepotCpt)>0){
|
||
foreach ($tabDepotCpt as $iDep=>$depot) {
|
||
// Date de la plus récente Annonce changement de capital
|
||
$this->ANNONCECAPDATE=$depot['DateParution'];
|
||
if (count($tabDepotCpt)>1 && $iDep == count($tabDepotCpt)-2) {
|
||
if ($depot['capitalDev']=='FRF') {
|
||
$this->CAPITAL_PRE = round($depot['capital']/6.55957);
|
||
} else {
|
||
$this->CAPITAL_PRE = $depot['capital'];
|
||
}
|
||
}
|
||
// Boucle sur les evenements
|
||
foreach ($depot['evenements'] as $even) {
|
||
// Evenement 2101 : Modificaition de capital
|
||
if ($even['CodeEven'] == 2101) {
|
||
if ($iDep > 0 && $this->CAPITAL_PRE > 0) {
|
||
if ($depot['capitalDev']=='FRF') {
|
||
$annonceCapital = round($depot['capital']/6.55957);
|
||
} else {
|
||
$annonceCapital = $depot['capital'];
|
||
}
|
||
// Augmentation
|
||
if ($annonceCapital > $this->CAPITAL_PRE) {
|
||
$even['CodeEven'] = 2102;
|
||
}
|
||
// Diminution
|
||
elseif ($annonceCapital < $this->CAPITAL_PRE) {
|
||
$even['CodeEven'] = 2100;
|
||
}
|
||
}
|
||
}
|
||
switch ($even['CodeEven']*1) {
|
||
// Diminution de capital
|
||
case 2100:
|
||
$this->ANNONCECAPDIM++;
|
||
if ($this->ANNONCECAPDIM==1) {
|
||
// Année de la plus ancienne Annonce diminution de capital
|
||
$this->ANNONCECAPDIM_AAD = substr($depot['DateParution'],0,4);
|
||
} else {
|
||
// Date de la plus récente Annonce de diminution de capital
|
||
$this->ANNONCECAPDIMDATE=$depot['DateParution'];
|
||
// Année de la plus récente Annonce diminution de capital
|
||
$this->ANNONCECAPDIM_AAF=substr($depot['DateParution'],0,4);
|
||
}
|
||
// Augmentation suivie de diminution de capital
|
||
if ($annCapPre == 2102) {
|
||
$this->ANNONCECAPAUGDIM++;
|
||
}
|
||
$annCapPre=2100;
|
||
break;
|
||
// Augmentation de capital
|
||
case 2102:
|
||
$this->ANNONCECAPAUG++;
|
||
if ($this->ANNONCECAPAUG==1) {
|
||
// Année de la plus ancienne Annonce Augmentation de capital
|
||
$this->ANNONCECAPAUG_AAD = substr($depot['DateParution'],0,4);
|
||
} else {
|
||
// Date de la plus récente Annonce Augmentation de capital
|
||
$this->ANNONCECAPAUGDATE=$depot['DateParution'];
|
||
// Année de la plus récente Annonce Augmentation de capital
|
||
$this->ANNONCECAPAUG_AAF=substr($depot['DateParution'],0,4);
|
||
}
|
||
// Diminution suivie de Augmentation de capital
|
||
if ($annCapPre == 2100){
|
||
$this->ANNONCECAPDIMAUG++;
|
||
}
|
||
$annCapPre=2102;
|
||
break;
|
||
}
|
||
}
|
||
$this->ANNONCECAP++;
|
||
$this->ANNONCECAPSIG++;
|
||
}
|
||
}
|
||
|
||
// Annonces BODACC Cessation d'activité avec dissolution
|
||
$tabDepotCpt = $iInsee->annoncesFilter($companyAnnonces, array(2202,2203,2204,2210,2212));
|
||
if (is_array($tabDepotCpt) && count($tabDepotCpt)>0){
|
||
foreach ($tabDepotCpt as $iDep=>$depot) {
|
||
if ($this->BILANDATE<str_replace('-','',$depot['DateParution'])*1) {
|
||
$this->ANNONCEDISSODATE=$depot['DateParution'];
|
||
$this->ANNONCEDISSO=true;
|
||
}
|
||
break;
|
||
}
|
||
}
|
||
|
||
// Annonces BODACC Poursuite de l'activité malgré la perte de plus de la moitié du capital social
|
||
$tabDepotCpt = $iInsee->annoncesFilter($companyAnnonces, array(2314,2319));
|
||
if (is_array($tabDepotCpt) && count($tabDepotCpt)>0){
|
||
foreach ($tabDepotCpt as $iDep=>$depot) {
|
||
$this->ANNONCEPOURSDATE= $this->ANNONCEDISSONONDATE= $depot['DateParution'];
|
||
$this->ANNONCEPOURS= $this->ANNONCEDISSONON= true;
|
||
break;
|
||
}
|
||
}
|
||
|
||
// Annonces BODACC Reconsitution de l'actif net ou de la moitié
|
||
$tabDepotCpt = $iInsee->annoncesFilter($companyAnnonces, array(2320,2321));
|
||
if (is_array($tabDepotCpt) && count($tabDepotCpt)>0){
|
||
foreach ($tabDepotCpt as $iDep=>$depot) {
|
||
$this->ANNONCERECONDATE=$depot['DateParution'];
|
||
$this->ANNONCERECON=true;
|
||
break;
|
||
}
|
||
}
|
||
|
||
// Annonces BODACC Location gérance reçue
|
||
$tabDepotCpt = $iInsee->annoncesFilter($companyAnnonces, array(2800,2880,4355));
|
||
if (is_array($tabDepotCpt) && count($tabDepotCpt)>0){
|
||
foreach ($tabDepotCpt as $iDep=>$depot) {
|
||
$this->ANNONCELOCDATE=$depot['DateParution'];
|
||
$this->ANNONCELOC=true;
|
||
break;
|
||
}
|
||
}
|
||
|
||
// Annonces BODACC Mise en sommeil de la société
|
||
$tabDepotCpt = $iInsee->annoncesFilter($companyAnnonces, array(2206));
|
||
if (is_array($tabDepotCpt) && count($tabDepotCpt)>0){
|
||
foreach ($tabDepotCpt as $iDep=>$depot) {
|
||
$this->ANNONCESOMMDATE=$depot['DateParution'];
|
||
$this->ANNONCESOMM=true;
|
||
break;
|
||
}
|
||
}
|
||
$timer['bodacc']=microtime(true);
|
||
|
||
$this->ANNONCEOBJET=$tabIdentite['Activite'];
|
||
|
||
if ($tabIdentite['SituationJuridique']=='P') {
|
||
$this->ANNONCEPC='Procédure Collective';
|
||
$tabProCol = $iInsee->annoncesFilter($companyAnnonces, 'P');
|
||
foreach ($tabProCol as $iProcol=>$procol) {
|
||
foreach ($procol['evenements'] as $even) {
|
||
if ($iProcol==0) $this->ANNONCEPC=$even['LibEven'];
|
||
switch ($even['CodeEven']*1) {
|
||
case 1300: // Conversion Redressement Judiciaire en Liquidation Judiciaire
|
||
case 1301: // Ouverture Liquidation Judiciaire
|
||
case 1302: // Ouverture Liquidation Judiciaire Simplifiée
|
||
case 1305: // Liquidation Judiciaire
|
||
if (substr($procol['dateFinObservation'],0,4)*1>0) $this->ANNONCEPC_OBS=true;
|
||
case 1303: // Ouverture Liquidation Judiciaire sur résolution du plan
|
||
case 1304: // Réouverture Liquidation Judiciaire
|
||
case 1306: // Liquidation Judiciaire simplifiée
|
||
case 1307: // Conversion sauvegarde en Liquidation Judiciaire
|
||
case 1311: // Liquidation Judiciaire par extension au(x) gérant(s)
|
||
case 1312: // Liquidation Judiciaire avec continuation d'exploitation
|
||
case 1313: // Liquidation Judiciaire sans remise des accessoires
|
||
case 1417: // Jugement d'extension de liquidation judiciaire
|
||
// Annonce de liquidation judiciaire
|
||
$this->ANNONCELJ=true;
|
||
// Date de l'annonce LJ
|
||
$this->ANNONCELJDATE=$procol['dateJugement'];
|
||
$this->ANNONCEDATE=$this->ANNONCEPCDATE=$procol['dateJugement'];
|
||
$this->TRIBUNAL_PROCOL=strtr($procol['Tribunal'],array('TC '=>'Tribunal de Commerce de '));
|
||
break;
|
||
case 1200: // Redressement Judiciaire
|
||
if (substr($procol['dateFinObservation'],0,4)*1>0) $this->ANNONCEPC_OBS=true;
|
||
case 1201: // Conversion sauvegarde en Redressement Judiciaire
|
||
case 1211: // Redressement Judiciaire par extension au(x) gérant(s)
|
||
case 1212: // Réforme de Liquidation Judiciaire en Redressement Judiciaire
|
||
case 1418: // Jugement d'extension d'une procédure de redressement judiciaire
|
||
// Annonce de redressement judiciaire
|
||
$this->ANNONCERJ=true;
|
||
// Date de l'annonce RJ
|
||
$this->ANNONCERJDATE=$procol['dateJugement'];
|
||
$this->ANNONCEDATE=$this->ANNONCEPCDATE=$procol['dateJugement'];
|
||
$this->TRIBUNAL_PROCOL=strtr($procol['Tribunal'],array('TC '=>'Tribunal de Commerce de '));
|
||
break;
|
||
case 1100: // Ouverture sauvegarde
|
||
if (substr($procol['dateFinObservation'],0,4)*1>0) $this->ANNONCEPC_OBS=true;
|
||
case 1419: // Jugement d'extension d'une procédure de sauvegarde
|
||
// Annonce de sauvegarde
|
||
$this->ANNONCESV=true;
|
||
// Date de l'annonce Sauv
|
||
$this->ANNONCESVDATE=$procol['dateJugement'];
|
||
$this->ANNONCEDATE=$this->ANNONCEPCDATE=$procol['dateJugement'];
|
||
$this->TRIBUNAL_PROCOL=strtr($procol['Tribunal'],array('TC '=>'Tribunal de Commerce de '));
|
||
break;
|
||
case 1407: // Modification de plan
|
||
case 1408: // Modification du plan de cession
|
||
case 1409: // Modification du plan de continuation
|
||
case 1415: // Prolongement du plan cession
|
||
// Modif de plan d'apurement
|
||
$this->PLANMODIF=true;
|
||
$this->ANNONCEPLANMODIFDATE=$this->ANNONCEDATE=$procol['dateJugement'];
|
||
break;
|
||
|
||
case 1411: // Arrêt du plan de cession
|
||
case 1414: // Arrêt du plan de redressement
|
||
$this->ANNONCEPLANFINDATE=$procol['dateFinObservation'];
|
||
if (substr($this->ANNONCEPLANFINDATE,0,4)*1==0) $this->ANNONCEPLANFINDATE='';
|
||
/** @todo $ANNONCEPLANDUREE='';
|
||
**/
|
||
case 1412: // Arrêt du plan de cession partielle
|
||
case 1413: // Arrêt du plan de continuation
|
||
case 1101: // Jugement arrêtant plan de sauvegarde
|
||
$this->PLAN=true; // Présence d'une annonce de plan d'apurement
|
||
if ($even['CodeEven']*1==1411) $this->ANNONCEPLAN='cession';
|
||
elseif ($even['CodeEven']*1==1412) $this->ANNONCEPLAN='cession partielle';
|
||
elseif ($even['CodeEven']*1==1413) $this->ANNONCEPLAN='continuation';
|
||
elseif ($even['CodeEven']*1==1414) $this->ANNONCEPLAN='redressement';
|
||
elseif ($even['CodeEven']*1==1101) $this->ANNONCEPLAN='sauvegarde';
|
||
|
||
// Date de l'annonce de plan
|
||
$this->ANNONCEPLANDATE=$procol['dateJugement'];
|
||
$this->ANNONCEDATE=$this->ANNONCEPCDATE=$procol['dateJugement'];
|
||
break;
|
||
case 1600: // Interdictions et Faillites
|
||
case 1601:
|
||
case 1610:
|
||
case 1611:
|
||
$this->ANNONCEINTERDITDATE=$procol['dateJugement'];
|
||
break;
|
||
case 1202: // Renouvellement de la période d'observation
|
||
$this->ANNONCEPC_OBS=true;
|
||
//1430, Jugement autorisant la poursuite d'activité
|
||
break;
|
||
}
|
||
}
|
||
}
|
||
// Le SIREN est éliminé du scoring
|
||
$this->ELIMINE=true;
|
||
} elseif ($tabIdentite['SituationJuridique']=='PL') {
|
||
$this->ANNONCEPCHISTO=true;
|
||
$this->ELIMINE=false;
|
||
$this->ANNONCEPC='Plan de continuation/redressement';
|
||
$tabProCol = $iInsee->annoncesFilter($companyAnnonces, 'P');
|
||
foreach ($tabProCol as $iProcol=>$procol) {
|
||
foreach ($procol['evenements'] as $even) {
|
||
if ($iProcol==0) $this->ANNONCEPC=$even['LibEven'];
|
||
switch ($even['CodeEven']*1) {
|
||
case 1300: // Conversion Redressement Judiciaire en Liquidation Judiciaire
|
||
case 1301: // Ouverture Liquidation Judiciaire
|
||
case 1302: // Ouverture Liquidation Judiciaire Simplifiée
|
||
case 1305: // Liquidation Judiciaire
|
||
if (substr($procol['dateFinObservation'],0,4)*1>0) $this->ANNONCEPC_OBS=true;
|
||
case 1303: // Ouverture Liquidation Judiciaire sur résolution du plan
|
||
case 1304: // Réouverture Liquidation Judiciaire
|
||
case 1306: // Liquidation Judiciaire simplifiée
|
||
case 1307: // Conversion sauvegarde en Liquidation Judiciaire
|
||
case 1311: // Liquidation Judiciaire par extension au(x) gérant(s)
|
||
case 1312: // Liquidation Judiciaire avec continuation d'exploitation
|
||
case 1313: // Liquidation Judiciaire sans remise des accessoires
|
||
case 1417: // Jugement d'extension de liquidation judiciaire
|
||
|
||
// Annonce de liquidation judiciaire
|
||
$this->ANNONCELJ=true;
|
||
|
||
// Date de l'annonce LJ
|
||
$this->ANNONCELJDATE=$procol['dateJugement'];
|
||
$this->ANNONCEDATE=$this->ANNONCEPCDATE=$procol['dateJugement'];
|
||
$this->TRIBUNAL_PROCOL=strtr($procol['Tribunal'],array('TC '=>'Tribunal de Commerce de '));
|
||
break;
|
||
case 1200: // Redressement Judiciaire
|
||
if (substr($procol['dateFinObservation'],0,4)*1>0) $this->ANNONCEPC_OBS=true;
|
||
case 1201: // Conversion sauvegarde en Redressement Judiciaire
|
||
case 1211: // Redressement Judiciaire par extension au(x) gérant(s)
|
||
case 1212: // Réforme de Liquidation Judiciaire en Redressement Judiciaire
|
||
case 1418: // Jugement d'extension d'une procédure de redressement judiciaire
|
||
// Annonce de redressement judiciaire
|
||
$this->ANNONCERJ=true;
|
||
// Date de l'annonce RJ
|
||
$this->ANNONCERJDATE=$procol['dateJugement'];
|
||
$this->ANNONCEDATE=$this->ANNONCEPCDATE=$procol['dateJugement'];
|
||
$this->TRIBUNAL_PROCOL=strtr($procol['Tribunal'],array('TC '=>'Tribunal de Commerce de '));
|
||
break;
|
||
case 1100: // Ouverture sauvegarde
|
||
if (substr($procol['dateFinObservation'],0,4)*1>0) $this->ANNONCEPC_OBS=true;
|
||
case 1419: // Jugement d'extension d'une procédure de sauvegarde
|
||
// Annonce de sauvegarde
|
||
$this->ANNONCESV=true;
|
||
// Date de l'annonce Sauv
|
||
$this->ANNONCESVDATE=$procol['dateJugement'];
|
||
$this->ANNONCEDATE=$this->ANNONCEPCDATE=$procol['dateJugement'];
|
||
$this->TRIBUNAL_PROCOL=strtr($procol['Tribunal'],array('TC '=>'Tribunal de Commerce de '));
|
||
break;
|
||
case 1407: // Modification de plan
|
||
case 1408: // Modification du plan de cession
|
||
case 1409: // Modification du plan de continuation
|
||
case 1415: // Prolongement du plan cession
|
||
// Modif de plan d'apurement
|
||
$this->PLANMODIF=true;
|
||
$this->ANNONCEPLANMODIFDATE=$this->ANNONCEDATE=$procol['dateJugement'];
|
||
break;
|
||
case 1411: // Arrêt du plan de cession
|
||
case 1414: // Arrêt du plan de redressement
|
||
$this->ANNONCEPLANFINDATE=$procol['dateFinObservation'];
|
||
if (substr($this->ANNONCEPLANFINDATE,0,4)*1==0) $this->ANNONCEPLANFINDATE='';
|
||
case 1412: // Arrêt du plan de cession partielle
|
||
case 1413: // Arrêt du plan de continuation
|
||
case 1101: // Jugement arrêtant plan de sauvegarde
|
||
$this->PLAN=true; // Présence d'une annonce de plan d'apurement
|
||
if ($even['CodeEven']*1==1411) $this->ANNONCEPLAN='cession';
|
||
elseif ($even['CodeEven']*1==1412) $this->ANNONCEPLAN='cession partielle';
|
||
elseif ($even['CodeEven']*1==1413) $this->ANNONCEPLAN='continuation';
|
||
elseif ($even['CodeEven']*1==1414) $this->ANNONCEPLAN='redressement';
|
||
elseif ($even['CodeEven']*1==1101) $this->ANNONCEPLAN='sauvegarde';
|
||
// Date de l'annonce de plan
|
||
$this->ANNONCEPLANDATE=$procol['dateJugement'];
|
||
$this->ANNONCEDATE=$this->ANNONCEPCDATE=$procol['dateJugement'];
|
||
break;
|
||
case 1600: // Interdictions et Faillites
|
||
case 1601:
|
||
case 1610:
|
||
case 1611:
|
||
$this->ANNONCEINTERDITDATE=$procol['dateJugement'];
|
||
break;
|
||
case 1202: // Renouvellement de la période d'observation
|
||
$this->ANNONCEPC_OBS=true;
|
||
//1430, Jugement autorisant la poursuite d'activité
|
||
break;
|
||
}
|
||
}
|
||
}
|
||
} else {
|
||
$tabProCol = $iInsee->annoncesFilter($companyAnnonces, 'PH');
|
||
if (count($tabProCol)>0) $this->ANNONCEPCHISTO=true;
|
||
else $this->ANNONCEPCHISTO=false;
|
||
if ($tabIdentite['Actif']==0) $this->ELIMINE=true;
|
||
else $this->ELIMINE=false;
|
||
}
|
||
|
||
/** Annonces d'Homologation **/
|
||
$tabDepotCpt = $iInsee->annoncesFilter($companyAnnonces, array(1050,1550));
|
||
if (is_array($tabDepotCpt) && count($tabDepotCpt)>0){
|
||
foreach ($tabDepotCpt as $iDep=>$depot) {
|
||
if ($iDep==0)
|
||
$this->ANNONCEHOMDATE=$depot['DateParution'];
|
||
$this->ANNONCEHOM++;
|
||
}
|
||
}
|
||
|
||
/** Ventes Cessions en tant que vendeur **/
|
||
$tabProCol = $iInsee->annoncesFilter($companyAnnonces, 'V');
|
||
$this->ANNONCEVC=0; // Nombre d'annonce de VC (vendeur)
|
||
$this->ANNONCEVC_OBJ=$this->ANNONCEVCDATE=$this->ANNONCEVC_MT='';
|
||
|
||
foreach ($tabProCol as $iProcol=>$procol) {
|
||
$this->ANNONCEVC++;
|
||
if ($iProcol==0) {
|
||
foreach ($procol['evenements'] as $even) {
|
||
$this->ANNONCEVC_OBJ[]=$even['LibEven'];
|
||
}
|
||
$this->ANNONCEVC_OBJ=implode(', ', $this->ANNONCEVC_OBJ);
|
||
$this->ANNONCEVCDATE=$procol['dateJugement'];
|
||
$this->ANNONCEVC_MT=$procol['montantVente']; // Montant de la vente
|
||
}
|
||
}
|
||
|
||
if ($naf=='741J' || $naf=='6420Z' || // Activités des sociétés holding
|
||
$this->R[302]>0 || $this->R[303]>0 || $this->R[304]>0 // Holding déclaré au Bilan
|
||
) $this->HOLDING=true;
|
||
else $this->HOLDING=false;
|
||
// Présence d'au moins un bilan
|
||
if ($this->NBBILAN>0) $this->BILAN=true;
|
||
else $this->BILAN=false;
|
||
// Département du siège de l'entreprise
|
||
if ($depcomen==0) $depcomen=$tabIdentite['CP']*1;
|
||
|
||
if ($depcomen>99000) $this->DEPSIE=$depcomen;
|
||
elseif ($depcomen>96000) $this->DEPSIE=substr($depcomen,0,3);
|
||
elseif ($depcomen<10000) $this->DEPSIE=substr($depcomen,0,1);
|
||
else $this->DEPSIE=substr($depcomen,0,2);
|
||
$this->DEPSIE_DE = $iInsee->getDepartement($this->DEPSIE,true);
|
||
|
||
/**
|
||
* Solvabilité
|
||
*/
|
||
$isolv = new Metier_Scores_MSolvabilite(
|
||
$siren,
|
||
$naf,
|
||
$tabIdentite['EffEnTr'],
|
||
$tabIdentite['Effectif']*1,
|
||
$tabIdentite['CP'],
|
||
$fj,
|
||
$tabIdentite['Capital'],
|
||
$tabIdentite['CapitalDev'],
|
||
$tabIdentite['DateCreaEn'],
|
||
$tabIdentite['DateCreaEt'],
|
||
'',
|
||
$this->RECME,
|
||
$this->db
|
||
);
|
||
$noteStructure = $isolv->getSolvabilite();
|
||
$timer['solv'] = microtime(true);
|
||
|
||
$tabStructure['activite'] = $isolv->getPtActivite();
|
||
$tabStructure['naf4'] = $isolv->getNaf4($naf);
|
||
$tabStructure['age'] = $isolv->getPtAge(date('Y'));
|
||
$tabStructure['capital'] = $isolv->getPtCapital();
|
||
$tabStructure['effectif'] = $isolv->getPtEffectif();
|
||
$tabStructure['fj'] = $isolv->getPtFormeJuridique();
|
||
$tabStructure['localite'] = $isolv->getPtGeographie();
|
||
$tabStructure['singulier'] = $isolv->getPtSingularite();
|
||
|
||
// Le dépôt des comptes annuel est facultatif ?
|
||
if ($isolv->doitPublier($fj, $naf)) {
|
||
$this->FJURPUB=true;
|
||
$this->BILANFACULT=false;
|
||
} else {
|
||
$this->FJURPUB=false; // L'entreprise n'est pas soumise à publication de ses bilans
|
||
$this->BILANFACULT=true;
|
||
}
|
||
/** @todo : Attention, variable à charger uniquement si le dernier bilan est non diffusible **/
|
||
$this->BILANNONDIF=false;
|
||
|
||
/** Classements import Export **/
|
||
$tabImportExport=$iInsee->getImportExport($siren);
|
||
$this->EXPORTRANG=$this->IMPORTRANG=0;
|
||
foreach ($tabImportExport as $rangAnnee) {
|
||
if ($rangAnnee['importExport']=='I' && $this->IMPORTRANG==0) {
|
||
$this->IMPORTRANG=$rangAnnee['rangNational']*1;
|
||
//$IMPORTRANG_ARR;
|
||
switch (strlen($this->IMPORTRANG)) {
|
||
case 1: $this->IMPORTRANG_ARR=10; break;
|
||
case 2: $this->IMPORTRANG_ARR=100; break;
|
||
case 3: $this->IMPORTRANG_ARR='1 000'; break;
|
||
case 4: $this->IMPORTRANG_ARR='10 000'; break;
|
||
default: $this->IMPORTRANG_ARR='100 000'; break;
|
||
}
|
||
}
|
||
elseif ($rangAnnee['importExport']=='E' && $this->EXPORTRANG==0) {
|
||
$this->EXPORTRANG=$rangAnnee['rangNational']*1;
|
||
switch (strlen($this->EXPORTRANG)) {
|
||
case 1: $this->EXPORTRANG_ARR=10; break;
|
||
case 2: $this->EXPORTRANG_ARR=100; break;
|
||
case 3: $this->EXPORTRANG_ARR='1 000'; break;
|
||
case 4: $this->EXPORTRANG_ARR='10 000'; break;
|
||
default: $this->EXPORTRANG_ARR='100 000'; break;
|
||
}
|
||
}
|
||
}
|
||
$timer['importexport']=microtime(true);
|
||
|
||
/** Recherche d'une annonce de RJ sur Actionnaire / Participation **/
|
||
$this->RJMERE=$this->RJFILLE=false;
|
||
$this->SITUACT=$this->NICMERE=$this->SIRENMERE=$this->SIRETMERE=$this->NOMMERE='';
|
||
|
||
$lienM = new SdMetier_Liens_Base($siren, 'siren');
|
||
|
||
// Actionnaire
|
||
$tabA = $lienM->getActionnaires(null, true);
|
||
if (count($tabA)>0) {
|
||
foreach ($tabA as $i=>$lien)
|
||
{
|
||
$lienInsee = new Metier_Insee_MInsee($this->db);
|
||
if(intval($lien->siren)>100 && ( $lien->MajMin=='+' || $lien->PDetention>50))
|
||
{
|
||
$tabIdentiteA=$lienInsee->getIdentiteLight($lien->siren);
|
||
if ($this->NICMERE*1==0) {
|
||
$this->NICMERE=substr($tabIdentiteA['SiretSiege'],-5);
|
||
$this->SIRENMERE=$lien->Siren;
|
||
$this->SIRETMERE=$tabIdentiteA['SiretSiege'];
|
||
$this->NOMMERE=$tabIdentiteA['Nom'];
|
||
if ($tabIdentiteA['FJ']<2000)
|
||
$this->TYPEMERE='PP';
|
||
else
|
||
$this->TYPEMERE='PM';
|
||
}
|
||
$mBilA = new Metier_Partenaires_MBilans($lien->siren, $this->db);
|
||
$tabBilansA = $mBilA->listeBilans(false,2);
|
||
$nbBilansA = count($tabBilansA);
|
||
if ($nbBilansA > 0) {
|
||
$mRatiosA = new Metier_Scores_MRatios();
|
||
$mRatiosA->setTrancheEffectif($tabIdentiteA['EffEnTr']);
|
||
$tabRatiosA = $mRatiosA->calcul($tabBilansA);
|
||
$this->SITUACT=$tabRatiosA[0][19];
|
||
$this->Ra=$tabRatiosA[0];
|
||
$this->Rap=$tabRatiosA[1];
|
||
}
|
||
if ($lien->siren>100 && count($lienInsee->getAnnoncesLegales($lien->siren, 0, 'P', false))>0) {
|
||
$this->RJMERE=true;
|
||
}
|
||
break;
|
||
}
|
||
}
|
||
}
|
||
$timer['actionnaires']=microtime(true);
|
||
|
||
// Participation
|
||
$this->NBFILLE=0;
|
||
$this->NICFILLE=$this->SIRENFILLE=$this->SIRETFILLE=$this->NOMFILLE='';
|
||
$tabP=$lienM->getParticipations(null, true);
|
||
if (count($tabP)>0) {
|
||
foreach ($tabP as $i=>$lien) {
|
||
if ($lien->siren>100 && ( $lien->MajMin=='+' || $lien->PDetention>50)) {
|
||
$lienInsee = new Metier_Insee_MInsee($this->db);
|
||
$this->NBFILLE++; // Nombre de participations à plus de 50%
|
||
if ($this->NBFILLE==1) {
|
||
$tabIdentiteP=$lienInsee->getIdentiteLight($lien->siren);
|
||
$this->NICFILLE=substr($tabIdentiteP['SiretSiege'],-5);
|
||
$this->SIRENFILLE=$lien->Siren;
|
||
$this->SIRETFILLE=$tabIdentiteP['SiretSiege']; // N° SIRET de la sté 1ere fille à plus de 50%
|
||
$this->NOMFILLE=$tabIdentiteP['Nom'];
|
||
}
|
||
if (count($lienInsee->getAnnoncesLegales($lien->siren, 0, 'P', false))>0) {
|
||
$this->RJFILLE=true;
|
||
}
|
||
}
|
||
}
|
||
}
|
||
$timer['participations']=microtime(true);
|
||
|
||
$tabBil=array();
|
||
if ($this->NBBILAN == 0) {
|
||
$noteSolvabilite = round($noteStructure) * 5; // La note finale est sur 100
|
||
/** Pas de bilan mais capital elevé **/
|
||
if ($this->ACTIFRNCS && $this->FJURRNCS1>1 && $this->FJURRNCS1<7) {
|
||
if ($this->CAPITAL < 9000) $this->NOTECAP20=3;
|
||
elseif ($this->CAPITAL < 30000) $this->NOTECAP20=5;
|
||
elseif ($this->CAPITAL < 150000) $this->NOTECAP20=7;
|
||
elseif ($this->CAPITAL < 350000) $this->NOTECAP20=9;
|
||
elseif ($this->CAPITAL < 500000) $this->NOTECAP20=10;
|
||
elseif ($this->CAPITAL < 750000) $this->NOTECAP20=11;
|
||
elseif ($this->CAPITAL < 1500000) $this->NOTECAP20=12;
|
||
elseif ($this->CAPITAL < 2000000) $this->NOTECAP20=13;
|
||
elseif ($this->CAPITAL < 5000000) $this->NOTECAP20=15;
|
||
elseif ($this->CAPITAL < 10000000) $this->NOTECAP20=17;
|
||
else $this->NOTECAP20=19;
|
||
}
|
||
}
|
||
else {
|
||
$numBil = $i = 0;
|
||
foreach ($tabBilan as $item)
|
||
{
|
||
if ($item['CONSOLIDE']=='S')
|
||
{
|
||
$tabTmp = $mBil->bilanSimplifie2Normal($item);
|
||
$tabBilan[$i] = array_merge($tabTmp, $item);
|
||
$numBil++;
|
||
}
|
||
elseif ($item['CONSOLIDE']=='N')
|
||
{
|
||
$numBil++;
|
||
}
|
||
else
|
||
{
|
||
continue;
|
||
}
|
||
if ($numBil>2) break;
|
||
|
||
$icotation = new Metier_Scores_ICotation($item, true, $this->db);
|
||
$secteur=$icotation->getSecteurActivite($isolv->getNaf4($naf));
|
||
$libSecteur=$icotation->tabLibActivite[$secteur];
|
||
$chiffeAffaire=$icotation->calculChiffreAffaires($isolv->getNaf4($naf));
|
||
$tabBil[$i] = array(
|
||
'Millesime'=>$item['DATE_CLOTURE'],
|
||
'FraisPerso'=>$icotation->calculFraisPersonnel(),
|
||
'CA'=>$chiffeAffaire,
|
||
'EBE'=>$icotation->calculEBE(),
|
||
'TxInvest'=>$icotation->calculTauxInvestissement(),
|
||
'TxEndett'=>$icotation->calculTauxEndettementFinancier(),
|
||
'DettesCT'=>$icotation->calculDettesCT(),
|
||
'FraisFi'=>$icotation->calculFraisFinanciers(),
|
||
'BFR'=>$icotation->calculBFR(),
|
||
'FR'=>$icotation->calculFR(),
|
||
'FondsPr'=>$icotation->calculFondsPropres(),
|
||
'DelaiCli'=>$icotation->calculDelaisClients(),
|
||
'DelaiFour'=>$icotation->calculDelaisFournisseurs(),
|
||
);
|
||
unset($note); unset($noteB); unset($numerateur); unset($denominateur);
|
||
$note[0]=$noteB[0]=$numerateur[0]=$denominateur[0]=$noteTot=0;
|
||
|
||
$tabTmp = $icotation->noteCapitalisation();
|
||
$numerateur[1] = number_format($tabTmp['NUMERATEUR'], 0, ',', '');
|
||
$denominateur[1]= number_format($tabTmp['DENOMINATEUR'], 0, ',', '');
|
||
$note[1] = number_format($tabTmp['NOTE'], 2, ',', ' ');
|
||
$noteB[1] = $icotation->getNoteBorne($tabTmp['NOTE'], 1, $secteur, $numerateur[1], $denominateur[1]);
|
||
// On minimise la note de capitalisation qui est souvent un peu violente
|
||
if ($noteB[1]<11 && $this->CAPITAL>=100000000) $noteB[1]=11;
|
||
if ($noteB[1]<6 && $chiffeAffaire>=50000000 && $this->EFFECTIF>300) $noteB[1]=11;
|
||
$this->NOTECAP20=$noteTot+=$noteB[1];
|
||
|
||
$tabTmp = $icotation->noteLevierEndettement();
|
||
$numerateur[2] = number_format($tabTmp['NUMERATEUR'], 0, ',', '');
|
||
$denominateur[2]= number_format($tabTmp['DENOMINATEUR'], 0, ',', '');
|
||
$note[2] = number_format($tabTmp['NOTE'], 2, ',', ' ');
|
||
$noteB[2] = $icotation->getNoteBorne($tabTmp['NOTE'], 2, $secteur, $numerateur[2], $denominateur[2]);
|
||
$noteTot+=$noteB[2];
|
||
$this->NOTELED20=$noteB[2];
|
||
|
||
$tabTmp = $icotation->noteCapaciteRemboursement();
|
||
$numerateur[3] = number_format($tabTmp['NUMERATEUR'], 0, ',', '');
|
||
$denominateur[3]= number_format($tabTmp['DENOMINATEUR'], 0, ',', '');
|
||
$note[3] = number_format($tabTmp['NOTE'], 2, ',', ' ');
|
||
$noteB[3] = $icotation->getNoteBorne($tabTmp['NOTE'], 3, $secteur, $numerateur[3], $denominateur[3]);
|
||
$noteTot+=$noteB[3];
|
||
$this->NOTERBT20=$noteB[3];
|
||
|
||
$tabTmp = $icotation->noteCouvChargesFi();
|
||
$numerateur[4] = number_format($tabTmp['NUMERATEUR'], 0, ',', '');
|
||
$denominateur[4]= number_format($tabTmp['DENOMINATEUR'], 0, ',', '');
|
||
$note[4] = number_format($tabTmp['NOTE'], 2, ',', ' ');
|
||
$noteB[4] = $icotation->getNoteBorne($tabTmp['NOTE'], 4, $secteur, $numerateur[4], $denominateur[4]);
|
||
$noteTot+=$noteB[4];
|
||
$this->NOTECFI20=$noteB[4];
|
||
|
||
$tabTmp = $icotation->noteTresorerie($isolv->getNaf4($naf));
|
||
$numerateur[5] = number_format($tabTmp['NUMERATEUR'], 0, ',', '');
|
||
$denominateur[5]= number_format($tabTmp['DENOMINATEUR'], 0, ',', '');
|
||
$note[5] = number_format($tabTmp['NOTE'], 0, ',', '');
|
||
$noteB[5] = $icotation->getNoteBorne($tabTmp['NOTE'], 5, $secteur, $numerateur[5], $denominateur[5]);
|
||
$noteTot+=$noteB[5];
|
||
$this->NOTETRES20=$noteB[5];
|
||
|
||
$tabTmp = $icotation->noteMargeExploitation($isolv->getNaf4($naf));
|
||
$numerateur[6] = number_format($tabTmp['NUMERATEUR'], 0, ',', '');
|
||
$denominateur[6]= number_format($tabTmp['DENOMINATEUR'], 0, ',', '');
|
||
$note[6] = number_format($tabTmp['NOTE'], 2, ',', ' ');
|
||
$noteB[6] = $icotation->getNoteBorne($tabTmp['NOTE'], 6, $secteur, $numerateur[6], $denominateur[6]);
|
||
$noteTot+=$noteB[6];
|
||
$this->NOTEMEX20=$noteB[6];
|
||
|
||
$noteMoy=number_format($noteTot/6, 2, '.', '');
|
||
if ($noteMoy<8 && $chiffeAffaire>=100000000 && $this->EFFECTIF>=1000) $noteMoy=8;
|
||
|
||
$noteFinanciere = $icotation->getNotationFin($noteMoy);
|
||
$libNoteFinanciere = $icotation->getInfosNotation($noteFinanciere);
|
||
$noteSD=round(($noteStructure+$noteMoy)*2.5);
|
||
$fondsPropres=$icotation->calculFondsPropresNetsCorriges();
|
||
|
||
/** MALUS **/
|
||
// Limitation de la note si Fonds Propres Négatifs
|
||
if ($fondsPropres<0 && $noteSD>50) $noteSD=50;
|
||
// Limitation de la note si RJ sur société mère
|
||
if ($this->RJMERE && $noteSD>40) $noteSD=40;
|
||
// Limitation de la note si RJ sur société fille
|
||
if ($this->RJFILLE && $noteSD>55) $noteSD=55;
|
||
|
||
/** BONUS **/
|
||
// Major. si entreprise majoritairement contrôlée par l'état
|
||
if ($this->RECME && $noteSD<55) $noteSD=55;
|
||
|
||
if ((trim(strtr($tabIdentite['DateClotEt'],'-/',' '))*1)>0 ){
|
||
$noteSD=0;
|
||
$analyseConf='L\'entreprise est radiée depuis le '.$tabIdentite['DateClotEt'];
|
||
} else
|
||
$analyseConf='L\'analyse de la conformité est correcte.';
|
||
if ($numBil==1) {
|
||
$caEntrep=$chiffeAffaire;
|
||
$noteSolvabilite=$noteSD;
|
||
$noteFin=$noteMoy;
|
||
$scoreConanH=round($icotation->scoreConanHolder(),1);
|
||
$scoreAfdcc1=round($icotation->scoreAfdcc1(),2);
|
||
$scoreAfdcc2=round($icotation->scoreAfdcc2($naf, $trancheEffectif),1);
|
||
$scoreAfdcc2note=round($icotation->noteAfdcc,2);
|
||
$scoreZ =round($icotation->scoreZbis(),1);
|
||
$pDef36 =$icotation->evaluationCCF();
|
||
$valeurCCF =$icotation->valeurCCF;
|
||
$scoreAltman=round($icotation->scoreAltman(),2);
|
||
$scoreAltmanB=round($icotation->scoreAltman(true),2);
|
||
$tabInfosNotation=$icotation->getInfosNotation($noteFinanciere, 'array');
|
||
$this->SCOREDEFTAUX=$tabInfosNotation['ProbabiliteDefaut'];
|
||
|
||
// Liste des équivalences de notes
|
||
$note20scoreCH=$note20afdcc2=NULL;
|
||
|
||
// AFDCC1 Pertinant ?
|
||
$nbScoresComp=3; // Par défaut on compare 3 scores : BDF, S&D et AFDCC1
|
||
$note20afdcc1=($scoreAfdcc1+4)*1.95;
|
||
if ($note20afdcc1<0) $note20afdcc1=0;
|
||
elseif ($note20afdcc1>20) $note20afdcc1=20;
|
||
|
||
// BDF Z Pertinant ?
|
||
$note20scoreZ=($scoreZ+3)*3;
|
||
if ($note20scoreZ<0) $note20scoreZ=0;
|
||
elseif ($note20scoreZ>20) $note20scoreZ=20;
|
||
|
||
// Secteur Industriel : Conan Holder mauvais ?
|
||
switch ($secteur) {
|
||
case 15: // Industries Alimentaires : Collecte Appro
|
||
case 1: // Industries Manufacturières
|
||
case 2:
|
||
case 3:
|
||
case 5: // Industries Alimentaires
|
||
case 6: // Industries extractives / Production Distribution : Énergie Eau
|
||
if ($caEntrep>=1500000 && $caEntrep<=75000000) {
|
||
$nbScoresComp++;
|
||
$note20scoreCH=$scoreConanH+4;
|
||
if ($note20scoreCH<0) $note20scoreCH=0;
|
||
elseif ($note20scoreCH>20) $note20scoreCH=20;
|
||
}
|
||
break;
|
||
}
|
||
|
||
// Score AFDCC2 mauvais ?
|
||
if ($caEntrep>=150000 && $caEntrep<=75000000) {
|
||
$nbScoresComp++;
|
||
$note20afdcc2=$scoreAfdcc2note+9.5;
|
||
if ($note20afdcc2<0) $note20afdcc2=0;
|
||
elseif ($note20afdcc2>20) $note20afdcc2=20;
|
||
}
|
||
|
||
if ($this->debug) {
|
||
$strNote="";
|
||
$tabTmp=array(
|
||
1=>'Capitalisation',
|
||
2=>'Levier Endettement',
|
||
3=>'CapaciteRemboursement',
|
||
4=>'CouvChargesFi',
|
||
5=>'Tresorerie',
|
||
6=>'MargeExploitation',
|
||
);
|
||
for($iTmp=1; $iTmp<7; $iTmp++)
|
||
$strNote.=$tabTmp[$iTmp]." : ".$numerateur[$iTmp].'/'.$denominateur[$iTmp].'='.$note[$iTmp].' (Borné à '.$noteB[$iTmp].')'.EOL;
|
||
$strNote.="Note Financière=$noteFin Conan Holder=$scoreConanH Afdcc1=$scoreAfdcc1 Afdcc2=$scoreAfdcc2note (Classe $scoreAfdcc2) Z=$scoreZ CCF=$valeurCCF ($pDef36) Altman=$scoreAltman AltmanCote=$scoreAltmanB".EOL.print_r($tabInfosNotation,true);
|
||
}
|
||
}
|
||
else
|
||
{
|
||
$noteSolvabilitePre=$noteSD;
|
||
$noteFinPre=$noteMoy;
|
||
if ($noteSolvabilite>$noteSolvabilitePre) $tendance='Haussière';
|
||
elseif ($noteSolvabilite==$noteSolvabilitePre) $tendance='Stable';
|
||
else $tendance='Baissière';
|
||
}
|
||
|
||
$i++;
|
||
}
|
||
|
||
// Cas de présence unique de bilan Banque ou Assurance qui ne sont pas géré financièrement
|
||
if ($numBil==0 && !isset($noteSD))
|
||
$noteSolvabilite=round($noteStructure)*5; // La note finale est sur 100
|
||
|
||
}
|
||
$timer['scorefi']=microtime(true);
|
||
|
||
// Au cas ou !
|
||
if ($noteSolvabilite>90) $noteSolvabilite=90;
|
||
|
||
$this->SCORECONF=100;
|
||
|
||
// Présence d'un bilan mais trop vieux
|
||
if ($this->NBBILAN>0 && $classWdate->nbMoisEntre($this->BILANDATE,date('Ymd'))>=24) $this->BILANVIEUX=true;
|
||
else $this->BILANVIEUX=false;
|
||
|
||
// Présence d'un bilan mais trop vieux et c'est anormal
|
||
if ($this->NBBILAN>0 && $classWdate->nbMoisEntre($this->BILANDATE,date('Ymd'))>=30) $this->BILANMANQUE=true;
|
||
else $this->BILANMANQUE=false;
|
||
|
||
if ( (@$tabBil[0]['Millesime']+20000<date('Ymd')*1) && // Le dernier bilan date de + de 2 ans
|
||
(substr($tabIdentite['DateCreaEn'],0,4)*1+2)<date('Y') && // L'entreprise à plus de 2 ans
|
||
$this->FJURPUB ) { // et est soumise à publication
|
||
$this->SCORECONF-=20;
|
||
}
|
||
if (!$tabIdentite['TvaAttribue']) { // Entreprise sans numéro de TVA
|
||
$this->TVAINTRA=false;
|
||
$this->TVAINTRAFACULT=$tabIdentite['TvaFacultatif']; // 0, 1=MicroEntrep, 2=Dom Tom Etranger, 99=Erreur validation n°TVA
|
||
if ($this->TVAINTRAFACULT==0) $this->SCORECONF-=10;
|
||
} else
|
||
$this->TVAINTRA=$tabIdentite['TvaNumero'];
|
||
|
||
if ($tabIdentite['NonDiffusible']>0) { // Entreprise FJ=1xxx ayant demandé à sortir du champ de diffusion INSEE
|
||
$this->SCORECONF-=5;
|
||
//$tabCommentaires['gen'][]=prepareString("Cette affaire personnelle à demandée son retrait du champs de diffusion commercial de la base SIRENE.");
|
||
$this->PPNONDIFF=true;
|
||
} else {
|
||
$this->PPNONDIFF=false;
|
||
}
|
||
|
||
/** Entreprise en Zone Prioritaire ? **/
|
||
$this->ZONEPRI=false;
|
||
$this->ZONEPRIZUS=$this->ZONEPRIAFR=$this->ZONEPRICUCS=$this->ZONEPRIZFU=$this->ZONEPRIZRR=$this->ZONEPRIZRU='';
|
||
if ($tabIdentite['GeoInfos']['ZUS']=='OUI') $this->ZONEPRIZUS=$tabIdentite['GeoInfos']['NZUS'];
|
||
if ($tabIdentite['GeoInfos']['AFR']=='OUI') $this->ZONEPRIAFR=$tabIdentite['GeoInfos']['NAFR'];
|
||
if ($tabIdentite['GeoInfos']['CUCS']=='OUI')$this->ZONEPRICUCS=$tabIdentite['GeoInfos']['NCUCS'];
|
||
if ($tabIdentite['GeoInfos']['ZFU']=='OUI') $this->ZONEPRIZFU=$tabIdentite['GeoInfos']['NZFU'];
|
||
if ($tabIdentite['GeoInfos']['ZRR']=='OUI') $this->ZONEPRIZRR=$tabIdentite['GeoInfos']['NZRR'];
|
||
if ($tabIdentite['GeoInfos']['ZRU']=='OUI') $this->ZONEPRIZRU=$tabIdentite['GeoInfos']['NZRU'];
|
||
if ($this->ZONEPRIZUS || $this->ZONEPRIAFR || $this->ZONEPRICUCS || $this->ZONEPRIZFU || $this->ZONEPRIZRR || $this->ZONEPRIZRU) {
|
||
// Entreprise en Zone Prioritaire
|
||
$this->SCORECONF-=10;
|
||
$zonesPri=array();
|
||
foreach ($tabIdentite['GeoInfos'] as $zone=>$valeur)
|
||
if ($valeur=='OUI')
|
||
$zonesPri[]=$zone;
|
||
$this->ZONEPRI=implode(', ', $zonesPri);
|
||
//$tabCommentaires['gen'][]=prepareString("Cette entreprise est située en Zone Prioritaire.");
|
||
}
|
||
|
||
/** Domiciliation d'entreprise **/
|
||
$this->ADRDOM=@$tabIdentite['AdresseDom'];
|
||
if ($tabIdentite['AdresseDom']==2) $this->SCORECONF-=50;
|
||
elseif ($tabIdentite['AdresseDom']==1) $this->SCORECONF-=35;
|
||
// Nombre d'entrep à l'adresse de domiciliation
|
||
$this->DOM_NB=@$tabIdentite['AdresseDomNb'];
|
||
// Nom du domiciliuataire avéré ou suspecté
|
||
$this->DOM_NOM=@$tabIdentite['AdresseDomEnt'][0]['nom'];
|
||
// SIREN du domiciliataire avéré ou suspecté
|
||
$this->DOM_SIREN=@$tabIdentite['AdresseDomEnt'][0]['siren'];
|
||
|
||
/** Calcul du score Dirigeance **/
|
||
$this->SCOREDIRI=100;
|
||
$this->ANNONCEINTERDIT=0;
|
||
$dirs = $iInsee->getDirigeants($siren, false);
|
||
$timer['getDirigeants'] = microtime(true);
|
||
//debugLog('I', 'SCOREDIR = '. print_r($dirs,1), __LINE__, __FILE__, __FUNCTION__, __CLASS__);
|
||
$this->DIR_NB=$this->NBDIRLIENS=$this->NBDIRSCI=$this->NBDIRSCIADR=0;
|
||
if (count($dirs) > 0 ) {
|
||
foreach ($dirs as $nb => $dir) {
|
||
if ($dir['Ancien']==0 && preg_match('/G.rant|Personne|Pr.sident|Directeur|Repr.sentant/Uisu', $dir['Titre'])) {
|
||
$this->DIR_NB++;
|
||
if ($this->DIR_NB==1) {
|
||
$this->DIR1_NOM=preg_replace('/ +/',' ',$dir['Civilite'].' '.$dir['Nom'].' '.$dir['Prenom']);
|
||
$this->DIR1_AGE=floor($classWdate->nbMoisEntre($classWdate->dateT('d/m/Y','Ymd',$dir['NaissDate']))/12);
|
||
$this->DIR1_FONC=$dir['Titre'];
|
||
$this->DIR1_TYPE='PP';
|
||
} elseif ($this->DIR_NB==2) {
|
||
$this->DIR2_NOM=preg_replace('/ +/',' ',$dir['Civilite'].' '.$dir['Nom'].' '.$dir['Prenom']);
|
||
$this->DIR2_AGE=floor($classWdate->nbMoisEntre($classWdate->dateT('d/m/Y','Ymd',$dir['NaissDate']))/12);
|
||
$this->DIR2_FONC=$dir['Titre'];
|
||
$this->DIR2_TYPE='PP';
|
||
}
|
||
|
||
$activeRechercheDir = false;
|
||
if ($activeRechercheDir){
|
||
$tabDir = $iInsee->rechercheDir($dir['Nom'], $dir['Prenom'], '', $dir['NaissDate'], '', 0, 200, 200);
|
||
$tabDir = $tabDir['reponses'];
|
||
$nbFctDir=$nbFctDirSci=$nbFctDirSciAdr=0;
|
||
if (count($tabDir)>0){
|
||
foreach($tabDir as $iDir=>$tabDiri) {
|
||
if ($tabDiri['Actif']==1 && $tabDiri['Siege']==1) {
|
||
$nbFctDir++;
|
||
if ($tabDiri['FJ']==6540) {
|
||
$nbFctDirSci++;
|
||
if ($tabDiri['FJ']==6540) {
|
||
/* [Adresse] => 0001 RUE DU CHAMP FLEURI
|
||
[Adresse2] =>
|
||
[CP] => 49770
|
||
[Ville] => LA MEIGNANNE
|
||
*/
|
||
$nbFctDirSciAdr++;
|
||
}
|
||
}
|
||
}
|
||
}
|
||
}
|
||
}
|
||
|
||
// Nombre d'entreprises maximum dirigé par un des dirigeants
|
||
if ($nbFctDir>$this->NBDIRLIENS) $this->NBDIRLIENS=$nbFctDir;
|
||
|
||
// Nombre de SCI maximum dirigé par un des dirigeants (inclus dans NBDIRLIENS)
|
||
if ($nbFctDirSci>$this->NBDIRSCI) $this->NBDIRSCI=$nbFctDirSci;
|
||
|
||
// Nombre de SCI maximum dirigé par un des dirigeants à l'adresse (inclus dans les autres NBDIR...)
|
||
if ($nbFctDirSciAdr>$this->NBDIRSCIADR) $this->NBDIRSCIADR=$nbFctDirSciAdr;
|
||
|
||
}
|
||
|
||
switch ($dir['Cinf']) {
|
||
case 11:
|
||
case 12: // Interdiction de gérer ou FP en cours
|
||
if ($dir['Ancien']==0) {
|
||
$noteSolvabilite=5;
|
||
$this->SCORECONF=0;
|
||
$this->SCOREDIRI=0;
|
||
} elseif ($dir['Ancien']==1) {
|
||
if ($this->SCORECONF>50) $this->SCORECONF=50;
|
||
$this->SCOREDIRI=30;
|
||
if ($noteSolvabilite>35) $noteSolvabilite=35;
|
||
|
||
}
|
||
$this->ANNONCEINTERDIT++;
|
||
$this->ANNONCEINTERDITDATE=$classWdate->dateT('d/m/Y','Y-m-d', $dir['DateFct']);
|
||
break(2);
|
||
case 15:
|
||
case 16: // Procédure collective dans l'historique du dirigeant
|
||
if ($dir['Ancien']==0 && preg_match('/G.rant|Personne|Pr.sident|Directeur|Repr.sentant/Uisu', $dir['Titre'])) {
|
||
$this->SCORECONF-=20;
|
||
$this->SCOREDIRI-=60;
|
||
if ($noteSolvabilite>45) $noteSolvabilite=45;
|
||
} elseif ($dir['Ancien']==1 && preg_match('/G.rant|Personne|Pr.sident|Directeur|Repr.sentant/Uisu', $dir['Titre'])) {
|
||
$this->SCORECONF-=10;
|
||
$this->SCOREDIRI-=30;
|
||
if ($noteSolvabilite>55) $noteSolvabilite=55;
|
||
} else {
|
||
$this->SCOREDIRI-=20;
|
||
if ($noteSolvabilite>60) $noteSolvabilite=60;
|
||
}
|
||
break(2);
|
||
case 19:
|
||
if ($dir['Ancien']==0 && preg_match('/G.rant|Personne|Pr.sident|Directeur|Repr.sentant/Uisu', $dir['Titre'])) {
|
||
$this->SCOREDIRI-=50;
|
||
if ($noteSolvabilite>40) $noteSolvabilite=40;
|
||
}
|
||
elseif ($dir['Ancien']==1 && preg_match('/G.rant|Personne|Pr.sident|Directeur|Repr.sentant/Uisu', $dir['Titre'])) {
|
||
$this->SCOREDIRI-=20;
|
||
if ($noteSolvabilite>52) $noteSolvabilite=52;
|
||
} else {
|
||
$this->SCOREDIRI-=10;
|
||
if ($noteSolvabilite>65) $noteSolvabilite=65;
|
||
}
|
||
break(2);
|
||
default:
|
||
break;
|
||
}
|
||
}
|
||
}
|
||
$timer['traitementDirigeants'] = microtime(true);
|
||
|
||
/** Affichage des informations de paiement dans le score **/
|
||
$this->COTEOK_MMAA=$this->IMPAYE_MMAA=$this->PRIVILEGES_MMAA=$this->RISQUEGROUPE_MMAA='';
|
||
$this->DEFAUT_MMAA=$this->LCASSUR_MMAA=$this->RISQUEIMPAYE_MMAA=$this->CSFACTO_MMAA='';
|
||
$this->COTEOK=$this->IMPAYE=$this->PRIVILEGES=$this->RISQUEGROUPE=$this->DEFAUT=$this->LCASSUR=$this->RISQUEIMPAYE=$this->CSFACTO=false;
|
||
$this->MODIFPAIDATE=0;
|
||
|
||
$iFacto = new Metier_Partenaires_MFacto($this->db);
|
||
$infoFacto = $iFacto->getCoteSpeciale($siren);
|
||
$timer['factoCS']=microtime(true);
|
||
|
||
$libProfilPayeur=trim($iFacto->getProfilPayeur($siren));
|
||
$profilPayeur=$iFacto->profilPayeur;
|
||
$timer['factoProfil']=microtime(true);
|
||
|
||
$this->DELAIPAY=$iFacto->DELAIPAY;
|
||
$this->DELAIPAYp=$iFacto->DELAIPAYp;
|
||
$this->DELAIPAY_MMAA=$iFacto->DELAIPAY_MMAA;
|
||
if (isset($infoFacto[0])) {
|
||
$nivRisquePaiement=$infoFacto[0]['risque'];
|
||
$this->MODIFPAIDATE=$infoFacto[0]['DateEven'];
|
||
switch ($infoFacto[0]['CodeRisque']) {
|
||
case 'OK':
|
||
$this->COTEOK=true;
|
||
$this->COTEOK_MMAA=$this->CSFACTO_MMAA=$classWdate->dateT('Y-m-d', 'Ym', $infoFacto[0]['DateEven']);
|
||
if ($noteSolvabilite>=40 && $noteSolvabilite<=45) $noteSolvabilite+=5;
|
||
$this->CSFACTO=0;
|
||
break;
|
||
case 'IP': $this->IMPAYE=true;
|
||
$this->IMPAYE_MMAA=$this->CSFACTO_MMAA=$classWdate->dateT('Y-m-d', 'Ym', $infoFacto[0]['DateEven']);
|
||
$this->CSFACTO='I';
|
||
$profilPayeur=5;
|
||
break;
|
||
case 'PR':
|
||
$this->PRIVILEGES=true;
|
||
$this->PRIVILEGES_MMAA=$this->CSFACTO_MMAA=$classWdate->dateT('Y-m-d', 'Ym', $infoFacto[0]['DateEven']);
|
||
$this->CSFACTO='P';
|
||
$profilPayeur=5;
|
||
break;
|
||
case 'RG':
|
||
$this->RISQUEGROUPE=true;
|
||
$this->RISQUEGROUPE_MMAA=$this->CSFACTO_MMAA=$classWdate->dateT('Y-m-d', 'Ym', $infoFacto[0]['DateEven']);
|
||
$this->CSFACTO=24; $this->SCOREDIRI-=10;
|
||
break;
|
||
case 'DEF':
|
||
$this->DEFAUT=true;
|
||
$this->DEFAUT_MMAA=$this->CSFACTO_MMAA=$classWdate->dateT('Y-m-d', 'Ym', $infoFacto[0]['DateEven']);
|
||
$this->CSFACTO='D';
|
||
break;
|
||
case 'LC':
|
||
$this->LCASSUR=true;
|
||
$this->LCASSUR_MMAA=$this->CSFACTO_MMAA=$classWdate->dateT('Y-m-d', 'Ym', $infoFacto[0]['DateEven']);
|
||
$this->CSFACTO='T';
|
||
break;
|
||
case 'KO':
|
||
$noteSolvabilite=$this->SCORECONF=$this->SCOREDIRI=0;
|
||
$this->CSFACTO=50;
|
||
$this->CSFACTO_MMAA=$classWdate->dateT('Y-m-d', 'Ym', $infoFacto[0]['DateEven']);
|
||
break;
|
||
default:
|
||
if ($iFacto->risqueImpaye) {
|
||
$this->RISQUEIMPAYE_MMAA=$iFacto->risqueImpayeMois;
|
||
$this->RISQUEIMPAYE=true;
|
||
} else {
|
||
$this->CSFACTO=$infoFacto[0]['CoteCS']*1;
|
||
$this->CSFACTO_MMAA=$classWdate->dateT('Y-m-d', 'Ym', $infoFacto[0]['DateEven']);
|
||
}
|
||
break;
|
||
}
|
||
$this->CSFACTOFIN_MMAA=$classWdate->dateT('Y-m-d', 'Ym', $infoFacto[0]['DateFin']);
|
||
if ($infoFacto[0]['CoteCS']*1>0)
|
||
$libInfoPaiement='Courant '.$classWdate->dateT('Y-m-d', 'M Y', $infoFacto[0]['DateEven']).' : '.$infoFacto[0]['LibCS'];
|
||
else {
|
||
$libInfoPaiement=trim('Depuis '.$classWdate->dateT('Y-m-d', 'M Y', $infoFacto[0]['DateEven']).' : '.$infoFacto[0]['LibCS'].' '.$libProfilPayeur);
|
||
$encoursCS=7500;
|
||
}
|
||
} else {
|
||
$nivRisquePaiement=0;
|
||
if ($libProfilPayeur<>'') {
|
||
$libInfoPaiement=$libProfilPayeur;
|
||
} else {
|
||
$libInfoPaiement='Aucun retard de paiement significatif n\'a été porté à notre connaissance par l\'ensemble de nos partenaires.';
|
||
}
|
||
if ($iFacto->risqueImpaye) {
|
||
$this->RISQUEIMPAYE_MMAA=$classWdate->dateT('Y-m', 'Ym', $iFacto->risqueImpayeDate);
|
||
if ((''.$iFacto->risqueImpayeDate.'-01')>$this->MODIFPAIDATE)
|
||
$this->MODIFPAIDATE=''.$iFacto->risqueImpayeDate.'-01';
|
||
}
|
||
}
|
||
$timer['factoImpaye']=microtime(true);
|
||
|
||
// Tableaux des Paiements
|
||
$tabPaiements=$iFacto->getTabPaiements($siren);
|
||
$timer['factoPaiements']=microtime(true);
|
||
|
||
// Présence de Privilèges
|
||
$this->PRIVILEGESECU=$this->PRIVILEGESECU_MT=$this->PRIVILEGETRES=$this->PRIVILEGETRES_MT=0;
|
||
$iPriv = new Metier_Partenaires_MPrivileges($this->db);
|
||
$tabPriv = $iPriv->getPrivilegesCumul($siren);
|
||
$noteSolvMax=100;
|
||
if (isset($tabPriv['03']['nb'])) {
|
||
$this->PRIVILEGES=true;
|
||
$this->PRIVILEGESECU=$tabPriv['03']['nb'];
|
||
$this->PRIVILEGESECU_MT=$tabPriv['03']['insCumul'];
|
||
$this->PRIVILEGES_MMAA=$classWdate->dateT('Y-m-d', 'Ym', $tabPriv['03']['dateFraiche']);
|
||
if ($tabPriv['03']['dateFraiche']>$this->MODIFPAIDATE)
|
||
$this->MODIFPAIDATE=$tabPriv['03']['dateFraiche'];
|
||
if ($infoFacto[0]['CoteCS']*1==0)
|
||
$libInfoPaiement=trim('Depuis le '.$classWdate->dateT('Y-m-d', 'd/m/Y', $tabPriv['03']['dateFraiche'])." : $this->PRIVILEGESECU inscription(s) URSSAF pour un montant de ".number_format($this->PRIVILEGESECU_MT,2,',',' ')." euros. $libProfilPayeur");
|
||
if ($this->PRIVILEGESECU==1 && $this->PRIVILEGESECU_MT<15000) {
|
||
if (($this->NBBILAN==0||$this->BILANVIEUX||$this->BILANMANQUE) && $this->CAPITAL<750000) $noteSolvMax=42;
|
||
elseif (($this->NBBILAN==0||$this->BILANVIEUX||$this->BILANMANQUE) && $this->CAPITAL>=750000) $noteSolvMax=45;
|
||
else $noteSolvMax=49;
|
||
} elseif ($this->PRIVILEGESECU>0) {
|
||
if (($this->NBBILAN==0||$this->BILANVIEUX||$this->BILANMANQUE) && $this->CAPITAL<750000) $noteSolvMax=37;
|
||
elseif (($this->NBBILAN==0||$this->BILANVIEUX||$this->BILANMANQUE) && $this->CAPITAL>=750000) $noteSolvMax=38;
|
||
else $noteSolvMax=39;
|
||
}
|
||
//if ($noteSolvabilite>$noteSolvMax) $noteSolvabilite=$noteSolvMax;
|
||
}
|
||
if (isset($tabPriv['04']['nb'])) {
|
||
$this->PRIVILEGES=true;
|
||
$this->PRIVILEGETRES=$tabPriv['04']['nb'];
|
||
$this->PRIVILEGETRES_MT=$tabPriv['04']['insCumul'];
|
||
$this->PRIVILEGES_MMAA=$classWdate->dateT('Y-m-d', 'Ym', $tabPriv['04']['dateFraiche']);
|
||
if ($tabPriv['04']['dateFraiche']>$this->MODIFPAIDATE)
|
||
$this->MODIFPAIDATE=$tabPriv['04']['dateFraiche'];
|
||
if ($infoFacto[0]['CoteCS']*1==0)
|
||
if ($this->PRIVILEGESECU<1)
|
||
$libInfoPaiement=trim('Depuis le '.$classWdate->dateT('Y-m-d', 'd/m/Y', $tabPriv['04']['dateFraiche'])." : $this->PRIVILEGETRES inscription(s) TRESOR pour un montant de ".number_format($this->PRIVILEGETRES_MT,2,',',' ')." euros. $libProfilPayeur");
|
||
else
|
||
$libInfoPaiement.='<br/>'.trim('Depuis le '.$classWdate->dateT('Y-m-d', 'd/m/Y', $tabPriv['04']['dateFraiche'])." : $this->PRIVILEGETRES inscription(s) TRESOR pour un montant de ".number_format($this->PRIVILEGETRES_MT,2,',',' ')." euros. $libProfilPayeur");
|
||
if ($this->PRIVILEGETRES==1 && $this->PRIVILEGETRES_MT<15000) {
|
||
if ($this->PRIVILEGESECU>0) $seuil=45;
|
||
else $seuil=55;
|
||
if (($this->NBBILAN==0||$this->BILANVIEUX||$this->BILANMANQUE) && $this->CAPITAL<750000) $noteSolvMax=$seuil-10;
|
||
elseif (($this->NBBILAN==0||$this->BILANVIEUX||$this->BILANMANQUE) && $this->CAPITAL>=750000) $noteSolvMax=$seuil-5;
|
||
else $noteSolvMax=$seuil;
|
||
} elseif ($this->PRIVILEGETRES>0) {
|
||
if ($this->PRIVILEGESECU>0) $seuil=46;
|
||
else $seuil=56;
|
||
if (($this->NBBILAN==0||$this->BILANVIEUX||$this->BILANMANQUE) && $this->CAPITAL<750000) $noteSolvMax=$seuil-11;
|
||
elseif (($this->NBBILAN==0||$this->BILANVIEUX||$this->BILANMANQUE) && $this->CAPITAL>=750000) $noteSolvMax=$seuil-6;
|
||
else $noteSolvMax=$seuil;
|
||
}
|
||
}
|
||
if ($this->PRIVILEGES) {
|
||
$this->SCORECONF-=20;
|
||
if ($noteSolvMax==100) {
|
||
if (($this->NBBILAN==0||$this->BILANVIEUX||$this->BILANMANQUE) && $this->CAPITAL<750000) $noteSolvMax=40;
|
||
elseif (($this->NBBILAN==0||$this->BILANVIEUX||$this->BILANMANQUE) && $this->CAPITAL>=750000) $noteSolvMax=46;
|
||
else $noteSolvMax=50;
|
||
}
|
||
}
|
||
|
||
if ($this->IMPAYE) {
|
||
$this->SCORECONF-=10;
|
||
if ($this->PRIVILEGES) $noteSolvMax-=10;
|
||
elseif ($this->SOCIETE_COTE) $noteSolvMax=61;
|
||
elseif ($this->NBBILAN==0 && $this->FJURPUB && $this->CAPITAL<750000) $noteSolvMax=40;
|
||
elseif ($this->NBBILAN==0 && !$this->FJURPUB && $this->CAPITAL<750000) $noteSolvMax=42;
|
||
elseif ($this->NBBILAN==0 && $this->FJURPUB && $this->CAPITAL<1500000) $noteSolvMax=45;
|
||
elseif ($this->NBBILAN==0 && !$this->FJURPUB && $this->CAPITAL<1500000) $noteSolvMax=47;
|
||
elseif ($this->NBBILAN==0 && $this->FJURPUB ) $noteSolvMax=50;
|
||
elseif ($this->NBBILAN==0 && !$this->FJURPUB) $noteSolvMax=51;
|
||
elseif ($this->NBBILAN>0 && $this->FJURPUB && ($this->BILANVIEUX||$this->BILANMANQUE) && $this->CAPITAL<750000) $noteSolvMax=45;
|
||
elseif ($this->NBBILAN>0 && $this->FJURPUB && ($this->BILANVIEUX||$this->BILANMANQUE) && $this->CAPITAL<1500000) $noteSolvMax=50;
|
||
elseif ($this->NBBILAN>0 && $this->FJURPUB && ($this->BILANVIEUX||$this->BILANMANQUE)) $noteSolvMax=52;
|
||
elseif ($this->CAPITAL<750000) $noteSolvMax=47;
|
||
elseif ($this->CAPITAL<1500000) $noteSolvMax=50;
|
||
else $noteSolvMax=52;
|
||
}
|
||
|
||
if ($this->ANNONCEHOM>0) {
|
||
//$this->SCORECONF+=10;
|
||
if ($this->PRIVILEGES || $this->IMPAYE || $this->DEFAUT) $noteSolvMax=46;
|
||
elseif ($this->CAPITAL<750000) $noteSolvMax=48;
|
||
elseif ($this->CAPITAL<1500000) $noteSolvMax=53;
|
||
else $noteSolvMax=56;
|
||
}
|
||
|
||
if ($this->DEFAUT) {
|
||
if (($this->NBBILAN==0 || $this->BILANVIEUX) && $this->CAPITAL<750000) $noteSolvMax=41;
|
||
elseif (($this->NBBILAN==0 || $this->BILANVIEUX) && $this->CAPITAL<1500000)$noteSolvMax=48;
|
||
elseif (($this->NBBILAN==0 || $this->BILANVIEUX)) $noteSolvMax=51;
|
||
else $noteSolvMax=54;
|
||
}
|
||
if ($this->RISQUEGROUPE) {
|
||
if ($this->RJMERE) $noteSolvMax=39;
|
||
elseif ($this->RJFILLE)$noteSolvMax=49;
|
||
else $noteSolvMax=56;
|
||
}
|
||
|
||
if ($tabIdentite['SituationJuridique']=='PL') {
|
||
$this->SCOREDIRI-=20;
|
||
$this->SCORECONF+=10;
|
||
if (($this->NBBILAN==0 || $this->BILANVIEUX) && $this->CAPITAL<750000) $noteSolvMax=39;
|
||
elseif (($this->NBBILAN==0 || $this->BILANVIEUX) && $this->CAPITAL<1500000) $noteSolvMax=41;
|
||
elseif (($this->NBBILAN==0 || $this->BILANVIEUX)) $noteSolvMax=48;
|
||
else $noteSolvMax=51;
|
||
}
|
||
|
||
if ($noteSolvabilite>$noteSolvMax) $noteSolvabilite=$noteSolvMax;
|
||
$timer['privileges']=microtime(true);
|
||
|
||
// Paiements
|
||
$this->MODIFDERDATE = $this->MODIFINSEEDATE;
|
||
if ($this->MODIFPAIDATE>$this->MODIFDERDATE) $this->MODIFDERDATE = $this->MODIFPAIDATE;
|
||
// Rcs
|
||
if ($this->MODIFRNCSDATE > $this->MODIFDERDATE) $this->MODIFDERDATE = $this->MODIFRNCSDATE;
|
||
// Annonces
|
||
if ($this->ANNONCEDERDATE > $this->MODIFDERDATE) $this->MODIFDERDATE = $this->ANNONCEDERDATE;
|
||
|
||
// --- Cut Off
|
||
$this->ENQUETE='';
|
||
if ($this->companyEvenDateStop === null) {
|
||
$tabTmp = $this->db->select('jo.scores_cutoff',
|
||
'encours, scoreSolv, scoreDir, scoreConf, DATE(dateInsert)*1 AS dateInsert, DATE(dateUpdate)*1 AS dateUpdate',
|
||
"siren=$siren", $this->debug, MYSQL_ASSOC);
|
||
$timer['scores_cutoff'] = microtime(true);
|
||
if (count($tabTmp) > 0) {
|
||
if($tabTmp[0]['dateUpdate'] > $tabTmp[0]['dateInsert']) {
|
||
$dateMaj = $tabTmp[0]['dateUpdate'];
|
||
} else {
|
||
$dateMaj = $tabTmp[0]['dateInsert'];
|
||
}
|
||
// Si pas plus vieux que 6 mois
|
||
if ($classWdate->nbMoisEntre($dateMaj, date('Ymd')) <= $this->ENQUETELIM) {
|
||
$encoursForce=$tabTmp[0]['encours'];
|
||
if ($tabTmp[0]['scoreConf'] !== null) {
|
||
$this->SCORECONF = $tabTmp[0]['scoreConf'];
|
||
}
|
||
if ($this->SCORECONF > $this->ENQUETEMAXI) {
|
||
$this->SCORECONF = $this->ENQUETEMAXI;
|
||
}
|
||
if ($tabTmp[0]['scoreDir'] !== null) {
|
||
$this->SCOREDIRI = $tabTmp[0]['scoreDir'];
|
||
}
|
||
if ($this->SCOREDIRI > $this->ENQUETEMAXI) {
|
||
$this->SCOREDIRI = $this->ENQUETEMAXI;
|
||
}
|
||
if ($tabTmp[0]['scoreSolv'] !== null) {
|
||
$this->ENQUETE = $noteSolvabilite = $tabTmp[0]['scoreSolv'];
|
||
}
|
||
if ($this->ENQUETE > $this->ENQUETEMAXI) {
|
||
$this->ENQUETE=$this->ENQUETEMAXI;
|
||
}
|
||
// Permet de supprimer la prise en compte de la procol
|
||
if ($this->ENQUETE > 0) {
|
||
$tabIdentite['SituationJuridique'] = $this->ANNONCEPC = '';
|
||
$this->ANNONCELJ = $this->ANNONCERJ = $this->ANNONCESV = $this->PLANMODIF = $this->PLAN = $this->ANNONCEPC_OBS = $this->ELIMINE = false;
|
||
}
|
||
}
|
||
}
|
||
}
|
||
|
||
// --- Commentaire Dirigeance
|
||
if ($this->SCOREDIRI>=70) {
|
||
$analyseDir="L'étude de la dirigeance ne relève aucun problème.";
|
||
} elseif ($this->SCOREDIRI>=40) {
|
||
$analyseDir="L'étude de la dirigeance retient notre attention.";
|
||
} elseif ($this->SCOREDIRI>0) {
|
||
$analyseDir="L'étude de la dirigeance attire toute notre attention.";
|
||
} else {
|
||
$analyseDir="L'étude de la dirigeance révèle des anomalies.";
|
||
$this->SCOREDIRI=0;
|
||
}
|
||
|
||
// --- Commentaire Conformité
|
||
if ($tabIdentite['SituationJuridique']=='P') {
|
||
$noteSolvabilite = $this->SCORECONF = $this->SCOREDIRI = 0;
|
||
$analyseConf = "L'entreprise est en procédure collective";
|
||
} elseif ($tabIdentite['SituationJuridique']=='D') {
|
||
$noteSolvabilite = $this->SCORECONF = $this->SCOREDIRI = 0;
|
||
$analyseConf = "L'entreprise est dissoute";
|
||
} elseif ($tabIdentite['Actif']==0) {
|
||
$noteSolvabilite = $this->SCORECONF = $this->SCOREDIRI = 0;
|
||
$analyseConf = "L'entreprise n'est pas en activité";
|
||
} elseif ($this->SCORECONF>=70) {
|
||
$analyseConf = "L'analyse de la conformité est correcte.";
|
||
} elseif ($this->SCORECONF>=40) {
|
||
$analyseConf = "L'analyse de la conformité est acceptable.";
|
||
} elseif ($this->SCORECONF>0) {
|
||
$analyseConf = "L'analyse de la conformité est sensible.";
|
||
} else {
|
||
$analyseConf = "L'analyse de la conformité est très sensible.";
|
||
$this->SCORECONF = 0;
|
||
}
|
||
|
||
// --- Commentaire Solvabilité
|
||
if ($noteFin>0) $noteSolv=($noteStructure+$noteFin)/2;
|
||
else $noteSolv=($noteStructure+$noteFin)/5;
|
||
if ($noteSolv>=15) $analyseSolv = 'Excellente';
|
||
elseif ($noteSolv>=12) $analyseSolv = 'Bonne';
|
||
elseif ($noteSolv>=10) $analyseSolv = 'Correcte';
|
||
elseif ($noteSolv>=8) $analyseSolv = 'Moyenne';
|
||
elseif ($noteSolv>=6) $analyseSolv = 'Délicate';
|
||
else $analyseSolv = 'Inquiétante';
|
||
if ($noteSolvabilite>=40 && $analyseSolv=='Inquiétante') $analyseSolv = 'Correcte';
|
||
|
||
// --- CA Moyen par salarié pour un secteur donné
|
||
$this->CAESTIME = $iInsee->getCAnafEffectif($naf, $this->EFFECTIF);
|
||
|
||
if ($this->CABILAN>0) $this->CABIOUES=$this->CABILAN;
|
||
else $this->CABIOUES=$this->CAESTIME;
|
||
|
||
// L'encours de départ est à 10% du capital
|
||
$encoursIni = $tabIdentite['Capital']/10;
|
||
// Ou à l'encours ini CS car pas d'informations négatives
|
||
if ($encoursCS>$encoursIni) $encoursIni=$encoursCS;
|
||
|
||
$this->ENCOURS = $encoursIni;
|
||
$encoursEstime = 0;
|
||
$timer['camoyen']=microtime(true);
|
||
|
||
// L'encours de trésorerie prend 1/6è de 1/12è de la Trésorerie
|
||
if ($this->R[63] > 0) {
|
||
$encoursTR = $this->R[63]/72;
|
||
}
|
||
|
||
if ($noteSolvabilite>=40) {
|
||
if ($this->HOLDING) {
|
||
// Cas des Holding
|
||
$this->ENCOURS=$tabIdentite['Capital']/12;
|
||
if (@$tabBil[0]['FondsPr']>0) {
|
||
$encoursFP=(($tabBil[0]['FondsPr'])/72);
|
||
if ($encoursFP>$this->ENCOURS) $this->ENCOURS=$encoursFP;
|
||
} elseif ($encoursTR>$this->ENCOURS) $this->ENCOURS=$encoursTR;
|
||
|
||
} elseif (isset($tabBil[0])) {
|
||
// SI BILAN : L'encours théorique de base est plafonnée au CA/36
|
||
if ($tabBil[0]['CA']>0) $this->ENCOURS=(($tabBil[0]['CA'])/36);
|
||
if ($encoursCS>$this->ENCOURS) $this->ENCOURS=$encoursCS;
|
||
//Plafond à 25% des fonds propres ou à 1000 ? si FP<0
|
||
if ($tabBil[0]['FondsPr']>0) $plafond=$tabBil[0]['FondsPr']/4;
|
||
elseif ($this->R[63]>0) $plafond=$this->R[63]/12;
|
||
|
||
if ($this->ENCOURS>$plafond) $this->ENCOURS=$plafond;
|
||
|
||
} else {
|
||
// Détermination de l'encours sans bilans : Encours estimé = CA Estimé / 72
|
||
if ($this->CAESTIME>0) $encoursEstime=$this->CAESTIME/36;
|
||
}
|
||
|
||
// Plafond des encours en fonction de la note / 100
|
||
if ($noteSolvabilite > 65) $plafond=500000;
|
||
elseif ($noteSolvabilite > 60) $plafond=350000;
|
||
elseif ($noteSolvabilite > 55) $plafond=250000;
|
||
elseif ($noteSolvabilite >= 50) $plafond=150000;
|
||
elseif ($noteSolvabilite >= 45) $plafond=30000;
|
||
else $plafond=15000;
|
||
|
||
if ($this->ENCOURS>$plafond) $this->ENCOURS=$plafond;
|
||
|
||
// Plafond si encours estimé
|
||
if ($noteSolvabilite<50) $plafondEstime=$plafond/10;
|
||
else $plafondEstime=$plafond/25;
|
||
|
||
if ($encoursEstime>$plafondEstime) $encoursEstime=$plafondEstime;
|
||
|
||
// debugLog('I', "INDISCORE B $encoursIni $encoursEstime $encours", __LINE__, __FILE__, __FUNCTION__, __CLASS__);
|
||
|
||
// Si l'entreprise à moins de 12 mois, on divise son encours estimé par 2
|
||
if ($encoursEstime>0) {
|
||
$dateCre=$tabIdentite['DateCreaEn']*1;
|
||
if ($dateCre==0 || ( ($tabIdentite['DateCreaEt']*1)>0 && $dateCre>$tabIdentite['DateCreaEt']*1) ) {
|
||
$dateCre=$tabIdentite['DateCreaEt']*1;
|
||
}
|
||
if ($dateCre+10000>date('Ymd')*1) {
|
||
$encoursEstime=$encoursEstime/2;
|
||
$libEncours='Encours limité étant donné la jeunesse de la structure.';
|
||
}
|
||
}
|
||
|
||
// Si encours sans bilan, l'encours donné est la moyenne de l'encours capital + l'encours estimé
|
||
if ($encoursEstime > 0 && $this->ENCOURS > 0) {
|
||
$this->ENCOURS = ($this->ENCOURS + $encoursEstime) / 2;
|
||
}
|
||
// Si l'encours est forcé, on en tiens compte !
|
||
if ($encoursForce != null) {
|
||
$this->ENCOURS = $encoursForce;
|
||
}
|
||
|
||
switch ($this->FJUR2) {
|
||
case 11:
|
||
case 12:
|
||
case 13:
|
||
case 14:
|
||
case 15:
|
||
case 16:
|
||
case 19:
|
||
if ($this->ENCOURS == 0 && $this->ENCOURS <= 2000 && !$this->IMPAYE &&
|
||
!$this->PRIVILEGES && !$this->RISQUEGROUPE && !$this->DEFAUT &&
|
||
!$this->LCASSUR && $this->CSFACTO != 50 && !$this->RISQUEIMPAYE) {
|
||
$this->ENCOURS = $this->CAESTIME/36;
|
||
if ($noteSolvabilite >= 50 && $this->AGE >= 120) {
|
||
$plafond = 7000;
|
||
}
|
||
elseif ($noteSolvabilite >= 45 && $this->AGE >= 60) {
|
||
$plafond = 5000;
|
||
}
|
||
elseif ($noteSolvabilite >= 45 && $this->AGE >= 36) {
|
||
$plafond = 3000;
|
||
}
|
||
elseif ($noteSolvabilite >= 55) {
|
||
$plafond = 2000;
|
||
}
|
||
if ($this->DELAIPAY > $this->DELAIPAYp && $this->DELAIPAYp > 0 && $this->DELAIPAY <= 90) {
|
||
$plafond = $plafond/2;
|
||
}
|
||
/*elseif ($this->DELAIPAY > 90) {
|
||
$plafond = 0;
|
||
}*/
|
||
if ($this->ENCOURS > $plafond) {
|
||
$this->ENCOURS = $plafond;
|
||
}
|
||
}
|
||
break;
|
||
case 18: // Associé Gérant de société
|
||
case 27: // Paroisse hors zone concordataire
|
||
case 29: // Autre groupement de droit privé non doté de la personnalité morale
|
||
//case 31: // Personne morale de droit étranger, immatriculée au RCS
|
||
//case 32: // Personne morale de droit étranger, non immatriculée au RCS
|
||
$this->ENCOURS='N/A';
|
||
$libEncours='Il est préférable de demander un enquête commerciale sur cette entité.';
|
||
break;
|
||
case 81: // Organisme gérant un régime de protection sociale à adhésion obligatoire
|
||
case 82: // Organisme mutualiste
|
||
case 83: // Comité d'entreprise
|
||
case 84: // Organisme professionnel
|
||
case 91: // Syndicat de propriétaires
|
||
case 92: // Association loi 1901 ou assimilé
|
||
case 93: // Fondation
|
||
case 99: // Fondation
|
||
$tabTmp=$this->db->select('jo.asso_bilans', 'dateCloture, dateCloture*1 as dateClotureNum', "siren=$siren ORDER BY dateCloture DESC LIMIT 0,5", $this->debug, MYSQL_ASSOC);
|
||
$this->NBBILAN=count($tabTmp);
|
||
$this->BILANDATE=$tabTmp[0]['dateClotureNum'];
|
||
if ($this->BILANDATE>0 && $tabIdentite['SituationJuridique']=='' && $tabIdentite['Actif']==1) {
|
||
$this->BILAN=true;
|
||
if ($classWdate->nbMoisEntre($this->BILANDATE,date('Ymd'))>=24) $this->BILANVIEUX=true;
|
||
else $this->BILANVIEUX=false;
|
||
if ($classWdate->nbMoisEntre($this->BILANDATE,date('Ymd'))>=30) $this->BILANMANQUE=true;
|
||
else $this->BILANMANQUE=false;
|
||
$this->ENCOURS=$this->CAESTIME/72;
|
||
if ($noteSolvabilite>=40 && $this->ENCOURS<5000) $this->ENCOURS=5000;
|
||
if ($noteSolvabilite> 65) $plafond=200000;
|
||
elseif ($noteSolvabilite> 60) $plafond=150000;
|
||
elseif ($noteSolvabilite> 55) $plafond=100000;
|
||
elseif ($noteSolvabilite>=50) $plafond=50000;
|
||
elseif ($noteSolvabilite>=45) $plafond=10000;
|
||
else $plafond=5000;
|
||
if ($this->ENCOURS>$plafond) $this->ENCOURS=$plafond;
|
||
$libEncours='Il est préférable de demander un enquête commerciale sur les organisations, associations et fondations.';
|
||
} else {
|
||
$this->ENCOURSCALC=$this->ENCOURS;
|
||
$this->ENCOURS='N/A';
|
||
$libEncours='Il est préférable de demander un enquête commerciale sur les organisations, associations et fondations.';
|
||
}
|
||
break;
|
||
case 99: // Autre personne morale de droit privé
|
||
case 41: // Établissement public ou régie à caractère industriel ou commercial
|
||
case 71: // Administration de l'état
|
||
case 72: // Collectivité territoriale
|
||
case 73: // Établissement public administratif
|
||
case 74: // Autre personne morale de droit public administratif
|
||
$this->ENCOURSCALC=$this->ENCOURS;
|
||
$this->ENCOURS='N/A';
|
||
$libEncours='Aucun risque de défaillance sur les administrations ou institutions.';
|
||
break;
|
||
}
|
||
} else {
|
||
// Encours à 0 car score < 40
|
||
$this->ENCOURSCALC=$this->ENCOURS;
|
||
$this->ENCOURS=0;
|
||
$libEncours='Aucun encours conseillé par rapport à notre évaluation.';
|
||
}
|
||
|
||
/** Pondération de l'encours en fonction des informations de paiement GE **/
|
||
if ($this->ENCOURS<>'N/A' && $this->ENCOURS*1>0 && $nivRisquePaiement>0) {
|
||
$plafond=7500;
|
||
switch ($nivRisquePaiement) {
|
||
case 4: // Défaut avéré
|
||
$this->ENCOURS=0;
|
||
break;
|
||
case 3: // Impayés
|
||
if ($noteSolvabilite>=50 && $caEntrep>=3000000) $plafond=30000;
|
||
elseif ($noteSolvabilite>=50 && $caEntrep< 3000000) $plafond=20000;
|
||
elseif ($noteSolvabilite<50 && $caEntrep>=3000000) $plafond=10000;
|
||
else $plafond=7500;
|
||
|
||
break;
|
||
case 2: // Risque d'impayés
|
||
if ($noteSolvabilite>=50 && $caEntrep>=3000000) $plafond=65000;
|
||
elseif ($noteSolvabilite>=50 && $caEntrep< 3000000) $plafond=45000;
|
||
elseif ($noteSolvabilite<50 && $caEntrep>=3000000) $plafond=25000;
|
||
else $plafond=15000;
|
||
break;
|
||
case 1: // Fin d'activité
|
||
$this->ENCOURS=0;
|
||
break;
|
||
default: break;
|
||
}
|
||
if ($this->ENCOURS>$plafond) $this->ENCOURS=$plafond;
|
||
}
|
||
if ($tendance=='') $tendance='Stable';
|
||
|
||
/** Avis à 3 ans **/
|
||
if ($noteSolvabilite>=50) {
|
||
if ($valeurCCF>2160) $this->AVIS3ANS=true;
|
||
elseif($valeurCCF>0 && $valeurCCF<2160) $this->AVIS3ANS=false;
|
||
}
|
||
|
||
/** Etalonage pour l'indiscore sur 20 **/
|
||
if ($noteSolvabilite<5) $indiscore20=0;
|
||
elseif ($noteSolvabilite<20) $indiscore20=1;
|
||
elseif ($noteSolvabilite<30) $indiscore20=2;
|
||
elseif ($noteSolvabilite<35) $indiscore20=3;
|
||
elseif ($noteSolvabilite<36) $indiscore20=4;
|
||
elseif ($noteSolvabilite<39) $indiscore20=5;
|
||
elseif ($noteSolvabilite<41) $indiscore20=6;
|
||
elseif ($noteSolvabilite<45) $indiscore20=7;
|
||
elseif ($noteSolvabilite<46) $indiscore20=8;
|
||
elseif ($noteSolvabilite<50) $indiscore20=9;
|
||
elseif ($noteSolvabilite<51) $indiscore20=10;
|
||
elseif ($noteSolvabilite<55) $indiscore20=11;
|
||
elseif ($noteSolvabilite<57) $indiscore20=12;
|
||
elseif ($noteSolvabilite<60) $indiscore20=13;
|
||
elseif ($noteSolvabilite<62) $indiscore20=14;
|
||
elseif ($noteSolvabilite<65) $indiscore20=15;
|
||
elseif ($noteSolvabilite<69) $indiscore20=16;
|
||
elseif ($noteSolvabilite<73) $indiscore20=17;
|
||
elseif ($noteSolvabilite<80) $indiscore20=18;
|
||
else $indiscore20=19;
|
||
|
||
/** Classe de risque **/
|
||
if ($indiscore20>=15) $classeRisque=5;
|
||
elseif ($indiscore20>=12) $classeRisque=4;
|
||
elseif ($indiscore20>=10) $classeRisque=3;
|
||
elseif ($indiscore20>=8) $classeRisque=2;
|
||
else $classeRisque=1;
|
||
|
||
if ( ($this->ACTIFRNCS*1==0 && $this->ACTIFINSEE*1==0)
|
||
|| $tabIdentite['SituationJuridique'] == 'P'
|
||
|| $tabIdentite['SituationJuridique'] == 'PL')
|
||
$classeRisque=9;
|
||
elseif ($this->ENCOURS==='N/A') $classeRisque=8;
|
||
|
||
/** Fin note **/
|
||
$this->NOTE100=$noteSolvabilite; // Note finale sur 100
|
||
$this->NOTESBRUTE=$this->NOTE100; // Note du score sur 100 originale (de type bancaire)
|
||
$this->NOTESCORE=$noteFin*5; // Note du score financier sur 100
|
||
|
||
$timer['encours']=microtime(true);
|
||
|
||
// --- Si NIVEAU avec generation des commentaires
|
||
if ($genereComment)
|
||
{
|
||
// --- Grand Groupe
|
||
$tabTmp=$this->db->select('jo.surveillances_site', 'count(*) as nb',
|
||
"login IN ('dgfipb', 'dgfipc', 'dgfipifu1', 'dgfipifu10', 'dgfipifu11', 'dgfipifu12', 'dgfipifu13', 'dgfipifu14', 'dgfipifu2', 'dgfipifu3', 'dgfipifu4', 'dgfipifu5', 'dgfipifu6', 'dgfipifu7', 'dgfipifu8', 'dgfipifu9') AND siren=$siren AND dateSuppr=0",
|
||
$this->debug, MYSQL_ASSOC);
|
||
$timer['GrandGroupe'] = microtime(true);
|
||
$tabTmp=$tabTmp[0];
|
||
if ($tabTmp['nb']>0) $this->GRANDGROUPE = true;
|
||
else $this->GRANDGROUPE = false;
|
||
|
||
// NBNIC
|
||
$tabTmp = $this->db->select('jo.etablissements', 'MAX(NIC) as NBNIC', "SIREN=$this->SIREN", $this->debug, MYSQL_ASSOC);
|
||
$this->NBNIC = $tabTmp[0]['NBNIC'];
|
||
$timer['nbNic']=microtime(true);
|
||
|
||
if ($this->ANNONCEPC<>'') {
|
||
// Intervenants
|
||
$tabInter = $iRncs->getIntervenants($this->SIREN);
|
||
$this->ANNONCEPC_INT1_TIT=$tabInter[0]['admfonction']; // Titre de l'intervenant
|
||
$this->ANNONCEPC_INT1=$tabInter[0]['admnom']; // NOM Prénom et adresse complète
|
||
$this->ANNONCEPC_INT2_TIT=$tabInter[1]['admfonction'];
|
||
$this->ANNONCEPC_INT2=$tabInter[1]['admnom'];
|
||
/* ANNONCEPC_INT2 NOM Prénom et adresse complète
|
||
ANNONCEPC_INT2TIT Titre de l'intervenant n°2
|
||
'admadrNum', 'admadrInd', 'admadrVoie','admadrCP','admadrVille' */
|
||
}
|
||
$timer['intervenants']=microtime(true);
|
||
|
||
/** N° d'ordre de l'entreprise dans le classement des CA pour le marché de l'entreprise **/
|
||
$caTmp = round($this->CABIOUES,0);
|
||
$tabTmp = $this->db->select('jo.etablissements_act', 'count(*) AS nb', "siege=1 AND ape_entrep='$naf' AND bilFL>=$caTmp", $this->debug, MYSQL_ASSOC);
|
||
if (count($tabTmp) > 0) {
|
||
$this->MARCHEPLACE = $tabTmp[0]['nb']*1;
|
||
}
|
||
$tabTmp = $this->db->select('jo.etablissements_act', 'count(*) AS nb', "siege=1 AND ape_entrep='$naf' AND bilFL>=$caTmp AND adr_dep='".$tabIdentite['Dept']."'", $this->debug, MYSQL_ASSOC);
|
||
if (count($tabTmp) > 0) {
|
||
$this->MARCHEPLACE_DEP = $tabTmp[0]['nb']*1;
|
||
}
|
||
$tabTmp = $this->db->select('jo.etablissements_act', 'count(*) AS nb', "siege=1 AND ape_entrep='$naf' AND adr_dep='".$tabIdentite['Dept']."' AND adr_com=".$tabIdentite['codeCommune'], $this->debug, MYSQL_ASSOC);
|
||
if (count($tabTmp) > 0) {
|
||
$this->MARCHENBENT_VILLE = $tabTmp[0]['nb']*1;
|
||
}
|
||
$tabTmp = $this->db->select('jo.etablissements_act', 'count(*) AS nb', "siege=1 AND ape_entrep='$naf' AND adr_dep='".$tabIdentite['Dept']."'", $this->debug, MYSQL_ASSOC);
|
||
if (count($tabTmp) > 0) {
|
||
$this->MARCHENBENT_DEP = $tabTmp[0]['nb']*1;
|
||
}
|
||
$timer['marcheEntrepPosition']=microtime(true);
|
||
|
||
/** Liste des communes couvertes **/
|
||
$tabTmp = $this->db->select(
|
||
'jo.etablissements',
|
||
'siren, nic, adr_dep, adr_com',
|
||
"siren=$siren AND nic>0 AND actif=1 ORDER BY siege DESC, teff_etab DESC LIMIT 0,50",
|
||
$this->debug, MYSQL_ASSOC);
|
||
$tabCommunes=array();
|
||
foreach ($tabTmp as $iTmp=>$tabArret) {
|
||
$dep=$tabArret['adr_dep']*1;
|
||
$com=$tabArret['adr_com'];
|
||
if ($dep==20) {
|
||
$tabCommunes[]='20'.$com;
|
||
$tabCommunes[]='2A'.$com;
|
||
$tabCommunes[]='2B'.$com;
|
||
} elseif ($dep>96)
|
||
$tabCommunes[]=''.substr($tabArret['adr_dep'],0,2).$com;
|
||
elseif ($dep<10)
|
||
$tabCommunes[]='0'.$dep.$com;
|
||
else
|
||
$tabCommunes[]=''.$dep.$com;
|
||
}
|
||
$strCom=implode("','", $tabCommunes);
|
||
$timer['risquesCommunes']=microtime(true);
|
||
|
||
/** Liste des risques Géo **/
|
||
$this->RISQUEGEO_NB=0; // Nombre d'établissements concernés: neutraliser si >= 10
|
||
$this->RISQUEGEO=array();
|
||
$tabTmp=$this->db->select('pollutions.prim_Risques','libCommune, risque',
|
||
"codeInsee IN ('$strCom') ORDER BY risque", $this->debug, MYSQL_ASSOC);
|
||
foreach ($tabTmp as $iTmp=>$tabArret) {
|
||
$this->RISQUEGEO[]=$tabArret['risque']; // Libellé risque lié à la localisation l'un des etablissements (INNONDATION, TREMBLEMENT DE TERRE etc..)
|
||
$this->RISQUEGEO_NB++;
|
||
}
|
||
|
||
$this->RISQUEGEO=array_unique($this->RISQUEGEO);
|
||
$this->RISQUEGEO=implode(', ', $this->RISQUEGEO);
|
||
$timer['risquesGeo']=microtime(true);
|
||
|
||
/** Liste des arretes de cata **/
|
||
$this->RISQUEGEOARRETE_NB=0; // Nombre d'Arrété de catastrophe naturelle sur la commune de l'un des étab depuis 1982
|
||
$this->RISQUEGEOARRETE_VILLE=$this->RISQUEGEOARRETE=$this->RISQUEGEOARRETE_DATE=$this->RISQUEGEOARRETE_JODATE=$this->RISQUEGEOARRETE_EVTDATE=$this->RISQUEGEOARRETE_AA='';
|
||
$tabTmp=$this->db->select( 'pollutions.prim_Arrets',
|
||
'libCommune, risque, dateDeb, dateFin, dateArret, dateJO',
|
||
"codeInsee IN ('$strCom') ORDER BY dateFin DESC", $this->debug, MYSQL_ASSOC);
|
||
foreach ($tabTmp as $iTmp=>$tabArret) {
|
||
$this->RISQUEGEOARRETE_NB++;
|
||
if ($iTmp==0) {
|
||
$this->RISQUEGEOARRETE_VILLE=$tabArret['libCommune'];
|
||
$this->RISQUEGEOARRETE=$tabArret['risque']; // Plus récent Arrété de catastrophe naturelle sur la commune de l'un des étab
|
||
$this->RISQUEGEOARRETE_DATE=$tabArret['dateArret']; // DATE du plus récent Arrété de catastrophe naturelle sur la commune de l'un des étab
|
||
$this->RISQUEGEOARRETE_AA=substr($this->RISQUEGEOARRETE_DATE,0,4);
|
||
$this->RISQUEGEOARRETE_JODATE=$tabArret['dateJO']; // Date du JO Arrété de catastrophe naturelle sur la commune de l'un des étab
|
||
$this->RISQUEGEOARRETE_EVTDATE=$tabArret['dateDeb']; // Date de début de l'événement, cité dans l'Arrété de catastrophe naturelle sur la commune de l'un des étab
|
||
}
|
||
}
|
||
$timer['risquesArret']=microtime(true);
|
||
|
||
/** Liste des établissements polluants **/
|
||
$sirenDeb=$siren.'00000';
|
||
$sirenFin=$siren.'99999';
|
||
$tabTmp=$this->db->select(
|
||
'pollutions.iREP_etablissements e, pollutions.iREP_rejets_etablissements r',
|
||
'e.codecommune, e.nom, e.codesiret, e.idetab, r.idrejet, r.coderejet, r.libellerejet, r.codeouvragedepollution, r.codeentitehydro, r.nomstep, r.nommilieu',
|
||
"e.codesiret BETWEEN $sirenDeb AND $sirenFin AND e.idetab=r.idetab GROUP BY e.codesiret, r.libellerejet LIMIT 0,50", $this->debug, MYSQL_ASSOC);
|
||
// Nombre d'établissements concernés: neutraliser si >= 10
|
||
$this->RISQUEACT_NB=count($tabTmp);
|
||
$this->RISQUEACT=array();
|
||
foreach ($tabTmp as $iTmp=>$tabArret) {
|
||
$this->RISQUEACT[]=$tabArret['libellerejet']; // Libellé risque lié à la l'activité de l'un des etablissements "l'entreprise à au moins l'un de ses établissements figurant au registre francais des émissions polluantes" (AIR, EAU ou et SOL)
|
||
}
|
||
$this->RISQUEACT=array_unique($this->RISQUEACT);
|
||
$this->RISQUEACT=implode(', ', $this->RISQUEACT);
|
||
$timer['risquesPollu']=microtime(true);
|
||
|
||
/** Bassin hydro : Le ou les libellés des bassins hydrographiques concernés
|
||
**/
|
||
$tabTmp=$this->db->select('pollutions.bassins', 'codeBassin',
|
||
"codeInsee IN ('$strCom') GROUP BY codeBassin", $this->debug, MYSQL_ASSOC);
|
||
$this->RISQUEACTBASSIN=array();
|
||
$tabBassins=array(
|
||
'A' =>'Artois-Picardie', // 01 Escaut, Somme et cours d'eau côtiers de la Manche et Mer du Nord
|
||
'B1'=>'Meuse', // 02 La Meuse
|
||
'B2'=>'Sambre', // 02 La Sambre
|
||
'C'=>'Rhin', // 02 Le Rhin
|
||
'D'=>'Rhone-Méditerranée', // 06 Le Rhône et les cours d'eau côtiers méditeranéens
|
||
'E'=>'Corse', // 06 Les cours d'eau de la Corse
|
||
'F'=>'Adour-Garonne', // 05 La Garonne, l'Adour, la Dordogne, la Charente et les cours d'eau côtiers charentais et aquitains
|
||
'G'=>'Loire-Bretagne', // 04 La Loire, les cours d'eau côtiers vendéens et bretons
|
||
'H'=>'Seine-Normandie', // 03 La Seine et les cours d'eau côtiers normands
|
||
'I'=>'Guadeloupe', // 07 Les cours d'eau de la Guadeloupe
|
||
'J'=>'Martinique', // 08 Les cours d'eau de la Martinique
|
||
'K'=>'Guyane', // 09 Les fleuves et cours d'eau côtiers de la Guyane
|
||
'L'=>'Réunion', // 10 Les cours d'eau de la Réunion
|
||
'M'=>'Mayotte', // Les cours d'eau de Mayotte
|
||
);
|
||
|
||
foreach ($tabTmp as $iTmp=>$tabArret) {
|
||
$this->RISQUEACTBASSIN[]=$tabBassins[$tabArret['codeBassin']]; // Libellé risque lié à la localisation l'un des etablissements (INNONDATION, TREMBLEMENT DE TERRE etc..)
|
||
}
|
||
$this->RISQUEACTBASSIN=trim(implode(', ', $this->RISQUEACTBASSIN)); // Le ou les libellés des bassins hydrographiques concernés
|
||
$timer['risquesBassins']=microtime(true);
|
||
|
||
/** INFOS Orias **/
|
||
$iOrias = new Metier_Partenaires_MOrias(false, $this->db);
|
||
$tabTmp = $iOrias->getInfosOrias($this->SIREN);
|
||
$this->ORIASID=$this->ORIASCAT=$this->ORIASID_DATE='';
|
||
if (count($tabTmp)>0) {
|
||
$this->ORIASID=$tabTmp['numOrias'];
|
||
$this->ORIASCAT='';
|
||
$this->ORIASID_DATE='';
|
||
foreach ($tabTmp['categories'] as $tabTmp) {
|
||
$this->ORIASCAT.=$tabTmp['categorie'].', ';
|
||
// On prend la première date
|
||
if ($this->ORIASID_DATE=='') $this->ORIASID_DATE=$tabTmp['dateInscription'];
|
||
}
|
||
$this->ORIASCAT=preg_replace('/, $/','', $this->ORIASCAT);
|
||
}
|
||
$timer['orias']=microtime(true);
|
||
|
||
/** Liste des marques **/
|
||
$this->MARQUENB_INT=0; // Nombre de marques déposées à l'international
|
||
$this->MARQUENB_EUR=0; // Nombre de marques déposées en EUROPE
|
||
$this->MARQUENB_FR=0; // Nombre de marques déposées en FRANCE
|
||
$tabMarques['WW']=$tabMarques['EU']=$tabMarques['FR']=array();
|
||
$iMarque = new Metier_Partenaires_MMarques($this->db);
|
||
$ret = $iMarque->getMarques($siren);
|
||
if ($ret!==false && count($ret)>0) {
|
||
foreach ($ret as $i=>$marque) {
|
||
switch ($marque['rayonMarque']) {
|
||
case 'Marque communautaire':
|
||
$this->MARQUENB_EUR++;
|
||
if ($this->MARQUENB_EUR<11 && $marque['nomMarque']<>'(figurative)') $tabMarques['EU'][]=$marque['nomMarque'];
|
||
break;
|
||
case 'Marque française':
|
||
$this->MARQUENB_FR++;
|
||
if ($this->MARQUENB_FR<11 && $marque['nomMarque']<>'(figurative)') $tabMarques['FR'][]=$marque['nomMarque'];
|
||
break;
|
||
case 'Marque internationale':
|
||
$this->MARQUENB_INT++;
|
||
if ($this->MARQUENB_INT<11 && $marque['nomMarque']<>'(figurative)') $tabMarques['WW'][]=$marque['nomMarque'];
|
||
break;
|
||
}
|
||
}
|
||
}
|
||
$this->MARQUENB=$this->MARQUENB_EUR+$this->MARQUENB_FR+$this->MARQUENB_INT; // Nombre de marques déposées en tout
|
||
$this->MARQUELISTE_INT=implode(', ', $tabMarques['WW']); // Liste en ligne des 10 dernières marques déposées à l'internationale séparées par des virgules
|
||
$this->MARQUELISTE_EUR=implode(', ', $tabMarques['EU']); // Liste en ligne des 10 dernières marques déposées à l'europe séparées par des virgules
|
||
$this->MARQUELISTE_FR =implode(', ', $tabMarques['FR']); // Liste en ligne des 10 dernières marques déposées à la France séparées par des virgules
|
||
$timer['marques']=microtime(true);
|
||
|
||
/** Marchés publics **/
|
||
$this->MARCHEPUBLIC3_NB=0; // Nombre de marchés public / 3 dernières années
|
||
$this->MARCHEPUBLIC3_MT=0; // Montant cumulé des marchés public / 3 dernières années
|
||
$this->MARCHEPUBLICDER_OBJ=''; // Objet du dernier MP remporté
|
||
$this->MARCHEPUBLICDER_CLI=''; // Nom complet de l'acheteur du dernier MP
|
||
$this->MARCHEPUBLICDER_MT=false; // Montant
|
||
$this->MARCHEPUBLICDER_ANNEE=0; // Année du dernier marché public remporté
|
||
$this->MARCHEPUBLICDER_DATE=0; // Date du dernier marché public remporté
|
||
$ret=$iInsee->getAnnoncesBoamp($siren);
|
||
if (count($ret)>0) {
|
||
foreach ($ret as $i=>$mp) {
|
||
if (substr($mp['id'],0,1)=='A' || $mp['BodaccCode']=='BOMP C') {
|
||
if ($this->MARCHEPUBLICDER_MT===false) {
|
||
$this->MARCHEPUBLICDER_MT =$mp['Montant'];
|
||
$this->MARCHEPUBLICDER_CLI=$mp['Organisme'];
|
||
$this->MARCHEPUBLICDER_OBJ=$mp['Objet'];
|
||
$this->MARCHEPUBLICDER_ANNEE=substr($mp['DateParution'],0,4)*1;
|
||
$this->MARCHEPUBLICDER_DATE=$mp['DateParution'];
|
||
}
|
||
if (substr($mp['DateParution'],0,4)*1>=$this->ANNEEp3) {
|
||
$this->MARCHEPUBLIC3_NB++;
|
||
$this->MARCHEPUBLIC3_MT+=$mp['Montant'];
|
||
}
|
||
}
|
||
}
|
||
}
|
||
// % du CA du dernier Bilan de la moyenne des 3 dernières années de MP
|
||
$this->MARCHEPUBLIC3_POURC=($this->MARCHEPUBLIC3_MT*100)/$this->CABIOUES;
|
||
$timer['marchesPublics']=microtime(true);
|
||
|
||
/** Recherche de Franchise si enseigne **/
|
||
$this->FRANCHISE='';
|
||
if ($this->ENSEIGNE<>'') {
|
||
$tmp=addslashes($this->ENSEIGNE);
|
||
$tabTmp=$this->db->select( 'sdv1.franchiseurs',
|
||
"id, enseigne, MATCH (enseigne) AGAINST ('$tmp') as score",
|
||
"MATCH (enseigne) AGAINST ('$tmp')
|
||
HAVING score>1 ORDER BY score DESC", $this->debug, MYSQL_ASSOC);
|
||
// Nombre d'établissements concernés: neutraliser si >= 10
|
||
foreach ($tabTmp as $iTmp=>$tabArret) {
|
||
$lev=levenshtein(strtoupper($this->ENSEIGNE), strtoupper($tabArret['enseigne']));
|
||
if ($lev<7) {
|
||
$this->FRANCHISE=$tabArret['enseigne'].' ('.$tabArret['score']." / $lev)"; // Nom du réseau des franchisés
|
||
break;
|
||
}
|
||
}
|
||
}
|
||
|
||
/** Population commune **/
|
||
$codeCommuneInsee=$tabIdentite['Dept'].$tabIdentite['codeCommune'];
|
||
$tabTmp = $this->db->select(
|
||
'insee.insee_tabVilles', 'Pop_mun_2007, popMunZFU, popMunZUS',
|
||
"CODGEO='$codeCommuneInsee'", $this->debug, MYSQL_ASSOC
|
||
);
|
||
// Nombre d'habitants de la commune du siège
|
||
$this->POPULATION = (is_array($tabTmp) && count($tabTmp)>0) ? $tabTmp[0]['Pop_mun_2007'] : null ;
|
||
// % d'effectif salarié sur la population communale
|
||
if (!empty($this->POPULATION)){
|
||
$this->EFFECTIF_POPU=($this->EFFECTIF/$this->POPULATION)*100;
|
||
} else {
|
||
$this->EFFECTIF_POPU = null;
|
||
}
|
||
|
||
// On filtre les ventes sur les entit<69>s similaires en terme de CA et effectif
|
||
$filtreCAEff="";
|
||
if ($tabIdentite['TrancheCA']*1==0) {
|
||
$filtreCAEff.=" AND (v.tca=0 OR v.tca IS NULL) ";
|
||
} else {
|
||
$filtreCAEff.=" AND v.tca=".$tabIdentite['TrancheCA'].' ';
|
||
}
|
||
|
||
if ($tabIdentite['EffEnTr']*1==0) {
|
||
$filtreCAEff.=" AND (v.teffEn=0 OR v.teffEn IS NULL) ";
|
||
} else {
|
||
$filtreCAEff.=" AND v.teffEn=".$tabIdentite['EffEnTr'].' ';
|
||
}
|
||
|
||
/** Ventes par villes, départements et France **/
|
||
// Attention, arrondissements pour Paris, Lyon & Marseille
|
||
//if ($codeCommuneInsee>=75000 && $codeCommuneInsee<76000)
|
||
$this->VILLE=$tabIdentite['Ville']; // Ville ou ville + arrondissement de l'entreprise
|
||
$ya2ans=$this->ANNEEp2.'-'.date('m-d');
|
||
$ret = $this->db->query("SELECT MIN(b.VenteMt) AS vtMin, AVG(b.VenteMt) AS vtMoy, MAX(b.VenteMt) AS vtMax, COUNT(b.id) AS vtNb
|
||
FROM (
|
||
SELECT v.id, v.VenteMt
|
||
FROM jo.scores_ventes v
|
||
WHERE v.nafEn LIKE '$this->APEENT'
|
||
AND v.codeCommune LIKE '$codeCommuneInsee'
|
||
AND v.Bodacc_Date_Parution>='$ya2ans'
|
||
AND v.VenteMt>1 AND v.VenteDev='EUR' $filtreCAEff
|
||
GROUP BY v.id)b");
|
||
if (count($ret)>0) {
|
||
while($ret=$this->db->fetch(MYSQL_ASSOC)) {
|
||
$this->VENTEMAX_MT = $this->VENTEMAX_VILLE_MT = $this->VENTEMAX_VILLE_EU = $ret['vtMax']; // Plus grand montant de vente annonce VC niveau "ville"
|
||
$this->VENTEMOY_VILLE_MT = $this->VENTEMOY_VILLE_EU = $ret['vtMoy'];
|
||
$this->VENTEMIN_MT = $this->VENTEMIN_VILLE_MT = $this->VENTEMIN_VILLE_EU = $ret['vtMin']; // Plus petit montant de vente annonce VC niveau "ville"
|
||
$this->VENTE_NB = $this->VENTE_VILLE_NB = $ret['vtNb']; // Nombre de ventes dans le niveau statistique "ville" dans les 24 derniers mois
|
||
}
|
||
}
|
||
// Par département
|
||
$this->DEPARTEMENT=$iInsee->getDepartement($tabIdentite['Dept']);
|
||
$this->DEPARTEMENT_DE=$iInsee->getDepartement($tabIdentite['Dept'], true);
|
||
$ret=$this->db->query("SELECT MIN(b.VenteMt) AS vtMin, AVG(b.VenteMt) AS vtMoy, MAX(b.VenteMt) AS vtMax, COUNT(b.id) AS vtNb
|
||
FROM (
|
||
SELECT v.id, v.VenteMt
|
||
FROM jo.scores_ventes v
|
||
WHERE v.nafEn LIKE '$this->APEENT'
|
||
AND v.codeCommune LIKE '".$tabIdentite['Dept']."%'
|
||
AND v.Bodacc_Date_Parution>='$ya2ans'
|
||
AND v.VenteMt>1 AND v.VenteDev='EUR' $filtreCAEff
|
||
GROUP BY v.id)b");
|
||
while($ret=$this->db->fetch(MYSQL_ASSOC)) {
|
||
$this->VENTEMAX_DEP_MT = $this->VENTEMAX_DEP_EU = $ret['vtMax']; // Plus grand montant de vente annonce VC niveau "ville"
|
||
$this->VENTEMOY_DEP_MT = $this->VENTEMOY_DEP_EU = $ret['vtMoy'];
|
||
$this->VENTEMIN_DEP_MT = $this->VENTEMIN_DEP_EU = $ret['vtMin']; // Plus petit montant de vente annonce VC niveau "ville"
|
||
$this->VENTE_DEP_NB = $ret['vtNb']; // Nombre de ventes dans le niveau statistique "ville" dans les 24 derniers mois
|
||
}
|
||
// France entière
|
||
$ret=$this->db->query("SELECT MIN(b.VenteMt) AS vtMin, AVG(b.VenteMt) AS vtMoy, MAX(b.VenteMt) AS vtMax, COUNT(b.id) AS vtNb
|
||
FROM (
|
||
SELECT v.id, v.VenteMt
|
||
FROM jo.scores_ventes v
|
||
WHERE v.nafEn LIKE '$this->APEENT'
|
||
AND v.Bodacc_Date_Parution>='$ya2ans'
|
||
AND v.VenteMt>1 AND v.VenteDev='EUR' $filtreCAEff
|
||
GROUP BY v.id)b");
|
||
while($ret=$this->db->fetch(MYSQL_ASSOC)) {
|
||
$this->VENTEMAX_FRA_MT = $this->VENTEMAX_FRA_EU = $ret['vtMax']; // Plus grand montant de vente annonce VC niveau "ville"
|
||
$this->VENTEMOY_FRA_MT = $this->VENTEMOY_FRA_EU = $ret['vtMoy'];
|
||
$this->VENTEMIN_FRA_MT = $this->VENTEMIN_FRA_EU = $ret['vtMin']; // Plus petit montant de vente annonce VC niveau "ville"
|
||
$this->VENTE_FRA_NB = $ret['vtNb']; // Nombre de ventes dans le niveau statistique "ville" dans les 24 derniers mois
|
||
}
|
||
$timer['ventes']=microtime(true);
|
||
|
||
/** Cadastre **/
|
||
$this->CADBAT_NB_TOT=0; // nombre de postes BATIMENT du SIREN toutes adresses
|
||
$this->CADTER_NB_TOT=0; // nombre de postes TERRAIN du SIREN toutes adresses
|
||
$this->CADBAT_NB_PROP=0; // nombre de postes BATIMENT à l'adresse dont elle est propriétaire
|
||
$this->CADTER_NB_PROP=0; // nombre de postes TERRAIN à l'adresse dont elle est propriétaire
|
||
$this->CADBAT_NB_NONPROP=0; // nombre de postes BATIMENT à l'adresse dont elle n'est pas propriétaire
|
||
$this->CADTER_NB_NONPROP=0; // nombre de postes TERRAINS à l'adresse dont elle n'est pas propriétaire
|
||
$this->CADBAT_SURF_TOT=0; // Surface totale des batiments du SIREN
|
||
$this->CADTER_SURF_TOT=0; // Surface totale des terrains du SIREN
|
||
/**
|
||
@todo
|
||
$CADBAT_SURF_CUM=0; // Cumul Surfaces des batiments à l'addresse
|
||
$CADTER_SURF_CUM=0; // Cumul Surfaces des terrains à l'addresse
|
||
*/
|
||
// Locaux
|
||
$iCadastre = new Metier_Partenaires_MCadastre($this->db);
|
||
$tabTmp=$iCadastre->getLocaux($siren);
|
||
if(count($tabTmp)>0 ) {
|
||
foreach ($tabTmp as $iTmp=>$cad) {
|
||
$this->CADBAT_NB_TOT++;
|
||
if ($cad['localDroit']=='P') $this->CADBAT_NB_PROP++;
|
||
else $this->CADBAT_NB_NONPROP++;
|
||
$this->CADBAT_SURF_TOT+=$cad['localSurface'];
|
||
}
|
||
}
|
||
// Parcelles
|
||
$tabTmp = $iCadastre->getParcelles($siren);
|
||
foreach ($tabTmp as $iTmp=>$cad) {
|
||
$this->CADTER_NB_TOT++;
|
||
if ($cad['parcelDroit']=='P') $this->CADTER_NB_PROP++;
|
||
else $this->CADTER_NB_NONPROP++;
|
||
$this->CADTER_SURF_TOT+=$cad['parcelSurface'];
|
||
}
|
||
$timer['cadastre']=microtime(true);
|
||
|
||
/** RPS : Entreprise avec négociations ou accord sur les RPS ? **/
|
||
$tabTmp = $this->db->select(
|
||
'sdv1.gouv_rps',
|
||
'idfent, dateMAJ, negotiations, nbreunions, accordsigne, accorddate, absenceEchec',
|
||
"siren='$this->SIREN'", $this->debug, MYSQL_ASSOC
|
||
);
|
||
if (isset($tabTmp[0]) && $tabTmp[0]['idfent']>0) {
|
||
$this->RPS_NEGO=$this->RPS_PLAN=false;
|
||
// Date de dernière MAJ dans le répertoire RPS
|
||
$this->RPS_INFODATE=$tabTmp[0]['dateMAJ'];
|
||
// Négotiations
|
||
if ($tabTmp[0]['negotiations']=='oui') $this->RPS_NEGO=true;
|
||
// Date de signature de l'accord des RPS qui peut être à 0
|
||
$this->RPS_ACCORDDATE=$tabTmp[0]['accorddate'];
|
||
// Présence du libellé Plan d'action
|
||
if (!$this->RPS_NEGO && $this->RPS_ACCORDDATE*1==0) $this->RPS_PLAN=true;
|
||
}
|
||
|
||
/** Recherche de la liste des Produits / NAF **/
|
||
$this->LISTEPRODUIT=implode(', ', $iInsee->listeProduits($naf));
|
||
|
||
/** Taux de défaillance secteur **/
|
||
// Nb Entrep actives
|
||
$tabTmp=$this->db->select(
|
||
'jo.scores_secteurs',"sum(nbEntrep) AS nb",
|
||
"annee=YEAR(NOW()) AND mois=MONTH(NOW())", $this->debug, MYSQL_ASSOC
|
||
);
|
||
$nbEntrep=$tabTmp[0]['nb'];
|
||
// Nb en défaut sur 12 mois glissant
|
||
$tabTmp=$this->db->select(
|
||
'jo.scores_secteurs',
|
||
"sum(nbProcol) AS nb",
|
||
"annee=YEAR(NOW())-1 AND mois>=MONTH(NOW()) OR annee=YEAR(NOW())",
|
||
$this->debug, MYSQL_ASSOC
|
||
);
|
||
$nbEntrepProcol=$tabTmp[0]['nb'];
|
||
// Nb en défaut sur 12 mois glissant
|
||
$tabTmp=$this->db->select(
|
||
'jo.scores_secteurs',
|
||
"MAX(nbEntrep) as nbSecteur, SUM(nbProcol) AS nb",
|
||
"naf5='$this->APEENT' AND (annee=YEAR(NOW())-1 AND mois>=MONTH(NOW()) OR annee=YEAR(NOW()))",
|
||
$this->debug, MYSQL_ASSOC
|
||
);
|
||
$nbEntrepSecteur=$tabTmp[0]['nbSecteur'];
|
||
$nbEntrepSecteurProcol=$tabTmp[0]['nb'];
|
||
|
||
$txDefautTotal=$nbEntrepProcol/$nbEntrep;
|
||
$txDefautSecteur=$nbEntrepSecteurProcol/$nbEntrepSecteur;
|
||
$this->NOTEDEFSEC=round(50+(1-($txDefautSecteur/$txDefautTotal))*50);
|
||
if ($this->NOTEDEFSEC>100) $this->NOTEDEFSEC=100;
|
||
elseif ($this->NOTEDEFSEC<50)
|
||
$this->NOTEDEFSEC=round(50+(1-($txDefautSecteur/$txDefautTotal))*10);
|
||
if ($this->NOTEDEFSEC<0) $this->NOTEDEFSEC=0;
|
||
|
||
/** Date de cessation des paiements et dernier numéro de jugement **/
|
||
$tabTmp=$this->db->select(
|
||
'jo.annonces',
|
||
"MIN(dateCessationPaiement) AS cessPai, MAX(numero) AS numPC",
|
||
"siren=$siren", $this->debug, MYSQL_ASSOC
|
||
);
|
||
|
||
$this->ANNONCEPC_CESDATE=$tabTmp[0]['cessPai'];
|
||
$this->ANNONCEPC_NUM=$tabTmp[0]['numPC'];
|
||
|
||
/** Activite réglementée **/
|
||
$this->ACTIVREG='';
|
||
$tabTmp=$iInsee->getActivite($siren, $nic);
|
||
if ($tabTmp)
|
||
$this->ACTIVREG=$tabTmp['libActivite']; // Libellé de l'activité règlementé
|
||
|
||
$this->NBSUIVICLI=0; // Nombre de clients suivants cette entreprise
|
||
$this->NBSOCSEC=0; // Nombre de siren composants les ratios secteurs
|
||
$this->NBSOCSECPUB=0; // Nombre de siren du secteurs devant publier
|
||
|
||
$this->NBINTERRO1=0;
|
||
$this->NBINTERRO3=0;
|
||
$this->NBINTERRO6=0;
|
||
$this->NBINTERRO12=0;
|
||
|
||
|
||
if ( $type == 'valo' ) {
|
||
|
||
$tabTxRendObli = $this->getTxRendement(date('Y'));
|
||
$this->TAUXRA = $tabTxRendObli;
|
||
|
||
/** Tableau des taux de rendement **/
|
||
$tabTmp=$tabTxRendObli;
|
||
krsort($tabTmp);
|
||
foreach ($tabTmp as $iTmp=>$tabTmp2) {
|
||
if ($iTmp==0) { $tmpTxN=$tabTmp2; }
|
||
elseif ($iTmp==1) { $tmpTxN1=$tabTmp2; $this->TAUXRAMOY1=($tmpTxN+$tabTmp2)/2; }
|
||
elseif ($iTmp==2) { $tmpTxN2=$tabTmp2; $this->TAUXRAMOY2=($tmpTxN+$tmpTxN1+$tabTmp2)/3; }
|
||
elseif ($iTmp==3) { $this->TAUXRAMOY3=($tmpTxN+$tmpTxN1+$tmpTxN2+$tabTmp2)/4; }
|
||
}
|
||
|
||
$this->VALCOEFMINCA=0;
|
||
$this->VALCOEFMAXCA=0;
|
||
$naf2=substr($this->APEENT,0,2);
|
||
$naf3=substr($this->APEENT,0,3);
|
||
$naf4=substr($this->APEENT,0,4);
|
||
$tabTmp=$this->db->select('jo.tabNafValo', 'naf5, MINI, MAXI, TYPE, LENGTH(naf5) AS naf5len',
|
||
"naf5 LIKE '$naf2%' OR naf5 LIKE '$naf3%' OR naf5 LIKE '$naf4%' OR naf5='$this->APEENT' ORDER BY naf5len DESC LIMIT 0,1", $this->debug, MYSQL_ASSOC);
|
||
// On prend le 1er secteur trouvé le + précis
|
||
if (count($tabTmp) > 0) {
|
||
$tabTmp=$tabTmp[0];
|
||
$this->VALCOEFMINCA=$tabTmp['MINI'];
|
||
$this->VALCOEFMAXCA=$tabTmp['MAXI'];
|
||
}
|
||
}
|
||
|
||
//Chargement des phrases de commentaires - @todo : mettre en valeur de config
|
||
$tabCommentaires = $tabTriAff = array();
|
||
switch( $type ) {
|
||
case 'scores':
|
||
$version = '414';
|
||
$tabCommentaires = include __DIR__ . '/Comment/ScoreTxt'.$version.'N'.$this->NIVEAU.'.php';
|
||
$tabTriAff = include __DIR__ . '/Comment/ScoreTri'.$version.'N'.$NIVEAU.'.php';
|
||
require_once 'Metier/scores/Formule/Score_'.$version.'.php';
|
||
break;
|
||
case 'valo':
|
||
$version = 'v209';
|
||
$tabCommentaires = include __DIR__ . '/Comment/ValoTxt'.$version.'N'.$this->NIVEAU.'.php';
|
||
$tabTriAff = include __DIR__ . '/Comment/ValoTri'.$version.'N'.$this->NIVEAU.'.php';
|
||
require_once 'Metier/scores/Formule/Valo_'.$version.'.php';
|
||
break;
|
||
}
|
||
|
||
asort($tabTriAff);
|
||
$tabCommentairesATrier=array();
|
||
$timer['calculcommentaires']=microtime(true);
|
||
$numC=0;
|
||
foreach ($C as $idx=>$value) {
|
||
$numC++;
|
||
if ($value) {
|
||
$commentaires=@implode('<br/>',$tabCommentaires[$idx]);
|
||
$commentaires=preg_replace('/\[0+/', '[', $commentaires);
|
||
|
||
if($this->debug) {
|
||
file_put_contents(LOG_PATH.'/debugFmt.log', date("Y/m/d H:i:s")." - formule 0=$idx : $commentaires\n", FILE_APPEND);
|
||
if ( preg_match_all('/(\{.*\})/Us', $commentaires, $tabTmp) ) {
|
||
foreach ($tabTmp[1] as $valeur) {
|
||
$valeur2=strtr($valeur, array('{'=>'', '}'=>''));
|
||
file_put_contents(LOG_PATH.'/debugFmt.log', date("Y/m/d H:i:s")." - formule A=$idx : $valeur\n", FILE_APPEND);
|
||
}
|
||
}
|
||
}
|
||
|
||
$strCommentaire=strtr(preg_replace_callback('/(\{.*\})/U', array($this,'format'), $commentaires), array('"'=>'\''));
|
||
|
||
// Gestion de la balise <Dxx> signifiant un espacement obligatoire de xx
|
||
if (preg_match('/\<D(\d+)\>/Ui', $strCommentaire, $matches)){
|
||
$strCommentaire=str_repeat('_', $matches[1]).preg_match('/\<D(\d+)\>/', '', $strCommentaire);
|
||
}
|
||
/*if (preg_match('/\<li\+\>(.*)$/Ui', $strCommentaire, $matches))
|
||
$strCommentaire='+ '.$matches[1];
|
||
elseif (preg_match('/\<li\-\>(.*)$/Ui', $strCommentaire, $matches))
|
||
$strCommentaire='- '.$matches[1];
|
||
elseif (preg_match('/\<li>(.*)$/Ui', $strCommentaire, $matches))
|
||
$strCommentaire='* '.$matches[1];*/
|
||
// Gestion de la balise <C> pour concaténation à la ligne précédente
|
||
if (preg_match('/\<href\>(.*)$/Ui', $strCommentaire, $matches))
|
||
$strCommentaire=$matches[1];
|
||
if (preg_match('/^\<C\.\>(.*)$/', trim($strCommentaire), $matches2)) {
|
||
if (substr(trim($tabCommentairesATrier[$idxPre]),-1)=='.')
|
||
$tabCommentairesATrier[$idxPre]=substr(trim($tabCommentairesATrier[$idxPre]),0,-1).//' '.
|
||
$matches2[1];
|
||
else
|
||
$tabCommentairesATrier[$idxPre].=$matches2[1];
|
||
}
|
||
elseif (preg_match('/^\<C\:\>(.*)$/', trim($strCommentaire), $matches2)) {
|
||
if (substr(trim($tabCommentairesATrier[$idxPre]),-1)==':')
|
||
$tabCommentairesATrier[$idxPre]=substr(trim($tabCommentairesATrier[$idxPre]),0,-1).//' '.
|
||
$matches2[1];
|
||
else
|
||
$tabCommentairesATrier[$idxPre].=$matches2[1];
|
||
}
|
||
elseif (preg_match('/^\<C;\>(.*)$/', trim($strCommentaire), $matches2)) {
|
||
if (substr(trim($tabCommentairesATrier[$idxPre]),-1)==';')
|
||
$tabCommentairesATrier[$idxPre]=substr(trim($tabCommentairesATrier[$idxPre]),0,-1).//' '.
|
||
$matches2[1];
|
||
else
|
||
$tabCommentairesATrier[$idxPre].=$matches2[1];
|
||
}
|
||
elseif (preg_match('/^\<C,\>(.*)$/', trim($strCommentaire), $matches2)) {
|
||
if (substr(trim($tabCommentairesATrier[$idxPre]),-1)==',')
|
||
$tabCommentairesATrier[$idxPre]=substr(trim($tabCommentairesATrier[$idxPre]),0,-1).//' '.
|
||
$matches2[1];
|
||
else
|
||
$tabCommentairesATrier[$idxPre].=$matches2[1];
|
||
}
|
||
elseif (preg_match('/^\<C\>(.*)$/', trim($strCommentaire), $matches2))
|
||
$tabCommentairesATrier[$idxPre].=$matches2[1];
|
||
else {
|
||
$tabCommentairesATrier[$idx]=$strCommentaire;
|
||
$idxPre=$idx;
|
||
}
|
||
}
|
||
}
|
||
|
||
//echo '<hr/>';
|
||
$tabComment=array();
|
||
$tableau=false;
|
||
foreach ($tabTriAff as $idxC=>$ordre) {
|
||
$idxC=floor($idxC);
|
||
if (isset($tabCommentairesATrier[$idxC])) {
|
||
//echo "<b>$idxC</b>";
|
||
// Gérer les parenthèses
|
||
//$strTmp2=strtr($tabCommentairesATrier[$idxC], array('(4)'=>''));
|
||
$strTmp2=$tabCommentairesATrier[$idxC];
|
||
$debLigne=$finLigne='';
|
||
if (preg_match('/(<table|<tr|<th|<td)/i', $strTmp2)) {
|
||
$strTmp2=strtr($strTmp2, array('<br/>'=>'','<br>'=>'','<BR/>'=>'','<BR>'=>''));
|
||
$tableau=true;
|
||
} else {
|
||
$tableau=false;
|
||
if ($tableauPre) $debLigne.='</table>';
|
||
}
|
||
if (preg_match('/<i>(.*)/Uis', $strTmp2, $matchesTmp)) {
|
||
if (!preg_match('/<\/i>/Uis', $matchesTmp[1]))
|
||
// Il manque la fin de l'italique
|
||
$finLigne.='</i>';
|
||
}
|
||
|
||
if (preg_match('/<h(\d)>(.*)($|<br\/>.*$)/Uis', $strTmp2, $matchesTmp)) {
|
||
$nivH=$matchesTmp[1];
|
||
$strTmp2="<h$nivH>".$matchesTmp[2]."</h$nivH>".$matchesTmp[3];
|
||
}
|
||
if (preg_match('/^(.*)\{GRAPH\((.*)\)\}(.*)$/Uis', $strTmp2, $matchesTmp)) {
|
||
$strTmp='ERREUR DE FORMULE LORS DE LA GENERATION DU GRAPHIQUE no '.$idxC;
|
||
$strTmp2=trim(str_replace('$','',$matchesTmp[1]))."[GRAPHIQUE id=$idxC titre=".$matchesTmp[2].']'.trim($matchesTmp[3]);
|
||
// $matchesTmp[3];
|
||
//{GRAPH("Marge brute d'exploitation/secteur",R[506]#H,Rs[506]#H)}
|
||
} else
|
||
$strTmp='ERREUR DE FORMULE LORS DE LA GENERATION DU COMMENTAIRE no '.$idxC;
|
||
|
||
//@eval('\$strTmp="'.$strTmp2.'";');
|
||
$strTmp=eval("return \"$strTmp2\";");
|
||
|
||
$tabComment[$idxC]=preg_replace('/<\/i>(?:<br\/>)<\/i>/i','</i>', $debLigne.prepareString($strTmp).$finLigne);//." ($idxC, $ordre)";
|
||
if (substr($strTmp,0,17)=='ERREUR DE FORMULE') {
|
||
|
||
}
|
||
// echo " ($ordre)<br/>";
|
||
$tableauPre=$tableau;
|
||
}
|
||
}
|
||
// Si le dernier commentaire est une fin de tableau, on gère le cas !
|
||
if ($tableau) $tabComment[$idxC].='</table>';
|
||
|
||
$timer['finIndiscore']=microtime(true);
|
||
|
||
} // Fin Génération des commentaires
|
||
|
||
if($this->debug) {
|
||
|
||
$variables="\n\$NIVEAU=$this->NIVEAU\n\$numBil=$numBil\n\$noteSD=$noteSD\n\t-----\n";
|
||
|
||
foreach ($tabVar as $var)
|
||
{
|
||
if (isset(${$var})) {
|
||
if (is_array(${$var})) {
|
||
$variables.="$var=".print_r(${$var}).EOL;
|
||
} else {
|
||
$variables.="$var='${$var}'".EOL;
|
||
}
|
||
}
|
||
else {
|
||
$variables.="$var='${$var}' NON DEFINIE !!!".EOL;
|
||
}
|
||
}
|
||
|
||
file_put_contents($this->SIREN.'_'.$type.'.log',
|
||
"Indiscore sur $siren : Commentaires".EOL.
|
||
"Liste des variables :\n$variables".EOL.
|
||
'CA_COEF='.$this->CA_COEF.EOL.
|
||
'CA_Y='.print_r($this->CA_Y,true).EOL.EOL.
|
||
'RCAI_COEF='.$this->RCAI_COEF.EOL.
|
||
'RCAI_Y='.print_r($this->RCAI_Y,true).EOL.
|
||
"PROJECCOEF=$this->PROJECCOEF".EOL.
|
||
"PROJECTAUX=$this->PROJECTAUX".EOL.
|
||
"Y=".print_r($this->Y,true).EOL.
|
||
"Yaff=".print_r($this->Yaff,true).EOL.
|
||
"tabRegX=".print_r($this->tabRegX,true).EOL.
|
||
print_r($tabComment, true).EOL.
|
||
"Liste des commentaires a trier :\n".print_r($tabCommentairesATrier,true).EOL.
|
||
"Tableau des codes de tri pour calcul :\n".print_r($tabTri,true).EOL.
|
||
"Tableau des codes de tri pour affichage :\n".print_r($tabTriAff,true).EOL.
|
||
$debugFormule.EOL.'-----------------------'.EOL.
|
||
"Liste des Bilans :\n".print_r($tabBilans, true).EOL.
|
||
"tabBil=".print_r($tabBil,true).EOL.
|
||
"Liste des Ratios :\n".print_r($tabRatios, true).EOL.
|
||
"Liste des ratios Evolutions :\n". print_r($tabRatiosEvol, true).EOL
|
||
);
|
||
|
||
$i=0; $strTime='';
|
||
foreach ($timer as $lib=>$time) {
|
||
$strTime.="$lib : ";
|
||
$duree=round($time-$timePre,3);
|
||
if ($i==0) { $strTime.="0 s"; $timeDeb=$time; }
|
||
else $strTime.="$duree s";
|
||
$strTime.="\n";
|
||
$timePre=$time;
|
||
$i++;
|
||
}
|
||
$duree=round($time-$timeDeb,3);
|
||
$strTime.="---------------------\nTOTAL : $duree secondes\n";
|
||
file_put_contents('time.log', "Indiscore sur $siren : Durées ".$strTime.EOL.$strNote.EOL.$variables.EOL.print_r($tabRatiosInfos,true));
|
||
}
|
||
|
||
// EntActiveRCS
|
||
if ($this->ACTIFRNCS || $this->ACTIFINSEE) {
|
||
$actif=1;
|
||
} else {
|
||
$actif=0;
|
||
}
|
||
|
||
// Libellé Information de paiemet - Procédure collective
|
||
if ($libInfoPaiement<>'' && $tabIdentite['SituationJuridique']=='P') {
|
||
$libInfoPaiement = 'En procédure collective';
|
||
}
|
||
|
||
//Retour
|
||
$tabRet = array(
|
||
'id' => $tabIdentite['id'],
|
||
'Siret' => $tabIdentite['SiretSiege'],
|
||
'Actif' => $actif,//$tabIdentite['Actif'],
|
||
'AutreId' => $tabIdentite['AutreId'],
|
||
'Nom' => $tabIdentite['Nom'],
|
||
'Sigle' => $tabIdentite['Sigle'],
|
||
'Enseigne' => $tabIdentite['Enseigne'],
|
||
'Adresse' => $tabIdentite['Adresse'],
|
||
'Adresse2' => $tabIdentite['Adresse2'],
|
||
'AdresseNum' => $tabIdentite['AdresseNum'],
|
||
'AdresseBtq' => $tabIdentite['AdresseBtq'],
|
||
'AdresseVoie' => $tabIdentite['AdresseVoie'],
|
||
'AdresseRue' => $tabIdentite['AdresseRue'],
|
||
'CP' => $tabIdentite['CP'],
|
||
'Ville' => $tabIdentite['Ville'],
|
||
'Civilite' => $tabIdentite['Civilite'],
|
||
'NbEtab' => $tabIdentite['NbEtab'],
|
||
'Tel' => $tabIdentite['Tel'],
|
||
'Fax' => $tabIdentite['Fax'],
|
||
'Web' => $tabIdentite['Web'],
|
||
'Mail' => $tabIdentite['Mail'],
|
||
'FJ' => $fj,
|
||
'FJ_lib' => $tabIdentite['FJ_lib'],
|
||
'Siren' => $tabIdentite['Siren'],
|
||
'Nic' => $tabIdentite['Nic'],
|
||
'NafEtab' => $tabIdentite['NafEtab'],
|
||
'NafEnt' => $tabIdentite['NafEnt'],
|
||
'NafEntLib' => $tabIdentite['NafEntLib'],
|
||
'Activite' => $tabIdentite['Activite'],
|
||
'Capital' => $tabIdentite['Capital'],
|
||
'CapitalDev' => $tabIdentite['CapitalDev'],
|
||
'DateCreaEt' => $tabIdentite['DateCreaEt'],
|
||
'DateCreaEn' => $tabIdentite['DateCreaEn'],
|
||
'DateClotEt' => $tabIdentite['DateClotEt'],
|
||
'EffEnTr' => $tabIdentite['EffEnTr'],
|
||
'EffEnTrLib' => $tabIdentite['EffEnTrLib'],
|
||
'Effectif' => $tabIdentite['Effectif'],
|
||
'Dept' => $tabIdentite['Dept'],
|
||
'codeCommune' => $tabIdentite['codeCommune'],
|
||
'TrancheCA' => $tabIdentite['TrancheCA'],
|
||
'TrancheCALib' => $tabIdentite['TrancheCALib'],
|
||
'dir1Titre' => $tabIdentite['dir1Titre'],
|
||
'dir1NomPrenom' => $tabIdentite['dir1NomPrenom'],
|
||
'dir1DateFct' => $tabIdentite['dir1DateFct'],
|
||
'dir2Titre' => $tabIdentite['dir2Titre'],
|
||
'dir2NomPrenom' => $tabIdentite['dir2NomPrenom'],
|
||
'dir2DateFct' => $tabIdentite['dir2DateFct'],
|
||
'Rivoli' => $tabIdentite['Rivoli'],
|
||
'NbBilansScore' => $this->NBBILAN,
|
||
'Bilans' => $tabBil,
|
||
'Note_Structure' => $noteStructure,
|
||
'Notes_Structure' => $tabStructure,
|
||
'Note_Financiere' => $noteFin,
|
||
'Indiscore' => $noteSolvabilite,
|
||
'Indiscore20' => $indiscore20,
|
||
'TendanceIndiscore' => $tendance,
|
||
'DevraitPublier' => $this->FJURPUB,
|
||
'ScoreSolvabilite' => $noteSolvabilite,
|
||
'AnalyseSolvabilite'=> $analyseSolv,
|
||
'ScoreDirigeance' => $this->SCOREDIRI,
|
||
'AnalyseDirigeance' => $analyseDir,
|
||
'ScoreConfor' => $this->SCORECONF,
|
||
'AnalyseConfor' => $analyseConf,
|
||
'LibSecteur' => $libSecteur,
|
||
'tabBilans' => $tabBilans,
|
||
'tabBilan' => $tabBilan,
|
||
'tabRatios' => $tabRatiosNew,
|
||
'tabRatiosDiff' => $tabRatiosDiff,
|
||
'tabRatiosEvol' => $tabRatiosEvol,
|
||
'encours' => $this->ENCOURS,
|
||
'encoursIni' => $encoursIni,
|
||
'encoursStat' => $encoursEstime,
|
||
'infoEncours' => $libEncours,
|
||
'infoPaiement' => $libInfoPaiement,
|
||
'profilPayeur' => $profilPayeur,
|
||
'classeRisque' => $classeRisque,
|
||
'AdresseDom' => $tabIdentite['AdresseDom'],
|
||
'scores' => array(
|
||
'ConanH'=> $scoreConanH,
|
||
'Afdcc1'=> $scoreAfdcc1,
|
||
'Afdcc2'=> $scoreAfdcc2,
|
||
'Afdcc2note'=>$scoreAfdcc2note,
|
||
'Z' => $scoreZ,
|
||
'Altman'=> $scoreAltman,
|
||
'AltmanCote'=> $scoreAltmanB,
|
||
'36mois'=> $pDef36,
|
||
'CCF' => $valeurCCF,
|
||
'NOTECAP'=> $this->NOTECAP20, // Capitalisation
|
||
'NOTELED'=> $this->NOTELED20, // Levier Endettement
|
||
'NOTERBT'=> $this->NOTERBT20, // Capa. Remboursement
|
||
'NOTECFI'=> $this->NOTECFI20, // Couv. Charges Finan.
|
||
'NOTETRES'=> $this->NOTETRES20,// Tresorerie
|
||
'NOTEMEX'=> $this->NOTEMEX20, // Marge Exploitation
|
||
),
|
||
'paiements' => $tabPaiements,
|
||
'cs' => $this->CSFACTO,
|
||
'csMoisMaj' => $this->CSFACTO_MMAA,
|
||
'csMoisFin' => $this->CSFACTOFIN_MMAA,
|
||
|
||
'SituationJuridique'=> $tabIdentite['SituationJuridique'],
|
||
'tabInfosNotations' => $tabInfosNotation,
|
||
'tabImportExport' => $tabImportExport,
|
||
'tabCommentaires' => $tabComment,
|
||
'tabVariables' => array('CA_Y'=>$this->Yaff),
|
||
);
|
||
|
||
$indiScore = $tabRet['Indiscore']*1;
|
||
$this->ENCOURS = round($tabRet['encours']);
|
||
|
||
/** Historisation du score **/
|
||
$tabTmp = $this->db->select('jo.scores_surveillance s',
|
||
"s.siren, s.actif, s.procol, s.indiScore, s.indiScore20, s.encours, s.indiScoreDate, scoreSolv, scoreConf, scoreDir, scoreZ, scoreCH, scoreAfdcc1, scoreAfdcc2, scoreAfdcc2note, scoreAltman, scoreAltmanCote, scoreCCF, situFi, infoNote, noteStruct, noteFin, tendance, nbModifs, s.dateUpdate, s.cs, s.csMoisMaj, s.csMoisFin",
|
||
"s.siren=$siren",
|
||
false, MYSQL_ASSOC);
|
||
|
||
//Déjà en surveillance score => il faut faire un update dans la base
|
||
if (count($tabTmp)>0) {
|
||
$entrep = $tabTmp[0];
|
||
$indiScorePre = $entrep['indiScore']*1;
|
||
$encoursPre = $entrep['encours']*1;
|
||
$dateScore = str_replace('-','',$entrep['indiScoreDate'])*1;
|
||
$procol = $entrep['procol'];
|
||
if ($entrep['nbModifs']==0) $sourceModif='ajout';
|
||
$nbModifs = ($entrep['nbModifs']*1)+1;
|
||
$actionHisto = 'update';
|
||
} else {
|
||
$entrep=array();
|
||
$indiScorePre=$encoursPre=null;
|
||
$dateScore=0;
|
||
$sourceModif='ajout';
|
||
$nbModifs = 1;
|
||
$actionHisto = 'insert';
|
||
}
|
||
|
||
/** Si un score a déjà été calculé, on affine la variable "TendanceIndiscore" **/
|
||
if ($dateScore>0) {
|
||
if ($indiScore>$indiScorePre) $tabRet['TendanceIndiscore']='Haussiere';
|
||
elseif ($indiScore<$indiScorePre) $tabRet['TendanceIndiscore']='Baissiere';
|
||
else $tabRet['TendanceIndiscore']='Stable';
|
||
}
|
||
|
||
if ($this->companyEvenDateStop === null) {
|
||
// --- Scores identique au précedent, simple mise à jour
|
||
if ($indiScore==$indiScorePre && $this->ENCOURS==$encoursPre && $dateScore<>0 ) {
|
||
$tabUpdate2 = array('sourceModif'=>$sourceModif, 'nbModifs'=>$nbModifs);
|
||
if (!$this->db->update('jo.scores_surveillance', $tabUpdate2, "siren=$siren", false, 0, true)) {
|
||
debugLog('W', 'Erreur lors de la MAJ du score en surveillance pour '. $tabIdentite['Nom'], __LINE__, __FILE__, __FUNCTION__, __CLASS__);
|
||
}
|
||
}
|
||
else {
|
||
// --- Calcul de l'effectif réel
|
||
$EffectifEn = $tabIdentite['Effectif'];
|
||
$bilanAgeMax = 3 * 12; //Age maximum du dernier bilan en mois
|
||
if (!empty($tabIdentite['bilanDate']) && intval($tabIdentite['bilanYP'])>0 ) {
|
||
|
||
Zend_Date::setOptions(array('extend_month' => true));
|
||
$dateBilan = new Zend_Date($tabIdentite['bilanDate'], 'yyyyMMdd');
|
||
$dateNow = new Zend_Date();
|
||
$difference = $dateNow->sub($dateBilan);
|
||
$measure = new Zend_Measure_Time($difference->toValue(), Zend_Measure_Time::SECOND);
|
||
$measure->convertTo(Zend_Measure_Time::MONTH);
|
||
$nbMonth = $measure->getValue();
|
||
|
||
if ( $nbMonth < $bilanAgeMax ) {
|
||
$EffectifEn = $tabIdentite['bilanYP'];
|
||
}
|
||
}
|
||
|
||
//Insertion ou mise à jour du score
|
||
$tabUpdate = array(
|
||
'siren' => $siren,
|
||
'naf' => $naf,
|
||
'CJ' => $tabIdentite['FJ'],
|
||
'dateImmat' => $tabIdentite['dateImmat'],
|
||
'dateCrea' => $tabIdentite['DateCreaEn'],
|
||
'effectif' => $EffectifEn,
|
||
'actif' => $tabRet['Actif'],
|
||
'procol' => $tabRet['SituationJuridique'],
|
||
'indiScore' => $tabRet['Indiscore'],
|
||
'indiScore20' => $tabRet['Indiscore20'],
|
||
'encours' => $tabRet['encours'],
|
||
'indiScoreDate' => $this->JOUR_DATE,
|
||
'dateBilan' => @$tabRet['Bilans'][0]['Millesime'],
|
||
'scoreSolv' => $tabRet['ScoreSolvabilite'],
|
||
'scoreConf' => $tabRet['ScoreConfor'],
|
||
'scoreDir' => $tabRet['ScoreDirigeance'],
|
||
'scoreZ' => $tabRet['scores']['Z'],
|
||
'scoreCH' => $tabRet['scores']['ConanH'],
|
||
|
||
'scoreAfdcc1' => $tabRet['scores']['Afdcc1'],
|
||
'scoreAfdcc2' => $tabRet['scores']['Afdcc2'],
|
||
'scoreAfdcc2note' => $tabRet['scores']['Afdcc2note'],
|
||
'scoreAltman' => $tabRet['scores']['Altman'],
|
||
'scoreAltmanCote' => $tabRet['scores']['AltmanCote'],
|
||
'scoreCCF' => $tabRet['scores']['CCF'],
|
||
|
||
'situFi' => $tabRet['tabInfosNotations']['SituationFinanciere'],
|
||
'infoNote' => $tabRet['tabInfosNotations']['Notation'],
|
||
'noteStruct' => $tabRet['Note_Structure'],
|
||
'noteFin' => $tabRet['Note_Financiere'],
|
||
'tendance' => $tabRet['TendanceIndiscore'],
|
||
'cs' => $tabRet['cs'],
|
||
'csMoisMaj' => $tabRet['csMoisMaj'],
|
||
'csMoisFin' => $tabRet['csMoisFin'],
|
||
'adresseDom' => $tabRet['AdresseDom'],
|
||
|
||
'sourceModif' => $sourceModif,
|
||
'indiScorePre' => $entrep['indiScore'],
|
||
'indiScore20Pre' => $entrep['indiScore20'],
|
||
'indiScoreDatePre' => $entrep['indiScoreDate'],
|
||
'encoursPre' => $entrep['encours'],
|
||
'scoreSolvPre' => $entrep['scoreSolv'],
|
||
'scoreConfPre' => $entrep['scoreConf'],
|
||
'scoreDirPre' => $entrep['scoreDir'],
|
||
'scoreZPre' => $entrep['scoreZ'],
|
||
'scoreCHPre' => $entrep['scoreCH'],
|
||
'scoreAfdcc1Pre' => $entrep['scoreAfdcc1'],
|
||
'scoreAfdcc2Pre' => $entrep['scoreAfdcc2'],
|
||
'scoreAfdcc2notePre'=> $entrep['scoreAfdcc2note'],
|
||
|
||
'scoreAltmanPre' => $entrep['scoreAltman'],
|
||
'scoreAltmanCotePre'=> $entrep['scoreAltmanCote'],
|
||
'scoreCCFPre' => $entrep['scoreCCF'],
|
||
|
||
'situFiPre' => $entrep['situFi'],
|
||
'infoNotePre' => $entrep['infoNote'],
|
||
'noteStructPre' => $entrep['noteStruct'],
|
||
'noteFinPre' => $entrep['noteFin'],
|
||
'tendancePre' => $entrep['tendance'],
|
||
'csPre' => $entrep['cs'],
|
||
'csMoisMajPre' => $entrep['csMoisMaj'],
|
||
'csMoisFinPre' => $entrep['csMoisFin'],
|
||
'adresseDomPre' => $entrep['adresseDom'],
|
||
'nbModifs' => $nbModifs,
|
||
);
|
||
|
||
// --- Sauvegarde et Historisation du score
|
||
if ( $actionHisto == 'insert' ) {
|
||
if (!$this->db->insert('jo.scores_surveillance', $tabUpdate, false, true)) {
|
||
debugLog('W', "Erreur lors de l'ajout du score en surveillance pour ". $tabIdentite['Nom']." - ".mysql_error(), __LINE__, __FILE__, __FUNCTION__, __CLASS__);
|
||
}
|
||
}
|
||
else {
|
||
if (!$this->db->update('jo.scores_surveillance', $tabUpdate, "siren=$siren", false, 0, true)) {
|
||
debugLog('W', "Erreur lors de mise à jour du score en surveillance pour ". $tabIdentite['Nom']." - ".mysql_error(), __LINE__, __FILE__, __FUNCTION__, __CLASS__);
|
||
}
|
||
}
|
||
|
||
// --- Historisation du score
|
||
if (!$this->db->insert('historiques.scores_surveillance', $tabUpdate)) {
|
||
debugLog('W', "Erreur lors de l'historisation du score pour ". $tabIdentite['Nom'], __LINE__, __FILE__, __FUNCTION__, __CLASS__);
|
||
}
|
||
}
|
||
}
|
||
|
||
debugLog('I', 'Etablissement retourné FIN = '. $tabIdentite['Nom'], __LINE__, __FILE__, __FUNCTION__, __CLASS__);
|
||
|
||
return $tabRet;
|
||
}
|
||
|
||
/**
|
||
* Calcul des éléments SCORE - EVALUATION
|
||
* Paramètres en ENTREE
|
||
* - Identite
|
||
* - Annonces Legales
|
||
* - Bilans
|
||
*
|
||
* Paramètres en SORTIE
|
||
* - Définir une structure de données
|
||
*
|
||
*
|
||
*/
|
||
public function calcul()
|
||
{
|
||
|
||
}
|
||
|
||
public function comment(){}
|
||
|
||
|
||
protected function save(){}
|
||
|
||
}
|
||
?>
|