391 lines
		
	
	
		
			14 KiB
		
	
	
	
		
			PHP
		
	
	
	
			
		
		
	
	
			391 lines
		
	
	
		
			14 KiB
		
	
	
	
		
			PHP
		
	
	
	
| <link rel="stylesheet" href="<?php echo base_url('bower_components/jvectormap/jquery-jvectormap.css') ?>">
 | ||
| <link rel="stylesheet" href="<?php echo base_url('bower_components/bootstrap-datepicker/dist/css/bootstrap-datepicker.min.css') ?>">
 | ||
| <link rel="stylesheet" href="<?php echo base_url('bower_components/bootstrap-daterangepicker/daterangepicker.css') ?>">
 | ||
| <link rel="stylesheet" href="<?php echo base_url('plugins/bootstrap-wysihtml5/bootstrap3-wysihtml5.min.css') ?>">
 | ||
| <script src="<?php echo base_url('bower_components/chart.js/Chart.js') ?>"></script>
 | ||
| <link rel="stylesheet" href="<?php echo base_url('bower_components/datatables.net-bs/css/dataTables.bootstrap.min.css') ?>">
 | ||
| 
 | ||
| <?php
 | ||
|     function convertDate($date){
 | ||
|         $month = null;
 | ||
|         switch ($date) {
 | ||
|             case "Jan":
 | ||
|                 $month = 1;
 | ||
|                 break;
 | ||
|             case "Feb":
 | ||
|                 $month = 2;
 | ||
|                 break;
 | ||
|             case "Mar":
 | ||
|                 $month = 3;
 | ||
|                 break;
 | ||
|             case "Apr":
 | ||
|                 $month = 4;
 | ||
|                 break;
 | ||
|             case "May":
 | ||
|                 $month = 5;
 | ||
|                 break;
 | ||
|             case "Jun":
 | ||
|                 $month = 6;
 | ||
|                 break;
 | ||
|             case "Jul":
 | ||
|                 $month = 7;
 | ||
|                 break;
 | ||
|             case "Aug":
 | ||
|                 $month = 8;
 | ||
|                 break;
 | ||
|             case "Sep":
 | ||
|                 $month = 9;
 | ||
|                 break;
 | ||
|             case "Oct":
 | ||
|                 $month = 10;
 | ||
|                 break;
 | ||
|             case "Nov":
 | ||
|                 $month = 11;
 | ||
|                 break;
 | ||
|             case "Dec":
 | ||
|                 $month = 12;
 | ||
|                 break;
 | ||
|         }
 | ||
|         return $month;
 | ||
|     }
 | ||
| 
 | ||
|     $month = time();
 | ||
|     $months[]=convertDate(date("M"));
 | ||
|     $label_months [] = date("M")." ".date("Y");
 | ||
|     $years[]= date("Y");
 | ||
|     for ($i = 1; $i <= 11; $i++) {
 | ||
|         $month = strtotime('last month', $month);
 | ||
|         $months [] = convertDate(date("M", $month));
 | ||
|         $years[] = date("Y", $month);
 | ||
|         $label_months [] = date("M", $month)." ".date("Y", $month);
 | ||
|     }
 | ||
| 
 | ||
|     /**
 | ||
|     ** Retraits
 | ||
|     **/
 | ||
|     $date = date("Y");
 | ||
| 
 | ||
|     $retraits_data[] = '';
 | ||
|     $retraits_data =array();
 | ||
|     for ($i = 1; $i <= 12; $i++) {
 | ||
|     	$retraits_query_mounth = array_filter($transactions, function ($trans) use ($i, $months ,$years){
 | ||
| 			$month = date("m",strtotime($trans->date));
 | ||
| 			$year = date("Y",strtotime($trans->date));
 | ||
|     		return $month == $months[$i-1] && $year == $years[$i-1] && $trans->type == 'debit' ;
 | ||
| 		});
 | ||
|         $retraits_data[] = sizeof($retraits_query_mounth);
 | ||
|     }
 | ||
| 
 | ||
