/** * 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); }