Blame view

controllers/OrderController.php 18.1 KB
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',
225903c8   Anastasia   - default sort
105
                      'defaultSort'      => 'created_at DESC'
fdce5f4a   Anastasia   - order
106
107
                  ],
              ];
2a050410   Yarik   Order
108
          }
fcd620e2   Alexey Boroda   -Number column ad...
109
          
fcd620e2   Alexey Boroda   -Number column ad...
110
          
2a050410   Yarik   Order
111
112
113
114
115
116
117
118
119
          /**
           * 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...
120
              
2a050410   Yarik   Order
121
              if ($model->load(Yii::$app->request->post()) && $model->save()) {
b6da6360   Alexey Boroda   -Order products r...
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
                  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
143
144
                  return $this->redirect(
                      [
bb609829   Anastasia   - order
145
                          'index',
2a050410   Yarik   Order
146
147
148
149
                      ]
                  );
              } else {
                  $labels = Label::find()
fdce5f4a   Anastasia   - order
150
151
                                 ->joinWith('language')
                                 ->select(
fcd620e2   Alexey Boroda   -Number column ad...
152
153
154
155
156
                                     [
                                         'title',
                                         'id',
                                     ]
                                 )
fdce5f4a   Anastasia   - order
157
                                 ->where(
fcd620e2   Alexey Boroda   -Number column ad...
158
159
160
161
                                     [
                                         'status' => true,
                                     ]
                                 )
fdce5f4a   Anastasia   - order
162
163
                                 ->indexBy('id')
                                 ->column();
2a050410   Yarik   Order
164
                  $deliveries = Delivery::find()
fdce5f4a   Anastasia   - order
165
166
                                        ->joinWith('language')
                                        ->select(
fcd620e2   Alexey Boroda   -Number column ad...
167
168
169
170
171
                                            [
                                                'title',
                                                'id',
                                            ]
                                        )
fdce5f4a   Anastasia   - order
172
                                        ->where(
fcd620e2   Alexey Boroda   -Number column ad...
173
174
175
176
                                            [
                                                'status' => true,
                                            ]
                                        )
fdce5f4a   Anastasia   - order
177
178
                                        ->indexBy('id')
                                        ->column();
2a050410   Yarik   Order
179
                  $payments = Payment::find()
fdce5f4a   Anastasia   - order
180
181
                                     ->joinWith('language')
                                     ->select(
fcd620e2   Alexey Boroda   -Number column ad...
182
183
184
185
186
                                         [
                                             'title',
                                             'id',
                                         ]
                                     )
fdce5f4a   Anastasia   - order
187
                                     ->where(
fcd620e2   Alexey Boroda   -Number column ad...
188
189
190
191
                                         [
                                             'status' => true,
                                         ]
                                     )
fdce5f4a   Anastasia   - order
192
193
                                     ->indexBy('id')
                                     ->column();
2a050410   Yarik   Order
194
                  return $this->render(
5fb852db   Anastasia   nova poshta admin
195
                      'create',
2a050410   Yarik   Order
196
197
198
199
200
201
202
203
204
                      [
                          'model'      => $model,
                          'labels'     => $labels,
                          'payments'   => $payments,
                          'deliveries' => $deliveries,
                      ]
                  );
              }
          }
fcd620e2   Alexey Boroda   -Number column ad...
205
          
2a050410   Yarik   Order
206
207
208
209
210
211
212
213
214
215
216
          /**
           * 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...
217
218
219
220
221
222
223
              
              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
224
                  OrderProduct::saveItems(\Yii::$app->request->post('OrderProduct'), $id);
2a050410   Yarik   Order
225
226
                  return $this->redirect(
                      [
bb609829   Anastasia   - order
227
                          'index',
2a050410   Yarik   Order
228
229
230
231
                      ]
                  );
              } else {
                  $labels = Label::find()
fdce5f4a   Anastasia   - order
232
                                 ->joinWith('language')
2a050410   Yarik   Order
233
234
235
236
237
238
239
240
241
242
243
244
245
246
                                 ->select(
                                     [
                                         'title',
                                         'id',
                                     ]
                                 )
                                 ->where(
                                     [
                                         'status' => true,
                                     ]
                                 )
                                 ->indexBy('id')
                                 ->column();
                  $deliveries = Delivery::find()
fdce5f4a   Anastasia   - order
247
248
                                        ->joinWith('language')
                                        ->select(
fcd620e2   Alexey Boroda   -Number column ad...
249
250
251
252
253
                                            [
                                                'title',
                                                'id',
                                            ]
                                        )
fdce5f4a   Anastasia   - order
254
                                        ->where(
fcd620e2   Alexey Boroda   -Number column ad...
255
256
257
258
                                            [
                                                'status' => true,
                                            ]
                                        )
fdce5f4a   Anastasia   - order
259
260
                                        ->indexBy('id')
                                        ->column();
2a050410   Yarik   Order
261
                  $payments = Payment::find()
fdce5f4a   Anastasia   - order
262
263
                                     ->joinWith('language')
                                     ->select(
fcd620e2   Alexey Boroda   -Number column ad...
264
265
266
267
268
                                         [
                                             'title',
                                             'id',
                                         ]
                                     )
fdce5f4a   Anastasia   - order
269
                                     ->where(
fcd620e2   Alexey Boroda   -Number column ad...
270
271
272
273
                                         [
                                             'status' => true,
                                         ]
                                     )
fdce5f4a   Anastasia   - order
274
275
                                     ->indexBy('id')
                                     ->column();
2a050410   Yarik   Order
276
                  return $this->render(
5fb852db   Anastasia   nova poshta admin
277
                      'update',
2a050410   Yarik   Order
278
279
280
281
282
283
284
285
286
                      [
                          'model'      => $model,
                          'labels'     => $labels,
                          'payments'   => $payments,
                          'deliveries' => $deliveries,
                      ]
                  );
              }
          }
fcd620e2   Alexey Boroda   -Number column ad...
287
          
2a050410   Yarik   Order
288
289
290
291
292
293
294
295
296
297
298
299
          /**
           * 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...
300
              
2a050410   Yarik   Order
301
302
              return $this->redirect([ 'index' ]);
          }
fcd620e2   Alexey Boroda   -Number column ad...
303
          
fd40a9e1   Yarik   Products to order
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
          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
320
                                     ->joinWith('product.lang', false)
a55bed64   Anastasia   - order
321
                                     ->where(
fd40a9e1   Yarik   Products to order
322
323
324
325
326
327
                                         [
                                             'like',
                                             'product_lang.title',
                                             $q,
                                         ]
                                     )
fd40a9e1   Yarik   Products to order
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
                                     ->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...
351
          
fd40a9e1   Yarik   Products to order
352
353
          public function actionAddToOrder()
          {
fd40a9e1   Yarik   Products to order
354
              /**
543a6adb   Anastasia   order
355
356
357
               * @var Variant      $variant
               * @var ActiveForm   $form
               * @var OrderProduct $orderProduct
fd40a9e1   Yarik   Products to order
358
               */
