|
- <?php
-
-
-
- use common\models\Order ;
- use common\models\Product ;
-
- $dayWeek = date('w', strtotime($date));
- $dayWeekArray = [0 => 'sunday', 1 => 'monday', 2 => 'tuesday', 3 => 'wednesday', 4 => 'thursday', 5 => 'friday', 6 => 'saturday'];
- $fieldInfosPointSale = 'infos_' . $dayWeekArray[$dayWeek];
-
- $html = '' ;
-
- $count = count($productsArray) ;
- $limit = 100 ;
- $isBig = $count > $limit ;
-
-
- foreach ($pointsSaleArray as $pointSale) {
- if (count($pointSale->orders)) {
-
- $html .= '<h3>'.$pointSale->name.'</h3>' ;
- $colCredit = ($pointSale->credit) ? '<th>Rappel crédit</th>' : '' ;
-
- $html .= '<table class="">'
- . '<thead>'
- . '<tr>'
- . '<th>Client</th>'
- . '<th>Produits</th>'
- . ($isBig ? '<th>Produits</th>' : '')
- . '<th>Commentaire</th>'
- . $colCredit
- . '<th>Montant</th>'
- . '</tr>'
- . '<tbody>';
-
- foreach ($pointSale->orders as $order) {
- $html .= '<tr>' ;
- $strUser = '';
-
-
- $strUser .= $order->getStrUser() ;
-
- if(strlen($order->comment_point_sale))
- {
- $strUser .= '<br /><em>'.$order->comment_point_sale.'</em>' ;
- }
-
-
- if (isset($order->user) && strlen($order->user->phone)) {
- $strUser .= '<br />' . $order->user->phone . '';
- }
-
-
- if($producer->option_order_reference_type == Producer::ORDER_REFERENCE_TYPE_YEARLY && $order->reference && strlen($order->reference) > 0) {
- $strUser .= '<br />'.$order->reference ;
- }
-
- $html .= '<td>'.$strUser.'</td>';
-
-
- $strProducts = '';
- foreach ($productsArray as $product) {
- $add = false;
- foreach ($order->productOrder as $productOrder) {
- if($product->id == $productOrder->id_product) {
- $unit = (Product::strUnit($productOrder->unit, 'wording_short', true) == 'p.') ? '' : ' '.Product::strUnit($productOrder->unit, 'wording_short', true) ;
- $strProducts .= '('.$productOrder->quantity .$unit.') '.$product->getNameExport() . '<br />';
- $add = true;
- }
- }
- }
-
- $html .= '<td>'.substr($strProducts, 0, strlen($strProducts) - 6).'</td>';
- if($isBig) {
- $html .= '<td></td>' ;
- }
- $html .= '<td>'.$order->getCommentReport().'</td>';
-
- if($pointSale->credit) {
- $credit = '' ;
-
- if(isset($order->user) && $order->user->id) {
- $userProducer = UserProducer::searchOne([
- 'id_user' => $order->user->id
- ]);
-
- if($userProducer) {
- $credit = number_format($userProducer->credit,2).' €' ;
- }
- }
-
- $html .= '<td>'.$credit.'</td>' ;
- }
-
- $html .= '<td><strong>'.number_format($order->amount_with_tax, 2) . ' € ';
-
- if($order->getPaymentStatus() == Order::PAYMENT_PAID)
- {
- $html .= '(payé)' ;
- }
- elseif($order->getPaymentStatus() == Order::PAYMENT_UNPAID && $order->getAmount(Order::AMOUNT_PAID))
- {
- $html .= '(reste '.$order->getAmount(Order::AMOUNT_REMAINING, true).' à payer)' ;
- }
- elseif($order->getPaymentStatus() == Order::PAYMENT_SURPLUS)
- {
- $html .= '(surplus : '.$order->getAmount(Order::PAYMENT_SURPLUS, true).' à rembourser)' ;
- }
-
- $html .= '</strong></td>' ;
-
- $html .= '</tr>' ;
-
- }
-
- $html .= '<tr><td><strong>Total</strong></td>' ;
-
- $strProducts = '';
- $cpt = 0 ;
- foreach ($productsArray as $product) {
- foreach(Product::$unitsArray as $unit => $dataUnit) {
- $quantity = Order::getProductQuantity($product->id, $pointSale->orders, false, $unit);
- if ($quantity) {
- $theUnit = (Product::strUnit($unit, 'wording_short', true) == 'p.') ? '' : ' '.Product::strUnit($unit, 'wording_short', true) ;
- $strProducts .= '(' .$quantity .$theUnit.') '.$product->getNameExport() . '<br />';
- }
- }
-
- if($isBig && $cpt == $limit) {
- $strProducts .= '</td><td>' ;
- }
-
- $cpt ++ ;
- }
-
-
-
- $html .= '<td>'.$strProducts.'</td><td></td>' ;
- if($pointSale->credit) {
- $html .= '<td></td>' ;
- }
- $html .= '<td><strong>'.Price::format($pointSale->revenues_with_tax) . '</strong></td>';
-
- $html .= '</tbody></table><pagebreak>' ;
- }
- }
-
-
-
- $html .= '<h3>Points de vente</h3>' ;
- $html .= '<table class="">'
- . '<thead>'
- . '<tr>'
- . '<th>Point de vente</th>'
- . '<th>Produits</th>'
- . ( $isBig ? '<th>Produits</th>' : '')
- . '<th>Montant</th>'
- . '</tr>'
- . '<tbody>';
-
- $revenues = 0 ;
- foreach ($pointsSaleArray as $pointSale)
- {
- if (count($pointSale->orders))
- {
- $html .= '<tr><td>'.$pointSale->name.'</td><td>' ;
-
- $cpt = 0 ;
- foreach ($productsArray as $product) {
- foreach(Product::$unitsArray as $unit => $dataUnit) {
- $quantity = Order::getProductQuantity($product->id, $pointSale->orders, false, $unit);
- if ($quantity) {
- $theUnit = (Product::strUnit($unit, 'wording_short', true) == 'p.') ? '' : ' '.Product::strUnit($unit, 'wording_short', true) ;
- $html .= '(' .$quantity .$theUnit.') '.$product->getNameExport() . '<br />';
- }
- }
-
- if($isBig && $cpt == $limit) {
- $html .= '</td><td>' ;
- }
-
- $cpt ++ ;
- }
-
-
-
- $html .= '</td><td>'.Price::format($pointSale->revenues_with_tax, 2).'</td></tr>' ;
- $revenues += $pointSale->revenues_with_tax ;
- }
- }
-
-
- $html .= '<tr><td><strong>Total</strong></td><td>' ;
-
- $cpt = 0 ;
- foreach ($productsArray as $product) {
- foreach(Product::$unitsArray as $unit => $dataUnit) {
- $quantity = Order::getProductQuantity($product->id, $ordersArray, false, $unit);
- if ($quantity) {
- $theUnit = (Product::strUnit($unit, 'wording_short', true) == 'p.') ? '' : ' '.Product::strUnit($unit, 'wording_short', true) ;
- $html .= '(' .$quantity .$theUnit.') '.$product->name . '<br />';
- }
- }
- if($isBig && $cpt == $limit) {
- $html .= '</td><td>' ;
- }
-
- $cpt ++ ;
- }
-
-
-
- $html .= '</td><td><strong>'.number_format($revenues, 2).' €</strong></td></tr>' ;
-
- $html .= '</tbody></table>' ;
-
- echo $html ;
-
- ?>
|