| 	$startDate = (new DateTime('01-'.$months[11].'-'.$years[11]))-> format('Y-m-d H:i:s');
 | ||
| 	$endDate = date_create_from_format ('m/Y',$months[0].'/'.$years[0])-> format('Y-m-d H:i:s');
 | ||
| 
 | ||
| 	$retraits = array_filter($transactions, function ($trans) use ($i, $endDate ,$startDate){
 | ||
| 		$date = strtotime($trans->date);
 | ||
| //		return $date >= strtotime($startDate) && $date <= strtotime($endDate) && $trans->type == 'debit' ;
 | ||
| 		return  $trans->type == 'debit' ;
 | ||
| 
 | ||
| 	});
 | ||
| 
 | ||
|     /**
 | ||
|     ** Dépots
 | ||
|     **/
 | ||
|     $date = date("Y");
 | ||
| 
 | ||
|     $depots_data[] = '';
 | ||
|     $depots_data =array();
 | ||
|     for ($i = 1; $i <= 12; $i++) {
 | ||
| 		$depots_query_mounth= array_filter($transactions, function ($trans) use ($i, $months ,$years){
 | ||
| 			$month = date("m",strtotime($trans->date));
 | ||
| 			$year = date("Y",strtotime($trans->date));
 | ||
| 			return $month == $months[$i-1] && $year == $years[$i-1] && $trans->type == 'credit' ;
 | ||
| 		});
 | ||
|         $depots_data[] = sizeof($depots_query_mounth);
 | ||
|     }
 | ||
| 	$depots = array_filter($transactions, function ($trans) use ($i, $endDate ,$startDate){
 | ||
| 		$date = strtotime($trans->date);
 | ||
| //		return $date >= strtotime($startDate) && $date <= strtotime($endDate) && $trans->type == 'credit' ;
 | ||
| 		return $trans->type == 'credit' ;
 | ||
| 
 | ||
| 	});
 | ||
| 
 | ||
|     if($transactions!=false){
 | ||
|         $transac=sizeof($transactions);
 | ||
|         $array_transac = array();
 | ||
|         $num = 0;
 | ||
|         if ($transac > 0) {
 | ||
|             foreach($transactions as $row) {
 | ||
|                 $num++;
 | ||
|                 $array_transac[] = $row->type;
 | ||
|             }
 | ||
|             $vals_transac = array_count_values($array_transac);
 | ||
|             $pieChart = array();
 | ||
|             foreach(array_keys($vals_transac) as $paramName) {
 | ||
|                 $color = dechex(rand(0x000000, 0xFFFFFF));
 | ||
|                 $trash = array("value" => $vals_transac[$paramName],
 | ||
|                     "color"    => "#".$color,
 | ||
|                     "highlight" => "#".$color,
 | ||
|                     "label" => $paramName);
 | ||
|     
 | ||
|                 $pieChart[]= $trash;
 | ||
|             }
 | ||
|         }
 | ||
|     }else{
 | ||
|         $pieChart = array();
 | ||
|     }
 | ||
| $fmt = new NumberFormatter( 'fr_FR', NumberFormatter::DECIMAL );
 | ||
| ?>
 | ||
| 
 | ||
| <div class="content-wrapper">
 | ||
|     <!-- Content Header (Page header) -->
 | ||
|     <section class="content-header">
 | ||
| 
 | ||
|         <h1>
 | ||
|             Wallet <?php echo $network; ?>
 | ||
|         </h1>
 | ||
|         <?php
 | ||
|         $site_url = base_url();
 | ||
| 
 | ||
