/** * GENERA LOS ALBARANES Y FACTURAS DE MANTENIMIENTOS * EN BASE A LOS INDICADO EN EL ARCHIVO CSV * * @param string $fileCsv */ public function mantenimientosAction($fileCsv = '') { if ($fileCsv == '') { $fileCsv = 'tmp/mantenimientos.csv'; } $archivo = new Archivo($fileCsv); $archivo->setColumnsDelimiter(";"); if ($archivo->open()) { while (($linea = $archivo->readLine()) !== FALSE) { $idSucursal = $linea[0]; $idAlmacen = $linea[1]; $idComercial = $linea[2]; $idCliente = $linea[3]; $codigoArticulo = $linea[4]; $unidades = $linea[5]; $precio = $linea[6]; $cliente = new Clientes($idCliente); $direccionesEntrega = $cliente->getDireccionesEntrega(); $direcEntrega = $direccionesEntrega[0]; $albaran = new AlbaranesCab(); $albaran->setIDCliente($cliente->getIDCliente()); $albaran->setIDSucursal($idSucursal); $albaran->setFecha(date("d-m-Y")); $albaran->setIDDirec($direcEntrega->getIDDirec()); $albaran->setIDAlmacen($idAlmacen); $albaran->setIDComercial($idComercial); $albaran->setIDContador(2); $albaran->setIDEstado(0); $albaran->setIDFP($cliente->getIDFP()->getIDFP()); $idAlbaran = $albaran->create(); if ($idAlbaran) { $articulo = new Articulos(); $articulo = $articulo->find("Codigo", $codigoArticulo); $lineas = new AlbaranesLineas(); $lineas->setIDAlbaran($idAlbaran); $lineas->setIDArticulo($articulo->getIDArticulo()); $lineas->setDescripcion($articulo->getDescripcion() . " Mes " . date("m Y")); $lineas->setUnidades($unidades); $lineas->setPrecio($precio); $lineas->setDescuento(0); $lineas->setIva($articulo->getIDIva()->getIva()); $lineas->setImporte($unidades * $precio); $ok = $lineas->create(); if ($ok) { $albaran = new AlbaranesCab($idAlbaran); $albaran->confirma(); if ($albaran->expide()) { $albaran = new AlbaranesCab($idAlbaran); $contador = new Contadores(); $contador = $contador->dameContador($idSucursal, 2); $albaran->facturar($contador); } } else { print_r($lineas->getErrores()); exit; } } else { $this->values['errores'][] = "No se ha podido crear el albarán para " . $cliente->getRazonSocial(); } } } else { $this->values['errores'][] = "El fichero de importación " . $fileCsv . " no existe"; } }
} $linea = new AlbaranesLineas($datos['IDLinea']); $linea->bind($datos); if ($linea->valida(array())) { if (!$linea->save()) { $errores = $linea->getErrores(); } else { $alertas = $linea->getAlertas(); $linea = new AlbaranesLineas($datos['IDLinea']); } } break; case 'cierre': include_once '../modules/ExpedirLineas/ExpedirLineasController.class.php'; $albaran = new AlbaranesCab($datos['IDAlbaran']); $albaran->confirma(); $expedir = new ExpedirLineasController(); $expedir->cargaLineasAlbaran($datos['IDAlbaran'], 0); //$albaran->expide(); break; } $albaran = new AlbaranesCab($datos['IDAlbaran']); $lineaAlbaran = $linea->iterator(); $lineaAlbaran['Codigo'] = $linea->getIDArticulo()->getCodigo(); $status = 'ok'; if (count($errores)) { $status = "error"; } if (count($alertas)) { $status = "alerta"; }
/** * Confirma el presupuesto, que consiste en aprobarlo * y generar un albaran en base al mismo. * Devuelve el id del albaran generado * IMPORTANTE: APLICA LA TARIFA Y PROMOCIONES VIGENTES * * @return integer El id del albaran generado */ public function confirma() { //Crear cabecera de albaran. //No pongo los totales porque los recalculo una vez //creadas las lineas del albaran. $contador = new Contadores(); $albaran = new AlbaranesCab(); $albaran->setIDSucursal($this->IDSucursal); $albaran->setIDContador($contador->dameContador($this->IDSucursal, 1)); $albaran->setIDAlmacen($this->IDAlmacen); $albaran->setIDAgente($_SESSION['usuarioPortal']['Id']); $albaran->setIDComercial($this->IDComercial); $albaran->setFecha(date('d-m-Y')); $albaran->setIDCliente($this->IDCliente); $albaran->setIDDirec($this->IDDirec); $albaran->setDescuento($this->Descuento); $albaran->setObservaciones($this->Observaciones . "Proviene del Psto N. " . $this->NumeroPsto); $albaran->setIDAgencia($this->IDAgencia); $albaran->setIDFP($this->IDFP); $albaran->setIDPsto($this->IDPsto); $idAlbaran = $albaran->create(); unset($contador); if ($idAlbaran) { // Marco el presupuesto como confirmado (Estado=1) $this->setIDEstado(1); $this->setIDAlbaran($idAlbaran); $this->setFechaAceptacion(date('d-m-Y')); $this->save(); // Crear las lineas de albaran $lineas = new PstoLineas(); $rows = $lineas->cargaCondicion('*', "IDPsto='{$this->IDPsto}'", "IDLinea ASC"); unset($lineas); foreach ($rows as $row) { $linea = new AlbaranesLineas(); $linea->setIDAlbaran($idAlbaran); $linea->setIDArticulo($row['IDArticulo']); $linea->setDescripcion($row['Descripcion']); $linea->setUnidades($row['Unidades']); $linea->setPrecio($row['Precio']); $linea->setDescuento($row['Descuento']); $linea->setImporte($row['Importe']); $linea->setImporteCosto($row['ImporteCosto']); $linea->setIDAlmacen($this->IDAlmacen); $linea->setIva($row['Iva']); $linea->setRecargo($row['Recargo']); $linea->setIDAgente($_SESSION['usuarioPortal']['Id']); $linea->setIDComercial($this->IDComercial); $linea->setAltoAl($row['AltoAl']); $linea->setAnchoAl($row['AnchoAl']); $linea->setIDEstado(0); if ($linea->valida()) { $linea->create(); // Marco la línea de psto como confirmado (Estado=1) $lineaPsto = new PstoLineas($row['IDLinea']); $lineaPsto->setIDEstado(1); $lineaPsto->save(); unset($lineaPsto); } } // Recalcular el albarán $albaran->recalcula(); $albaran->save(); // Confirmar el albarán $albaran->confirma(); $this->_alertas[] = "Se ha generado el albarán n. " . $albaran->getNumeroAlbaran(); } else { $this->_alertas[] = "No se ha generado albarán"; } return $idAlbaran; }