[ 'class' => VerbFilter::className(), 'actions' => [ 'delete' => [ 'POST' ], ], ], ]; } /** * Lists all ProductVariant models. * * @param int $product_id * * @return mixed */ public function actionIndex($product_id) { $product = $this->findProduct($product_id); $searchModel = new ProductVariantSearch(); $dataProvider = $searchModel->search(Yii::$app->request->queryParams); /** * @var ActiveQuery $query */ $query = $dataProvider->query; $query->with('image') ->andWhere([ 'product_id' => $product->id ]); return $this->render( 'index', [ 'searchModel' => $searchModel, 'dataProvider' => $dataProvider, 'product' => $product, ] ); } /** * Displays a single ProductVariant model. * * @param integer $id * * @return mixed */ public function actionView($id) { $model = $this->findModel($id); $properties = $model->getProperties(); return $this->render( 'view', [ 'model' => $model, 'properties' => $properties, ] ); } /** * Creates a new ProductVariant model. * If creation is successful, the browser will be redirected to the 'view' page. * * @param int $product_id * * @return mixed */ public function actionCreate($product_id) { $product = $this->findProduct($product_id); $model = new ProductVariant(); $model->product_id = $product->id; $model->generateLangs(); if ($model->load(Yii::$app->request->post())) { $model->loadLangs(\Yii::$app->request); if ($model->save() && $model->transactionStatus) { $ProductStocks = Yii::$app->request->post('ProductStock'); $total_quantity = 0; if (!empty( $ProductStocks ) && is_array($ProductStocks)) { $model->unlinkAll('stocks', true); $sorted_array = []; foreach ($ProductStocks as $subArray) { if (!empty( $subArray[ 'title' ] ) && !empty( $subArray[ 'quantity' ] )) { if (!empty( $sorted_array[ $subArray[ 'title' ] ] )) { $sorted_array[ $subArray[ 'title' ] ] += $subArray[ 'quantity' ]; } else { $sorted_array[ $subArray[ 'title' ] ] = $subArray[ 'quantity' ]; } } } $ProductStocks = $sorted_array; $stock_names = array_keys($ProductStocks); $stocks = Stock::find() ->where([ 'title' => $stock_names ]) ->indexBy('title') ->all(); foreach ($ProductStocks as $name => $quantity) { $quantity = (int) $quantity; if (!array_key_exists($name, $stocks)) { $stock = new Stock( [ 'title' => $name, ] ); if (!$stock->save()) { continue; } } else { $stock = $stocks[ $name ]; } $psModel = new ProductStock( [ 'product_variant_id' => $model->id, 'stock_id' => $stock->id, 'quantity' => $quantity, ] ); if ($psModel->save()) { $total_quantity += $quantity; } } } else { $model->unlinkAll('stocks', true); } $model->stock = $total_quantity; if ($model->save() && $model->transactionStatus) { return $this->redirect( [ 'index', 'product_id' => $product->id, ] ); } } } $groups = $model->getTaxGroupsByLevel(1); return $this->render( 'create', [ 'model' => $model, 'modelLangs' => $model->modelLangs, 'groups' => $groups, 'stocks' => [ new ProductStock() ], 'product' => $product, ] ); } /** * Updates an existing ProductVariant model. * If update is successful, the browser will be redirected to the 'view' page. * * @param integer $product_id * @param integer $id * * @return mixed */ public function actionUpdate($product_id, $id) { $product = $this->findProduct($product_id); $model = $this->findModel($id); $model->generateLangs(); if ($model->load(Yii::$app->request->post())) { $model->loadLangs(\Yii::$app->request); if ($model->save() && $model->transactionStatus) { $ProductStocks = Yii::$app->request->post('ProductStock'); $total_quantity = 0; if (!empty( $ProductStocks ) && is_array($ProductStocks)) { $model->unlinkAll('stocks', true); $sorted_array = []; foreach ($ProductStocks as $subArray) { if (!empty( $subArray[ 'title' ] ) && !empty( $subArray[ 'quantity' ] )) { if (!empty( $sorted_array[ $subArray[ 'title' ] ] )) { $sorted_array[ $subArray[ 'title' ] ] += $subArray[ 'quantity' ]; } else { $sorted_array[ $subArray[ 'title' ] ] = $subArray[ 'quantity' ]; } } } $ProductStocks = $sorted_array; $stock_names = array_keys($ProductStocks); $stocks = Stock::find() ->where([ 'title' => $stock_names ]) ->indexBy('title') ->all(); foreach ($ProductStocks as $name => $quantity) { $quantity = (int) $quantity; if (!array_key_exists($name, $stocks)) { $stock = new Stock( [ 'title' => $name, ] ); if (!$stock->save()) { continue; } } else { $stock = $stocks[ $name ]; } $psModel = new ProductStock( [ 'product_variant_id' => $model->id, 'stock_id' => $stock->id, 'quantity' => $quantity, ] ); if ($psModel->save()) { $total_quantity += $quantity; } } } else { $model->unlinkAll('stocks', true); } $model->stock = $total_quantity; if ($model->save() && $model->transactionStatus) { return $this->redirect( [ 'index', 'product_id' => $product_id, ] ); } } } $groups = $model->getTaxGroupsByLevel(1); return $this->render( 'update', [ 'model' => $model, 'modelLangs' => $model->modelLangs, 'groups' => $groups, 'stocks' => ( !empty( $model->variantStocks ) ) ? $model->variantStocks : [ new ProductStock ], 'product' => $product, ] ); } /** * Deletes an existing ProductVariant model. * If deletion is successful, the browser will be redirected to the 'index' page. * * @param integer $product_id * @param integer $id * * @return mixed */ public function actionDelete($product_id, $id) { $this->findModel($id) ->delete(); return $this->redirect( [ 'index', 'product_id' => $product_id, ] ); } public function actionDelimg($id) { $image = ProductImage::findOne($id); if ($image) { $image->delete(); } print '1'; exit; } /** * Finds the ProductVariant model based on its primary key value. * If the model is not found, a 404 HTTP exception will be thrown. * * @param integer $id * * @return ProductVariant the loaded model * @throws NotFoundHttpException if the model cannot be found */ protected function findModel($id) { if (( $model = ProductVariant::find() ->where([ 'id' => $id ]) ->with('lang') ->one() ) !== null ) { return $model; } else { throw new NotFoundHttpException('The requested page does not exist.'); } } /** * @param int $product_id * * @return Product * @throws NotFoundHttpException */ protected function findProduct($product_id) { if (( $model = Product::find() ->with('lang') ->where([ 'id' => $product_id ]) ->one() ) !== null ) { return $model; } else { throw new NotFoundHttpException('The requested page does not exist.'); } } }