2011-04-19 07:37:39 +00:00
< ? php
class EvaluationController extends Zend_Controller_Action
{
2015-07-08 13:48:28 +00:00
protected $theme ;
protected $siret = null ;
2011-05-20 09:06:34 +00:00
protected $id = 0 ;
2012-05-20 16:31:28 +00:00
2011-04-19 07:37:39 +00:00
public function init ()
{
2011-05-20 09:06:34 +00:00
$request = $this -> getRequest ();
$this -> siret = $request -> getParam ( 'siret' );
$this -> id = $request -> getParam ( 'id' , 0 );
2012-05-20 16:31:28 +00:00
2011-05-20 09:06:34 +00:00
require_once 'Scores/WsScores.php' ;
2011-06-07 15:01:03 +00:00
require_once 'Scores/IdentiteEntreprise.php' ;
2011-04-19 07:37:39 +00:00
}
2011-05-19 15:24:35 +00:00
2011-08-24 15:27:22 +00:00
public function indexAction ()
{
2013-12-26 14:42:44 +00:00
$this -> forward ( 'entreprise' , 'recherche' );
2011-08-24 15:27:22 +00:00
}
2012-05-20 16:31:28 +00:00
2011-09-05 13:34:33 +00:00
/**
* Affichage d ' une reglette représentant le score
*/
2011-05-26 15:56:16 +00:00
public function printscoresAction ()
{
$this -> _helper -> layout () -> disableLayout ();
$request = $this -> getRequest ();
$score = strtolower ( $request -> getParam ( 'score' ));
2012-05-20 16:31:28 +00:00
2011-06-07 15:01:03 +00:00
if ( $score == 'indiscore' ){
2012-05-20 16:31:28 +00:00
$user = new Scores_Utilisateur ();
2011-06-07 15:01:03 +00:00
switch ( $user -> getTypeScore ()) {
case '20' : $score .= '20' ; break ;
case '100' :
default : $score .= '100' ; break ;
}
}
2012-05-20 16:31:28 +00:00
2011-05-26 15:56:16 +00:00
$note = $request -> getParam ( 'note' );
2011-06-07 15:01:03 +00:00
$bornes = array (
'conanh' => array ( 'min' => - 4.5 , 'max' => 16 ),
'afdcc2' => array ( 'min' => 0 , 'max' => 5 ),
'afdcc1' => array ( 'min' => - 10 , 'max' => 10 ),
'z' => array ( 'min' => - 3 , 'max' => 3 ),
'indiscore100' => array ( 'min' => 0 , 'max' => 100 ),
'indiscore20' => array ( 'min' => 0 , 'max' => 20 ),
2011-05-26 15:56:16 +00:00
);
$note = round (( $note - $bornes [ $score ][ 'min' ]) * 100 / ( $bornes [ $score ][ 'max' ] - $bornes [ $score ][ 'min' ]));
2012-05-20 16:31:28 +00:00
2011-05-26 15:56:16 +00:00
if ( $note < 0 ) $note = 0 ;
if ( $note > 100 ) $note = 100 ;
2012-05-20 16:31:28 +00:00
2011-05-26 15:56:16 +00:00
$this -> view -> assign ( 'note' , $note );
$this -> view -> assign ( 'min' , $bornes [ $score ][ 'min' ]);
$this -> view -> assign ( 'max' , $bornes [ $score ][ 'max' ]);
}
2012-05-20 16:31:28 +00:00
2014-04-24 10:46:36 +00:00
/**
* Historique des scores
*/
2014-05-09 20:24:46 +00:00
public function scoreshistoAction ()
2014-04-24 10:46:36 +00:00
{
2014-05-13 20:39:35 +00:00
$this -> view -> headLink ()
-> appendStylesheet ( '/libs/tablesorter/themes/blue/style.css' , 'all' );
$this -> view -> headScript ()
-> appendFile ( '/libs/tablesorter/jquery.tablesorter.js' , 'text/javascript' );
2014-04-24 10:46:36 +00:00
$sessionEntreprise = new Scores_Session_Entreprise ( $this -> siret , $this -> id );
$siren = substr ( $this -> siret , 0 , 9 );
2014-05-10 14:34:40 +00:00
2014-05-09 20:24:46 +00:00
$types = array (
2014-05-10 14:34:40 +00:00
'indiScore' => 'IndiScore' ,
'scoreDir' => 'Dirigeance' ,
'scoreConf' => 'Conformité' ,
'scoreZ' => 'Score Z' ,
'scoreCH' => 'Conan & Holder' ,
'scoreAfdcc1' => 'Afdcc1' ,
'scoreAfdcc2' => 'Afdcc2' ,
'scoreAltman' => 'Altman' ,
'scoreCCF' => 'CCF' ,
);
2014-05-09 20:24:46 +00:00
$bornes = array (
2015-04-10 11:57:56 +00:00
'indiScore' => array ( 'min' => 0 , 'max' => 20 , 'rouge' => 7 , 'orange' => 10 ),
'scoreDir' => array ( 'min' => 0 , 'max' => 100 , 'rouge' => 45 , 'orange' => 56 ),
'scoreConf' => array ( 'min' => 0 , 'max' => 100 , 'rouge' => 45 , 'orange' => 56 ),
'scoreZ' => array ( 'min' => - 3 , 'max' => 3 , 'rouge' => - 0.25 , 'orange' => 0.125 ),
'scoreCH' => array ( 'min' => - 4.5 , 'max' => 16 , 'rouge' => 3.75 , 'orange' => 10 ),
'scoreAfdcc1' => array ( 'min' => - 7 , 'max' => 7 , 'rouge' => 0 , 'orange' => 1 ),
'scoreAfdcc2' => array ( 'min' => - 3 , 'max' => 2 , 'rouge' => - 1 , 'orange' => 0.5 ),
'scoreAltman' => array ( 'min' => - 2 , 'max' => 8 , 'rouge' => 0 , 'orange' => 2.7 ),
'scoreCCF' => array ( 'min' => 500 , 'max' => 5000 , 'rouge' => 2160 , 'orange' => 3450 ),
2014-05-10 14:34:40 +00:00
);
2014-05-09 20:24:46 +00:00
$request = $this -> getRequest ();
$type = $request -> getParam ( 'type' , 'indiScore' );
2014-04-24 10:46:36 +00:00
$user = new Scores_Utilisateur ();
$this -> view -> headTitle () -> prepend ( 'Historique indiScore' );
$this -> view -> headTitle () -> prepend ( 'Siret ' . $this -> siret );
$ws = new WsScores ();
2014-05-09 20:24:46 +00:00
$histoScores = $ws -> getScoresHisto ( $this -> siret , $type );
2014-04-24 10:46:36 +00:00
if ( $histoScores -> nbReponses > 1 ) {
$data = array ();
foreach ( $histoScores -> result -> item as $item ) {
$d = array (
'date' => $item -> date ,
'value' => $item -> value ,
2014-05-09 20:24:46 +00:00
'encours' => $item -> encours ,
2014-04-24 10:46:36 +00:00
);
$data [ 'data' ][] = $d ;
}
//Make the graph - Ready to create a class for this char
require_once 'Vendors/ChartDirector/phpchartdir.php' ;
require_once 'Scores/Cache.php' ;
$c = Zend_Registry :: get ( 'config' );
$path = $c -> profil -> path -> pages . '/imgcache/' ;
2014-05-09 20:24:46 +00:00
$file = 'indiscorehisto-' . $this -> siret . '-' . $this -> id . '-' . $type . '.png' ;
2014-04-24 10:46:36 +00:00
$cache = new Cache ();
$return = null ;
if ( $cache -> exist ( $path . $file ) ){
$return = $file ;
} else {
2014-05-01 17:19:47 +00:00
if ( count ( $data ) < 1 ){
2014-04-24 10:46:36 +00:00
$return = null ;
} else {
$labelsX = array ();
2014-05-01 17:19:47 +00:00
$dataX = array ();
2014-05-09 20:24:46 +00:00
$encours = array ();
2014-04-24 10:46:36 +00:00
foreach ( $data [ 'data' ] as $value ){
2014-05-01 17:19:47 +00:00
$dataX [] = $value [ 'value' ];
2014-05-09 20:24:46 +00:00
$encours [] = $value [ 'encours' ];
2014-05-01 17:19:47 +00:00
$date = new Zend_Date ( $value [ 'date' ], 'yyyy-MM-dd' );
2014-05-09 20:24:46 +00:00
$labelsX [] = chartTime ( $date -> toString ( 'yyyy' ), $date -> toString ( 'MM' ), $date -> toString ( 'dd' ));
}
2014-05-01 17:19:47 +00:00
$c = new XYChart ( 600 , 300 );
2014-05-09 20:24:46 +00:00
$c -> setPlotArea ( 50 , 10 , $c -> getWidth () - 60 , $c -> getHeight () - 60 , 0xFFFFFF , - 1 , 0xC0C0C0 , $c -> dashLineColor ( 0x808080 , DotLine ), - 1 );
$c -> xAxis -> setTitle ( $this -> view -> translate ( " Année " ));
2014-05-01 17:19:47 +00:00
$c -> xAxis -> setColors ( 0x777777 , 0x444444 , 0x777777 );
2014-04-24 10:46:36 +00:00
$c -> xAxis -> setWidth ( 2 );
2014-05-09 20:24:46 +00:00
$c -> yAxis -> setTitle ( $this -> view -> translate ( " Score " ));
2014-05-01 17:19:47 +00:00
$c -> yAxis -> setColors ( 0x777777 , 0x444444 , 0x777777 );
2014-04-24 10:46:36 +00:00
$c -> yAxis -> setWidth ( 2 );
2014-05-09 20:24:46 +00:00
$c -> yAxis -> addZone ( abs ( $bornes [ $type ][ 'min' ]) * ( - 5 ), $bornes [ $type ][ 'rouge' ], 0xFFE2E2 );
$c -> yAxis -> addZone ( $bornes [ $type ][ 'rouge' ], $bornes [ $type ][ 'orange' ], 0xFFF2E2 );
$c -> yAxis -> addZone ( $bornes [ $type ][ 'orange' ], abs ( $bornes [ $type ][ 'max' ]) * 5 , 0xE2FFE2 );
// If real value is not between min max scores, enlarge Y of graphic and mark limits
$maxY = ( max ( $dataX ) >= $bornes [ $type ][ 'max' ]) ? max ( $dataX ) * 1.1 : $bornes [ $type ][ 'max' ];
$minY = ( min ( $dataX ) <= $bornes [ $type ][ 'min' ]) ? min ( $dataX ) * 1.1 : $bornes [ $type ][ 'min' ];
$c -> yAxis -> setLinearScale ( $minY , $maxY );
$textBox = $c -> addText ( 550 , 15 , $types [ $type ], " arialbi.ttf " , 11 , 0xAAAAAA );
$textBox -> setAlignment ( TopRight );
$layer = $c -> addSplineLayer ();
$layer -> setXData ( $labelsX );
2014-05-01 17:19:47 +00:00
$layer -> setLineWidth ( 1 );
2014-05-09 20:24:46 +00:00
$layer -> addExtraField ( $encours );
2014-05-10 14:34:40 +00:00
2014-05-09 20:24:46 +00:00
$dataSet = $layer -> addDataSet ( $dataX , 0x0000FF );
$dataSet -> setDataSymbol ( CircleSymbol , 4 , 0x5555FF );
2014-05-10 14:34:40 +00:00
2014-04-24 10:46:36 +00:00
if ( $c -> makeChart ( $path . $file ) === true ){
$return = $file ;
2014-05-09 20:24:46 +00:00
$graphMap = $c -> getHTMLImageMap ( " " , " " , " title=' { x|dd/mm/yyyy} \n Score: { value} \n Encours: { field0} K€' style='cursor:pointer;' " );
2014-04-24 10:46:36 +00:00
} else {
$return = false ;
}
}
}
2014-05-09 20:24:46 +00:00
$this -> view -> assign ( 'graphMap' , $graphMap );
2014-04-24 10:46:36 +00:00
$this -> view -> assign ( 'graph' , $return );
2014-05-09 20:24:46 +00:00
//Assign vars
$this -> view -> assign ( 'scores' , $histoScores -> result -> item );
2015-02-04 13:12:14 +00:00
$this -> view -> assign ( 'typeTxt' , $histoScores -> type );
$this -> view -> assign ( 'type' , $type );
2014-05-09 20:24:46 +00:00
$this -> view -> assign ( 'bornes' , $bornes );
2014-04-24 10:46:36 +00:00
}
$this -> view -> assign ( 'siret' , $this -> siret );
$this -> view -> assign ( 'id' , $this -> id );
$this -> view -> assign ( 'siren' , $siren );
$this -> view -> assign ( 'raisonSociale' , $sessionEntreprise -> getRaisonSociale ());
2014-05-09 20:24:46 +00:00
$this -> view -> assign ( 'types' , $types );
2014-04-24 10:46:36 +00:00
$this -> view -> assign ( 'exportObjet' , $histoScores );
}
2011-05-19 15:24:35 +00:00
/**
* IndiScore
*/
2011-05-24 16:03:25 +00:00
public function indiscoreAction ()
{
2013-12-26 14:42:44 +00:00
$user = new Scores_Utilisateur ();
2012-02-23 15:55:31 +00:00
if ( ! $user -> checkPerm ( 'INDISCORE' ) && ! $user -> checkPerm ( 'INDISCOREP' ))
2013-12-26 14:42:44 +00:00
$this -> forward ( 'perms' , 'error' );
2012-05-20 16:31:28 +00:00
2013-01-15 17:19:20 +00:00
$this -> view -> assign ( 'edition' , $user -> checkModeEdition ());
2011-07-05 15:57:05 +00:00
$request = $this -> getRequest ();
$autrePage = $request -> getParam ( 'apage' );
2012-05-20 16:31:28 +00:00
2015-01-26 16:11:38 +00:00
// --- Récupération des informations
if ( empty ( $autrePage ) ) {
2013-12-26 14:42:44 +00:00
$this -> view -> headTitle () -> prepend ( 'IndiScore' );
$this -> view -> headTitle () -> prepend ( 'Siret ' . $this -> siret );
2011-10-18 08:21:26 +00:00
$plus = false ;
if ( $user -> checkPerm ( 'indiscorep' )){
$plus = true ;
}
$ref = $request -> getParam ( 'ref' , '' );
$encours = $request -> getParam ( 'encours' , 0 );
$email = $request -> getParam ( 'email' , '' );
2012-05-20 16:31:28 +00:00
$ws = new WsScores ();
$infos = $ws -> getIndiScore ( substr ( $this -> siret , 0 , 9 ), 0 , 1 , $plus , $ref , $encours , $email );
2013-12-26 14:42:44 +00:00
if ( $infos === false ) $this -> forward ( 'soap' , 'error' );
2011-07-05 15:57:05 +00:00
} else {
$infos = $this -> getRequest () -> getParam ( 'infos' );
}
2011-06-07 15:01:03 +00:00
$this -> view -> assign ( 'siret' , $this -> siret );
2011-05-24 16:03:25 +00:00
$this -> view -> assign ( 'typeScore' , $user -> getTypeScore ());
2011-07-05 15:57:05 +00:00
$this -> view -> assign ( 'indiscore' , $infos );
$this -> view -> assign ( 'AutrePage' , $autrePage );
2011-09-05 13:34:33 +00:00
$this -> view -> assign ( 'exportObjet' , $infos );
2012-05-20 16:31:28 +00:00
2012-03-12 16:18:55 +00:00
$this -> view -> assign ( 'aviscredit' , $user -> checkPerm ( 'aviscredit' ));
2012-03-01 13:10:25 +00:00
$this -> view -> assign ( 'surveillance' , $user -> checkPerm ( 'survscore' ));
2011-05-24 16:03:25 +00:00
}
2012-05-20 16:31:28 +00:00
2011-05-19 15:24:35 +00:00
/**
* Rapport de synthese
*/
2011-05-24 16:03:25 +00:00
public function indiscore2Action ()
{
2011-06-07 15:01:03 +00:00
$this -> view -> headScript () -> appendFile ( '/themes/default/scripts/finance.js' , 'text/javascript' );
2013-12-26 14:42:44 +00:00
$this -> view -> headTitle () -> prepend ( " Rapport de synthèse " );
$this -> view -> headTitle () -> prepend ( " Siret " . $this -> siret );
2012-05-20 16:31:28 +00:00
$user = new Scores_Utilisateur ();
2012-02-23 15:55:31 +00:00
if ( ! $user -> checkPerm ( 'INDISCORE2' ) && ! $user -> checkPerm ( 'INDISCORE2P' ))
2013-12-26 14:42:44 +00:00
$this -> forward ( 'perms' , 'error' );
2012-05-20 16:31:28 +00:00
2011-07-06 06:49:05 +00:00
$siren = substr ( $this -> siret , 0 , 9 );
2012-05-20 16:31:28 +00:00
2015-01-22 10:53:21 +00:00
//@todo : transformer le webservice pour ne faire qu'une seule requete
2011-06-22 15:31:04 +00:00
$ws = new WsScores ();
2013-11-21 16:31:49 +00:00
$entreprise = new Scores_Session_Entreprise ( $this -> siret , $this -> id );
2011-07-06 06:49:05 +00:00
$identite = $ws -> getIdentite ( $siren );
2011-06-22 15:31:04 +00:00
$indiscore = $ws -> getIndiScore ( $siren );
2015-01-22 10:53:21 +00:00
$infos = $ws -> getRatios ( $siren , 'indiscore2' );
2015-06-10 14:52:05 +00:00
2011-07-06 06:49:05 +00:00
$score = array ();
$tabRatio = array (
2011-06-07 15:01:03 +00:00
'r5' => array ( 'total' => 'r5' , 'total_info' => '% ca' , 'op' => 1000 , 'titre' => 'CHIFFRE D\'AFFAIRES' ),
'r16' => array ( 'total' => 'r5' , 'total_info' => '% ca' , 'op' => 1000 , 'titre' => 'RESULTAT D\'EXPLOITATION' ),
'r7' => array ( 'total' => 'r5' , 'total_info' => '% ca' , 'op' => 1000 , 'titre' => 'RESULTAT COURANT' ),
'r10' => array ( 'total' => 'r5' , 'total_info' => '% ca' , 'op' => 1000 , 'titre' => 'RESULTAT NET' ),
'r18' => array ( 'total' => 'r22' , 'total_info' => '% bilan' , 'op' => 1000 , 'titre' => 'FONDS PROPRES' ),
'r231' => array ( 'total' => 'r22' , 'total_info' => '% bilan' , 'op' => 1000 , 'titre' => 'FONDS DE ROULEMENT' ),
'r232' => array ( 'total' => 'r22' , 'total_info' => '% bilan' , 'op' => 1000 , 'titre' => 'BESOIN EN FONDS DE ROULEMENT' ),
'r249' => array ( 'total' => '' , 'total_info' => '' , 'op' => 1000 , 'titre' => 'TRESORERIE NETTE' ),
'r20' => array ( 'total' => 'r5' , 'total_info' => '% ca' , 'op' => 1000 , 'titre' => 'FRAIS FINANCIER' ),
2011-05-26 15:56:16 +00:00
);
2012-05-20 16:31:28 +00:00
2011-07-06 06:49:05 +00:00
//Formattage des données
$typeBilan = 'N' ;
2013-10-23 14:20:56 +00:00
$ratiosData = new Scores_Finance_Ratios_Data ( $infos );
2012-05-20 16:31:28 +00:00
2011-07-06 06:49:05 +00:00
$nbBilanN = $ratiosData -> getNbBilan ( 'N' );
2012-02-21 18:21:56 +00:00
$nbBilanC = $ratiosData -> getNbBilan ( 'C' );
2011-07-06 06:49:05 +00:00
if ( $nbBilanN != 0 )
{
2015-01-22 10:53:21 +00:00
foreach ( $tabRatio as $idRatio => $valRatio )
{
2011-07-06 06:49:05 +00:00
$tabRatio [ $idRatio ][ 'comment' ] = $ratiosData -> wrapComment ( $idRatio );
}
$this -> view -> assign ( 'tabRatio' , $tabRatio );
2012-05-20 16:31:28 +00:00
2011-07-11 13:26:18 +00:00
$infosAnnee = $ratiosData -> getBilansInfo ( $typeBilan );
2011-07-06 06:49:05 +00:00
$annees = array_keys ( $infosAnnee );
2012-05-20 16:31:28 +00:00
2011-07-06 06:49:05 +00:00
//On prend les 3 derniers bilans pour l'affichage
$nbMaxBilan = 3 ;
rsort ( $annees );
$annees = array_slice ( $annees , 0 , $nbMaxBilan );
sort ( $annees );
$tabResult = array ();
2015-01-22 10:53:21 +00:00
foreach ( $annees as $annee )
{
2011-07-06 06:49:05 +00:00
$data = array ();
$dataEvol = array ();
//Formatter les données
2015-01-22 10:53:21 +00:00
foreach ( $tabRatio as $idRatio => $valRatio )
{
2011-07-06 06:49:05 +00:00
$data [ $idRatio ] = $ratiosData -> dRatio ( $typeBilan , $annee , $idRatio );
$dataTotal [ $idRatio ] = $ratiosData -> dTotal ( $typeBilan , $annee , $idRatio , $valRatio [ 'total' ]);
$dInfo [ $idRatio ] = $valRatio [ 'total_info' ];
}
2015-06-10 14:52:05 +00:00
2013-10-25 14:30:46 +00:00
$date = new Zend_Date ( $annee , 'yyyyMMdd' );
2011-07-06 06:49:05 +00:00
$tabResult [] = array (
2013-10-25 14:30:46 +00:00
'dateCloture' => $date -> toString ( 'dd/MM/yyyy' ),
2011-07-06 06:49:05 +00:00
'duree' => $infosAnnee [ $annee ] -> duree . ' Mois' ,
'ratio' => $data ,
'total' => $dataTotal ,
'info' => $dInfo ,
);
}
$this -> view -> assign ( 'tabResult' , $tabResult );
}
2012-05-20 16:31:28 +00:00
$this -> view -> assign ( 'tabRatio' , $tabRatio );
2011-06-07 16:15:53 +00:00
/*
2011-07-06 06:49:05 +00:00
Correction pour indiscore seule
2011-06-07 16:15:53 +00:00
$indiscore -> Siege ;
$indiscore -> SiretSiege ;
$indiscore -> NumRC ;
*/
2012-02-21 18:21:56 +00:00
$indiscore -> SiretSiege = $identite -> SiretSiege ;
2012-05-20 16:31:28 +00:00
2011-07-08 09:25:38 +00:00
$identite = new IdentiteEntreprise ( $identite );
2011-06-07 15:01:03 +00:00
//Définition des blocks
$blocks = array (
2012-02-21 18:21:56 +00:00
'Siret' ,
2011-06-07 15:01:03 +00:00
'SiretSiege' ,
'NumRC' ,
'Actif' ,
'RaisonSociale' ,
'FormeJuridique' ,
'DateImmat' ,
'DateCreaEt' ,
'Adresse' ,
'ActiviteEn' ,
'Naf4' ,
'OrigineFond' ,
'TypeExploitation' ,
'Saisonnalite' ,
'Capital' ,
'ChiffreAffaire' ,
);
$dBlock = array ();
foreach ( $blocks as $item ) {
$display = array (
'label' => method_exists ( $identite , 'get' . $item . 'Label' ) ? $identite -> { 'get' . $item . 'Label' }() : '' ,
'texte' => method_exists ( $identite , 'get' . $item . 'Texte' ) ? $identite -> { 'get' . $item . 'Texte' }() : '' ,
'titre' => method_exists ( $identite , 'get' . $item . 'Titre' ) ? $identite -> { 'get' . $item . 'Titre' }() : '' ,
);
$dBlock [ $item ] = $display ;
}
$this -> view -> assign ( 'dBlock' , $dBlock );
2012-05-20 16:31:28 +00:00
2011-06-07 15:01:03 +00:00
$dateRadiation = '' ;
2013-10-25 14:30:46 +00:00
if ( isset ( $indiscore -> DateRadiation ) && $indiscore -> DateRadiation != '' && $indiscore -> DateRadiation != '0000-00-00' ) {
$date = new Zend_Date ( str_replace ( '-' , '' , $indiscore -> DateRadiation ), 'yyyyMMdd' );
$this -> view -> assign ( 'dateRadiation' , $date -> toString ( 'dd/MM/yyyy' ));
}
2011-05-26 15:56:16 +00:00
foreach ( $indiscore -> scores as $name => $sc ){
if ( $name == 'ConanH' )
$score [ $name ] = array ( $sc , 'Score Conan Holder' );
2015-01-26 04:46:22 +00:00
if ( $name == 'Afdcc1' )
$score [ $name ] = array ( $sc , 'Score Afdcc 1' );
2011-05-26 15:56:16 +00:00
if ( $name == 'Afdcc2' )
$score [ $name ] = array ( $sc , 'Score Afdcc 2' );
if ( $name == 'Z' )
$score [ $name ] = array ( $sc , 'Score Z' );
}
2012-05-20 16:31:28 +00:00
2011-06-07 15:01:03 +00:00
$typeScore = $user -> getTypeScore ();
switch ( $typeScore ) {
case '20' :
$maxIndiscore = $typeScore ;
$score [ 'Indiscore' ] = array ( $indiscore -> Indiscore20 , 'IndiScore' );
break ;
case '100' :
default :
$maxIndiscore = empty ( $typeScore ) ? '100' : $typeScore ;
$score [ 'Indiscore' ] = array ( $indiscore -> Indiscore , 'IndiScore' );
break ;
}
2012-05-20 16:31:28 +00:00
2011-06-07 15:01:03 +00:00
$this -> view -> assign ( 'siret' , $this -> siret );
$this -> view -> assign ( 'id' , $this -> id );
2011-06-22 15:31:04 +00:00
$this -> view -> assign ( 'siren' , $siren );
2012-05-20 16:31:28 +00:00
2011-06-07 15:01:03 +00:00
$this -> view -> assign ( 'encours' , $indiscore -> encours );
$this -> view -> assign ( 'TendanceIndiscore' , $indiscore -> TendanceIndiscore );
$this -> view -> assign ( 'SituationJuridique' , $indiscore -> SituationJuridique );
2011-05-26 15:56:16 +00:00
$this -> view -> assign ( 'paiement' , $indiscore -> infoPaiement );
2012-05-20 16:31:28 +00:00
2011-06-07 15:01:03 +00:00
$this -> view -> assign ( 'scores' , $score );
2012-05-20 16:31:28 +00:00
2011-05-26 15:56:16 +00:00
$this -> view -> assign ( 'bilanReference' , $bilanReference );
2011-05-24 16:03:25 +00:00
}
2012-05-20 16:31:28 +00:00
2011-05-19 15:24:35 +00:00
/**
* Rapport complet
*/
2011-06-03 08:52:01 +00:00
public function indiscore3Action ()
{
2012-11-20 07:33:06 +00:00
$this -> view -> headScript () -> appendFile ( '/themes/default/scripts/evaluation.js' , 'text/javascript' );
2013-12-26 14:42:44 +00:00
$this -> view -> headTitle () -> prepend ( " Rapport complet " );
$this -> view -> headTitle () -> prepend ( " Siret " . $this -> siret );
2012-05-20 16:31:28 +00:00
$user = new Scores_Utilisateur ();
2012-02-23 15:55:31 +00:00
if ( ! $user -> checkPerm ( 'INDISCORE3' ) && ! $user -> checkPerm ( 'INDISCORE3P' ))
2013-12-26 14:42:44 +00:00
$this -> forward ( 'perms' , 'error' );
2011-06-22 15:31:04 +00:00
2012-01-13 11:03:05 +00:00
// Lien pour le rapport personnalisé
if ( $user -> getIdClient () == '110' || $user -> checkModeEdition ()) {
$this -> view -> assign ( 'customRapport' , $this -> view -> url ( array (
2012-05-20 16:31:28 +00:00
'controller' => 'evaluation' ,
'action' => 'customindiscore3' ,
'siret' => $this -> siret ,
2012-01-13 11:03:05 +00:00
'id' => $this -> id )
2014-08-11 12:11:23 +00:00
), 'default' , true );
2012-01-13 11:03:05 +00:00
}
2012-05-20 16:31:28 +00:00
2013-11-21 16:31:49 +00:00
$sessionEntreprise = new Scores_Session_Entreprise ( $this -> siret , $this -> id );
2011-06-22 15:31:04 +00:00
$ws = new WsScores ();
$siren = substr ( $this -> siret , 0 , 9 );
2011-10-18 08:21:26 +00:00
$plus = false ;
if ( $user -> checkPerm ( 'indiscore3p' )){
2012-05-20 16:31:28 +00:00
$plus = true ;
2011-10-18 08:21:26 +00:00
}
2011-12-08 12:58:03 +00:00
$request = $this -> getRequest ();
2011-10-18 08:21:26 +00:00
$ref = $request -> getParam ( 'ref' , '' );
$encours = $request -> getParam ( 'encours' , 0 );
$email = $request -> getParam ( 'email' , '' );
2012-05-20 16:31:28 +00:00
2011-10-18 08:21:26 +00:00
$infos = $ws -> getRapport ( $siren , 3 , 0 , $plus , $ref , $encours , $email );
2013-06-06 12:01:45 +00:00
Zend_Registry :: get ( 'firebug' ) -> info ( $infos );
2013-03-19 10:20:51 +00:00
if ( $infos === false ) {
$this -> forward ( 'soap' , 'error' );
}
2012-05-20 16:31:28 +00:00
2011-06-22 15:31:04 +00:00
$this -> view -> assign ( 'Identite' , $infos -> Identite );
$this -> view -> assign ( 'Dirigeants' , $infos -> Dirigeants );
$this -> view -> assign ( 'Liens' , $infos -> Liens );
$this -> view -> assign ( 'Annonces' , $infos -> Annonces );
$this -> view -> assign ( 'Ratios' , $infos -> Ratios );
$this -> view -> assign ( 'Indiscore' , $infos -> Indiscore );
2012-05-20 16:31:28 +00:00
2011-06-22 15:31:04 +00:00
require_once 'Scores/RapportComment.php' ;
2013-06-06 12:01:45 +00:00
$rapportComment = new RapportComment ( $siren , $this -> id ,
$infos -> Indiscore -> tabCommentaires -> item ,
$infos -> Ratios -> RatiosInfos ,
$infos -> Ratios -> BilansInfos ,
$infos -> Ratios -> RatiosSecteur ,
$infos -> Indiscore -> tabVariables
);
2011-06-22 15:31:04 +00:00
$this -> view -> assign ( 'comment' , $rapportComment -> out ());
2012-05-20 16:31:28 +00:00
2011-06-22 15:31:04 +00:00
$this -> view -> assign ( 'siret' , $this -> siret );
2011-06-07 15:01:03 +00:00
$this -> view -> assign ( 'id' , $this -> id );
2011-06-22 15:31:04 +00:00
$this -> view -> assign ( 'siren' , $siren );
2011-06-07 15:01:03 +00:00
$this -> view -> assign ( 'raisonSociale' , $sessionEntreprise -> getRaisonSociale ());
2011-09-05 13:34:33 +00:00
$this -> view -> assign ( 'exportObjet' , $infos );
2011-06-03 08:52:01 +00:00
}
2011-05-19 15:24:35 +00:00
2011-09-05 13:34:33 +00:00
/**
* Génération de rapport personnalisé
* @ todo : à améliorer
*/
2011-09-02 09:44:09 +00:00
public function customindiscore3Action ()
{
$this -> _helper -> layout () -> disableLayout ();
2012-05-20 16:31:28 +00:00
$request = $this -> getRequest ();
2011-09-02 09:44:09 +00:00
$upload = $request -> getParam ( 'upload' , null );
2013-04-08 01:03:34 +00:00
$siren = substr ( $this -> siret , 0 , 9 );
2012-05-20 16:31:28 +00:00
$user = new Scores_Utilisateur ();
2011-09-02 09:44:09 +00:00
if ( empty ( $upload )){
2012-05-20 16:31:28 +00:00
$adresse = array ();
2013-03-21 15:03:33 +00:00
if ( $user -> checkModeEdition () || $user -> getIdClient () == 110 ) {
2011-09-02 09:44:09 +00:00
$adresse [] = 'Order to Cash' ;
2013-03-22 15:17:25 +00:00
$adresse [] = '6, rue Euryale Dehaynin ' ;
$adresse [] = '75019 PARIS' ;
2011-09-02 09:44:09 +00:00
$color1 = '#DFDB00' ;
$color2 = '#EFED9A' ;
2012-01-30 11:24:12 +00:00
$background = " background-image:url('/themes/default/images/customrapport/logo_ordertocash.jpg');background-repeat:no-repeat;background-position:center " ;
2011-09-02 09:44:09 +00:00
} else {
$adresse [] = 'Financement Entreprise' ;
$adresse [] = '16 RUE SENAC DE MEILHAN' ;
$adresse [] = '17000 LA ROCHELLE' ;
$color1 = '#6699FF' ;
$color2 = '##66CCFF' ;
$background = null ;
}
2012-05-20 16:31:28 +00:00
2011-09-02 09:44:09 +00:00
$this -> view -> assign ( 'adresse' , $adresse );
$this -> view -> assign ( 'color1' , $color1 );
$this -> view -> assign ( 'color2' , $color2 );
$this -> view -> assign ( 'background' , $background );
$this -> view -> assign ( 'siret' , $this -> siret );
$this -> view -> assign ( 'id' , $this -> id );
2012-05-20 16:31:28 +00:00
2013-11-21 16:31:49 +00:00
$sessionEntreprise = new Scores_Session_Entreprise ( $this -> siret , $this -> id );
2013-04-08 01:03:34 +00:00
$this -> view -> assign ( 'rs' , $sessionEntreprise -> getRaisonSociale ());
2012-05-20 16:31:28 +00:00
} else {
2011-09-02 10:27:31 +00:00
$this -> _helper -> viewRenderer -> setNoRender ( true );
2012-05-20 16:31:28 +00:00
2011-09-02 09:44:09 +00:00
$couleurh1 = $request -> getParam ( 'couleurh1' , null );
$couleurh2 = $request -> getParam ( 'couleurh2' , null );
$texth1 = $request -> getParam ( 'texth1' , null );
$texth2 = $request -> getParam ( 'texth2' , null );
$societe_name = $request -> getParam ( 'societe_name' , null );
$adresse = $request -> getParam ( 'adresse' , null );
$logo_background = $request -> getParam ( 'logo_background' , null );
2012-05-20 16:31:28 +00:00
2013-05-14 09:32:08 +00:00
$siren = substr ( $this -> siret , 0 , 9 );
2011-09-02 10:27:31 +00:00
if ( $this -> id != 0 ){
$file = 'evaluation-indiscore3-' . $this -> siret . '-' . $this -> id . '.html' ;
2011-09-02 09:44:09 +00:00
} else {
2012-05-20 16:31:28 +00:00
$file = 'evaluation-indiscore3-' . $this -> siret . '.html' ;
2011-09-02 09:44:09 +00:00
}
2012-11-16 14:12:03 +00:00
$c = Zend_Registry :: get ( 'config' );
$path = $c -> profil -> path -> pages ;
if ( file_exists ( $path . '/' . $file ))
2012-05-20 16:31:28 +00:00
{
2011-09-02 10:27:31 +00:00
$doc = new DOMDocument ();
2012-05-20 16:31:28 +00:00
$doc -> preserveWhiteSpace = true ;
2012-11-16 14:12:03 +00:00
@ $doc -> loadHTMLFile ( $path . '/' . $file );
2012-05-20 16:31:28 +00:00
2011-09-02 10:27:31 +00:00
//Générer style particulier pour le rapport
2013-04-08 10:43:21 +00:00
$style .= 'body {background-color:#ffffff;} ' ;
$style .= '#footer {display:none;} ' ;
$style .= '#customRapport {display:none;} ' ;
$style .= '.notvisible{display:none;} ' ;
2013-03-21 14:48:24 +00:00
$style .= '#center h1 {background-color:' . $couleurh1 . ';color:' . $texth1 . ';border:1px solid;} ' ;
2014-08-14 07:41:51 +00:00
/* if ( $logo_background ) {
2013-04-08 00:51:57 +00:00
$style .= '#center {background-image:url(./themes/default/images/customrapport/logo_ordertocash_background.jpg);background-repeat:no-repeat;background-position:center;} ' ;
2014-08-14 07:41:51 +00:00
} */
2013-03-21 14:48:24 +00:00
$style .= '#center h2 {background-color:' . $couleurh2 . ';color:' . $texth2 . '} ' ;
2013-03-21 15:12:34 +00:00
$style .= 'p#rsynthese {font-size:14px;font-weight:bold;} ' ;
2012-05-20 16:31:28 +00:00
2011-09-02 10:27:31 +00:00
$styleDom = $doc -> createElement ( 'style' , $style );
2012-05-20 16:31:28 +00:00
2011-09-02 10:27:31 +00:00
//Ajout information
$contentDom = $doc -> createElement ( 'div' );
2012-05-20 16:31:28 +00:00
if ( ! $user -> checkModeEdition ()) {
$element = $doc -> createElement ( 'img' );
2012-01-30 13:51:30 +00:00
$element -> setAttribute ( 'src' , './themes/default/images/customrapport/logo_ordertocash.jpg' );
2011-09-02 10:27:31 +00:00
$element -> setAttribute ( 'width' , '12%' );
} else {
2012-01-30 14:29:40 +00:00
$element = $doc -> createElement ( 'img' );
2012-01-30 13:51:30 +00:00
$element -> setAttribute ( 'src' , './themes/default/images/customrapport/logo_ordertocash.jpg' );
2012-05-20 16:31:28 +00:00
$element -> setAttribute ( 'width' , '12%' );
2011-09-02 10:27:31 +00:00
}
2012-01-30 14:33:04 +00:00
$div = $doc -> createElement ( 'div' );
2012-01-30 14:35:05 +00:00
$div -> setAttribute ( 'style' , " clear:both; " );
2012-01-30 14:33:04 +00:00
$div -> appendChild ( $element );
$contentDom -> appendChild ( $div );
2012-05-20 16:31:28 +00:00
2011-09-02 10:27:31 +00:00
$i = 0 ;
foreach ( $adresse as $item ){
$element = $doc -> createElement ( 'span' , $item );
$contentDom -> appendChild ( $element );
$element = $doc -> createElement ( 'br' );
$contentDom -> appendChild ( $element );
$i ++ ;
}
2012-05-20 16:31:28 +00:00
2011-09-02 10:27:31 +00:00
$element = $doc -> createElement ( 'center' , $societe_name . ' Enquête Financière' );
$element -> setAttribute ( 'style' , 'font-size:17px' );
$contentDom -> appendChild ( $element );
2012-05-20 16:31:28 +00:00
2014-08-14 07:41:51 +00:00
/* if ( $user -> checkModeEdition () || $user -> getIdClient () == 110 ) {
2013-04-08 01:03:34 +00:00
$element = $doc -> createElement ( 'span' , " Les équipes d'Order To Cash se tiennent à votre disposition pour vous assister dans l'interprétation de ces données au 01 84 16 50 00 ou par mail à l'adresse suivante : contact@ordertocash.fr " );
$element -> setAttribute ( 'style' , 'text-align:left;' );
2011-09-02 10:27:31 +00:00
$contentDom -> appendChild ( $element );
2014-08-14 07:41:51 +00:00
} */
2012-05-20 16:31:28 +00:00
2011-09-02 10:27:31 +00:00
$ajout = $doc -> createElement ( 'div' );
$ajout -> appendChild ( $styleDom );
$ajout -> appendChild ( $contentDom );
2012-05-20 16:31:28 +00:00
2011-09-02 10:27:31 +00:00
//Après <div id="center"> on insére le contenu
2012-05-20 16:31:28 +00:00
$body = $doc -> getElementsByTagName ( 'body' ) -> item ( 0 );
2011-09-02 10:27:31 +00:00
$div = $body -> getElementsByTagName ( 'div' );
foreach ( $div as $item ){
if ( $item -> hasAttribute ( 'id' ) && $item -> getAttribute ( 'id' ) == 'center' ){
break ;
}
}
2012-05-20 16:31:28 +00:00
2011-09-02 10:27:31 +00:00
$item -> parentNode -> insertBefore ( $ajout , $item );
$xml = $doc -> saveXML ();
2012-05-20 16:31:28 +00:00
2012-11-16 14:12:03 +00:00
$c = Zend_Registry :: get ( 'config' );
$outfile = $c -> profil -> path -> pages . '/p' . $user -> getIdClient () . '-' . $file ;
2012-05-20 16:31:28 +00:00
file_put_contents ( $outfile , $xml );
2011-09-02 10:27:31 +00:00
//Génération du pdf
2013-10-23 14:20:56 +00:00
$wkhtmltopdf = new Scores_Wkhtml_Pdf ();
2012-03-22 15:36:37 +00:00
$wkhtmltopdf -> setOptions ( 'footer-right' , 'Page [page] sur [toPage]' );
$wkhtmltopdf -> setOptions ( 'header-right' , date ( 'd/m/Y H:i:s' ));
2013-04-08 00:51:57 +00:00
$wkhtmltopdf -> setOptions ( 'disable-external-links' );
$wkhtmltopdf -> setOptions ( 'disable-internal-links' );
2011-09-02 10:27:31 +00:00
$pdfFile = $wkhtmltopdf -> exec ( $outfile );
2012-05-20 16:31:28 +00:00
2011-09-02 10:27:31 +00:00
if ( file_exists ( $pdfFile )){
echo '<center>Votre fichier est prêt pour être téléchargé !<br />' .
'<a target="_blank" href="' . $this -> view -> url (
2012-05-20 16:31:28 +00:00
array ( 'controller' => 'fichier' ,
'action' => 'customrapport' ,
2014-08-11 12:11:23 +00:00
'fichier' => basename ( $pdfFile )), 'default' , true ) . '">Télécharger</a></center>' ;
2011-09-02 10:27:31 +00:00
} else {
2012-05-20 16:31:28 +00:00
echo " Erreur lors de la génération du PDF. " ;
2011-09-02 10:27:31 +00:00
}
} else {
2012-05-20 16:31:28 +00:00
echo " Erreur fichier non présent ! " ;
}
2011-09-02 09:44:09 +00:00
}
}
2012-05-20 16:31:28 +00:00
2011-05-19 15:24:35 +00:00
/**
* Enquete commerciale
2011-09-05 13:34:33 +00:00
* @ todo : Vérifier l ' enregistrement
2011-05-19 15:24:35 +00:00
*/
public function enquetecAction ()
{
2011-05-20 09:06:34 +00:00
$this -> view -> headScript () -> appendFile ( '/themes/default/scripts/enquetec.js' , 'text/javascript' );
2013-12-26 14:42:44 +00:00
$this -> view -> headTitle () -> prepend ( " Enquete commerciale " );
$this -> view -> headTitle () -> prepend ( " Siret " . $this -> siret );
2012-05-20 16:31:28 +00:00
2011-05-20 09:06:34 +00:00
//isset($_REQUEST['pays']) ? $pays=$_REQUEST['pays'] : $pays='' ;
2012-05-20 16:31:28 +00:00
2011-05-20 09:06:34 +00:00
$commandeEnquete = false ;
$request = $this -> getRequest ();
2012-05-20 16:31:28 +00:00
2011-05-20 09:06:34 +00:00
if ( $request -> isPost ()){
2012-05-20 16:31:28 +00:00
2011-05-20 09:06:34 +00:00
$InfoUser = $request -> getParam ( 'InfoUser' );
$InfoEnq = $request -> getParam ( 'InfoEnq' );
2012-05-20 16:31:28 +00:00
2011-05-20 09:06:34 +00:00
//Affichage de la demande
//Vérification des informations
$formError = false ;
$fields = array ();
2012-05-20 16:31:28 +00:00
2011-05-20 09:06:34 +00:00
//Info utilisateur obligatoire :
if ( $InfoUser [ 'Identite' ] == '' ){ $fields [] = 'Votre Identite' ; $formError = true ;}
if ( $InfoUser [ 'Tel' ] == '' ){ $fields [] = 'Votre Téléphone' ; $formError = true ;}
if ( $InfoUser [ 'Email' ] == '' ){ $fields [] = 'Votre Email' ; $formError = true ;}
2012-05-20 16:31:28 +00:00
2011-05-20 09:06:34 +00:00
//Info entreprise obligatoire :
if ( isset ( $InfoEnq [ 'Type' ]) && $InfoEnq [ 'Type' ] == '' ){ $fields [] = 'Choix du type d\'enquête' ; $formError = true ;}
if ( $InfoEnq [ 'PrecisionsChoix' ] == '1' ){
if ( $InfoEnq [ 'Precisions' ][ 'Motif' ] == '' ){ $fields [] = 'Mofif de la demande' ; $formError = true ;}
} elseif ( $InfoEnq [ 'PrecisionsChoix' ] == '3' || $InfoEnq [ 'PrecisionsChoix' ] == '4' ){
if ( $InfoEnq [ 'Precisions' ][ 'MontantCA' ] == '' ){ $fields [] = 'Précisions de la demande' ; $formError = true ;}
} elseif ( $InfoEnq [ 'PrecisionsChoix' ] == '5' ){
if ( $InfoEnq [ 'Precisions' ][ 'Autre' ] == '' ){ $fields [] = 'Précisions de la demande' ; $formError = true ;}
}
2012-05-20 16:31:28 +00:00
2011-05-20 09:06:34 +00:00
if ( isset ( $InfoEnq [ 'ImpayeesChoix' ]) && $InfoEnq [ 'ImpayeesChoix' ] == 'oui' ){
if ( $InfoEnq [ 'Impayees' ][ 'Montant' ] == '' || $InfoEnq [ 'Impayees' ][ 'Nombre' ] == '' || $InfoEnq [ 'Impayees' ][ 'Date' ] == '' ){ $fields [] = 'Précisions sur les impayées' ; $formError = true ;}
}
if ( isset ( $InfoEnq [ 'RetardPaiementChoix' ]) && $InfoEnq [ 'RetardPaiementChoix' ] == 'oui' ){
if ( $InfoEnq [ 'RetardPaiement' ][ 'Montant' ] == '' || $InfoEnq [ 'Nombre' ] == '' || $InfoEnq [ 'RetardPaiement' ][ 'Date' ] == '' ){ $fields [] = 'Précisions sur le retarde de paiement' ; $formError = true ;}
}
if ( isset ( $_REQUEST [ 'InfoEnq' ][ 'LitigeChoix' ]) && $_REQUEST [ 'InfoEnq' ][ 'LitigeChoix' ] == 'oui' ){
if ( $_REQUEST [ 'InfoEnq' ][ 'Litige' ][ 'Precisions' ] == '' || $_REQUEST [ 'InfoEnq' ][ 'Litige' ][ 'Precisions' ] == '' ){ $fields [] = 'Précisions sur le litige' ; $formError = TRUE ;}
}
2012-05-20 16:31:28 +00:00
2011-05-20 09:06:34 +00:00
if ( $formError == true ){
$message = '<font color="red">' ;
$message .= 'Veuillez remplir les champs suivants : ' ;
$message .= join ( ', ' , $fields );
$message .= '</font>' ;
} else {
$InfoDemande = $InfoUser ;
$siren = $InfoEnq [ 'Siren' ];
unset ( $InfoEnq [ 'Siren' ]);
//Suppression et assigation des valeurs pour le webservice
2011-06-03 08:52:01 +00:00
if ( $InfoEnq [ 'PrecisionsChoix' ] = 1 ){
2011-05-20 09:06:34 +00:00
$InfoEnq [ 'Precisions' ][ 'Type' ] = " Enquête sur un client (contrôle crédit) " ;
unset ( $InfoEnq [ 'PrecisionsChoix' ]);
} elseif ( $InfoEnq [ 'PrecisionsChoix' ] == 2 ){
$InfoEnq [ 'Precisions' ][ 'Type' ] = " Enquête sur un prospect (ouverture de compte) " ;
unset ( $InfoEnq [ 'PrecisionsChoix' ]);
} elseif ( $InfoEnq [ 'PrecisionsChoix' ] == 3 ){
$InfoEnq [ 'Precisions' ][ 'Type' ] = " Enquête sur un fournisseur stratégique " ;
unset ( $InfoEnq [ 'PrecisionsChoix' ]);
} elseif ( $InfoEnq [ 'PrecisionsChoix' ] == 4 ){
$InfoEnq [ 'Precisions' ][ 'Type' ] = " Enquête sur un fournisseur non stratégique " ;
unset ( $InfoEnq [ 'PrecisionsChoix' ]);
} elseif ( $InfoEnq [ 'PrecisionsChoix' ] == 5 ){
$InfoEnq [ 'Precisions' ][ 'Type' ] = " Autre type d'enquête (Précisez...) " ;
unset ( $InfoEnq [ 'PrecisionsChoix' ]);
}
2011-09-06 12:08:21 +00:00
2011-05-20 09:06:34 +00:00
$ws = new WsScore ();
$result = $ws -> commandeEnquete ( $siren , $InfoEnq , $InfoDemande );
2011-09-06 12:08:21 +00:00
if ( $result === false ) {
2012-05-20 16:31:28 +00:00
$this -> _forward ( 'soap' , 'error' );
2011-09-06 12:08:21 +00:00
} else {
$this -> view -> assign ( 'annee' , substr ( $result -> dateCommande , 0 , 4 ));
$this -> view -> assign ( 'mois' , substr ( $result -> dateCommande , 4 , 2 ));
$this -> view -> assign ( 'jour' , substr ( $result -> dateCommande , 6 , 2 ));
$this -> view -> assign ( 'heure' , substr ( $result -> dateCommande , 8 , 2 ));
$this -> view -> assign ( 'minutes' , substr ( $result -> dateCommande , 10 , 2 ));
$this -> view -> assign ( 'ref' , substr ( $result -> refCmde , 1 ));
$this -> view -> assign ( 'siren' , $result -> siren );
$commandeEnquete = true ;
}
2012-05-20 16:31:28 +00:00
$this -> view -> assign ( 'commandeEnquete' , $commandeEnquete );
2011-05-20 09:06:34 +00:00
}
$this -> view -> assign ( 'formError' , $formError );
$this -> view -> assign ( 'message' , $message );
$this -> view -> assign ( 'InfoUser' , $InfoUser );
$this -> view -> assign ( 'InfoEnq' , $InfoEnq );
}
2012-05-20 16:31:28 +00:00
2011-05-20 09:06:34 +00:00
if ( $commandeEnquete == false ) {
$ws = new WsScores ();
$infosEntrep = $ws -> getIdentite ( $this -> siret , $this -> id );
$this -> view -> assign ( 'Etab' , $infosEntrep );
2012-05-20 16:31:28 +00:00
$user = new Scores_Utilisateur ();
2011-05-20 09:06:34 +00:00
$this -> view -> assign ( 'user' , $user );
}
2012-05-20 16:31:28 +00:00
2011-05-20 09:06:34 +00:00
$this -> view -> assign ( 'commandeEnquete' , $commandeEnquete );
2011-05-19 15:24:35 +00:00
}
2012-05-20 16:31:28 +00:00
2013-12-26 14:42:44 +00:00
/**
* Demande d ' avis de credit
*/
2012-03-12 13:14:17 +00:00
public function aviscreditAction ()
2012-05-20 16:31:28 +00:00
{
2013-12-26 14:42:44 +00:00
$this -> view -> headTitle () -> prepend ( " Avis de crédit " );
$this -> view -> headTitle () -> prepend ( " Siret " . $this -> siret );
2012-03-12 13:14:17 +00:00
$commande = false ;
2012-05-20 16:31:28 +00:00
2012-03-12 13:14:17 +00:00
$request = $this -> getRequest ();
2012-05-20 16:31:28 +00:00
2012-03-12 13:14:17 +00:00
//Reception des données du formulaire
2012-05-20 16:31:28 +00:00
if ( $request -> isPost ())
2012-03-12 13:14:17 +00:00
{
$InfoUser = $request -> getParam ( 'InfoUser' );
2012-05-20 16:31:28 +00:00
$InfoEnq = $request -> getParam ( 'InfoEnq' );
2012-03-12 13:14:17 +00:00
$formError = false ;
$fields = array ();
2012-05-20 16:31:28 +00:00
2012-03-12 13:14:17 +00:00
//Info utilisateur obligatoire :
if ( $InfoUser [ 'Identite' ] == '' ){
$fields [] = 'Votre Identite' ; $formError = true ;
}
if ( $InfoUser [ 'Tel' ] == '' ){
$fields [] = 'Votre Téléphone' ; $formError = true ;
}
if ( $InfoUser [ 'Email' ] == '' ){
$fields [] = 'Votre Email' ; $formError = true ;
}
2012-05-20 16:31:28 +00:00
2012-03-12 13:14:17 +00:00
//Info entreprise obligatoire :
if ( isset ( $InfoEnq [ 'Type' ]) && $InfoEnq [ 'Type' ] == '' ){
$fields [] = 'Choix du type d\'enquête' ; $formError = true ;
}
2012-05-20 16:31:28 +00:00
2012-03-12 13:14:17 +00:00
if ( isset ( $InfoEnq [ 'ImpayeesChoix' ]) && $InfoEnq [ 'ImpayeesChoix' ] == 'oui' ){
if ( $InfoEnq [ 'Impayees' ][ 'Montant' ] == '' || $InfoEnq [ 'Impayees' ][ 'Nombre' ] == '' || $InfoEnq [ 'Impayees' ][ 'Date' ] == '' ){
$fields [] = 'Précisions sur les impayées' ; $formError = true ;
}
}
if ( isset ( $InfoEnq [ 'RetardPaiementChoix' ]) && $InfoEnq [ 'RetardPaiementChoix' ] == 'oui' ){
if ( $InfoEnq [ 'RetardPaiement' ][ 'Montant' ] == '' || $InfoEnq [ 'Nombre' ] == '' || $InfoEnq [ 'RetardPaiement' ][ 'Date' ] == '' ){
$fields [] = 'Précisions sur le retard de paiement' ; $formError = true ;
}
}
if ( isset ( $_REQUEST [ 'InfoEnq' ][ 'LitigeChoix' ]) && $_REQUEST [ 'InfoEnq' ][ 'LitigeChoix' ] == 'oui' ){
if ( $_REQUEST [ 'InfoEnq' ][ 'Litige' ][ 'Precisions' ] == '' || $_REQUEST [ 'InfoEnq' ][ 'Litige' ][ 'Precisions' ] == '' ){
$fields [] = 'Précisions sur le litige' ; $formError = TRUE ;
}
}
2012-05-20 16:31:28 +00:00
2012-03-12 13:14:17 +00:00
//Envoi du mail formatté
2012-05-20 16:31:28 +00:00
if ( $formError == true )
2012-03-12 16:31:00 +00:00
{
2012-03-12 13:14:17 +00:00
$message = '<font color="red">' ;
$message .= 'Veuillez remplir les champs suivants : ' ;
$message .= join ( ', ' , $fields );
$message .= '</font>' ;
2012-05-20 16:31:28 +00:00
2012-03-12 16:31:00 +00:00
$this -> view -> assign ( 'message' , $message );
2012-05-20 16:31:28 +00:00
}
else
2012-03-12 16:31:00 +00:00
{
2012-05-20 16:31:28 +00:00
2012-03-12 13:14:17 +00:00
$sujet = " Demande d'avis personnalisé " ;
$texte = " <pre> " . print_r ( $InfoUser , 1 ) . " </pre> " .
2012-03-12 16:31:00 +00:00
" <pre> " . print_r ( $InfoEnq , 1 ) . " </pre> " ;
2012-05-20 16:31:28 +00:00
2015-06-10 14:52:05 +00:00
$mail = new Scores_Mail_Method ();
2015-06-11 15:29:14 +00:00
$mail -> setFromKey ( 'production' );
2012-03-12 13:14:17 +00:00
$mail -> addToKey ( 'support' );
$mail -> setSubject ( $sujet );
$mail -> setBodyHtml ( $texte );
2012-05-20 16:31:28 +00:00
2015-06-11 15:29:14 +00:00
if ( $mail -> execute ()) {
2012-05-20 16:31:28 +00:00
$commande = true ;
}
2012-03-12 13:14:17 +00:00
}
2012-05-20 16:31:28 +00:00
$this -> view -> assign ( 'commande' , $commande );
2012-03-12 13:14:17 +00:00
$this -> view -> assign ( 'formError' , $formError );
$this -> view -> assign ( 'message' , $message );
$this -> view -> assign ( 'InfoUser' , $InfoUser );
$this -> view -> assign ( 'InfoEnq' , $InfoEnq );
2012-05-20 16:31:28 +00:00
2012-03-12 13:14:17 +00:00
$this -> view -> assign ( 'siren' , substr ( $this -> siret , 0 , 9 ));
2012-05-20 16:31:28 +00:00
}
2012-03-12 13:14:17 +00:00
//Affichage du formulaire
if ( $commande == false ) {
$ws = new WsScores ();
$infosEntrep = $ws -> getIdentite ( $this -> siret , $this -> id );
$this -> view -> assign ( 'Etab' , $infosEntrep );
2012-05-20 16:31:28 +00:00
$user = new Scores_Utilisateur ();
2012-03-12 13:14:17 +00:00
$this -> view -> assign ( 'user' , $user );
2012-05-20 16:31:28 +00:00
}
2012-03-12 13:14:17 +00:00
}
2012-05-20 16:31:28 +00:00
2011-06-29 12:22:59 +00:00
/**
* Affichage des informations de scoring creditsafe
*/
2011-06-21 16:09:34 +00:00
public function scoringAction ()
{
2013-12-26 14:42:44 +00:00
$this -> view -> headTitle () -> prepend ( " Scoring Credit Safe " );
$this -> view -> headTitle () -> prepend ( " Siret " . $this -> siret );
$user = new Scores_Utilisateur ();
2012-05-20 16:31:28 +00:00
if ( ! $user -> checkModeEdition () or ! $user -> checkPerm ( 'SCORECSF' ))
2011-06-22 13:01:08 +00:00
$this -> render ( 'error/perms' , null , 'error' );
2012-05-20 16:31:28 +00:00
2011-06-21 16:09:34 +00:00
define ( 'CREDITSAFE_WS_URL' , 'https://www.creditsafe.fr/getdata/service/CSFRServices.asmx' );
define ( 'CREDITSAFE_WS_URI' , 'https://www.creditsafe.fr/getdata/service/' );
define ( 'CREDITSAFE_WS_USER' , 'scores_decisions' );
define ( 'CREDITSAFE_WS_PASS' , 'yoann1306' );
define ( 'CREDITSAFE_WS_REF' , 'ref' );
/**
* L ' Url du WSDL est bonne simplament le formatage des données a changés , il faut respecter les données !
* comparer les exemples donnés .
2011-06-22 15:31:04 +00:00
*
2011-06-21 16:09:34 +00:00
*/
$req = '<xmlrequest>' .
'<header>' .
'<username>' . CREDITSAFE_WS_USER . '</username>' .
'<password>' . CREDITSAFE_WS_PASS . '</password>' .
//'<operation>getcompanyinformation</operation>'.
'<operation>getratinglimit</operation>' .
'<country>FR</country>' .
'<language>FR</language>' .
'<chargereference>' . CREDITSAFE_WS_REF . '</chargereference>' .
'</header>' .
'<body>' .
//'<package>standard</package>'.
'<package>ratinglimit</package>' .
" <companynumber> " . $this -> siret . " </companynumber> " .
'</body>' .
'</xmlrequest>' ;
2012-05-20 16:31:28 +00:00
2011-06-21 16:09:34 +00:00
$date = date ( 'Ymd' );
$url = 'https://www.creditsafe.fr/getdata/service/CSFRServices.asmx/GetData?RequestXmlStr=' . $req ;
$file = APPLICATION_PATH . '/../../data/creditsafe/' . $this -> siret . '.xml' ;
2012-05-20 16:31:28 +00:00
2013-11-05 14:45:25 +00:00
try {
$client = new Zend_Http_Client ( $url );
$client -> setStream ();
$response = $client -> request ( 'GET' );
if ( $response -> isSuccessful () ) {
$xml = html_entity_decode ( $response -> getBody (), ENT_QUOTES , 'UTF-8' );
$dom_object = new DOMDocument ();
$ws = new WsScores ();
if ( ! file_exists ( $file )) {
file_put_contents ( $file , $xml ); // Ne pas oublier de metre les bons droits sur le dossier.
$ws -> setLog ( 'scorecsf' , $this -> siret );
} else {
$ws -> setLog ( 'scorecsf' , $this -> siret , 0 , 'local' );
}
$dom_object -> load ( $file );
$companyname = $dom_object -> getElementsByTagName ( 'companyname' ) -> item ( 0 ) -> nodeValue ;
$rating = $dom_object -> getElementsByTagName ( 'rating' ) -> item ( 0 ) -> nodeValue ;
$ratingdesc1 = str_replace ( '?' , " ' " , $dom_object -> getElementsByTagName ( 'ratingdesc1' ) -> item ( 0 ) -> nodeValue );
$ratingdesc2 = str_replace ( '?' , " ' " , $dom_object -> getElementsByTagName ( 'ratingdesc2' ) -> item ( 0 ) -> nodeValue );
$creditlimit = $dom_object -> getElementsByTagName ( 'creditlimit' ) -> item ( 0 ) -> nodeValue ;
$libelle = '' ;
if ( strtoupper ( $creditlimit ) <> strtolower ( $creditlimit ) || $creditlimit == '' )
$strCreditlimit = $creditlimit ;
else
$strCreditlimit = number_format ( $creditlimit , null , null , ' ' ) . ' €' ;
if ( $rating >= 40 ){
$fontColor = 'green' ;
$imgFeux = '<img src="/themes/default/images/scoring/feux_vert.png"/>' ;
if ( $rating >= 71 ) $libelle = 'Très bonne cote de crédit/solvabilité' ;
elseif ( $rating >= 51 ) $libelle = 'Bonne cote de crédit/solvabilité' ;
else $libelle = 'Solvable' ;
} elseif ( $rating >= 20 ) {
$fontColor = 'yellow' ; //#f2be2c';
$imgFeux = '<img src="/themes/default/images/scoring/feux_orange.png"/>' ;
$libelle = 'Précautions recommandées' ;
} elseif ( strtoupper ( $rating ) <> strtolower ( $rating )) {
$fontColor = 'black' ;
$imgFeux = ' ' ;
}
elseif ( $rating == '' ) {
$fontColor = 'black' ;
$imgFeux = ' ' ;
}
else {
$fontColor = 'red' ;
$imgFeux = '<img src="/themes/default/images/scoring/feux_rouge.png"/>' ;
if ( $rating == 0 ) $libelle = 'Entreprise en situation de défaillance et ayant un très fort risque de radiation' ;
else $libelle = 'Avertissement - Crédit à votre discrétion' ;
}
2012-05-20 16:31:28 +00:00
2013-11-05 14:45:25 +00:00
/** Assigne les valeur a la vue **/
if ( ! empty ( $companyname )) {
$this -> view -> raisonSociale = $companyname ;
} else {
2013-11-21 16:31:49 +00:00
$session = new Scores_Session_Entreprise ( $this -> siret , $this -> id );
2013-11-05 14:45:25 +00:00
$this -> view -> raisonSociale = $session -> getRaisonSociale ();
}
$this -> view -> emailCommande = $user -> getEmail ();
$this -> view -> id = $this -> id ;
$this -> view -> siren = substr ( $this -> siret , 0 , 9 );
$this -> view -> imgFeux = $imgFeux ;
$this -> view -> fontColor = $fontColor ;
$this -> view -> rating = $rating ;
$this -> view -> libelle = $libelle ;
$this -> view -> strCreditlimit = $strCreditlimit ;
}
} catch ( Zend_Http_Client_Exception $e ) {}
2011-06-21 16:09:34 +00:00
}
2012-05-20 16:31:28 +00:00
2011-06-29 12:22:59 +00:00
/**
* Commande de scoring partenaire creditsafe
*/
2011-06-29 14:06:51 +00:00
public function scoringcommandeAction ()
2011-06-29 12:22:59 +00:00
{
if ( $this -> getRequest () -> isPost ()){
$request = $this -> getRequest ();
$email = $request -> getParam ( 'email' , '' );
$siren = $request -> getParam ( 'siren' , '' );
2012-05-20 16:31:28 +00:00
2011-06-30 15:30:43 +00:00
if ( preg_match ( '#^[\w.-]+@[\w.-]+\.[a-zA-Z]{2,5}$#' , $email )) {
2011-06-29 12:22:59 +00:00
$message = 'Entreprise mise sous surveillance scoring partenaire !' ;
2015-06-10 14:52:05 +00:00
$mail = new Scores_Mail_Method ();
2011-06-29 12:22:59 +00:00
$mail -> setSubject ( " Demande de surveillance score CreditSafe pour $siren à " . $email );
2012-05-20 16:31:28 +00:00
$user = new Scores_Utilisateur ();
2011-06-30 15:30:43 +00:00
$login = $user -> getLogin ();
2011-06-29 12:22:59 +00:00
$texte = 'REQUEST=' . EOL . print_r ( $request -> getParams (), true ) . EOL .
'Utilisateur=' . $login ;
2012-05-20 16:31:28 +00:00
2015-06-11 15:29:14 +00:00
$mail -> setBodyText ( $texte );
$mail -> setFromKey ( 'contact' );
2011-06-29 12:22:59 +00:00
$mail -> addToKey ( 'contact' );
2015-06-11 15:29:14 +00:00
$mail -> execute ();
2012-05-20 16:31:28 +00:00
2012-11-05 15:33:01 +00:00
$c = Zend_Registry :: get ( 'config' );
2012-11-16 14:12:03 +00:00
$path = $c -> profil -> path -> data . '/log' ;
2012-05-20 16:31:28 +00:00
2011-09-29 15:15:14 +00:00
$fp = fopen ( $path . '/surveillance_scf.csv' , 'a' );
2011-06-29 12:22:59 +00:00
fwrite ( $fp , date ( 'Y/m/d H:i:s' ) . " ; $siren ; " . $email . ';' . $login . ';' . $user -> getEmail () . ';' . $user -> getIpAddress () . " \n " );
fclose ( $fp );
2012-05-20 16:31:28 +00:00
2011-06-29 12:22:59 +00:00
} else {
$message = " ERREUR : Veuillez saisir une adresse email valide pour la mise sous surveillance " ;
}
$this -> view -> assign ( 'message' , $message );
}
}
2013-03-15 15:47:36 +00:00
public function valorisationAction ()
{
2013-12-26 14:42:44 +00:00
$this -> view -> headTitle () -> prepend ( " Valorisation " );
$this -> view -> headTitle () -> prepend ( " Siret " . $this -> siret );
2013-03-15 15:47:36 +00:00
$user = new Scores_Utilisateur ();
if ( ! $user -> checkPerm ( 'INDISCORE3' ) && ! $user -> checkPerm ( 'INDISCORE3P' ))
$this -> _forward ( 'perms' , 'error' );
2013-11-21 16:31:49 +00:00
$sessionEntreprise = new Scores_Session_Entreprise ( $this -> siret , $this -> id );
2013-03-15 15:47:36 +00:00
$ws = new WsScores ();
$siren = substr ( $this -> siret , 0 , 9 );
$request = $this -> getRequest ();
$ref = $request -> getParam ( 'ref' , '' );
$encours = $request -> getParam ( 'encours' , 0 );
$email = $request -> getParam ( 'email' , '' );
$infos = $ws -> getEntrepriseValo ( $siren );
require_once 'Scores/RapportComment.php' ;
2013-06-06 12:01:45 +00:00
$rapportComment = new RapportComment ( $siren , $this -> id ,
$infos -> Indiscore -> tabCommentaires -> item ,
$infos -> RatiosInfos ,
$infos -> RatiosBilansInfos ,
$infos -> RatiosSecteur ,
$infos -> Indiscore -> tabVariables
);
2013-03-15 15:47:36 +00:00
$this -> view -> assign ( 'comment' , $rapportComment -> out ());
$this -> view -> assign ( 'siret' , $this -> siret );
$this -> view -> assign ( 'id' , $this -> id );
$this -> view -> assign ( 'siren' , $siren );
$this -> view -> assign ( 'raisonSociale' , $sessionEntreprise -> getRaisonSociale ());
$this -> view -> assign ( 'exportObjet' , $infos );
}
2011-04-19 07:37:39 +00:00
}