/**
  * 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');
     }
 }
Ejemplo n.º 2
0
 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>";
     }
 }
Ejemplo n.º 3
0
 /**
  * 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);
 }