/** * Cambia de estado al conjunto de recibos recibidos * * Actualiza su estado, la fecha de vencimiento y la cuenta contable * Además genera apunte de caja si procede * * @return array */ public function CobrarAction() { if ($this->values['permisos']['permisosModulo']['UP']) { $formaPago = new FormasPago($this->request['idFP']); $anotarEnCaja = $formaPago->getAnotarEnCaja()->getIDTipo() == '1'; $estadoRecibo = $formaPago->getEstadoRecibo()->getIDTipo(); $cContable = $formaPago->getCContable(); $caja = new CajaArqueos(); foreach ($this->request['RecibosClientes'] as $recibo) { $objeto = new RecibosClientes($recibo['IDRecibo']); $objeto->setVencimiento($this->request['fechaCobro']); $objeto->setIDEstado($estadoRecibo); $objeto->setCContable($cContable); if ($objeto->save() and $anotarEnCaja) { $caja->anotaEnCaja($objeto, $this->request['idFP']); } if (count($objeto->getErrores) > 0) { print_r($objeto->getErrores()); } } unset($objeto); unset($formaPago); unset($caja); return $this->listAction(); } else { return array('template' => '_global/forbiden.html.twig'); } }
public function RecibosClientes() { $nItems = 0; $nErrores = 0; $dbLink = mysql_connect("localhost", "root", "albatronic"); $query = "TRUNCATE {$this->dbDestino}.ErpRecibosClientes"; mysql_query($query); // Correspondencia entre número de factura e id de factura $query = "SELECT r.NumeroFactura as Numero, f.IDFactura as Id FROM {$this->dbOrigen}.recibos_clientes AS r LEFT JOIN {$this->dbOrigen}.femitidas_cab AS f ON r.NumeroFactura = f.NumeroFactura"; $result = mysql_query($query, $dbLink); while ($row1 = mysql_fetch_array($result, MYSQL_ASSOC)) { $correspondencia[$row1['Numero']] = $row1['Id']; } $query = "select * from {$this->dbOrigen}.recibos_clientes"; $result = mysql_query($query, $dbLink); while ($row = mysql_fetch_array($result, MYSQL_ASSOC)) { $c = new RecibosClientes(); $c->setIDRecibo($row['IDRecibo']); $c->setRecibo($row['Recibo']); $c->setIDSucursal(1); $c->setIDFactura($correspondencia[$row['NumeroFactura']]); $c->setIDCliente($row['IDCliente']); $c->setIDComercial(8); $c->setFecha($row['Fecha']); $c->setVencimiento($row['Vencimiento']); $c->setImporte($row['Importe']); $c->setIban(Utils::iban($row['CBanco'])); $c->setMandato($row['IDCliente']); $c->setFechaMandato('2013-01-01'); $c->setIDRemesa($row['IDRemesa']); $c->setCContable($row['CContable']); $c->setAsiento($row['Asiento']); $c->setConcepto($row['Concepto']); if ($row['Estado'] == 'C') { $c->setIDEstado(6); } else { $c->setIDEstado(0); } $c->setPrimaryKeyMD5(md5($row['IDRecibo'])); if (!$c->create()) { $errores[] = $c->getErrores(); $nErrores++; } else { $nItems++; } } //mysql_close($dbLink); echo "Recibos clientes creados {$nItems}<br/>"; if (count($errores)) { echo "<pre>"; print_r($errores); echo "</pre>"; } }
/** * Crea los recibos de la factura en curso en base a la forma de pago. * Si el n. de vctos de la forma de pago es 0, no se crea ningún vencimiento. */ public function creaVctos() { if ($this->Total == 0) { return; } $factura = new FemitidasCab($this->IDFactura); //SI LA FACTURA ES SIN IVA, EN CASO DE CREAR RECIBOS SE MARCARÁN //CON N. DE ASIENTO 999999 PARA QUE NO SE TRASPASEN A CONTABILIDAD. $tieneiva = $factura->getIva1() + $factura->getIva2() + $factura->getIva3() != 0; if ($tieneiva) { $asiento = 0; } else { $asiento = 999999; } $formaPago = $factura->getIDFP(); $nvctos = $formaPago->getNumeroVctos(); $fecha = new Fecha($factura->getFecha()); $mes = $fecha->getmm(); $dia = $fecha->getdd(); $anio = $fecha->getaaaa(); unset($fecha); if ($factura->getIDCliente()->getDiaDePago() > 0) { //SI TIENE UN DIA DE PAGO ESTABLECIDO, LOS VENCIMIENTOS SE CALCULAN //A PARTIR DE ESE DIA PERO DEL MES SIGUIENTE $mes = $mes + 1; if ($mes > 12) { $mes = 1; $anio = $anio + 1; } $dia = $factura->getIDCliente()->getDiaDePago(); } if ($nvctos > 0) { $importe = ROUND($factura->getTotal() / $nvctos, 2); $diferencia = $factura->getTotal() - $importe * $nvctos; $i = 0; while ($i < $nvctos) { $i = $i + 1; if ($i == 1) { $intervalo = $formaPago->getDiaPrimerVcto(); $importeRecibo = $importe + $diferencia; } else { $intervalo = $intervalo + $formaPago->getDiasIntervalo(); $importeRecibo = $importe; } $numRecibo = str_pad($i, 2, "0", STR_PAD_LEFT) . str_pad($nvctos, 2, "0", STR_PAD_LEFT); $fVcto = date('Y-m-d', mktime(0, 0, 0, $mes, $dia + $intervalo, $anio)); $recibo = new RecibosClientes(); $recibo->setRecibo($numRecibo); $recibo->setIDSucursal($factura->getIDSucursal()->getIDSucursal()); $recibo->setIDFactura($factura->getIDFactura()); $recibo->setIDCliente($factura->getIDCliente()->getIDCliente()); $recibo->setIDComercial($factura->getIDComercial()->getIDAgente()); $recibo->setFecha($factura->getFecha()); $recibo->setVencimiento($fVcto); $recibo->setImporte($importeRecibo); $recibo->setIban($factura->getIDCliente()->getIban()); $recibo->setBic($factura->getIDCliente()->getBic()); $recibo->setMandato($factura->getIDCliente()->getMandato()); $recibo->setFechaMandato($factura->getIDCliente()->getFechaMandato()); $recibo->setConcepto("Cobro Factura"); $recibo->setAsiento($asiento); $recibo->setIDEstado($formaPago->getEstadoRecibo()->getIDTipo()); // Si el recibo se crea cobrado, se pone la fecha de vencimiento en la remesa if ($formaPago->getEstadoRecibo()->getIDTipo() == '6') { $recibo->setIDRemesa(str_replace("-", "", $fVcto)); } else { $recibo->setIDRemesa(''); } $recibo->setRemesar(1); $recibo->setCContable($formaPago->getCContable()); $recibo->create(); unset($recibo); } } unset($factura); unset($formaPago); }