303 lines
9.1 KiB
PHP
303 lines
9.1 KiB
PHP
<?php
|
|
class DashboardController extends Zend_Controller_Action
|
|
{
|
|
public function init()
|
|
{
|
|
$this->view->headLink()->appendStylesheet('/themes/default/styles/dashboard.css', 'all');
|
|
$this->view->headScript()->appendFile('/themes/default/scripts/dashboard.js', 'text/javascript');
|
|
}
|
|
|
|
public function indexAction()
|
|
{
|
|
$auth = Zend_Auth::getInstance();
|
|
$user = $auth->getIdentity();
|
|
|
|
$criteresM = new Application_Model_Criteres();
|
|
$sql = $criteresM->select()
|
|
->from($criteresM, array('id', 'reference', 'dateAjout'))
|
|
->where("idClient = ?", $user->idClient)
|
|
->where("login = ?", $user->username)
|
|
->order('dateAjout DESC')
|
|
->limit(5);
|
|
|
|
$rows = $criteresM->fetchAll($sql);
|
|
|
|
//
|
|
$results = array();
|
|
$comptagesM = new Application_Model_Comptages();
|
|
foreach($rows->toArray() as $item)
|
|
{
|
|
$info = array(
|
|
'id' => $item['id'],
|
|
'reference' => $item['reference'],
|
|
'dateCriteres' => $item['dateAjout'],
|
|
);
|
|
//Recherche des comptages
|
|
$sql = $comptagesM->select()
|
|
->from($comptagesM, array('resultat', 'uniteInsee', "DATE_FORMAT(dateAjout, '%Y/%m/%d %H:%i:%s') as dateAjout"))
|
|
->where('idDefinition = ?', $item['id'])
|
|
->order('dateAjout DESC')->limit(1);
|
|
$comptage = $comptagesM->fetchAll($sql)->toArray();
|
|
|
|
if (count($comptage)>0){
|
|
$info['resultat'] = $comptage[0]['resultat'];
|
|
$info['uniteInsee'] = $comptage[0]['uniteInsee'];
|
|
$info['dateComptage'] = $comptage[0]['dateAjout'];
|
|
}
|
|
|
|
$results[] = $info;
|
|
}
|
|
|
|
$this->view->comptages = $results;
|
|
|
|
//
|
|
$enrichissements = new Application_Model_EnrichissementIdentifiants();
|
|
$sql = $enrichissements->select()
|
|
->setIntegrityCheck(false)
|
|
->from(
|
|
array('i' => 'enrichissement_identifiants'),
|
|
array('id', 'reference', 'fichier', 'nbLigneTotales', 'nbLigneTraites', 'error', 'dateAdded', 'dateStart', 'dateStop')
|
|
)
|
|
->join(
|
|
array('c' => 'criteres'), 'i.idCriteres = c.id',
|
|
array('')
|
|
)
|
|
->where('c.idClient = ?', $user->idClient)
|
|
->where('c.login = ?', $user->username)
|
|
->order('i.dateAdded DESC');
|
|
|
|
$this->view->enrichissements = $enrichissements->fetchAll($sql);
|
|
|
|
}
|
|
|
|
public function ciblagesAction()
|
|
{
|
|
|
|
$request = $this->getRequest();
|
|
$page = $request->getParam('page', 1);
|
|
|
|
|
|
$offset = 20;
|
|
//Liste des ciblages par paquet de n
|
|
$auth = Zend_Auth::getInstance();
|
|
$user = $auth->getIdentity();
|
|
|
|
$criteresM = new Application_Model_Criteres();
|
|
|
|
//Compter le nombre de page
|
|
$sql = $criteresM->select()
|
|
->from($criteresM, array('nb' => 'COUNT(*)'))
|
|
->where("idClient = ?", $user->idClient)
|
|
->where("login = ?", $user->username);
|
|
$count = $criteresM->fetchRow($sql);
|
|
$nbCiblage = $count->nb;
|
|
|
|
//Récupérer les informations
|
|
$position = ($page-1)*$offset+1;
|
|
$sql = $criteresM->select()
|
|
->from($criteresM, array('id', 'reference', 'dateAjout'))
|
|
->where("idClient = ?", $user->idClient)
|
|
->where("login = ?", $user->username)
|
|
->order('dateAjout DESC')
|
|
->limitPage($position, $offset);
|
|
|
|
$rows = $criteresM->fetchAll($sql);
|
|
$results = array();
|
|
$comptagesM = new Application_Model_Comptages();
|
|
foreach($rows->toArray() as $item)
|
|
{
|
|
$info = array(
|
|
'id' => $item['id'],
|
|
'reference' => $item['reference'],
|
|
'dateCriteres' => $item['dateAjout'],
|
|
);
|
|
//Recherche des comptages
|
|
$sql = $comptagesM->select()
|
|
->from($comptagesM, array('resultat', 'uniteInsee', "DATE_FORMAT(dateAjout, '%d/%m/%Y %H:%i:%s') as dateAjout"))
|
|
->where('idDefinition = ?', $item['id'])
|
|
->order('dateAjout DESC')->limit(1);
|
|
$comptage = $comptagesM->fetchAll($sql)->toArray();
|
|
|
|
if (count($comptage)>0){
|
|
$info['resultat'] = $comptage[0]['resultat'];
|
|
$info['uniteInsee'] = $comptage[0]['uniteInsee'];
|
|
$info['dateComptage'] = $comptage[0]['dateAjout'];
|
|
}
|
|
|
|
$results[] = $info;
|
|
}
|
|
$this->view->ciblages = $results;
|
|
$this->view->nbCiblage = $nbCiblage;
|
|
|
|
}
|
|
|
|
public function ciblageAction()
|
|
{
|
|
$request = $this->getRequest();
|
|
$auth = Zend_Auth::getInstance();
|
|
$user = $auth->getIdentity();
|
|
|
|
$comptageId = $request->getParam('id');
|
|
|
|
$fields = new Scores_Fields();
|
|
|
|
//Lecture des paramètres du ciblage
|
|
$criteresM = new Application_Model_Criteres();
|
|
$sql = $criteresM->select()
|
|
->where('idClient = ?', $user->idClient)
|
|
->where('login = ?', $user->username)
|
|
->where('id = ?', $comptageId);
|
|
$criteres = $criteresM->fetchRow($sql)->toArray();
|
|
|
|
|
|
$infosCriteres = array();
|
|
if ($criteres != null) {
|
|
|
|
$decodeCriteres = json_decode($criteres['criteres'], true);
|
|
|
|
//Construction affichage des critères
|
|
foreach ( $decodeCriteres as $key => $item ) {
|
|
|
|
$inValue = $fields->getValueLabel($key, $item['in']);
|
|
$exValue = $fields->getValueLabel($key, $item['ex']);
|
|
|
|
//Add label to struct for display
|
|
$infosCriteres[] = array(
|
|
'label' => $fields->getLabel($key),
|
|
'in' => $inValue,
|
|
'ex' => $exValue,
|
|
);
|
|
}
|
|
|
|
//Lecture des comptages
|
|
$comptageM = new Application_Model_Comptages();
|
|
$sql = $comptageM->select()
|
|
->where('idDefinition = ?', $comptageId)
|
|
->order('dateAjout DESC');
|
|
$comptages = $comptageM->fetchAll($sql)->toArray();
|
|
Zend_Registry::get('firebug')->info($comptages[0]);
|
|
|
|
//Lecture enrichissement existe
|
|
|
|
//Affichage
|
|
$this->view->comptageId = $comptageId;
|
|
$this->view->criteres = $infosCriteres;
|
|
$this->view->comptages = $comptages;
|
|
$this->view->enrichissements = $enrichissement;
|
|
|
|
}
|
|
}
|
|
|
|
public function rcomptageAction()
|
|
{
|
|
$this->_helper->layout()->disableLayout();
|
|
$this->_helper->viewRenderer->setNoRender(true);
|
|
|
|
$request = $this->getRequest();
|
|
$q = $request->getParam('q');
|
|
$auth = Zend_Auth::getInstance();
|
|
$user = $auth->getIdentity();
|
|
|
|
$criteresM = new Application_Model_Criteres();
|
|
$sql = $criteresM->select()
|
|
->from($criteresM, array('id', 'reference', "DATE_FORMAT(dateAjout, '%d/%m/%Y') as date"))
|
|
->where("idClient = ?", $user->idClient)
|
|
->where("login = ?", $user->username)
|
|
->where("reference LIKE ?", $q.'%');
|
|
$rows = $criteresM->fetchAll($sql);
|
|
if (count($rows)>0){
|
|
$separator = " , ";
|
|
foreach ($rows as $item) {
|
|
$output[] = array(
|
|
'label' => $item->reference . $separator . $item->date,
|
|
'value' => $item->reference,
|
|
'url' => $this->view->url(array('controller'=>'dashboard', 'action'=>'ciblage', 'id'=>$item->id)),
|
|
);
|
|
}
|
|
}
|
|
echo json_encode($output);
|
|
}
|
|
|
|
/**
|
|
* Liste des enrichissements
|
|
*/
|
|
public function enrichissementsAction()
|
|
{
|
|
$auth = Zend_Auth::getInstance();
|
|
$user = $auth->getIdentity();
|
|
//Criteres => Comptages (last) => enrichissement_identifiants => enrichissement_commandes
|
|
$enrichissementsM = new Application_Model_EnrichissementIdentifiants();
|
|
|
|
// Pending
|
|
$sql = $enrichissementsM->select()
|
|
->setIntegrityCheck(false)
|
|
->from(
|
|
array('i' => 'enrichissement_identifiants'),
|
|
array('id', 'reference', 'fichier', 'nbLigneTotales', 'nbLigneTraites', 'error', 'dateAdded', 'dateStart', 'dateStop')
|
|
)
|
|
->join(
|
|
array('c' => 'comptages'), 'i.idComptage = c.id',
|
|
array('')
|
|
)
|
|
->join(
|
|
array('criteres' => 'criteres'), 'i.idCriteres = criteres.id',
|
|
array('')
|
|
);
|
|
$sql->where('i.dateStop = ?', 0)
|
|
->where('criteres.idClient = ?', $user->idClient)
|
|
->where('criteres.login = ?', $user->username);
|
|
$encours = $enrichissementsM->fetchAll($sql);
|
|
$this->view->encours = $encours;
|
|
|
|
// Impossible de copie la varible issu d'un select car sinon elle conserve les meme propriété que sont parent
|
|
// donc les selects... donc obliger de faire deux requetes pour le moment.
|
|
$sql = $enrichissementsM->select()
|
|
->setIntegrityCheck(false)
|
|
->from(
|
|
array('i' => 'enrichissement_identifiants'),
|
|
array('id', 'reference', 'fichier', 'nbLigneTotales', 'nbLigneTraites', 'error', 'dateAdded', 'dateStart', 'dateStop')
|
|
)
|
|
->join(
|
|
array('c' => 'comptages'), 'i.idComptage = c.id',
|
|
array('')
|
|
)
|
|
->join(
|
|
array('criteres' => 'criteres'), 'i.idCriteres = criteres.id',
|
|
array('')
|
|
);
|
|
$sql->where('criteres.idClient = ?', $user->idClient)
|
|
->where('criteres.login = ?', $user->username)
|
|
->where('i.dateStart != ?', '0000-00-00 00:00:00');
|
|
$fini = $enrichissementsM->fetchAll($sql)->toArray();
|
|
$this->view->fini = $fini;
|
|
$this->view->pathfile = $config->path->data;
|
|
}
|
|
|
|
/**
|
|
* Détail d'un enrichissment
|
|
*/
|
|
public function enrichissementAction()
|
|
{
|
|
|
|
}
|
|
|
|
public function configurationAction()
|
|
{
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|