|         if($alert=="ok") {
 | ||
| 
 | ||
|             if(!$success=="ok"){
 | ||
|                 ?>
 | ||
|                 <div class='alert alert-danger alert-dismissible col-xs-6'>
 | ||
|                     <button type='button' class='close' data-dismiss='alert' aria-hidden='true'>×</button>
 | ||
|                     <h4><i class='icon fa fa-ban'></i> Erreur!</h4>
 | ||
|                     <?php echo $message; ?>
 | ||
|                 </div>
 | ||
| 
 | ||
|                 <?php
 | ||
|             } else {
 | ||
|                 ?>
 | ||
|                 <div class="alert alert-success alert-dismissible col-xs-6">
 | ||
|                     <button type="button" class="close" data-dismiss="alert" aria-hidden="true">×</button>
 | ||
|                     <h4><i class="icon fa fa-check"></i> Success!</h4>
 | ||
|                     <?php echo $message; ?>
 | ||
|                 </div>
 | ||
| 
 | ||
|                 <?php
 | ||
|             }
 | ||
|         }
 | ||
|         ?>
 | ||
| 
 | ||
| 	</section>
 | ||
| 
 | ||
|     <section class="content">
 | ||
| 		<div class="row">
 | ||
| 			<div class="col-lg-4 col-xs-6">
 | ||
| 				<div class="small-box bg-aqua">
 | ||
| 					<div class="inner">
 | ||
| 						<h3><?php echo $fmt->format($principal); ?><sup style="font-size: 20px">FCFA</sup></h3>
 | ||
| 						<p>Solde principal</p>
 | ||
| 					</div>
 | ||
| 					<div class="icon">
 | ||
| 						<i class="ion ion-cash"></i>
 | ||
| 					</div>
 | ||
| 				</div>
 | ||
| 			</div>
 | ||
| 
 | ||
| 			<div class="col-lg-4 col-xs-6">
 | ||
|                 <div class="small-box bg-green">
 | ||
|                     <div class="inner">
 | ||
|                         <h3><?php echo $fmt->format($commission); ?><sup style="font-size: 20px">FCFA</sup></h3>
 | ||
|                         <p>Solde commission</p>
 | ||
|                     </div>
 | ||
|                     <div class="icon">
 | ||
|                         <i class="ion ion-cash"></i>
 | ||
|                     </div>
 | ||
| 				</div>
 | ||
|             </div>
 | ||
| 
 | ||
| 			<div class="col-lg-4 col-xs-6">
 | ||
| 				<div class="small-box bg-yellow">
 | ||
| 					<div class="inner">
 | ||
| 						<h3><?php echo $fmt->format($totalCommissionBanque); ?><sup style="font-size: 20px">FCFA</sup></h3>
 | ||
| 						<p>Total commission de la banque</p>
 | ||
| 					</div>
 | ||
| 					<div class="icon">
 | ||
| 						<i class="ion ion-cash"></i>
 | ||
| 					</div>
 | ||
| 				</div>
 | ||
| 			</div>
 | ||
| 
 | ||
|             <div class="col-xs-12">
 | ||
|                 <div class="box box-success">
 | ||
|                     <div class="box-header with-border">
 | ||
|                         <h3 class="box-title">Retraits et dépots des 12 derniers mois<?php //echo $this->lang->line('Souscription des 12 derniers mois'); ?></h3>
 | ||
|                     </div>
 | ||
|                     <div class="box-body">
 | ||
|                         <div class="chart" id="chart">
 | ||
|                             <canvas id="barChart" style="height:230px"></canvas>
 | ||
|                         </div>
 | ||
|                     </div>
 | ||
|                 </div>
 | ||
|             </div>
 | ||
|             <div class="col-xs-6">
 | ||
|                 <div class="box box-danger">
 | ||
|                     <div class="box-header with-border">
 | ||
|                         <h3 class="box-title">Parts dépots & retraits<?php //echo $this->lang->line("Utilisateurs géolocalisés par ville"); ?></h3>
 | ||
|                     </div>
 | ||
|                     <div class="box-body" id="chart2">
 | ||
|                         <canvas id="pieChart" style="height:250px"></canvas>
 | ||
|                     </div>
 | ||
|                 </div>
 | ||
|             </div>
 | ||
| 
 | ||
|             <div class="col-xs-6">
 | ||
|                 <div class="box">
 | ||
|                     <div class="box-header">
 | ||
|                         <h3 class="box-title"><?php echo  $this->lang->line('Commissions Agents') ?></h3>
 | ||
|                     </div>
 | ||
