[ 'class' => AccessControl::className(), 'rules' => [ [ 'actions' => ['report-cron'], 'allow' => true, 'roles' => ['?'] ], [ 'allow' => true, 'roles' => ['@'], 'matchCallback' => function ($rule, $action) { return User::getCurrentStatus() == USER::STATUS_ADMIN || User::getCurrentStatus() == USER::STATUS_PRODUCER; } ] ], ], ]; } /** * Génére un PDF récapitulatif des commandes d'un producteur pour une * date donnée. * * @param string $date * @param boolean $save * @param integer $id_etablissement * @return PDF|null */ public function actionReport($date = '', $save = false, $idProducer = 0) { if (!Yii::$app->user->isGuest) { $idProducer = Producer::getId() ; } $ordersArray = Order::searchAll([ 'distribution.date' => $date, ], [ 'orderby' => 'comment_point_sale ASC, user.name ASC', 'conditions' => 'date_delete IS NULL' ]) ; $distribution = Distribution::searchOne([],[ 'conditions' => 'date LIKE :date', 'params' => [':date' => $date] ]) ; if ($distribution) { $selectedProductsArray = ProductDistribution::searchByDistribution($distribution->id) ; $pointsSaleArray = PointSale::searchAll() ; foreach ($pointsSaleArray as $pointSale) { $pointSale->initOrders($ordersArray) ; } // produits $productsArray = Product::searchAll() ; // get your HTML raw content without any layouts or scripts $content = $this->renderPartial('report', [ 'date' => $date, 'distribution' => $distribution, 'selectedProductsArray' => $selectedProductsArray, 'pointsSaleArray' => $pointsSaleArray, 'productsArray' => $productsArray, 'ordersArray' => $ordersArray ]); $dateStr = date('d/m/Y', strtotime($date)); if ($save) { $destination = Pdf::DEST_FILE; } else { $destination = Pdf::DEST_BROWSER; } $pdf = new Pdf([ // set to use core fonts only 'mode' => Pdf::MODE_UTF8, // A4 paper format 'format' => Pdf::FORMAT_A4, // portrait orientation 'orientation' => Pdf::ORIENT_PORTRAIT, // stream to browser inline 'destination' => $destination, 'filename' => Yii::getAlias('@app/web/pdf/Commandes-' . $date . '-' . $idProducer . '.pdf'), // your html content input 'content' => $content, // format content from your own css file if needed or use the // enhanced bootstrap css built by Krajee for mPDF formatting //'cssFile' => '@vendor/kartik-v/yii2-mpdf/assets/kv-mpdf-bootstrap.min.css', // any css to be embedded if required //'cssInline' => '.kv-heading-1{font-size:18px}', // set mPDF properties on the fly //'options' => ['title' => 'Krajee Report Title'], // call mPDF methods on the fly 'methods' => [ 'SetHeader' => ['Commandes du ' . $dateStr], 'SetFooter' => ['{PAGENO}'], ] ]); // return the pdf output as per the destination setting return $pdf->render(); } return null ; } /** * Supprime une commande. * * @param string $date * @param integer $id_commande */ public function actionDeleteOrder($date, $idOrder) { $order = Order::searchOne(['id' =>$idOrder]) ; if ($order) { // remboursement de la commande if ($order->id_user && $order->getAmount(Order::AMOUNT_PAID) && Producer::getConfig('credit')) { $order->saveCreditHistory( CreditHistory::TYPE_REFUND, $order->getAmount(Order::AMOUNT_PAID), $order->distribution->id_producer, $order->id_user, User::getCurrentId() ); } $order->delete(); ProductOrder::deleteAll(['id_order' => $idOrder]); } $this->redirect(['index', 'date' => $date]); } /** * Traite le formulaire d'ajout/modification de commande. * * @param Distribution $distribution * @param string $date * @param array $points_vente * @param array $produits * @param array $users */ public function processOrderForm( $distribution, $date, $pointsSale, $products, $users) { if ($date != '') { // commandes $orders = Order::searchAll([ 'distribution.date' => $date ]) ; foreach ($pointsSale as $point) { $point->initOrders($orders); if (isset($_POST['submit_pv']) && $_POST['submit_pv']) { // modifs foreach ($point->orders as $order) { // suppression des product_order ProductOrder::deleteAll(['id_order' => $order->id]) ; // création des commande_produit modifiés foreach ($products as $product) { $quantity = Yii::$app->getRequest()->post('product_' . $point->id . '_' . $product->id, 0); if ($quantity) { $productOrder = new ProductOrder; $productOrder->id_order = $order->id; $productOrder->id_product = $product->id; $productOrder->quantity = $quantity; $productOrder->price = $p->price; $productOrder->save(); } } } $username = Yii::$app->getRequest()->post('username_point_sale_' . $point->id, 0); $date = Yii::$app->getRequest()->post('date_order_point_sale_' . $point->id, 0); $oneProduct = false; foreach ($products as $product) { $quantity = Yii::$app->getRequest()->post('product_point_sale_' . $point->id . '_' . $product->id, 0); if ($quantity) { $oneProduct = true; } } if (strlen($username) && $date && $oneProduct) { $order = new Order; $order->id_point_sale = $point->id; $order->id_production = $distribution->id; $order->id_user = 0; $order->username = $username; $arrayDate = explode('/', $date); $order->date = $arrayDate[2] . '-' . $arrayDate[1] . '-' . $arrayDate[0] . ' 00:00:00'; $order->save(); foreach ($products as $product) { $quantity = Yii::$app->getRequest()->post('product_point_sale_' . $point->id . '_' . $product->id, 0); if ($quantity) { $productOrder = new ProductOrder; $productOrder->id_order = $order->id; $productOrder->id_product = $product->id; $productOrder->quantity = $quantity; $productOrder->price = $p->price; $productOrder->save(); } } } } } } } /** * Page principale de la gestion des commandes. * * @param string $date * @param boolean $returnData * @return string */ public function actionIndex($date = '', $returnData = false) { if (!Product::count() && !PointSale::count()) { $this->redirect(['site/index', 'error_products_points_sale' => 1]); } $orders = []; // users $arrayUsers = [0 => '--']; $users = User::searchAll([],['orderby' => 'lastname, name ASC']) ; foreach ($users as $user) { $arrayUsers[$user->id] = $user->name . ' ' . $user->lastname; } // création du jour de distribution $distribution = Distribution::initDistribution($date) ; // points de vente if ($distribution) { $arrayPointsSale = PointSale::find() ->joinWith(['pointSaleDistribution' => function($q) use ($distribution) { $q->where(['id_distribution' => $distribution->id]); }]) ->where([ 'id_producer' => Producer::getId(), ]) ->all(); } else { $arrayPointsSale = PointSale::searchAll() ; } // produits $arrayProducts = Product::searchAll(); // gestion des commandes $this->processOrderForm($distribution, $date, $arrayPointsSale, $arrayProducts, $users); // commandes $arrayOrders = Order::searchAll([ 'distribution.date' => $date, ], [ 'conditions' => 'date_delete IS NULL' ]); $revenues = 0; $weight = 0 ; $revenuesDelivered = 0; if($arrayOrders) { foreach ($arrayOrders as $order) { if(is_null($order->date_delete)) { $revenues += $order->amount; if ($order->id_point_sale != 1) { $revenuesDelivered += $order->amount; } $weight += $order->weight; } } } $revenues = number_format($revenues, 2); // init commandes point de vente foreach ($arrayPointsSale as $pointSale) { $pointSale->initOrders($arrayOrders); $dataSelectOrders = []; $dataOptionsOrders = []; foreach ($pointSale->orders as $order) { if ($order->user) { $dataSelectOrders[$order->id] = $order->user->name . ' ' . $order->user->lastname; } else { $dataSelectOrders[$order->id] = $order->username; } $dataOptionsOrders[$order->id] = []; $arrayOptions = []; $arrayOptions[$order->id]['amount'] = $order->amount; $arrayOptions[$order->id]['str_amount'] = number_format($order->amount, 2, ',', '') . ' €'; $arrayOptions[$order->id]['paid_amount'] = $order->paid_amount; $arrayOptions[$order->id]['products'] = []; $arrayOptions[$order->id]['comment'] = Html::encode($order->comment); foreach ($order->productOrder as $productOrder) { $arrayOptions[$order->id]['products'][$productOrder->id_product] = $productOrder->quantity; } $dataOptionsOrders[$order->id]['data-order'] = json_encode($arrayOptions[$order->id]); $dataOptionsOrders[$order->id]['value'] = $order->id; } $pointSale->data_select_orders = $dataSelectOrders ; $pointSale->data_options_orders = $dataOptionsOrders ; } // gestion produits selec if (isset($_POST['valider_produit_selec'])) { if (isset($_POST['Product'])) { foreach ($arrayProducts as $product) { $productDistribution = ProductDistribution::searchOne([ 'id_distribution' => $distribution->id, 'id_product' => $product->id ]) ; if (!$productDistribution) { $productDistribution = new ProductDistribution(); $productDistribution->id_distribution = $distribution->id; $productDistribution->id_product = $product->id; $productDistribution->active = 0; if (isset($product->quantity_max)) { $productDistribution->quantity_max = $product->quantity_max; } else { $productDistribution->quantity_max = null; } $productDistribution->save(); } if (isset($_POST['Product'][$product->id]['active'])) { $productDistribution->active = 1; } else { $productDistribution->active = 0; } if ((isset($_POST['Product'][$product->id]['quantity_max']) && $_POST['Product'][$product->id]['quantity_max'] != '')) { $productDistribution->quantity_max = (int) $_POST['Product'][$product->id]['quantity_max']; } else { $productDistribution->quantity_max = null; } $productDistribution->save(); } } } $arrayProductsSelected = [] ; if($distribution) { // produits selec pour production $arrayProductsSelected = ProductDistribution::searchByDistribution($distribution->id) ; } // produits if ($distribution) { $arrayProducts = Product::searchByDistribution($distribution->id) ; } // poids total de la production et CA potentiel $potentialTurnover = 0; $totalWeight = 0; foreach ($arrayProductsSelected as $idSelectedProduct => $selectedProduct) { if ($selectedProduct['active']) { foreach ($arrayProducts as $product) { if ($product->id == $idSelectedProduct) { $potentialTurnover += $selectedProduct['quantity_max'] * $product->price; $totalWeight += $selectedProduct['quantity_max'] * $product->weight / 1000; } } } } // jours de distribution $arrayDistributionDays = Distribution::searchAll([ 'active' => 1 ]) ; // commandes auto $subscriptionForm = new SubscriptionForm; // productions point vente $pointSaleDistribution = new PointSaleDistribution; $oointsSaleDistribution = []; if ($distribution) { $pointsSaleDistribution = PointSaleDistribution::searchAll([ 'id_distribution' => $distribution->id ]) ; } $arrayPointsSaleDistribution = []; if(isset($pointsSaleDistribution)) { foreach ($pointsSaleDistribution as $pointSaleDistrib) { $key = $pointSaleDistrib->id_distribution . '-' . $pointSaleDistrib->id_point_sale; if ($pointSaleDistrib->delivery == 1) { $pointSaleDistribution->points_sale_distribution[] = $key; } if(isset($pointSaleDistrib->pointSale) && strlen($pointSaleDistrib->pointSale->name)) { $arrayPointsSaleDistribution[$key] = Html::encode($pointSaleDistrib->pointSale->name); } } } // une production de la semaine activée ou non $oneDistributionWeekActive = false ; $week = sprintf('%02d',date('W',strtotime($date))); $start = strtotime(date('Y',strtotime($date)).'W'.$week); $dateMonday = date('Y-m-d',strtotime('Monday',$start)) ; $dateTuesday = date('Y-m-d',strtotime('Tuesday',$start)) ; $dateWednesday = date('Y-m-d',strtotime('Wednesday',$start)) ; $dateThursday = date('Y-m-d',strtotime('Thursday',$start)) ; $dateFriday = date('Y-m-d',strtotime('Friday',$start)) ; $dateSaturday = date('Y-m-d',strtotime('Saturday',$start)) ; $dateSunday = date('Y-m-d',strtotime('Sunday',$start)) ; $weekDistribution = Distribution::find() ->andWhere([ 'id_producer' => Producer::getId(), 'active' => 1, ]) ->andWhere(['or', ['date' => $dateMonday], ['date' => $dateTuesday], ['date' => $dateWednesday], ['date' => $dateThursday], ['date' => $dateFriday], ['date' => $dateSaturday], ['date' => $dateSunday], ]) ->one(); if($weekDistribution) { $oneDistributionWeekActive = true ; } $datas = [ 'arrayProducts' => $arrayProducts, 'arrayPointsSale' => $arrayPointsSale, 'arrayOrders' => $arrayOrders, 'date' => $date, 'distribution' => $distribution, 'arrayDistributionDays' => $arrayDistributionDays, 'selectedProducts' => $arrayProductsSelected, 'users' => $arrayUsers, 'revenues' => $revenues, 'revenuesDelivered' => $revenuesDelivered, 'weight' => $weight, 'potentialTurnover' => $potentialTurnover, 'totalWeight' => $totalWeight, 'subscriptionForm' => $subscriptionForm, 'pointSaleDistribution' => $pointSaleDistribution, 'arrayPointsSaleDistribution' => $arrayPointsSaleDistribution, 'oneDistributionWeekActive' => $oneDistributionWeekActive ]; if ($returnData) { return $datas; } else { return $this->render('index', $datas); } } /** * Génère un fichier d'export des commandes au format CSV. * * @param string $date * @param integer $id_point_vente * @param boolean $global */ public function actionDownload($date = '', $idPointSale = 0, $global = 0) { // commandes $ordersArray = Order::searchAll([ 'distribution.date' => $date ]) ; // points de vente $pointsSaleArray = PointSale::searchAll() ; foreach ($pointsSaleArray as $pointSale) { $pv->initOrders($ordersArray); } // produits $productsArray = Product::find()->orderBy('order ASC')->all(); $distribution = Distribution::find() ->where('date LIKE \':date\'') ->params([':date' => $date]) ->one(); $selectedProductsArray = ProductDistribution::searchByDistribution($distribution->id); /* * export global */ if ($global) { $data = []; $filename = 'export_' . $date . '_global'; $dayWeek = date('w', strtotime($date)); $dayWeekArray = [0 => 'sunday', 1 => 'monday', 2 => 'tuesday', 3 => 'wednesday', 4 => 'thursday', 5 => 'friday', 6 => 'saturday']; $fieldsHoursPointSale = 'infos_' . $dayWeekArray[$dayWeek]; // par point de vente foreach ($pointsSaleArray as $pointSale) { if (count($pointSale->orders) && strlen($pointSale->$fieldsHoursPointSale)) { $line = [$pointSale->name, 'Produits', 'Montant', 'Commentaire']; $data[] = $line; $res = $this->contentPointSaleCSV($date, $productsArray, $pointsSaleArray, $pointSale->id); foreach ($res['data'] as $line) { $data[] = $line; } } if (count($pointSale->orders) && strlen($pointSale->$fieldsHoursPointSale)) { $line = ['Total']; $strProducts = ''; foreach ($productsArray as $product) { if ( isset($selectedProductsArray[$product->id]['active']) && $selectedProductsArray[$product->id]['active']) { $quantity = Order::getProductQuantity($product->id, $pointSale->orders); $strQuantity = ''; if ($quantity) { $strQuantity = $quantity; $strProducts .= $strQuantity . ', '; } } } $line[] = substr($strProducts, 0, strlen($strProducts) - 2); $line[] = number_format($pointSale->revenues, 2) . ' €'; $data[] = $line; $data[] = []; } } $line = ['Total']; $strProducts = ''; foreach ($productsArray as $product) { if (isset($selectedProductsArray[$product->id]['active']) && $selectedProductsArray[$product->id]['active']) { $quantity = Order::getProductQuantity($product->id, $ordersArray); $strQuantity = ''; if ($quantity) { $strQuantity = $quantity; $strQuantity .= $strQuantity . ', '; } } } $line[] = substr($strProducts, 0, strlen($strProducts) - 2); $data[] = $line; $infos = $this->actionIndex($date, true); CSV::downloadSendHeaders($filename . '.csv'); echo CSV::array2csv($data); die(); } /* * export individuel */ else { if ($ordersArray && count($ordersArray)) { $data = []; // par point de vente if ($idPointSale) { $res = $this->contentPointSaleCSV($date, $productsArray, $pointsSaleArray, $idPointSale); $data = $res['data']; $filename = $res['filename']; } // récapitulatif else { $res = $this->contentRecapCSV($date, $productsArray, $pointsSaleArray, $ordersArray); $filename = 'summary_' . $date; $data = $res['data']; } CSV::downloadSendHeaders($filename . '.csv'); echo CSV::array2csv($data); die(); } } } /** * Génère le contenu nécessaire aux exports au format CSV. * * @see OrderController::actionDownload() * @param string $date * @param array $products * @param array $pointsSale * @param array $orders * @return array */ public function contentRecapCSV($date, $products, $pointsSale, $orders) { $data = []; $filename = 'summary_' . $date; $distribution = Distribution::find() ->where('date LIKE \':date\'') ->params([':date' => $date]) ->one(); $selectedProductsArray = ProductDistribution::searchByDistribution($distribution->id); // head $data[0] = ['Lieu']; foreach ($products as $product) { if (isset($selectedProductsArray[$product->id]['active']) && $selectedProductsArray[$product->id]['active']) { $data[0][] = $product->description; } } $dayWeek = date('w', strtotime($date)); $dayWeekArray = [0 => 'sunday', 1 => 'monday', 2 => 'tuesday', 3 => 'wednesday', 4 => 'thursday', 5 => 'friday', 6 => 'saturday']; $fieldHoursPointSale = 'infos_' . $dayWeekArray[$dayWeek]; // datas foreach ($pointsSale as $pointSale) { if (count($pointSale->orders) && strlen($pointSale->$fieldHoursPointSale)) { $dataAdd = [$pointSale->name]; foreach ($products as $product) { if (isset($selectedProductsArray[$product->id]['active']) && $selectedProductsArray[$product->id]['active']) { $dataAdd[] = Order::getProductQuantity($product->id, $pointSale->orders); } } $data[] = $dataAdd; } } $dataAdd = ['Total']; foreach ($products as $product) { if (isset($selectedProductsArray[$product->id]['active']) && $selectedProductsArray[$product->id]['active']) { $dataAdd[] = Order::getProductQuantity($product->id, $orders); } } $data[] = $dataAdd; return [ 'data' => $data, 'filename' => $filename ]; } /** * Génère le contenu relatif aux points de vente nécessaires aux exports au * format CSV. * * @param string $date * @param array $produits * @param array $points_vente * @param integer $id_point_vente * @return array */ public function contentPointSaleCSV($date, $products, $pointsSale, $idPointSale) { $data = []; $distribution = Distribution::find()->where('date LIKE \':date\'')->params([':date' => $date])->one(); $selectedProductsArray = ProductDistribution::searchByDistribution($distribution->id); // datas foreach ($pointsSale as $pointSale) { if ($pointSale->id == $idPointSale) { $filename = 'export_' . $date . '_' . strtolower(str_replace(' ', '-', $pointSale->name)); foreach ($pointSale->orders as $order) { $strUser = ''; // username if ($order->user) { $strUser = $order->user->name . " " . $order->user->lastname; } else { $strUser = $order->username; } // téléphone if (isset($order->user) && strlen($order->user->phone)) { $strUser .= ' (' . $order->user->phone . ')'; } $dataAdd = [$strUser]; // produits $strProducts = ''; foreach ($products as $product) { if (isset($selectedProductsArray[$product->id]['active']) && $selectedProductsArray[$product->id]['active']) { $add = false; foreach ($product->productOrder as $productOrder) { if ($product->id == $productOrder->id_product) { $strProducts .= $productOrder->quantity ; $add = true; } } } } $dataAdd[] = substr($strProducts, 0, strlen($strProducts) - 2); $dataAdd[] = number_format($order->amount, 2) . ' €'; $dataAdd[] = $order->comment; $data[] = $dataAdd; } } } return [ 'data' => $data, 'filename' => $filename ]; } /** * Ajoute les commandes récurrentes pour une date donnée. * * @param string $date */ public function actionAddSubscriptions($date) { Subscription::addAll($date, true); $this->redirect(['index', 'date' => $date]); } /** * Change l'état d'un jour de production (activé, désactivé). * * @param string $date * @param integer $actif * @param boolean $redirect */ public function actionChangeState($date, $active, $redirect = true) { // changement état $distribution = Distribution::initDistribution($date) ; $distribution->active = $active; $distribution->save(); if ($active) { // add commandes automatiques Subscription::addAll($date); } if($redirect) { $this->redirect(['index', 'date' => $date]); } } /** * Change l'état d'une semaine de production (activé, désactivé). * * @param string $date * @param integer $actif */ public function actionChangeStateWeek($date, $active) { $week = sprintf('%02d',date('W',strtotime($date))); $start = strtotime(date('Y',strtotime($date)).'W'.$week); $dateMonday = date('Y-m-d',strtotime('Monday',$start)) ; $dateTuesday = date('Y-m-d',strtotime('Tuesday',$start)) ; $dateWednesday = date('Y-m-d',strtotime('Wednesday',$start)) ; $dateThursday = date('Y-m-d',strtotime('Thursday',$start)) ; $dateFriday = date('Y-m-d',strtotime('Friday',$start)) ; $dateSaturday = date('Y-m-d',strtotime('Saturday',$start)) ; $dateSunday = date('Y-m-d',strtotime('Sunday',$start)) ; $pointsSaleArray = PointSale::searchAll() ; $activeMonday = false ; $activeTuesday = false ; $activeWednesday = false ; $activeThursday = false ; $activeFriday = false ; $activeSaturday = false ; $activeSunday = false ; foreach($pointsSaleArray as $pointSale) { if($pointSale->delivery_monday) $activeMonday = true ; if($pointSale->delivery_tuesday) $activeTuesday = true ; if($pointSale->delivery_wednesday) $activeWednesday = true ; if($pointSale->delivery_thursday) $activeThursday = true ; if($pointSale->delivery_friday) $activeFriday = true ; if($pointSale->delivery_saturday) $activeSaturday = true ; if($pointSale->delivery_sunday) $activeSunday = true ; } if($activeMonday || !$active) $this->actionChangeState($dateMonday, $active, false) ; if($activeTuesday || !$active) $this->actionChangeState($activeTuesday, $active, false) ; if($activeWednesday || !$active) $this->actionChangeState($activeWednesday, $active, false) ; if($activeThursday || !$active) $this->actionChangeState($activeThursday, $active, false) ; if($activeFriday || !$active) $this->actionChangeState($activeFriday, $active, false) ; if($activeSaturday || !$active) $this->actionChangeState($activeSaturday, $active, false) ; if($activeSunday || !$active) $this->actionChangeState($activeSunday, $active, false) ; $this->redirect(['index', 'date' => $date]); } /** * Met à jour une commande via une requête AJAX. * * @param integer $id_commande * @param array $produits * @param string $date * @param string $commentaire */ public function actionAjaxUpdate( $idOrder, $products, $date, $comment) { $order = Order::searchOne(['id' => $idOrder]) ; if ($order && $order->distribution->id_producer == Producer::getId()) { $products = json_decode($products); foreach ($products as $key => $quantity) { $productOrder = ProductOrder::findOne([ 'id_order' => $idOrder, 'id_product' => $key ]); if ($quantity) { if ($productOrder) { $productOrder->quantity = $quantity; } else { $product = Product::findOne($key); if ($product) { $productOrder = new ProductOrder; $productOrder->id_order = $idOrder; $productOrder->id_product = $key; $productOrder->quantity = $quantity; $productOrder->price = $product->price; } } $productOrder->save(); } else { if ($productOrder) { $productOrder->delete(); } } } $order->date_update = date('Y-m-d H:i:s'); $order->comment = $comment; $order->save(); // data commande $jsonOrder = $order->getDataJson(); // total point de vente $pointSale = PointSale::findOne($order->id_point_sale); $orders = Order::searchAll([ 'distribution.date' => $date ]) ; $pointSale->initOrders($orders); echo json_encode([ 'total_point_sale' => number_format($pointSale->revenues, 2) . ' €', 'json_order' => $jsonOrder ]); die(); } } /** * Supprime une commande via une requête AJAX. * * @param string $date * @param integer $idOrder */ public function actionAjaxDelete($date, $idOrder) { $order = Order::searchOne([ 'id' => $idOrder ]) ; // delete if ($order) { // remboursement si l'utilisateur a payé pour cette commande $amountPaid = $order->getAmount(Order::AMOUNT_PAID); if ($amountPaid > 0.01) { $order->saveCreditHistory( CreditHistory::TYPE_REFUND, $amountPaid, Producer::getId(), $order->id_user, User::getCurrentId() ); } $order->delete(); ProductOrder::deleteAll(['id_order' => $idOrder]); } // total point de vente $pointSale = PointSale::findOne($order->id_point_sale); $orders = Order::searchAll([ 'distribution.date' => $date, ]) ; $pointSale->initOrders($orders); echo json_encode([ 'total_point_sale' => number_format($pointSale->revenues, 2) . ' €', ]); die(); } /** * Crée une commande via une requête AJAX. * * @param string $date * @param integer $id_pv * @param integer $id_user * @param string $username * @param array $produits * @param string $commentaire */ public function actionAjaxCreate( $date, $idPointSale, $idUser, $username, $products, $comment) { $products = json_decode($products); $pointSale = PointSale::findOne($idPointSale); $distribution = Distribution::searchOne([ 'date' => $date ]); if (preg_match("/^[0-9]{4}-(0[1-9]|1[0-2])-(0[1-9]|[1-2][0-9]|3[0-1])$/", $date) && ($idUser || strlen($username)) && $pointSale && count($products) && $distribution) { $order = new Order; $order->date = date('Y-m-d H:i:s', strtotime($date . ' ' . date('H:i:s'))); $order->id_point_sale = $idPointSale; $order->id_distribution = $distribution->id; $order->origin = Order::ORIGIN_ADMIN; $order->comment = $comment; if ($idUser) { $order->id_user = $idUser; // commentaire du point de vente $userPointSale = UserPointSale::searchOne([ 'id_point_sale' => $idPointSale, 'id_user' => $idUser ]) ; if ($userPointSale && strlen($userPointSale->comment)) { $order->comment_point_sale = $userPointSale->comment; } } else { $order->username = $username; $order->id_user = 0; } $order->save(); foreach ($products as $key => $quantity) { $product = Product::findOne($key); if ($product) { $productOrder = new ProductOrder; $productOrder->id_order = $order->id; $productOrder->id_product = $key; $productOrder->quantity = $quantity; $productOrder->price = $product->price; $productOrder->save(); } } // total point de vente $pointSale = PointSale::findOne($order->id_point_sale); $orders = Order::searchAll([ 'distribution.date' => $date ]) ; $pointSale->initOrders($orders); // json commande $order = Order::searchOne([ 'id' => $order->id ]) ; $products = []; foreach ($order->productOrder as $productOrder) { $products[$productOrder->id_product] = $productOrder->quantity; } $jsonOrder = json_encode(['amount' => number_format($order->amount, 2), 'products' => $products]); $jsonOrder = $order->getDataJson(); $str_user = ''; if ($order->user) { $strUser = $order->user->name . ' ' . $order->user->lastname; } else { $strUser = $order->username; } $strComment = ''; if (strlen($order->comment)) { $strComment = ' '; } $strLabelOrderOrigin = ''; if ($order->origin) { $strLabelOrderOrigin = ' vous'; } echo json_encode([ 'id_order' => $order->id, 'total_point_sale' => number_format($pointSale->revenues, 2) . ' €', 'order' => '
  • ' . '' . '' . number_format($order->amount, 2) . ' €' . '' . $strLabelOrderOrigin . ' ' . $strUser . '' . $strComment . '
  • ', ]); die(); } } /** * Retourne un récapitulatif du total des commandes (potentiel, commandé et * par produits) au format HTML; * * @param string $date */ public function actionAjaxTotalOrders($date) { $distribution = Distribution::searchOne([ 'date' => $date ]) ; if ($distribution) { // produits $products = Product::searchAll() ; // commandes $orders = Order::searchAll([ 'distribution.date' => $date ]) ; $revenues = 0; $weight = 0; foreach ($orders as $c) { if(is_null($c->date_delete)) { $revenues += $c->amount; $weight += $c->weight; } } // produits selec pour production $selectedProducts = ProductDistribution::searchByDistribution($distribution->id); $potentialTurnover = 0; $totalWeight = 0; foreach ($selectedProducts as $idSelectedProduct => $selectedProduct) { if ($selectedProduct['active']) { foreach ($products as $product) { if ($product->id == $idSelectedProduct) { $potentialTurnover += $selectedProduct['quantity_max'] * $product->price; $totalWeight += $selectedProduct['quantity_max'] * $product->weight / 1000; } } } } $htmlTotals = $this->renderPartial('_total_orders.php', [ 'arrayProducts' => $products, 'arrayOrders' => $orders, 'arrayProductsSelected' => $selectedProducts, 'revenues' => $revenues, 'totalWeight' => $totalWeight, 'potentialTurnover' => $potentialTurnover, 'weight' => $weight, ]); echo json_encode([ 'html_totals' => $htmlTotals, ]); } die(); } /** * Active ou désactive la livraison dans un point de vente. * * @param integer $id_production * @param integer $id_point_vente * @param boolean $bool_livraison */ public function actionAjaxPointSaleDelivery( $idDistribution, $idPointSale, $boolDelivery) { $pointSaleDistribution = PointSaleDistribution::searchOne([ 'id_distribution' => $idDistribution, 'id_point_sale' => $idPointSale, ]) ; if ($pointSaleDistribution) { $pointSaleDistribution->delivery = $boolDelivery; $pointSaleDistribution->save(); } die(); } /** * Retourne l'état du paiement (historique, crédit) d'une commande donnée. * * @param integer $idOrder */ public function actionPaymentStatus($idOrder) { $order = Order::searchOne(['id' => $idOrder]) ; if ($order) { $html = ''; if ($order->id_user) { $userProducer = UserProducer::find() ->where([ 'id_user' => $order->id_user, 'id_producer' => $order->distribution->id_producer ]) ->one(); $amountPaid = $order->getAmount(Order::AMOUNT_PAID); if (abs($order->amount - $amountPaid) < 0.0001) { $html .= 'Payé'; $buttonsCredit = Html::a('Rembourser ' . $order->getAmount(Order::AMOUNT_TOTAL, true), 'javascript:void(0);', ['class' => 'btn btn-default btn-xs rembourser', 'data-montant' => $order->amount, 'data-type' => 'refund']); } elseif ($order->amount > $amountPaid) { $amountToPay = $order->amount - $amountPaid; $html .= 'Non payé reste ' . number_format($amountToPay, 2) . ' € à payer'; $buttonsCredit = Html::a('Payer ' . number_format($amountToPay, 2) . ' €', 'javascript:void(0);', ['class' => 'btn btn-default btn-xs payer', 'data-montant' => $amountToPay, 'data-type' => 'payment']); } elseif ($order->amount < $amountPaid) { $amountToRefund = $amountPaid - $order->amount; $html .= ' Payé ' . number_format($amountToRefund, 2) . ' € à rembourser'; $buttonsCredit = Html::a('Rembourser ' . number_format($amountToRefund, 2) . ' €', 'javascript:void(0);', ['class' => 'btn btn-default btn-xs rembourser', 'data-montant' => $amountToRefund, 'data-type' => 'refund']); } $html .= '' . 'Crédit : ' . number_format($userProducer->credit, 2) . ' €
    ' . $buttonsCredit . '
    '; // historique $history = CreditHistory::find() ->with('userAction') ->where(['id_order' => $idOrder]) ->all(); $html .= '

    Historique
    ' . '' . ''; if ($history && is_array($history) && count($history)) { foreach ($history as $h) { $html .= '' . '' . '' . '' . '' . '' . ''; } } else { $html .= ''; } $html .= '
    DateUtilisateurAction- Débit+ Crédit
    ' . date('d/m/Y H:i:s', strtotime($h->date)) . '' . Html::encode($h->strUserAction()) . '' . $h->getStrWording() . '' . ($h->isTypeDebit() ? '- '.$h->getAmount(Order::AMOUNT_TOTAL,true) : '') . '' . ($h->isTypeCredit() ? '+ '.$h->getAmount(Order::AMOUNT_TOTAL,true) : '') . '
    Aucun résultat
    '; } else { $html .= '
    Pas de gestion de crédit pain pour cette commande car elle n\'est pas liée à un compte utilisateur.
    '; } echo json_encode([ 'html_payment_status' => $html, 'json_order' => $order->getDataJson() ]); } die(); } /** * Effectue le paiement/remboursement d'une commande. * * @param integer $id_commande * @param string $type * @param float $montant * @return string */ public function actionPayment($idOrder, $type, $amount) { $order = Order::searchOne([ 'id' => $idOrder ]) ; if ($order) { $order->saveCreditHistory( $type, $amount, Producer::getId(), $order->id_user, User::getCurrentId() ); } return $this->actionPaymentStatus($idOrder); } }