2a050410
Yarik
Order
|
1
2
3
|
<?php
namespace artbox\order\controllers;
|
fcd620e2
Alexey Boroda
-Number column ad...
|
4
|
|
fd40a9e1
Yarik
Products to order
|
5
|
use artbox\catalog\models\Variant;
|
fdce5f4a
Anastasia
- order
|
6
|
use artbox\core\admin\actions\Index;
|
36744c04
Anastasia
- fast order in a...
|
7
|
use artbox\order\columns\ActionColumn;
|
fdce5f4a
Anastasia
- order
|
8
9
|
use artbox\order\labels\models\Delivery;
use artbox\order\labels\models\Label;
|
fd40a9e1
Yarik
Products to order
|
10
|
use artbox\order\models\OrderProduct;
|
fdce5f4a
Anastasia
- order
|
11
|
use artbox\order\labels\models\Payment;
|
2a050410
Yarik
Order
|
12
13
|
use Yii;
use artbox\order\models\Order;
|
2a050410
Yarik
Order
|
14
15
16
|
use yii\web\Controller;
use yii\web\NotFoundHttpException;
use yii\filters\VerbFilter;
|
faf0eca8
Anastasia
access control
|
17
|
use yii\filters\AccessControl;
|
543a6adb
Anastasia
order
|
18
19
|
use yii\web\Response;
use yii\widgets\ActiveForm;
|
fcd620e2
Alexey Boroda
-Number column ad...
|
20
|
|
2a050410
Yarik
Order
|
21
22
23
24
25
26
27
28
|
/**
* OrderController implements the CRUD actions for Order model.
*/
class OrderController extends Controller
{
/**
* @inheritdoc
*/
|
fdce5f4a
Anastasia
- order
|
29
30
31
32
|
public function getViewPath()
{
return '@artbox/order/views/order';
}
|
fcd620e2
Alexey Boroda
-Number column ad...
|
33
|
|
2a050410
Yarik
Order
|
34
35
36
|
public function behaviors()
{
return [
|
fcd620e2
Alexey Boroda
-Number column ad...
|
37
|
'verbs' => [
|
2a050410
Yarik
Order
|
38
39
40
41
42
|
'class' => VerbFilter::className(),
'actions' => [
'delete' => [ 'POST' ],
],
],
|
faf0eca8
Anastasia
access control
|
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
|
'access' => [
'class' => AccessControl::className(),
'rules' => [
[
'actions' => [
'login',
'error',
],
'allow' => true,
],
[
'allow' => true,
'roles' => [ '@' ],
],
],
],
|
2a050410
Yarik
Order
|
59
60
|
];
}
|
fcd620e2
Alexey Boroda
-Number column ad...
|
61
|
|
fdce5f4a
Anastasia
- order
|
62
|
public function actions()
|
2a050410
Yarik
Order
|
63
|
{
|
fdce5f4a
Anastasia
- order
|
64
65
66
67
|
return [
'index' => [
'class' => Index::className(),
'columns' => [
|
fcd620e2
Alexey Boroda
-Number column ad...
|
68
69
70
|
'id' => [
'type' => Index::NUMBER_COL,
],
|
fdce5f4a
Anastasia
- order
|
71
|
'name' => [
|
fcd620e2
Alexey Boroda
-Number column ad...
|
72
|
'type' => Index::ACTION_COL,
|
b983b856
Anastasia
- blog bug fix
|
73
|
'columnConfig' => [
|
36744c04
Anastasia
- fast order in a...
|
74
|
'class' => ActionColumn::class,
|
b983b856
Anastasia
- blog bug fix
|
75
|
'buttonsTemplate' => '{edit}{delete}',
|
36744c04
Anastasia
- fast order in a...
|
76
77
78
79
80
81
82
|
'columnTemplate' => function (Order $model){
if (empty($model->name)){
return "<span>(не указано)<b class='mouse-lmc'></b></span>";
}else{
return $model->name;
}
}
|
b983b856
Anastasia
- blog bug fix
|
83
|
],
|
fdce5f4a
Anastasia
- order
|
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
|
],
'phone' => [
'type' => Index::STRING_COL,
],
'email' => [
'type' => Index::STRING_COL,
],
'label' => [
'type' => Index::RELATION_COL,
'columnConfig' => [
'relationField' => 'title',
],
],
'created_at' => [
'type' => Index::DATETIME_COL,
],
|
fdce5f4a
Anastasia
- order
|
100
101
102
103
104
|
],
'model' => Order::className(),
'hasLanguage' => false,
'enableMassDelete' => false,
'modelPrimaryKey' => 'id',
|
f884421b
Anastasia
- default sort
|
105
106
107
|
'defaultSort' => [
'created_at' => 'DESC'
]
|
fdce5f4a
Anastasia
- order
|
108
109
|
],
];
|
2a050410
Yarik
Order
|
110
|
}
|
fcd620e2
Alexey Boroda
-Number column ad...
|
111
|
|
fcd620e2
Alexey Boroda
-Number column ad...
|
112
|
|
2a050410
Yarik
Order
|
113
114
115
116
117
118
119
120
121
|
/**
* Creates a new Order model.
* If creation is successful, the browser will be redirected to the 'view' page.
*
* @return mixed
*/
public function actionCreate()
{
$model = new Order();
|
fcd620e2
Alexey Boroda
-Number column ad...
|
122
|
|
2a050410
Yarik
Order
|
123
|
if ($model->load(Yii::$app->request->post()) && $model->save()) {
|
b6da6360
Alexey Boroda
-Order products r...
|
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
|
if (!empty(\Yii::$app->request->post('Product'))) {
foreach (\Yii::$app->request->post('Product') as $id => $count) {
/**
* @var Variant $variant
*/
$variant = Variant::findOne($id);
if ($variant) {
$orderProduct = new OrderProduct(
[
'variant_id' => $variant->id,
'order_id' => $model->id,
'sku' => $variant->sku,
'price' => $variant->price,
'count' => $count,
]
);
$orderProduct->save();
}
}
}
|
2a050410
Yarik
Order
|
145
146
|
return $this->redirect(
[
|
bb609829
Anastasia
- order
|
147
|
'index',
|
2a050410
Yarik
Order
|
148
149
150
151
|
]
);
} else {
$labels = Label::find()
|
fdce5f4a
Anastasia
- order
|
152
153
|
->joinWith('language')
->select(
|
fcd620e2
Alexey Boroda
-Number column ad...
|
154
155
156
157
158
|
[
'title',
'id',
]
)
|
fdce5f4a
Anastasia
- order
|
159
|
->where(
|
fcd620e2
Alexey Boroda
-Number column ad...
|
160
161
162
163
|
[
'status' => true,
]
)
|
fdce5f4a
Anastasia
- order
|
164
165
|
->indexBy('id')
->column();
|
2a050410
Yarik
Order
|
166
|
$deliveries = Delivery::find()
|
fdce5f4a
Anastasia
- order
|
167
168
|
->joinWith('language')
->select(
|
fcd620e2
Alexey Boroda
-Number column ad...
|
169
170
171
172
173
|
[
'title',
'id',
]
)
|
fdce5f4a
Anastasia
- order
|
174
|
->where(
|
fcd620e2
Alexey Boroda
-Number column ad...
|
175
176
177
178
|
[
'status' => true,
]
)
|
fdce5f4a
Anastasia
- order
|
179
180
|
->indexBy('id')
->column();
|
2a050410
Yarik
Order
|
181
|
$payments = Payment::find()
|
fdce5f4a
Anastasia
- order
|
182
183
|
->joinWith('language')
->select(
|
fcd620e2
Alexey Boroda
-Number column ad...
|
184
185
186
187
188
|
[
'title',
'id',
]
)
|
fdce5f4a
Anastasia
- order
|
189
|
->where(
|
fcd620e2
Alexey Boroda
-Number column ad...
|
190
191
192
193
|
[
'status' => true,
]
)
|
fdce5f4a
Anastasia
- order
|
194
195
|
->indexBy('id')
->column();
|
2a050410
Yarik
Order
|
196
|
return $this->render(
|
5fb852db
Anastasia
nova poshta admin
|
197
|
'create',
|
2a050410
Yarik
Order
|
198
199
200
201
202
203
204
205
206
|
[
'model' => $model,
'labels' => $labels,
'payments' => $payments,
'deliveries' => $deliveries,
]
);
}
}
|
e715ad66
Anastasia
incust final
|
207
|
|
2a050410
Yarik
Order
|
208
209
210
211
212
213
214
|
/**
* Updates an existing Order model.
* If update is successful, the browser will be redirected to the 'view' page.
*
* @param integer $id
*
* @return mixed
|
e715ad66
Anastasia
incust final
|
215
|
* @throws \yii\base\InvalidConfigException
|
2a050410
Yarik
Order
|
216
217
218
219
|
*/
public function actionUpdate($id)
{
$model = $this->findModel($id);
|
e715ad66
Anastasia
incust final
|
220
221
222
223
|
/**
* @var \backend\components\Incust $incust;
*/
$incust = \Yii::$app->get('incust');
|
fcd620e2
Alexey Boroda
-Number column ad...
|
224
225
226
227
228
229
230
|
if ($model->load(Yii::$app->request->post()) && $model->save() && !empty(
\Yii::$app->request->post(
'OrderProduct'
)
)) {
//print_r(\Yii::$app->request->post('OrderProduct')); die();
|
fd40a9e1
Yarik
Products to order
|
231
|
OrderProduct::saveItems(\Yii::$app->request->post('OrderProduct'), $id);
|
e715ad66
Anastasia
incust final
|
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
|
if ($model->paid) {
$check = $incust->generateCheck($model);
$data = $incust->processCheck($check);
if (is_array($data) and !empty($data)) {
\Yii::info('The check process ID' . $model->id);
$model->save(true, [ 'status_incust' => 'process_check' ]);
$data = $incust->finalCheck($data);
if (!empty($data) and is_array($data)){
$model->status_incust = 'final_check';
$model->id_incust = $data['id'];
$model->bonuses_add = $data['bonuses_added'];
\Yii::info('The check final ID'.$model->id);
$model->save();
}
}
}
|
2a050410
Yarik
Order
|
248
249
|
return $this->redirect(
[
|
bb609829
Anastasia
- order
|
250
|
'index',
|
2a050410
Yarik
Order
|
251
252
253
254
|
]
);
} else {
$labels = Label::find()
|
fdce5f4a
Anastasia
- order
|
255
|
->joinWith('language')
|
2a050410
Yarik
Order
|
256
257
258
259
260
261
262
263
264
265
266
267
268
269
|
->select(
[
'title',
'id',
]
)
->where(
[
'status' => true,
]
)
->indexBy('id')
->column();
$deliveries = Delivery::find()
|
fdce5f4a
Anastasia
- order
|
270
271
|
->joinWith('language')
->select(
|
fcd620e2
Alexey Boroda
-Number column ad...
|
272
273
274
275
276
|
[
'title',
'id',
]
)
|
fdce5f4a
Anastasia
- order
|
277
|
->where(
|
fcd620e2
Alexey Boroda
-Number column ad...
|
278
279
280
281
|
[
'status' => true,
]
)
|
fdce5f4a
Anastasia
- order
|
282
283
|
->indexBy('id')
->column();
|
2a050410
Yarik
Order
|
284
|
$payments = Payment::find()
|
fdce5f4a
Anastasia
- order
|
285
286
|
->joinWith('language')
->select(
|
fcd620e2
Alexey Boroda
-Number column ad...
|
287
288
289
290
291
|
[
'title',
'id',
]
)
|
fdce5f4a
Anastasia
- order
|
292
|
->where(
|
fcd620e2
Alexey Boroda
-Number column ad...
|
293
294
295
296
|
[
'status' => true,
]
)
|
fdce5f4a
Anastasia
- order
|
297
298
|
->indexBy('id')
->column();
|
2a050410
Yarik
Order
|
299
|
return $this->render(
|
5fb852db
Anastasia
nova poshta admin
|
300
|
'update',
|
2a050410
Yarik
Order
|
301
302
303
304
305
306
307
308
309
|
[
'model' => $model,
'labels' => $labels,
'payments' => $payments,
'deliveries' => $deliveries,
]
);
}
}
|
fcd620e2
Alexey Boroda
-Number column ad...
|
310
|
|
2a050410
Yarik
Order
|
311
312
313
314
315
316
317
318
319
320
321
322
|
/**
* Deletes an existing Order model.
* If deletion is successful, the browser will be redirected to the 'index' page.
*
* @param integer $id
*
* @return mixed
*/
public function actionDelete($id)
{
$this->findModel($id)
->delete();
|
fcd620e2
Alexey Boroda
-Number column ad...
|
323
|
|
2a050410
Yarik
Order
|
324
325
|
return $this->redirect([ 'index' ]);
}
|
fcd620e2
Alexey Boroda
-Number column ad...
|
326
|
|
fd40a9e1
Yarik
Products to order
|
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
|
public function actionProductList($q = null, $id = null)
{
$response = \Yii::$app->response;
$response->format = $response::FORMAT_JSON;
$out = [
'results' => [
'id' => '',
'text' => '',
],
];
if (!is_null($q)) {
$out[ 'results' ] = [];
/**
* @var Variant[] $variants
*/
$variants = Variant::find()
|
fd40a9e1
Yarik
Products to order
|
343
|
->joinWith('product.lang', false)
|
a55bed64
Anastasia
- order
|
344
|
->where(
|
fd40a9e1
Yarik
Products to order
|
345
346
347
348
349
350
|
[
'like',
'product_lang.title',
$q,
]
)
|
fd40a9e1
Yarik
Products to order
|
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
|
->orWhere([ 'variant.sku' => $q ])
->all();
foreach ($variants as $variant) {
$out[ 'results' ][] = [
'id' => $variant->id,
'text' => $variant->product->lang->title,
];
}
} elseif ($id > 0) {
/**
* @var Variant $variant
*/
$variant = Variant::find()
->with('lang', 'product.lang')
->where([ 'id' => $id ])
->one();
$out[ 'results' ] = [
'id' => $id,
'text' => $variant->product->lang->title,
];
}
return $out;
}
|
fcd620e2
Alexey Boroda
-Number column ad...
|
374
|
|
fd40a9e1
Yarik
Products to order
|
375
376
|
public function actionAddToOrder()
{
|
fd40a9e1
Yarik
Products to order
|
377
|
/**
|
543a6adb
Anastasia
order
|
378
379
380
|
* @var Variant $variant
* @var ActiveForm $form
* @var OrderProduct $orderProduct
|
fd40a9e1
Yarik
Products to order
|
381
|
*/
|
543a6adb
Anastasia
order
|
382
383
384
|
\Yii::$app->response->format = Response::FORMAT_JSON;
$id = \Yii::$app->request->post('id');
$count = \Yii::$app->request->post('count') ? \Yii::$app->request->post('count') : 1;
|
fcd620e2
Alexey Boroda
-Number column ad...
|
385
|
|
fd40a9e1
Yarik
Products to order
|
386
|
$variant = Variant::find()
|
543a6adb
Anastasia
order
|
387
388
389
390
391
392
|
->with('product.lang')
->where(
[
'id' => $id,
]
)
|
fd40a9e1
Yarik
Products to order
|
393
|
->one();
|
fcd620e2
Alexey Boroda
-Number column ad...
|
394
|
|
543a6adb
Anastasia
order
|
395
396
397
|
if ($variant) {
$form = new ActiveForm();
$orderProduct = new OrderProduct(
|
fd40a9e1
Yarik
Products to order
|
398
|
[
|
fd40a9e1
Yarik
Products to order
|
399
|
'count' => $count,
|
543a6adb
Anastasia
order
|
400
|
'variant_id' => $variant->id,
|
fd40a9e1
Yarik
Products to order
|
401
402
|
]
);
|
fcd620e2
Alexey Boroda
-Number column ad...
|
403
|
|
543a6adb
Anastasia
order
|
404
405
406
407
408
409
410
411
412
413
|
$row = $this->renderPartial(
'_order_product',
[
'orderProduct' => $orderProduct,
'index' => rand(0, 10000),
'variant' => $variant,
'price' => $variant->price,
'form' => $form,
]
);
|
fcd620e2
Alexey Boroda
-Number column ad...
|
414
|
|
543a6adb
Anastasia
order
|
415
416
417
|
return [
'success' => true,
'row' => $row,
|
8b638e12
Anastasia
sum in order
|
418
|
'price' => $variant->price * $count,
|
543a6adb
Anastasia
order
|
419
|
];
|
fd40a9e1
Yarik
Products to order
|
420
|
}
|
fcd620e2
Alexey Boroda
-Number column ad...
|
421
|
|
543a6adb
Anastasia
order
|
422
423
424
425
|
return [
'success' => false,
'message' => \Yii::t('app', 'Product not found'),
];
|
b6db17e5
Anastasia
order in admin
|
426
|
}
|
fcd620e2
Alexey Boroda
-Number column ad...
|
427
|
|
2a050410
Yarik
Order
|
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
|
/**
* Finds the Order model based on its primary key value.
* If the model is not found, a 404 HTTP exception will be thrown.
*
* @param integer $id
*
* @return Order the loaded model
* @throws NotFoundHttpException if the model cannot be found
*/
protected function findModel($id)
{
if (( $model = Order::findOne($id) ) !== null) {
return $model;
} else {
throw new NotFoundHttpException('The requested page does not exist.');
}
}
|
7b952362
Anastasia
price and count u...
|
445
|
|
fcd620e2
Alexey Boroda
-Number column ad...
|
446
447
|
public function actionPrint($id)
{
|
7b952362
Anastasia
price and count u...
|
448
449
|
$this->layout = false;
$model = $this->findModel($id);
|
fcd620e2
Alexey Boroda
-Number column ad...
|
450
451
452
453
454
455
|
return $this->renderPartial(
'@backend/views/layouts/print',
[
'model' => $model,
]
);
|
7b952362
Anastasia
price and count u...
|
456
|
}
|
fcd620e2
Alexey Boroda
-Number column ad...
|
457
|
|
543a6adb
Anastasia
order
|
458
459
460
461
|
protected function hasProducts()
{
if (empty(\Yii::$app->request->post('OrderProduct'))) {
\Yii::$app->session->setFlash('error', \Yii::t('app', 'Заказ не может быть без товаров'));
|
fcd620e2
Alexey Boroda
-Number column ad...
|
462
|
|
543a6adb
Anastasia
order
|
463
464
|
return false;
}
|
fcd620e2
Alexey Boroda
-Number column ad...
|
465
|
|
543a6adb
Anastasia
order
|
466
467
|
return true;
}
|
fcd620e2
Alexey Boroda
-Number column ad...
|
468
|
|
543a6adb
Anastasia
order
|
469
470
471
472
473
474
|
/**
* @return array
*/
protected function getLabels()
{
return Label::find()
|
fdce5f4a
Anastasia
- order
|
475
|
->joinWith('language')
|
543a6adb
Anastasia
order
|
476
477
478
479
480
481
482
483
484
485
486
487
488
489
|
->select(
[
'title',
'id',
]
)
->where(
[
'status' => true,
]
)
->indexBy('id')
->column();
}
|
fcd620e2
Alexey Boroda
-Number column ad...
|
490
|
|
543a6adb
Anastasia
order
|
491
492
493
494
495
496
|
/**
* @return array
*/
protected function getPayments()
{
return Payment::find()
|
fdce5f4a
Anastasia
- order
|
497
|
->joinWith('language')
|
543a6adb
Anastasia
order
|
498
499
500
501
502
503
504
505
506
507
508
509
510
511
|
->select(
[
'title',
'id',
]
)
->where(
[
'status' => true,
]
)
->indexBy('id')
->column();
}
|
fcd620e2
Alexey Boroda
-Number column ad...
|
512
|
|
543a6adb
Anastasia
order
|
513
514
515
516
517
518
|
/**
* @return array
*/
protected function getDeliveries()
{
return Delivery::find()
|
fdce5f4a
Anastasia
- order
|
519
|
->joinWith('language')
|
543a6adb
Anastasia
order
|
520
521
522
523
524
525
526
527
528
529
530
531
532
533
|
->select(
[
'title',
'id',
]
)
->where(
[
'status' => true,
]
)
->indexBy('id')
->column();
}
|
2a050410
Yarik
Order
|
534
|
}
|