internal bool Atender(TituloCondicionante cond, TituloCondicionantePeriodicidade periodicidade) { if (cond == null || cond.Id <= 0) { Validacao.Add(Mensagem.Condicionante.Inexistente); return(false); } IdValido(cond.Id); if (cond.Situacao.Id == 4) //Atendida { Validacao.Add(Mensagem.Condicionante.JaAtendida); return(false); } if (cond.Situacao.Id != 2) //Ativa { Validacao.Add(Mensagem.Condicionante.AtenderNaoAtiva(cond.Situacao.Texto)); return(false); } if (periodicidade != null) { if (periodicidade.Situacao.Id == 5) { Validacao.Add(Mensagem.Condicionante.AtenderEncerrada); } } return(Validacao.EhValido); }
public TituloCondicionante Prorrogar(int condicionanteId, int periodicidadeId, int?diasProrrogados) { TituloCondicionante cond = null; TituloCondicionantePeriodicidade periodicidade = null; try { if (condicionanteId > 0) { cond = _da.Obter(condicionanteId); if (periodicidadeId > 0) { periodicidade = cond.Periodicidades.SingleOrDefault(x => x.Id == periodicidadeId); } } if (_validar.Prorrogar(cond, periodicidade, diasProrrogados)) { if (periodicidadeId == 0 || periodicidade == null) { cond.DiasProrrogados = (cond.DiasProrrogados ?? 0) + diasProrrogados; if (cond.Situacao.Id == 2 || cond.Situacao.Id == 3) { cond.DataVencimento.Data = cond.DataInicioPrazo.Data.Value.AddDays(diasProrrogados.GetValueOrDefault()); } //3 - Prorrogado cond.Situacao = _listaBus.TituloCondicionanteSituacoes.Single(x => x.Id == 3); } else { periodicidade.DiasProrrogados = (periodicidade.DiasProrrogados ?? 0) + diasProrrogados; if (periodicidade.Situacao.Id == 2 || periodicidade.Situacao.Id == 3) { periodicidade.DataVencimento.Data = periodicidade.DataVencimento.Data.Value.AddDays(diasProrrogados.GetValueOrDefault()); } //3 - Prorrogado periodicidade.Situacao = _listaBus.TituloCondicionanteSituacoes.Single(x => x.Id == 3); cond.Periodicidades[cond.Periodicidades.FindIndex(x => x.Id == periodicidade.Id)] = periodicidade; } _da.Prorrogar(cond, periodicidade); } } catch (Exception exc) { Validacao.AddErro(exc); } return(cond); }
internal void Prorrogar(TituloCondicionante condicionante, TituloCondicionantePeriodicidade periodicidade, BancoDeDados banco = null) { GerenciadorTransacao.ObterIDAtual(); using (BancoDeDados bancoDeDados = BancoDeDados.ObterInstancia(banco)) { #region Condicionante de Título bancoDeDados.IniciarTransacao(); Comando comando = null; if (periodicidade == null) { comando = bancoDeDados.CriarComando(@"update {0}tab_titulo_condicionantes c set c.possui_prazo = 1, situacao = :situacao, c.dias_prorrogados = :diasprorrogados, c.data_vencimento = :data_vencimento, c.tid = :tid where c.id =: id" , EsquemaBanco); comando.AdicionarParametroEntrada("id", condicionante.Id, DbType.Int32); comando.AdicionarParametroEntrada("situacao", condicionante.Situacao.Id, DbType.Int32); comando.AdicionarParametroEntrada("diasprorrogados", (condicionante.DiasProrrogados.HasValue) ? condicionante.DiasProrrogados : 0, DbType.Int32); comando.AdicionarParametroEntrada("data_vencimento", (condicionante.DataVencimento.Data.HasValue) ? condicionante.DataVencimento.Data : (object)DBNull.Value, DbType.DateTime); comando.AdicionarParametroEntrada("tid", DbType.String, 36, GerenciadorTransacao.ObterIDAtual()); } else { comando = bancoDeDados.CriarComando(@"update tab_titulo_condicionantes_peri p set p.situacao = :situacao, p.dias_prorrogados = :diasprorrogados, p.data_vencimento = :data_vencimento, p.tid = :tid where p.id =: id" , EsquemaBanco); comando.AdicionarParametroEntrada("id", periodicidade.Id, DbType.Int32); comando.AdicionarParametroEntrada("situacao", periodicidade.Situacao.Id, DbType.Int32); comando.AdicionarParametroEntrada("diasprorrogados", (periodicidade.DiasProrrogados.HasValue) ? periodicidade.DiasProrrogados : 0, DbType.Int32); comando.AdicionarParametroEntrada("data_vencimento", (periodicidade.DataVencimento.Data.HasValue) ? periodicidade.DataVencimento.Data : (object)DBNull.Value, DbType.DateTime); comando.AdicionarParametroEntrada("tid", DbType.String, 36, GerenciadorTransacao.ObterIDAtual()); } bancoDeDados.ExecutarNonQuery(comando); #endregion #region Histórico Historico.Gerar(condicionante.Id, eHistoricoArtefato.titulocondicionante, eHistoricoAcao.prorrogar, bancoDeDados); #endregion bancoDeDados.Commit(); } }
internal bool Prorrogar(TituloCondicionante cond, TituloCondicionantePeriodicidade periodicidade, int?diasProrrogados) { if (cond == null) { Validacao.Add(Mensagem.Condicionante.Inexistente); return(false); } if (!IdValido(cond.Id)) { return(Validacao.EhValido); } if (!cond.PossuiPrazo) { Validacao.Add(Mensagem.Condicionante.ProrrogarNaoPossuiPrazo); return(Validacao.EhValido); } if (cond.Situacao.Id == 1 || !cond.DataVencimento.Data.HasValue) { Validacao.Add(Mensagem.Condicionante.NaoAtiva); } if (diasProrrogados == null || !diasProrrogados.HasValue || diasProrrogados.Value == 0) { Validacao.Add(Mensagem.Condicionante.ProrrogarDiasObrigatorio); } if (cond.Situacao.Id == 4 || cond.Situacao.Id == 5) { Validacao.Add(Mensagem.Condicionante.ProrrogarAtentidaEncerrada); } if (cond.PossuiPeriodicidade) { if (periodicidade != null && periodicidade.Situacao.Id == 4 || periodicidade.Situacao.Id == 5) { Validacao.Add(Mensagem.Condicionante.ProrrogarAtentidaEncerrada); } } return(Validacao.EhValido); }
public TituloCondicionante Atender(int condicionanteId, int periodicidadeId) { TituloCondicionante cond = null; TituloCondicionantePeriodicidade periodicidade = null; try { if (condicionanteId > 0) { cond = _da.Obter(condicionanteId); if (periodicidadeId > 0) { periodicidade = cond.Periodicidades.SingleOrDefault(x => x.Id == periodicidadeId); } } if (_validar.Atender(cond, periodicidade)) { if (cond.Situacao.Id != 4) { if (periodicidadeId == 0) { //4 - Prorrogado cond.Situacao = _listaBus.TituloCondicionanteSituacoes.Single(x => x.Id == 4); } else { periodicidade.Situacao = _listaBus.TituloCondicionanteSituacoes.Single(x => x.Id == 4); } _da.AlterarSituacao(cond, periodicidade); } } } catch (Exception exc) { Validacao.AddErro(exc); } return(cond); }
internal void AlterarSituacao(TituloCondicionante condicionante, TituloCondicionantePeriodicidade periodicidade = null, BancoDeDados banco = null) { GerenciadorTransacao.ObterIDAtual(); using (BancoDeDados bancoDeDados = BancoDeDados.ObterInstancia(banco)) { #region Condicionante de Título bancoDeDados.IniciarTransacao(); Comando comando = null; if (periodicidade == null) { comando = bancoDeDados.CriarComando(@"update {0}tab_titulo_condicionantes c set c.situacao = :situacao, c.tid = :tid where c.id =: id", EsquemaBanco); comando.AdicionarParametroEntrada("id", condicionante.Id, DbType.Int32); comando.AdicionarParametroEntrada("situacao", condicionante.Situacao.Id, DbType.Int32); } else { comando = bancoDeDados.CriarComando(@"update {0}tab_titulo_condicionantes_peri c set c.situacao = :situacao, c.tid = :tid where c.id =: id", EsquemaBanco); comando.AdicionarParametroEntrada("id", periodicidade.Id, DbType.Int32); comando.AdicionarParametroEntrada("situacao", periodicidade.Situacao.Id, DbType.Int32); } comando.AdicionarParametroEntrada("tid", DbType.String, 36, GerenciadorTransacao.ObterIDAtual()); bancoDeDados.ExecutarNonQuery(comando); #endregion #region Histórico Historico.Gerar(condicionante.Id, eHistoricoArtefato.titulocondicionante, eHistoricoAcao.alterarsituacao, bancoDeDados); #endregion bancoDeDados.Commit(); } }
public void AlterarSituacao(Titulo titulo, int acao, BancoDeDados banco, bool gerouPdf = true) { Titulo atualTitulo = _da.ObterSimplificado(titulo.Id); if (titulo.Modelo.Regras == null || titulo.Modelo.Regras.Count == 0) { titulo.Modelo = _busModelo.Obter(titulo.Modelo.Id); } titulo.Situacao = ObterNovaSituacao(titulo, acao); bool isLimparPdfENumero = false; bool isGerarNumero = false; bool isGerarPdf = false; int novaSituacaoCondicionante = 0; if (titulo.Modelo.Codigo == (int)eTituloModeloCodigo.CertificadoRegistroAtividadeFlorestal) { if (titulo.Atividades.Any(x => x.Codigo == (int)eAtividadeCodigo.FabricanteMotosserra) || titulo.Atividades.Any(x => x.Codigo == (int)eAtividadeCodigo.ComercianteMotosserra)) { titulo.Prazo = 365; } else { titulo.Prazo = new DateTime(DateTime.Now.Year, 12, 31).DayOfYear - titulo.DataEmissao.Data.Value.DayOfYear; } } if (!_validar.AlterarSituacao(titulo, acao, gerouPdf)) { return; } #region Configurar Nova Situacao //Situação Nova switch ((eTituloSituacao)titulo.Situacao.Id) { #region 1 - Cadastrado case eTituloSituacao.Cadastrado: if (atualTitulo.Situacao.Id == (int)eTituloSituacao.Emitido) { if (titulo.Modelo.Regra(eRegra.NumeracaoAutomatica)) { titulo.Numero.Inteiro = null; titulo.Numero.Ano = null; } } titulo.DataEmissao.Data = null; titulo.DataInicioPrazo.Data = null; titulo.DataAssinatura.Data = null; titulo.DataVencimento.Data = null; titulo.DataEncerramento.Data = null; titulo.Prazo = null; isLimparPdfENumero = true; break; #endregion #region 2 - Emitido case eTituloSituacao.Emitido: isGerarNumero = true; isGerarPdf = true; //titulo.DataEmissao info na tela if (titulo.Modelo.Regra(eRegra.Prazo)) { int prazoId = Convert.ToInt32(titulo.Modelo.Resposta(eRegra.Prazo, eResposta.TipoPrazo).Valor); titulo.PrazoUnidade = _busLista.TituloModeloTiposPrazos.Single(x => x.Id == prazoId).Texto; } break; #endregion #region 3 - Concluído case eTituloSituacao.Concluido: if (titulo.Modelo.Regra(eRegra.Condicionantes)) { novaSituacaoCondicionante = 2; } if (atualTitulo.Situacao.Id == (int)eTituloSituacao.Cadastrado) { isGerarNumero = true; isGerarPdf = true; } //titulo.DataAssinatura info na tela if (titulo.Modelo.Regra(eRegra.Prazo)) { int prazoId = Convert.ToInt32(titulo.Modelo.Resposta(eRegra.Prazo, eResposta.TipoPrazo).Valor); titulo.PrazoUnidade = _busLista.TituloModeloTiposPrazos.Single(x => x.Id == prazoId).Texto; switch ((eAlterarSituacaoAcao)acao) { case eAlterarSituacaoAcao.EmitirParaAssinatura: titulo.DataInicioPrazo.Data = titulo.DataEmissao.Data.GetValueOrDefault(); break; case eAlterarSituacaoAcao.Assinar: titulo.DataInicioPrazo.Data = titulo.DataAssinatura.Data.GetValueOrDefault(); break; case eAlterarSituacaoAcao.Entregar: case eAlterarSituacaoAcao.Concluir: if (titulo.Modelo.Resposta(eRegra.Prazo, eResposta.InicioPrazo).Valor.ToString() == "2") //data da assinatura { titulo.DataInicioPrazo.Data = titulo.DataAssinatura.Data.GetValueOrDefault(); } else { titulo.DataInicioPrazo.Data = titulo.DataEmissao.Data.GetValueOrDefault(); } break; default: titulo.DataInicioPrazo.Data = DateTime.Now; break; } if (prazoId == 1) //Dias { titulo.DataVencimento.Data = titulo.DataInicioPrazo.Data.Value.AddDays(titulo.Prazo.GetValueOrDefault()); } else { titulo.DataVencimento.Data = titulo.DataInicioPrazo.Data.Value.AddYears(titulo.Prazo.GetValueOrDefault()); } } break; #endregion #region 4 - Assinado case eTituloSituacao.Assinado: //titulo.DataAssinatura info na tela break; #endregion #region 5 - Encerrado case eTituloSituacao.Encerrado: if (titulo.Modelo.Regra(eRegra.Condicionantes)) { novaSituacaoCondicionante = 5; } break; #endregion #region 6 - Prorrogado case eTituloSituacao.Prorrogado: if (titulo.Modelo.Regra(eRegra.Prazo)) { titulo.DataVencimento.Data = titulo.DataVencimento.Data.Value.AddDays(titulo.DiasProrrogados.GetValueOrDefault()); } break; #endregion } #endregion #region Numero de Titulo if (isGerarNumero) { titulo.Numero.ReiniciaPorAno = titulo.Modelo.Regra(eRegra.NumeracaoReiniciada); if (titulo.Modelo.Regra(eRegra.NumeracaoAutomatica)) { titulo.Numero.Automatico = true; TituloModeloResposta iniciarEm = titulo.Modelo.Resposta(eRegra.NumeracaoAutomatica, eResposta.InicioNumeracao); titulo.Numero.IniciaEm = null; titulo.Numero.IniciaEmAno = null; if (iniciarEm != null) { if (iniciarEm.Valor == null || !ValidacoesGenericasBus.ValidarMaskNumeroBarraAno(iniciarEm.Valor.ToString())) { Validacao.Add(Mensagem.Titulo.IniciarEmInvalido); return; } string[] iniciar = iniciarEm.Valor.ToString().Split('/'); titulo.Numero.IniciaEm = Convert.ToInt32(iniciar[0]); titulo.Numero.IniciaEmAno = Convert.ToInt32(iniciar[1]); if (titulo.Numero.IniciaEmAno.GetValueOrDefault() != DateTime.Now.Year) { titulo.Numero.IniciaEm = null; titulo.Numero.IniciaEmAno = null; } } } if (titulo.DataEmissao.IsValido) { titulo.Numero.Ano = titulo.DataEmissao.Data.Value.Year; } } //Limpar numero if (isLimparPdfENumero) { if (titulo.Modelo.Regra(eRegra.NumeracaoAutomatica)) { titulo.Numero = null; } } #endregion if (isLimparPdfENumero) { titulo.ArquivoPdf.Id = null; } GerenciadorTransacao.ObterIDAtual(); using (BancoDeDados bancoDeDados = BancoDeDados.ObterInstancia(banco)) { bancoDeDados.IniciarTransacao(); #region Condicionante if (novaSituacaoCondicionante > 0) { foreach (var item in titulo.Condicionantes) { TituloCondicionante condicionanteAtual = _daCondicionante.Obter(item.Id, bancoDeDados); //Filtro para não alterar as 4 - atendida if (novaSituacaoCondicionante == 5 && condicionanteAtual.Situacao.Id == 4) //5 - encerrada | 4 - atendida { continue; } //Ativa a condicionante if (novaSituacaoCondicionante == 2 && condicionanteAtual.Situacao.Id != 2) { if (condicionanteAtual.PossuiPrazo) { //Regras do Modelo Sem Prazo em Condicionantes com Prazo if (!titulo.Modelo.Regra(eRegra.Prazo)) { condicionanteAtual.DataInicioPrazo.Data = titulo.DataEmissao.Data; condicionanteAtual.DataVencimento.Data = titulo.DataEmissao.Data.Value.AddDays(condicionanteAtual.Prazo.GetValueOrDefault()); } else { condicionanteAtual.DataInicioPrazo = titulo.DataInicioPrazo; condicionanteAtual.DataVencimento.Data = titulo.DataInicioPrazo.Data.Value.AddDays(condicionanteAtual.Prazo.GetValueOrDefault()); } } //Periodicidade if (!item.PossuiPeriodicidade && item.Periodicidades != null) { item.Periodicidades.Clear(); } TituloCondicionantePeriodicidade periodicidade = null; if (item.PossuiPeriodicidade) { int diasTotais = item.PeriodicidadeValor.GetValueOrDefault(); switch (item.PeriodicidadeTipo.Id) { case 1: //dia break; case 2: //Mes diasTotais *= 30; break; case 3: //Ano diasTotais *= 365; break; default: break; } if (item.Prazo.GetValueOrDefault() > 0 && item.Prazo.GetValueOrDefault() <= diasTotais) { int qtdPeriodo = Math.Abs((diasTotais / (item.Prazo.GetValueOrDefault()))); for (int i = 0; i < qtdPeriodo; i++) { periodicidade = new TituloCondicionantePeriodicidade(); periodicidade.Situacao.Id = 2; //Ativa //Regras do Modelo Sem Prazo em Condicionantes com Prazo if (!titulo.Modelo.Regra(eRegra.Prazo)) { periodicidade.DataInicioPrazo.Data = titulo.DataEmissao.Data.Value.AddDays(i * item.Prazo.GetValueOrDefault()); periodicidade.DataVencimento.Data = titulo.DataEmissao.Data.Value.AddDays((i + 1) * item.Prazo.GetValueOrDefault()); } else { periodicidade.DataInicioPrazo.Data = titulo.DataInicioPrazo.Data.Value.AddDays(i * item.Prazo.GetValueOrDefault()); periodicidade.DataVencimento.Data = titulo.DataInicioPrazo.Data.Value.AddDays((i + 1) * item.Prazo.GetValueOrDefault()); } item.Periodicidades.Add(periodicidade); } } } condicionanteAtual.Periodicidades = item.Periodicidades; condicionanteAtual.Situacao.Id = novaSituacaoCondicionante; _daCondicionante.Ativar(condicionanteAtual, bancoDeDados); } else { condicionanteAtual.Situacao.Id = novaSituacaoCondicionante; _daCondicionante.AlterarSituacao(condicionanteAtual, banco: bancoDeDados); } } } #endregion _da.AlterarSituacao(titulo, bancoDeDados); #region Atividades TituloBus tituloBus = new TituloBus(); AtividadeBus atividadeBus = new AtividadeBus(); List <Atividade> lstTituloAtividades = null; #region Título Concluido if (titulo.Situacao.Id == (int)eTituloSituacao.Concluido) //3 - Concluido { lstTituloAtividades = tituloBus.ObterAtividades(titulo.Id); if (lstTituloAtividades != null && lstTituloAtividades.Count > 0) { int?situacao = null; if (EspecificiadadeBusFactory.Possui(titulo.Modelo.Codigo.GetValueOrDefault())) { IEspecificidadeBus busEsp = EspecificiadadeBusFactory.Criar(titulo.Modelo.Codigo.GetValueOrDefault()); situacao = busEsp.ObterSituacaoAtividade(titulo.Id); } if (situacao != null || LstModeloCodigoPendencia.Any(x => x == titulo.Modelo.Codigo.GetValueOrDefault()) || LstModeloCodigoIndeferido.Any(x => x == titulo.Modelo.Codigo.GetValueOrDefault())) { eAtividadeSituacao atividadeSituacao = (LstModeloCodigoPendencia.Any(x => x == titulo.Modelo.Codigo.GetValueOrDefault())) ? eAtividadeSituacao.ComPendencia : eAtividadeSituacao.Indeferida; if (situacao != null) { atividadeSituacao = (eAtividadeSituacao)situacao; } atividadeBus.AlterarSituacao(lstTituloAtividades, atividadeSituacao, bancoDeDados); } else { foreach (Atividade atividade in lstTituloAtividades) { if (atividadeBus.VerificarDeferir(atividade, bancoDeDados)) { atividade.SituacaoId = (int)eAtividadeSituacao.Deferida; atividadeBus.AlterarSituacao(atividade, bancoDeDados); } } } } } #endregion #region Título Encerrado if (titulo.Situacao.Id == (int)eTituloSituacao.Encerrado) //Encerrado { lstTituloAtividades = tituloBus.ObterAtividades(titulo.Id); eAtividadeSituacao situacaoAtual = eAtividadeSituacao.EmAndamento; if (lstTituloAtividades != null && lstTituloAtividades.Count > 0) { foreach (Atividade atividade in lstTituloAtividades) { situacaoAtual = (eAtividadeSituacao)atividadeBus.ObterAtividadeSituacao(atividade, bancoDeDados).SituacaoId; if (situacaoAtual == eAtividadeSituacao.Indeferida || situacaoAtual == eAtividadeSituacao.ComPendencia) { atividade.SituacaoId = (int)eAtividadeSituacao.EmAndamento; atividadeBus.AlterarSituacao(atividade, bancoDeDados); } else { if (titulo.MotivoEncerramentoId == 1 || titulo.MotivoEncerramentoId == 4) { atividade.SituacaoId = (int)eAtividadeSituacao.EmAndamento; atividadeBus.AlterarSituacao(atividade, bancoDeDados); } else if (atividadeBus.VerificarEncerrar(atividade, bancoDeDados)) { atividade.SituacaoId = (int)eAtividadeSituacao.Encerrada; atividadeBus.AlterarSituacao(atividade, bancoDeDados); } } } } } #endregion #region Título Prorrogado if (titulo.Situacao.Id == (int)eTituloSituacao.Prorrogado) //6 - Prorrogar { lstTituloAtividades = tituloBus.ObterAtividades(titulo.Id); if (lstTituloAtividades != null && lstTituloAtividades.Count > 0) { if (LstModeloCodigoPendencia.Any(x => x == titulo.Modelo.Codigo) || LstModeloCodigoIndeferido.Any(x => x == titulo.Modelo.Codigo)) { eAtividadeSituacao atividadeSituacao = (LstModeloCodigoPendencia.Any(x => x == titulo.Modelo.Codigo)) ? eAtividadeSituacao.ComPendencia : eAtividadeSituacao.Indeferida; atividadeBus.AlterarSituacao(lstTituloAtividades, atividadeSituacao, bancoDeDados); } else { int finalidade = _da.VerificarEhTituloAnterior(titulo); if (finalidade > 0) { eAtividadeSituacao atividadeSituacao = (finalidade == 1) ? eAtividadeSituacao.NovaFase : eAtividadeSituacao.EmRenovacao; atividadeBus.AlterarSituacao(lstTituloAtividades, atividadeSituacao, bancoDeDados); } else { foreach (Atividade atividade in lstTituloAtividades) { if (atividadeBus.VerificarDeferir(atividade, bancoDeDados)) { atividade.SituacaoId = (int)eAtividadeSituacao.Deferida; atividadeBus.AlterarSituacao(atividade, bancoDeDados); continue; } //Voltar a situação default de andamento atividade.SituacaoId = (int)eAtividadeSituacao.EmAndamento; atividadeBus.AlterarSituacao(atividade, bancoDeDados); } } } } } #endregion #endregion #region Gerar Pdf de Titulo ArquivoBus arqBus = new ArquivoBus(eExecutorTipo.Interno); if (isGerarPdf && titulo.Modelo.Regra(eRegra.PdfGeradoSistema)) { TituloBus bus = new TituloBus(); titulo.ArquivoPdf.Nome = "Titulo.pdf"; titulo.ArquivoPdf.Extensao = ".pdf"; titulo.ArquivoPdf.ContentType = "application/pdf"; titulo.ArquivoPdf.Buffer = bus.GerarPdf(titulo, bancoDeDados); if (titulo.ArquivoPdf.Buffer != null) { arqBus.Salvar(titulo.ArquivoPdf); ArquivoDa _arquivoDa = new ArquivoDa(); _arquivoDa.Salvar(titulo.ArquivoPdf, User.EtramiteIdentity.FuncionarioId, User.EtramiteIdentity.Name, User.EtramiteIdentity.Login, (int)eExecutorTipo.Interno, User.EtramiteIdentity.FuncionarioTid, bancoDeDados); _da.SalvarPdfTitulo(titulo, bancoDeDados); } } #endregion #region Análise de Item //Trava a Análise de item de processo/documento caso o titulo que está sendo alterado seja um de pendência if (titulo.Atividades != null && titulo.Atividades.Count > 0) { Protocolo protocolo = titulo.Atividades.First().Protocolo; AnaliseItem analise = _busAnalise.Obter(protocolo); if (analise != null && analise.Id > 0) { if (_busTitulo.ExisteTituloPendencia(protocolo, bancoDeDados)) { if (analise.Situacao == 1) // 1 - Em andamento { analise.Situacao = 2; // 2 - Com Pendência _busAnalise.AlterarSituacao(analise, bancoDeDados); } } else if (analise.Situacao == 2) { analise.Situacao = 1; _busAnalise.AlterarSituacao(analise, bancoDeDados); } } } #endregion #region Gerar/Enviar Email #region Gerar Email Email email = null; if (titulo.Situacao.Id == (int)eTituloSituacao.Concluido && titulo.Modelo.Regra(eRegra.EnviarEmail)) //3 - Concluido { if (titulo.Modelo.Resposta(eRegra.EnviarEmail, eResposta.TextoEmail).Valor != null) { string textoEmail = titulo.Modelo.Resposta(eRegra.EnviarEmail, eResposta.TextoEmail).Valor.ToString(); if (!String.IsNullOrWhiteSpace(textoEmail)) { Dictionary <String, String> emailKeys = new Dictionary <string, string>(); emailKeys.Add("[orgão sigla]", _configSys.Obter <String>(ConfiguracaoSistema.KeyOrgaoSigla)); emailKeys.Add("[data da conclusão]", titulo.Modelo.Regra(eRegra.Prazo) ? titulo.DataInicioPrazo.DataTexto : titulo.DataEmissao.DataTexto); emailKeys.Add("[nome do modelo]", titulo.Modelo.Nome); emailKeys.Add("[nome do subtipo]", titulo.Modelo.SubTipo); emailKeys.Add("[nº do título]", titulo.Numero.Texto); emailKeys.Add("[nº processo/documento do título]", titulo.Protocolo.Numero); emailKeys.Add("[nome do empreendimento]", titulo.EmpreendimentoTexto); foreach (string key in emailKeys.Keys) { textoEmail = textoEmail.Replace(key, emailKeys[key]); } email = new Email(); email.Assunto = _configSys.Obter <String>(ConfiguracaoSistema.KeyOrgaoSigla); email.Texto = textoEmail; email.Tipo = eEmailTipo.TituloConcluir; email.Codigo = titulo.Id; } } } #endregion if (email != null) { List <String> lstEmail = _da.ObterEmails(titulo.Id, bancoDeDados); if (lstEmail != null && lstEmail.Count > 0) { email.Destinatario = String.Join(", ", lstEmail.ToArray()); if (titulo.Modelo.Regra(eRegra.AnexarPDFTitulo)) { email.Anexos.Add(titulo.ArquivoPdf); } EmailBus emailBus = new EmailBus(); emailBus.Enviar(email, bancoDeDados); } } #endregion #region [ Solicitação CAR ] if (LstCadastroAmbientalRuralTituloCodigo.Any(x => x == titulo.Modelo.Codigo)) { if (titulo.Situacao.Id == (int)eTituloSituacao.Concluido) { //Interno List <int> situacoes = new List <int>() { (int)eCARSolicitacaoSituacao.EmCadastro, (int)eCARSolicitacaoSituacao.Pendente, (int)eCARSolicitacaoSituacao.Valido, (int)eCARSolicitacaoSituacao.Suspenso }; CARSolicitacao solicitacao = _busCARSolicitacao.ObterPorEmpreendimento(titulo.EmpreendimentoId.GetValueOrDefault(0), situacoes, false, bancoDeDados) ?? new CARSolicitacao(); if (solicitacao != null && solicitacao.Id > 0) { solicitacao.SituacaoId = (int)eCARSolicitacaoSituacao.SubstituidoPeloTituloCAR; solicitacao.DataSituacao.Data = DateTime.Now; _busCARSolicitacao.AlterarSituacao(solicitacao, bancoDeDados, mostrarMsg: false); } else { //Credenciado _busCARSolicitacao.SubstituirPorTituloCARCredenciado(titulo.EmpreendimentoId.GetValueOrDefault(0), bancoDeDados); } } if (titulo.Situacao.Id == (int)eTituloSituacao.Encerrado) { List <int> situacoes = new List <int>() { (int)eCARSolicitacaoSituacao.SubstituidoPeloTituloCAR }; CARSolicitacao solicitacao = _busCARSolicitacao.ObterPorEmpreendimento(titulo.EmpreendimentoId.GetValueOrDefault(0), situacoes, false, bancoDeDados) ?? new CARSolicitacao(); if (solicitacao != null && solicitacao.Id > 0) { solicitacao.SituacaoAnteriorId = solicitacao.SituacaoId; solicitacao.DataSituacaoAnterior = solicitacao.DataSituacao; solicitacao.SituacaoId = (int)eCARSolicitacaoSituacao.Valido; solicitacao.DataSituacao.Data = DateTime.Now; _busCARSolicitacao.AlterarSituacao(solicitacao, bancoDeDados, mostrarMsg: false); } else { //Credenciado Empreendimento empreendimento = new EmpreendimentoBus().ObterSimplificado(titulo.EmpreendimentoId.GetValueOrDefault(0)); CARSolicitacaoCredenciadoBus carSolicitacaoCredBus = new CARSolicitacaoCredenciadoBus(); CARSolicitacao carSolicitacaoCred = new CARSolicitacao(); carSolicitacaoCred.Empreendimento.Codigo = empreendimento.Codigo; carSolicitacaoCredBus.AlterarSituacao(carSolicitacaoCred, new CARSolicitacao() { SituacaoId = (int)eCARSolicitacaoSituacao.Valido }); } } //SE situacao == Encerrado //TODO:Mudar Situação para Válido } #endregion if (!Validacao.EhValido) { bancoDeDados.Rollback(); return; } #region Salvar A especificidade if (EspecificiadadeBusFactory.Possui(titulo.Modelo.Codigo.GetValueOrDefault())) { IEspecificidadeBus busEsp = EspecificiadadeBusFactory.Criar(titulo.Modelo.Codigo.GetValueOrDefault()); titulo.Especificidade = busEsp.Obter(titulo.Id) as Especificidade; titulo.Especificidade = titulo.ToEspecificidade(); busEsp.Salvar(titulo.Especificidade, bancoDeDados); List <DependenciaLst> lstDependencias = busEsp.ObterDependencias(titulo.Especificidade); if (isGerarPdf && lstDependencias != null && lstDependencias.Count > 0) { if (!lstDependencias.Exists(x => x.TipoId == (int)eTituloDependenciaTipo.Caracterizacao && x.DependenciaTipo == (int)eCaracterizacao.Dominialidade)) { lstDependencias.Add(new DependenciaLst() { TipoId = (int)eTituloDependenciaTipo.Caracterizacao, DependenciaTipo = (int)eCaracterizacao.Dominialidade }); } _da.Dependencias(titulo.Id, titulo.Modelo.Id, titulo.EmpreendimentoId.GetValueOrDefault(), lstDependencias); } } #endregion #region Histórico eHistoricoAcao eAcao; switch ((eAlterarSituacaoAcao)acao) { case eAlterarSituacaoAcao.EmitirParaAssinatura: eAcao = eHistoricoAcao.emitir; break; case eAlterarSituacaoAcao.CancelarEmissao: eAcao = eHistoricoAcao.cancelaremissao; break; case eAlterarSituacaoAcao.Assinar: eAcao = eHistoricoAcao.assinar; break; case eAlterarSituacaoAcao.Prorrogar: eAcao = eHistoricoAcao.prorrogar; break; case eAlterarSituacaoAcao.Encerrar: eAcao = eHistoricoAcao.encerrar; break; case eAlterarSituacaoAcao.Entregar: eAcao = eHistoricoAcao.entregar; break; default: eAcao = eHistoricoAcao.emitir; break; } _da.Historico.Gerar(titulo.Id, eHistoricoArtefato.titulo, eAcao, bancoDeDados); _da.Consulta.Gerar(titulo.Id, eHistoricoArtefato.titulo, bancoDeDados); #region Solicitacao CAR if (LstCadastroAmbientalRuralTituloCodigo.Any(x => x == titulo.Modelo.Codigo.GetValueOrDefault())) { if (titulo.Situacao.Id != (int)eTituloSituacao.Concluido) { _da.Consulta.Deletar(titulo.Id, eHistoricoArtefato.carsolicitacaotitulo, bancoDeDados); } else { _da.Consulta.Gerar(titulo.Id, eHistoricoArtefato.carsolicitacaotitulo, bancoDeDados); } } #endregion #endregion bancoDeDados.Commit(); Validacao.Add(Mensagem.TituloAlterarSituacao.TituloAltSituacaoSucesso); } }
public void Salvar(Titulo titulo) { try { titulo.Autor = new Funcionario() { Id = User.FuncionarioId }; if (titulo.Id <= 0) { titulo.Situacao.Id = (int)eTituloSituacao.Cadastrado; titulo.DataCriacao.Data = DateTime.Now; } if (titulo.Modelo.Regra(eRegra.NumeracaoAutomatica)) { titulo.Numero.Inteiro = null; titulo.Numero.Ano = null; } //Carrega o Modelo e suas regras do modelo titulo.Modelo = _busModelo.Obter(titulo.Modelo.Id); if (titulo.Condicionantes != null && titulo.Condicionantes.Count > 0) { foreach (var cond in titulo.Condicionantes) { if (!cond.PossuiPrazo || !cond.PossuiPeriodicidade) { if (cond.Periodicidades != null) { cond.Periodicidades.Clear(); } continue; } TituloCondicionantePeriodicidade periodicidade = new TituloCondicionantePeriodicidade(); periodicidade.Situacao.Id = 1; } } IEspecificidadeBus busEsp = EspecificiadadeBusFactory.Criar(titulo.Modelo.Codigo.GetValueOrDefault()); string jsonEsp = (titulo.Especificidade != null) ? titulo.Especificidade.Json : null; titulo.Especificidade = (Especificidade)busEsp.Deserialize(jsonEsp); titulo.Especificidade = titulo.ToEspecificidade(); //Delega a validação de especificidade _validar.ValidarEspecificidade = () => { busEsp.Validar.Salvar(titulo.Especificidade); }; if (_validar.Salvar(titulo)) { #region Arquivos/Diretorio ArquivoBus _busArquivo = new ArquivoBus(eExecutorTipo.Interno); if (!titulo.Modelo.Regra(eRegra.PdfGeradoSistema) && titulo.ArquivoPdf.Id == 0) { titulo.ArquivoPdf = _busArquivo.Copiar(titulo.ArquivoPdf); } if (titulo.Anexos != null && titulo.Anexos.Count > 0) { foreach (Anexo anexo in titulo.Anexos) { if (anexo.Arquivo.Id == 0) { anexo.Arquivo = _busArquivo.Copiar(anexo.Arquivo); } } } #endregion using (BancoDeDados bancoDeDados = BancoDeDados.ObterInstancia()) { GerenciadorTransacao.ObterIDAtual(); bancoDeDados.IniciarTransacao(); #region Arquivos/Banco ArquivoDa arquivoDa = new ArquivoDa(); if (!titulo.Modelo.Regra(eRegra.PdfGeradoSistema)) { arquivoDa.Salvar(titulo.ArquivoPdf, User.FuncionarioId, User.Name, User.Login, (int)eExecutorTipo.Interno, User.FuncionarioTid, bancoDeDados); } if (titulo.Anexos != null && titulo.Anexos.Count > 0) { foreach (Anexo anexo in titulo.Anexos) { if (anexo.Arquivo.Id == 0) { arquivoDa.Salvar(anexo.Arquivo, User.FuncionarioId, User.Name, User.Login, (int)eExecutorTipo.Interno, User.FuncionarioTid, bancoDeDados); } } } #endregion _da.Salvar(titulo, bancoDeDados); //Atualiza os Ids em Especificidade titulo.Especificidade = titulo.ToEspecificidade(); busEsp.Salvar(titulo.Especificidade, bancoDeDados); //Trata quando o catch do busEsp.Salvar silencia o erro. if (!Validacao.EhValido) { return; } bancoDeDados.Commit(); } Validacao.Add(Mensagem.Titulo.Salvar); if (LstCadastroAmbientalRuralTituloCodigo.Any(x => x == titulo.Modelo.Codigo)) { Validacao.Add(Mensagem.Retificacao.msgInst4()); } } } catch (Exception exc) { Validacao.AddErro(exc); } }
internal TituloCondicionante Obter(int id, BancoDeDados banco = null) { TituloCondicionante condicionante = new TituloCondicionante(); using (BancoDeDados bancoDeDados = BancoDeDados.ObterInstancia(banco)) { #region Condicionante de Título Comando comando = bancoDeDados.CriarComando(@"select (select min(htc.data_execucao) idc from hst_titulo_condicionantes htc where htc.condicionante_id = c.id) data_criacao, c.id, c.titulo, (case when tn.numero is not null then tn.numero||'/'||tn.ano else null end) titulo_numero, ls.id situacao_id, ls.texto situacao_texto, c.descricao, c.possui_prazo, c.data_vencimento, c.data_inicio, c.dias_prorrogados, c.prazo, c.periodicidade, c.periodo, lp.id periodo_tipo_id, lp.texto periodo_tipo_texto, c.tid from {0}tab_titulo_condicionantes c, {0}tab_titulo t, {0}tab_titulo_numero tn, {0}lov_titulo_cond_situacao ls, {0}lov_titulo_cond_periodo_tipo lp where t.id = tn.titulo(+) and c.titulo = t.id and c.situacao = ls.id and c.periodo_tipo = lp.id(+) and c.id = :id" , EsquemaBanco); comando.AdicionarParametroEntrada("id", id, DbType.Int32); using (IDataReader reader = bancoDeDados.ExecutarReader(comando)) { if (reader.Read()) { condicionante.Id = id; condicionante.Tid = reader["tid"].ToString(); condicionante.tituloId = Convert.ToInt32(reader["titulo"]); condicionante.tituloNumero = reader["titulo_numero"].ToString(); condicionante.Situacao.Id = Convert.ToInt32(reader["situacao_id"]); condicionante.Situacao.Texto = reader["situacao_texto"].ToString(); condicionante.Descricao = reader["descricao"].ToString(); condicionante.PossuiPrazo = Convert.ToInt32(reader["possui_prazo"]) > 0; if (reader["prazo"] != null && !Convert.IsDBNull(reader["prazo"])) { condicionante.Prazo = Convert.ToInt32(reader["prazo"]); } if (reader["dias_prorrogados"] != null && !Convert.IsDBNull(reader["dias_prorrogados"])) { condicionante.DiasProrrogados = Convert.ToInt32(reader["dias_prorrogados"]); } if (reader["data_inicio"] != null && !Convert.IsDBNull(reader["data_inicio"])) { condicionante.DataInicioPrazo.Data = Convert.ToDateTime(reader["data_inicio"]); } if (reader["data_criacao"] != null && !Convert.IsDBNull(reader["data_criacao"])) { condicionante.DataCriacao.Data = Convert.ToDateTime(reader["data_criacao"]); } if (reader["data_vencimento"] != null && !Convert.IsDBNull(reader["data_vencimento"])) { condicionante.DataVencimento.Data = Convert.ToDateTime(reader["data_vencimento"]); } condicionante.PossuiPeriodicidade = Convert.ToInt32(reader["periodicidade"]) > 0; if (reader["periodo"] != null && !Convert.IsDBNull(reader["periodo"])) { condicionante.PeriodicidadeValor = Convert.ToInt32(reader["periodo"]); } if (reader["periodo_tipo_id"] != null && !Convert.IsDBNull(reader["periodo_tipo_id"])) { condicionante.PeriodicidadeTipo.Id = Convert.ToInt32(reader["periodo_tipo_id"]); condicionante.PeriodicidadeTipo.Texto = reader["periodo_tipo_texto"].ToString(); } } reader.Close(); } comando = bancoDeDados.CriarComando(@"select p.id, p.situacao, ls.texto situacao_texto, p.dias_prorrogados, p.data_inicio, p.data_vencimento, p.tid from {0}tab_titulo_condicionantes_peri p, {0}lov_titulo_cond_situacao ls where p.situacao = ls.id and p.condicionante = :id" , EsquemaBanco); comando.AdicionarParametroEntrada("id", id, DbType.Int32); using (IDataReader reader = bancoDeDados.ExecutarReader(comando)) { TituloCondicionantePeriodicidade periodicidade = null; while (reader.Read()) { periodicidade = new TituloCondicionantePeriodicidade(); periodicidade.Id = Convert.ToInt32(reader["id"]); periodicidade.Tid = reader["tid"].ToString(); periodicidade.Situacao.Id = Convert.ToInt32(reader["situacao"]); periodicidade.Situacao.Texto = reader["situacao_texto"].ToString(); if (reader["dias_prorrogados"] != null && !Convert.IsDBNull(reader["dias_prorrogados"])) { periodicidade.DiasProrrogados = Convert.ToInt32(reader["dias_prorrogados"]); } if (reader["data_inicio"] != null && !Convert.IsDBNull(reader["data_inicio"])) { periodicidade.DataInicioPrazo.Data = Convert.ToDateTime(reader["data_inicio"]); } if (reader["data_vencimento"] != null && !Convert.IsDBNull(reader["data_vencimento"])) { periodicidade.DataVencimento.Data = Convert.ToDateTime(reader["data_vencimento"]); } condicionante.Periodicidades.Add(periodicidade); } reader.Close(); } #endregion } return(condicionante); }