Пример #1
0
 // GET: Apolice/Details/5
 public ActionResult Details(int? id)
 {
     if (id == null)
     {
         return new HttpStatusCodeResult(HttpStatusCode.BadRequest);
     }
     Apolice apolice = db.Apolice.Find(id);
     PropostaDAO propostaDao = new PropostaDAO();
     propostaDao.GetProposta(apolice.CodigoProposta);
     apolice.Proposta = propostaDao.GetProposta(apolice.CodigoProposta);
     apolice.Comissao = db.Comissao.Find(apolice.CodigoComissao);
     apolice.Seguradora = db.Seguradora.Find(apolice.CodigoSeguradora);
     if (apolice == null)
     {
         return HttpNotFound();
     }
     return View(apolice);
 }
Пример #2
0
        // GET: Apolice/Create
        public ActionResult Create(int? propostaId)
        {
            Apolice apolice = new Apolice();

            PropostaDAO propostaDao = new PropostaDAO();
            apolice.Proposta = propostaDao.GetProposta(propostaId);
            apolice.Seguradoras = db.Seguradora.ToList();
            apolice.ValorContrato = 0;
            return View(apolice);
        }
Пример #3
0
 public ActionResult Delete(int? id)
 {
     if (id == null)
     {
         return new HttpStatusCodeResult(HttpStatusCode.BadRequest);
     }
     PropostaDAO propostaDao = new PropostaDAO();
     Proposta proposta = propostaDao.GetProposta(id);
     if (proposta == null)
     {
         return HttpNotFound();
     }
     return View(proposta);
 }
Пример #4
0
        public ViewResult Index(Proposta propostaSearch, string sortOrder, string currentFilter, int? page)
        {
            string searchString = "";
            ViewBag.CurrentSort = sortOrder;
            ViewBag.StatusParm = String.IsNullOrEmpty(sortOrder) ? "status_desc" : "";
            ViewBag.NameSortParm = String.IsNullOrEmpty(sortOrder) ? "nome_desc" : "nome";
            ViewBag.CpfSortParm = String.IsNullOrEmpty(sortOrder) ? "cpf_desc" : "cpf";

            if (searchString != null)
            {
                page = 1;
            }
            else
            {
                searchString = currentFilter;
            }

            ViewBag.CurrentFilter = searchString;

            //old
            List<Proposta> propostas = db.Proposta.ToList();
            List<Proposta> propostasCompleta = new List<Proposta>();
            PropostaDAO propostaDAO = new PropostaDAO();
            foreach (Proposta proposta in propostas)
            {
                propostasCompleta.Add(propostaDAO.GetProposta(proposta.Id));
            }

            //buscas
            if (StatusProposta.NENHUM != propostaSearch.Status)
            {
                propostasCompleta = propostasCompleta.Where(a => (int)a.Status == (int)propostaSearch.Status).ToList();
            }
            if (propostaSearch != null && propostaSearch.Segurado != null && propostaSearch.Segurado.Nome != null)
            {
                propostasCompleta = propostasCompleta.Where(a => a.Segurado.Nome.IndexOf(propostaSearch.Segurado.Nome, StringComparison.OrdinalIgnoreCase) >= 0).ToList();
            }

            switch (sortOrder)
            {
                case "status_desc":
                    propostasCompleta = propostasCompleta.OrderByDescending(p => p.Status).ToList();
                    break;
                case "nome_desc":
                    propostasCompleta = propostasCompleta.OrderByDescending(p => p.Segurado.Nome).ToList();
                    break;
                case "nome":
                    propostasCompleta = propostasCompleta.OrderBy(p => p.Segurado.Nome).ToList();
                    break;
                case "cpf":
                    propostasCompleta = propostasCompleta.OrderBy(p => p.Segurado.CodigoCpf).ToList();
                    break;
                case "cpf_desc":
                    propostasCompleta = propostasCompleta.OrderByDescending(p => p.Segurado.CodigoCpf).ToList();
                    break;

                default:  // Name ascending
                    propostasCompleta = propostasCompleta.OrderBy(p => p.Segurado.Nome).ToList();
                    break;
            }

            int pageSize = 15;
            int pageNumber = (page ?? 1);
            PagedList<Proposta> propostaList = new PagedList<Proposta>(propostasCompleta, pageNumber, pageSize);
            return View(propostaList);
        }
