/**
  * Creates a new ComercioProducto model.
  * If creation is successful, the browser will be redirected to the 'view' page.
  * @return mixed
  */
 public function actionCreate()
 {
     $model = new ComercioProducto();
     if ($model->load(Yii::$app->request->post()) && $model->save()) {
         return $this->redirect(['view', 'id' => $model->id]);
     } else {
         return $this->render('create', ['model' => $model]);
     }
 }
 /**
  * Creates data provider instance with search query applied
  *
  * @param array $params
  *
  * @return ActiveDataProvider
  */
 public function search($params)
 {
     $query = ComercioProducto::find();
     $dataProvider = new ActiveDataProvider(['query' => $query]);
     $this->load($params);
     if (!$this->validate()) {
         // uncomment the following line if you do not want to return any records when validation fails
         // $query->where('0=1');
         return $dataProvider;
     }
     $query->andFilterWhere(['id' => $this->id, 'fecha' => $this->fecha, 'vendidos' => $this->vendidos, 'id_comercio' => $this->id_comercio, 'id_producto' => $this->id_producto]);
     return $dataProvider;
 }
 public function cargarArrayVentas($id)
 {
     $productosDelComercio = ComercioProductosRelacionados::find()->where(['id_comercio' => $id])->all();
     $ventasGenerales = [];
     $respuesta = [];
     $i = 0;
     foreach ($productosDelComercio as $prod) {
         $ventas = ComercioProducto::find()->where(['id_producto' => $prod->id_producto])->all();
         $cantidad = 0;
         foreach ($ventas as $venta) {
             $cantidad = $cantidad + $venta->vendidos;
         }
         $row = ['id_producto' => $prod->id_producto, 'cantidad' => $cantidad];
         $ventasGenerales[$prod->id_producto] = $row;
         $i++;
     }
     foreach ($ventasGenerales as $venta) {
         $respuesta = $this->actualizarMasVendidos($respuesta, $venta);
     }
     return $respuesta;
 }
 /**
  * @return \yii\db\ActiveQuery
  */
 public function getComercioProductos()
 {
     return $this->hasMany(ComercioProducto::className(), ['id_producto' => 'id']);
 }
 public function actionStock()
 {
     $params = Yii::$app->getRequest()->post();
     $user = User::findIdentityByAccessToken($params['muli_token']);
     $valid = false;
     //return $params;
     $arrayStock = $params['stock'];
     foreach ($arrayStock as $stockEnv) {
         $rutaDiaria = RutaDiaria::find()->where(['id_usuario' => $user->id])->andWhere(['fecha' => date('Y-m-d')])->one();
         $rutaDiariaComercio = RutaDiariaComercio::find()->where(['id_comercio' => $params['id_comercio']])->andWhere(['id_ruta_diaria' => $rutaDiaria->id])->one();
         $stockIdProd = Stock::find()->where(['id_producto' => $stockEnv['id_producto']])->andWhere(['id_ruta_diaria_com' => $rutaDiariaComercio->id])->one();
         if ($stockIdProd != null) {
             $stock = $stockIdProd;
             $stock->setAttribute('cantidad', $stockEnv['cant']);
         } else {
             $stock = new Stock();
             $stock->setAttribute('id_ruta_diaria_com', $rutaDiariaComercio->id);
             $stock->setAttribute('id_producto', $stockEnv['id_producto']);
             $stock->setAttribute('cantidad', $stockEnv['cant']);
         }
         if ($stock->cantidad != 0) {
             if ($stock->validate()) {
                 if ($stockIdProd != null) {
                     //es un update del Stock, podemos haber realizado ya el calculo de la venta.
                     $rutaDiariaComercioFecha = RutaDiariaComercio::find()->where('ruta_diaria_comercio.id !=' . $rutaDiariaComercio->id)->andWhere('ruta_diaria_comercio.id_ruta_diaria!=' . $rutaDiariaComercio->id_ruta_diaria)->andWhere(['ruta_diaria_comercio.id_comercio' => $rutaDiariaComercio->id_comercio])->joinWith(['idRutaDiaria' => function ($query) {
                         //$query->where('MAX(ruta_diaria.fecha)');
                         $query->groupBy('ruta_diaria.id')->having('MAX(ruta_diaria.fecha)')->orderBy('fecha DESC');
                     }])->one();
                     $stockAnterior = Stock::find()->where(['id_producto' => $stock->id_producto])->andWhere(['id_ruta_diaria_com' => $rutaDiariaComercioFecha->id])->one();
                     $pedidoAnterior = Pedido::find()->where(['id_producto' => $stock->id_producto])->andWhere(['id_ruta_diaria_com' => $rutaDiariaComercioFecha->id])->one();
                     if ($stockAnterior != null) {
                         $vendidos = $stockAnterior->cantidad - $stock->cantidad;
                         if ($pedidoAnterior != null) {
                             $vendidos = $vendidos + $pedidoAnterior->cantidad;
                         }
                         $compraProducto = ComercioProducto::find()->where(['id_comercio' => $params['id_comercio']])->andWhere(['id_producto' => $stock->id_producto])->andWhere(['fecha' => date('Y-m-d')])->one();
                         $compraProducto->setAttribute('vendidos', $vendidos);
                         $compraProducto->save();
                     }
                 } else {
                     $rutaDiariaComercioFecha = RutaDiariaComercio::find()->where('ruta_diaria_comercio.id !=' . $rutaDiariaComercio->id)->andWhere('ruta_diaria_comercio.id_ruta_diaria!=' . $rutaDiariaComercio->id_ruta_diaria)->andWhere(['ruta_diaria_comercio.id_comercio' => $rutaDiariaComercio->id_comercio])->joinWith(['idRutaDiaria' => function ($query) {
                         //$query->where('MAX(ruta_diaria.fecha)');
                         $query->groupBy('ruta_diaria.id')->having('MAX(ruta_diaria.fecha)')->orderBy('fecha DESC');
                     }])->one();
                     if ($rutaDiariaComercioFecha != null) {
                         //return "existe?:".$stock->id_producto;
                         $stockAnterior = Stock::find()->where(['id_producto' => $stock->id_producto])->andWhere(['id_ruta_diaria_com' => $rutaDiariaComercioFecha->id])->one();
                         $pedidoAnterior = Pedido::find()->where(['id_producto' => $stock->id_producto])->andWhere(['id_ruta_diaria_com' => $rutaDiariaComercioFecha->id])->one();
                         if ($stockAnterior != null) {
                             $vendidos = $stockAnterior->cantidad - $stock->cantidad;
                             if ($pedidoAnterior != null) {
                                 $vendidos = $vendidos + $pedidoAnterior->cantidad;
                             }
                             $compraProducto = new ComercioProducto();
                             $compraProducto->setAttribute('vendidos', $vendidos);
                             $compraProducto->setAttribute('id_comercio', $params['id_comercio']);
                             $compraProducto->setAttribute('id_producto', $stock->id_producto);
                             $compraProducto->setAttribute('fecha', date('Y-m-d'));
                             $compraProducto->save();
                         }
                     }
                 }
                 if ($stock->save()) {
                     $valid = true;
                 } else {
                     $valid = false;
                 }
             } else {
                 throw new BadRequestHttpException(Yii::t('mobile', 'Failed to save orders data...'));
             }
         } else {
             if ($stock->validate()) {
                 $valid = true;
             } else {
                 throw new BadRequestHttpException(Yii::t('mobile', 'Failed to save orders data...'));
             }
         }
     }
     return $valid;
 }