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