Example #1
0
 public function updateInventario(sfWebRequest $request)
 {
     $conn = $this->getTable()->getConnection();
     $conn->beginTransaction();
     try {
         $cantidad = count($this->getDetalleSolicitud());
         for ($index = 1; $index <= $cantidad; $index++) {
             $datos = $request->getParameter($index);
             $inventario = new inventario();
             $inventario->articulo_id = $datos['articulo_id'];
             $inventario->cantidad = $datos['cantidad'];
             $inventario->departamento_id = $datos['departamento_id'];
             $inventario->fecha_vencimiento = $datos['fecha_vencimiento']['year'] . '-' . $datos['fecha_vencimiento']['month'] . '-' . $datos['fecha_vencimiento']['day'];
             $inventario->save();
         }
         $this->recibida = true;
         $this->save();
         $conn->commit();
         return true;
     } catch (Exception $e) {
         $conn->rollback();
         throw $e;
     }
 }
 protected function private_core()
 {
     /// ¿El usuario tiene permiso para eliminar en esta página?
     $this->allow_delete = $this->user->allow_delete_on(__CLASS__);
     $articulo = new articulo();
     $this->familia = new familia();
     $this->fabricante = new fabricante();
     $this->impuesto = new impuesto();
     $this->tarifa = new tarifa();
     $inventario = new inventario();
     /**
      * Si hay alguna extensión de tipo config y texto no_tab_tarifas,
      * desactivamos la pestaña tarifas.
      */
     $this->mostrar_tab_tarifas = TRUE;
     foreach ($this->extensions as $ext) {
         if ($ext->type == 'config' and $ext->text == 'no_tab_tarifas') {
             $this->mostrar_tab_tarifas = FALSE;
             break;
         }
     }
     if (isset($_POST['codtarifa'])) {
         /// crear/editar tarifa
         $tar0 = $this->tarifa->get($_POST['codtarifa']);
         if (!$tar0) {
             $tar0 = new tarifa();
             $tar0->codtarifa = $_POST['codtarifa'];
         }
         $tar0->nombre = $_POST['nombre'];
         $tar0->aplicar_a = $_POST['aplicar_a'];
         $tar0->set_x(floatval($_POST['dtopor']));
         $tar0->set_y(floatval($_POST['inclineal']));
         if ($tar0->save()) {
             $this->new_message("Tarifa guardada correctamente.");
         } else {
             $this->new_error_msg("¡Imposible guardar la tarifa!");
         }
     } else {
         if (isset($_GET['delete_tarifa'])) {
             /// eliminar tarifa
             $tar0 = $this->tarifa->get($_GET['delete_tarifa']);
             if ($tar0) {
                 if ($tar0->delete()) {
                     $this->new_message("Tarifa borrada correctamente.");
                 } else {
                     $this->new_error_msg("¡Imposible borrar la tarifa!");
                 }
             } else {
                 $this->new_error_msg("¡La tarifa no existe!");
             }
         } else {
             if (isset($_POST['referencia']) and isset($_POST['codfamilia']) and isset($_POST['codimpuesto'])) {
                 /// nuevo artículo
                 $this->save_codfamilia($_POST['codfamilia']);
                 $this->save_codimpuesto($_POST['codimpuesto']);
                 $art0 = $articulo->get($_POST['referencia']);
                 if ($art0) {
                     $this->new_error_msg('Ya existe el artículo <a href="' . $art0->url() . '">' . $art0->referencia . '</a>');
                 } else {
                     $articulo->referencia = $_POST['referencia'];
                     $articulo->descripcion = $_POST['referencia'];
                     $articulo->nostock = isset($_POST['nostock']);
                     if ($_POST['codfamilia'] != '') {
                         $articulo->codfamilia = $_POST['codfamilia'];
                     }
                     if ($_POST['codfabricante'] != '') {
                         $articulo->codfabricante = $_POST['codfabricante'];
                     }
                     $articulo->set_pvp(floatval($_POST['pvp']));
                     $articulo->set_impuesto($_POST['codimpuesto']);
                     if ($articulo->save()) {
                         $inventario->codalmacen = $_POST['codfamilia'];
                         $inventario->referencia = $_POST['referencia'];
                         $inventario->save();
                         header('location: ' . $articulo->url());
                     } else {
                         $this->new_error_msg("¡Error al crear el articulo!");
                     }
                 }
             } else {
                 if (isset($_GET['delete'])) {
                     /// eliminar artículo
                     $art = $articulo->get($_GET['delete']);
                     if ($art) {
                         if ($art->delete()) {
                             $this->new_message("Articulo " . $art->referencia . " eliminado correctamente.");
                         } else {
                             $this->new_error_msg("¡Error al eliminarl el articulo!");
                         }
                     }
                 }
             }
         }
     }
     /// recogemos los datos necesarios para la búsqueda
     $this->buscar = FALSE;
     $this->codfamilia = '';
     if (isset($_REQUEST['codfamilia'])) {
         $this->codfamilia = $_REQUEST['codfamilia'];
         $this->buscar = TRUE;
     }
     $this->codfabricante = '';
     if (isset($_REQUEST['codfabricante'])) {
         $this->codfabricante = $_REQUEST['codfabricante'];
         $this->buscar = TRUE;
     }
     $this->con_stock = isset($_REQUEST['con_stock']);
     $this->bloqueados = isset($_REQUEST['bloqueados']);
     if (isset($_REQUEST['query']) or $this->con_stock or $this->bloqueados) {
         $this->buscar = TRUE;
     }
     $this->offset = 0;
     if (isset($_GET['offset'])) {
         $this->offset = intval($_GET['offset']);
     }
     if (isset($_GET['solo_stock'])) {
         $this->resultados = $articulo->search('', $this->offset, '', TRUE);
     } else {
         if (isset($_GET['public'])) {
             $this->resultados = $articulo->all_publico($this->offset);
         } else {
             $this->resultados = $articulo->search($this->query, $this->offset, $this->codfamilia, $this->con_stock, $this->codfabricante, $this->bloqueados);
         }
     }
 }
 protected function private_core()
 {
     $articulo = new articulo();
     $this->almacen = new almacen();
     $this->articulo = FALSE;
     $this->impuesto = new impuesto();
     $this->fabricante = new fabricante();
     $inventario = new inventario();
     /// ¿El usuario tiene permiso para eliminar en esta página?
     $this->allow_delete = $this->user->allow_delete_on(__CLASS__);
     /**
      * Si hay alguna extensión de tipo config y texto no_tab_recios,
      * desactivamos la pestaña precios.
      */
     $this->mostrar_tab_precios = TRUE;
     foreach ($this->extensions as $ext) {
         if ($ext->type == 'config' and $ext->text == 'no_tab_precios') {
             $this->mostrar_tab_precios = FALSE;
             break;
         }
     }
     /**
      * Si hay alguna extensión de tipo config y texto no_tab_stock,
      * desactivamos la pestaña stock.
      */
     $this->mostrar_tab_stock = TRUE;
     foreach ($this->extensions as $ext) {
         if ($ext->type == 'config' and $ext->text == 'no_tab_stock') {
             $this->mostrar_tab_stock = FALSE;
             break;
         }
     }
     /**
      * Si hay alguna extensión de tipo config y texto no_button_publicar,
      * desactivamos el botón publicar.
      */
     $this->mostrar_boton_publicar = TRUE;
     foreach ($this->extensions as $ext) {
         if ($ext->type == 'config' and $ext->text == 'no_button_publicar') {
             $this->mostrar_boton_publicar = FALSE;
             break;
         }
     }
     if (isset($_POST['pvpiva'])) {
         $this->articulo = $articulo->get($_POST['referencia']);
         if ($this->articulo) {
             $continuar = TRUE;
             $this->articulo->set_impuesto($_POST['codimpuesto']);
             $this->articulo->set_pvp_iva(floatval($_POST['pvpiva']));
             if (isset($_POST['preciocoste'])) {
                 $this->articulo->preciocoste = floatval($_POST['preciocoste']);
             }
             if ($this->articulo->save()) {
                 if (!($this->inventario = $inventario->get_ref($_POST['referencia']))) {
                     $inventario->referencia = $_POST['referencia'];
                     $inventario->preciocoste = $this->articulo->preciocoste;
                     $inventario->cantidad = 0;
                     $inventario->save();
                 } else {
                     $this->inventario->preciocoste = $this->articulo->preciocoste;
                     $this->inventario->cantidad = 0;
                     $this->inventario->inventario_agregar($this->inventario->codalmacen, $_POST['referencia'], $this->inventario->cantidad, $this->inventario->preciocoste);
                     //				$this->inventario->save();
                 }
             } else {
                 $this->new_message("Precio modificado correctamente.");
             }
         }
     } else {
         if (isset($_POST['almacen'])) {
             $this->articulo = $articulo->get($_POST['referencia']);
             if ($this->articulo) {
                 if ($_POST['cantidadini'] == $_POST['cantidad']) {
                     $this->new_message('Sin cambios.');
                 } else {
                     if ($this->articulo->set_stock($_POST['almacen'], $_POST['cantidad'])) {
                         $this->new_message("Stock guardado correctamente.");
                         /// añadimos la regularización
                         foreach ($this->articulo->get_stock() as $stock) {
                             if ($stock->codalmacen == $_POST['almacen']) {
                                 $regularizacion = new regularizacion_stock();
                                 $regularizacion->idstock = $stock->idstock;
                                 $regularizacion->cantidadini = floatval($_POST['cantidadini']);
                                 $regularizacion->cantidadfin = floatval($_POST['cantidad']);
                                 $regularizacion->codalmacendest = $_POST['almacen'];
                                 $regularizacion->motivo = $_POST['motivo'];
                                 $regularizacion->nick = $this->user->nick;
                                 if ($regularizacion->save()) {
                                     $inventario->inventario_agregar($_POST['almacen'], $_POST['referencia'], floatval($_POST['cantidad']) - floatval($_POST['cantidadini']), $this->articulo->preciocoste);
                                 }
                                 break;
                             }
                         }
                     } else {
                         $this->new_error_msg("Error al guardar el stock.");
                     }
                 }
             }
         } else {
             if (isset($_POST['imagen'])) {
                 $this->articulo = $articulo->get($_POST['referencia']);
                 if (is_uploaded_file($_FILES['fimagen']['tmp_name']) and $_FILES['fimagen']['size'] <= 1024000) {
                     $this->articulo->set_imagen(file_get_contents($_FILES['fimagen']['tmp_name']));
                     if ($this->articulo->save()) {
                         $this->new_message("Imagen del articulo modificada correctamente");
                     } else {
                         $this->new_error_msg("¡Error al guardar la imagen del articulo!");
                     }
                 }
             } else {
                 if (isset($_GET['delete_img'])) {
                     $this->articulo = $articulo->get($_GET['ref']);
                     $this->articulo->set_imagen(NULL);
                     if ($this->articulo->save()) {
                         $this->new_message("Imagen del articulo eliminada correctamente");
                     } else {
                         $this->new_error_msg("¡Error al eliminar la imagen del articulo!");
                     }
                 } else {
                     if (isset($_POST['referencia'])) {
                         $this->articulo = $articulo->get($_POST['referencia']);
                         $this->articulo->descripcion = $_POST['descripcion'];
                         $this->articulo->tipo = NULL;
                         if ($_POST['tipo'] != '') {
                             $this->articulo->tipo = $_POST['tipo'];
                         }
                         $this->articulo->codfamilia = NULL;
                         if ($_POST['codfamilia'] != '') {
                             $this->articulo->codfamilia = $_POST['codfamilia'];
                         }
                         $this->articulo->codfabricante = NULL;
                         if ($_POST['codfabricante'] != '') {
                             $this->articulo->codfabricante = $_POST['codfabricante'];
                         }
                         /// ¿Existe ya ese código de barras?
                         if ($_POST['codbarras'] != '') {
                             $arts = $this->articulo->search_by_codbar($_POST['codbarras']);
                             if ($arts) {
                                 foreach ($arts as $art2) {
                                     if ($art2->referencia != $this->articulo->referencia) {
                                         $this->new_advice('Ya hay un artículo con este mismo código de barras. ' . 'En concreto, el artículo <a href="' . $art2->url() . '">' . $art2->referencia . '</a>.');
                                         break;
                                     }
                                 }
                             }
                         }
                         $this->articulo->codbarras = $_POST['codbarras'];
                         $this->articulo->equivalencia = $_POST['equivalencia'];
                         $this->articulo->bloqueado = isset($_POST['bloqueado']);
                         $this->articulo->controlstock = isset($_POST['controlstock']);
                         $this->articulo->nostock = isset($_POST['nostock']);
                         $this->articulo->secompra = isset($_POST['secompra']);
                         $this->articulo->sevende = isset($_POST['sevende']);
                         $this->articulo->publico = isset($_POST['publico']);
                         $this->articulo->observaciones = $_POST['observaciones'];
                         $this->articulo->stockmin = floatval($_POST['stockmin']);
                         $this->articulo->stockmax = floatval($_POST['stockmax']);
                         if ($this->articulo->save()) {
                             if ($this->inventario = $inventario->get_ref($this->articulo->referencia)) {
                                 $this->inventario->guardar_modif_refe($_POST['nreferencia']);
                             }
                             $this->new_message("Datos del articulo modificados correctamente");
                             $this->articulo->set_referencia($_POST['nreferencia']);
                         } else {
                             $this->new_error_msg("¡Error al guardar el articulo!");
                         }
                     } else {
                         if (isset($_GET['ref'])) {
                             $this->articulo = $articulo->get($_GET['ref']);
                         }
                     }
                 }
             }
         }
     }
     if ($this->articulo) {
         $this->page->title = $this->articulo->referencia;
         if ($this->articulo->bloqueado) {
             $this->new_advice("Este artículo está bloqueado / obsoleto.");
         }
         /**
          * Si está desactivado el control de stok en el artículo, no muestro la pestaña.
          */
         if ($this->articulo->nostock) {
             $this->mostrar_tab_stock = FALSE;
         }
         $this->familia = $this->articulo->get_familia();
         if (!$this->familia) {
             $this->familia = new familia();
         }
         $this->fabricante = $this->articulo->get_fabricante();
         if (!$this->fabricante) {
             $this->fabricante = new fabricante();
         }
         $this->stocks = $this->articulo->get_stock();
         /// metemos en un array los almacenes que no tengan stock de este producto
         $this->nuevos_almacenes = array();
         foreach ($this->almacen->all() as $a) {
             $encontrado = FALSE;
             foreach ($this->stocks as $s) {
                 if ($a->codalmacen == $s->codalmacen) {
                     $encontrado = TRUE;
                 }
             }
             if (!$encontrado) {
                 $this->nuevos_almacenes[] = $a;
             }
         }
         $reg = new regularizacion_stock();
         $this->regularizaciones = $reg->all_from_articulo($this->articulo->referencia);
         $this->equivalentes = $this->articulo->get_equivalentes();
     } else {
         $this->new_error_msg("Artículo no encontrado.");
     }
 }