|                     <div class="box-body">
 | ||
|                         <table id="example1" class="table table-bordered table-hover">
 | ||
|                             <thead>
 | ||
|                             <tr>
 | ||
|                                 <th>Nom</th>
 | ||
| 								<th>Solde Princ.</th>
 | ||
|                                 <th>Solde Com.</th>
 | ||
| 								<th>Com. Banque</th>
 | ||
|                                 <th>Dépots</th>
 | ||
|                                 <th>Retraits</th>
 | ||
|                             </tr>
 | ||
|                             </thead>
 | ||
|                             <tbody>
 | ||
|                             <?php
 | ||
| 
 | ||
|                                 if($agents_g){
 | ||
|                                         foreach($agents_g->result() as $row) {
 | ||
|                                         	$wallet = null;
 | ||
| 											foreach ($agentWalletInfos->result() as $value) {
 | ||
| 												if ($value->agent_id == $row->agent_id) {
 | ||
| 													$wallet = $value;
 | ||
| 													break;
 | ||
| 												}
 | ||
| 											}
 | ||
| 											$com = 0;
 | ||
| 											$princ = 0;
 | ||
| 											if($wallet) {
 | ||
| 												$com = $wallet->balance_com;
 | ||
| 												$princ = $wallet->balance_princ;
 | ||
| 											}
 | ||
|                                             echo "<tr>
 | ||
|                                                     <td>".$row->lastname."</td>
 | ||
|                                                     <td>".$fmt->format($princ)."</td>
 | ||
|                                                       <td>".$fmt->format($com)."</td>";
 | ||
| 											$nb_depots = 0;
 | ||
| 											$nb_retraits = 0;
 | ||
| 											$commission_banque = 0;
 | ||
|                                             foreach($depots as $depot){
 | ||
|                                                 if($depot->agent_id == $row->agent_id) {
 | ||
| 													$nb_depots ++;
 | ||
| 													$commission_banque+= $depot->commission_banque;
 | ||
| 												}
 | ||
|                                             }
 | ||
| 											foreach($retraits as $retrait){
 | ||
| 												if($retrait->agent_id == $row->agent_id) {
 | ||
| 													$nb_retraits ++;
 | ||
| 													$commission_banque+= $retrait->commission_banque;
 | ||
| 												}
 | ||
| 											}
 | ||
| 											echo "<td>".$fmt->format($commission_banque)."</td>
 | ||
| 												  <td>".$nb_depots."</td>
 | ||
|                                 				  <td>".$nb_retraits."</td>
 | ||
|                                                  </tr>";
 | ||
|                                         }
 | ||
| 
 | ||
|                                 }
 | ||
|                             ?>
 | ||
|                             </tbody>
 | ||
|                         </table>
 | ||
|                     </div>
 | ||
|                 </div>
 | ||
|             </div>
 | ||
|         </div>
 | ||
|         
 | ||
|     </section>
 | ||
| </div>
 | ||
|     <!-- jQuery 3 -->
 | ||
| <script src="<?php echo base_url('bower_components/jquery/dist/jquery.min.js') ?>"></script>
 | ||
| <!-- Bootstrap 3.3.7 -->
 | ||
| <script src="<?php echo base_url('bower_components/bootstrap/dist/js/bootstrap.min.js') ?>"></script>
 | ||
| <!-- DataTables -->
 | ||
| <script src="<?php echo base_url('bower_components/datatables.net/js/jquery.dataTables.min.js') ?>"></script>
 | ||
| <script src="<?php echo base_url('bower_components/datatables.net-bs/js/dataTables.bootstrap.min.js') ?>"></script>
 | ||
| <!-- Slimscroll -->
 | ||
| <script src="<?php echo base_url('bower_components/jquery-slimscroll/jquery.slimscroll.min.js') ?>"></script>
 | ||
| <!-- FastClick -->
 | ||
| <script src="<?php echo base_url('bower_components/fastclick/lib/fastclick.js') ?>"></script>
 | ||
| <!-- AdminLTE App -->
 | ||
