|
- <?php
-
- /**
- Copyright La boîte à pain (2018)
-
- contact@laboiteapain.net
-
- Ce logiciel est un programme informatique servant à aider les producteurs
- à distribuer leur production en circuits courts.
-
- Ce logiciel est régi par la licence CeCILL soumise au droit français et
- respectant les principes de diffusion des logiciels libres. Vous pouvez
- utiliser, modifier et/ou redistribuer ce programme sous les conditions
- de la licence CeCILL telle que diffusée par le CEA, le CNRS et l'INRIA
- sur le site "http://www.cecill.info".
-
- En contrepartie de l'accessibilité au code source et des droits de copie,
- de modification et de redistribution accordés par cette licence, il n'est
- offert aux utilisateurs qu'une garantie limitée. Pour les mêmes raisons,
- seule une responsabilité restreinte pèse sur l'auteur du programme, le
- titulaire des droits patrimoniaux et les concédants successifs.
-
- A cet égard l'attention de l'utilisateur est attirée sur les risques
- associés au chargement, à l'utilisation, à la modification et/ou au
- développement et à la reproduction du logiciel par l'utilisateur étant
- donné sa spécificité de logiciel libre, qui peut le rendre complexe à
- manipuler et qui le réserve donc à des développeurs et des professionnels
- avertis possédant des connaissances informatiques approfondies. Les
- utilisateurs sont donc invités à charger et tester l'adéquation du
- logiciel à leurs besoins dans des conditions permettant d'assurer la
- sécurité de leurs systèmes et ou de leurs données et, plus généralement,
- à l'utiliser et l'exploiter dans les mêmes conditions de sécurité.
-
- Le fait que vous puissiez accéder à cet en-tête signifie que vous avez
- pris connaissance de la licence CeCILL, et que vous en avez accepté les
- termes.
- */
-
- use common\models\Order ;
-
- $num_jour_semaine = date('w', strtotime($date));
- $arr_jour_semaine = [0 => 'dimanche', 1 => 'lundi', 2 => 'mardi', 3 => 'mercredi', 4 => 'jeudi', 5 => 'vendredi', 6 => 'samedi'];
- $champs_horaires_point_vente = 'horaires_' . $arr_jour_semaine[$num_jour_semaine];
-
- $html = '' ;
-
- // par point de vente
- foreach ($points_vente as $pv) {
- if (count($pv->order) && strlen($pv->$champs_horaires_point_vente)) {
-
- $html .= '<h3>'.$pv->name.'</h3>' ;
-
- $col_credit_pain = '' ;
- if($pv->credit) {
- $col_credit = '<th>Rappel crédit</th>' ;
- }
-
- $html .= '<table class="table table-bordered">'
- . '<thead>'
- . '<tr>'
- . '<th>Client</th>'
- . '<th>Produits</th>'
- . '<th>Commentaire</th>'
- . $col_credit
- . '<th>Montant</th>'
- . '</tr>'
- . '<tbody>';
-
- foreach ($pv->orders as $c) {
- $html .= '<tr>' ;
- $str_user = '';
-
- // username
- if ($c->user) {
- $str_user = $c->user->name . " " . $c->user->lastname;
- } else {
- $str_user = $c->username;
- }
-
- if(strlen($c->comment_point_sale))
- {
- $str_user .= '<br /><em>'.$c->comment_point_sale.'</em>' ;
- }
-
- // téléphone
- if (isset($c->user) && strlen($c->user->phone)) {
- $str_user .= '<br />' . $c->user->phone . '';
- }
-
- $html .= '<td>'.$str_user.'</td>';
-
- // produits
- $str_produits = '';
- foreach ($produits as $p) {
- $add = false;
- foreach ($c->productOrder as $cp) {
- if ($p->id == $cp->id_product) {
- $str_produits .= $cp->quantity . ' ' . $p->name . ', ';
- $add = true;
- }
- }
- }
-
- $html .= '<td>'.substr($str_produits, 0, strlen($str_produits) - 2).'</td>';
- $html .= '<td>'.$c->comment.'</td>';
-
- if($pv->credit) {
- $credit = '' ;
- if(isset($c->user) && isset($c->user->userProducer)) {
- $credit = number_format($c->user->userProducer[0]->credit,2).' €' ;
- }
- $html .= '<td>'.$credit.'</td>' ;
- }
-
- $html .= '<td><strong>'.number_format($c->amount, 2) . ' € ';
-
- if($c->getStatusPayment() == Order::PAYMENT_PAID)
- {
- $html .= '(payé)' ;
- }
- elseif($c->getStatusPayment() == Order::PAYMENT_UNPAID && $c->getAmount(Order::AMOUNT_PAID))
- {
- $html .= '(reste '.$c->getAmount(Order::AMOUNT_REMAINING, true).' à payer)' ;
- }
- elseif($c->getStatusPayment() == Order::PAYMENT_SURPLUS)
- {
- $html .= '(surplus : '.$c->getAmount(Order::PAYMENT_SURPLUS, true).' à rembourser)' ;
- }
-
- $html .= '</strong></td>' ;
-
- $html .= '</tr>' ;
-
- }
-
- $html .= '<tr><td><strong>Total</strong></td>' ;
-
- $str_produits = '';
- foreach ($produits as $p) {
- $quantite = Order::getProductQuantity($p->id, $pv->orders);
- $str_quantite = '';
- if ($quantite) {
- $str_quantite = $quantite;
- $str_produits .= $str_quantite .' '. $p->name . ', ';
- }
- }
-
- $str_produits = substr($str_produits, 0, strlen($str_produits) - 2) ;
-
- $html .= '<td>'.$str_produits.'</td><td></td>' ;
- if($pv->credit) {
- $html .= '<td></td>' ;
- }
- $html .= '<td><strong>'.number_format($pv->revenues, 2) . ' €</strong></td>';
-
- $html .= '</tbody></table><pagebreak>' ;
- }
- }
-
- // par point de vente
- $html .= '<h3>Points de vente</h3>' ;
- $html .= '<table class="table table-bordered">'
- . '<thead>'
- . '<tr>'
- . '<th>Point de vente</th>'
- . '<th>Produits</th>'
- . '<th>Montant</th>'
- . '</tr>'
- . '<tbody>';
-
- $recettes = 0 ;
- foreach ($points_vente as $pv)
- {
- if (count($pv->orders) && strlen($pv->$champs_horaires_point_vente))
- {
- $html .= '<tr><td>'.$pv->name.'</td><td>' ;
- foreach ($produits as $p) {
- $quantite = Order::getProductQuantity($p->id, $pv->orders);
- $str_quantite = '';
-
- if ($quantite) {
- $str_quantite = $quantite;
- }
-
- if(strlen($str_quantite)) {
- $html .= $str_quantite . ' '.$p->name.', ' ;
- }
-
- }
-
- $html = substr($html, 0, strlen($html) - 2) ;
-
- $html .= '</td><td>'.number_format($pv->revenues, 2).' €</td></tr>' ;
- $recettes += $pv->revenues ;
- }
- }
-
- // total
- $html .= '<tr><td><strong>Total</strong></td><td>' ;
- foreach ($produits as $p) {
- $quantite = Order::getProductQuantity($p->id, $orders);
- if($quantite) {
- $html .= $quantite . ' '.$p->name.', ' ;
- }
- }
-
- $html = substr($html, 0, strlen($html) - 2) ;
-
- $html .= '</td><td><strong>'.number_format($recettes, 2).' €</strong></td></tr>' ;
-
- $html .= '</tbody></table>' ;
-
- echo $html ;
-
- ?>
|