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.');
     }
 }
Beispiel #4
0
 /**
  * @return \yii\db\ActiveQuery
  */
 public function getIdPriceCategory()
 {
     return $this->hasOne(PriceCategory::className(), ['id_price_category' => 'id_price_category']);
 }
Beispiel #5
0
 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;
 }
Beispiel #6
0
 /**
  * @return \yii\db\ActiveQuery
  */
 public function getIdPriceCategories()
 {
     return $this->hasMany(PriceCategory::className(), ['id_price_category' => 'id_price_category'])->viaTable('price', ['id_product' => 'id_product']);
 }