[ 'class' => VerbFilter::className(), 'actions' => [ ], ], 'access' => [ 'class' => AccessControl::className(), 'rules' => [ [ 'allow' => true, 'roles' => ['@'], 'matchCallback' => function ($rule, $action) { return User::hasAccessBackend(); } ] ], ], ]; } public function actionGeneratePdfValidatedDocuments() { set_time_limit(0); $validatedDocumentsArray = array_merge( Quotation::find()->where(['status' => Document::STATUS_VALID])->all(), DeliveryNote::find()->where(['status' => Document::STATUS_VALID])->all(), Invoice::find()->where(['status' => Document::STATUS_VALID])->all() ); foreach($validatedDocumentsArray as $document) { if(!file_exists($document->getFilenameComplete())) { $document->generatePdf(Pdf::DEST_FILE); } } } public function actionCreate() { $class = $this->getClass(); $model = new $class(); $model->initTaxCalculationMethod(); if ($model->load(Yii::$app->request->post())) { $model->id_producer = GlobalParam::getCurrentProducerId(); if ($model->save()) { $this->processInvoiceViaDeliveryNotes($model); Yii::$app->getSession()->setFlash('success', $this->getFlashMessage('create', $model)); return $this->redirect(['/' . $this->getControllerUrl() . '/update', 'id' => $model->id]); } else { Yii::$app->getSession()->setFlash('error', 'Un problème est survenu lors de la création du document.'); } } return $this->render('/document/create', [ 'title' => $this->getTitle('Ajouter'), 'typeDocument' => $this->getDocumentType(), 'model' => $model, ]); } public function processInvoiceViaDeliveryNotes($model) { if ($model->getClass() == 'Invoice') { if ($model->deliveryNotes && is_array($model->deliveryNotes) && count($model->deliveryNotes)) { foreach ($model->deliveryNotes as $key => $idDeliveryNote) { Order::updateAll([ 'id_invoice' => $model->id ], [ 'id_delivery_note' => $idDeliveryNote ]); } } } } /** * Modifie un modèle Produit existant. * Si la modification réussit, le navigateur est redirigé vers la page 'index'. * * @param integer $id * @return mixed */ public function actionUpdate($id) { $model = $this->findModel($id); if (!$model) { throw new NotFoundHttpException('Le document n\'a pas été trouvé.'); } if ($model && $model->load(Yii::$app->request->post()) && $model->save()) { Yii::$app->getSession()->setFlash('success', $this->getFlashMessage('update', $model)); } return $this->render('/document/update', [ 'title' => $this->getTitle('Modifier'), 'typeDocument' => $this->getDocumentType(), 'model' => $model, ]); } public function actionDelete($id) { $model = $this->findModel($id); if ($model->isStatusValid()) { throw new UserException('Vous ne pouvez pas supprimer un document validé.'); } $model->delete(); if ($this->getClass() == 'DeliveryNote') { Order::updateAll([ 'order.id_delivery_note' => null ], [ 'order.id_delivery_note' => $id ]); } if ($this->getClass() == 'Quotation') { Order::updateAll([ 'order.id_quotation' => null ], [ 'order.id_quotation' => $id ]); } if ($this->getClass() == 'Invoice') { Order::updateAll([ 'order.id_invoice' => null ], [ 'order.id_invoice' => $id ]); } Yii::$app->getSession()->setFlash('success', $this->getFlashMessage('delete', $model)); $this->redirect([$this->getControllerUrl() . '/index']); } public function actionExportCsvEvoliz($id) { $datas = []; $document = $this->findModel($id); // données $datas[] = [ 'N° facture externe *', 'Date facture *', 'Client', 'Code client *', 'Total TVA', 'Total HT', 'Total TTC', 'Total réglé', 'Etat', 'Date Etat', 'Date de création', 'Objet', 'Date d\'échéance', 'Date d\'exécution', 'Taux de pénalité', 'Frais de recouvrement', 'Taux d\'escompte', 'Conditions de règlement *', 'Mode de paiement', 'Remise globale', 'Acompte', 'Nombre de relance', 'Commentaires', 'N° facture', 'Annulé', 'Catalogue', 'Réf.', 'Désignation *', 'Qté *', 'Unité', 'PU HT *', 'Remise', 'TVA', 'Total TVA', 'Total HT', 'Créateur', ]; foreach($document->getProductsOrders() as $productOrderArray) { foreach($productOrderArray as $productOrder) { $price = $productOrder->getPrice() ; if($document->isInvoicePrice() && $productOrder->getInvoicePrice()) { $price = $productOrder->getInvoicePrice() ; } $datas[] = [ $document->reference, // N° facture externe * date('d/m/Y', strtotime($document->date)), // Date facture * '', // Client $document->user->evoliz_code, // Code client * '', // Total TVA '', // Total HT '', // Total TTC '', // Total réglé '', // Etat '', // Date Etat '', // Date de création $document->name, // Objet '', // Date d'échéance '', // Date d'exécution '', // Taux de pénalité '', // Frais de recouvrement '', // Taux d\'escompte 'A réception', // Conditions de règlement * '', // Mode de paiement '', // Remise globale '', // Acompte '', // Nombre de relance '', // Commentaires '', // N° facture '', // Annulé 'Non', // Catalogue '', // Réf. $productOrder->product->name, // Désignation * $productOrder->quantity, // Qté * '', // Product::strUnit($productOrder->unit, 'wording'), // Unité $price, // PU HT * '', // Remise $productOrder->taxRate->value * 100, // TVA '', // Total TVA '', // Total HT '', // Créateur ]; } } // nom fichier $reference = $document->id; if($document->reference && strlen($document->reference)) { $reference = $document->reference; } // status $status = ''; if($document->isStatusDraft()) { $status = 'brouillon_'; } CSV::downloadSendHeaders(strtolower($this->getDocumentType()).'_' . $status . $reference . '.csv'); echo CSV::array2csv($datas); die(); } public function actionDownload($id) { $document = $this->findModel($id); return $document->downloadPdf(); } public function actionSend($id, $backUpdateForm = false) { $document = $this->findModel($id); if ($document->send()) { $document->is_sent = true; $document->save(); Yii::$app->getSession()->setFlash('success', $this->getFlashMessage('send', $document)); } else { Yii::$app->getSession()->setFlash('danger', $this->getFlashMessage('send', $document)); } if($backUpdateForm) { return $this->redirect([$this->getControllerUrl() . '/update', 'id' => $id]); } else { return $this->redirect([$this->getControllerUrl() . '/index']); } } public function actionAjaxUserInfos($typeAction, $idUser, $classDocument, $idDocument = false) { \Yii::$app->response->format = \yii\web\Response::FORMAT_JSON; if ($idUser > 0) { $user = User::searchOne([ 'id' => $idUser ]); if ($user) { $document = null; if (Document::isValidClass($classDocument)) { $document = $classDocument::searchOne([ 'id' => $idDocument, 'id_user' => $idUser ]); } if ($document && $document->id_user == $user->id) { $address = $document->address; } else { $address = $user->getFullAddress(); } $json = [ 'return' => 'success', 'address' => $address ]; if ($classDocument == 'Invoice') { $options = [ 'orderby' => 'distribution.date ASC' ]; $deliveryNotesCreateArray = DeliveryNote::searchAll([ 'id_user' => $user->id, 'status' => Document::STATUS_VALID ], $options); $deliveryNotesUpdateArray = DeliveryNote::searchAll([ 'id_user' => $user->id, 'status' => Document::STATUS_VALID, 'order.id_invoice' => $idDocument ], $options); $json['delivery_note_create_array'] = $this->initDeliveryNoteArray('create', $deliveryNotesCreateArray); $json['delivery_note_update_array'] = $this->initDeliveryNoteArray('update', $deliveryNotesUpdateArray); } return $json; } } return ['return' => 'error']; } public function initDeliveryNoteArray($type, $deliveryNoteArrayResults) { $deliveryNoteArray = []; $isCreate = false; if($type == 'create') { $isCreate = true; } if($deliveryNoteArrayResults) { foreach ($deliveryNoteArrayResults as $deliveryNote) { $deliveryNoteData = $this->addDeliveryNoteToArray($deliveryNote, $isCreate); if($deliveryNoteData) { $deliveryNoteArray[] = $deliveryNoteData; } } } return $deliveryNoteArray; } public function addDeliveryNoteToArray($deliveryNote, $isCreate = true) { $deliveryNoteData = array_merge( $deliveryNote->getAttributes(), [ 'url' => Yii::$app->urlManager->createUrl(['delivery-note/update', 'id' => $deliveryNote->id]), 'total' => $deliveryNote->getAmountWithTax(Order::INVOICE_AMOUNT_TOTAL) ] ); if (($isCreate && !$deliveryNote->isInvoiced()) || !$isCreate) { return $deliveryNoteData; } return false; } public function actionValidate($id, $backUpdateForm = false) { $classDocument = $this->getClass(); if ($id > 0 && Document::isValidClass($classDocument)) { $document = $classDocument::searchOne([ 'id' => $id ]); if ($document) { $document->changeStatus(Document::STATUS_VALID); $document->save(); // génération PDF $document->generatePdf(Pdf::DEST_FILE); Yii::$app->getSession()->setFlash('success', $this->getFlashMessage('validate', $document)); if($backUpdateForm) { return $this->redirect([$this->getControllerUrl() . '/update', 'id' => $id]); } else { return $this->redirect([$this->getControllerUrl() . '/index']); } } } Yii::$app->getSession()->setFlash('danger', 'Une erreur est survenue lors de la validation du document.'); return $this->redirect([$this->getControllerUrl() . '/index']); } public function actionAjaxValidateDocument($idDocument, $classDocument) { \Yii::$app->response->format = \yii\web\Response::FORMAT_JSON; if ($idDocument > 0 && Document::isValidClass($classDocument)) { $document = $classDocument::searchOne([ 'id' => $idDocument ]); if ($document) { $document->changeStatus(Document::STATUS_VALID); $document->save(); return [ 'return' => 'success', 'alert' => [ 'type' => 'success', 'message' => 'Document validé' ] ]; } } return [ 'return' => 'error', 'alert' => [ 'type' => 'danger', 'message' => 'Une erreur est survenue lors de la validation du document.' ] ]; } public function actionAjaxInit($idDocument, $classDocument) { \Yii::$app->response->format = \yii\web\Response::FORMAT_JSON; if ($idDocument > 0 && Document::isValidClass($classDocument)) { $document = $classDocument::searchOne([ 'id' => $idDocument ]); if ($document) { $productsArray = Product::searchAll([], [ 'orderby' => 'product.order ASC' ]); $ordersArray = []; foreach ($document->orders as $order) { $order->init(); $productsOrderArray = []; foreach ($order->productOrder as $productOrder) { $productsOrderArray[$productOrder->id] = array_merge($productOrder->getAttributes(), [ 'url_order' => Yii::$app->urlManager->createUrl(['distribution/index', 'idOrderUpdate' => $productOrder->id_order]) ]); } $ordersArray[$order->id] = array_merge( $order->getAttributes(), [ 'username' => $order->getUsername(), 'distribution_date' => isset($order->distribution) ? date( 'd/m/Y', strtotime( $order->distribution->date ) ) : null, 'point_sale_name' => isset($order->pointSale) ? $order->pointSale->name : null, 'productOrder' => $productsOrderArray, ] ); } $userProducer = UserProducer::searchOne([ 'id_user' => $document->user->id, 'id_producer' => GlobalParam::getCurrentProducerId() ]); $pointSale = PointSale::searchOne([ 'id_user' => $document->user->id ]); $productsArray = yii\helpers\ArrayHelper::map( $productsArray, 'order', function ($product) use ($document, $userProducer, $pointSale) { return array_merge($product->getAttributes(), [ 'unit_coefficient' => Product::$unitsArray[$product->unit]['coefficient'], 'prices' => $product->getPriceArray($userProducer->user, $pointSale), 'wording_unit' => $product->wording_unit, 'tax_rate' => $product->taxRate->value ]); } ); return [ 'return' => 'success', 'tax_rate_producer' => GlobalParam::getCurrentProducer()->taxRate->value, 'document' => array_merge($document->getAttributes(), [ 'html_label' => $document->getHtmlLabel(), 'class' => $document->getClass() ]), 'id_user' => $document->user->id, 'products' => $productsArray, 'orders' => $ordersArray, 'total' => ($document->getClass() == 'Invoice' || $document->getClass( ) == 'DeliveryNote') ? $document->getAmount( Order::INVOICE_AMOUNT_TOTAL ) : $document->getAmount(Order::AMOUNT_TOTAL), 'total_with_tax' => ($document->getClass() == 'Invoice' || $document->getClass( ) == 'DeliveryNote') ? $document->getAmountWithTax( Order::INVOICE_AMOUNT_TOTAL ) : $document->getAmountWithTax(Order::AMOUNT_TOTAL), 'invoice_url' => ($document->getClass() == 'DeliveryNote' && $document->getInvoice()) ? Yii::$app->urlManager->createUrl(['invoice/update', 'id' => $document->getInvoice()->id]) : null ]; } } return ['return' => 'error']; } public function actionAjaxAddProduct($idDocument, $classDocument, $idProduct, $quantity, $price) { \Yii::$app->response->format = \yii\web\Response::FORMAT_JSON; if (Document::isValidClass($classDocument)) { $document = $classDocument::searchOne([ 'id' => $idDocument ]); $product = Product::searchOne([ 'id' => $idProduct ]); if ($document && $product) { if (count($document->orders) == 0) { $order = new Order; $order->id_user = $document->id_user; $order->id_point_sale = null; $order->id_distribution = null; $order->status = 'tmp-order'; $order->origin = Order::ORIGIN_ADMIN; $order->date = date('Y-m-d H:i:s'); $fieldIdDocument = 'id_' . $classDocument::tableName(); $order->$fieldIdDocument = $document->id; $order->save(); } else { $order = $document->orders[0]; } if ($order) { $productOrder = new ProductOrder; $productOrder->id_order = $order->id; $productOrder->id_product = $idProduct; $quantity = $quantity / Product::$unitsArray[$product->unit]['coefficient']; $productOrder->quantity = $quantity; $productOrder->price = (float)$price; $productOrder->unit = $product->unit; $productOrder->step = $product->step; $productOrder->id_tax_rate = $product->taxRate->id; $productOrder->save(); return [ 'return' => 'success', 'alert' => [ 'type' => 'success', 'message' => 'Produit ajouté' ] ]; } } } return [ 'return' => 'error', 'alert' => [ 'type' => 'danger', 'message' => 'Une erreur est survenue lors de la suppression du produit.' ] ]; } public function actionAjaxDeleteProductOrder($idProductOrder) { \Yii::$app->response->format = \yii\web\Response::FORMAT_JSON; $productOrder = ProductOrder::searchOne([ 'id' => $idProductOrder ]); if ($productOrder) { $productOrder->delete(); return [ 'return' => 'success', 'alert' => [ 'type' => 'danger', 'message' => 'Produit supprimé' ] ]; } return [ 'return' => 'error', 'alert' => [ 'type' => 'danger', 'message' => 'Une erreur est survenue lors de la suppression du produit.' ] ]; } public function getClass() { $class = get_class($this); $class = str_replace('Controller', '', $class); $class = str_replace('backend\controllers\\', '', $class); return $class; } public function getDocumentType() { $class = $this->getClass(); if ($class == 'Invoice') { $documentType = 'Facture'; } elseif ($class == 'DeliveryNote') { $documentType = 'Bon de livraison'; } elseif ($class == 'Quotation') { $documentType = 'Devis'; } if (isset($documentType)) { return $documentType; } return ''; } public function getFlashMessage($type = 'create', $model) { $class = $this->getClass(); $message = $this->getDocumentType(); $message .= ' ' . Html::encode($model->name) . ' '; if ($type == 'create') { $message .= 'ajouté'; } elseif ($type == 'update') { $message .= 'modifié'; } elseif ($type == 'delete') { $message .= 'supprimé'; } elseif ($type == 'validate') { $message .= 'validé'; } elseif ($type == 'send') { $message .= 'envoyé'; } if ($class == 'Invoice') { $message .= 'e'; } return $message; } protected function getTitle($prepend) { $class = $this->getClass(); switch ($class) { case 'Invoice' : $title = $prepend . ' une facture'; break; case 'DeliveryNote' : $title = $prepend . ' un bon de livraison'; break; case 'Quotation' : $title = $prepend . ' un devis'; break; } return $title; } public function getControllerUrl() { $path = strtolower($this->getClass()); $path = str_replace('deliverynote', 'delivery-note', $path); return $path; } /** * Recherche un Document en fonction de son ID. * * @param integer $id * @return Document * @throws NotFoundHttpException si le modèle n'est pas trouvé */ protected function findModel($id) { $class = $this->getClass(); $model = $class::searchOne([ 'id' => $id ], [ 'orderby' => 'teshtygjhtyt' ]); if ($model) { return $model; } else { throw new NotFoundHttpException('The requested page does not exist.'); } } }