report.php 6.0KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161
  1. <?php
  2. use common\models\Commande ;
  3. $num_jour_semaine = date('w', strtotime($date));
  4. $arr_jour_semaine = [0 => 'dimanche', 1 => 'lundi', 2 => 'mardi', 3 => 'mercredi', 4 => 'jeudi', 5 => 'vendredi', 6 => 'samedi'];
  5. $champs_horaires_point_vente = 'horaires_' . $arr_jour_semaine[$num_jour_semaine];
  6. $html = '' ;
  7. // par point de vente
  8. foreach ($points_vente as $pv) {
  9. if (count($pv->commandes) && strlen($pv->$champs_horaires_point_vente)) {
  10. $html .= '<h3>'.$pv->nom.'</h3>' ;
  11. $html .= '<table class="table table-bordered">'
  12. . '<thead>'
  13. . '<tr>'
  14. . '<th>Client</th>'
  15. . '<th>Produits</th>'
  16. . '<th>Commentaire</th>'
  17. . '<th>Montant</th>'
  18. . '</tr>'
  19. . '<tbody>';
  20. foreach ($pv->commandes as $c) {
  21. $html .= '<tr>' ;
  22. $str_user = '';
  23. // username
  24. if ($c->user) {
  25. $str_user = $c->user->prenom . " " . $c->user->nom; //.' - '.date('d/m', strtotime($c->date)) ;
  26. } else {
  27. $str_user = $c->username; //.' - '.date('d/m', strtotime($c->date)) ;
  28. }
  29. if(strlen($c->commentaire_point_vente))
  30. {
  31. $str_user .= '<br /><em>'.$c->commentaire_point_vente.'</em>' ;
  32. }
  33. // téléphone
  34. if (isset($c->user) && strlen($c->user->telephone)) {
  35. $str_user .= '<br />' . $c->user->telephone . '';
  36. }
  37. $html .= '<td>'.$str_user.'</td>';
  38. // produits
  39. $str_produits = '';
  40. foreach ($produits as $p) {
  41. if (isset($produits_selec[$p->id]['actif']) && $produits_selec[$p->id]['actif']) {
  42. $add = false;
  43. foreach ($c->commandeProduits as $cp) {
  44. if ($p->id == $cp->id_produit) {
  45. $str_produits .= $cp->quantite . ' x ' . $p->nom . '<br /> ';
  46. $add = true;
  47. }
  48. }
  49. }
  50. }
  51. $html .= '<td>'.substr($str_produits, 0, strlen($str_produits) - 2).'</td>';
  52. $html .= '<td>'.$c->commentaire.'</td>';
  53. $html .= '<td>'.number_format($c->montant, 2) . ' € ';
  54. if($c->getStatutPaiement() == Commande::STATUT_PAYEE)
  55. {
  56. $html .= '(payé)' ;
  57. }
  58. elseif($c->getStatutPaiement() == Commande::STATUT_IMPAYEE && $c->getMontantPaye())
  59. {
  60. $html .= '(reste '.$c->getMontantRestant(true).' à payer)' ;
  61. }
  62. elseif($c->getStatutPaiement() == Commande::STATUT_SURPLUS)
  63. {
  64. $html .= '(surplus : '.$c->getMontantSurplus(true).' à rembourser)' ;
  65. }
  66. $html .= '</td>' ;
  67. $html .= '</tr>' ;
  68. }
  69. $html .= '<tr><td><strong>Total</strong></td>' ;
  70. $str_produits = '';
  71. foreach ($produits as $p) {
  72. if (!$p->vrac && isset($produits_selec[$p->id]['actif']) && $produits_selec[$p->id]['actif']) {
  73. $quantite = Commande::getQuantiteProduit($p->id, $pv->commandes);
  74. $str_quantite = '';
  75. if ($quantite) {
  76. $str_quantite = $quantite;
  77. $str_produits .= $str_quantite .' x '. $p->nom . '<br />';
  78. }
  79. }
  80. }
  81. $html .= '<td>'.$str_produits.'</td><td></td>' ;
  82. $html .= '<td><strong>'.number_format($pv->recettes_pain, 2) . ' €</strong></td>';
  83. $html .= '</tbody></table><pagebreak>' ;
  84. }
  85. }
  86. // par point de vente
  87. $html .= '<h3>Points de vente</h3>' ;
  88. $html .= '<table class="table table-bordered">'
  89. . '<thead>'
  90. . '<tr>'
  91. . '<th>Point de vente</th>'
  92. . '<th>Produits</th>'
  93. . '<th>Montant</th>'
  94. . '</tr>'
  95. . '<tbody>';
  96. $recettes = 0 ;
  97. foreach ($points_vente as $pv)
  98. {
  99. if (count($pv->commandes) && strlen($pv->$champs_horaires_point_vente))
  100. {
  101. $html .= '<tr><td>'.$pv->nom.'</td><td>' ;
  102. foreach ($produits as $p) {
  103. if (isset($produits_selec[$p->id]['actif']) && $produits_selec[$p->id]['actif']) {
  104. $quantite = Commande::getQuantiteProduit($p->id, $pv->commandes);
  105. $str_quantite = '';
  106. if (!$p->vrac) {
  107. if ($quantite)
  108. $str_quantite = $quantite;
  109. }
  110. if(strlen($str_quantite))
  111. $html .= $str_quantite . ' x '.$p->nom.'<br />' ;
  112. }
  113. }
  114. $html .= '</td><td>'.number_format($pv->recettes_pain, 2).' €</td></tr>' ;
  115. $recettes += $pv->recettes_pain ;
  116. }
  117. }
  118. // total
  119. $html .= '<tr><td><strong>Total</strong></td><td>' ;
  120. foreach ($produits as $p) {
  121. if (isset($produits_selec[$p->id]['actif']) && $produits_selec[$p->id]['actif']) {
  122. $quantite = Commande::getQuantiteProduit($p->id, $commandes);
  123. if(!$p->vrac && $quantite)
  124. $html .= $quantite . ' x '.$p->nom.'<br />' ;
  125. }
  126. }
  127. $html .= '</td><td><strong>'.number_format($recettes, 2).' €</strong></td></tr>' ;
  128. $html .= '</tbody></table>' ;
  129. echo $html ;
  130. ?>