Bonjour à tous,

J'ai créé une page php permettant de faire une recherche multicritères contenant pour filtrer mes résultats:

* 1 plage de date (les dates sont positionnées par défaut à une semaine avant et apres par rapport à la date du jour pour eviter de retourner tout les résultats car ils sont nombreux)
* 3 Combobox

Lorsque je veux filtrer sur une plage de dates et pour un client donné et/ou un statut, la pagination fonctionne (calcul et affichage du nb de page est correct), la premiere page affichée est correcte.
Dès que je passe sur la page 2, là, mon critère de filtre sur le client n'est pas conservés sauf la plage de date.

J'ai cherché en utilisant les $_SESSION en php mais je dois me rendre à l’évidence je n'en fais pas un bon usage.

Est ce que vous pourriez m'aider svp?

Ci dessous le code de ma page:

Code : Sélectionner tout - Visualiser dans une fenêtre à part
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
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
 
<?php
    session_start();
 
//initialisation des variables de sessions
include 'header.php';
include 'db_connect.php';
 
header('Content-type: text/html; charset=iso-8859-1');
 
//$stardate="";
//$enddate="";
 
//requete combo client
$sql_clt="select id,name from products where isactive = '1'";
 
//requete combo sev
$sql_sev="select id, value from bug_severity";
 
//requete status
$sql_status="SELECT * FROM bug_status where is_open='1' order by id";
 
$sql="SELECT
    `bugs_activity`.`bug_id` AS `bug_id`,
    `products`.`name` AS `client`,
    `bugs`.`version` AS  `version`,
    `bugs`.`cf_platforme` AS `plateforme`,
    `bugs_activity`.`bug_when` AS `bug_when`,
    `bugs`.`product_id` AS `product_id`,
    `bug_severity`.`id` AS `severity_id`,
    `bugs`.`bug_severity` AS `severité`,
    `bug_status`.`id` AS `id_status`,
    `bugs`.`bug_status` AS `ticket_last_status`,
    `bugs`.`delta_ts` AS `last_action_date`,
    COUNT(*) AS count
FROM
     `bugs_activity`,
	 `bugs`,
     `bug_status`,
     `bug_severity`,
     `products`
WHERE
     `bugs`.`product_id` = `products`.`id`
     AND `bug_status`.`value` = `bugs`.`bug_status`
     AND  `bug_severity`.`value` = `bugs`.`bug_severity`
     AND `bugs`.`bug_id` = `bugs_activity`.`bug_id`
     AND `bugs_activity`.`bug_when` IS NOT NULL
     AND `bugs_activity`.`added` = 'REOPENED'
     AND `bugs`.`bug_status` not in ('DELIVERED','CLOSED')";
 
//fixe les dates à -1 semaine avant et apres la date du jour
//filtrage sur les dates pour éviter de retourner toutes les datas.
 
if(!isset($_SESSION['startdate'])){
        $_SESSION['startdate']=date('Y-m-d', strtotime("-7 days"));
    }
 
if(!isset($_SESSION['enddate'])){    
        $_SESSION['enddate']=date('Y-m-d', strtotime("+7 days"));;
}
 
//fin filtrage pour éviter de retourner toutes les datas
 
//clique sur "Filtrer"
if(isset($_POST['submit'])){
        //$_SESSION est vide   
    if(isset($_SESSION['startdate'])){
            $_SESSION['startdate']=$_POST['from_date'];
        }
 
        //date de fin
        if(isset($_SESSION['enddate'])){
            $_SESSION['enddate']=$_POST['to_date'];
        }
 
        //client
        if(isset($_POST['idclient'])){            
            $_SESSION['idclient']=$_POST['idclient'];          
            $sql .= " AND `bugs`.`product_id`='".$_SESSION['idclient']."'";
 
            echo "id select :".$_SESSION['idclient']."'";
        }
 
        //severite
        if(isset($_POST['idsev'])){          
            $_SESSION['idsev']=$_POST['idsev'];
            //ajout de la condition sql de filtrage sur l'id de severite
            $sql .= " AND `bug_severity`.`id`='". $_SESSION['idsev'] ."'";
        }
 
        //filtre sur le Statut
        if(isset($_POST['idstatus'])){           
            $_SESSION['idstatus']=$_POST['idstatus'];
            //ajout de la condition sql de filtrage sur l'id de severite
            $sql .= " AND `bug_status`.`id`= '".$_SESSION['idstatus']."'"; 
 
        }
}
 
$sql .= " AND `bugs_activity`.`bug_when` BETWEEN '". $_SESSION['startdate']."' AND '". $_SESSION['enddate']."'";
 
$sql .= " GROUP BY `bugs_activity`.`bug_id`";
$sql .= " ORDER BY BUG_ID ASC";
 
?>
 
