Par rapport a la demande qu'on ma faite je préfère faire des onChange après le problème c'est que a la création du deuxieme menu deroulant sa bug en gros rien ne s'affiche et j'arrive meme pas a voir le deuxieme menu deroulant
Version imprimable
Par rapport a la demande qu'on ma faite je préfère faire des onChange après le problème c'est que a la création du deuxieme menu deroulant sa bug en gros rien ne s'affiche et j'arrive meme pas a voir le deuxieme menu deroulant
Faites comme au depart à partir de mon exemple votre premier cas qui marche, on va voir pour le second et autres menu deroulant
Pour mon premier cas j'ai fais comme ton exemple sa fonctionne a merveille avec un seul menu déroulant, maintenant je suis prêt a entamer la seconde partie qui est de pouvoir mettre deux ou plusieurs menu déroulant
Quand vous ajouter "juste" le second menu déroulant, vous n'avez pas d'erreur ?
vous pouvez poster le fichier view ?
il va falloir maintenant prendre en compte le deuxieme menu deroulant dans votre fichier main.php et aussi dans la requete sql
vous pouvez poster le fichier main.php et le fichier model_maTable.php concerné ?
J'ai reussi a faire mon deuxieme filtre mais le probleme c'est que j'arrive pas a faire correspondre mes filtres
Exemple : le premier filtre je choisi 2018, sa m'affiche le camembert avec toute les données ayant 2018 dans ma base de données mais quand je vais choisir le mois sur la deuxieme liste de choix plus rien ne fonctionne
Peut tu m'aider ?
Bonjour
Vous pouvez poster votre fichier main.php (du module), le fichier view appelé ainsi que le fichier model pour que je puisse regarder la coherence voir reproduire l'idee sur mon pc ?
Mon view :
Code:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43 <?php $oForm=new plugin_form(); ?> <form action="" method="POST"> Année <?php echo $oForm->getSelect('datejours',$this->tstatistique,array('onChange'=>'this.parentNode.submit()'))?> Mois <?php echo $oForm->getSelect('datejours',$this->tstatistique2,array('onChange'=>'this.parentNode.submit()'))?> </form> <p> </p> <?php if(isset($this->oChartPie) ):?> <h1><center>Total heures par demandeur </center></h1><br><br> <table class="table"> <tr> <th>Demandeur</th> <th>Total</th> </tr> <?php foreach($this->tData as $data):?> <?php list($demandeur,$total)=$data;?> <tr> <td><?php echo $demandeur?></td> <td><?php echo $total?></td> </tr> <?php endforeach;?> </table> <p> </p> <center><?php echo $this->oChartPie->show()?></center> <?php endif;?>
Mon model_mission
Code:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54 public function findbyAnnee(){ return $this->findManySimple('SELECT DISTINCT EXTRACT(YEAR FROM datejours) AS annee FROM '.$this->sTable); } public function findbyMois(){ return $this->findManySimple('SELECT DISTINCT EXTRACT(MONTH FROM datejours) AS mois FROM '.$this->sTable); } public function getSelect(){ $tab=$this->findbyAnnee(); $tSelect=array(null); if($tab){ foreach($tab as $oRow){ $tSelect[ $oRow->annee ]=$oRow->annee; } } return $tSelect; } public function getSelect2(){ $tab=$this->findbyMois(); $tSelect=array(null); if($tab){ foreach($tab as $oRow){ $tSelect[ $oRow->mois ]=$oRow->mois; } } return $tSelect; } public function listjourtotal($magId, $datejours){ return $this->findMany(' SELECT DISTINCT SEC_TO_TIME(SUM(DISTINCT TIME_TO_SEC( heurejourtotal))) as totals, demandeur FROM mission INNER JOIN user ON mission.magasins_id=user.magasin_id WHERE etat != 5 AND etat != 1 AND etat != 6 AND magasin_id=? AND YEAR(datejours)=? GROUP BY demandeur ',$magId, $datejours); }
Mon main :
Code:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42 public function _statistique(){ $tstatistique=model_mission::getInstance()->getSelect(); $tstatistique2=model_mission::getInstance()->getSelect2(); $oView=new _view('statistiques::statistique'); $oView->tstatistique=$tstatistique; $oView->tstatistique2=$tstatistique2; $tjours=$this->getResultatJour( _root::getAuth()->getAccount()->magasin_id, _root::getParam('datejours') ); if($tjours){ $tData=array(); foreach($tjours as $ojour){ $tData[]=array($ojour->demandeur, $ojour->totals); } $oChartPie=new plugin_chart('PIE',400,200); $oChartPie->setTextSizeLegend('12px arial'); $oChartPie->setData($tData); //coordonnees de la legende $oChartPie->setCoordLegend(220,60); $oView->oChartPie=$oChartPie; $oView->tData=$tData; } $this->oLayout->add('main',$oView); public function getResultatJour($magId, $datejours){ if( _root::getRequest()->isPost() == false ){ return null; } return model_mission::getInstance()->listjourtotal(_root::getAuth()->getAccount()->magasin_id, $datejours); }
Voici mes différents fichier
Le problème vient de la logique de la vue , vous avez écrit:
Code:
1
2
3
4 Année <?php echo $oForm->getSelect('datejours',$this->tstatistique,array('onChange'=>'this.parentNode.submit()'))?> Mois <?php echo $oForm->getSelect('datejours',$this->tstatistique2,array('onChange'=>'this.parentNode.submit()'))?>
Pour rappel, le premier paramètre est le nom du champ du menu deroulant, alors que là vous avez deux fois "datejours"
il faut que vous mettiez par exemple pour le premier dateAnnee, et pour le second dateMois
a la base l'idée c'est de concatener annnee et mois, c'est ça ?
il faudrait donc par exemple faire
Code:
1
2
3
4 Année <?php echo $oForm->getSelect('dateAnnee',$this->tstatistique,array('onChange'=>'this.parentNode.submit()'))?> Mois <?php echo $oForm->getSelect('dateMois',$this->tstatistique2,array('onChange'=>'this.parentNode.submit()'))?>
et dans le fichier main.php
remplacer
parCode:
1
2 $tjours=$this->getResultatJour( _root::getAuth()->getAccount()->magasin_id, _root::getParam('datejours') );
Code:
1
2
3 $sDate= _root::getParam('dateAnnee'). _root::getParam('dateMois'); $tjours=$this->getResultatJour( _root::getAuth()->getAccount()->magasin_id,$sDate );