Commit fd40a9e1a50870b86e374e87e579162b8d4d7097
1 parent
2a050410
Products to order
Showing
5 changed files
with
429 additions
and
161 deletions
Show diff stats
assets/OrderAsset.php
controllers/OrderController.php
| 1 | 1 | <?php |
| 2 | 2 | |
| 3 | 3 | namespace artbox\order\controllers; |
| 4 | - | |
| 4 | + | |
| 5 | + use artbox\catalog\models\Product; | |
| 6 | + use artbox\catalog\models\Variant; | |
| 5 | 7 | use artbox\order\models\Delivery; |
| 6 | 8 | use artbox\order\models\Label; |
| 9 | + use artbox\order\models\OrderProduct; | |
| 7 | 10 | use artbox\order\models\Payment; |
| 8 | 11 | use Yii; |
| 9 | 12 | use artbox\order\models\Order; |
| 10 | 13 | use artbox\order\models\OrderSearch; |
| 14 | + use yii\base\InvalidParamException; | |
| 11 | 15 | use yii\base\Model; |
| 12 | 16 | use yii\web\Controller; |
| 13 | 17 | use yii\web\NotFoundHttpException; |
| 14 | 18 | use yii\filters\VerbFilter; |
| 15 | - | |
| 19 | + | |
| 16 | 20 | /** |
| 17 | 21 | * OrderController implements the CRUD actions for Order model. |
| 18 | 22 | */ |
| ... | ... | @@ -32,7 +36,7 @@ |
| 32 | 36 | ], |
| 33 | 37 | ]; |
| 34 | 38 | } |
| 35 | - | |
| 39 | + | |
| 36 | 40 | /** |
| 37 | 41 | * Lists all Order models. |
| 38 | 42 | * |
| ... | ... | @@ -43,21 +47,21 @@ |
| 43 | 47 | $searchModel = new OrderSearch(); |
| 44 | 48 | $dataProvider = $searchModel->search(Yii::$app->request->queryParams); |
| 45 | 49 | $labels = Label::find() |
| 46 | - ->select( | |
| 47 | - [ | |
| 48 | - 'title', | |
| 49 | - 'id', | |
| 50 | - ] | |
| 51 | - ) | |
| 52 | - ->joinWith('lang') | |
| 53 | - ->andWhere( | |
| 54 | - [ | |
| 55 | - 'status' => true, | |
| 56 | - ] | |
| 57 | - ) | |
| 58 | - ->indexBy('id') | |
| 59 | - ->column(); | |
| 60 | - | |
| 50 | + ->select( | |
| 51 | + [ | |
| 52 | + 'title', | |
| 53 | + 'id', | |
| 54 | + ] | |
| 55 | + ) | |
| 56 | + ->joinWith('lang') | |
| 57 | + ->andWhere( | |
| 58 | + [ | |
| 59 | + 'status' => true, | |
| 60 | + ] | |
| 61 | + ) | |
| 62 | + ->indexBy('id') | |
| 63 | + ->column(); | |
| 64 | + | |
| 61 | 65 | return $this->render( |
| 62 | 66 | '@artbox/order/views/order/index', |
| 63 | 67 | [ |
| ... | ... | @@ -67,7 +71,7 @@ |
| 67 | 71 | ] |
| 68 | 72 | ); |
| 69 | 73 | } |
| 70 | - | |
| 74 | + | |
| 71 | 75 | /** |
| 72 | 76 | * Displays a single Order model. |
| 73 | 77 | * |
| ... | ... | @@ -84,7 +88,7 @@ |
| 84 | 88 | ] |
| 85 | 89 | ); |
| 86 | 90 | } |
| 87 | - | |
| 91 | + | |
| 88 | 92 | /** |
| 89 | 93 | * Creates a new Order model. |
| 90 | 94 | * If creation is successful, the browser will be redirected to the 'view' page. |
| ... | ... | @@ -94,7 +98,7 @@ |
| 94 | 98 | public function actionCreate() |
| 95 | 99 | { |
| 96 | 100 | $model = new Order(); |
| 97 | - | |
| 101 | + | |
| 98 | 102 | if ($model->load(Yii::$app->request->post()) && $model->save()) { |
| 99 | 103 | return $this->redirect( |
| 100 | 104 | [ |
| ... | ... | @@ -104,50 +108,50 @@ |
| 104 | 108 | ); |
| 105 | 109 | } else { |
| 106 | 110 | $labels = Label::find() |
| 107 | - ->joinWith('lang') | |
| 108 | - ->select( | |
| 109 | - [ | |
| 110 | - 'title', | |
| 111 | - 'id', | |
| 112 | - ] | |
| 113 | - ) | |
| 114 | - ->where( | |
| 115 | - [ | |
| 116 | - 'status' => true, | |
| 117 | - ] | |
| 118 | - ) | |
| 119 | - ->indexBy('id') | |
| 120 | - ->column(); | |
| 111 | + ->joinWith('lang') | |
| 112 | + ->select( | |
| 113 | + [ | |
| 114 | + 'title', | |
| 115 | + 'id', | |
| 116 | + ] | |
| 117 | + ) | |
| 118 | + ->where( | |
| 119 | + [ | |
| 120 | + 'status' => true, | |
| 121 | + ] | |
| 122 | + ) | |
| 123 | + ->indexBy('id') | |
| 124 | + ->column(); | |
| 121 | 125 | $deliveries = Delivery::find() |
| 122 | - ->joinWith('lang') | |
| 123 | - ->select( | |
| 124 | - [ | |
| 125 | - 'title', | |
| 126 | - 'id', | |
| 127 | - ] | |
| 128 | - ) | |
| 129 | - ->where( | |
| 130 | - [ | |
| 131 | - 'status' => true, | |
| 132 | - ] | |
| 133 | - ) | |
| 134 | - ->indexBy('id') | |
| 135 | - ->column(); | |
| 126 | + ->joinWith('lang') | |
| 127 | + ->select( | |
| 128 | + [ | |
| 129 | + 'title', | |
| 130 | + 'id', | |
| 131 | + ] | |
| 132 | + ) | |
| 133 | + ->where( | |
| 134 | + [ | |
| 135 | + 'status' => true, | |
| 136 | + ] | |
| 137 | + ) | |
| 138 | + ->indexBy('id') | |
| 139 | + ->column(); | |
| 136 | 140 | $payments = Payment::find() |
| 137 | - ->joinWith('lang') | |
| 138 | - ->select( | |
| 139 | - [ | |
| 140 | - 'title', | |
| 141 | - 'id', | |
| 142 | - ] | |
| 143 | - ) | |
| 144 | - ->where( | |
| 145 | - [ | |
| 146 | - 'status' => true, | |
| 147 | - ] | |
| 148 | - ) | |
| 149 | - ->indexBy('id') | |
| 150 | - ->column(); | |
| 141 | + ->joinWith('lang') | |
| 142 | + ->select( | |
| 143 | + [ | |
| 144 | + 'title', | |
| 145 | + 'id', | |
| 146 | + ] | |
| 147 | + ) | |
| 148 | + ->where( | |
| 149 | + [ | |
| 150 | + 'status' => true, | |
| 151 | + ] | |
| 152 | + ) | |
| 153 | + ->indexBy('id') | |
| 154 | + ->column(); | |
| 151 | 155 | return $this->render( |
| 152 | 156 | '@artbox/order/views/order/create', |
| 153 | 157 | [ |
| ... | ... | @@ -159,7 +163,7 @@ |
| 159 | 163 | ); |
| 160 | 164 | } |
| 161 | 165 | } |
| 162 | - | |
| 166 | + | |
| 163 | 167 | /** |
| 164 | 168 | * Updates an existing Order model. |
| 165 | 169 | * If update is successful, the browser will be redirected to the 'view' page. |
| ... | ... | @@ -171,16 +175,9 @@ |
| 171 | 175 | public function actionUpdate($id) |
| 172 | 176 | { |
| 173 | 177 | $model = $this->findModel($id); |
| 174 | - | |
| 178 | + | |
| 175 | 179 | if ($model->load(Yii::$app->request->post()) && $model->save()) { |
| 176 | - if (Model::loadMultiple($model->orderProducts, \Yii::$app->request->post()) && Model::validateMultiple( | |
| 177 | - $model->orderProducts | |
| 178 | - ) | |
| 179 | - ) { | |
| 180 | - foreach ($model->orderProducts as $orderProduct) { | |
| 181 | - $orderProduct->save(false); | |
| 182 | - } | |
| 183 | - } | |
| 180 | + OrderProduct::saveItems(\Yii::$app->request->post('OrderProduct'), $id); | |
| 184 | 181 | return $this->redirect( |
| 185 | 182 | [ |
| 186 | 183 | 'view', |
| ... | ... | @@ -204,35 +201,35 @@ |
| 204 | 201 | ->indexBy('id') |
| 205 | 202 | ->column(); |
| 206 | 203 | $deliveries = Delivery::find() |
| 207 | - ->joinWith('lang') | |
| 208 | - ->select( | |
| 209 | - [ | |
| 210 | - 'title', | |
| 211 | - 'id', | |
| 212 | - ] | |
| 213 | - ) | |
| 214 | - ->where( | |
| 215 | - [ | |
| 216 | - 'status' => true, | |
| 217 | - ] | |
| 218 | - ) | |
| 219 | - ->indexBy('id') | |
| 220 | - ->column(); | |
| 204 | + ->joinWith('lang') | |
| 205 | + ->select( | |
| 206 | + [ | |
| 207 | + 'title', | |
| 208 | + 'id', | |
| 209 | + ] | |
| 210 | + ) | |
| 211 | + ->where( | |
| 212 | + [ | |
| 213 | + 'status' => true, | |
| 214 | + ] | |
| 215 | + ) | |
| 216 | + ->indexBy('id') | |
| 217 | + ->column(); | |
| 221 | 218 | $payments = Payment::find() |
| 222 | - ->joinWith('lang') | |
| 223 | - ->select( | |
| 224 | - [ | |
| 225 | - 'title', | |
| 226 | - 'id', | |
| 227 | - ] | |
| 228 | - ) | |
| 229 | - ->where( | |
| 230 | - [ | |
| 231 | - 'status' => true, | |
| 232 | - ] | |
| 233 | - ) | |
| 234 | - ->indexBy('id') | |
| 235 | - ->column(); | |
| 219 | + ->joinWith('lang') | |
| 220 | + ->select( | |
| 221 | + [ | |
| 222 | + 'title', | |
| 223 | + 'id', | |
| 224 | + ] | |
| 225 | + ) | |
| 226 | + ->where( | |
| 227 | + [ | |
| 228 | + 'status' => true, | |
| 229 | + ] | |
| 230 | + ) | |
| 231 | + ->indexBy('id') | |
| 232 | + ->column(); | |
| 236 | 233 | return $this->render( |
| 237 | 234 | '@artbox/order/views/order/update', |
| 238 | 235 | [ |
| ... | ... | @@ -244,7 +241,7 @@ |
| 244 | 241 | ); |
| 245 | 242 | } |
| 246 | 243 | } |
| 247 | - | |
| 244 | + | |
| 248 | 245 | /** |
| 249 | 246 | * Deletes an existing Order model. |
| 250 | 247 | * If deletion is successful, the browser will be redirected to the 'index' page. |
| ... | ... | @@ -257,10 +254,116 @@ |
| 257 | 254 | { |
| 258 | 255 | $this->findModel($id) |
| 259 | 256 | ->delete(); |
| 260 | - | |
| 257 | + | |
| 261 | 258 | return $this->redirect([ 'index' ]); |
| 262 | 259 | } |
| 263 | - | |
| 260 | + | |
| 261 | + public function actionProductList($q = null, $id = null) | |
| 262 | + { | |
| 263 | + $response = \Yii::$app->response; | |
| 264 | + $response->format = $response::FORMAT_JSON; | |
| 265 | + $out = [ | |
| 266 | + 'results' => [ | |
| 267 | + 'id' => '', | |
| 268 | + 'text' => '', | |
| 269 | + ], | |
| 270 | + ]; | |
| 271 | + if (!is_null($q)) { | |
| 272 | + $out[ 'results' ] = []; | |
| 273 | + /** | |
| 274 | + * @var Variant[] $variants | |
| 275 | + */ | |
| 276 | + $variants = Variant::find() | |
| 277 | + ->joinWith('lang', false) | |
| 278 | + ->joinWith('product.lang', false) | |
| 279 | + ->andWhere( | |
| 280 | + [ | |
| 281 | + 'like', | |
| 282 | + 'product_lang.title', | |
| 283 | + $q, | |
| 284 | + ] | |
| 285 | + ) | |
| 286 | + ->orWhere( | |
| 287 | + [ | |
| 288 | + 'like', | |
| 289 | + 'variant_lang.title', | |
| 290 | + $q, | |
| 291 | + ] | |
| 292 | + ) | |
| 293 | + ->orWhere([ 'variant.sku' => $q ]) | |
| 294 | + ->all(); | |
| 295 | + foreach ($variants as $variant) { | |
| 296 | + $out[ 'results' ][] = [ | |
| 297 | + 'id' => $variant->id, | |
| 298 | + 'text' => $variant->product->lang->title, | |
| 299 | + ]; | |
| 300 | + } | |
| 301 | + } elseif ($id > 0) { | |
| 302 | + /** | |
| 303 | + * @var Variant $variant | |
| 304 | + */ | |
| 305 | + $variant = Variant::find() | |
| 306 | + ->with('lang', 'product.lang') | |
| 307 | + ->where([ 'id' => $id ]) | |
| 308 | + ->one(); | |
| 309 | + $out[ 'results' ] = [ | |
| 310 | + 'id' => $id, | |
| 311 | + 'text' => $variant->product->lang->title, | |
| 312 | + ]; | |
| 313 | + } | |
| 314 | + return $out; | |
| 315 | + } | |
| 316 | + | |
| 317 | + public function actionAddToOrder() | |
| 318 | + { | |
| 319 | + $id = \Yii::$app->request->post('id'); | |
| 320 | + $count = \Yii::$app->request->post('count'); | |
| 321 | + $orderId = \Yii::$app->request->post('order'); | |
| 322 | + if (empty($id) || empty($count)) { | |
| 323 | + throw new InvalidParamException(\Yii::t('order', 'Set id and count')); | |
| 324 | + } | |
| 325 | + $order = Order::find() | |
| 326 | + ->where([ 'id' => $orderId ]) | |
| 327 | + ->one(); | |
| 328 | + if (empty($order)) { | |
| 329 | + throw new NotFoundHttpException(\Yii::t('order', 'Order not found')); | |
| 330 | + } | |
| 331 | + /** | |
| 332 | + * @var Variant $variant | |
| 333 | + */ | |
| 334 | + $variant = Variant::find() | |
| 335 | + ->where([ 'id' => $id ]) | |
| 336 | + ->one(); | |
| 337 | + if (empty($variant)) { | |
| 338 | + throw new NotFoundHttpException(\Yii::t('order', 'Variant not found')); | |
| 339 | + } | |
| 340 | + /** | |
| 341 | + * @var OrderProduct $model | |
| 342 | + */ | |
| 343 | + $model = OrderProduct::find() | |
| 344 | + ->where( | |
| 345 | + [ | |
| 346 | + 'order_id' => $orderId, | |
| 347 | + 'variant_id' => $id, | |
| 348 | + ] | |
| 349 | + ) | |
| 350 | + ->one(); | |
| 351 | + if ($model) { | |
| 352 | + $model->count += $count; | |
| 353 | + } else { | |
| 354 | + $model = new OrderProduct( | |
| 355 | + [ | |
| 356 | + 'order_id' => $orderId, | |
| 357 | + 'variant_id' => $id, | |
| 358 | + 'sku' => $variant->sku, | |
| 359 | + 'price' => $variant->price, | |
| 360 | + 'count' => $count, | |
| 361 | + ] | |
| 362 | + ); | |
| 363 | + } | |
| 364 | + $model->save(); | |
| 365 | + } | |
| 366 | + | |
| 264 | 367 | /** |
| 265 | 368 | * Finds the Order model based on its primary key value. |
| 266 | 369 | * If the model is not found, a 404 HTTP exception will be thrown. | ... | ... |
models/OrderProduct.php
| ... | ... | @@ -4,6 +4,7 @@ |
| 4 | 4 | |
| 5 | 5 | use artbox\catalog\models\Variant; |
| 6 | 6 | use Yii; |
| 7 | + use yii\helpers\ArrayHelper; | |
| 7 | 8 | |
| 8 | 9 | /** |
| 9 | 10 | * This is the model class for table "order_product". |
| ... | ... | @@ -105,4 +106,74 @@ |
| 105 | 106 | { |
| 106 | 107 | return $this->hasOne(Variant::className(), [ 'id' => 'variant_id' ]); |
| 107 | 108 | } |
| 109 | + | |
| 110 | + /** | |
| 111 | + * @param array $items | |
| 112 | + * @param int $orderId | |
| 113 | + * | |
| 114 | + * @return \artbox\order\models\OrderProduct[] | |
| 115 | + */ | |
| 116 | + public static function saveItems(array $items, int $orderId): array | |
| 117 | + { | |
| 118 | + $variantIds = ArrayHelper::getColumn($items, 'variant_id', false); | |
| 119 | + /** | |
| 120 | + * @var \artbox\order\models\OrderProduct[] $deletion | |
| 121 | + */ | |
| 122 | + $deletion = self::find() | |
| 123 | + ->where( | |
| 124 | + [ | |
| 125 | + 'not', | |
| 126 | + [ 'variant_id' => $variantIds ], | |
| 127 | + ] | |
| 128 | + ) | |
| 129 | + ->andWhere([ 'order_id' => $orderId ]) | |
| 130 | + ->all(); | |
| 131 | + foreach ($deletion as $record) { | |
| 132 | + $record->delete(); | |
| 133 | + } | |
| 134 | + /** | |
| 135 | + * @var \artbox\order\models\OrderProduct[] $orderProducts | |
| 136 | + */ | |
| 137 | + $orderProducts = self::find() | |
| 138 | + ->where( | |
| 139 | + [ | |
| 140 | + 'variant_id' => $variantIds, | |
| 141 | + 'order_id' => $orderId, | |
| 142 | + ] | |
| 143 | + ) | |
| 144 | + ->all(); | |
| 145 | + $newItems = []; | |
| 146 | + foreach ($items as $item) { | |
| 147 | + $id = $item[ 'variant_id' ]; | |
| 148 | + $count = $item[ 'count' ]; | |
| 149 | + foreach ($orderProducts as $orderProduct) { | |
| 150 | + if ($orderProduct->variant_id == $id) { | |
| 151 | + $orderProduct->count = $count; | |
| 152 | + break 2; | |
| 153 | + } | |
| 154 | + } | |
| 155 | + /** | |
| 156 | + * @var Variant $variant | |
| 157 | + */ | |
| 158 | + $variant = Variant::find() | |
| 159 | + ->where([ 'id' => $id ]) | |
| 160 | + ->one(); | |
| 161 | + if ($variant) { | |
| 162 | + $newItems[] = new OrderProduct( | |
| 163 | + [ | |
| 164 | + 'order_id' => $orderId, | |
| 165 | + 'variant_id' => $id, | |
| 166 | + 'sku' => $variant->sku, | |
| 167 | + 'price' => $variant->price, | |
| 168 | + 'count' => $count, | |
| 169 | + ] | |
| 170 | + ); | |
| 171 | + } | |
| 172 | + } | |
| 173 | + $orderProducts = array_merge($orderProducts, $newItems); | |
| 174 | + foreach ($orderProducts as $orderProduct) { | |
| 175 | + $orderProduct->save(); | |
| 176 | + } | |
| 177 | + return $orderProducts; | |
| 178 | + } | |
| 108 | 179 | } | ... | ... |
views/order/_form.php
| 1 | 1 | <?php |
| 2 | 2 | |
| 3 | + use kartik\select2\Select2; | |
| 3 | 4 | use yii\bootstrap\Html; |
| 5 | + use yii\helpers\Url; | |
| 6 | + use yii\web\JsExpression; | |
| 4 | 7 | use yii\widgets\ActiveForm; |
| 5 | 8 | |
| 6 | 9 | /** |
| ... | ... | @@ -54,72 +57,129 @@ |
| 54 | 57 | if (!$model->isNewRecord) { |
| 55 | 58 | ?> |
| 56 | 59 | <div class="order-product-container"> |
| 57 | - <div class="row strong"> | |
| 58 | - <div class="col-md-4"> | |
| 60 | + <div id="order-product-pjax" style="position: relative;"> | |
| 61 | + <div class="row strong"> | |
| 62 | + <div class="col-md-4"> | |
| 63 | + <?php | |
| 64 | + echo Html::tag('strong', \Yii::t('order', 'Product')); | |
| 65 | + ?> | |
| 66 | + </div> | |
| 67 | + <div class="col-md-4"> | |
| 68 | + <?php | |
| 69 | + echo Html::tag('strong', \Yii::t('order', 'Price')); | |
| 70 | + ?> | |
| 71 | + </div> | |
| 72 | + <div class="col-md-4"> | |
| 73 | + <?php | |
| 74 | + echo Html::tag('strong', \Yii::t('order', 'Count')); | |
| 75 | + ?> | |
| 76 | + </div> | |
| 77 | + </div> | |
| 78 | + | |
| 79 | + <?php | |
| 80 | + foreach ($model->orderProducts as $index => $orderProduct) { | |
| 81 | + ?> | |
| 82 | + <div class="row row-order-product"> | |
| 83 | + <div class="col-md-4"> | |
| 84 | + <?php | |
| 85 | + echo $form->field($orderProduct, "[$index]variant_id") | |
| 86 | + ->hiddenInput() | |
| 87 | + ->label(false); | |
| 88 | + echo $orderProduct->variant->product->lang->title . '(' . $orderProduct->variant->sku . ')'; | |
| 89 | + ?> | |
| 90 | + </div> | |
| 91 | + <div class="col-md-4"> | |
| 92 | + <?php echo $orderProduct->price; ?> | |
| 93 | + </div> | |
| 94 | + <div class="col-md-3"> | |
| 95 | + <?php | |
| 96 | + echo $form->field($orderProduct, "[$index]count") | |
| 97 | + ->textInput() | |
| 98 | + ->label(false); | |
| 99 | + ?> | |
| 100 | + </div> | |
| 101 | + <div class="col-md-1"> | |
| 102 | + <?php | |
| 103 | + echo Html::a( | |
| 104 | + Html::icon( | |
| 105 | + 'trash-o', | |
| 106 | + [ | |
| 107 | + 'prefix' => 'fa fa-', | |
| 108 | + ] | |
| 109 | + ), | |
| 110 | + '#', | |
| 111 | + [ | |
| 112 | + 'class' => 'remove-order-product', | |
| 113 | + ] | |
| 114 | + ) | |
| 115 | + ?> | |
| 116 | + </div> | |
| 117 | + </div> | |
| 118 | + <?php | |
| 119 | + } | |
| 120 | + ?> | |
| 121 | + </div> | |
| 122 | + <div class="row"> | |
| 123 | + <div class="col-md-8"> | |
| 59 | 124 | <?php |
| 60 | - echo Html::tag('strong', \Yii::t('order', 'Product')); | |
| 125 | + echo Select2::widget( | |
| 126 | + [ | |
| 127 | + 'name' => 'add-to-order', | |
| 128 | + 'options' => [ | |
| 129 | + 'placeholder' => \Yii::t('order', 'Select product'), | |
| 130 | + ], | |
| 131 | + 'pluginOptions' => [ | |
| 132 | + 'allowClear' => true, | |
| 133 | + 'minimumInputLength' => 3, | |
| 134 | + 'language' => [ | |
| 135 | + 'errorLoading' => new JsExpression( | |
| 136 | + "function() {return '" . \Yii::t('order', 'Waiting for results') . "'; }" | |
| 137 | + ), | |
| 138 | + ], | |
| 139 | + 'ajax' => [ | |
| 140 | + 'url' => Url::to([ 'product-list' ]), | |
| 141 | + 'dataType' => 'json', | |
| 142 | + 'data' => new JsExpression('function(params) { return {q:params.term}; }'), | |
| 143 | + ], | |
| 144 | + 'escapeMarkup' => new JsExpression('function (markup) { return markup; }'), | |
| 145 | + 'templateResult' => new JsExpression('function(city) { return city.text; }'), | |
| 146 | + 'templateSelection' => new JsExpression('function (city) { return city.text; }'), | |
| 147 | + ], | |
| 148 | + 'id' => 'add-to-order', | |
| 149 | + ] | |
| 150 | + ); | |
| 61 | 151 | ?> |
| 62 | 152 | </div> |
| 63 | - <div class="col-md-4"> | |
| 153 | + <div class="col-md-3"> | |
| 64 | 154 | <?php |
| 65 | - echo Html::tag('strong', \Yii::t('order', 'Price')); | |
| 155 | + echo Html::textInput( | |
| 156 | + 'count-to-order', | |
| 157 | + null, | |
| 158 | + [ | |
| 159 | + 'class' => 'form-control', | |
| 160 | + 'id' => 'count-to-order', | |
| 161 | + ] | |
| 162 | + ); | |
| 66 | 163 | ?> |
| 67 | 164 | </div> |
| 68 | - <div class="col-md-4"> | |
| 165 | + <div class="col-md-1"> | |
| 69 | 166 | <?php |
| 70 | - echo Html::tag('strong', \Yii::t('order', 'Count')); | |
| 167 | + echo Html::a( | |
| 168 | + Html::icon( | |
| 169 | + 'plus-circle', | |
| 170 | + [ | |
| 171 | + 'prefix' => 'fa fa-', | |
| 172 | + ] | |
| 173 | + ), | |
| 174 | + '#', | |
| 175 | + [ | |
| 176 | + 'class' => 'variant-to-order', | |
| 177 | + 'data-id' => $model->id, | |
| 178 | + ] | |
| 179 | + ); | |
| 71 | 180 | ?> |
| 72 | 181 | </div> |
| 73 | 182 | </div> |
| 74 | - | |
| 75 | - <?php | |
| 76 | - foreach ($model->orderProducts as $index => $orderProduct) { | |
| 77 | - ?> | |
| 78 | - <div class="row row-order-product"> | |
| 79 | - <div class="col-md-4"> | |
| 80 | - <?php | |
| 81 | - echo $form->field($orderProduct, "[$index]variant_id") | |
| 82 | - ->hiddenInput() | |
| 83 | - ->label(false); | |
| 84 | - echo $orderProduct->variant->product->lang->title . '(' . $orderProduct->variant->sku . ')'; | |
| 85 | - ?> | |
| 86 | - </div> | |
| 87 | - <div class="col-md-4"> | |
| 88 | - <?php echo $orderProduct->price; ?> | |
| 89 | - </div> | |
| 90 | - <div class="col-md-3"> | |
| 91 | - <?php | |
| 92 | - echo $form->field($orderProduct, "[$index]count") | |
| 93 | - ->textInput() | |
| 94 | - ->label(false); | |
| 95 | - ?> | |
| 96 | - </div> | |
| 97 | - <div class="col-md-1"> | |
| 98 | - <?php | |
| 99 | - echo Html::a( | |
| 100 | - Html::icon( | |
| 101 | - 'trash-o', | |
| 102 | - [ | |
| 103 | - 'prefix' => 'fa fa-', | |
| 104 | - ] | |
| 105 | - ), | |
| 106 | - '#', | |
| 107 | - [ | |
| 108 | - 'class' => 'remove-order-product', | |
| 109 | - ] | |
| 110 | - ) | |
| 111 | - ?> | |
| 112 | - </div> | |
| 113 | - </div> | |
| 114 | - <?php | |
| 115 | - } | |
| 116 | - ?> | |
| 117 | - <div class="row"> | |
| 118 | - <div class="col-md-8"> | |
| 119 | - </div> | |
| 120 | - <div class="col-md-4"> | |
| 121 | - </div> | |
| 122 | - </div> | |
| 123 | 183 | </div> |
| 124 | 184 | <?php |
| 125 | 185 | } | ... | ... |
web/js/order.js
| ... | ... | @@ -6,4 +6,34 @@ $(function() { |
| 6 | 6 | .parents('.row-order-product') |
| 7 | 7 | .remove(); |
| 8 | 8 | }); |
| 9 | -}); | |
| 10 | 9 | \ No newline at end of file |
| 10 | + $(document) | |
| 11 | + .on('click', '.variant-to-order', function(e) { | |
| 12 | + e.preventDefault(); | |
| 13 | + var id = $('#add-to-order'); | |
| 14 | + var count = $('#count-to-order'); | |
| 15 | + var order = $(this) | |
| 16 | + .data('id'); | |
| 17 | + if (id.val() && count.val()) { | |
| 18 | + var selector = '#order-product-pjax'; | |
| 19 | + showLoader(selector); | |
| 20 | + $.post('/admin/order/add-to-order', { | |
| 21 | + id: id.val(), | |
| 22 | + count: count.val(), | |
| 23 | + order: order | |
| 24 | + }, function() { | |
| 25 | + $.pjax.reload(selector, { | |
| 26 | + timeout: 5000, | |
| 27 | + fragment: selector | |
| 28 | + }); | |
| 29 | + }); | |
| 30 | + id.val(null) | |
| 31 | + .trigger('change'); | |
| 32 | + count.val(null) | |
| 33 | + .trigger('change'); | |
| 34 | + } | |
| 35 | + }); | |
| 36 | +}); | |
| 37 | +function showLoader(container) { | |
| 38 | + $(container) | |
| 39 | + .prepend('<div class="loader-wrapper"></div>'); | |
| 40 | +} | |
| 11 | 41 | \ No newline at end of file | ... | ... |