/// <summary> /// Lista todos los PLU de una referencia existentes. /// </summary> /// <param name="Referencia"></param> /// <returns></returns> public List <PLUInfo> ListxReferencia(string Referencia) { db.SetParameterValue(commandPLU, "i_operation", 'S'); db.SetParameterValue(commandPLU, "i_option", 'B'); db.SetParameterValue(commandPLU, "i_referencia", Referencia); List <PLUInfo> col = new List <PLUInfo>(); IDataReader dr = null; PLUInfo m = null; try { dr = db.ExecuteReader(commandPLU); while (dr.Read()) { m = Factory.GetPLU(dr); col.Add(m); } } catch (Exception ex) { System.Diagnostics.Trace.WriteLine(string.Format("NIVI Error: {0} , NameSpace: {1}, Clase: {2}, Metodo: {3} ", ex.Message, MethodBase.GetCurrentMethod().DeclaringType.Namespace, MethodBase.GetCurrentMethod().DeclaringType.Name, MethodBase.GetCurrentMethod().Name)); bool rethrow = ExceptionPolicy.HandleException(ex, "DataAccess Policy"); if (rethrow) { throw; } } finally { if (dr != null) { dr.Close(); } } return(col); }
/// <summary> /// lista un producto premio /// </summary> /// <returns></returns> public PLUInfo productoPremio(string plu, string referencia) { /* db.SetParameterValue(commandAmarres, "i_operation", 'S'); * db.SetParameterValue(commandAmarres, "i_option", '7'); * db.SetParameterValue(commandAmarres, "i_plu", plu); * db.SetParameterValue(commandAmarres, "i_referencia", referencia); * * IDataReader dr = null; */ PLUInfo m = null; /* * try * { * dr = db.ExecuteReader(commandAmarres); * * while (dr.Read()) * { * m = Factory.GetPLU(dr); * } * } * catch (Exception ex) * { * System.Diagnostics.Trace.WriteLine(string.Format("NIVI Error: {0} , NameSpace: {1}, Clase: {2}, Metodo: {3} ", ex.Message, MethodBase.GetCurrentMethod().DeclaringType.Namespace, MethodBase.GetCurrentMethod().DeclaringType.Name, MethodBase.GetCurrentMethod().Name)); * * bool rethrow = ExceptionPolicy.HandleException(ex, "DataAccess Policy"); * * if (rethrow) * { * throw; * } * } * finally * { * if (dr != null) * { * dr.Close(); * } * }*/ return(m); }
/// <summary> /// Consulta el articulo por medio del PLU por el tipo de precio. (Empresaria, Catalogo, Especial, Credito) /// </summary> /// <param name="PLU"></param> /// <param name="TipoPrecio"></param> /// <returns></returns> public PLUInfo ListxArticulosxPLUxTipoPrecioJUTA(int PLU, string TipoPrecio, string campana) { db.SetParameterValue(commandPLU, "i_operation", 'S'); db.SetParameterValue(commandPLU, "i_option", 'D'); db.SetParameterValue(commandPLU, "i_plu", PLU); db.SetParameterValue(commandPLU, "i_option_tipo", TipoPrecio); db.SetParameterValue(commandPLU, "i_codigocolor", campana); IDataReader dr = null; PLUInfo m = null; try { dr = db.ExecuteReader(commandPLU); while (dr.Read()) { m = Factory.GetArticuloxPLUxTipoPrecio(dr); } } catch (Exception ex) { System.Diagnostics.Trace.WriteLine(string.Format("NIVI Error: {0} , NameSpace: {1}, Clase: {2}, Metodo: {3} ", ex.Message, MethodBase.GetCurrentMethod().DeclaringType.Namespace, MethodBase.GetCurrentMethod().DeclaringType.Name, MethodBase.GetCurrentMethod().Name)); bool rethrow = ExceptionPolicy.HandleException(ex, "DataAccess Policy"); if (rethrow) { throw; } } finally { if (dr != null) { dr.Close(); } } return(m); }
/// <summary> /// lista un producto /// </summary> /// <returns></returns> public PLUInfo producto(string plu, string referencia) { db.SetParameterValue(commandReglasPremios, "i_operation", 'S'); db.SetParameterValue(commandReglasPremios, "i_option", 'D'); db.SetParameterValue(commandReglasPremios, "i_plu", plu); db.SetParameterValue(commandReglasPremios, "i_referencia", referencia); IDataReader dr = null; PLUInfo m = null; try { dr = db.ExecuteReader(commandReglasPremios); while (dr.Read()) { m = Factory.GetPLU(dr); } } catch (Exception ex) { System.Diagnostics.Trace.WriteLine(string.Format("NIVI Error: {0} , NameSpace: {1}, Clase: {2}, Metodo: {3} ", ex.Message, MethodBase.GetCurrentMethod().DeclaringType.Namespace, MethodBase.GetCurrentMethod().DeclaringType.Name, MethodBase.GetCurrentMethod().Name)); bool rethrow = ExceptionPolicy.HandleException(ex, "DataAccess Policy"); if (rethrow) { throw; } } finally { if (dr != null) { dr.Close(); } } return(m); }
public IEnumerable <PLUInfoDto> ListCatalogoActual(PLUInfo ObjPluInfoRequest) { List <PLUInfo> lista = new List <PLUInfo>();; IEnumerable <PLUInfoDto> ListaDto; PLU module = new PLU("conexion"); //-------------------------------------------------------------------------------------------------------- //-------------------------------------------------------------------------------------------------------- ListaDto = module.ListCatalogoActual(ObjPluInfoRequest.Campana); if (lista != null && lista.Count > 0) { } else { lista = new List <PLUInfo>(); } return(ListaDto); }
public PLUInfo ListarxCodigoRapido(PLUInfo ObjPLUInfo) { PLUInfo lista = new PLUInfo(); bool ExcentoIVA = false; //MRG: Arreglar esta bandera para que se ponga en true si hay IVA x ciudad x zona x articulo x cliente. string CodCiudadCliente = ObjPLUInfo.SessionEmpresaria.CodCiudadCliente.Trim(); decimal PrecioCat = 0; decimal IVAPrecioCat = 0; int CantidadSeleccionada = 0; decimal PrecioTotal = 0; decimal PrecioUnitario = 0; int Cantidad = 1; decimal PrecioCatalogo = 0; decimal ValorIVA = 0; PLUInfo objPLU = new PLUInfo(); PLU module = new PLU("conexion"); PLUInfo objPLUPrecioCat = new PLUInfo(); CatalogoPluInfo objCatalogoPluInfo = new CatalogoPluInfo(); CatalogoPlu objCatalogoPlu = new CatalogoPlu("conexion"); objCatalogoPluInfo = objCatalogoPlu.ListxCodigoRapidoSinCatalogo(ObjPLUInfo.CodigoRapido.ToUpper()); if (objCatalogoPluInfo != null) { objPLU = module.ListxArticulosxPLUxTipoPrecio(objCatalogoPluInfo.PLU, ((int)TipoPrecioEnum.PrecioEmpresaria).ToString()); if (objPLU != null) { objPLU.CatalogoReal = objCatalogoPluInfo.CatalogoReal; objPLU.CodigoRapido = ObjPLUInfo.CodigoRapido.ToUpper(); string strProducto = objPLU.NombreProducto.Trim().ToUpper(); string[] strProductoList = strProducto.Split(','); objPLU.NombreProducto = strProductoList[0].Trim().ToUpper(); objPLU.NombreColor = strProductoList[1].Trim().ToUpper(); objPLU.NombreTalla = strProductoList[2].Trim().ToUpper(); objPLU.IdZona = ObjPLUInfo.SessionEmpresaria.IdZona.Trim().ToUpper(); objPLU.PLU = objCatalogoPluInfo.PLU; objPLU.Referencia = objCatalogoPluInfo.Referencia.Trim().ToUpper(); objPLU.Campana = ObjPLUInfo.SessionEmpresaria.Campana.Trim().ToUpper(); objPLU.PrecioPuntos = objPLU.PrecioPuntos; objPLU.PuntosGanados = objPLU.PuntosGanados; if (!ExcentoIVA) { //()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()() ArtExcentosxCiudad objArtExcentosxCiudad = new ArtExcentosxCiudad("conexion"); ArtExcentosxCiudadInfo objArtExcentosxCiudadInfo = new ArtExcentosxCiudadInfo(); //()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()() //()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()() //Se valida si el articulo se encuentra excento de iva en la ciudad del cliente. objArtExcentosxCiudadInfo = objArtExcentosxCiudad.ListxCiudadxPlu(ObjPLUInfo.SessionEmpresaria.CodCiudadCliente.Trim(), objPLU.PLU); //Si se encuentra exento el iva debe ser 0. if (objArtExcentosxCiudadInfo != null) { PrecioCat = objPLU.PrecioSinIVA; IVAPrecioCat = 0; PrecioUnitario = objPLU.PrecioSinIVA; //PrecioCatalogo = objPLU.PrecioSinIVA; ValorIVA = 0; } else { PrecioCat = objPLU.PrecioSinIVA; IVAPrecioCat = objPLU.IVA; PrecioUnitario = objPLU.PrecioConIVA; //PrecioCatalogo = objPLU.PrecioConIVA; ValorIVA = objPLU.IVA; } } else { PrecioCat = objPLU.PrecioSinIVA; IVAPrecioCat = 0; PrecioUnitario = objPLU.PrecioSinIVA; //PrecioCatalogo = objPLU.PrecioSinIVA; ValorIVA = 0; } PrecioTotal = PrecioUnitario * Cantidad; CantidadSeleccionada = Cantidad; objPLU.Cantidad = Cantidad; //--------------------------------------------------------------------------------------- //Descuento y Consulta la disponibilidad de cada articulo. DescuentoGlod glod = new DescuentoGlod("conexion"); DescuentoInfo info3 = new DescuentoInfo(); decimal descuento = 0M; string bodegasel = ""; Inventario inventario = new Inventario("conexion"); InventarioInfo info = new InventarioInfo(); string grupodscto = ""; if (ObjPLUInfo.SessionEmpresaria.GrupoDescuento != null) { grupodscto = ObjPLUInfo.SessionEmpresaria.GrupoDescuento; } KardexInfo info5 = new Kardex("conexion").ListxArticuloxPLU(Convert.ToInt32(objCatalogoPluInfo.PLU)); descuento = this.CalcularDescuentoPrivilegioProdEstrella(info5.UnidadNegocio.Trim(), info5.GrupoProducto.Trim(), ObjPLUInfo.SessionEmpresaria.Campana, objCatalogoPluInfo.CatalogoReal.Trim().ToUpper(), info5.ProdEstrella, PrecioUnitario, grupodscto); bodegasel = ""; if (ObjPLUInfo.SessionEmpresaria.Bodegas != null) { bodegasel = ObjPLUInfo.SessionEmpresaria.Bodegas.Bodega; } info = inventario.ListSaldosBodegaxPLUxEmpresaria(bodegasel, Convert.ToInt32(objCatalogoPluInfo.PLU)); decimal punitario = PrecioUnitario; //Ver codigo de arriba xq aqui ya viene sumado o no el IVA excluido. decimal precioempivadesc = 0M; decimal precioempsiniva = 0; decimal ivaprecioempresaria = 0; if (ReferenceEquals(info, null)) { descuento = 0M; objPLU.Disponible = false; precioempsiniva = 0; ivaprecioempresaria = 0; precioempsiniva = PrecioCat; precioempivadesc = PrecioTotal; } else if (info.Saldo > 0M) { //PrecioEmpresaria= objPLU.PrecioTotalConIVA* objPLU.PorcentajeDescuento precioempivadesc = punitario - (punitario * (descuento / 100M)); objPLU.Disponible = true; precioempsiniva = PrecioCat - (PrecioCat * (descuento / 100)); //ivaprecioempresaria = (((1 + (objPLU.PorcentajeIVA / 100)) * precioempsiniva) - precioempsiniva); ivaprecioempresaria = precioempsiniva * ((objPLU.PorcentajeIVA / 100)); } else { descuento = 0M; precioempsiniva = 0; ivaprecioempresaria = 0; objPLU.Disponible = false; precioempsiniva = PrecioCat; precioempivadesc = PrecioTotal; } objPLU.PorcentajeDescuento = descuento; objPLU.PrecioEmpresaria = precioempivadesc; //------------------------------------------------------------- //MRG: Se envian los precios del producto PLU con la configuracion de ExcentoIVA IVA. objPLU.PrecioTotalConIVA = PrecioTotal; //MRG: Este es el valor que se carga en el front en la sesion DetallePedidoService con IVA o sin IVA. objPLU.PrecioCatalogoSinIVA = objPLU.PrecioSinIVA; objPLU.PrecioEmpresariaSinIVA = precioempsiniva; objPLU.IVAPrecioCatalogo = ValorIVA; objPLU.IVAPrecioEmpresaria = ivaprecioempresaria; objPLU.PorcentajeIVA = objPLU.PorcentajeIVA; objPLU.ExcentoIVA = ExcentoIVA; //------------------------------------------------------------- objPLU.SessionEmpresaria = new SessionEmpresariaInfo(); objPLU.SessionEmpresaria = ObjPLUInfo.SessionEmpresaria; //........................................................................................ //Path de imagenes objPLU.SessionEmpresaria.CarpetaImagenes = ObjPLUInfo.SessionEmpresaria.CarpetaImagenes.Trim(); /*llenar variable de sesion con el % Descuento asingado en la busqeuda de la cedula * validar path de imagenes para que cargue lo que es y dejar ese path desde bd, sino trae imagenes x default * organizar calculos de detalle articulo con lo obtenido desde aqui * mostrar bien disponible en verde o rojo*/ } } else { objPLU.PLU = -1; objPLU.Error = new Error(); objPLU.Error.Id = -1; objPLU.Error.Descripcion = "No se encontraron resultados. Por favor verifique. Codigo Rapido: " + ObjPLUInfo.CodigoRapido.ToUpper(); objPLU.CodigoRapido = ObjPLUInfo.CodigoRapido.ToUpper(); } return(objPLU); }