Пример #5
0
        public ActionResult Edit(int? id)
        {
            if (id == null)
            {
                return new HttpStatusCodeResult(HttpStatusCode.BadRequest);
            }

            PropostaDAO propostaDao = new PropostaDAO();
            Proposta proposta = propostaDao.GetProposta(id);
            proposta.Coberturas = db.Cobertura.ToList();

            if (proposta == null)
            {
                return HttpNotFound();
            }
            return View(proposta);
        }
Пример #6
0
        public ActionResult SendForm(Apolice apolice)
        {
            //if (ModelState.IsValid)
            //{
            db.Comissao.Add(apolice.Comissao);
            db.SaveChanges();
            apolice.CodigoComissao = apolice.Comissao.Id;
            db.Apolice.Add(apolice);
            db.SaveChanges();

            PropostaDAO propostaDao = new PropostaDAO();
            Proposta proposta = propostaDao.GetProposta(apolice.CodigoProposta);

            //Mudando Status para fins de organização
            propostaDao.MudarStatus(proposta.Id, (int)StatusProposta.ATENDIDO);

            //criando valor da proposta do condutor
            ValorProposta valorProposta = new ValorProposta();
            valorProposta.Valor = apolice.ValorContrato;
            valorProposta.CodigoCondutor = proposta.Segurado.Id;
            valorProposta.DataVencimento = new DateTime(2016, 05, 12);
            valorProposta.CodigoApolice = apolice.Id;

            db.ValorProposta.Add(valorProposta);
            db.SaveChanges();
            //}

            Usuario usuario = (Usuario)Session["UsuarioLogado"];
            //PREPARANDO EMAIL
            apolice.Seguradora = db.Seguradora.Find(apolice.CodigoSeguradora);
            apolice.formularioApoliceHtml = apolice.formularioApoliceHtml.Replace("#seguradoraEmail", apolice.Seguradora.NomeSeguradora.ToString());
            apolice.formularioApoliceHtml = apolice.formularioApoliceHtml.Replace("#valorContratoEmail", apolice.ValorContrato.ToString());
            apolice.formularioApoliceHtml = apolice.formularioApoliceHtml.Replace("#corretorEmail", "Seu Corretor - " + usuario.Nome);
            string url = Request.Url.AbsoluteUri.Replace(Request.Url.AbsolutePath,"");
            apolice.formularioApoliceHtml = apolice.formularioApoliceHtml.Replace("#EnderecoConfirmaEmail", url + "/Proposta/AceitarProposta?" +
                                                                                                            "email=" + proposta.Segurado.Email +
                                                                                                            "&codigoProposta=" + apolice.CodigoProposta +
                                                                                                            "&codigoApolice=" + apolice.Id);

            UtilEmailMessage utilEmail = new UtilEmailMessage();
            utilEmail.EnviarEmail("[BUSCA SEGUROS] Sua Proposta de Cotação de Seguro", proposta.Segurado.Email, apolice.formularioApoliceHtml);

            return View(apolice);
        }