543a6adb   Anastasia   order
359
360
361
              \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...
362
              
fd40a9e1   Yarik   Products to order
363
              $variant = Variant::find()
543a6adb   Anastasia   order
364
365
366
367
368
369
                                ->with('product.lang')
                                ->where(
                                    [
                                        'id' => $id,
                                    ]
                                )
fd40a9e1   Yarik   Products to order
370
                                ->one();
fcd620e2   Alexey Boroda   -Number column ad...
371
              
543a6adb   Anastasia   order
372
373
374
              if ($variant) {
                  $form = new ActiveForm();
                  $orderProduct = new OrderProduct(
fd40a9e1   Yarik   Products to order
375
                      [
fd40a9e1   Yarik   Products to order
376
                          'count'      => $count,
543a6adb   Anastasia   order
377
                          'variant_id' => $variant->id,
fd40a9e1   Yarik   Products to order
378
379
                      ]
                  );
fcd620e2   Alexey Boroda   -Number column ad...
380
                  
543a6adb   Anastasia   order
381
382
383
384
385
386
387
388
389
390
                  $row = $this->renderPartial(
                      '_order_product',
                      [
                          'orderProduct' => $orderProduct,
                          'index'        => rand(0, 10000),
                          'variant'      => $variant,
                          'price'        => $variant->price,
                          'form'         => $form,
                      ]
                  );
fcd620e2   Alexey Boroda   -Number column ad...
391
                  
543a6adb   Anastasia   order
392
393
394
                  return [
                      'success' => true,
                      'row'     => $row,
8b638e12   Anastasia   sum in order
395
                      'price'   => $variant->price * $count,
543a6adb   Anastasia   order
396
                  ];
fd40a9e1   Yarik   Products to order
397
              }
