Exemplo n.º 1
0
        /// <summary>
        /// Apaga o subtipo de perda.
        /// </summary>
        /// <param name="subtipoPerda"></param>
        /// <returns></returns>
        public Colosoft.Business.DeleteResult ApagarSubtipoPerda(Entidades.SubtipoPerda subtipoPerda)
        {
            subtipoPerda.Require("subtipoPerda").NotNull();

            using (var session = SourceContext.Instance.CreateSession())
            {
                var resultado = subtipoPerda.Delete(session);
                if (!resultado)
                {
                    return(resultado);
                }

                return(session.Execute(false).ToDeleteResult());
            }
        }
Exemplo n.º 2
0
        /// <summary>
        /// Valida a existencia do subtipo de perda.
        /// </summary>
        /// <param name="subtipoPerda"></param>
        /// <returns></returns>
        public IMessageFormattable[] ValidaExistencia(Entidades.SubtipoPerda subtipoPerda)
        {
            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", subtipoPerda.IdSubtipoPerda)
                             .Count(),

                             tratarResultado(String.Format(
                                                 "Este subtipo de perda não pode ser excluído por possuir {0} relacionad{1}s ao mesmo.",
                                                 nome, genero)));
            });

            adicionaConsulta(typeof(Glass.Data.Model.TrocaDevolucao), "IdSubtipoPerda", "trocas/devoluções", 'o');
            adicionaConsulta(typeof(Glass.Data.Model.PerdaChapaVidro), "IdSubTipoPerda", "perdas de chapa de vidro", 'a');
            adicionaConsulta(typeof(Glass.Data.Model.DadosReposicao), "IdSubtipoPerdaRepos", "reposições de peça anteriores", 'a');
            adicionaConsulta(typeof(Glass.Data.Model.ProdutoPedidoProducao), "IdSubtipoPerda", "reposições de peça (pedido)", 'a');
            adicionaConsulta(typeof(Glass.Data.Model.ProdutoPedidoProducao), "IdSubtipoPerdaRepos", "reposições de peça", 'a');

            consulta.Execute();

            return(mensagens.Select(f => f.GetFormatter()).ToArray());
        }