|
- <?php
-
-
-
- namespace common\models;
-
- use common\helpers\Debug;
- use common\helpers\GlobalParam;
- use common\helpers\Price;
- use common\models\Producer;
- use Yii;
- use yii\helpers\Html;
- use common\components\ActiveRecordCommon;
- use yii\web\NotFoundHttpException;
-
-
- class Order extends ActiveRecordCommon
- {
- var $amount = 0;
- var $amount_with_tax = 0;
- var $invoice_amount = 0;
- var $invoice_amount_with_tax = 0;
- var $paid_amount = 0;
- var $weight = 0;
-
- const ORIGIN_AUTO = 'auto';
- const ORIGIN_USER = 'user';
- const ORIGIN_ADMIN = 'admin';
-
- const PAYMENT_PAID = 'paid';
- const PAYMENT_UNPAID = 'unpaid';
- const PAYMENT_SURPLUS = 'surplus';
-
- const INVOICE_AMOUNT_TOTAL = 'invoice-total' ;
- const AMOUNT_TOTAL = 'total';
- const AMOUNT_PAID = 'paid';
- const AMOUNT_REMAINING = 'remaining';
- const AMOUNT_SURPLUS = 'surplus';
-
- const STATE_OPEN = 'open';
- const STATE_PREPARATION = 'preparation';
- const STATE_DELIVERED = 'delivered';
-
-
-
- public static function tableName()
- {
- return 'order';
- }
-
-
-
- public function rules()
- {
- return [
- [['id_user', 'date', 'status'], 'required', 'message' => ''],
- [['id_user', 'id_point_sale', 'id_distribution', 'id_subscription', 'id_invoice', 'id_quotation', 'id_delivery_note'], 'integer'],
- [['auto_payment', 'tiller_synchronization'], 'boolean'],
- [['status'], 'string'],
- [['date', 'date_update', 'comment', 'comment_point_sale', 'mean_payment'], 'safe']
- ];
- }
-
-
-
- public function attributeLabels()
- {
- return [
- 'id' => 'ID',
- 'id_user' => 'Id User',
- 'date' => 'Date',
- 'date_update' => 'Date de modification',
- 'id_point_sale' => 'Point de vente',
- 'id_distribution' => 'Date de distribution',
- 'id_subscription' => 'Abonnement',
- 'status' => 'Statut',
- 'id_invoice' => 'Facture',
- 'id_quotation' => 'Devis',
- 'id_delivery_note' => 'Bon de livraison'
- ];
- }
-
-
-
-
- public function getUser()
- {
- return $this->hasOne(User::className(), ['id' => 'id_user']);
- }
-
- public function getProductOrder()
- {
- return $this->hasMany(ProductOrder::className(), ['id_order' => 'id'])
- ->orderBy(['product.order' => SORT_ASC])
- ->joinWith('product');
- }
-
- public function getDistribution()
- {
- return $this->hasOne(Distribution::className(), ['id' => 'id_distribution'])
- ->with('producer');
- }
-
- public function getPointSale()
- {
- return $this->hasOne(PointSale::className(), ['id' => 'id_point_sale'])
- ->with('userPointSale');
- }
-
- public function getCreditHistory()
- {
- return $this->hasMany(CreditHistory::className(), ['id_order' => 'id']);
- }
-
- public function getSubscription()
- {
- return $this->hasOne(Subscription::className(), ['id' => 'id_subscription'])
- ->with('productSubscription');
- }
-
- public function getInvoice()
- {
- return $this->hasOne(Invoice::className(), ['id' => 'id_invoice']);
- }
-
- public function getQuotation()
- {
- return $this->hasOne(Quotation::className(), ['id' => 'id_quotation']);
- }
-
- public function getDeliveryNote()
- {
- return $this->hasOne(DeliveryNote::className(), ['id' => 'id_delivery_note']);
- }
-
-
-
- public static function defaultOptionsSearch()
- {
- return [
- 'with' => ['productOrder', 'productOrder.product', 'creditHistory', 'creditHistory.userAction', 'pointSale'],
- 'join_with' => ['distribution', 'user', 'user.userProducer'],
- 'orderby' => 'order.date ASC',
- 'attribute_id_producer' => 'distribution.id_producer'
- ];
- }
-
-
-
- public function init()
- {
- $this->initAmount();
- $this->initPaidAmount();
-
- return $this;
- }
-
-
-
- public function initAmount()
- {
- $this->amount = 0;
- $this->amount_with_tax = 0;
- $this->invoice_amount = 0;
- $this->invoice_amount_with_tax = 0;
- $this->weight = 0;
-
- if (isset($this->productOrder)) {
- foreach ($this->productOrder as $productOrder) {
-
- $this->amount += $productOrder->price * $productOrder->quantity;
- $this->amount_with_tax += Price::getPriceWithTax($productOrder->price, $productOrder->taxRate->value) * $productOrder->quantity;
-
- $invoicePrice = $productOrder->invoice_price ? $productOrder->invoice_price : $productOrder->price ;
- $this->invoice_amount += $invoicePrice * $productOrder->quantity;
- $this->invoice_amount_with_tax += Price::getPriceWithTax($invoicePrice, $productOrder->taxRate->value) * $productOrder->quantity;
-
- if ($productOrder->unit == 'piece') {
- if (isset($productOrder->product)) {
- $this->weight += ($productOrder->quantity * $productOrder->product->weight) / 1000;
- }
- } else {
- $this->weight += $productOrder->quantity;
- }
- }
- }
- }
-
-
-
- public function initPaidAmount()
- {
- if (isset($this->creditHistory)) {
- $history = $this->creditHistory;
- } else {
- $history = CreditHistory::find()
- ->where(['id_order' => $this->id])
- ->all();
- }
-
- $this->paid_amount = 0;
-
- if (count($history)) {
- foreach ($history as $ch) {
- if ($ch->type == CreditHistory::TYPE_PAYMENT) {
- $this->paid_amount += $ch->amount;
- } elseif ($ch->type == CreditHistory::TYPE_REFUND) {
- $this->paid_amount -= $ch->amount;
- }
- }
- }
- }
-
- public function delete()
- {
-
-
- $amountPaid = $this->getAmount(Order::AMOUNT_PAID);
- if ($amountPaid > 0.01) {
- $this->saveCreditHistory(
- CreditHistory::TYPE_REFUND,
- $amountPaid,
- GlobalParam::getCurrentProducerId(),
- $this->id_user,
- User::getCurrentId()
- );
- }
-
-
- if (Producer::getConfig('option_behavior_cancel_order') == Producer::BEHAVIOR_DELETE_ORDER_DELETE ||
- (Producer::getConfig('option_behavior_cancel_order') == Producer::BEHAVIOR_DELETE_ORDER_STATUS && strlen($this->date_delete))) {
- ProductOrder::deleteAll(['id_order' => $this->id]);
- return parent::delete();
- }
- elseif (Producer::getConfig('option_behavior_cancel_order') == Producer::BEHAVIOR_DELETE_ORDER_STATUS) {
- $this->date_delete = date('Y-m-d H:i:s');
- return $this->save();
- }
- }
-
-
-
-
- public function changeOrderStatus($newStatus, $origin)
- {
- $orderStatusArray = GlobalParam::get('orderStatus');
- switch ($newStatus) {
- case 'new-order' :
- $this->addOrderStatusHistory($newStatus, $origin);
- $this->status = $newStatus;
- $this->save();
- break;
- case 'waiting-paiement-on-delivery':
- if(in_array($newStatus, $orderStatusArray[$this->status]['nextStatusAllow'])){
-
- $this->addOrderStatusHistory($newStatus, $origin);
- $this->status = $newStatus;
- $this->save();
- }
- break;
- case 'waiting-paiement-by-credit':
- if(in_array($newStatus, $orderStatusArray[$this->status]['nextStatusAllow'])){
-
- $this->addOrderStatusHistory($newStatus, $origin);
- $this->status = $newStatus;
- $this->save();
- }
- break;
- case 'paid-by-credit':
- if(in_array($newStatus, $orderStatusArray[$this->status]['nextStatusAllow'])){
-
- $this->addOrderStatusHistory($newStatus, $origin);
- $this->status = $newStatus;
- $this->save();
- }
- break;
- case 'waiting-delevery' :
- if(in_array($newStatus, $orderStatusArray[$this->status]['nextStatusAllow'])){
-
- $this->addOrderStatusHistory($newStatus, $origin);
- $this->status = $newStatus;
- $this->save();
- }
- break;
- case 'delivered':
- if(in_array($newStatus, $orderStatusArray[$this->status]['nextStatusAllow'])){
-
- $this->addOrderStatusHistory($newStatus, $origin);
- $this->status = $newStatus;
- $this->save();
- }
- break;
- case 'refunded':
- if(in_array($newStatus, $orderStatusArray[$this->status]['nextStatusAllow'])){
-
- $this->addOrderStatusHistory($newStatus, $origin);
- $this->status = $newStatus;
- $this->save();
- }
- break;
- case 'cancel':
- if(in_array($newStatus, $orderStatusArray[$this->status]['nextStatusAllow'])){
-
- $this->addOrderStatusHistory($newStatus, $origin);
- $this->status = $newStatus;
- $this->save();
- }
- break;
- default:
- throw new NotFoundHttpException('Statut de commande inconnu.');
- break;
- }
- }
-
- public function addOrderStatusHistory($newStatus,$origin)
- {
-
- $orderStatusHistory = new OrderStatusHistory();
- $orderStatusHistory->id_user = User::getCurrentId();
- $orderStatusHistory->id_order = $this->id;
- $orderStatusHistory->status = $newStatus;
- $orderStatusHistory->origin = $origin;
- $orderStatusHistory->date = date('Y-m-d H:i:s');
- $orderStatusHistory->save();
- }
-
-
-
-
- public function getAmount($type = self::AMOUNT_TOTAL, $format = false)
- {
- $amount = $this->amount ;
- if($type == self::INVOICE_AMOUNT_TOTAL) {
- $amount = $this->invoice_amount ;
- }
-
- return $this->_getAmountGeneric($type, $amount, $format) ;
- }
-
- public function getAmountWithTax($type = self::AMOUNT_TOTAL, $format = false)
- {
- $amount = $this->amount_with_tax ;
- if($type == self::INVOICE_AMOUNT_TOTAL) {
- $amount = $this->invoice_amount_with_tax ;
- }
-
- return $this->_getAmountGeneric($type, $amount, $format) ;
- }
-
- protected function _getAmountGeneric($type, $amountOrder, $format)
- {
- switch ($type) {
- case self::AMOUNT_TOTAL :
- case self::INVOICE_AMOUNT_TOTAL :
- $amount = $amountOrder;
- break;
- case self::AMOUNT_PAID :
- $this->initPaidAmount();
- $amount = $this->paid_amount;
- break;
- case self::AMOUNT_REMAINING :
- $amount = $this->getAmountWithTax(self::AMOUNT_TOTAL)
- - $this->getAmountWithTax(self::AMOUNT_PAID);
- break;
- case self::AMOUNT_SURPLUS :
- $amount = $this->getAmountWithTax(self::AMOUNT_PAID)
- - $this->getAmountWithTax(self::AMOUNT_TOTAL);
- break;
- default:
- throw new NotFoundHttpException('Type de montant inconnu.') ;
- }
-
- if ($format) {
- return Price::format($amount) ;
- } else {
- return $amount;
- }
- }
-
-
-
- public function getDataJson()
- {
- $order = Order::searchOne(['order.id' => $this->id]);
-
- $jsonOrder = [];
- if ($order) {
- $jsonOrder = [
- 'products' => [],
- 'amount' => $order->amount,
- 'str_amount' => $order->getAmountWithTax(self::AMOUNT_TOTAL, true),
- 'paid_amount' => $order->getAmount(self::AMOUNT_PAID),
- 'comment' => $order->comment,
- ];
-
- foreach ($order->productOrder as $productOrder) {
- $jsonOrder['products'][$productOrder->id_product] = $productOrder->quantity;
- }
- }
-
- return json_encode($jsonOrder);
- }
-
-
-
- public function saveCreditHistory($type, $amount, $idProducer, $idUser, $idUserAction)
- {
- $creditHistory = new CreditHistory;
- $creditHistory->id_user = $this->id_user;
- $creditHistory->id_order = $this->id;
- $creditHistory->amount = $amount;
- $creditHistory->type = $type;
- $creditHistory->id_producer = $idProducer;
- $creditHistory->id_user_action = $idUserAction;
- $creditHistory->populateRelation('order', $this);
- $creditHistory->populateRelation('user', User::find()->where(['id' => $this->id_user])->one());
- $creditHistory->save();
- }
-
-
-
- public function processCredit()
- {
- if ($this->id_user) {
- $paymentStatus = $this->getPaymentStatus();
-
- if ($paymentStatus == self::PAYMENT_PAID) {
- return true;
- } elseif ($paymentStatus == self::PAYMENT_SURPLUS) {
- $type = CreditHistory::TYPE_REFUND;
- $amount = $this->getAmount(self::AMOUNT_SURPLUS);
- } elseif ($paymentStatus == self::PAYMENT_UNPAID) {
- $type = CreditHistory::TYPE_PAYMENT;
- $amount = $this->getAmount(self::AMOUNT_REMAINING);
- }
-
- $this->saveCreditHistory(
- $type,
- $amount,
- GlobalParam::getCurrentProducerId(),
- $this->id_user,
- User::getCurrentId()
- );
- }
- }
-
- public function setTillerSynchronization()
- {
- $order = Order::searchOne(['id' => $this->id]);
-
- $paymentStatus = $order->getPaymentStatus();
-
- if ($paymentStatus == self::PAYMENT_PAID) {
- $order->tiller_synchronization = 1 ;
- }
- else {
- $order->tiller_synchronization = 0 ;
- }
-
- $order->save() ;
-
- return $order ;
- }
-
-
-
- public function getPaymentStatus()
- {
-
- if ($this->getAmountWithtax() - $this->getAmount(self::AMOUNT_PAID) < 0.01 &&
- $this->getAmountWithtax() - $this->getAmount(self::AMOUNT_PAID) > -0.01) {
- return self::PAYMENT_PAID;
- }
- elseif ($this->getAmountWithtax() - $this->getAmount(self::AMOUNT_PAID) <= -0.01) {
- return self::PAYMENT_SURPLUS;
- }
- elseif ($this->getAmountWithtax() - $this->getAmount(self::AMOUNT_PAID) >= 0.01) {
- return self::PAYMENT_UNPAID;
- }
- }
-
-
-
- public function getCartSummary()
- {
- if (!isset($this->productOrder)) {
- $this->productOrder = productOrder::find()->where(['id_order' => $this->id])->all();
- }
-
- $html = '';
- $count = count($this->productOrder);
- $i = 0;
- foreach ($this->productOrder as $p) {
- if (isset($p->product)) {
- $html .= Html::encode($p->product->name) . ' (' . $p->quantity . ' ' . Product::strUnit($p->unit, 'wording_short', true) . ')';
- if (++$i != $count) {
- $html .= '<br />';
- }
- }
- }
-
- return $html;
- }
-
-
-
- public function getPointSaleSummary()
- {
- $html = '';
-
- if (isset($this->pointSale)) {
- $html .= '<span class="name-point-sale">' .
- Html::encode($this->pointSale->name) .
- '</span>' .
- '<br /><span class="locality">'
- . Html::encode($this->pointSale->locality)
- . '</span>';
-
- if (strlen($this->comment_point_sale)) {
- $html .= '<div class="comment"><span>'
- . Html::encode($this->comment_point_sale)
- . '</span></div>';
- }
- } else {
- $html .= 'Point de vente supprimé';
- }
-
- return $html;
- }
-
-
-
- public function getAmountSummary()
- {
- $html = '';
-
- $creditActive = Producer::getConfig('credit') ;
- $html .= $this->getAmountWithTax(self::AMOUNT_TOTAL, true) ;
-
- if($creditActive) {
- $html .= '<br />' ;
- if ($this->paid_amount) {
- if ($this->getPaymentStatus() == Order::PAYMENT_PAID) {
- $html .= '<span class="label label-success">Payée</span>';
- }
- elseif ($this->getPaymentStatus() == Order::PAYMENT_UNPAID) {
- $html .= '<span class="label label-danger">Non payée</span><br />
- Reste <strong>' . $this->getAmount(Order::AMOUNT_REMAINING, true) . '</strong> à payer';
- }
- elseif ($this->getPaymentStatus() == Order::PAYMENT_SURPLUS) {
- $html .= '<span class="label label-success">Payée</span>';
- }
- }
- else {
- $html .= '<span class="label label-default">Non réglé</span>';
- }
- }
-
-
- return $html;
- }
-
-
-
- public function getStrUser()
- {
- if (isset($this->user)) {
- if(isset($this->user->name_legal_person) && strlen($this->user->name_legal_person)) {
- return Html::encode($this->user->name_legal_person);
- }
- else {
- return Html::encode($this->user->lastname . ' ' . $this->user->name);
- }
- }
- elseif (strlen($this->username)) {
- return Html::encode($this->username);
- }
- else {
- return 'Client introuvable';
- }
- }
-
-
-
- public function getState()
- {
- $orderDate = strtotime($this->distribution->date);
- $today = strtotime(date('Y-m-d'));
- $todayHour = date('G');
- $dayDistribution = strtolower(date('l', strtotime($this->distribution->date))) ;
-
- $orderDelay = Producer::getConfig(
- 'order_delay',
- $this->distribution->id_producer
- );
- $orderDelaySpecific = Producer::getConfig(
- 'order_delay_'.$dayDistribution,
- $this->distribution->id_producer
- );
- if($orderDelaySpecific) {
- $orderDelay = $orderDelaySpecific ;
- }
-
- $orderDeadline = Producer::getConfig(
- 'order_deadline',
- $this->distribution->id_producer
- );
- $orderDeadlineSpecific = Producer::getConfig(
- 'order_deadline_'.$dayDistribution,
- $this->distribution->id_producer
- );
- if($orderDeadlineSpecific) {
- $orderDeadline = $orderDeadlineSpecific ;
- }
-
- $nbDays = (int) round((($orderDate - $today) / (24 * 60 * 60)));
-
- if ($nbDays <= 0) {
- return self::STATE_DELIVERED;
- } elseif ($nbDays >= $orderDelay &&
- ($nbDays != $orderDelay ||
- ($nbDays == $orderDelay && $todayHour < $orderDeadline))) {
- return self::STATE_OPEN;
- }
-
- return self::STATE_PREPARATION;
- }
-
-
-
- public function getStrOrigin($withLabel = false)
- {
- $classLabel = '';
- $str = '';
-
- if ($this->origin == self::ORIGIN_USER) {
- $classLabel = 'success';
- $str = 'Client';
- } elseif ($this->origin == self::ORIGIN_AUTO) {
- $classLabel = 'default';
- $str = 'Auto';
- } elseif ($this->origin == self::ORIGIN_ADMIN) {
- $classLabel = 'warning';
- $str = 'Vous';
- }
-
- if ($withLabel) {
- return '<span class="label label-' . $classLabel . '">'
- . $str . '</span>';
- } else {
- return $str;
- }
- }
-
-
-
- public function getStrHistory()
- {
- $arr = [
- 'class' => 'create',
- 'glyphicon' => 'plus',
- 'str' => 'Ajoutée',
- 'date' => $this->date
- ];
-
- if (!is_null($this->date_update)) {
- $arr = [
- 'class' => 'update',
- 'glyphicon' => 'pencil',
- 'str' => 'Modifiée',
- 'date' => $this->date_update
- ];
- }
- if (!is_null($this->date_delete)) {
- $arr = [
- 'class' => 'delete',
- 'glyphicon' => 'remove',
- 'str' => 'Annulée',
- 'date' => $this->date_delete
- ];
- }
-
- $html = '<div class="small"><span class="' . $arr['class'] . '">'
- . '<span class="glyphicon glyphicon-' . $arr['glyphicon'] . '"></span> '
- . $arr['str'] . '</span> le <strong>'
- . date('d/m/Y à G\hi', strtotime($arr['date'])) . '</strong></div>';
-
- return $html;
- }
-
-
-
- public function getClassHistory()
- {
- if (!is_null($this->date_delete)) {
- return 'commande-delete';
- }
- if (!is_null($this->date_update)) {
- return 'commande-update';
- }
- return 'commande-create';
- }
-
-
-
- public static function getProductQuantity($idProduct, $orders, $ignoreCancel = false, $unit = null)
- {
- $quantity = 0;
-
- if (isset($orders) && is_array($orders) && count($orders)) {
- foreach ($orders as $c) {
- if (is_null($c->date_delete) || $ignoreCancel) {
- foreach ($c->productOrder as $po) {
- if ($po->id_product == $idProduct &&
- ((is_null($unit) && $po->product->unit == $po->unit) || (!is_null($unit) && strlen($unit) && $po->unit == $unit))) {
- $quantity += $po->quantity;
- }
- }
- }
- }
- }
-
- return $quantity;
- }
-
- public static function getProductQuantityPieces($idProduct, $orders)
- {
- $quantity = 0;
-
- if (isset($orders) && is_array($orders) && count($orders)) {
- foreach ($orders as $c) {
- if (is_null($c->date_delete)) {
- foreach ($c->productOrder as $po) {
- if ($po->id_product == $idProduct) {
- if($po->unit == 'piece') {
- $quantity += $po->quantity ;
- }
- else {
- if(isset($po->product) && $po->product->weight > 0) {
- $quantity += ($po->quantity * Product::$unitsArray[$po->unit]['coefficient']) / $po->product->weight ;
- }
- }
- }
- }
- }
- }
- }
-
- return $quantity;
- }
-
-
-
- public static function searchBy($params = [], $options = [])
- {
- $orders = parent::searchBy($params, $options);
-
-
-
-
- if (is_array($orders)) {
- if (count($orders)) {
- foreach ($orders as $order) {
- if (is_a($order, 'common\models\Order')) {
- $order->init();
- }
- }
- return $orders;
- }
- } else {
- $order = $orders;
- if (is_a($order, 'common\models\Order')) {
- return $order->init();
- }
- else {
- return $order;
- }
- }
-
- return false;
- }
-
-
-
- public function countProducts()
- {
- $count = 0;
- if ($this->productOrder && is_array($this->productOrder)) {
- foreach ($this->productOrder as $productOrder) {
- if ($productOrder->unit == 'piece') {
- $count++;
- } else {
- $count += $productOrder->quantity;
- }
- }
- }
- return $count;
- }
-
-
-
- public function getBlockDate()
- {
- return '<div class="block-date">
- <div class="day">' . strftime('%A', strtotime($this->distribution->date)) . '</div>
- <div class="num">' . date('d', strtotime($this->distribution->date)) . '</div>
- <div class="month">' . strftime('%B', strtotime($this->distribution->date)) . '</div>
- </div>';
- }
-
- public function getUsername()
- {
- $username = '' ;
- if($this->user) {
- $username = $this->user->getUsername() ;
- }
- if(strlen($this->username)) {
- $username = $this->username ;
- }
- return $username ;
- }
-
- }
|