| <script src="<?php echo base_url('dist/js/adminlte.min.js') ?>"></script>
 | ||
| <!-- AdminLTE for demo purposes -->
 | ||
| <script src="<?php echo base_url('dist/js/demo.js') ?>"></script>
 | ||
| 
 | ||
| <script src="<?php echo base_url('dist/js/demo.js') ?>"></script>
 | ||
| 
 | ||
| <script src="<?php echo base_url('bower_components/moment/min/moment.min.js') ?>"></script>
 | ||
| <script src="<?php echo base_url('bower_components/bootstrap-daterangepicker/daterangepicker.js') ?>"></script>
 | ||
| <script src="<?php echo base_url('bower_components/bootstrap-datepicker/dist/js/bootstrap-datepicker.min.js') ?>"></script>
 | ||
| <script src="https://cdnjs.cloudflare.com/ajax/libs/bootstrap-datetimepicker/4.17.47/js/bootstrap-datetimepicker.min.js"></script>
 | ||
| <!-- ChartJS -->
 | ||
| <script src="<?php echo base_url('bower_components/chart.js/Chart.js') ?>"></script>
 | ||
| 
 | ||
| <script>
 | ||
|   $(function () {
 | ||
| 	  $('#example1').DataTable();
 | ||
|     // $('#example1').DataTable({
 | ||
|     //   "aLengthMenu": [[5, 10, 15, -1], [5, 10, 5, "All"]],
 | ||
|     //   "iDisplayLength": 5
 | ||
|     // });
 | ||
|     // $('#example2').DataTable({
 | ||
|     //   'paging'      : true,
 | ||
|     //   'lengthChange': false,
 | ||
|     //   'searching'   : false,
 | ||
|     //   'ordering'    : true,
 | ||
|     //   'info'        : true,
 | ||
|     //   'autoWidth'   : false
 | ||
|     // })
 | ||
|   })
 | ||
| </script>
 | ||
| 
 | ||
| <script>
 | ||
|     var areaChartData = {
 | ||
|     labels  : <?php echo json_encode($label_months) ?>,
 | ||
|     datasets: [
 | ||
|         {
 | ||
|         label               : 'Electronics',
 | ||
|         fillColor           : 'rgba(255, 162, 0, 1)',
 | ||
|         strokeColor         : 'rgba(255, 162, 0, 1)',
 | ||
|         pointColor          : 'rgba(255, 162, 0, 1)',
 | ||
|         pointStrokeColor    : '#ffa200',
 | ||
|         pointHighlightFill  : '#fff',
 | ||
|         pointHighlightStroke: 'rgba(220,220,220,1)',
 | ||
|         data: <?php echo json_encode($depots_data) ?>
 | ||
|         },
 | ||
|         {
 | ||
|         label               : 'Digital Goods',
 | ||
|         fillColor           : 'rgba(0, 187, 255, 1)',
 | ||
|         strokeColor         : 'rgba(0, 187, 255, 1)',
 | ||
|         pointColor          : '#00bbff',
 | ||
|         pointStrokeColor    : 'rgba(0, 187, 255, 1)',
 | ||
|         pointHighlightFill  : '#fff',
 | ||
|         pointHighlightStroke: 'rgba(0, 187, 255, 1)',
 | ||
|         data                : <?php echo json_encode($retraits_data) ?>
 | ||
|         }
 | ||
|     ]
 | ||
|     };
 | ||
| 
 | ||
|     
 | ||
|     var Pie = '<?php echo json_encode($pieChart) ?>';
 | ||
|     if(Pie==='[]'){
 | ||
|         var select = document.getElementById('chart2');
 | ||
|         $(select.children).hide();
 | ||
|         $(select).append("<p>Aucune transaction</p>");
 | ||
|     }else{
 | ||
|         Pie = JSON.parse(Pie);
 | ||
|     }
 | ||
| </script>
 | ||
| <script>
 | ||
| 
 | ||
| </script>
 | ||
| <!-- Page script -->
 | ||
| <script src="<?php echo base_url('dist/js/custom.js') ?>"></script>
 |