Commit fcd620e29bbd32b893485a0fe315863ab7341cc5
1 parent
995dd689
-Number column added to order
Showing
1 changed file
with
89 additions
and
78 deletions
Show diff stats
controllers/OrderController.php
| 1 | <?php | 1 | <?php |
| 2 | 2 | ||
| 3 | namespace artbox\order\controllers; | 3 | namespace artbox\order\controllers; |
| 4 | - | 4 | + |
| 5 | use artbox\catalog\models\Variant; | 5 | use artbox\catalog\models\Variant; |
| 6 | use artbox\core\admin\actions\Index; | 6 | use artbox\core\admin\actions\Index; |
| 7 | use artbox\order\labels\models\Delivery; | 7 | use artbox\order\labels\models\Delivery; |
| @@ -16,7 +16,7 @@ | @@ -16,7 +16,7 @@ | ||
| 16 | use yii\filters\AccessControl; | 16 | use yii\filters\AccessControl; |
| 17 | use yii\web\Response; | 17 | use yii\web\Response; |
| 18 | use yii\widgets\ActiveForm; | 18 | use yii\widgets\ActiveForm; |
| 19 | - | 19 | + |
| 20 | /** | 20 | /** |
| 21 | * OrderController implements the CRUD actions for Order model. | 21 | * OrderController implements the CRUD actions for Order model. |
| 22 | */ | 22 | */ |
| @@ -29,11 +29,11 @@ | @@ -29,11 +29,11 @@ | ||
| 29 | { | 29 | { |
| 30 | return '@artbox/order/views/order'; | 30 | return '@artbox/order/views/order'; |
| 31 | } | 31 | } |
| 32 | - | 32 | + |
| 33 | public function behaviors() | 33 | public function behaviors() |
| 34 | { | 34 | { |
| 35 | return [ | 35 | return [ |
| 36 | - 'verbs' => [ | 36 | + 'verbs' => [ |
| 37 | 'class' => VerbFilter::className(), | 37 | 'class' => VerbFilter::className(), |
| 38 | 'actions' => [ | 38 | 'actions' => [ |
| 39 | 'delete' => [ 'POST' ], | 39 | 'delete' => [ 'POST' ], |
| @@ -57,15 +57,18 @@ | @@ -57,15 +57,18 @@ | ||
| 57 | ], | 57 | ], |
| 58 | ]; | 58 | ]; |
| 59 | } | 59 | } |
| 60 | - | 60 | + |
| 61 | public function actions() | 61 | public function actions() |
| 62 | { | 62 | { |
| 63 | return [ | 63 | return [ |
| 64 | 'index' => [ | 64 | 'index' => [ |
| 65 | 'class' => Index::className(), | 65 | 'class' => Index::className(), |
| 66 | 'columns' => [ | 66 | 'columns' => [ |
| 67 | + 'id' => [ | ||
| 68 | + 'type' => Index::NUMBER_COL, | ||
| 69 | + ], | ||
| 67 | 'name' => [ | 70 | 'name' => [ |
| 68 | - 'type' => Index::ACTION_COL, | 71 | + 'type' => Index::ACTION_COL, |
| 69 | 'columnConfig' => [ | 72 | 'columnConfig' => [ |
| 70 | 'buttonsTemplate' => '{edit}{delete}', | 73 | 'buttonsTemplate' => '{edit}{delete}', |
| 71 | ], | 74 | ], |
| @@ -93,7 +96,7 @@ | @@ -93,7 +96,7 @@ | ||
| 93 | ], | 96 | ], |
| 94 | ]; | 97 | ]; |
| 95 | } | 98 | } |
| 96 | - | 99 | + |
| 97 | /** | 100 | /** |
| 98 | * Displays a single Order model. | 101 | * Displays a single Order model. |
| 99 | * | 102 | * |
| @@ -110,7 +113,7 @@ | @@ -110,7 +113,7 @@ | ||
| 110 | ] | 113 | ] |
| 111 | ); | 114 | ); |
| 112 | } | 115 | } |
| 113 | - | 116 | + |
| 114 | /** | 117 | /** |
| 115 | * Creates a new Order model. | 118 | * Creates a new Order model. |
| 116 | * If creation is successful, the browser will be redirected to the 'view' page. | 119 | * If creation is successful, the browser will be redirected to the 'view' page. |
| @@ -120,7 +123,7 @@ | @@ -120,7 +123,7 @@ | ||
| 120 | public function actionCreate() | 123 | public function actionCreate() |
| 121 | { | 124 | { |
| 122 | $model = new Order(); | 125 | $model = new Order(); |
| 123 | - | 126 | + |
| 124 | if ($model->load(Yii::$app->request->post()) && $model->save()) { | 127 | if ($model->load(Yii::$app->request->post()) && $model->save()) { |
| 125 | if (!empty(\Yii::$app->request->post('Product'))) { | 128 | if (!empty(\Yii::$app->request->post('Product'))) { |
| 126 | foreach (\Yii::$app->request->post('Product') as $id => $count) { | 129 | foreach (\Yii::$app->request->post('Product') as $id => $count) { |
| @@ -153,46 +156,46 @@ | @@ -153,46 +156,46 @@ | ||
| 153 | $labels = Label::find() | 156 | $labels = Label::find() |
| 154 | ->joinWith('language') | 157 | ->joinWith('language') |
| 155 | ->select( | 158 | ->select( |
| 156 | - [ | ||
| 157 | - 'title', | ||
| 158 | - 'id', | ||
| 159 | - ] | ||
| 160 | - ) | 159 | + [ |
| 160 | + 'title', | ||
| 161 | + 'id', | ||
| 162 | + ] | ||
| 163 | + ) | ||
| 161 | ->where( | 164 | ->where( |
| 162 | - [ | ||
| 163 | - 'status' => true, | ||
| 164 | - ] | ||
| 165 | - ) | 165 | + [ |
| 166 | + 'status' => true, | ||
| 167 | + ] | ||
| 168 | + ) | ||
| 166 | ->indexBy('id') | 169 | ->indexBy('id') |
| 167 | ->column(); | 170 | ->column(); |
| 168 | $deliveries = Delivery::find() | 171 | $deliveries = Delivery::find() |
| 169 | ->joinWith('language') | 172 | ->joinWith('language') |
| 170 | ->select( | 173 | ->select( |
| 171 | - [ | ||
| 172 | - 'title', | ||
| 173 | - 'id', | ||
| 174 | - ] | ||
| 175 | - ) | 174 | + [ |
| 175 | + 'title', | ||
| 176 | + 'id', | ||
| 177 | + ] | ||
| 178 | + ) | ||
| 176 | ->where( | 179 | ->where( |
| 177 | - [ | ||
| 178 | - 'status' => true, | ||
| 179 | - ] | ||
| 180 | - ) | 180 | + [ |
| 181 | + 'status' => true, | ||
| 182 | + ] | ||
| 183 | + ) | ||
| 181 | ->indexBy('id') | 184 | ->indexBy('id') |
| 182 | ->column(); | 185 | ->column(); |
| 183 | $payments = Payment::find() | 186 | $payments = Payment::find() |
| 184 | ->joinWith('language') | 187 | ->joinWith('language') |
| 185 | ->select( | 188 | ->select( |
| 186 | - [ | ||
| 187 | - 'title', | ||
| 188 | - 'id', | ||
| 189 | - ] | ||
| 190 | - ) | 189 | + [ |
| 190 | + 'title', | ||
| 191 | + 'id', | ||
| 192 | + ] | ||
| 193 | + ) | ||
| 191 | ->where( | 194 | ->where( |
| 192 | - [ | ||
| 193 | - 'status' => true, | ||
| 194 | - ] | ||
| 195 | - ) | 195 | + [ |
| 196 | + 'status' => true, | ||
| 197 | + ] | ||
| 198 | + ) | ||
| 196 | ->indexBy('id') | 199 | ->indexBy('id') |
| 197 | ->column(); | 200 | ->column(); |
| 198 | return $this->render( | 201 | return $this->render( |
| @@ -206,7 +209,7 @@ | @@ -206,7 +209,7 @@ | ||
| 206 | ); | 209 | ); |
| 207 | } | 210 | } |
| 208 | } | 211 | } |
| 209 | - | 212 | + |
| 210 | /** | 213 | /** |
| 211 | * Updates an existing Order model. | 214 | * Updates an existing Order model. |
| 212 | * If update is successful, the browser will be redirected to the 'view' page. | 215 | * If update is successful, the browser will be redirected to the 'view' page. |
| @@ -218,9 +221,13 @@ | @@ -218,9 +221,13 @@ | ||
| 218 | public function actionUpdate($id) | 221 | public function actionUpdate($id) |
| 219 | { | 222 | { |
| 220 | $model = $this->findModel($id); | 223 | $model = $this->findModel($id); |
| 221 | - | ||
| 222 | - if ($model->load(Yii::$app->request->post()) && $model->save() && !empty(\Yii::$app->request->post('OrderProduct'))) { | ||
| 223 | - //print_r(\Yii::$app->request->post('OrderProduct')); die(); | 224 | + |
| 225 | + if ($model->load(Yii::$app->request->post()) && $model->save() && !empty( | ||
| 226 | + \Yii::$app->request->post( | ||
| 227 | + 'OrderProduct' | ||
| 228 | + ) | ||
| 229 | + )) { | ||
| 230 | + //print_r(\Yii::$app->request->post('OrderProduct')); die(); | ||
| 224 | OrderProduct::saveItems(\Yii::$app->request->post('OrderProduct'), $id); | 231 | OrderProduct::saveItems(\Yii::$app->request->post('OrderProduct'), $id); |
| 225 | return $this->redirect( | 232 | return $this->redirect( |
| 226 | [ | 233 | [ |
| @@ -247,31 +254,31 @@ | @@ -247,31 +254,31 @@ | ||
| 247 | $deliveries = Delivery::find() | 254 | $deliveries = Delivery::find() |
| 248 | ->joinWith('language') | 255 | ->joinWith('language') |
| 249 | ->select( | 256 | ->select( |
| 250 | - [ | ||
| 251 | - 'title', | ||
| 252 | - 'id', | ||
| 253 | - ] | ||
| 254 | - ) | 257 | + [ |
| 258 | + 'title', | ||
| 259 | + 'id', | ||
| 260 | + ] | ||
| 261 | + ) | ||
| 255 | ->where( | 262 | ->where( |
| 256 | - [ | ||
| 257 | - 'status' => true, | ||
| 258 | - ] | ||
| 259 | - ) | 263 | + [ |
| 264 | + 'status' => true, | ||
| 265 | + ] | ||
| 266 | + ) | ||
| 260 | ->indexBy('id') | 267 | ->indexBy('id') |
| 261 | ->column(); | 268 | ->column(); |
| 262 | $payments = Payment::find() | 269 | $payments = Payment::find() |
| 263 | ->joinWith('language') | 270 | ->joinWith('language') |
| 264 | ->select( | 271 | ->select( |
| 265 | - [ | ||
| 266 | - 'title', | ||
| 267 | - 'id', | ||
| 268 | - ] | ||
| 269 | - ) | 272 | + [ |
| 273 | + 'title', | ||
| 274 | + 'id', | ||
| 275 | + ] | ||
| 276 | + ) | ||
| 270 | ->where( | 277 | ->where( |
| 271 | - [ | ||
| 272 | - 'status' => true, | ||
| 273 | - ] | ||
| 274 | - ) | 278 | + [ |
| 279 | + 'status' => true, | ||
| 280 | + ] | ||
| 281 | + ) | ||
| 275 | ->indexBy('id') | 282 | ->indexBy('id') |
| 276 | ->column(); | 283 | ->column(); |
| 277 | return $this->render( | 284 | return $this->render( |
| @@ -285,7 +292,7 @@ | @@ -285,7 +292,7 @@ | ||
| 285 | ); | 292 | ); |
| 286 | } | 293 | } |
| 287 | } | 294 | } |
| 288 | - | 295 | + |
| 289 | /** | 296 | /** |
| 290 | * Deletes an existing Order model. | 297 | * Deletes an existing Order model. |
| 291 | * If deletion is successful, the browser will be redirected to the 'index' page. | 298 | * If deletion is successful, the browser will be redirected to the 'index' page. |
| @@ -298,10 +305,10 @@ | @@ -298,10 +305,10 @@ | ||
| 298 | { | 305 | { |
| 299 | $this->findModel($id) | 306 | $this->findModel($id) |
| 300 | ->delete(); | 307 | ->delete(); |
| 301 | - | 308 | + |
| 302 | return $this->redirect([ 'index' ]); | 309 | return $this->redirect([ 'index' ]); |
| 303 | } | 310 | } |
| 304 | - | 311 | + |
| 305 | public function actionProductList($q = null, $id = null) | 312 | public function actionProductList($q = null, $id = null) |
| 306 | { | 313 | { |
| 307 | $response = \Yii::$app->response; | 314 | $response = \Yii::$app->response; |
| @@ -349,7 +356,7 @@ | @@ -349,7 +356,7 @@ | ||
| 349 | } | 356 | } |
| 350 | return $out; | 357 | return $out; |
| 351 | } | 358 | } |
| 352 | - | 359 | + |
| 353 | public function actionAddToOrder() | 360 | public function actionAddToOrder() |
| 354 | { | 361 | { |
| 355 | /** | 362 | /** |
| @@ -360,7 +367,7 @@ | @@ -360,7 +367,7 @@ | ||
| 360 | \Yii::$app->response->format = Response::FORMAT_JSON; | 367 | \Yii::$app->response->format = Response::FORMAT_JSON; |
| 361 | $id = \Yii::$app->request->post('id'); | 368 | $id = \Yii::$app->request->post('id'); |
| 362 | $count = \Yii::$app->request->post('count') ? \Yii::$app->request->post('count') : 1; | 369 | $count = \Yii::$app->request->post('count') ? \Yii::$app->request->post('count') : 1; |
| 363 | - | 370 | + |
| 364 | $variant = Variant::find() | 371 | $variant = Variant::find() |
| 365 | ->with('product.lang') | 372 | ->with('product.lang') |
| 366 | ->where( | 373 | ->where( |
| @@ -369,7 +376,7 @@ | @@ -369,7 +376,7 @@ | ||
| 369 | ] | 376 | ] |
| 370 | ) | 377 | ) |
| 371 | ->one(); | 378 | ->one(); |
| 372 | - | 379 | + |
| 373 | if ($variant) { | 380 | if ($variant) { |
| 374 | $form = new ActiveForm(); | 381 | $form = new ActiveForm(); |
| 375 | $orderProduct = new OrderProduct( | 382 | $orderProduct = new OrderProduct( |
| @@ -378,7 +385,7 @@ | @@ -378,7 +385,7 @@ | ||
| 378 | 'variant_id' => $variant->id, | 385 | 'variant_id' => $variant->id, |
| 379 | ] | 386 | ] |
| 380 | ); | 387 | ); |
| 381 | - | 388 | + |
| 382 | $row = $this->renderPartial( | 389 | $row = $this->renderPartial( |
| 383 | '_order_product', | 390 | '_order_product', |
| 384 | [ | 391 | [ |
| @@ -389,20 +396,20 @@ | @@ -389,20 +396,20 @@ | ||
| 389 | 'form' => $form, | 396 | 'form' => $form, |
| 390 | ] | 397 | ] |
| 391 | ); | 398 | ); |
| 392 | - | 399 | + |
| 393 | return [ | 400 | return [ |
| 394 | 'success' => true, | 401 | 'success' => true, |
| 395 | 'row' => $row, | 402 | 'row' => $row, |
| 396 | 'price' => $variant->price * $count, | 403 | 'price' => $variant->price * $count, |
| 397 | ]; | 404 | ]; |
| 398 | } | 405 | } |
| 399 | - | 406 | + |
| 400 | return [ | 407 | return [ |
| 401 | 'success' => false, | 408 | 'success' => false, |
| 402 | 'message' => \Yii::t('app', 'Product not found'), | 409 | 'message' => \Yii::t('app', 'Product not found'), |
| 403 | ]; | 410 | ]; |
| 404 | } | 411 | } |
| 405 | - | 412 | + |
| 406 | /** | 413 | /** |
| 407 | * Finds the Order model based on its primary key value. | 414 | * Finds the Order model based on its primary key value. |
| 408 | * If the model is not found, a 404 HTTP exception will be thrown. | 415 | * If the model is not found, a 404 HTTP exception will be thrown. |
| @@ -421,25 +428,29 @@ | @@ -421,25 +428,29 @@ | ||
| 421 | } | 428 | } |
| 422 | } | 429 | } |
| 423 | 430 | ||
| 424 | - public function actionPrint($id){ | 431 | + public function actionPrint($id) |
| 432 | + { | ||
| 425 | $this->layout = false; | 433 | $this->layout = false; |
| 426 | $model = $this->findModel($id); | 434 | $model = $this->findModel($id); |
| 427 | - return $this->renderPartial('@backend/views/layouts/print', [ | ||
| 428 | - 'model' => $model | ||
| 429 | - ]); | 435 | + return $this->renderPartial( |
| 436 | + '@backend/views/layouts/print', | ||
| 437 | + [ | ||
| 438 | + 'model' => $model, | ||
| 439 | + ] | ||
| 440 | + ); | ||
| 430 | } | 441 | } |
| 431 | - | 442 | + |
| 432 | protected function hasProducts() | 443 | protected function hasProducts() |
| 433 | { | 444 | { |
| 434 | if (empty(\Yii::$app->request->post('OrderProduct'))) { | 445 | if (empty(\Yii::$app->request->post('OrderProduct'))) { |
| 435 | \Yii::$app->session->setFlash('error', \Yii::t('app', 'Заказ не может быть без товаров')); | 446 | \Yii::$app->session->setFlash('error', \Yii::t('app', 'Заказ не может быть без товаров')); |
| 436 | - | 447 | + |
| 437 | return false; | 448 | return false; |
| 438 | } | 449 | } |
| 439 | - | 450 | + |
| 440 | return true; | 451 | return true; |
| 441 | } | 452 | } |
| 442 | - | 453 | + |
| 443 | /** | 454 | /** |
| 444 | * @return array | 455 | * @return array |
| 445 | */ | 456 | */ |
| @@ -461,7 +472,7 @@ | @@ -461,7 +472,7 @@ | ||
| 461 | ->indexBy('id') | 472 | ->indexBy('id') |
| 462 | ->column(); | 473 | ->column(); |
| 463 | } | 474 | } |
| 464 | - | 475 | + |
| 465 | /** | 476 | /** |
| 466 | * @return array | 477 | * @return array |
| 467 | */ | 478 | */ |
| @@ -483,7 +494,7 @@ | @@ -483,7 +494,7 @@ | ||
| 483 | ->indexBy('id') | 494 | ->indexBy('id') |
| 484 | ->column(); | 495 | ->column(); |
| 485 | } | 496 | } |
| 486 | - | 497 | + |
| 487 | /** | 498 | /** |
| 488 | * @return array | 499 | * @return array |
| 489 | */ | 500 | */ |