Blame view

models/Order.php 15.8 KB
8a7e6ecf   Yarik   Namespaces
1
2
3
  <?php
      namespace artweb\artbox\ecommerce\models;
      
17569d93   Alexey Boroda   -Order product lo...
4
      use artweb\artbox\ecommerce\components\OrderLogger;
8a7e6ecf   Yarik   Namespaces
5
      use artweb\artbox\models\Customer;
3bb55546   Alexey Boroda   -Fixing bugs
6
      use common\behaviors\DefaultLabelBehavior;
01185786   Alexey Boroda   -Sms in process
7
      use common\models\User;
8a7e6ecf   Yarik   Namespaces
8
      use Yii;
2b29877e   Alexey Boroda   -Added time colum...
9
      use yii\behaviors\TimestampBehavior;
8a7e6ecf   Yarik   Namespaces
10
      use yii\db\ActiveRecord;
ee0e1df5   Alexey Boroda   -Statistics half ...
11
      use yii\db\Query;
8a7e6ecf   Yarik   Namespaces
12
13
14
15
16
17
      
      /**
       * Class Order
       *
       * @todo    Write docs and refactor
       * @package artweb\artbox\ecommerce\models
eb190b1f   Alexey Boroda   -Order form add p...
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
       * @property OrderProduct[] $products
       * @property integer        $created_at
       * @property integer        $updated_at
       * @property integer        $deleted_at
       * @property integer        $deadline
       * @property boolean        $wasted
       * @property string         $delivery_cost
       * @property integer        $reason
       * @property string         $check
       * @property string         $sms
       * @property int            $id
       * @property integer        $edit_id
       * @property integer        $edit_time
       * @property integer        $manager_id
       * @property int            $user_id
       * @property string         $name
       * @property string         $phone
       * @property string         $phone2
       * @property string         $email
       * @property string         $adress
       * @property string         $body
       * @property double         $total
       * @property string         $date_time
       * @property string         $date_dedline
       * @property string         $reserve
       * @property string         $status
       * @property string         $comment
       * @property int            $label
       * @property int            $pay
       * @property int            $numbercard
       * @property int            $delivery
       * @property string         $declaration
       * @property string         $stock
       * @property string         $consignment
       * @property string         $payment
       * @property string         $insurance
       * @property double         $amount_imposed
       * @property string         $shipping_by
       * @property string         $city
       * @property string         $deliveryString
       * @property boolean        $published
3bee3445   Alexey Boroda   -Order history ready
59
60
61
       * @property Label          $orderLabel
       * @property Delivery       $orderDelivery
       * @property OrderPayment   $orderPayment
d3406983   Alexey Boroda   -Order history ha...
62
       * @property OrderLog[]     $logs
93a0cd0b   Yarik   Credits
63
64
       * @property float          $credit_sum
       * @property int            $credit_month
2f4b4e77   Alexey Boroda   -Statistics expor...
65
       * @property User           $manager
8a7e6ecf   Yarik   Namespaces
66
67
68
       */
      class Order extends ActiveRecord
      {
bb962a6d   Alexey Boroda   -Order in process
69
70
71
72
73
74
75
76
77
          
          const SHIPPING_BY = [
              1 => [
                  'label' => 'Отправитель',
              ],
              2 => [
                  'label' => 'Получатель',
              ],
          ];
8a7e6ecf   Yarik   Namespaces
78
          
db3040d3   Alexey Boroda   -Order module alm...
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
          const REASONS = [
              1  => 'Нет товара',
              2  => 'Нет оплаты',
              3  => 'Передумал',
              4  => ' - Купил в другом месте',
              5  => ' - Не подошли условия доставки',
              6  => ' - Не подошел срок доставки',
              7  => ' - Нет денег',
              8  => ' - Купит позже',
              9  => 'Купил в другом месте',
              10 => 'Подьедет в маг.',
              11 => 'Дубль заказа.',
              12 => 'Другое',
              13 => 'Брак',
              14 => 'Отказался от Самовывоза',
              15 => 'Не приехал за Самовывозом',
              16 => 'Отменил заказ',
              17 => 'Не берет трубку',
          ];
          
8a7e6ecf   Yarik   Namespaces
99
100
101
102
          public static function tableName()
          {
              return 'order';
          }
3bee3445   Alexey Boroda   -Order history ready
103
          
ee0e1df5   Alexey Boroda   -Statistics half ...
104
          /**
29257441   Alexey Boroda   -Manager filter o...
105
106
           * @param array $date
           * @param array $manager
ee0e1df5   Alexey Boroda   -Statistics half ...
107
108
109
           *
           * @return array
           */
29257441   Alexey Boroda   -Manager filter o...
110
          public static function getRejectionStatistics(array $date = [], array $manager = [])
ee0e1df5   Alexey Boroda   -Statistics half ...
111
112
113
114
115
116
117
118
119
120
121
122
123
124
          {
              $result = [];
              foreach (self::REASONS as $id => $reason) {
                  $result[ $reason ] = ( new Query() )->select(
                      [
                          'sum'   => 'SUM(total)',
                          'count' => 'COUNT(*)',
                      ]
                  )
                                                      ->from(self::tableName())
                                                      ->where(
                                                          [
                                                              'reason' => $id,
                                                          ]
3bee3445   Alexey Boroda   -Order history ready
125
                                                      )
29257441   Alexey Boroda   -Manager filter o...
126
127
                                                      ->andFilterWhere($date)
                                                      ->andFilterWhere($manager)
3bee3445   Alexey Boroda   -Order history ready
128
                                                      ->one();
ee0e1df5   Alexey Boroda   -Statistics half ...
129
130
131
132
              }
              
              return $result;
          }
8a7e6ecf   Yarik   Namespaces
133
          
ff71eeed   Alexey Boroda   -Logs ready
134
          /**
3bee3445   Alexey Boroda   -Order history ready
135
136
           * @inheritdoc
           */
2b29877e   Alexey Boroda   -Added time colum...
137
138
139
140
141
142
          public function behaviors()
          {
              return [
                  [
                      'class' => TimestampBehavior::className(),
                  ],
3bb55546   Alexey Boroda   -Fixing bugs
143
144
145
                  [
                      'class' => DefaultLabelBehavior::className(),
                  ],
2b29877e   Alexey Boroda   -Added time colum...
146
147
148
              ];
          }
          
3bee3445   Alexey Boroda   -Order history ready
149
150
151
          /**
           * @inheritdoc
           */
8a7e6ecf   Yarik   Namespaces
152
153
154
155
          public function rules()
          {
              return [
                  [
eb190b1f   Alexey Boroda   -Order form add p...
156
157
158
159
                      [
                          'pay',
                          'published',
                      ],
bb962a6d   Alexey Boroda   -Order in process
160
161
162
                      'boolean',
                  ],
                  [
8a7e6ecf   Yarik   Namespaces
163
                      [
e861ae92   Alexey Boroda   -Add column to pa...
164
                          'shipping_by',
2b29877e   Alexey Boroda   -Added time colum...
165
166
167
                          'created_at',
                          'updated_at',
                          'deleted_at',
ccfc5763   Alexey Boroda   -Order in process 3
168
169
170
                          'payment',
                          'reason',
                          'label',
01185786   Alexey Boroda   -Sms in process
171
                          'manager_id',
d57c8c00   Alexey Boroda   -Blocking in process
172
173
                          'edit_time',
                          'edit_id',
622a985a   Alexey Boroda   -Feed in process
174
                          'delivery',
2b29877e   Alexey Boroda   -Added time colum...
175
176
177
178
                      ],
                      'integer',
                  ],
                  [
01185786   Alexey Boroda   -Sms in process
179
180
181
182
                      [ 'total' ],
                      'double',
                  ],
                  [
2b29877e   Alexey Boroda   -Added time colum...
183
                      [
8a7e6ecf   Yarik   Namespaces
184
185
186
187
188
                          'phone',
                      ],
                      'required',
                  ],
                  [
6035d2b4   Yarik   Order body length
189
190
191
192
                      [
                          'comment',
                          'body',
                      ],
bb962a6d   Alexey Boroda   -Order in process
193
                      'string',
8a7e6ecf   Yarik   Namespaces
194
195
196
197
198
199
                  ],
                  [
                      [ 'email' ],
                      'email',
                  ],
                  [
bb962a6d   Alexey Boroda   -Order in process
200
201
202
203
                      [
                          'phone',
                          'phone2',
                      ],
8a7e6ecf   Yarik   Namespaces
204
205
                      'match',
                      'pattern' => '/^\+38\(\d{3}\)\d{3}-\d{2}-\d{2}$/',
8a7e6ecf   Yarik   Namespaces
206
207
208
                  ],
                  [
                      [
93a0cd0b   Yarik   Credits
209
210
211
212
213
214
215
216
217
218
219
                          'credit_month',
                      ],
                      'integer',
                      'min' => 3,
                      'max' => 36,
                  ],
                  [
                      [
                          'credit_sum',
                      ],
                      'number',
03c7b7bc   Yarik   Credit v2
220
                      'min' => 0,
93a0cd0b   Yarik   Credits
221
222
223
                  ],
                  [
                      [
ccfc5763   Alexey Boroda   -Order in process 3
224
                          'deadline',
8a7e6ecf   Yarik   Namespaces
225
                          'name',
8a7e6ecf   Yarik   Namespaces
226
                          'numbercard',
8a7e6ecf   Yarik   Namespaces
227
228
229
                          'declaration',
                          'stock',
                          'consignment',
8a7e6ecf   Yarik   Namespaces
230
231
                          'insurance',
                          'amount_imposed',
8a7e6ecf   Yarik   Namespaces
232
233
                          'city',
                          'adress',
8a7e6ecf   Yarik   Namespaces
234
                          'status',
ccfc5763   Alexey Boroda   -Order in process 3
235
236
                          'check',
                          'sms',
28b51b30   Alexey Boroda   -Order module bug...
237
                          'delivery_cost',
8a7e6ecf   Yarik   Namespaces
238
239
240
241
                      ],
                      'string',
                      'max' => 255,
                  ],
8a7e6ecf   Yarik   Namespaces
242
243
244
              ];
          }
          
3bee3445   Alexey Boroda   -Order history ready
245
246
          public function afterSave($insert, $changedAttributes)
          {
17569d93   Alexey Boroda   -Order product lo...
247
248
              $data = OrderLogger::generateData($changedAttributes, $this->oldAttributes, $insert);
              OrderLogger::saveData($data, $this->id);
d3406983   Alexey Boroda   -Order history ha...
249
              
17569d93   Alexey Boroda   -Order product lo...
250
              OrderLogger::saveOrderLabelHistory($changedAttributes, $this->label, $this->id);
d3406983   Alexey Boroda   -Order history ha...
251
              
3bee3445   Alexey Boroda   -Order history ready
252
253
254
255
256
257
              parent::afterSave($insert, $changedAttributes);
          }
          
          /**
           * @inheritdoc
           */
ccfc5763   Alexey Boroda   -Order in process 3
258
259
260
          public function afterFind()
          {
              parent::afterFind();
ee0e1df5   Alexey Boroda   -Statistics half ...
261
              $this->deadline = !empty($this->deadline) ? date('d.m.Y', $this->deadline) : '';
ccfc5763   Alexey Boroda   -Order in process 3
262
263
264
              
          }
          
3bee3445   Alexey Boroda   -Order history ready
265
266
267
          /**
           * @inheritdoc
           */
ccfc5763   Alexey Boroda   -Order in process 3
268
269
270
271
272
273
274
275
276
277
278
          public function beforeSave($insert)
          {
              if (parent::beforeSave($insert)) {
                  
                  $this->convertDate();
                  return true;
              }
              return false;
              
          }
          
3bee3445   Alexey Boroda   -Order history ready
279
280
281
          /**
           * Convert some date
           */
ccfc5763   Alexey Boroda   -Order in process 3
282
283
          protected function convertDate()
          {
ee0e1df5   Alexey Boroda   -Statistics half ...
284
              if (!empty($this->deadline)) {
db0c93ce   Alexey Boroda   -Timestamp problem
285
                  $date = new \DateTime();
48fb8190   Alexey Boroda   -Timestamp proble...
286
                  $date->setTimestamp(strtotime($this->deadline));
ccfc5763   Alexey Boroda   -Order in process 3
287
288
289
290
291
292
293
                  $date->format("d.m.Y");
                  $this->deadline = $date->getTimestamp();
                  
              }
              
          }
          
3bee3445   Alexey Boroda   -Order history ready
294
295
296
          /**
           * @inheritdoc
           */
8a7e6ecf   Yarik   Namespaces
297
298
299
          public function attributeLabels()
          {
              return [
43127bab   Alexey Boroda   -Order translatio...
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
                  'name'           => Yii::t('app', 'order_name'),
                  'phone'          => Yii::t('app', 'order_phone'),
                  'phone2'         => Yii::t('app', 'Конактный телефон 2'),
                  'email'          => Yii::t('app', 'E-mail'),
                  'comment'        => Yii::t('app', 'Комментарий '),
                  'created_at'     => Yii::t('app', 'Дата добавления'),
                  'updated_at'     => Yii::t('app', 'Дата обновления'),
                  'deleted_at'     => Yii::t('app', 'Дата удаления'),
                  'deadline'       => Yii::t('app', 'Дедлайн'),
                  'reason'         => Yii::t('app', 'Причина'),
                  'check'          => Yii::t('app', 'Чек'),
                  'sms'            => Yii::t('app', 'СМС'),
                  'consignment'    => Yii::t('app', 'Номер накладной'),
                  'manager_id'     => Yii::t('app', 'Менеджер'),
                  'delivery_cost'  => Yii::t('app', 'Стоимость доставки'),
                  'published'      => Yii::t('app', 'Опубликован'),
                  'label'          => Yii::t('app', 'Метка'),
                  'declaration'    => Yii::t('app', 'Номер декларации'),
                  'delivery'       => Yii::t('app', 'Способ доставки'),
                  'total'          => Yii::t('app', 'Сумма'),
                  'adress'         => Yii::t('app', 'Адрес'),
                  'pay'            => Yii::t('app', 'Оплата'),
                  'body'           => Yii::t('app', 'Комментарий менеджера'),
                  'id'             => Yii::t('app', 'Номер'),
                  'stock'          => Yii::t('app', 'Номер склада'),
                  'payment'        => Yii::t('app', 'Способ оплаты'),
                  'insurance'      => Yii::t('app', 'Страховка'),
                  'amount_imposed' => Yii::t('app', 'Сумма наложенного'),
                  'shipping_by'    => Yii::t('app', 'Отправка за счет'),
                  'city'           => Yii::t('app', 'Город'),
                  'numbercard'     => Yii::t('app', '№ карточки'),
93a0cd0b   Yarik   Credits
331
                  'credit_month'   => Yii::t('app', 'Количество месяцев'),
03c7b7bc   Yarik   Credit v2
332
                  'credit_sum'     => Yii::t('app', 'Первоначальный взнос'),
8a7e6ecf   Yarik   Namespaces
333
334
335
              ];
          }
          
3bee3445   Alexey Boroda   -Order history ready
336
337
338
          /**
           * @return \yii\db\ActiveQuery
           */
8a7e6ecf   Yarik   Namespaces
339
340
341
342
          public function getUser()
          {
              return $this->hasOne(Customer::className(), [ 'id' => 'user_id' ]);
          }
ccfc5763   Alexey Boroda   -Order in process 3
343
          
25b21043   Administrator   add create_item t...
344
345
346
          /**
           * @return \yii\db\ActiveQuery
           */
8a7e6ecf   Yarik   Namespaces
347
348
349
350
          public function getProducts()
          {
              return $this->hasMany(OrderProduct::className(), [ 'order_id' => 'id' ]);
          }
ccfc5763   Alexey Boroda   -Order in process 3
351
          
25b21043   Administrator   add create_item t...
352
353
354
          /**
           * @return \yii\db\ActiveQuery
           */
ccfc5763   Alexey Boroda   -Order in process 3
355
356
357
          public function getOrderDelivery()
          {
              return $this->hasOne(Delivery::className(), [ 'id' => 'delivery' ]);
25b21043   Administrator   add create_item t...
358
          }
ccfc5763   Alexey Boroda   -Order in process 3
359
          
25b21043   Administrator   add create_item t...
360
361
362
          /**
           * @return \yii\db\ActiveQuery
           */
ccfc5763   Alexey Boroda   -Order in process 3
363
364
          public function getOrderLabel()
          {
ce75bc1d   Alexey Boroda   -Grid view half w...
365
              return $this->hasOne(Label::className(), [ 'id' => 'label' ]);
25b21043   Administrator   add create_item t...
366
          }
ccfc5763   Alexey Boroda   -Order in process 3
367
          
25b21043   Administrator   add create_item t...
368
369
370
          /**
           * @return \yii\db\ActiveQuery
           */
ccfc5763   Alexey Boroda   -Order in process 3
371
372
373
          public function getOrderPayment()
          {
              return $this->hasOne(OrderPayment::className(), [ 'id' => 'payment' ]);
25b21043   Administrator   add create_item t...
374
          }
ccfc5763   Alexey Boroda   -Order in process 3
375
          
25b21043   Administrator   add create_item t...
376
          /**
3bee3445   Alexey Boroda   -Order history ready
377
378
379
380
381
382
383
384
           * @return \yii\db\ActiveQuery
           */
          public function getLabelsHistory()
          {
              return $this->hasMany(OrderLabelHistory::className(), [ 'order_id' => 'id' ]);
          }
          
          /**
25b21043   Administrator   add create_item t...
385
386
           * @return string
           */
ccfc5763   Alexey Boroda   -Order in process 3
387
388
          public function getDeliveryString()
          {
ee0e1df5   Alexey Boroda   -Statistics half ...
389
390
              if (!empty($this->orderDelivery)) {
                  if (!empty($this->orderDelivery->parent)) {
ccfc5763   Alexey Boroda   -Order in process 3
391
                      return $this->orderDelivery->parent->lang->title . ': ' . $this->orderDelivery->lang->title;
25b21043   Administrator   add create_item t...
392
                  } else {
fbfae870   Administrator   add create_item t...
393
                      return $this->orderDelivery->lang->title;
25b21043   Administrator   add create_item t...
394
395
396
397
398
                  }
              } else {
                  return '';
              }
          }
01185786   Alexey Boroda   -Sms in process
399
          
ce75bc1d   Alexey Boroda   -Grid view half w...
400
          /**
d3406983   Alexey Boroda   -Order history ha...
401
402
403
404
405
406
           * @return \yii\db\ActiveQuery
           */
          public function getLogs()
          {
              return $this->hasMany(OrderLog::className(), [ 'order_id' => 'id' ]);
          }
17569d93   Alexey Boroda   -Order product lo...
407
408
409
410
411
412
413
414
      
          /**
           * @return \yii\db\ActiveQuery
           */
          public function getProductLogs()
          {
              return $this->hasMany(OrderProductLog::className(), [ 'order_id' => 'id' ]);
          }
d3406983   Alexey Boroda   -Order history ha...
415
416
          
          /**
ce75bc1d   Alexey Boroda   -Grid view half w...
417
418
           * If deadline is fucked up returns true,
           * if deadline is not setted return false, like everything is ok
01185786   Alexey Boroda   -Sms in process
419
           *
ce75bc1d   Alexey Boroda   -Grid view half w...
420
421
422
423
           * @return bool
           */
          public function getWasted()
          {
ee0e1df5   Alexey Boroda   -Statistics half ...
424
              if (empty($this->deadline)) {
ce75bc1d   Alexey Boroda   -Grid view half w...
425
426
                  return false;
              } else {
eb15a89c   Alexey Boroda   -Dancing with com...
427
                  return time() > strtotime($this->deadline);
ce75bc1d   Alexey Boroda   -Grid view half w...
428
429
              }
          }
01185786   Alexey Boroda   -Sms in process
430
431
          
          /**
3bee3445   Alexey Boroda   -Order history ready
432
           * @return \yii\db\ActiveQuery
01185786   Alexey Boroda   -Sms in process
433
434
435
           */
          public function getManager()
          {
b0c7d586   Alexey Boroda   -Bykov fixes
436
              return $this->hasOne(User::className(), [ 'id' => 'manager_id' ]);
01185786   Alexey Boroda   -Sms in process
437
          }
d57c8c00   Alexey Boroda   -Blocking in process
438
          
3bee3445   Alexey Boroda   -Order history ready
439
440
441
442
443
          /**
           * Check if order is blocked for updating
           *
           * @return bool
           */
d57c8c00   Alexey Boroda   -Blocking in process
444
445
          public function isBlocked()
          {
3bb55546   Alexey Boroda   -Fixing bugs
446
447
              if ($this->edit_id === 0) {
                  return false;
d57c8c00   Alexey Boroda   -Blocking in process
448
              } else {
3bb55546   Alexey Boroda   -Fixing bugs
449
                  if ($this->edit_time + 7200 > time()) {
d57c8c00   Alexey Boroda   -Blocking in process
450
                      return true;
3bb55546   Alexey Boroda   -Fixing bugs
451
                  } else {
d57c8c00   Alexey Boroda   -Blocking in process
452
453
454
455
                      return false;
                  }
              }
          }
28b51b30   Alexey Boroda   -Order module bug...
456
          
3bee3445   Alexey Boroda   -Order history ready
457
458
459
          /**
           * If order products changed recount te total value
           */
28b51b30   Alexey Boroda   -Order module bug...
460
461
462
463
464
          public function totalRecount()
          {
              $products = $this->products;
              $newTotal = 0;
              foreach ($products as $product) {
eb190b1f   Alexey Boroda   -Order form add p...
465
466
467
                  if ($product->removed) {
                      continue;
                  }
28b51b30   Alexey Boroda   -Order module bug...
468
469
470
471
472
                  $newTotal += $product->count * $product->price;
              }
              $this->total = $newTotal;
              $this->save();
          }
eb190b1f   Alexey Boroda   -Order form add p...
473
          
3bee3445   Alexey Boroda   -Order history ready
474
475
476
          /**
           * If exit unpublished order - delete it
           */
eb190b1f   Alexey Boroda   -Order form add p...
477
478
479
480
481
482
483
484
485
486
487
488
          public function deleteUnpublished()
          {
              /**
               * @var OrderProduct[] $products
               */
              $products = $this->products;
              foreach ($products as $product) {
                  $product->delete();
              }
              
              $this->delete();
          }
8a7e6ecf   Yarik   Namespaces
489
      }