|
1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171 |
- <?php
-
- /**
- * Copyright distrib (2018)
- *
- * contact@opendistrib.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.
- */
-
- namespace backend\controllers;
-
- use common\helpers\GlobalParam;
-
- class OrderController extends BackendController
- {
- var $enableCsrfValidation = false;
-
- public function behaviors()
- {
- return [
- 'access' => [
- 'class' => AccessControl::className(),
- 'rules' => [
- [
- 'allow' => true,
- 'roles' => ['@'],
- 'matchCallback' => function ($rule, $action) {
- return User::getCurrentStatus() == User::STATUS_ADMIN
- || User::getCurrentStatus() == User::STATUS_PRODUCER;
- }
- ]
- ],
- ],
- ];
- }
-
- /**
- * 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->unit = $p->unit;
- $productOrder->step = $p->step;
- $productOrder->id_tax_rate = $p->taxRate->id;
- $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->unit = $p->unit;
- $productOrder->step = $p->step;
- $productOrder->id_tax_rate = $p->taxRate->id;
- $productOrder->save();
- }
- }
-
- $order->initReference();
- }
- }
- }
- }
- }
-
- /**
- * Page principale de la gestion des commandes.
- *
- * @param string $date
- * @param boolean $returnData
- * @return string
- */
- public function actionIndex($date = '', $returnData = false)
- {
- if (! Product::searchCount() || !PointSale::searchCount()) {
- $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 = DistributionModel::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' => GlobalParam::getCurrentProducerId(),
- ])
- ->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,
- ]);
-
- $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 = ProductDistributionModel::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 = ProductDistributionModel::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 = DistributionModel::searchAll([
- 'active' => 1
- ]);
-
- // commandes auto
- $subscriptionForm = new SubscriptionForm;
-
- // productions point vente
- $pointSaleDistribution = new PointSaleDistribution;
-
- $oointsSaleDistribution = [];
-
- if ($distribution) {
- $pointsSaleDistribution = PointSaleDistributionModel::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 = DistributionModel::find()
- ->andWhere([
- 'id_producer' => GlobalParam::getCurrentProducerId(),
- '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 = DistributionModel::find()
- ->where('date LIKE \':date\'')
- ->params([':date' => $date])
- ->one();
-
- $selectedProductsArray = ProductDistributionModel::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.
- *
- * @param string $date
- * @param array $products
- * @param array $pointsSale
- * @param array $orders
- * @return array
- * @see OrderController::actionDownload()
- */
- public function contentRecapCSV($date, $products, $pointsSale, $orders)
- {
- $data = [];
- $filename = 'summary_' . $date;
-
- $distribution = DistributionModel::find()
- ->where('date LIKE \':date\'')
- ->params([':date' => $date])
- ->one();
-
- $selectedProductsArray = ProductDistributionModel::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 = DistributionModel::find()->where('date LIKE \':date\'')->params([':date' => $date])->one();
- $selectedProductsArray = ProductDistributionModel::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
- ];
- }
-
- /**
- * 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 = DistributionModel::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]);
- }
-
- /**
- * Supprime une commande via une requête AJAX.
- *
- * @param string $date
- * @param integer $idOrder
- */
- public function actionAjaxDelete($idOrder)
- {
- \Yii::$app->response->format = \yii\web\Response::FORMAT_JSON;
-
- $order = Order::searchOne([
- 'id' => $idOrder
- ]);
-
- // delete
- if ($order) {
- $order->delete();
- }
-
- return ['success'];
- }
-
-
- /**
- * Supprime une commande.
- *
- * @param string $date
- * @param integer $idOrder
- */
- public function actionDelete($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,
- GlobalParam::getCurrentUserId()
- );
- }
-
- $order->delete();
- ProductOrder::deleteAll(['id_order' => $idOrder]);
- }
-
- $this->redirect(['index', 'date' => $date]);
- }
-
- /**
- * Crée une commande via une requête AJAX.
- *
- * @param string $date
- * @param integer $idPointSale
- * @param integer $idUser
- * @param string $username
- * @param array $produits
- * @param string $commentaire
- * @param string $processCredit
- */
- public function actionAjaxCreate(
- $date, $idPointSale, $idUser, $username, $meanPayment = '', $products, $comment, $processCredit = 0)
- {
- \Yii::$app->response->format = \yii\web\Response::FORMAT_JSON;
-
- $products = json_decode($products);
- $pointSale = PointSale::findOne($idPointSale);
- $distribution = DistributionModel::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(get_object_vars($products)) &&
- $distribution) {
-
- $order = new Order;
- $order->date = date('Y-m-d H:i:s');
- $order->id_point_sale = $idPointSale;
- $order->mean_payment = $meanPayment;
- $order->id_distribution = $distribution->id;
- $order->origin = Order::ORIGIN_ADMIN;
- $order->comment = $comment;
- $order->status = 'tmp-order';
-
- 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();
-
- $user = false;
- $userProducer = false;
- if (isset($order->user) && $order->user) {
- $user = $order->user;
- $userProducer = UserProducer::searchOne([
- 'id_user' => $user->id,
- 'id_producer' => $order->distribution->id_producer
- ]);
- }
-
- foreach ($products as $key => $dataProductOrder) {
- $product = Product::findOne($key);
- $quantity = $dataProductOrder->quantity / Product::$unitsArray[$dataProductOrder->unit]['coefficient'];
- if ($product && $quantity) {
- $productOrder = new ProductOrder;
- $productOrder->id_order = $order->id;
- $productOrder->id_product = $key;
- $productOrder->quantity = $quantity;
- $productOrder->unit = $product->unit;
- $productOrder->step = $product->step;
- if ($dataProductOrder->price) {
- $productOrder->price = $dataProductOrder->price;
- } else {
- $productOrder->price = $product->getPrice([
- 'user' => $user,
- 'user_producer' => $userProducer,
- 'point_sale' => $order->pointSale,
- 'quantity' => $productOrder->quantity
- ]);
- }
- $productOrder->id_tax_rate = $product->taxRate->id;
- $productOrder->save();
- }
- }
-
- $order = Order::searchOne(['id' => $order->id]);
- if ($order && $processCredit) {
- $order->processCredit();
- }
-
- if ($order) {
- $order->initReference();
- $order->setTillerSynchronization();
- }
-
- // lien utilisateur / point de vente
- if ($idUser && $pointSale) {
- $pointSale->linkUser($idUser);
- }
- }
-
- return ['success'];
- }
-
- /**
- * Met à jour une commande via une requête AJAX.
- *
- * @param integer $idOrder
- * @param array $products
- * @param string $date
- * @param string $comment
- */
- public function actionAjaxUpdate()
- {
- $request = Yii::$app->request;
-
- $date = $request->post('date');
- $idOrder = $request->post('idOrder');
- $idPointSale = $request->post('idPointSale');
- $idUser = $request->post('idUser');
- $username = $request->post('username');
- $meanPayment = $request->post('meanPayment');
- $products = $request->post('products');
- $comment = $request->post('comment');
- $processCredit = $request->post('processCredit');
-
- \Yii::$app->response->format = \yii\web\Response::FORMAT_JSON;
-
- $order = Order::searchOne(['id' => $idOrder]);
-
- if ($order &&
- $order->distribution->id_producer == GlobalParam::getCurrentProducerId()) {
-
- $oldIdUser = $order->id_user;
- if ($idUser) {
- $order->username = '';
- $order->id_user = $idUser;
-
- // commentaire du point de vente
- $userPointSale = UserPointSale::searchOne([
- 'id_point_sale' => $order->id_point_sale,
- 'id_user' => $idUser
- ]);
-
- if ($userPointSale && strlen($userPointSale->comment)) {
- $order->comment_point_sale = $userPointSale->comment;
- }
- } else {
- $order->username = $username;
- $order->id_user = 0;
- }
-
- $user = User::searchOne(['id' => $order->id_user]);
- $userProducer = false;
- if ($user) {
- $userProducer = UserProducer::searchOne([
- 'id_user' => $user->id,
- 'id_producer' => $order->distribution->id_producer
- ]);
- }
-
- $products = json_decode($products);
- foreach ($products as $key => $dataProductOrder) {
- $productOrder = ProductOrder::findOne([
- 'id_order' => $idOrder,
- 'id_product' => $key
- ]);
-
- $quantity = $dataProductOrder->quantity
- / Product::$unitsArray[$dataProductOrder->unit]['coefficient'];
-
- if ($quantity) {
- if ($productOrder) {
- $productOrder->quantity = $quantity;
- $productOrder->price = $dataProductOrder->price;
- } else {
- $product = Product::findOne($key);
-
- if ($product) {
- $productOrder = new ProductOrder;
- $productOrder->id_order = $idOrder;
- $productOrder->id_product = $key;
- $productOrder->quantity = $quantity;
- $productOrder->unit = $product->unit;
- $productOrder->step = $product->step;
- $productOrder->id_tax_rate = $product->taxRate->id;
-
- if ($dataProductOrder->price) {
- $productOrder->price = $dataProductOrder->price;
- } else {
- $productOrder->price = $product->getPrice([
- 'user' => $user,
- 'user_producer' => $userProducer,
- 'point_sale' => $order->pointSale,
- 'quantity' => $productOrder->quantity
- ]);
- }
- }
- }
-
- $productOrder->save();
- } else {
- if ($productOrder) {
- $productOrder->delete();
- }
- }
- }
-
- $order->id_point_sale = $idPointSale;
- $order->date_update = date('Y-m-d H:i:s');
- $order->mean_payment = $meanPayment;
- $order->comment = $comment;
-
- $order->save();
-
- $order = Order::searchOne(['id' => $order->id]);
- if ($order && $processCredit) {
- // Si changement d'user : on rembourse l'ancien user
- $amountPaid = $order->getAmount(Order::AMOUNT_PAID);
- if($oldIdUser != $idUser && $amountPaid > 0) {
- $order->saveCreditHistory(
- CreditHistory::TYPE_REFUND,
- $amountPaid,
- GlobalParam::getCurrentProducerId(),
- $oldIdUser,
- GlobalParam::getCurrentUserId()
- );
- $order = Order::searchOne(['id' => $order->id]);
- }
-
- $order->processCredit();
- }
- }
- }
-
-
- /**
- * Retourne l'état du paiement (historique, crédit) d'une commande donnée.
- *
- * @param integer $idOrder
- */
- public function actionPaymentStatus($idOrder)
- {
- $creditHistoryService = \Yii::$app->logic->getCreditHistoryContainer()->getService();
- $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 .= '<span class="label label-success">Payé</span>';
- $buttonsCredit = Html::a('Rembourser ' . $order->getAmountWithTax(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 .= '<span class="label label-danger">Non payé</span> reste <strong>' . number_format($amountToPay, 2) . ' €</strong> à 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 .= ' <span class="label label-success">Payé</span> <strong>' . number_format($amountToRefund, 2) . ' €</strong> à 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 .= '<span class="buttons-credit">'
- . 'Crédit : <strong>' . number_format($userProducer->credit, 2) . ' €</strong><br />'
- . $buttonsCredit
- . '</span>';
-
- // historique
- $history = CreditHistory::find()
- ->with('userAction')
- ->where(['id_order' => $idOrder])
- ->all();
-
- $html .= '<br /><br /><strong>Historique</strong><br /><table class="table table-condensed table-bordered">'
- . '<thead><tr><th>Date</th><th>Utilisateur</th><th>Action</th><th>- Débit</th><th>+ Crédit</th></tr></thead>'
- . '<tbody>';
-
- if ($history && is_array($history) && count($history)) {
- foreach ($history as $creditHistory) {
- $html .= '<tr>'
- . '<td>' . date('d/m/Y H:i:s', strtotime($creditHistoryService->getDate($creditHistory))) . '</td>'
- . '<td>' . Html::encode($creditHistoryService->getStrUserAction($creditHistory)) . '</td>'
- . '<td>' . $creditHistoryService->getStrWording($creditHistory) . '</td>'
- . '<td>' . ($creditHistoryService->isTypeDebit($creditHistory) ? '- ' . $creditHistoryService->getAmountWithTax($creditHistory, Order::AMOUNT_TOTAL, true) : '') . '</td>'
- . '<td>' . ($creditHistoryService->isTypeCredit($creditHistory) ? '+ ' . $creditHistoryService->getAmountWithTax($creditHistory, Order::AMOUNT_TOTAL, true) : '') . '</td>'
- . '</tr>';
- }
- } else {
- $html .= '<tr><td colspan="4">Aucun résultat</td></tr>';
- }
-
- $html .= '</tbody></table>';
- } else {
- $html .= '<div class="alert alert-warning">Pas de gestion de crédit pain pour cette commande car elle n\'est pas liée à un compte utilisateur.</div>';
- }
-
- echo json_encode([
- 'html_payment_status' => $html,
- 'json_order' => $order->getDataJson()
- ]);
- }
-
- die();
- }
-
- /**
- * Effectue le paiement/remboursement d'une commande.
- *
- * @param integer $idOrder
- * @param string $type
- * @param float $amount
- * @return string
- */
- public function actionAjaxPayment($idOrder, $type, $amount)
- {
- \Yii::$app->response->format = \yii\web\Response::FORMAT_JSON;
-
- $order = Order::searchOne([
- 'id' => $idOrder
- ]);
-
- if ($order) {
- $order->saveCreditHistory(
- $type,
- $amount,
- GlobalParam::getCurrentProducerId(),
- $order->id_user,
- GlobalParam::getCurrentUserId()
- );
- }
-
- return ['success'];
- }
-
- /**
- * Modifie l'état de la synchronisation Tiller d'une commande.
- *
- * @param int $idOrder
- * @param boolean $boolSynchroTiller
- * @return array
- */
- public function actionAjaxChangeSynchroTiller($idOrder, $boolSynchroTiller)
- {
- \Yii::$app->response->format = \yii\web\Response::FORMAT_JSON;
-
- $order = Order::searchOne([
- 'id' => (int)$idOrder
- ]);
-
- if ($order) {
- $order->tiller_synchronization = (int)$boolSynchroTiller;
- $res = $order->save();
- return ['success'];
- }
-
- return ['error'];
- }
-
- }
-
|