/** * Anula la confirmacion de la orden de traspaso, que consiste en: * * 1.- Quitar la reserva de mercancia en el registro de existencias sin indicar lote ni ubicacion * solo para aquellos artículos que estén sujetos a inventario * 2.- Poner la cabecera de la orden de traspaso y sus lineas en estado PTE. DE CONFIRMAR (0) * */ public function anulaConfirmacion() { // Si está confirmado if ($this->getIDEstado()->getIDTipo() == 1) { $em = new EntityManager($this->getConectionName()); $query = "SELECT t1.IDArticulo, t1.IDAlmacen, t1.Unidades, t1.UnidadMedida\n FROM {$this->_dataBaseName}.ErpTraspasosLineas as t1, ErpArticulos as t2\n WHERE t1.IDTraspaso='{$this->IDTraspaso}'\n AND t1.Tipo='0'\n AND t1.IDEstado='1'\n AND t1.IDArticulo=t2.IDArticulo\n AND t2.Inventario='1'"; $em->query($query); $rows = $em->fetchResult(); $em->desConecta(); // Quitar las reservas $exi = new Existencias(); foreach ($rows as $row) { $exi->quitaReserva($row['IDAlmacen'], $row['IDArticulo'], $row['Unidades'], $row['UnidadMedida']); } unset($exi); // Poner en estado de PTE DE CONFIRMAR las líneas de la orden de traspaso de tipo 0 (salida) $lineas = new TraspasosLineas(); $lineas->queryUpdate(array("IDEstado" => 0), "IDTraspaso='{$this->IDTraspaso}' and IDEstado='1' and Tipo='0'"); unset($lineas); // Borrar las eventuales lineas de expedicion $expediciones = new Expediciones(); $expediciones->queryDelete("Entidad='TraspasosCab' and IDEntidad='{$this->IDTraspaso}'"); unset($expediciones); // Anular la reserva en la cabecera de la orden de traspaso $this->setIDEstado(0); $this->save(); } }
/** * Expide la linea de elaboracion de tipo 0 (la de envío) * Actualiza las existencias y marca la línea como expedida. * * NO SE REALIZA NINGUN TRATAMIENTO CON LAS EXISTENCIAS SI EL ARTICULO NO ES INVENTARIABLE * * @return boolean */ public function expide() { $ok = true; $articulo = new Articulos($this->IDArticulo); $esInventariable = $articulo->getInventario()->getIDTipo(); if ($esInventariable) { // Quitar la reserva de mercancía $exi = new Existencias(); $ok = $exi->quitaReserva($this->IDAlmacen, $this->IDArticulo, $this->Unidades, $this->UnidadMedida); unset($exi); } if ($esInventariable and $ok) { // Expedir la línea de elaboración $expedicion = new Expediciones(); $unidadesNetas = $expedicion->expide("ManufacCab", $this->IDLinea); unset($expedicion); } else { $unidadesNetas = $this->Unidades; } if ($ok) { // Marcar la línea de elaboracion como expedida y // poner las unidades netas expedidas $this->setIDEstado(2); $this->setUnidades($unidadesNetas); $this->totalizaLinea(); $this->save(); } unset($articulo); return $ok; }
/** * Expide la linea de traspaso de tipo 0 (la de envío) * Actualiza las existencias y marca la línea como expedida. * Genera la línea de traspaso de tipo 1 (la de entrada) poniendo el 'entrando' y * generar tantas líneas de recepción como líneas de expedición se hayan generado * para mantener las mismas unidades y lotes * * NO SE REALIZA NINGUN TRATAMIENTO CON LAS EXISTENCIAS SI EL ARTICULO NO ES INVENTARIABLE * * @return boolean */ public function expide() { $ok = true; $articulo = new Articulos($this->IDArticulo); $esInventariable = $articulo->getInventario()->getIDTipo(); if ($esInventariable) { // Quitar la reserva de mercancía $exi = new Existencias(); $ok = $exi->quitaReserva($this->IDAlmacen, $this->IDArticulo, $this->Unidades, $this->UnidadMedida); unset($exi); } if ($esInventariable and $ok) { // Expedir la línea de traspaso $expedicion = new Expediciones(); $unidadesNetas = $expedicion->expide("TraspasosCab", $this->IDLinea); unset($expedicion); } else { $unidadesNetas = $this->Unidades; } if ($ok) { // Marcar la línea de traspaso como expedida y // poner las unidades netas expedidas $this->setIDEstado(2); $this->setUnidades($unidadesNetas); $this->totalizaLinea(); $this->save(); // Generar la línea de traspaso de tipo 1 (la de entrada) y poner el entrando $idAlmacenDestino = $this->getIDTraspaso()->getIDAlmacenDestino()->getIDAlmacen(); $lineaEntrada = new TraspasosLineas(); $lineaEntrada->setIDLinea(''); $lineaEntrada->setIDTraspaso($this->IDTraspaso); $lineaEntrada->setTipo(1); $lineaEntrada->setIDArticulo($this->IDArticulo); $lineaEntrada->setDescripcion($this->Descripcion); $lineaEntrada->setUnidades($this->Unidades); $lineaEntrada->setUnidadMedida($this->UnidadMedida); $lineaEntrada->setIDAlmacen($idAlmacenDestino); $lineaEntrada->setPrecio($this->Precio); $lineaEntrada->setImporte($this->Importe); $lineaEntrada->setIDEstado(0); $idLineaEntrada = $lineaEntrada->create(); unset($lineaEntrada); // Generar tantas líneas de recepción como líneas de expedición haya para // la línea de traspaso expedida $expedicion = new Expediciones(); $rows = $expedicion->cargaCondicion("*", "Entidad='TraspasosCab' and IDLineaEntidad='{$this->IDLinea}'"); unset($expedicion); foreach ($rows as $row) { $recepcion = new Recepciones(); $recepcion->setEntidad($row['Entidad']); $recepcion->setIDEntidad($row['IDEntidad']); $recepcion->setIDLineaEntidad($idLineaEntrada); $recepcion->setIDAlmacen($idAlmacenDestino); $recepcion->setIDAlmacenero($_SESSION['usuarioPortal']['Id']); $recepcion->setIDArticulo($row['IDArticulo']); $recepcion->setUnidades($row['Unidades']); $recepcion->setUnidadMedida($row['UnidadMedida']); $recepcion->setUnidadesBrutas($row['Unidades']); $recepcion->setUnidadesNetas($row['Unidades']); $recepcion->setIDLote($row['IDLote']); $recepcion->create(); unset($recepcion); } // Poner el entrando $exi = new Existencias(); $ok = $exi->hazEntrando($idAlmacenDestino, $this->IDArticulo, $this->getUnidades(), $this->getUnidadMedida()); unset($exi); } unset($articulo); return $ok; }