PostulanteController.java 9.54 KB
Newer Older
1 2 3
package com.roshka.controller;


4
import java.util.ArrayList;
willgonzz committed
5
import java.util.Date;
6
import java.util.List;
7
import java.util.Locale;
8 9


10
import javax.validation.ConstraintViolationException;
11

12
import com.roshka.DTO.PostulanteListaDTO;
13
import com.roshka.modelo.*;
14 15
import com.fasterxml.jackson.core.JsonProcessingException;
import com.fasterxml.jackson.databind.ObjectMapper;
16
import com.roshka.modelo.Disponibilidad;
17 18
import com.roshka.modelo.EstadoCivil;
import com.roshka.modelo.Nacionalidad;
19
import com.roshka.modelo.Postulante;
20
import com.roshka.modelo.TipoExperiencia;
21
import com.roshka.repositorio.*;
22
import com.roshka.repositorio.CiudadRepository;
willgonzz committed
23
import com.roshka.repositorio.ConvocatoriaRepository;
24
import com.roshka.repositorio.DepartamentoRepository;
25
import com.roshka.repositorio.ExperienciaRepository;
26
import com.roshka.repositorio.InstitucionRepository;
27
import com.roshka.repositorio.PostulanteRepository;
28
import com.roshka.repositorio.TecnologiaRepository;
29
import com.roshka.utils.Helper;
30

31

32 33
import org.hibernate.jpa.TypedParameterValue;
import org.hibernate.type.StringType;
willgonzz committed
34 35
import org.hibernate.type.IntegerType;
import org.hibernate.type.LongType;
36
import org.springframework.beans.factory.annotation.Autowired;
37 38 39
import org.springframework.data.domain.Page;
import org.springframework.data.domain.PageRequest;
import org.springframework.data.domain.Pageable;
40
import org.springframework.data.domain.Sort;
41 42
import org.springframework.http.HttpStatus;
import org.springframework.http.ResponseEntity;
43
import org.springframework.stereotype.Controller;
44
import org.springframework.ui.Model;
45 46
import org.springframework.web.bind.MethodArgumentNotValidException;
import org.springframework.web.bind.annotation.*;
47

48 49


