Blame view

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