private void Novo(object objParam)
        {
            tbProduto objProdutoAux = new tbProduto();

            objProduto             = objProdutoAux;
            base.enStatusTelaAtual = enStatusTela.EmInclusaoOuAlteracao;
        }
Beispiel #2
0
        private string ValidaProduto(tbProduto objProduto)
        {
            if (string.IsNullOrEmpty(objProduto.pro_nome) || string.IsNullOrWhiteSpace(objProduto.pro_nome))
            {
                return("O nome deve ser informado.");
            }

            return(_objCtx.tbProduto.AsNoTracking().Any(pro => (pro.pro_nome.Equals(objProduto.pro_nome)) && pro.pro_codigo != objProduto.pro_codigo) ? "Já existe produto com esse nome." : string.Empty);
        }
        public void Pesquisar(object objParam)
        {
            if (objParam != null && objParam.GetType() == typeof(tbProduto))
            {
                if (base.blnJanela)
                {
                    _objProduto = (tbProduto)objParam;
                    Dispose();
                }
            }
            else
            {
                int intSkip;
                if (objParam == null || !int.TryParse(objParam.ToString(), out intSkip))
                {
                    intSkip = 0;
                }

                Retorno objRetorno;
                using (var objBLL = new Produtos())
                {
                    objRetorno = objBLL.RetornaListaProduto(strProCodigoPesquisa, strProNomePesquisa, intSkip, base.intQtdeRegPagina);
                }
                if (objRetorno.intCodigoErro == 0)
                {
                    if (objRetorno.intQtdeRegistro > 0)
                    {
                        if ((objRetorno.intQtdeRegistro % base.intQtdeRegPagina) > 0)
                        {
                            base.intTotalPagina = (int)(objRetorno.intQtdeRegistro / base.intQtdeRegPagina) + 1;
                        }
                        else
                        {
                            base.intTotalPagina = (int)(objRetorno.intQtdeRegistro / base.intQtdeRegPagina);
                        }
                        base.intPaginaAtual = 1;
                        base.intQtdeReg     = objRetorno.intQtdeRegistro;
                    }
                    arrProdutoPesquisa = (List <tbProduto>)objRetorno.objRetorno;
                    if (arrProdutoPesquisa.Count() == 0)
                    {
                        base.intTotalPagina = 1;
                        base.intPaginaAtual = 1;
                        base.intQtdeReg     = 0;
                    }
                }
                else
                {
                    MessageBox.Show(objRetorno.strMsgErro, "Atenção", MessageBoxButton.OK, Util.GetMessageImage(objRetorno.intCodigoErro));
                }
            }
        }
Beispiel #4
0
        public Retorno RetornaProduto(int intCodigo, enNavegacao?enDirecao)
        {
            var objRetorno = new Retorno();

            try
            {
                tbProduto objProduto = null;
                if (enDirecao == null)
                {
                    objProduto = _objCtx.tbProduto.AsNoTracking()
                                 .FirstOrDefault(pro => pro.pro_codigo == intCodigo);
                }
                if (enDirecao == enNavegacao.Proximo)
                {
                    objProduto = _objCtx.tbProduto.AsNoTracking()
                                 .Where(pro => pro.pro_codigo > intCodigo)
                                 .OrderBy(pro => pro.pro_codigo).FirstOrDefault();
                }
                if (enDirecao == enNavegacao.Anterior)
                {
                    objProduto = _objCtx.tbProduto.AsNoTracking()
                                 .Where(pro => pro.pro_codigo < intCodigo)
                                 .OrderByDescending(pro => pro.pro_codigo).FirstOrDefault();
                }
                if (objProduto != null)
                {
                    objRetorno.intCodigoErro = 0;
                    objRetorno.objRetorno    = objProduto;
                }
                else
                {
                    objRetorno.intCodigoErro = 48;
                    objRetorno.strMsgErro    = "Registro não encontrado";
                }
            }
            catch (Exception ex)
            {
                FrameworkUtil.LogErro(ex);
                objRetorno.intCodigoErro        = 16;
                objRetorno.strMsgErro           = ex.Message;
                objRetorno.strExceptionToString = ex.ToString();
            }
            return(objRetorno);
        }
Beispiel #5
0
        public Retorno SalvarProduto(tbProduto objProduto, int intFunCodigo)
        {
            var objRetorno   = new Retorno();
            var strValidacao = ValidaProduto(objProduto);

            try
            {
                if (strValidacao == string.Empty)
                {
                    enOperacao enTipoOperacao;
                    if (objProduto.pro_codigo == 0)
                    {
                        enTipoOperacao = enOperacao.Inclusao;
                        _objCtx.tbProduto.Add(objProduto);
                    }
                    else
                    {
                        enTipoOperacao = enOperacao.Alteracao;
                        var objProdutoContexto = _objCtx.tbProduto.FirstOrDefault(pro => pro.pro_codigo == objProduto.pro_codigo);
                        _objCtx.Entry(objProdutoContexto).CurrentValues.SetValues(objProduto);
                    }
                    _objCtx.SaveChanges();
                    using (var objBll = new Auditoria(ref _objCtx, ref _objTransacao))
                        objBll.SalvarAuditoria(objProduto.pro_codigo, enTipoOperacao, objProduto, intFunCodigo);
                    objRetorno.intCodigoErro = 0;
                }
                else
                {
                    objRetorno.intCodigoErro = 48;
                    objRetorno.strMsgErro    = strValidacao;
                }
            }
            catch (Exception ex)
            {
                FrameworkUtil.LogErro(ex);
                objRetorno.intCodigoErro        = 16;
                objRetorno.strMsgErro           = ex.Message;
                objRetorno.strExceptionToString = ex.ToString();
            }
            return(objRetorno);
        }