protected function updatePrice($params) { $categories = PriceCategory::find()->all(); foreach ($categories as $category) { $price = Price::findOne(['id_product' => $params['id_product'], 'id_price_category' => $category->id_price_category]); if (!$price) { $price = new Price(); $price->setAttributes(['id_product' => $params['id_product'], 'id_price_category' => $category->id_price_category, 'id_uom' => $params['id_uom'], 'price' => 0]); } if ($price->canSetProperty('logParams')) { $logParams = []; foreach (['app', 'id_ref'] as $key) { if (isset($params[$key]) || array_key_exists($key, $params)) { $logParams[$key] = $params[$key]; } } $price->logParams = $logParams; } $price->price = $this->executePriceFormula($category->formula, $params['price']); if (!$price->save()) { throw new UserException(implode(",\n", $price->firstErrors)); } } return true; }
public function search($params) { $query = PriceCategoryModel::find(); $dataProvider = new ActiveDataProvider(['query' => $query]); if (!($this->load($params) && $this->validate())) { return $dataProvider; } $query->andFilterWhere(['id_price_category' => $this->id_price_category, 'create_by' => $this->create_by, 'update_by' => $this->update_by]); $query->andFilterWhere(['like', 'nm_price_category', $this->nm_price_category])->andFilterWhere(['like', 'formula', $this->formula])->andFilterWhere(['like', 'update_date', $this->update_date])->andFilterWhere(['like', 'create_date', $this->create_date]); return $dataProvider; }
/** * Finds the PriceCategory model based on its primary key value. * If the model is not found, a 404 HTTP exception will be thrown. * @param integer $id * @return PriceCategory the loaded model * @throws NotFoundHttpException if the model cannot be found */ protected function findModel($id) { if (($model = PriceCategory::findOne($id)) !== null) { return $model; } else { throw new NotFoundHttpException('The requested page does not exist.'); } }
/** * @return \yii\db\ActiveQuery */ public function getIdPriceCategory() { return $this->hasOne(PriceCategory::className(), ['id_price_category' => 'id_price_category']); }
public static function updatePrice($params, $logs = []) { $categories = PriceCategory::find()->all(); foreach ($categories as $category) { $price = Price::findOne(['id_product' => $params['id_product'], 'id_price_category' => $category->id_price_category]); if (!$price) { $price = new Price(); $price->setAttributes(['id_product' => $params['id_product'], 'id_price_category' => $category->id_price_category, 'id_uom' => $params['id_uom'], 'price' => 0]); } if (!empty($logs) && $price->canSetProperty('logParams')) { $price->logParams = $logs; } $price->price = self::executePriceFormula($category->formula, $params['price']); if (!$price->save()) { throw new UserException(implode(",\n", $price->firstErrors)); } } return true; }
/** * @return \yii\db\ActiveQuery */ public function getIdPriceCategories() { return $this->hasMany(PriceCategory::className(), ['id_price_category' => 'id_price_category'])->viaTable('price', ['id_product' => 'id_product']); }