Exemplo n.º 1
0
 /**
  * Devuelve un array con los artículos que forman
  * parte del escandallo del articulo actual
  * 
  * array('IDArticulo'=>,'Codigo'=>,'Descripcion'=>,'Unidades'=>,'UMV'=>)
  * 
  * @return array \Articulos
  */
 public function getEscandallo()
 {
     $escan = new ArticulosEscandallos();
     $filtro = "IDArticuloOrigen='{$this->IDArticulo}' and IDArticuloDestino<>'0'";
     $rows = $escan->cargaCondicion("IDArticuloDestino,Unidades", $filtro, "Id ASC");
     unset($escan);
     $array = array();
     foreach ($rows as $row) {
         $articulo = new Articulos($row['IDArticuloDestino']);
         $array[] = array('IDArticulo' => $articulo->getIDArticulo(), 'Codigo' => $articulo->getCodigo(), 'Descripcion' => $articulo->getDescripcion(), 'Unidades' => $row['Unidades'], 'UMV' => $articulo->getUMV()->getUnidadMedida());
         unset($articulo);
     }
     return $array;
 }
 /**
  * Recalcular el escandallo y actualiza los precios
  * en el articulo padre (origen)
  * 
  * @param inter $idArticuloOrigen
  */
 private function recalcular($idArticuloOrigen)
 {
     $escan = new ArticulosEscandallos();
     $totales = $escan->cargaCondicion("sum(Unidades) as Unidades,sum(ImporteCosto) as Costo,sum(ImporteVenta) as Venta,sum(Peso) as Peso,sum(Volumen) as Volumen", "IDArticuloOrigen='{$idArticuloOrigen}' and IDArticuloDestino>0 GROUP BY IDArticuloOrigen");
     $totales = $totales[0];
     unset($escan);
     // Borrar la fila de totalización y volverla a crear
     $escan = new ArticulosEscandallos();
     $escan->queryDelete("IDArticuloOrigen='{$idArticuloOrigen}' and IDArticuloDestino='0'");
     $escan = new ArticulosEscandallos();
     $escan->setIDArticuloOrigen($idArticuloOrigen);
     $escan->setIDArticuloDestino(0);
     $escan->setUnidades($totales['Unidades']);
     $escan->setImporteCosto($totales['Costo']);
     $escan->setImporteVenta($totales['Venta']);
     $escan->setPeso($totales['Peso']);
     $escan->setVolumen($totales['Volumen']);
     $escan->create();
     unset($escan);
     // Actualizar el artículo padre
     // Leo el parametro 'ACTU_PRECIOS' para ver el comportamiento a seguir
     // en el cambio de precio de venta o margen. Si no estuviera definido,
     // se respeta el PVP a costa del MARGEN
     $parametro = $_SESSION['usuarioPortal']['actuPrecios'];
     if ($parametro != 'MARGEN' and $parametro != 'PVP') {
         $parametro = 'MARGEN';
     }
     $articulo = new Articulos($idArticuloOrigen);
     // Calculo el nuevo margen o el nuevo precio de venta (según el parámetro) sobre el PRECIO MEDIO DE COSTO
     $articulo->setPvd($totales['Costo']);
     $articulo->setPvp($totales['Venta']);
     if ($articulo->getPmc() == 0) {
         $articulo->setPmc($articulo->getPvd());
     }
     if ($articulo->getPmc() != 0) {
         $articulo->setMargen(100 * ($articulo->getPvp() / $articulo->getPmc() - 1));
     } else {
         $articulo->setMargen(0);
     }
     $articulo->setFechaUltimoPrecio(date('Y-m-d H:i:s'));
     $articulo->save();
     unset($articulo);
 }