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
|
}
|