@ -15,6 +15,7 @@ import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestMapping ;
import org.springframework.web.bind.annotation.RequestMapping ;
import org.springframework.web.bind.annotation.RequestParam ;
import org.springframework.web.bind.annotation.RequestParam ;
import javax.servlet.http.HttpSession ;
import java.util.* ;
import java.util.* ;
@Controller
@Controller
@ -59,34 +60,17 @@ public class BuscadorController {
@RequestParam ( defaultValue = "asc" ) String sortDir ,
@RequestParam ( defaultValue = "asc" ) String sortDir ,
@RequestParam String secondaryOption ,
@RequestParam String secondaryOption ,
Model model ) {
Model model ) {
System . out . println ( "Selected option TEST: " + secondaryOption ) ;
Page < Empresa > page = empresaService . getPage ( pageNum , size , sortField , sortDir , query , secondaryOption ) ;
Page < Empresa > page = empresaService . getPage ( pageNum , size , sortField , sortDir , query , secondaryOption ) ;
List < Integer > itemsPage = Arrays . asList ( 5 , 10 , 15 , 20 , 25 , 50 ) ;
List < Integer > itemsPage = Arrays . asList ( 5 , 10 , 15 , 20 , 25 , 50 ) ;
if ( page ! = null ) {
if ( page ! = null ) {
List < Empresa > empresas = page . getContent ( ) ;
List < Empresa > empresas = page . getContent ( ) ;
model . addAttribute ( "currentPage" , pageNum ) ;
addPaginationAttributes ( model , pageNum , page , sortField , sortDir , query , itemsPage , size ) ;
model . addAttribute ( "totalPages" , page . getTotalPages ( ) ) ;
model . addAttribute ( "totalItems" , page . getTotalElements ( ) ) ;
model . addAttribute ( "empresas" , empresas ) ;
model . addAttribute ( "empresas" , empresas ) ;
model . addAttribute ( "sortField" , sortField ) ;
model . addAttribute ( "sortDir" , sortDir ) ;
model . addAttribute ( "reverseSortDir" , sortDir . equals ( "asc" ) ? "desc" : "asc" ) ;
model . addAttribute ( "query" , query ) ;
model . addAttribute ( "query" , query ) ;
model . addAttribute ( "secondaryOption" , secondaryOption ) ;
model . addAttribute ( "secondaryOption" , secondaryOption ) ;
model . addAttribute ( "itemsPage" , itemsPage ) ;
model . addAttribute ( "currentSize" , size ) ;
} else {
} else {
System . out . println ( "No se encontraron empresas" ) ;
// System.out.println("No se encontraron empresas");
}
}
// List<Object> models = model.asMap().values().stream().toList();
// for(Object m : models){
// System.out.println(m);
// }
return "/list/empresas" ;
return "/list/empresas" ;
}
}
@ -101,15 +85,11 @@ public class BuscadorController {
String [ ] word = query . split ( "\\b(y|o)\\b|[,/]" ) ;
String [ ] word = query . split ( "\\b(y|o)\\b|[,/]" ) ;
List < Integer > itemsPage = Arrays . asList ( 5 , 10 , 15 , 20 , 25 , 50 ) ;
List < Integer > itemsPage = Arrays . asList ( 5 , 10 , 15 , 20 , 25 , 50 ) ;
Map < String , Object > attributes = new HashMap < > ( ) ;
Map < String , Object > attributes = new HashMap < > ( ) ;
if ( secondaryOption . equalsIgnoreCase ( "Todo" ) ) {
attributes = getPaginatedAttributes ( pageNum , query , size , sortField , sortDir , sectorService , itemsPage ) ;
sortField = "nombre" ;
sortDir = "asc" ;
attributes = getPaginatedAttributes ( pageNum , query , size , sortField , sortDir , alumnoService , itemsPage ) ;
}
for ( Map . Entry < String , Object > entry : attributes . entrySet ( ) ) {
for ( Map . Entry < String , Object > entry : attributes . entrySet ( ) ) {
model . addAttribute ( entry . getKey ( ) , entry . getValue ( ) ) ;
model . addAttribute ( entry . getKey ( ) , entry . getValue ( ) ) ;
}
}
model . addAttribute ( "secondaryOption" , secondaryOption ) ;
return "/list/sectores" ;
return "/list/sectores" ;
}
}
@ -122,17 +102,16 @@ public class BuscadorController {
@RequestParam ( defaultValue = "asc" ) String sortDir ,
@RequestParam ( defaultValue = "asc" ) String sortDir ,
@RequestParam ( defaultValue = "" ) String secondaryOption ,
@RequestParam ( defaultValue = "" ) String secondaryOption ,
Model model ) {
Model model ) {
String[ ] word = query . split ( "\\b(y|o)\\b|[,/]" ) ;
Page< Contacto > page = contactosService . getPage ( pageNum , size , sortField , sortDir , query , secondaryOption ) ;
List < Integer > itemsPage = Arrays . asList ( 5 , 10 , 15 , 20 , 25 , 50 ) ;
List < Integer > itemsPage = Arrays . asList ( 5 , 10 , 15 , 20 , 25 , 50 ) ;
Map < String , Object > attributes = new HashMap < > ( ) ;
if ( page ! = null ) {
if ( secondaryOption . equalsIgnoreCase ( "Todo" ) ) {
List < Contacto > contactos = page . getContent ( ) ;
sortField = "nombre" ;
addPaginationAttributes ( model , pageNum , page , sortField , sortDir , query , itemsPage , size ) ;
sortDir = "asc" ;
model . addAttribute ( "contactos" , contactos ) ;
attributes = getPaginatedAttributes ( pageNum , query , size , sortField , sortDir , alumnoService , itemsPage ) ;
model . addAttribute ( "query" , query ) ;
}
model . addAttribute ( "secondaryOption" , secondaryOption ) ;
} else {
for ( Map . Entry < String , Object > entry : attributes . entrySet ( ) ) {
//System.out.println("No se encontraron Contactos");
model . addAttribute ( entry . getKey ( ) , entry . getValue ( ) ) ;
}
}
return "/list/contactos" ;
return "/list/contactos" ;
}
}
@ -145,16 +124,16 @@ public class BuscadorController {
@RequestParam ( defaultValue = "asc" ) String sortDir ,
@RequestParam ( defaultValue = "asc" ) String sortDir ,
@RequestParam ( defaultValue = "" ) String secondaryOption ,
@RequestParam ( defaultValue = "" ) String secondaryOption ,
Model model ) {
Model model ) {
String[ ] word = query . split ( "\\b(y|o)\\b|[,/]" ) ;
Page< Sucursal > page = sucursalService . getPage ( pageNum , size , sortField , sortDir , query , secondaryOption ) ;
List < Integer > itemsPage = Arrays . asList ( 5 , 10 , 15 , 20 , 25 , 50 ) ;
List < Integer > itemsPage = Arrays . asList ( 5 , 10 , 15 , 20 , 25 , 50 ) ;
Map < String , Object > attributes = new HashMap < > ( ) ;
if ( page ! = null ) {
if ( secondaryOption . equalsIgnoreCase ( "Todo" ) ) {
List < Sucursal > sucursals = page . getContent ( ) ;
sortField = "nombre" ;
addPaginationAttributes( model , pageNum , page , sortField , sortDir , query , itemsPage , size ) ;
sortDir = "asc" ;
model. addAttribute ( "sucursals" , sucursals ) ;
attributes = getPaginatedAttributes ( pageNum , query , size , sortField , sortDir , alumnoService , itemsPage ) ;
model. addAttribute ( "query" , query ) ;
}
model . addAttribute ( "secondaryOption" , secondaryOption ) ;
for ( Map . Entry < String , Object > entry : attributes . entrySet ( ) ) {
} else {
model . addAttribute ( entry . getKey ( ) , entry . getValue ( ) ) ;
// System.out.println("No se encontraron sucursales");
}
}
return "/list/sucursales" ;
return "/list/sucursales" ;
}
}
@ -167,16 +146,16 @@ public class BuscadorController {
@RequestParam ( defaultValue = "asc" ) String sortDir ,
@RequestParam ( defaultValue = "asc" ) String sortDir ,
@RequestParam ( defaultValue = "" ) String secondaryOption ,
@RequestParam ( defaultValue = "" ) String secondaryOption ,
Model model ) {
Model model ) {
String[ ] word = query . split ( "\\b(y|o)\\b|[,/]" ) ;
Page< Oferta > page = ofertasService . getPage ( pageNum , size , sortField , sortDir , query , secondaryOption ) ;
List < Integer > itemsPage = Arrays . asList ( 5 , 10 , 15 , 20 , 25 , 50 ) ;
List < Integer > itemsPage = Arrays . asList ( 5 , 10 , 15 , 20 , 25 , 50 ) ;
Map < String , Object > attributes = new HashMap < > ( ) ;
if ( page ! = null ) {
if ( secondaryOption . equalsIgnoreCase ( "Todo" ) ) {
List < Oferta > ofertas = page . getContent ( ) ;
sortField = "nombre" ;
addPaginationAttributes( model , pageNum , page , sortField , sortDir , query , itemsPage , size ) ;
sortDir = "asc" ;
model. addAttribute ( "ofertas" , ofertas ) ;
attributes = getPaginatedAttributes ( pageNum , query , size , sortField , sortDir , alumnoService , itemsPage ) ;
model . addAttribute ( "query" , query ) ;
}
model . addAttribute ( "secondaryOption" , secondaryOption ) ;
for ( Map . Entry < String , Object > entry : attributes . entrySet ( ) ) {
} else {
model . addAttribute ( entry . getKey ( ) , entry . getValue ( ) ) ;
// System.out.println("No se encontraron ofertas");
}
}
return "/list/ofertas" ;
return "/list/ofertas" ;
}
}
@ -195,11 +174,12 @@ public class BuscadorController {
if ( secondaryOption . equalsIgnoreCase ( "Todo" ) ) {
if ( secondaryOption . equalsIgnoreCase ( "Todo" ) ) {
sortField = "nombre" ;
sortField = "nombre" ;
sortDir = "asc" ;
sortDir = "asc" ;
attributes = getPaginatedAttributes ( pageNum , query , size , sortField , sortDir , alumno Service, itemsPage ) ;
attributes = getPaginatedAttributes ( pageNum , query , size , sortField , sortDir , familia Service, itemsPage ) ;
}
}
for ( Map . Entry < String , Object > entry : attributes . entrySet ( ) ) {
for ( Map . Entry < String , Object > entry : attributes . entrySet ( ) ) {
model . addAttribute ( entry . getKey ( ) , entry . getValue ( ) ) ;
model . addAttribute ( entry . getKey ( ) , entry . getValue ( ) ) ;
}
}
model . addAttribute ( "secondaryOption" , secondaryOption ) ;
return "/list/familias" ;
return "/list/familias" ;
}
}
@ -211,16 +191,16 @@ public class BuscadorController {
@RequestParam ( defaultValue = "asc" ) String sortDir ,
@RequestParam ( defaultValue = "asc" ) String sortDir ,
@RequestParam ( defaultValue = "" ) String secondaryOption ,
@RequestParam ( defaultValue = "" ) String secondaryOption ,
Model model ) {
Model model ) {
String[ ] word = query . split ( "\\b(y|o)\\b|[,/]" ) ;
Page< Ciclo > page = cicloService . getPage ( pageNum , size , sortField , sortDir , query , secondaryOption ) ;
List < Integer > itemsPage = Arrays . asList ( 5 , 10 , 15 , 20 , 25 , 50 ) ;
List < Integer > itemsPage = Arrays . asList ( 5 , 10 , 15 , 20 , 25 , 50 ) ;
Map < String , Object > attributes = new HashMap < > ( ) ;
if ( page ! = null ) {
if ( secondaryOption . equalsIgnoreCase ( "Todo" ) ) {
List < Ciclo > ciclos = page . getContent ( ) ;
sortField = "nombre" ;
addPaginationAttributes( model , pageNum , page , sortField , sortDir , query , itemsPage , size ) ;
sortDir = "asc" ;
model. addAttribute ( "ciclos" , ciclos ) ;
attributes = getPaginatedAttributes ( pageNum , query , size , sortField , sortDir , alumnoService , itemsPage ) ;
model. addAttribute ( "query" , query ) ;
}
model . addAttribute ( "secondaryOption" , secondaryOption ) ;
for ( Map . Entry < String , Object > entry : attributes . entrySet ( ) ) {
} else {
model . addAttribute ( entry . getKey ( ) , entry . getValue ( ) ) ;
// System.out.println("No se encontraron ofertas");
}
}
return "/list/ciclos" ;
return "/list/ciclos" ;
}
}
@ -234,16 +214,16 @@ public class BuscadorController {
@RequestParam ( defaultValue = "" ) String secondaryOption ,
@RequestParam ( defaultValue = "" ) String secondaryOption ,
Model model ) {
Model model ) {
String[ ] word = query . split ( "\\b(y|o)\\b|[,/]" ) ;
Page< Alumno > page = alumnoService . getPage ( pageNum , size , sortField , sortDir , query , secondaryOption ) ;
List < Integer > itemsPage = Arrays . asList ( 5 , 10 , 15 , 20 , 25 , 50 ) ;
List < Integer > itemsPage = Arrays . asList ( 5 , 10 , 15 , 20 , 25 , 50 ) ;
Map < String , Object > attributes = new HashMap < > ( ) ;
if ( page ! = null ) {
if ( secondaryOption . equalsIgnoreCase ( "Todo" ) ) {
List < Alumno > alumnos = page . getContent ( ) ;
sortField = "nombre" ;
addPaginationAttributes( model , pageNum , page , sortField , sortDir , query , itemsPage , size ) ;
sortDir = "asc" ;
model. addAttribute ( "alumnos" , alumnos ) ;
attributes = getPaginatedAttributes ( pageNum , query , size , sortField , sortDir , alumnoService , itemsPage ) ;
model. addAttribute ( "query" , query ) ;
}
model . addAttribute ( "secondaryOption" , secondaryOption ) ;
for ( Map . Entry < String , Object > entry : attributes . entrySet ( ) ) {
} else {
model . addAttribute ( entry . getKey ( ) , entry . getValue ( ) ) ;
// System.out.println("No se encontraron alumnos");
}
}
return "/list/alumnos" ;
return "/list/alumnos" ;
}
}
@ -268,6 +248,7 @@ public class BuscadorController {
for ( Map . Entry < String , Object > entry : attributes . entrySet ( ) ) {
for ( Map . Entry < String , Object > entry : attributes . entrySet ( ) ) {
model . addAttribute ( entry . getKey ( ) , entry . getValue ( ) ) ;
model . addAttribute ( entry . getKey ( ) , entry . getValue ( ) ) ;
}
}
model . addAttribute ( "secondaryOption" , secondaryOption ) ;
return "/list/skills" ;
return "/list/skills" ;
}
}
public < T > Map < String , Object > getPaginatedAttributes ( int pageNum , String query , int size , String sortField , String sortDir , IPagination < T > service , List < Integer > itemsPage ) {
public < T > Map < String , Object > getPaginatedAttributes ( int pageNum , String query , int size , String sortField , String sortDir , IPagination < T > service , List < Integer > itemsPage ) {
@ -287,11 +268,24 @@ public class BuscadorController {
return attributes ;
return attributes ;
}
}
public void addPaginationAttributes ( Model model , int pageNum , Page < ? > page , String sortField , String sortDir , String query , List < Integer > itemsPage , int size ) {
model . addAttribute ( "currentPage" , pageNum ) ;
model . addAttribute ( "totalPages" , page . getTotalPages ( ) ) ;
model . addAttribute ( "totalItems" , page . getTotalElements ( ) ) ;
model . addAttribute ( "sortField" , sortField ) ;
model . addAttribute ( "sortDir" , sortDir ) ;
model . addAttribute ( "reverseSortDir" , sortDir . equals ( "asc" ) ? "desc" : "asc" ) ;
model . addAttribute ( "itemsPage" , itemsPage ) ;
model . addAttribute ( "currentSize" , size ) ;
}
@GetMapping ( "/empresas/search" )
@GetMapping ( "/empresas/search" )
public ResponseEntity < List < Empresa > > searchEmpresas ( @RequestParam String query ) {
public ResponseEntity < List < Empresa > > searchEmpresas ( @RequestParam String query , @RequestParam String secondaryQuery ) {
List < Empresa > empresas = empresaService . search ( query ) ;
List < Empresa > searchResult = empresaService . search ( query ) ;
return ResponseEntity . ok ( empresas ) ;
return ResponseEntity . ok ( searchResult ) ;
}
}
@GetMapping ( "/sectores/search" )
@GetMapping ( "/sectores/search" )