fcd620e2   Alexey Boroda   -Number column ad...
398
              
543a6adb   Anastasia   order
399
400
401
402
              return [
                  'success' => false,
                  'message' => \Yii::t('app', 'Product not found'),
              ];
b6db17e5   Anastasia   order in admin
403
          }
fcd620e2   Alexey Boroda   -Number column ad...
404
          
2a050410   Yarik   Order
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
          /**
           * 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...
422
          
fcd620e2   Alexey Boroda   -Number column ad...
423
424
          public function actionPrint($id)
          {
7b952362   Anastasia   price and count u...
425
426
              $this->layout = false;
              $model = $this->findModel($id);
fcd620e2   Alexey Boroda   -Number column ad...
427
428
429
430
431
432
              return $this->renderPartial(
                  '@backend/views/layouts/print',
                  [
                      'model' => $model,
                  ]
              );
7b952362   Anastasia   price and count u...
433
          }
fcd620e2   Alexey Boroda   -Number column ad...
434
          
543a6adb   Anastasia   order
435
436
437
438
          protected function hasProducts()
          {
              if (empty(\Yii::$app->request->post('OrderProduct'))) {
                  \Yii::$app->session->setFlash('error', \Yii::t('app', 'Заказ не может быть без товаров'));
fcd620e2   Alexey Boroda   -Number column ad...
439
                  
543a6adb   Anastasia   order
440
441
                  return false;
              }
fcd620e2   Alexey Boroda   -Number column ad...
442
              
543a6adb   Anastasia   order
443
444
              return true;
          }
fcd620e2   Alexey Boroda   -Number column ad...
445
          
543a6adb   Anastasia   order
446
447
448
449
450
451
          /**
           * @return array
           */
          protected function getLabels()
          {
              return Label::find()
fdce5f4a   Anastasia   - order
452
                          ->joinWith('language')
543a6adb   Anastasia   order
453
454
455
456
457
458
459
460
461
462
463
464
465
466
                          ->select(
                              [
                                  'title',
                                  'id',
                              ]
                          )
                          ->where(
                              [
                                  'status' => true,
                              ]
                          )
                          ->indexBy('id')
                          ->column();
          }
fcd620e2   Alexey Boroda   -Number column ad...
467
          
543a6adb   Anastasia   order
468
469
470
471
472
473
          /**
           * @return array
           */
          protected function getPayments()
          {
              return Payment::find()
fdce5f4a   Anastasia   - order
474
                            ->joinWith('language')
543a6adb   Anastasia   order
475
476
477
478
479
480
481
482
483
484
485
486
487
488
                            ->select(
                                [
                                    'title',
                                    'id',
                                ]
                            )
                            ->where(
                                [
                                    'status' => true,
                                ]
                            )
                            ->indexBy('id')
                            ->column();
          }
fcd620e2   Alexey Boroda   -Number column ad...
489
          
543a6adb   Anastasia   order
490
491
492
493
494
495
          /**
           * @return array
           */
          protected function getDeliveries()
          {
              return Delivery::find()
fdce5f4a   Anastasia   - order
496
                             ->joinWith('language')
543a6adb   Anastasia   order
497
498
499
500
501
502
503
504
505
506
507
508
509
510
                             ->select(
                                 [
                                     'title',
                                     'id',
                                 ]
                             )
                             ->where(
                                 [
                                     'status' => true,
                                 ]
                             )
                             ->indexBy('id')
                             ->column();
          }
2a050410   Yarik   Order
511
      }