50 51
@Controller
public class PostulanteController {
52
    PostulanteRepository post;
53
    TecnologiaRepository tecRepo;
54
    ExperienciaRepository expRepo;
55
    InstitucionRepository institucionRepository;
56
    DepartamentoRepository depRepo;
57
    CiudadRepository ciuRepo;
58 59
    EstudioRepository estudioRepository;
    PostulanteTecnologiaRepository postulanteTecnologiaRepository;
willgonzz committed
60 61
    ConvocatoriaRepository cargoRepo;
    CargoRepository carRepo;
62

63
    @Autowired
64 65 66
    public PostulanteController(
            PostulanteRepository post, TecnologiaRepository tecRepo, ExperienciaRepository expRepo,
            InstitucionRepository institucionRepository, DepartamentoRepository depRepo,
67
            CiudadRepository ciuRepo, EstudioRepository estudioRepository,
68 69
            PostulanteTecnologiaRepository postulanteTecnologiaRepository,
            ConvocatoriaRepository cargoRepo, CargoRepository carRepo) {
70 71 72 73
        this.post = post;
        this.tecRepo = tecRepo;
        this.expRepo = expRepo;
        this.institucionRepository = institucionRepository;
74 75
        this.depRepo = depRepo;
        this.ciuRepo = ciuRepo;
76 77
        this.estudioRepository = estudioRepository;
        this.postulanteTecnologiaRepository = postulanteTecnologiaRepository;
willgonzz committed
78 79
        this.cargoRepo =cargoRepo;
        this.carRepo=carRepo;
80
    }
81

82
    @RequestMapping("home")
83
    public String index() {
84
      
85

86
      return "index";
87 88
    }

Joel Florentin committed
89
    @RequestMapping("/postulantes")
Joel Florentin committed
90
    public String postulantes(Model model,
91 92 93
                            @RequestParam(required = false)Long tecId,
                            @RequestParam(required = false)String nombre,
                            @RequestParam(required = false)Disponibilidad dispo,
94 95
                            @RequestParam(required = false)Long lvlEng,
                            @RequestParam(required = false)Long lvlTec,
96
                            @RequestParam(required = false)Long instId,
97
                            @RequestParam(required = false)Long expInMonths,
98
                            @RequestParam(required = false)Long cargoId,
99
                            @RequestParam(defaultValue = "0")Integer nroPagina
100
                            ) {
101
        final Integer CANTIDAD_POR_PAGINA = 5;
102
        Pageable page = PageRequest.of(nroPagina,CANTIDAD_POR_PAGINA,Sort.by("id"));
Joel Florentin committed
103
        model.addAttribute("tecnologias", tecRepo.findAll());
104 105
        model.addAttribute("disponibilidades", Disponibilidad.values());
        model.addAttribute("institucionesEducativas", institucionRepository.findAll());
106
        Page<Postulante> postulantesPag = post.postulantesMultiFiltro(nombre == null || nombre.trim().isEmpty() ? new TypedParameterValue(StringType.INSTANCE,null) : new TypedParameterValue(StringType.INSTANCE,"%"+nombre+"%"), dispo, lvlEng, lvlTec, tecId, instId,cargoId,page);
107
        List<Postulante> postulantes = postulantesPag.getContent();
108 109 110 111 112 113 114 115 116 117 118 119 120
        List<PostulanteListaDTO> postulantesDTO = new ArrayList<>();
        
        for (Postulante postulante : postulantes) {
            long expTotal = 0;
            //Sumamos el tiempo de experiencia total en meses de cada postulante
            //expTotal = postulante.getExperiencias().stream().mapToLong(e -> Helper.getMonthsDifference(e.getFechaDesde(), e.getFechaHasta())).sum();
            for (Experiencia experiencia : postulante.getExperiencias()) {
                expTotal +=  Helper.getMonthsDifference(experiencia.getFechaDesde(), experiencia.getFechaHasta());
            }
            if(expInMonths != null && expInMonths > expTotal) continue;
            postulantesDTO.add(new PostulanteListaDTO(postulante.getId(), postulante.getNombre(), postulante.getApellido(), postulante.getDisponibilidad(), postulante.getNivelIngles(), expTotal, postulante.getTecnologias()));
        }
        
121
        model.addAttribute("pages", postulantesPag.getTotalPages());
122
        model.addAttribute("postulantes", postulantesDTO);
Joel Florentin committed
123 124 125
        return "postulantes";
    }

126
    @RequestMapping("/postulante")
127 128
    public String getFormPostulante(Model model){
        model.addAttribute("tecnologias", tecRepo.findAll());
129
        model.addAttribute("disponibilidades", Disponibilidad.values());
130 131
        model.addAttribute("tiposDeEstudio", TipoDeEstudio.values());
        model.addAttribute("estadosEstudio", EstadoEstudio.values());
132 133 134
        model.addAttribute("estadosCiviles", EstadoCivil.values());
        model.addAttribute("nacionalidades", Nacionalidad.values());
        model.addAttribute("tiposExperencia", TipoExperiencia.values());
willgonzz committed
135
        model.addAttribute("CargosDisponibles", cargoRepo.f1ndByCargoAndEstado(new TypedParameterValue(LongType.INSTANCE, null), new Date(), new TypedParameterValue(IntegerType.INSTANCE, 1)));
136 137
        try {
            model.addAttribute("ciudades", new ObjectMapper().writeValueAsString(ciuRepo.findAll()));
willgonzz committed
138
        } catch (JsonProcessingException er) {
139
            // TODO Auto-generated catch block
willgonzz committed
140
            er.printStackTrace();
141 142
        }
        model.addAttribute("departamentos", depRepo.findAll());
143

144 145
        return "postulante-form";
    }
146

147 148
    @PostMapping(value = "/postulante",consumes = "application/json")
    public String guardarPostulante(@RequestBody Postulante postulante){
149 150 151 152 153 154 155 156
        //Codigo encargado de modificar postulacion si se envia mismo CI
        Postulante postulantex = post.findByNroDocument(postulante.getnroDocument());
        if(postulantex != null){
            estudioRepository.findByPostulante(postulantex).forEach(x -> estudioRepository.delete(x));
            expRepo.findByPostulante(postulantex).forEach(x -> expRepo.delete(x));
            postulanteTecnologiaRepository.findByPostulante(postulantex).forEach(x -> postulanteTecnologiaRepository.delete(x));
            postulante.setId(postulantex.getId());
        }
157 158 159 160
        postulante.getTecnologias().stream().filter(
                    tec -> tec.getTecnologia().getId() != 0 
            ).forEach(
                    tec -> tec.setTecnologia(tecRepo.getById(tec.getTecnologia().getId()))
161
        );
162
        /* for (int i = 0; i < postulante.getPostulaciones().size(); i++) {
willgonzz committed
163 164
            postulante.getPostulaciones().set(i, cargoRepo.getById(postulante.getPostulaciones().get(i).getId()));
        }
165
         */
166

167
        for(Estudio estudio: postulante.getEstudios()){
168 169 170
            String nombreIns = "";
            nombreIns = estudio.getInstitucion().getNombre().toLowerCase();
            Institucion institucion = institucionRepository.findByNombre(nombreIns);
171
            if(institucion==null){
172
                institucionRepository.save(estudio.getInstitucion());
173 174
            }else{
                estudio.setInstitucion(institucion);
175 176
            }
        }
177
        post.save(postulante);
178 179 180 181 182 183 184 185
        return "redirect:/postulacion-correcta";
    }

    @GetMapping("/postulacion-correcta")
    public String successPostulation(Model model){
        model.addAttribute("mensaje1", "Tu informacion se ha recibido correctamente!");
        model.addAttribute("mensaje2", " espera por que nos pongamos en contacto!");
        return "exitoRegistro";
186 187
    }

188 189 190 191 192 193 194 195 196 197 198 199 200 201 202
    @ResponseStatus(HttpStatus.BAD_REQUEST)
    @ExceptionHandler({MethodArgumentNotValidException.class})
    public ResponseEntity<String> handleValidationExceptions(
            MethodArgumentNotValidException ex) {
        return ResponseEntity.status(HttpStatus.BAD_REQUEST)
                .body(ex.getMessage());
    }

    @ResponseStatus(HttpStatus.BAD_REQUEST)
    @ExceptionHandler({ConstraintViolationException.class})
    public ResponseEntity<String> handleValidationExceptions2(
            ConstraintViolationException ex) {
        return ResponseEntity.status(HttpStatus.BAD_REQUEST)
                .body(ex.getMessage());
    }
203 204
    

205

206 207 208
   @GetMapping({"/postulante/{postulanteId}"})
  	public String getPostulanteDetalle(Model model, @PathVariable("postulanteId") Long postulanteId) {
 		Postulante p = post.findById(postulanteId).orElse(null);
209 210 211
  		model.addAttribute("postulante",p);				
  		return "detallepostulante";
   
212
    }
213
   }