/// <summary> /// Apaga os dados da origem. /// </summary> /// <param name="origemTrocaDesconto"></param> /// <returns></returns> public Colosoft.Business.DeleteResult ApagarOrigemTrocaDesconto(Entidades.OrigemTrocaDesconto origemTrocaDesconto) { origemTrocaDesconto.Require("origemTrocaDesconto").NotNull(); using (var session = SourceContext.Instance.CreateSession()) { var resultado = origemTrocaDesconto.Delete(session); if (!resultado) { return(resultado); } return(session.Execute(false).ToDeleteResult()); } }
/// <summary> /// Valida a origem de Troca/Devolução. /// </summary> /// <param name="origemTrocaDesconto"></param> /// <returns></returns> IMessageFormattable[] Entidades.IValidadorOrigemTrocaDesconto.ValidaExistencia(Entidades.OrigemTrocaDesconto origemTrocaDesconto) { var mensagens = new List <string>(); // Handler para tratar o resultado da consulta de validação var tratarResultado = new Func <string, Colosoft.Query.QueryCallBack>(mensagem => (sender, query, result) => { if (result.Select(f => f.GetInt32(0)).FirstOrDefault() > 0 && !mensagens.Contains(mensagem)) { mensagens.Add(mensagem); } }); var consulta = SourceContext.Instance.CreateMultiQuery(); var adicionaConsulta = new Action <Type, string, string, char>((tipo, nomeCampo, nome, genero) => { consulta.Add(SourceContext.Instance.CreateQuery() .From(new Colosoft.Query.EntityInfo(tipo.FullName)) .Where(String.Format("{0}=?id", nomeCampo)) .Add("?id", origemTrocaDesconto.IdOrigemTrocaDesconto) .Count(), tratarResultado(String.Format( "Esta origem de troca/desconto não pode ser excluída por possuir {0} relacionad{1}s à mesma.", nome, genero))); }); adicionaConsulta(typeof(Data.Model.ContasReceber), "IdOrigemDescontoAcrescimo", "contas a receber", 'a'); adicionaConsulta(typeof(Data.Model.TrocaDevolucao), "IdOrigemTrocaDevolucao", "trocas/devoluções", 'a'); consulta.Execute(); return(mensagens.Select(f => f.GetFormatter()).ToArray()); }