<!DOCTYPE html>
<html>
    <head>
        <meta http-equiv="X-UA-Compatible" content="IE=edge">
        <link rel="stylesheet" href="css/style.css" type="text/css">
        <link rel="stylesheet" href="css/nav.css" type="text/css">
        <link rel="stylesheet" href="css/jquery-ui.css" type="text/css">
        <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/font-awesome/4.5.0/css/font-awesome.min.css">
        <script type = "text/javascript" src="js/jquery-3.3.1.js"></script>
        <script type = "text/javascript" src="js/jquery-ui.js"></script>
        <script type = "text/javascript" src="js/jquery.tablesorter.js"></script>
        <script type = "text/javascript" src="js/jquery.tablesorter.min.js"></script>       
        <script>
    		$(document).ready(function(){
       		 	$.datepicker.setDefaults({
            		dateFormat: 'yy-mm-dd',
            		changeYear:true,
            		changeMonth:true
        		});
        		$(function(){
            		$("#from_date").datepicker();
            		$("#to_date").datepicker();
        		});
        		$('#filterbutton').click(function(){
 
           	 		var from_date = $('#from_date').val();
            		var to_date = $('#to_date').val();
 
            		if(from_date != '' && to_date != ''){	
 
            		} 
            		else{ 
                 		alert("Please Select Date"); 
            		}
        		});
    		});
		</script>
        <title>Tickets Demo</title>
    </head>
 			<div id="cssmenu">
  				<ul>
     				<li class="active"><a href="#" target="_blank"><span><i class="fa fa-fw fa-home"></i> Home</span></a></li>
     				<li class="has-sub"><a href="#"><span><i class="fa fa-fw fa-bars"></i> Reports</span></a>
        				<ul>
           					<li><a href="#"><span>Par Client</span></a></li>
           					<li><a href="#"><span>Par Severite</span></a></li>
        				</ul>
     				</li>
 				 </ul>
		</div>
    <body>
        <div id="container">     
            <form method="post" action="index.php">   
            <!-- plage de date -->
		    <div class="group_txt"> 
                        <label>Du:</label><input id="from_date"  type="text" placeholder="Date Debut" value="<?php echo $_SESSION['startdate'] ?>" name="from_date"> &nbsp;
                        <label>Au: </label><input id="to_date" type="text" placeholder="Date Fin" value="<?php echo $_SESSION['enddate']?>"   name="to_date"> &nbsp;
                    </div>
                <!-- Remplissage de Combo client -->
            		<div class="select-clt">
            			<select id="idclient" name="idclient" >
            				<option value="0" disabled selected>---Client---</option>
                    			<?php
                                    $stmt=$conn->prepare($sql_clt);
                                    $stmt->execute();
                                    $clients=$stmt->fetchAll(PDO::FETCH_ASSOC);
 
                                    foreach($clients as $client): ?>
                                		<option value="<?php echo $client['id'] ?> selected"><?php echo $client['name']?>                   
                          			<?php endforeach; ?>
            			</select>
            		</div>&nbsp;                               
            <!-- Remplissage de Combo "severite" -->
            		<div class="select-sev">
            			<select id="idsev" name="idsev">
                			<option value = "" disabled selected>---Severite---</option>
                    			<?php
                                    $stmt=$conn->prepare($sql_sev);
                                    $stmt->execute();
                                    $severity=$stmt->fetchAll(PDO::FETCH_ASSOC);
 
                                    foreach($severity as $sev): ?>
                                		<option value="<?php echo $sev['id'] ?>"><?php echo $sev['value']  ?>
                          			<?php endforeach; ?>                         			
            			</select>
           			</div>&nbsp;
            <!-- Remplissage de Combo "STATUS" -->
             		<div class="select-sev">
            			<select id="idstatus" name="idstatus">
                			<option value = "" disabled selected>---Status---</option>
                    			<?php
                    			    $stmt=$conn->prepare($sql_status);
                                    $stmt->execute();
                                    $status_list=$stmt->fetchAll(PDO::FETCH_ASSOC);
 
                                    foreach($status_list as $status): ?>
                                		<option value="<?php echo $status['id'] ?>"><?php echo $status['value']  ?>
                          			<?php endforeach; ?>            			
            			</select>&nbsp;
           			</div>
            		<input id="filterbutton" type="submit" value="Filtrer" name="submit">&nbsp;&nbsp;
           			<input id="resetbutton" type="submit" value="Reset" name="resetbutton" onclick="this.form.reset();"><br><br>
            </form> 
            <table id="table_data" class="data-table">
                <thead>
                    <tr>
                        <th>TICKET</th>
                        <th>CLIENT</th>
                        <th>VERSION</th>                        
                        <th>PLATEFORME</th>
                        <th>SEVERITE</th>              
                        <th>DATE_REOPENED</th>
                        <th>STATUT_ACTUEL</th>
                        <th>DATE_DERNIERE_ACTION</th>                        
                        <th>NB_REOPENED</th>
                    </tr>
                </thead>
                <tbody>                        
                    <?php
                       $record_per_page=10;
                       $sql_data=$paginate->paging($sql,$record_per_page);
                       $paginate->dataview($sql_data);
                    ?>
                </tbody>
            </table><br>
            </div>
 
             <div class="paginate">
                    <?php $paginate->pagelink($sql, $record_per_page);    ?>
             </div> 
    </body>
</html>
A travers tout ce que j'ai pu voir sur le net sur le sujet, il faudrait que j'utilise un array() dans lequel je place mes variables mais
j'avoue ne pas trop voir comment l'implementer dans mon cas.

Merci à vous,