public ActionResult MontarMenuDeOperacoes(string uk) { try { IncidenteVeiculo fichaPersistida = IncidenteVeiculoBusiness.Consulta.FirstOrDefault(a => string.IsNullOrEmpty(a.UsuarioExclusao) && a.UniqueKey.Equals(uk)); if (fichaPersistida == null) { throw new Exception("As informações fornecidas para montagem do menu de operações não são válidas."); } Workflow wfPersistida = WorkflowBusiness.Consulta.FirstOrDefault(a => string.IsNullOrEmpty(a.UsuarioExclusao) && a.UKObject.Equals(fichaPersistida.UniqueKey)); if (wfPersistida == null) { //Criar método } else { fichaPersistida.Operacoes = OperacaoBusiness.RecuperarTodasPermitidas(CustomAuthorizationProvider.UsuarioAutenticado.Login, CustomAuthorizationProvider.UsuarioAutenticado.Permissoes, wfPersistida); } return(PartialView("_MenuOperacoes", fichaPersistida)); } catch (Exception ex) { Response.StatusCode = 500; return(Content(ex.Message, "text/html")); } }
public ActionResult Cadastrar(IncidenteVeiculo entidade) { if (ModelState.IsValid) { try { entidade.UniqueKey = Guid.NewGuid().ToString(); entidade.UsuarioInclusao = CustomAuthorizationProvider.UsuarioAutenticado.Login; entidade.Status = "Em Edição"; entidade.Responsavel = entidade.UsuarioInclusao; entidade.Codigo = "I-" + DateTime.Now.Year.ToString() + "-" + IncidenteVeiculoBusiness.GetNextNumber("IncidenteVeiculo", "select max(SUBSTRING(codigo, 8, 6)) from objincidenteveiculo").ToString().PadLeft(6, '0'); entidade.StatusWF = "RS"; entidade.DataAtualizacao = DateTime.Now; IncidenteVeiculoBusiness.Inserir(entidade); Severino.GravaCookie("MensagemSucesso", "O incidente foi cadastrado com sucesso.", 10); Severino.GravaCookie("FuncaoInboxAChamar", "IncidentesVeiculo", 10); Severino.GravaCookie("ObjRecemCriado", entidade.UniqueKey, 10); ReiniciarCache(CustomAuthorizationProvider.UsuarioAutenticado.Login); return(Json(new { resultado = new RetornoJSON() { URL = Url.Action("Index", "Inbox") } })); } catch (Exception ex) { if (ex.GetBaseException() == null) { return(Json(new { resultado = new RetornoJSON() { Erro = ex.Message } })); } else { return(Json(new { resultado = new RetornoJSON() { Erro = ex.GetBaseException().Message } })); } } } else { return(Json(new { resultado = TratarRetornoValidacaoToJSON() })); } }
public ActionResult Detalhes(string uniquekey) { try { if (string.IsNullOrEmpty(uniquekey)) { throw new Exception("Não foi possível localizar o parâmetro que identifica o incidente com veículo."); } else { List <IncidenteVeiculo> lista = IncidenteVeiculoBusiness.Consulta.Where(a => a.UniqueKey.Equals(uniquekey) && string.IsNullOrEmpty(a.UsuarioExclusao)).ToList(); IncidenteVeiculo registro = lista[0]; registro.PassoAtual = WorkflowBusiness.Consulta.FirstOrDefault(a => string.IsNullOrEmpty(a.UsuarioExclusao) && a.UKObject.Equals(registro.UniqueKey)); VMIncidenteVeiculo vm = new VMIncidenteVeiculo(); if (registro.PassoAtual != null) { vm.UKWorkflow = registro.PassoAtual.UniqueKey; vm.StatusWF = registro.PassoAtual.Nome; } else { vm.StatusWF = registro.Status.ToString(); } vm.UniqueKey = registro.UniqueKey; vm.Codigo = registro.Codigo; //vm.Status = registro.Status; vm.Descricao = registro.Descricao; vm.AcidenteFatal = registro.AcidenteFatal ? "Sim" : "Não"; vm.AcidenteGraveIP102 = registro.AcidenteGraveIP102 ? "Sim" : "Não"; vm.Centro = registro.Centro.GetDisplayName(); vm.Regional = registro.Regional.ToString(); vm.NumeroSmart = registro.NumeroSmart; if (registro.ETipoEntrada != 0) { vm.TipoEntrada = registro.ETipoEntrada.GetDisplayName(); } Municipio mun = MunicipioBusiness.Consulta.FirstOrDefault(a => string.IsNullOrEmpty(a.UsuarioExclusao) && a.UniqueKey.Equals(registro.UKMunicipio)); if (mun != null) { vm.Municipio = mun.NomeCompleto; } ESocial eso = ESocialBusiness.Consulta.FirstOrDefault(a => string.IsNullOrEmpty(a.UsuarioExclusao) && a.UniqueKey.Equals(registro.UKESocial)); if (eso != null) { vm.ESocial = eso.Codigo; ViewBag.ESocialDesc = eso.Descricao; } vm.Estado = registro.Estado; vm.Logradouro = registro.Logradouro; vm.NumeroLogradouro = registro.NumeroLogradouro; vm.ETipoAcidente = registro.ETipoAcidente.GetDisplayName(); vm.LocalAcidente = registro.LocalAcidente; Departamento dep = DepartamentoBusiness.Consulta.FirstOrDefault(a => string.IsNullOrEmpty(a.UsuarioExclusao) && a.UniqueKey.Equals(registro.UKOrgao)); if (dep != null) { vm.Orgao = dep.Sigla; } if (registro.TipoLocalAcidente != 0) { vm.TipoLocalAcidente = registro.TipoLocalAcidente.GetDisplayName(); } vm.DataIncidente = registro.DataIncidente.ToString("dd/MM/yyyy"); vm.HoraIncidente = registro.HoraIncidente; vm.DataInclusao = registro.DataInclusao.ToString("dd/MM/yyyy HH:mm"); if (registro.DataAtualizacao != null) { vm.DataAtualizacao = ((DateTime)registro.DataAtualizacao).ToString("dd/MM/yyyy HH:mm"); } vm.UsuarioInclusao = registro.UsuarioInclusao; vm.Arquivos = ArquivoBusiness.Consulta.Where(a => string.IsNullOrEmpty(a.UsuarioExclusao) && a.UKObjeto.Equals(uniquekey)).ToList(); vm.Operacoes = OperacaoBusiness.RecuperarTodasPermitidas(CustomAuthorizationProvider.UsuarioAutenticado.Login, CustomAuthorizationProvider.UsuarioAutenticado.Permissoes, lista); registro.Operacoes = vm.Operacoes; ViewBag.Incidente = registro; vm.Veiculos = (from iv in IncidenteVeiculoVeiculoBusiness.Consulta.Where(p => string.IsNullOrEmpty(p.UsuarioExclusao) && p.UKIncidenteVeiculo.Equals(vm.UniqueKey)).ToList() join v in VeiculoBusiness.Consulta.Where(p => string.IsNullOrEmpty(p.UsuarioExclusao)).ToList() on iv.UKVeiculo equals v.UniqueKey select new VMVeiculo() { TipoCondutor = iv.TipoCondutor, NomeCondutor = iv.NomeCondutor, TipoFrota = v.TipoFrota, Placa = v.Placa, TipoVeiculo = v.TipoVeiculo, UKRel = iv.UniqueKey }).ToList(); vm.Populacao = (from iv in IncidenteVeiculoPopulacaoBusiness.Consulta.Where(p => string.IsNullOrEmpty(p.UsuarioExclusao) && p.UKIncidenteVeiculo.Equals(vm.UniqueKey)).ToList() join v in PopulacaoBusiness.Consulta.Where(p => string.IsNullOrEmpty(p.UsuarioExclusao)).ToList() on iv.UKPopulacao equals v.UniqueKey select new VMPopulacao() { TipoAcidente = iv.TipoAcidente, Atividade = iv.Atividade, Causa = iv.Causa, AgenteCausador = iv.AgenteCausador, DataNascimento = v.DataNascimento.ToString("dd/MM/yyyy"), Sexo = v.Sexo, Nome = v.Nome, Natureza = iv.Natureza, UKPopulacao = v.UniqueKey, UKRel = iv.UniqueKey }).ToList(); vm.Materiais = MaterialBusiness.Consulta.Where(a => string.IsNullOrEmpty(a.UsuarioExclusao) && a.UKIncidente.Equals(vm.UniqueKey)).ToList(); return(PartialView("_DetalhesVeiculo", vm)); } } catch (Exception ex) { if (ex.GetBaseException() == null) { return(Json(new { resultado = new RetornoJSON() { Erro = ex.Message } })); } else { return(Json(new { resultado = new RetornoJSON() { Erro = ex.GetBaseException().Message } })); } } }