public function create() { // Calcular el Numero de traspaso en base al contador $contador = new Contadores($this->IDContador); $this->setNumeroTraspaso($contador->asignaContador()); unset($contador); return parent::create(); }
/** * Proceso de facturacion. * Puede ser facturación separada: Una factura por cada albarán * o facturación agrupada: Una factura con todos los albaranes, con las siguientes salvedades: * * Se agrupan las facturas en base a la forma de pago, comercial y al flag "Facturación agrupada" * de la ficha del cliente. * * @return <type> */ public function facturarAction() { $facturados = array(); $filtro = $this->request['filtro']; $fecha = new Fecha($filtro['desdeFecha']); $desdeFecha = $fecha->getaaaammdd(); $fecha = new Fecha($filtro['hastaFecha']); $hastaFecha = $fecha->getaaaammdd(); unset($fecha); switch ($this->request['tipo']) { case '0': // Facturación individual. Se genera una factura por cada albarán $filter = "IDFactura='0' and IDEstado='2' and IDCliente='{$filtro['idCliente']}' and FechaEntrega>='{$desdeFecha}' and FechaEntrega<'{$hastaFecha}' and FlagFacturar='1'"; $albaran = new AlbaranesCab(); $rows = $albaran->cargaCondicion("IDAlbaran", $filter, "FechaEntrega ASC"); foreach ($rows as $row) { $albaran = new AlbaranesCab($row['IDAlbaran']); $idFactura = $albaran->facturar(new Contadores($this->request['idContador']), $this->request['fecha']); if (count($albaran->getErrores()) != 0) { $this->values['errores'] = $albaran->getErrores(); break; } else { $facturados[] = $idFactura; } } unset($albaran); break; case '1': // Agrupada. Se agrupan los albaranes por forma de pago, comercial $filter = "c.IDFactura='0' and c.IDEstado='2' and c.IDCliente='{$filtro['idCliente']}' and c.FechaEntrega>='{$desdeFecha}' and c.FechaEntrega<'{$hastaFecha}' and c.FlagFacturar='1'"; //COMPRUEBO QUE NO HAYA MAS DE TRES TIPOS DE IVA ENTRE TODOS LOS ALBARANES A FACTURAR $albaran = new AlbaranesCab(); $albaranTabla = $albaran->getDataBaseName() . "." . $albaran->getTableName(); $lineas = new AlbaranesLineas(); $lineasTabla = $lineas->getDataBaseName() . "." . $lineas->getTableName(); $em = new EntityManager($albaran->getConectionName()); if (!$em->getDbLink()) { $this->values['errores'] = $em->getError(); return $this->listAction(); } $query = "select l.Iva from {$lineasTabla} as l, {$albaranTabla} as c\n where {$filter} and c.IDAlbaran=l.IDAlbaran\n group by l.Iva"; $em->query($query); $rows = $em->fetchResult(); $em->desConecta(); if (count($rows) > 3) { $this->values['alertas'] = "Hay más de tres tipos de iva distintos. No se puede agrupar"; return $this->listAction(); } $contador = new Contadores($this->request['idContador']); // Buscar la cuenta contable de ventas para la sucursal $sucursal = new Sucursales($filtro['idSucursal']); $ctaVentas = $sucursal->getCtaContableVentas(); unset($sucursal); $cliente = new Clientes($filtro['idCliente']); $agruparDireccionEntrega = $cliente->getFacturacionAgrupada()->getIDTipo() == '1'; unset($cliente); $query = $agruparDireccionEntrega ? "select c.IDFP,c.IDComercial, sum(c.Importe) as Importe, sum(Descuento) as Descuento from {$albaranTabla} c where {$filter} GROUP BY c.IDFP, c.IDComercial;" : "select c.IDFP,c.IDComercial, c.IDDirec, sum(c.Importe) as Importe, sum(Descuento) as Descuento from {$albaranTabla} c where {$filter} GROUP BY c.IDFP, c.IDComercial, c.IDDirec;"; unset($cliente); //AGRUPO LOS ALBARANES POR FORMA DE PAGO, COMERCIAL Y (si procede) DIRECCION DE ENTREGA. $em = new EntityManager($albaran->getConectionName()); $em->query($query); $rows = $em->fetchResult(); $em->desConecta(); foreach ($rows as $row) { $numeroFactura = $contador->asignaContador(); $factura = new FemitidasCab(); $factura->setIDSucursal($filtro['idSucursal']); $factura->setIDContador($this->request['idContador']); $factura->setNumeroFactura($numeroFactura); $factura->setIDAgente($_SESSION['usuarioPortal']['Id']); $factura->setIDComercial($row['IDComercial']); $factura->setFecha($this->request['fecha']); $factura->setIDCliente($filtro['idCliente']); $factura->setCuentaVentas($ctaVentas); $factura->setDescuento($row['Descuento']); $factura->setImporte($row['Importe']); $factura->setIDFP($row['IDFP']); $idFactura = $factura->create(); // Guardo en un array los id's de facturas generadas $facturados[] = $idFactura; if ($idFactura != 0) { // Crear las lineas de factura // No incluyo las lineas de albaran cuyas unidades sean 0 $em = new EntityManager($albaran->getConectionName()); $query = $agruparDireccionEntrega ? "select l.* from {$lineasTabla} l, {$albaranTabla} c where (c.IDAlbaran=l.IDAlbaran) and (c.IDFP='{$row['IDFP']}') and (l.Unidades<>0) and {$filter}" : "select l.* from {$lineasTabla} l, {$albaranTabla} c where (c.IDAlbaran=l.IDAlbaran) and (c.IDFP='{$row['IDFP']}') and (c.IDDirec='{$row['IDDirec']}') and (l.Unidades<>0) and {$filter}"; $em->query($query); $lineas = $em->fetchResult(); $em->desConecta(); foreach ($lineas as $linea) { $linFactura = new FemitidasLineas(); $linFactura->setIDFactura($idFactura); $linFactura->setIDArticulo($linea['IDArticulo']); $linFactura->setDescripcion($linea['Descripcion']); $linFactura->setUnidades($linea['Unidades']); $linFactura->setPrecio($linea['Precio']); $linFactura->setDescuento($linea['Descuento']); $linFactura->setImporte($linea['Importe']); $linFactura->setImporteCosto($linea['ImporteCosto']); $linFactura->setIDAlbaran($linea['IDAlbaran']); $linFactura->setIDLineaAlbaran($linea['IDLinea']); $linFactura->setIva($linea['Iva']); $linFactura->setRecargo($linea['Recargo']); $linFactura->setIDVenta($linea['IDVenta']); $linFactura->setComisionAgente($linea['ComisionAgente']); $linFactura->setComisionMontador($linea['ComisionMontador']); $linFactura->setComisionar($linea['Comisionar']); $linFactura->setIDAgente($_SESSION['usuarioPortal']['Id']); $linFactura->setIDComercial($linea['IDComercial']); $linFactura->setIDPromocion($linea['IDPromocion']); $linFactura->setAltoAl($linea['AltoAl']); $linFactura->setAnchoAl($linea['AnchoAl']); $linFactura->setMtsAl($linea['MtsAl']); $linFactura->setAltoFa($linea['AltoFa']); $linFactura->setAnchoFa($linea['AnchoFa']); $linFactura->setMtsFa($linea['MtsFa']); if ($linFactura->create()) { // Pongo el estado de la linea de albaran a "Facturado" $lineaAlbaran = new AlbaranesLineas($linea['IDLinea']); $lineaAlbaran->setIDEstado(3); $lineaAlbaran->save(); } else { print_r($linFactura->getErrores()); } unset($linFactura); } // Totalizar la factura $factura->recalcula(); // Crear vencimientos $factura->creaVctos(); // Anotar en caja sin procede $factura->anotaEnCaja(); // Actualiza las cabecera del grupo de albaranes $em = new EntityManager($albaran->getConectionName()); $query = $agruparDireccionEntrega ? "update {$albaranTabla} c set c.IDFactura='{$idFactura}', c.IDEstado='3' where (c.IDFP='{$row['IDFP']}') and ({$filter})" : "update {$albaranTabla} c set c.IDFactura='{$idFactura}', c.IDEstado='3' where (c.IDFP='{$row['IDFP']}') and (c.IDDirec='{$row['IDDirec']}') and ({$filter})"; $em->query($query); $em->desConecta(); unset($factura); } else { $this->values['errores'] = $factura->getErrores(); } } break; } if ($this->request['imprimir'] == 'on' and count($facturados) > 0) { $this->values['archivo'] = $this->generaPdf('FemitidasCab', $facturados); } if (count($facturados) > 0) { $this->values['alertas'][] = "Se han generado las siguientes facturas:"; foreach ($facturados as $item) { $this->values['alertas'][] = $item; } } return $this->listAction(); }
error_reporting(0); session_start(); $krd = strtoupper($krd); $ruta_raiz = "."; if (!isset($_SESSION['dependencia'])) { include "./rec_session.php"; } include_once $ruta_raiz . '/config.php'; // incluir configuracion. include_once $ruta_raiz . "/include/db/ConnectionHandler.php"; $db = new ConnectionHandler("{$ruta_raiz}"); if ($db) { $db->conn->SetFetchMode(ADODB_FETCH_ASSOC); include $ruta_raiz . "/include/class/Contadores.php"; $contador = new Contadores($db); $numRadicadosUsu = $contador->getContadorRad($_SESSION['dependencia'], $_SESSION['codusuario']); $numRadicadosDepe = $contador->getContadorJefe($_SESSION['dependencia']); if ($_SESSION["codusuario"] == 1) { $vencidos = $contador->getContadorJefe($_SESSION['dependencia']); } $vencidos0 = $contador->getContador($_SESSION['dependencia'], $_SESSION['codusuario'], 0); $vencidos1 = $contador->getContador($_SESSION['dependencia'], $_SESSION['codusuario'], 1); $vencidos2 = $contador->getContador($_SESSION['dependencia'], $_SESSION['codusuario'], 2); $expVencido = $contador->getExpPresVencidos($krd, 0); $expVencidoBolqueado = $contador->getExpPresVencidos($krd, 1); //$expVencido=$contador->getExpPresVencidos($krd,'7'); } ?> <html> <head>
/** * Construye un tag html <select> con todos las series de contadores de * la sucursal y tipo de contador indicado * @param integer $idSucursal ID de la sucursal * @param integer $tipo El tipo de contador (albaranes, pstos, etc). * @param string $nameSelect El Name del select * @param string $idSelect El Id del select * @return string Codigo html con el tag select */ function getContadoresSucursal($idSucursal, $tipo, $nameSelect = '', $idSelect = '') { if ($nameSelect == '') { $nameSelect = $_GET['nameselect']; } if ($idSelect == '') { $idSelect = $_GET['idselect']; } $contadores = new Contadores(); $rows = $contadores->fetchAll($idSucursal, $tipo); unset($contadores); $ch = "<div class='Etiqueta'>Serie</div>"; $ch .= "<select name='" . $nameSelect . "' id='" . $idSelect . "' class='Select'>"; foreach ($rows as $row) { $ch .= "<option value='" . $row['Id'] . "'>" . $row['Value'] . "</option>"; } $ch .= "</select>"; return $ch; }
/** * Facturar el pedido * Según la forma de pago, se actualiza la cartera de efectos. * Recibe el objeto contador que se utilizará para obtener el nº de factura. * * @param Contadores $contador El objeto contador * @param date $fecha La fecha de la factura (opcional, toma la del sistema) * @param string $suFactura El numero de factura del proveedor (opcional) * @param integer $idFp El id de la forma de pago (opcional) * @return int El id de la factura generada */ public function facturar(Contadores $contador, $fecha = '', $suFactura = '', $idFp = '') { if ($fecha == '') { $fecha = date('d-m-Y'); } $idFactura = 0; if ($this->getIDEstado()->getIDTipo() == 2 and $this->getIDFactura()->getIDFactura() == 0) { // Buscar la cuenta contable de compras para la sucursal $sucursal = new Sucursales($this->IDSucursal); $ctaCompras = $sucursal->getCtaContableCompras(); unset($sucursal); // Lee contador $idContador = $contador->getIDContador(); $numeroFactura = $contador->asignaContador(); unset($contador); // Crear la cabecera de la factura $factura = new FrecibidasCab(); $factura->setIDSucursal($this->IDSucursal); $factura->setIDContador($idContador); $factura->setNumeroFactura($numeroFactura); $factura->setSuFactura($suFactura); $factura->setFecha($fecha); $factura->setIDProveedor($this->IDProveedor); $factura->setImporte($this->Importe); $factura->setDescuento($this->Descuento); $factura->setBaseImponible1($this->BaseImponible1); $factura->setIva1($this->Iva1); $factura->setCuotaIva1($this->CuotaIva1); $factura->setRecargo1($this->Recargo1); $factura->setCuotaRecargo1($this->CuotaRecargo1); $factura->setBaseImponible2($this->BaseImponible2); $factura->setIva2($this->Iva2); $factura->setCuotaIva2($this->CuotaIva2); $factura->setRecargo2($this->Recargo2); $factura->setCuotaRecargo2($this->CuotaRecargo2); $factura->setBaseImponible3($this->BaseImponible3); $factura->setIva3($this->Iva3); $factura->setCuotaIva3($this->CuotaIva3); $factura->setRecargo3($this->Recargo3); $factura->setCuotaRecargo3($this->CuotaRecargo3); $factura->setTotalBases($this->TotalBases); $factura->setTotalIva($this->TotalIva); $factura->setTotalRecargo($this->TotalRecargo); $factura->setTotal($this->Total); $factura->setReferencia($this->Referencia); $factura->setCuentaCompras($ctaCompras); if ($idFp == '') { $factura->setIDFP($this->IDFP); } else { $factura->setIDFP($idFp); } $idFactura = $factura->create(); if ($idFactura != 0) { // Crear las lineas de factura $linPedido = new PedidosLineas(); $rows = $linPedido->cargaCondicion("*", "IDPedido='{$this->IDPedido}'", "IDLinea ASC"); unset($linPedido); foreach ($rows as $row) { $importe = $row['UnidadesRecibidas'] * $row['Precio'] * (1 - $row['Descuento'] / 100); $linFactura = new FrecibidasLineas(); $linFactura->setIDFactura($idFactura); $linFactura->setIDArticulo($row['IDArticulo']); $linFactura->setDescripcion($row['Descripcion']); $linFactura->setUnidades($row['UnidadesRecibidas']); $linFactura->setPrecio($row['Precio']); $linFactura->setDescuento($row['Descuento']); $linFactura->setImporte($importe); $linFactura->setIDPedido($row['IDPedido']); $linFactura->setIDLineaPedido($row['IDLinea']); $linFactura->setIva($row['Iva']); if ($linFactura->create()) { // Pongo el estado de la linea de pedido a "Facturado" $lineaPedido = new PedidosLineas($row['IDLinea']); $lineaPedido->setIDEstado(3); $lineaPedido->setUnidadesPtesFacturar(0); $lineaPedido->save(); unset($lineaPedido); } unset($linFactura); } // Recalcula la factura: // puede que las cantidades facturas sean distintas a las pedidas $factura->recalcula(); // Crear vencimientos $factura->creaVctos(); // Anotar en caja si procede $factura->anotaEnCaja(); // Actualiza la cabecera del pedido $this->setIDFactura($idFactura); $this->setIDEstado(3); $this->save(); } unset($factura); } return $idFactura; }
/** * 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; }
/** * Proceso de facturación agrupada. * * Se pueden agrupar pedidos de distintas sucursales, en cuyo caso * la factura generada se asignará a la sucursal en curso. * * Se agrupan las facturas en base a la forma de pago. * * @return <type> */ public function ConformarAction() { $facturados = array(); $filtro = $this->request['filtro']; $fecha = new Fecha($filtro['desdeFecha']); $desdeFecha = $fecha->getaaaammdd(); $fecha = new Fecha($filtro['hastaFecha']); $hastaFecha = $fecha->getaaaammdd(); unset($fecha); if ($filtro['idSucursal'] == '') { $filterSucursal = "(1)"; $idSucursal = $_SESSION['suc']; } else { $filterSucursal = "(IDSucursal='{$filtro['idSucursal']}')"; $idSucursal = $filtro['idSucursal']; } $filter = $filterSucursal . " AND c.IDFactura='0' and c.IDEstado='2' and c.IDProveedor='{$filtro['idProveedor']}' and c.Fecha>='{$desdeFecha}' and c.Fecha<'{$hastaFecha}' and c.FlagFacturar='1'"; //COMPRUEBO QUE NO HAYA MAS DE TRES TIPOS DE IVA ENTRE TODOS LOS ALBARANES A FACTURAR $pedidos = new PedidosCab(); $em = new EntityManager($pedidos->getConectionName()); if (!$em->getDbLink()) { $this->values['errores'] = $em->getError(); return $this->listAction(); } $query = "SELECT l.Iva\n FROM\n {$em->getDataBase()}.ErpPedidosLineas as l,\n {$em->getDataBase()}.ErpPedidosCab as c\n WHERE {$filter} and c.IDPedido=l.IDPedido\n GROUP BY l.Iva"; $em->query($query); $rows = $em->fetchResult(); $em->desConecta(); if (count($rows) > 3) { $this->values['alertas'] = "Hay más de tres tipos de iva distintos. No se puede agrupar"; return $this->listAction(); } $contador = new Contadores($this->request['idContador']); // Buscar la cuenta contable de compras para la sucursal $sucursal = new Sucursales($idSucursal); $ctaCompras = $sucursal->getCtaContableCompras(); unset($sucursal); //AGRUPO LOS PEDIDOS POR FORMA DE PAGO. $em = new EntityManager($pedidos->getConectionName()); $query = "SELECT c.IDFP, sum(c.Total) as Total FROM {$pedidos->getDataBaseName()}.ErpPedidosCab as c WHERE {$filter} GROUP BY c.IDFP"; $em->query($query); $rows = $em->fetchResult(); $em->desConecta(); foreach ($rows as $row) { $numeroFactura = $contador->asignaContador(); $factura = new FrecibidasCab(); $factura->setIDSucursal($idSucursal); $factura->setIDContador($this->request['idContador']); $factura->setNumeroFactura($numeroFactura); $factura->setSuFactura($this->request['suFactura']); $factura->setFecha($this->request['fecha']); $factura->setIDProveedor($filtro['idProveedor']); $factura->setCuentaCompras($ctaCompras); $factura->setIDFP($row['IDFP']); $idFactura = $factura->create(); // Guardo en un array los id's de facturas generadas $facturados[] = $idFactura; if ($idFactura != 0) { // Crear las líneas de factura $em = new EntityManager($pedidos->getConectionName()); $query = "select l.* from {$pedidos->getDataBaseName()}.ErpPedidosLineas l, {$pedidos->getDataBaseName()}.ErpPedidosCab c where (c.IDPedido=l.IDPedido) and (c.IDFP='{$row['IDFP']}') and {$filter}"; $em->query($query); $lineas = $em->fetchResult(); $em->desConecta(); foreach ($lineas as $linea) { $linFactura = new FrecibidasLineas(); $linFactura->setIDFactura($idFactura); $linFactura->setIDArticulo($linea['IDArticulo']); $linFactura->setDescripcion($linea['Descripcion']); $linFactura->setUnidades($linea['UnidadesPtesFacturar']); $linFactura->setPrecio($linea['Precio']); $linFactura->setDescuento($linea['Descuento']); $linFactura->setIva($linea['Iva']); $linFactura->setIDPedido($linea['IDPedido']); $linFactura->setIDLineaPedido($linea['IDLinea']); if ($linFactura->create()) { // Pongo el estado de la linea de pedido a "Facturado" y // quitar el pendiente de facturar. $lineaPedido = new PedidosLineas($linea['IDLinea']); $lineaPedido->setIDEstado(3); $lineaPedido->setUnidadesPtesFacturar(0); $lineaPedido->save(); } unset($linFactura); } // Totalizar la factura $factura->recalcula(); // Crear vencimientos $factura->creaVctos(); // Anotar en caja si procede $factura->anotaEnCaja(); // Actualiza las cabecera del grupo de pedidos $em = new EntityManager($pedidos->getConectionName()); $query = "update {$pedidos->getDataBaseName()}.ErpPedidosCab c set c.IDFactura='{$idFactura}', c.IDEstado='3' where (c.IDFP='{$row['IDFP']}') and ({$filter})"; $em->query($query); $em->desConecta(); unset($factura); } else { $this->values['errores'] = $factura->getErrores(); } } return $this->listAction(); }