public function __construct($l = FALSE) { parent::__construct('lineaspresupuestoscli', 'plugins/presupuestos_y_pedidos/'); if (!isset(self::$presupuestos)) { self::$presupuestos = array(); } if ($l) { $this->cantidad = floatval($l['cantidad']); $this->codimpuesto = $l['codimpuesto']; $this->descripcion = $l['descripcion']; $this->dtolineal = floatval($l['dtolineal']); $this->dtopor = floatval($l['dtopor']); $this->idlinea = intval($l['idlinea']); $this->idpresupuesto = intval($l['idpresupuesto']); $this->irpf = floatval($l['irpf']); $this->iva = floatval($l['iva']); $this->pvpsindto = floatval($l['pvpsindto']); $this->pvptotal = floatval($l['pvptotal']); $this->pvpunitario = floatval($l['pvpunitario']); $this->recargo = floatval($l['recargo']); $this->referencia = $l['referencia']; } else { $this->cantidad = 0; $this->codimpuesto = NULL; $this->descripcion = NULL; $this->dtolineal = 0; $this->dtopor = 0; $this->idlinea = NULL; $this->idpresupuesto = NULL; $this->irpf = 0; $this->iva = 0; $this->pvpsindto = 0; $this->pvptotal = 0; $this->pvpunitario = 0; $this->recargo = 0; $this->referencia = ''; } }
private function nuevo_presupuesto_cliente() { $continuar = TRUE; $cliente = $this->cliente->get($_POST['cliente']); if (!$cliente) { $this->new_error_msg('Cliente no encontrado.'); $continuar = FALSE; } $almacen = $this->almacen->get($_POST['almacen']); if ($almacen) { $this->save_codalmacen($_POST['almacen']); } else { $this->new_error_msg('Almacén no encontrado.'); $continuar = FALSE; } $eje0 = new ejercicio(); $ejercicio = $eje0->get_by_fecha($_POST['fecha']); if (!$ejercicio) { $this->new_error_msg('Ejercicio no encontrado.'); $continuar = FALSE; } $serie = $this->serie->get($_POST['serie']); if (!$serie) { $this->new_error_msg('Serie no encontrada.'); $continuar = FALSE; } $forma_pago = $this->forma_pago->get($_POST['forma_pago']); if ($forma_pago) { $this->save_codpago($_POST['forma_pago']); } else { $this->new_error_msg('Forma de pago no encontrada.'); $continuar = FALSE; } $divisa = $this->divisa->get($_POST['divisa']); if (!$divisa) { $this->new_error_msg('Divisa no encontrada.'); $continuar = FALSE; } $presupuesto = new presupuesto_cliente(); if ($this->duplicated_petition($_POST['petition_id'])) { $this->new_error_msg('Petición duplicada. Has hecho doble clic sobre el botón guardar y se han enviado dos peticiones. Mira en <a href="' . $presupuesto->url() . '">Presupuestos</a> para ver si el presupuesto se ha guardado correctamente.'); $continuar = FALSE; } if ($continuar) { $presupuesto->fecha = $_POST['fecha']; $presupuesto->finoferta = date("Y-m-d", strtotime($_POST['fecha'] . " +1 month")); $presupuesto->codalmacen = $almacen->codalmacen; $presupuesto->codejercicio = $ejercicio->codejercicio; $presupuesto->codserie = $serie->codserie; $presupuesto->codpago = $forma_pago->codpago; $presupuesto->coddivisa = $divisa->coddivisa; $presupuesto->tasaconv = $divisa->tasaconv; if ($_POST['tasaconv'] != '') { $presupuesto->tasaconv = floatval($_POST['tasaconv']); } $presupuesto->codagente = $this->agente->codagente; $presupuesto->observaciones = $_POST['observaciones']; $presupuesto->numero2 = $_POST['numero2']; $presupuesto->irpf = $serie->irpf; $presupuesto->porcomision = $this->agente->porcomision; $presupuesto->codcliente = $cliente->codcliente; $presupuesto->cifnif = $cliente->cifnif; $presupuesto->nombrecliente = $cliente->razonsocial; $presupuesto->ciudad = $_POST['ciudad']; $presupuesto->codpais = $_POST['codpais']; $presupuesto->codpostal = $_POST['codpostal']; $presupuesto->direccion = $_POST['direccion']; $presupuesto->provincia = $_POST['provincia']; if ($presupuesto->save()) { $art0 = new articulo(); $n = floatval($_POST['numlineas']); for ($i = 0; $i <= $n; $i++) { if (isset($_POST['referencia_' . $i])) { $linea = new linea_presupuesto_cliente(); $linea->idpresupuesto = $presupuesto->idpresupuesto; $linea->descripcion = $_POST['desc_' . $i]; if (!$serie->siniva and $cliente->regimeniva != 'Exento') { $imp0 = $this->impuesto->get_by_iva($_POST['iva_' . $i]); if ($imp0) { $linea->codimpuesto = $imp0->codimpuesto; $linea->iva = floatval($_POST['iva_' . $i]); $linea->recargo = floatval($_POST['recargo_' . $i]); } else { $linea->iva = floatval($_POST['iva_' . $i]); $linea->recargo = floatval($_POST['recargo_' . $i]); } } $linea->irpf = floatval($_POST['irpf_' . $i]); $linea->pvpunitario = floatval($_POST['pvp_' . $i]); $linea->cantidad = floatval($_POST['cantidad_' . $i]); $linea->dtopor = floatval($_POST['dto_' . $i]); $linea->pvpsindto = $linea->pvpunitario * $linea->cantidad; $linea->pvptotal = floatval($_POST['neto_' . $i]); $articulo = $art0->get($_POST['referencia_' . $i]); if ($articulo) { $linea->referencia = $articulo->referencia; } if ($linea->save()) { $presupuesto->neto += $linea->pvptotal; $presupuesto->totaliva += $linea->pvptotal * $linea->iva / 100; $presupuesto->totalirpf += $linea->pvptotal * $linea->irpf / 100; $presupuesto->totalrecargo += $linea->pvptotal * $linea->recargo / 100; } else { $this->new_error_msg("¡Imposible guardar la linea con referencia: " . $linea->referencia); $continuar = FALSE; } } } if ($continuar) { /// redondeamos $presupuesto->neto = round($presupuesto->neto, FS_NF0); $presupuesto->totaliva = round($presupuesto->totaliva, FS_NF0); $presupuesto->totalirpf = round($presupuesto->totalirpf, FS_NF0); $presupuesto->totalrecargo = round($presupuesto->totalrecargo, FS_NF0); $presupuesto->total = $presupuesto->neto + $presupuesto->totaliva - $presupuesto->totalirpf + $presupuesto->totalrecargo; if (abs(floatval($_POST['atotal']) - $presupuesto->total) >= 0.02) { $this->new_error_msg("El total difiere entre el controlador y la vista (" . $presupuesto->total . " frente a " . $_POST['atotal'] . "). Debes informar del error."); $presupuesto->delete(); } else { if ($presupuesto->save()) { $this->new_message("<a href='" . $presupuesto->url() . "'>" . ucfirst(FS_PRESUPUESTO) . "</a> guardado correctamente."); $this->new_change(ucfirst(FS_PRESUPUESTO) . ' a Cliente ' . $presupuesto->codigo, $presupuesto->url(), TRUE); if ($_POST['redir'] == 'TRUE') { header('Location: ' . $presupuesto->url()); } } else { $this->new_error_msg("¡Imposible actualizar el <a href='" . $presupuesto->url() . "'>" . FS_PRESUPUESTO . "</a>!"); } } } else { if ($presupuesto->delete()) { $this->new_message(ucfirst(FS_PRESUPUESTO) . " eliminado correctamente."); } else { $this->new_error_msg("¡Imposible eliminar el <a href='" . $presupuesto->url() . "'>" . FS_PRESUPUESTO . "</a>!"); } } } else { $this->new_error_msg("¡Imposible guardar el " . FS_PRESUPUESTO . "!"); } } }
public function get_lineas() { $linea = new linea_presupuesto_cliente(); return $linea->all_from_presupuesto($this->idpresupuesto); }
private function modificar() { $this->presupuesto->observaciones = $_POST['observaciones']; $this->presupuesto->numero2 = $_POST['numero2']; if ($this->presupuesto->editable) { $eje0 = $this->ejercicio->get_by_fecha($_POST['fecha'], FALSE); if (!$eje0) { $this->new_error_msg('Ningún ejercicio encontrado.'); } else { $this->presupuesto->fecha = $_POST['fecha']; $this->presupuesto->hora = $_POST['hora']; $this->presupuesto->finoferta = NULL; if ($_POST['finoferta'] != '') { $this->presupuesto->finoferta = $_POST['finoferta']; } } /// ¿cambiamos el cliente? if ($_POST['cliente'] != $this->presupuesto->codcliente) { $cliente = $this->cliente->get($_POST['cliente']); if ($cliente) { foreach ($cliente->get_direcciones() as $d) { if ($d->domfacturacion) { $this->presupuesto->codcliente = $cliente->codcliente; $this->presupuesto->cifnif = $cliente->cifnif; $this->presupuesto->nombrecliente = $cliente->razonsocial; $this->presupuesto->apartado = $d->apartado; $this->presupuesto->ciudad = $d->ciudad; $this->presupuesto->coddir = $d->id; $this->presupuesto->codpais = $d->codpais; $this->presupuesto->codpostal = $d->codpostal; $this->presupuesto->direccion = $d->direccion; $this->presupuesto->provincia = $d->provincia; break; } } } else { die('No se ha encontrado el cliente.'); } } else { $this->presupuesto->nombrecliente = $_POST['nombrecliente']; $this->presupuesto->cifnif = $_POST['cifnif']; $this->presupuesto->codpais = $_POST['codpais']; $this->presupuesto->provincia = $_POST['provincia']; $this->presupuesto->ciudad = $_POST['ciudad']; $this->presupuesto->codpostal = $_POST['codpostal']; $this->presupuesto->direccion = $_POST['direccion']; $cliente = $this->cliente->get($this->presupuesto->codcliente); } $serie = $this->serie->get($this->presupuesto->codserie); /// ¿cambiamos la serie? if ($_POST['serie'] != $this->presupuesto->codserie) { $serie2 = $this->serie->get($_POST['serie']); if ($serie2) { $this->presupuesto->codserie = $serie2->codserie; $this->presupuesto->new_codigo(); $serie = $serie2; } } $this->presupuesto->codpago = $_POST['forma_pago']; /// ¿Cambiamos la divisa? if ($_POST['divisa'] != $this->presupuesto->coddivisa) { $divisa = $this->divisa->get($_POST['divisa']); if ($divisa) { $this->presupuesto->coddivisa = $divisa->coddivisa; $this->presupuesto->tasaconv = $divisa->tasaconv; } } else { if ($_POST['tasaconv'] != '') { $this->presupuesto->tasaconv = floatval($_POST['tasaconv']); } } if (isset($_POST['numlineas'])) { $numlineas = intval($_POST['numlineas']); $this->presupuesto->neto = 0; $this->presupuesto->totaliva = 0; $this->presupuesto->totalirpf = 0; $this->presupuesto->totalrecargo = 0; $this->presupuesto->irpf = 0; $lineas = $this->presupuesto->get_lineas(); $articulo = new articulo(); /// eliminamos las líneas que no encontremos en el $_POST foreach ($lineas as $l) { $encontrada = FALSE; for ($num = 0; $num <= $numlineas; $num++) { if (isset($_POST['idlinea_' . $num])) { if ($l->idlinea == intval($_POST['idlinea_' . $num])) { $encontrada = TRUE; break; } } } if (!$encontrada) { if (!$l->delete()) { $this->new_error_msg("¡Imposible eliminar la línea del artículo " . $l->referencia . "!"); } } } /// modificamos y/o añadimos las demás líneas for ($num = 0; $num <= $numlineas; $num++) { $encontrada = FALSE; if (isset($_POST['idlinea_' . $num])) { foreach ($lineas as $k => $value) { /// modificamos la línea if ($value->idlinea == intval($_POST['idlinea_' . $num])) { $encontrada = TRUE; $lineas[$k]->cantidad = floatval($_POST['cantidad_' . $num]); $lineas[$k]->pvpunitario = floatval($_POST['pvp_' . $num]); $lineas[$k]->dtopor = floatval($_POST['dto_' . $num]); $lineas[$k]->pvpsindto = $value->cantidad * $value->pvpunitario; $lineas[$k]->pvptotal = $value->cantidad * $value->pvpunitario * (100 - $value->dtopor) / 100; $lineas[$k]->descripcion = $_POST['desc_' . $num]; $lineas[$k]->codimpuesto = NULL; $lineas[$k]->iva = 0; $lineas[$k]->recargo = 0; $lineas[$k]->irpf = floatval($_POST['irpf_' . $num]); if (!$serie->siniva and $cliente->regimeniva != 'Exento') { $imp0 = $this->impuesto->get_by_iva($_POST['iva_' . $num]); if ($imp0) { $lineas[$k]->codimpuesto = $imp0->codimpuesto; } $lineas[$k]->iva = floatval($_POST['iva_' . $num]); $lineas[$k]->recargo = floatval($_POST['recargo_' . $num]); } if ($lineas[$k]->save()) { $this->presupuesto->neto += $value->pvptotal; $this->presupuesto->totaliva += $value->pvptotal * $value->iva / 100; $this->presupuesto->totalirpf += $value->pvptotal * $value->irpf / 100; $this->presupuesto->totalrecargo += $value->pvptotal * $value->recargo / 100; if ($value->irpf > $this->presupuesto->irpf) { $this->presupuesto->irpf = $value->irpf; } } else { $this->new_error_msg("¡Imposible modificar la línea del artículo " . $value->referencia . "!"); } break; } } /// añadimos la línea if (!$encontrada and intval($_POST['idlinea_' . $num]) == -1 and isset($_POST['referencia_' . $num])) { $linea = new linea_presupuesto_cliente(); $linea->idpresupuesto = $this->presupuesto->idpresupuesto; $linea->descripcion = $_POST['desc_' . $num]; if (!$serie->siniva and $cliente->regimeniva != 'Exento') { $imp0 = $this->impuesto->get_by_iva($_POST['iva_' . $num]); if ($imp0) { $linea->codimpuesto = $imp0->codimpuesto; } $linea->iva = floatval($_POST['iva_' . $num]); $linea->recargo = floatval($_POST['recargo_' . $num]); } $linea->irpf = floatval($_POST['irpf_' . $num]); $linea->cantidad = floatval($_POST['cantidad_' . $num]); $linea->pvpunitario = floatval($_POST['pvp_' . $num]); $linea->dtopor = floatval($_POST['dto_' . $num]); $linea->pvpsindto = $linea->cantidad * $linea->pvpunitario; $linea->pvptotal = $linea->cantidad * $linea->pvpunitario * (100 - $linea->dtopor) / 100; $art0 = $articulo->get($_POST['referencia_' . $num]); if ($art0) { $linea->referencia = $art0->referencia; } if ($linea->save()) { $this->presupuesto->neto += $linea->pvptotal; $this->presupuesto->totaliva += $linea->pvptotal * $linea->iva / 100; $this->presupuesto->totalirpf += $linea->pvptotal * $linea->irpf / 100; $this->presupuesto->totalrecargo += $linea->pvptotal * $linea->recargo / 100; if ($linea->irpf > $this->presupuesto->irpf) { $this->presupuesto->irpf = $linea->irpf; } } else { $this->new_error_msg("¡Imposible guardar la línea del artículo " . $linea->referencia . "!"); } } } } /// redondeamos $this->presupuesto->neto = round($this->presupuesto->neto, FS_NF0); $this->presupuesto->totaliva = round($this->presupuesto->totaliva, FS_NF0); $this->presupuesto->totalirpf = round($this->presupuesto->totalirpf, FS_NF0); $this->presupuesto->totalrecargo = round($this->presupuesto->totalrecargo, FS_NF0); $this->presupuesto->total = $this->presupuesto->neto + $this->presupuesto->totaliva - $this->presupuesto->totalirpf + $this->presupuesto->totalrecargo; if (abs(floatval($_POST['atotal']) - $this->presupuesto->total) >= 0.02) { $this->new_error_msg("El total difiere entre el controlador y la vista (" . $this->presupuesto->total . " frente a " . $_POST['atotal'] . "). Debes informar del error."); } } } if ($this->presupuesto->save()) { $this->new_message(ucfirst(FS_PRESUPUESTO) . " modificado correctamente."); $this->new_change(ucfirst(FS_PRESUPUESTO) . ' Cliente ' . $this->presupuesto->codigo, $this->presupuesto->url()); } else { $this->new_error_msg("¡Imposible modificar el " . FS_PRESUPUESTO . "!"); } }
public function buscar_lineas() { /// cambiamos la plantilla HTML $this->template = 'ajax/ventas_lineas_presupuestos'; $this->buscar_lineas = $_POST['buscar_lineas']; $linea = new linea_presupuesto_cliente(); if (isset($_POST['codcliente'])) { $this->lineas = $linea->search_from_cliente2($_POST['codcliente'], $this->buscar_lineas, $_POST['buscar_lineas_o'], $this->offset); } else { $this->lineas = $linea->search($this->buscar_lineas, $this->offset); } }
public function buscar_lineas() { /// cambiamos la plantilla HTML $this->template = 'ajax/ventas_lineas_presupuestos'; $this->buscar_lineas = $_POST['buscar_lineas']; $linea = new linea_presupuesto_cliente(); $this->lineas = $linea->search($this->buscar_lineas); }
public function get_lineas() { $linea = new linea_presupuesto_cliente(); $lineas = $linea->all_from_presupuesto($this->idpresupuesto); if (is_null($this->idpedido)) { foreach ($lineas as $l) { $db_articulo = $this->db->select("SELECT * FROM articulos WHERE referencia = " . $this->var2str($l->referencia) . " ORDER BY referencia ASC;"); foreach ($db_articulo as $a) { if (new DateTime($a["factualizado"]) > new DateTime($this->fecha)) { $this->new_error_msg("Artículo " . $l->referencia . " actualizado desde la elaboración del " . FS_PRESUPUESTO . "."); } } } } return $lineas; }
private function nuevo_presupuesto_cliente() { $continuar = TRUE; $cliente = $this->cliente->get($_POST['cliente']); if ($cliente) { $this->save_codcliente($cliente->codcliente); } else { $this->new_error_msg('Cliente no encontrado.'); $continuar = FALSE; } $almacen = $this->almacen->get($_POST['almacen']); if ($almacen) { $this->save_codalmacen($almacen->codalmacen); } else { $this->new_error_msg('Almacén no encontrado.'); $continuar = FALSE; } $eje0 = new ejercicio(); $ejercicio = $eje0->get_by_fecha($_POST['fecha']); if ($ejercicio) { $this->save_codejercicio($ejercicio->codejercicio); } else { $this->new_error_msg('Ejercicio no encontrado.'); $continuar = FALSE; } $serie = $this->serie->get($_POST['serie']); if (!$serie) { $this->new_error_msg('Serie no encontrada.'); $continuar = FALSE; } $forma_pago = $this->forma_pago->get($_POST['forma_pago']); if ($forma_pago) { $this->save_codpago($forma_pago->codpago); } else { $this->new_error_msg('Forma de pago no encontrada.'); $continuar = FALSE; } $divisa = $this->divisa->get($_POST['divisa']); if ($divisa) { $this->save_coddivisa($divisa->coddivisa); } else { $this->new_error_msg('Divisa no encontrada.'); $continuar = FALSE; } $presupuesto = new presupuesto_cliente(); if ($this->duplicated_petition($_POST['petition_id'])) { $this->new_error_msg('Petición duplicada. Has hecho doble clic sobre el botón guardar y se han enviado dos peticiones. Mira en <a href="' . $presupuesto->url() . '">Presupuestos</a> para ver si el presupuesto se ha guardado correctamente.'); $continuar = FALSE; } if ($continuar) { $presupuesto->fecha = $_POST['fecha']; $presupuesto->finoferta = date("Y-m-d", strtotime($_POST['fecha'] . " +30 days")); $presupuesto->codalmacen = $almacen->codalmacen; $presupuesto->codejercicio = $ejercicio->codejercicio; $presupuesto->codserie = $serie->codserie; $presupuesto->codpago = $forma_pago->codpago; $presupuesto->coddivisa = $divisa->coddivisa; $presupuesto->tasaconv = $divisa->tasaconv; $presupuesto->codagente = $this->agente->codagente; $presupuesto->observaciones = $_POST['observaciones']; $presupuesto->numero2 = $_POST['numero2']; $presupuesto->irpf = $serie->irpf; $presupuesto->porcomision = $this->agente->porcomision; foreach ($cliente->get_direcciones() as $d) { if ($d->domfacturacion) { $presupuesto->codcliente = $cliente->codcliente; $presupuesto->cifnif = $cliente->cifnif; $presupuesto->nombrecliente = $cliente->nombrecomercial; $presupuesto->apartado = $d->apartado; $presupuesto->ciudad = $d->ciudad; $presupuesto->coddir = $d->id; $presupuesto->codpais = $d->codpais; $presupuesto->codpostal = $d->codpostal; $presupuesto->direccion = $d->direccion; $presupuesto->provincia = $d->provincia; break; } } if (is_null($presupuesto->codcliente)) { $this->new_error_msg("No hay ninguna dirección asociada al cliente."); } else { if ($presupuesto->save()) { $art0 = new articulo(); $n = floatval($_POST['numlineas']); for ($i = 0; $i <= $n; $i++) { if (isset($_POST['referencia_' . $i])) { $articulo = $art0->get($_POST['referencia_' . $i]); if ($articulo) { $linea = new linea_presupuesto_cliente(); $linea->idpresupuesto = $presupuesto->idpresupuesto; $linea->referencia = $articulo->referencia; $linea->descripcion = $_POST['desc_' . $i]; if (!$serie->siniva and $cliente->regimeniva != 'Exento') { $imp0 = $this->impuesto->get_by_iva($_POST['iva_' . $i]); if ($imp0) { $linea->codimpuesto = $imp0->codimpuesto; $linea->iva = floatval($_POST['iva_' . $i]); $linea->recargo = floatval($_POST['recargo_' . $i]); } else { $linea->iva = floatval($_POST['iva_' . $i]); $linea->recargo = floatval($_POST['recargo_' . $i]); } } if ($linea->iva > 0) { $linea->irpf = $presupuesto->irpf; } $linea->pvpunitario = floatval($_POST['pvp_' . $i]); $linea->cantidad = floatval($_POST['cantidad_' . $i]); //$linea->dtopor = floatval($_POST['000001'.$i]); $linea->pvpsindto = $linea->pvpunitario * $linea->cantidad; $linea->pvptotal = floatval($_POST['neto_' . $i]); if ($linea->save()) { $presupuesto->neto += $linea->pvptotal; $presupuesto->totaliva += $linea->pvptotal * $linea->iva / 100; $presupuesto->totalirpf += $linea->pvptotal * $linea->irpf / 100; $presupuesto->totalrecargo += $linea->pvptotal * $linea->recargo / 100; } else { $this->new_error_msg("¡Imposible guardar la linea con referencia: " . $linea->referencia); $continuar = FALSE; } } else { $this->new_error_msg("Artículo no encontrado: " . $_POST['referencia_' . $i]); $continuar = FALSE; } } } if ($continuar) { /// redondeamos $presupuesto->neto = round($presupuesto->neto, FS_NF0); $presupuesto->totaliva = round($presupuesto->totaliva, FS_NF0); $presupuesto->totalirpf = round($presupuesto->totalirpf, FS_NF0); $presupuesto->totalrecargo = round($presupuesto->totalrecargo, FS_NF0); $presupuesto->total = $presupuesto->neto + $presupuesto->totaliva - $presupuesto->totalirpf + $presupuesto->totalrecargo; if ($presupuesto->save()) { $this->new_message("<a href='" . $presupuesto->url() . "'>" . ucfirst(FS_PRESUPUESTO) . "</a> guardado correctamente. <a href='index.php?page=imprimir_presu_pedi&presupuesto=TRUE&id=" . $presupuesto->idpresupuesto . "'>Imprimir</a>"); $this->new_change(ucfirst(FS_PRESUPUESTO) . ' a Cliente ' . $presupuesto->codigo, $presupuesto->url(), TRUE); $this->cliente_s = $this->cliente->get("000001"); //reseteo el cliente } else { $this->new_error_msg("¡Imposible actualizar el <a href='" . $presupuesto->url() . "'>" . FS_PRESUPUESTO . "</a>!"); } } else { if ($presupuesto->delete()) { $this->new_message(ucfirst(FS_PRESUPUESTO) . " eliminado correctamente."); } else { $this->new_error_msg("¡Imposible eliminar el <a href='" . $presupuesto->url() . "'>" . FS_PRESUPUESTO . "</a>!"); } } } else { $this->new_error_msg("¡Imposible guardar el " . FS_PRESUPUESTO . "!"); } } } }