extranet/application/controllers/DashboardController.php
2012-06-12 08:43:21 +00:00

620 lines
19 KiB
PHP

<?php
class DashboardController extends Zend_Controller_Action
{
protected $typeActes= array(
'a00' => 'MODIFICATION',
'a01' => 'MODIFICATION',
'a02' => 'DISSOLUTION',
'a03' => 'CONSTITUTION',
'a04' => 'STATUTS CONSTITUTIFS',
'a06' => 'STATUTS A JOUR',
'a07' => 'STATUTS A JOUR',
'a08' => 'STATUTS A JOUR ET DECLARATION DE CONFORMITE',
'a09' => 'STATUTS APRES TRANSFERT DE SIEGE',
'a1D' => 'AUGMENTATION ET REDUCTION CAPITAL',
'a25' => 'AUGMENTATION DE CAPITAL',
'a26' => 'REDUCTION DE CAPITAL',
'a31' => 'TRANSFERT SIEGE SOCIAL HORS RESSORT O',
'a33' => 'CHANGEMENT DE GERANT',
'a39' => 'CHANGEMENT DE COMMISSAIRE AUX COMPTES',
'a77' => 'CONTINUATION MALGRE LA PERTE DE LA MOITIE DU CAPITAL',
'aA1' => 'STATUTS',
'aAA' => 'ACTE',
'aAB' => 'ACTE MODIFICATIF',
'aAC' => 'ACTE RECTIFICATIF',
'aAD' => 'ACTE SOUS SEING PRIVE',
'aAE' => 'AMPLIATION',
'aAG' => 'AVENANT',
'aAH' => 'AVENANT AUX STATUTS',
'aAI' => 'ATTESTATION',
'aAJ' => 'ANNEXES',
'aAK' => 'ATTESTATION BANCAIRE',
'aAP' => 'PROJET APPORT PARTIEL D&quot,ACTIF',
'aAT' => 'DELIVRANCE DE L&quot,INFORMATION FAITE AU CONJOINT SUR LES CONSEQUENCES DES DETTES',
'aCA' => 'CERTIFICAT',
'aCB' => 'COMPTES DE CLOTURE DE LIQUIDATION',
'aCD' => 'CONTRAT',
'aCE' => 'CONVENTION',
'aCF' => 'CERTIFICAT DE SOUSCRIPTION D&quot,ACTIONS',
'aDA' => 'DECISION DE GERANCE',
'aDB' => 'DECISION DE L&quot,ASSOCIE UNIQUE',
'aDC' => 'DECISION DES ASSOCIES',
'aDE' => 'DECLARATION DE CONFORMITE',
'aDF' => 'DECLARATION DE SOUSCRIPTION ET DE VERSEMENT',
'aDH' => 'DECLARATION DE CONFORMITE (ART.374 L24/07/1966)',
'aDI' => 'DECISION DE L&quot,ACTIONNAIRE UNIQUE',
'aDP' => 'DECISION DU PRESIDENT',
'aEA' => 'EXPEDITION',
'aEB' => 'EXPEDITION NOTARIEE',
'aEC' => 'EXTRAIT DU PROCES-VERBAL',
'aFU' => 'PROJET DE FUSION',
'aIF' => 'PROJET APPORT PARTIEL D&quot,ACTIF',
'aJA' => 'JUGEMENT',
'aLA' => 'LETTRE',
'aLB' => 'LISTE DES SIEGES SOCIAUX ANTERIEURS',
'aLC' => 'LETTRE DE DEMISSION',
'aLD' => 'LETTRE DE NOMINATION',
'aLF' => 'LISTE DES SOUSCRIPTEURS',
'aLS' => 'CERTIFICAT DE DEPOT DES FONDS AVEC LISTE DES SOUSCRIPTEURS',
'aNA' => 'NOMINATION DE REPRESENTANT',
'aO9' => 'NOMINATION DE GERANT(S)',
'aOA' => 'ORDONNANCE',
'aOB' => 'ORDONNANCE DE REFERE',
'aOC' => 'ORDONNANCE DU PRESIDENT',
'aOD' => 'ORDONNANCE SUR REQUETE',
'aOE' => 'ORDONNANCE',
'aPA' => 'PROCES VERBAL',
'aPC' => 'PROCES VERBAL D&quot,ASSEMBLEE CONSTITUTIVE',
'aPD' => 'PROCES VERBAL D&quot,ASSEMBLEE DU DIRECTOIRE',
'aPE' => 'PROCES VERBAL D&quot,ASSEMBLEE GENERALE',
'aPF' => 'PROCES VERBAL D&quot,ASSEMBLEE GENERALE EXTRAORDINAIRE',
'aPG' => 'PROCES VERBAL D&quot,ASSEMBLEE GENERALE ORDINAIRE',
'aPH' => 'PROCES VERBAL D&quot,ASSEMBLEE MIXTE',
'aPI' => 'PROCES VERBAL D&quot,ASSEMBLEES ORDINAIRE ET EXTRAORDINAIRE',
'aPL' => 'PROCES VERBAL DIRIGEANT SOCIAL',
'aPM' => 'PROCES VERBAL DU CONSEIL D&quot,ADMINISTRATION',
'aPN' => 'PROCES VERBAL DU CONSEIL DE SURVEILLANCE',
'aPO' => 'PROCES VERBAL DE LA GERANCE',
'aPT' => 'PROJET DE TRAITE D&quot,APPORT',
'aPU' => 'PROJET DE FUSION',
'aPV' => 'PV D&quot,ASSEMBLEE',
'aQ2' => 'CONSTITUTION DE LA SOCIETE',
'aR1' => 'CESSION DE PARTS (OU DONATION)',
'aR4' => 'TRAITE DE FUSION',
'aRA' => 'RAPPORT',
'aRB' => 'RAPPORT COMMISSAIRE AUX COMPTES',
'aRC' => 'RAPPORT COMMISSAIRE FUSION',
'aRE' => 'RAPPORT CR/CPTES TRANSFORM. STE',
'aRG' => 'RAPPORT DU COMMISSAIRE A LA FUSION',
'aRH' => 'RAPPORT DU COMMISSAIRE A LA SCISSION',
'aRI' => 'RAPPORT DU COMMISSAIRE A LA TRANSFORMATION',
'aRK' => 'RAPPORT DU COMMISSAIRE AUX APPORTS',
'aRL' => 'RAPPORT DU COMMISSAIRE AUX APPORTS ET A LA FUSION',
'aRQ' => 'RAPPORT GERANCE',
'aRS' => 'RAPPORT SPECIAL DU CONSEIL D&quot,ADMINISTRATION',
'aRU' => 'PROJET',
'aTA' => 'TRAITE',
'aTB' => 'TRAITE D&quot,APPORT-FUSION',
'aTC' => 'TRAITE DE FUSION',
'aUA' => 'ATTESTATION DU CONJOINT COMMUN EN BIENS',
);
public function init()
{
require_once 'Scores/WsScores.php';
require_once 'common/dates.php';
}
public function preDispatch()
{
$user = new Scores_Utilisateur();
if (!$user->checkModeEdition() && $user->getIdClient()!=1 ){
$this->_forward('perms', 'error');
}
}
/**
* Affichage des différents liens d'administration
*/
public function indexAction()
{
$liens = array(
0 => array(
'libelle' => 'Gestion des clients',
'url' => $this->view->url(array('action'=>'clients')),
),
1 => array(
'libelle' => 'Créer un client',
'url' => $this->view->url(array('action'=>'client')),
),
2 => array(
'libelle' => 'Gestion des commandes',
'url' => $this->view->url(array('action'=>'commandes')),
),
3 => array(
'libelle' => 'Gestion des fichiers nouveautés',
'url' => $this->view->url(array('action'=>'newform')),
),
);
$this->view->assign('Liens', $liens);
}
/**
* Gestion des commandes de l'extranet
* Type : greffes | kbis | graydon | giant
*/
public function commandesAction()
{
$this->view->headScript()->appendFile('/themes/default/scripts/dashboard.js', 'text/javascript');
$request = $this->getRequest();
$type = $request->getParam('type', '');
$date = $request->getParam('date', mktime(0, 0, 0, date('n'), 1, date('Y')));
$user = new Scores_Utilisateur();
$typesCommande = array('kbis', 'greffes');
if (in_array($type, $typesCommande))
{
require_once 'Scores/GestionCommandes.php';
//Valeur pour la sélection des dates
$dateSelect = array();
$dateToday = date('m');
$dateIntervalle = 12;
if ($user->checkModeEdition()){
$dateIntervalle = 24;
}
for($i=$dateToday-$dateIntervalle; $i<=$dateToday; $i++)
{
$dateTime = mktime(0, 0, 0, $i, 1, date('Y'));
$selected = '';
if ($dateTime==$date){
$selected = 'selected';
}
$dateSelect[] = array(
'value' => $dateTime,
'select' => $selected,
'affichage' => date('m/Y', $dateTime)
);
}
$this->view->assign('dateSelect', $dateSelect);
switch($type)
{
case 'kbis':
$num = $request->getParam('num');
$num = str_replace(' ', '', strtoupper($num));
$etat = $request->getParam('etat');
$mode = $request->getParam('mode', 'M');
$modeSelect = array(
'C' => array('value' => 'C', 'select' => '', 'affichage' => 'courrier S&amp;D'),
'M' => array('value' => 'M', 'select' => '', 'affichage' => 'e-mail'),
);
$modeSelect[$mode]['select'] = ' selected';
$gestionCommande = new GestionCommande();
$status = $gestionCommande->listStatus($mode);
$etatSelect = array();
$etatSelect[] = array('value'=>0, 'select'=>'', 'affichage'=>'');
foreach($status as $item){
$select = '';
if ($item['id']==$etat){
$select = ' selected';
}
$etatSelect[] = array('value'=>$item['id'], 'select'=>$select, 'affichage'=>$item['libStatut']);
}
${'status'.$mode} = $gestionCommande->listStatus($mode);
$this->view->assign('etatSelect', $etatSelect);
$this->view->assign('modeSelect', $modeSelect);
$this->view->assign('num', $num);
if (!empty($num)){
if (preg_match('/[0-9]{9}/', $num)){
$listCommandes = $gestionCommande->listCommandesKbisBySiren($num);
} elseif(substr($num,0,1)=='K'){
$listCommandes = $gestionCommande->listCommandesKbisByNum($num);
}
} elseif (!empty($date)) {
$listCommandes = $gestionCommande->listCommandesKbis($date, $etat, $mode);
}
//Parcours de la liste des commandes et vérification document existe
if (count($listCommandes)>0) {
for($i=0;$i<count($listCommandes);$i++)
{
//Etat de la commande
$cmdEtatSelect = array();
$cmdEtatSelect[] = array('value'=>0, 'select'=>'', 'affichage'=>'');
$typeCommande = $listCommandes[$i]->type;
if (isset(${'status'.$typeCommande})){
foreach(${'status'.$typeCommande} as $item){
$select = '';
if ($item['id']==$listCommandes[$i]->statutCommande){
$select = ' selected';
}
$cmdEtatSelect[] = array(
'value' => $item['id'],
'affichage' => $item['libStatut'],
'select' => $select,
);
}
}
$listCommandes[$i]->cmdEtatSelect = $cmdEtatSelect;
}
}
break; //Fin Gestion Kbis
case 'greffes':
$num = $request->getParam('num');
$num = str_replace(' ', '', strtoupper($num));
$etat = $request->getParam('etat');
$mode = $request->getParam('mode', 'G');
$login = $request->getParam('login');
if (empty($mode) && !empty($num)) $mode = substr($num,0,1);
$modeSelect = array(
'G' => array('value' => 'G', 'select' => '', 'affichage' => 'courrier infogreffe'),
'C' => array('value' => 'C', 'select' => '', 'affichage' => 'courrier S&amp;D'),
'M' => array('value' => 'M', 'select' => '', 'affichage' => 'e-mail'),
);
$modeSelect[$mode]['select'] = ' selected';
$gestionCommande = new GestionCommande();
//Liste des états possible pour les commandes
$status = $gestionCommande->listStatus($mode);
$etatSelect = array();
$etatSelect[] = array('value'=>0, 'select'=>'', 'affichage'=>'');
foreach($status as $item){
$select = '';
if ($item['id']==$etat){
$select = ' selected';
}
$etatSelect[] = array(
'value' => $item['id'],
'select' => $select,
'affichage' => $item['libStatut']
);
}
$this->view->assign('etatSelect', $etatSelect);
$this->view->assign('modeSelect', $modeSelect);
$this->view->assign('num', $num);
$this->view->assign('login', $login);
if (!empty($num)){
if (preg_match('/[0-9]{9}/', $num)){
$listCommandes = $gestionCommande->listCommandesGreffeBySiren($num);
} elseif(substr($num,0,1)=='G' || substr($num,0,1)=='C'){
$listCommandes = $gestionCommande->listCommandesGreffeByNum($num);
}
} elseif (!empty($login)) {
$listCommandes = $gestionCommande->listCommandesGreffeByLogin($login, $date);
} elseif (!empty($date)) {
$listCommandes = $gestionCommande->listCommandesGreffe($date, $etat, $mode);
}
//Liste des différents états pour les commandes
${'status'.$mode} = $gestionCommande->listStatus($mode);
//Parcours de la liste des commandes et vérification document existe
if (count($listCommandes)>0)
{
for($i=0;$i<count($listCommandes);$i++)
{
//Etat de la commande
$cmdEtatSelect = array();
$cmdEtatSelect[] = array('value'=>0, 'select'=>'', 'affichage'=>'');
$typeCommande = $listCommandes[$i]->typeCommande;
if (isset(${'status'.$typeCommande})){
foreach(${'status'.$typeCommande} as $item){
$select = '';
if ($item['id']==$listCommandes[$i]->statutCommande){
$select = ' selected';
}
$cmdEtatSelect[] = array(
'value' => $item['id'],
'affichage' => $item['libStatut'],
'select' => $select,
);
}
}
$listCommandes[$i]->cmdEtatSelect = $cmdEtatSelect;
//Lien vers le fichier
$documentLien = '';
$document = '';
$sirenLien = '';
switch($type)
{
case 'greffes':
if (preg_match('/^([0-9a-zA-Z]{2,}-).*?$/', $listCommandes[$i]->refDocument, $matches)){
if (substr($listCommandes[$i]->refDocument,0,3)=='ST-'){
$document = 'DERNIER STATUS &Agrave; JOUR';
} else {
$explodedRef = explode('-', $listCommandes[$i]->refDocument);
$dateref = WDate::dateT('Ymd','d/m/Y',$explodedRef[1]);
$depot = ', Dépôt n°'.$explodedRef[6].' au '.$dateref;
$document = $this->typeActes['a'.substr($listCommandes[$i]->refDocument,0,2)].$depot;
}
$configuration = Zend_Registry::get('configuration');
$refFile = realpath($configuration->path->data).'/'.
$configuration->path->pdf.'/acte-'.
$listCommandes[$i]->siren.'-'.
trim($listCommandes[$i]->refDocument).'.pdf';
if (file_exists($refFile)) {
$document = '<a href="./fichier/pdf/acte-'.
$listCommandes[$i]->siren.'-'.
trim($listCommandes[$i]->refDocument).'.pdf'.
'" target="_blank">'.$document.'</a>';
}
$sirenLien = $this->view->url(array(
'controller' => 'pieces',
'action' => 'actes',
'siret' => $listCommandes[$i]->siren,
), null, true);
} elseif (preg_match('/^([0-9]{4}).*?$/', $listCommandes[$i]->refDocument, $matches)){
$document = 'Bilan de '.$matches[1];
$configuration = Zend_Registry::get('configuration');
$refFile = realpath($configuration->path->data).'/'.
$configuration->path->pdf.'/bilan-'.
$listCommandes[$i]->siren.'-'.
trim($listCommandes[$i]->refDocument).'.pdf';
if(file_exists($refFile)){
$document = '<a href="./fichier/pdf/bilan-'.
$listCommandes[$i]->siren.'-'.
trim($listCommandes[$i]->refDocument).'.pdf'.
'" target="_blank">'.$document.'</a>';
}
$sirenLien = $this->view->url(array(
'controller' => 'pieces',
'action' => 'bilans',
'siret' => $listCommandes[$i]->siren,
), null, true);
}
break;
}
$listCommandes[$i]->document = $document;
$listCommandes[$i]->documentLien = $documentLien;
$listCommandes[$i]->sirenLien = $sirenLien;
}
}
break; //Fin Gestion Greffes
}
$this->view->assign('commandes', $listCommandes);
$this->renderScript('dashboard/commandes-'.$type.'.phtml');
}
//Affichage des liens vers les différents types de commande
$this->view->assign('typesCommande', $typesCommande);
}
/**
* Modification de l'état d'une commande infogreffe
*/
public function commandesetatchangeAction()
{
$this->_helper->layout()->disableLayout();
$this->_helper->viewRenderer->setNoRender(true);
$request = $this->getRequest();
$etat = $request->getParam('etat');
$idCommande = $request->getParam('idCommande');
$mode = $request->getParam('mode', 'C');
$type = $request->getParam('type');
require_once 'Scores/GestionCommandes.php';
$commande = new GestionCommande();
if ($type == 'kbis'){
echo $commande->changeEtatKbis($idCommande, $etat, $mode);
} elseif ($type == 'greffe') {
echo $commande->changeEtatGreffe($idCommande, $etat, $mode);
}
}
/**
* Affichage de la raison sociale à partir du siren
*/
public function rsAction()
{
$this->_helper->layout()->disableLayout();
$this->_helper->viewRenderer->setNoRender(true);
$request = $this->getRequest();
$siren = $request->getParam('siren');
$ws = new WsScores();
$infos = $ws->getIdentite($siren);
if ($infos==false) {
echo 'Erreur';
} else {
echo $infos->Nom;
}
}
/**
* Génération automatique du courrier PDF / ODT
*/
public function courrierAction()
{
$this->_helper->layout()->disableLayout();
$this->_helper->viewRenderer->setNoRender(true);
$request = $this->getRequest();
$numCommande = $request->getParam('commande');
require_once 'GenCourrier/GenCourrier.php';
$courrier = new GenCourrier($numCommande);
$courrier->computeOdt();
}
/**
* Liste les clients
*/
public function clientsAction()
{
$user = new Scores_Utilisateur();
if ( !$user->isSuperAdmin() ){
$this->_forward('perms', 'error');
}
$this->view->headScript()->appendFile('/themes/default/scripts/dashboard.js', 'text/javascript');
$ws = new WsScores();
$reponse = $ws->getListeClients();
$listeClients = $reponse->result->item;
$reponse = $ws->getListeDroits();
$wsdroits = $reponse->item;
$this->view->assign('ListeClients', $listeClients);
$this->view->assign('wsdroits', $wsdroits);
}
/**
* Edition ou création d'un nouveau client
*/
public function clientAction()
{
$user = new Scores_Utilisateur();
if ( !$user->isSuperAdmin() ){
$this->_forward('perms', 'error');
}
$this->view->headScript()->appendFile('/libs/checkbox/jquery.checkbox.js', 'text/javascript');
$this->view->headLink()->appendStylesheet('/libs/checkbox/jquery.checkbox.css', 'all');
$request = $this->getRequest();
$idClient = $request->getParam('idClient', false);
$titre = 'CREATION NOUVEAU CLIENT';
$submitValue = 'Créer le client';
if ($idClient!==false){
$ws = new WsScores();
$reponse = $ws->getListeClients($idClient);
$InfosClient = $reponse->result->item[0];
$titre = 'EDITION CLIENT';
$submitValue = 'Modifier le client';
}
$ws = new WsScores();
$reponse = $ws->getListeDroits();
$wsdroits = $reponse->item;
$this->view->assign('idClient', $idClient);
$this->view->assign('InfosClient', $InfosClient);
$this->view->assign('titre', $titre);
$this->view->assign('submitValue', $submitValue);
$this->view->assign('wsdroits', $wsdroits);
}
/**
* Enregistre les informations sur le client
*/
public function clientsaveAction()
{
$request = $this->getRequest();
$infos = $request->getParams();
$ws = new WsScores();
$reponse = $ws->setClient($infos);
if ($reponse->error->errnum==1) {
$this->_forward('client', 'dashboard', null, array('idClient' => $infos['idClient']));
}
$this->view->assign('infos', $request->getParams());
}
/**
* Affichage du formulaire pour l'envoi des fichiers concernant les nouveautées
*/
public function newformAction()
{
//Nothing
}
/**
* Réception du fichier des nouveautés et enregistrement des informations
*/
public function newuploadAction()
{
$this->_helper->layout()->disableLayout();
$this->_helper->viewRenderer->setNoRender(true);
if ( isset($_FILES) && count($_FILES)==1 ) {
$config = new Zend_Config_Ini(APPLICATION_PATH . '/configs/configuration.ini', 'path');
$path = realpath($config->data).'/nouveautes';
if(!file_exists($path)) mkdir($path);
$tmp_name = $_FILES['fichier']['tmp_name'];
$n = $_FILES['fichier']['name'];
$name = uniqid('new');
$extValide = array('pdf');
$extension = strrchr($n,'.');
$extension = substr($extension,1);
//Vérifier l'extension du fichier
if(!in_array($extension, $extValide)){
echo "Extension de fichier incorrect !";
} elseif (move_uploaded_file($tmp_name, $path.'/'.$name.'.'.$extension)){
$request = $this->getRequest();
//Enregistrement des informations
$data = array(
'categorie' => $request->getParam('categorie'),
'intitule' => $request->getParam('intitule'),
'date' => $request->getParam('date'),
'fichier' => $name.'.'.$extension,
);
$new = new Application_Model_Nouveautes();
try {
$new->insert($data);
echo "Fichier enregistré";
} catch(Exception $e) {
echo "Erreur lors de l'enregistrement";
if ( file_exists($path.'/'.$name.'.'.$extension) ) unlink($path.'/'.$name.'.'.$extension);
}
} else {
echo "Erreur";
}
}
}
public function newprogressAction()
{
$this->_helper->layout()->disableLayout();
$this->_helper->viewRenderer->setNoRender(true);
$request = $this->getRequest();
$key = $request->getParam('key', '');
if (!empty($key)) {
//$rep sera égal à false si la clef n'existe pas dans le cache apc
$rep = apc_fetch('upload_'.$key);
echo json_encode($rep);
}
}
}