Пример #7
0
        // GET: Apolice
        public ViewResult Index(Apolice apoliceSearch, string sortOrder, string currentFilter, int? page)
        {
            string searchString = "";
            //List<Apolice> apolices = db.Apolice.ToList();
            //foreach (Apolice apolice in apolices)
            //{
            //    PropostaDAO propostaDao = new PropostaDAO();
            //    propostaDao.GetProposta(apolice.CodigoProposta);
            //    apolice.Proposta = propostaDao.GetProposta(apolice.CodigoProposta);
            //    apolice.Comissao = db.Comissao.Find(apolice.CodigoComissao);
            //    apolice.Seguradora = db.Seguradora.Find(apolice.CodigoSeguradora);
            //}
            //return View(apolices);
            //TODO
            ViewBag.CurrentSort = sortOrder;
            ViewBag.StatusSortParm = String.IsNullOrEmpty(sortOrder) ? "status_desc" : "";
            ViewBag.NomeSeguradoSortParm = String.IsNullOrEmpty(sortOrder) ? "nomeSegurado_desc" : "nomeSegurado";
            ViewBag.SeguradoraSortParm = String.IsNullOrEmpty(sortOrder) ? "seguradora_desc" : "seguradora";
            ViewBag.VeiculoSortParm = String.IsNullOrEmpty(sortOrder) ? "veiculo_desc" : "veiculo";
            ViewBag.ValorPremioLiquidoVeiculoSortParm = String.IsNullOrEmpty(sortOrder) ? "valorPremioLiquido_desc" : "valorPremioLiquido";

            if (searchString != null)
            {
                page = 1;
            }
            else
            {
                searchString = currentFilter;
            }

            ViewBag.CurrentFilter = searchString;

            //TODO: Fazer uma consulta só
            List<Apolice> apolices = db.Apolice.ToList();
            foreach (Apolice apolice in apolices)
            {
                PropostaDAO propostaDao = new PropostaDAO();
                apolice.Proposta = propostaDao.GetProposta(apolice.CodigoProposta);
                apolice.Comissao = db.Comissao.Find(apolice.CodigoComissao);
                apolice.Seguradora = db.Seguradora.Find(apolice.CodigoSeguradora);
            }

            //buscas
            if (Status.NENHUM != apoliceSearch.Status)
            {
                apolices = apolices.Where(a => (int)a.Status == (int)apoliceSearch.Status).ToList();
            }
            if(apoliceSearch.Proposta != null && apoliceSearch.Proposta.Segurado != null && apoliceSearch.Proposta.Segurado.Nome != null)
            {
                apolices = apolices.Where(a => a.Proposta.Segurado.Nome.IndexOf(apoliceSearch.Proposta.Segurado.Nome, StringComparison.OrdinalIgnoreCase) >= 0).ToList();
            }

            //ordenação
            switch (sortOrder)
            {
                case "status_desc":
                    apolices = apolices.OrderByDescending(a => (int)a.Status).ToList();
                    break;
                case "nomeSegurado":
                    apolices = apolices.OrderBy(a => a.Proposta.Segurado.Nome).ToList();
                    break;
                case "nomeSegurado_desc":
                    apolices = apolices.OrderByDescending(a => a.Proposta.Segurado.Nome).ToList();
                    break;
                case "seguradora":
                    apolices = apolices.OrderBy(a => a.Seguradora.NomeSeguradora).ToList();
                    break;
                case "seguradora_desc":
                    apolices = apolices.OrderByDescending(a => a.Seguradora.NomeSeguradora).ToList();
                    break;
                case "veiculo":
                    apolices = apolices.OrderBy(a => a.Proposta.NomeVeiculo).ToList();
                    break;
                case "veiculo_desc":
                    apolices = apolices.OrderByDescending(a => a.Proposta.NomeVeiculo).ToList();
                    break;
                case "valorPremioLiquido":
                    apolices = apolices.OrderBy(a => a.Proposta.NomeVeiculo).ToList();
                    break;
                case "valorPremioLiquido_desc":
                    apolices = apolices.OrderByDescending(a => a.Comissao.ValorComissaoLiquida).ToList();
                    break;
                default:  // Status ascending
                    apolices = apolices.OrderBy(a => (int)a.Status).ToList();
                    break;
            }
            int pageSize = 10;
            int pageNumber = (page ?? 1);
            PagedList<Apolice> apoliceList = new PagedList<Apolice>(apolices, pageNumber, pageSize);
            return View(apoliceList);
        }