Acabando con implementacion de keyword para almnos y empresas

master
vicsash 8 months ago
parent d4ec5ea057
commit cdbd05aa25

@ -59,11 +59,17 @@ public class AlumnoController {
@PostMapping("/alumno/save") @PostMapping("/alumno/save")
public ResponseEntity<String> saveAlumno(Alumno alumno, @RequestParam("ciclo") Long ciclo, @RequestParam("skills") List<Long> skills, @RequestParam("joinedKeywords") String keywords){ public ResponseEntity<String> saveAlumno(Alumno alumno, @RequestParam("ciclo") Long ciclo, @RequestParam("skills") List<Long> skills, @RequestParam("joinedKeywords") String keywords){
try{ try{
//For some reason the transef of keywords from html to controllers is not done completely right
//due to the fact that the first character is always a comma, so we need to remove it
if (keywords != null && !keywords.isEmpty() && keywords.charAt(0) == ',') {
keywords = keywords.substring(1);
}
Ciclo cicloEntity = cicloService.findById(ciclo); Ciclo cicloEntity = cicloService.findById(ciclo);
Set<Skill> skillEntities = skillService.findAllByIds(skills); Set<Skill> skillEntities = skillService.findAllByIds(skills);
alumno.setCiclo(cicloEntity); alumno.setCiclo(cicloEntity);
alumno.setSkills(skillEntities); alumno.setSkills(skillEntities);
alumno.setKeywords(keywords); // Set the keywords from the joinedKeywords string assert keywords != null;
alumno.setKeywords(keywords);
Alumno testIfExist = alumnoService.exists(alumno); Alumno testIfExist = alumnoService.exists(alumno);
if(testIfExist != null){ if(testIfExist != null){
return new ResponseEntity<>("El alumno ya existe", HttpStatus.BAD_REQUEST); return new ResponseEntity<>("El alumno ya existe", HttpStatus.BAD_REQUEST);
@ -109,12 +115,17 @@ public class AlumnoController {
@PostMapping("/alumno/update") @PostMapping("/alumno/update")
public ResponseEntity<String> updateAlumno(Alumno alumno, @RequestParam("ciclo") Long ciclo, @RequestParam("skills") List<Long> skills){ public ResponseEntity<String> updateAlumno(Alumno alumno, @RequestParam("ciclo") Long ciclo, @RequestParam("skills") List<Long> skills,@RequestParam("joinedKeywords") String keywords){
try{ try{
if (keywords != null && !keywords.isEmpty() && keywords.charAt(0) == ',') {
keywords = keywords.substring(1);
}
Ciclo cicloEntity = cicloService.findById(ciclo); Ciclo cicloEntity = cicloService.findById(ciclo);
Set<Skill> skillEntities = skillService.findAllByIds(skills); Set<Skill> skillEntities = skillService.findAllByIds(skills);
alumno.setCiclo(cicloEntity); alumno.setCiclo(cicloEntity);
alumno.setSkills(skillEntities); alumno.setSkills(skillEntities);
assert keywords != null;
alumno.setKeywords(keywords);
alumnoService.save(alumno); alumnoService.save(alumno);
return new ResponseEntity<>("El alumno fue actualizado con exito", HttpStatus.OK); return new ResponseEntity<>("El alumno fue actualizado con exito", HttpStatus.OK);
}catch (Exception e) { }catch (Exception e) {

@ -61,8 +61,13 @@ public class EmpressaController {
@PostMapping("/empresa/save") @PostMapping("/empresa/save")
public ResponseEntity<String> saveEmpresa(Empresa empresa, @RequestParam("sector.id") Long sectorId){ public ResponseEntity<String> saveEmpresa(Empresa empresa, @RequestParam("sector.id") Long sectorId, @RequestParam("joinedKeywords") String keywords){
try{ try{
if (keywords != null && !keywords.isEmpty() && keywords.charAt(0) == ',') {
keywords = keywords.substring(1);
}
assert keywords != null;
empresa.setKeywords(keywords);
Sector existingSector = sectorService.findById(sectorId); Sector existingSector = sectorService.findById(sectorId);
empresa.setSector(existingSector); empresa.setSector(existingSector);
if(empresaService.exists(empresa) != null){ if(empresaService.exists(empresa) != null){
@ -98,8 +103,13 @@ public class EmpressaController {
@PostMapping("/empresa/update") @PostMapping("/empresa/update")
public ResponseEntity<String> updateEmpresa(Empresa empresa, @RequestParam("sector.id") Long sectorId){ public ResponseEntity<String> updateEmpresa(Empresa empresa, @RequestParam("sector.id") Long sectorId, @RequestParam("joinedKeywords") String keywords){
try{ try{
if (keywords != null && !keywords.isEmpty() && keywords.charAt(0) == ',') {
keywords = keywords.substring(1);
}
assert keywords != null;
empresa.setKeywords(keywords);
Sector existingSector = sectorService.findById(sectorId); Sector existingSector = sectorService.findById(sectorId);
if(existingSector != null) { if(existingSector != null) {
empresa.setSector(existingSector); empresa.setSector(existingSector);

@ -99,7 +99,6 @@
<div class ="form-group row"> <div class ="form-group row">
<label class="col-sm-3 col-form-label" for="nia">Nia</label> <label class="col-sm-3 col-form-label" for="nia">Nia</label>
<div class = "col-sm-9"> <div class = "col-sm-9">
<!--TODO: Añadir validacion de nia-->
<input type="text" th:field="*{nia}" required minlength="8" maxlength="8" title="Entra un nia correcto" class="form-control" id="nia"> <input type="text" th:field="*{nia}" required minlength="8" maxlength="8" title="Entra un nia correcto" class="form-control" id="nia">
</div> </div>
</div> </div>
@ -121,7 +120,7 @@
<div class="form-group row"> <div class="form-group row">
<label class="col-sm-3 col-form-label" for="correo2">Correo2</label> <label class="col-sm-3 col-form-label" for="correo2">Correo2</label>
<div class="col-sm-9"> <div class="col-sm-9">
<input type="email" th:field="*{correo2}" required minlength="5" maxlength="100" class="form-control" id="correo2" title="Introduce correo alternativo"> <input type="email" th:field="*{correo2}" minlength="5" maxlength="100" class="form-control" id="correo2" title="Introduce correo alternativo">
</div> </div>
</div> </div>
@ -164,30 +163,46 @@
</div> </div>
</form> </form>
<script> <script>
var input = document.querySelector('input[name=tags]');
new Tagify(input);
$(document).ready(function() { $(document).ready(function() {
$('#skills').select2(); $('#skills').select2();
}); });
function goBack() { function goBack() {
window.history.back(); window.history.back();
} }
$(document).ready(function() { $(document).ready(function() {
$('#skills').select2(); $('#skills').select2();
var tagifyInput = document.querySelector('input[name=tags]'); var tagifyInput = document.querySelector('input[name=tags]');
var tagify = new Tagify(tagifyInput); // Create a new instance of Tagify var tagify = new Tagify(tagifyInput, {
callbacks: {
add: function(e){
if(e.detail.data.value.trim() === ""){
this.removeTag(e.detail.data, {backspace: true});
}
//console.log('Tag added: ', e.detail.data.value); // Log the added tag
//console.log('Current tags: ', tagify.value.map(function(tagData) { return tagData.value ? tagData.value.trim() : null; }).join(',')); // Log the current tags
},
remove: function(e){
//console.log('Tag removed: ', e.detail.data.value); // Log the removed tag
//console.log('Current tags: ', tagify.value.map(function(tagData) { return tagData.value ? tagData.value.trim() : null; }).join(',')); // Log the current tags
}
}
});
$("form").on("submit", function (event) { $("form").on("submit", function (event) {
event.preventDefault(); event.preventDefault();
var formDataArray = $(this).serializeArray(); var formDataArray = $(this).serializeArray();
var tags = tagify.value.map(function(tagData) { return tagData.value; }); // Use the tagify instance to get the tags var tags = tagify.value.map(function(tagData) {
return tagData.value ? tagData.value.trim() : null;
}).filter(function(tag) { return tag; });
// Convert the tags array to a comma-separated string
var joinedKeywords = tags.join(',');
formDataArray.push({name: 'ciclo', value: $('#ciclo').val()}); formDataArray.push({name: 'ciclo', value: $('#ciclo').val()});
formDataArray.push({name: 'skills', value: $('#skills').val()}); formDataArray.push({name: 'skills', value: $('#skills').val()});
var joinedKeywords = tags.join(','); formDataArray.push({name: 'joinedKeywords', value: joinedKeywords});
$('#joinedKeywords').val(joinedKeywords); //console.log('Joined keywords: ', joinedKeywords); // Log the joinedKeywords value
$.ajax({ $.ajax({
url: '/alumno/save', url: '/alumno/save',

@ -10,6 +10,8 @@
<link rel="stylesheet" type="text/css" th:href="@{/top.css}"> <link rel="stylesheet" type="text/css" th:href="@{/top.css}">
<link href="https://cdn.jsdelivr.net/npm/select2@4.1.0-beta.1/dist/css/select2.min.css" rel="stylesheet" /> <link href="https://cdn.jsdelivr.net/npm/select2@4.1.0-beta.1/dist/css/select2.min.css" rel="stylesheet" />
<script src="https://cdn.jsdelivr.net/npm/select2@4.1.0-beta.1/dist/js/select2.min.js"></script> <script src="https://cdn.jsdelivr.net/npm/select2@4.1.0-beta.1/dist/js/select2.min.js"></script>
<link rel="stylesheet" href="https://unpkg.com/@yaireo/tagify/dist/tagify.css">
<script src="https://unpkg.com/@yaireo/tagify"></script>
<style> <style>
form { form {
display: flex; display: flex;
@ -119,7 +121,7 @@
<div class="form-group row"> <div class="form-group row">
<label class="col-sm-3 col-form-label" for="correo2">Correo2</label> <label class="col-sm-3 col-form-label" for="correo2">Correo2</label>
<div class="col-sm-9"> <div class="col-sm-9">
<input type="email" th:field="*{correo2}" required minlength="5" maxlength="100"class="form-control" id="correo2" title="Introduce correo alternativo"> <input type="email" th:field="*{correo2}" minlength="5" maxlength="100"class="form-control" id="correo2" title="Introduce correo alternativo">
</div> </div>
</div> </div>
@ -133,9 +135,10 @@
<div class="form-group row"> <div class="form-group row">
<label class="col-sm-3 col-form-label" for="keywords">Keywords</label> <label class="col-sm-3 col-form-label" for="keywords">Keywords</label>
<div class="col-sm-9"> <div class="col-sm-9">
<input type="text" th:field="*{keywords}" class="form-control" id="keywords" title="Introduce keywords"> <input name="tags" id="keywords" placeholder="Introduce keywords">
</div> </div>
</div> </div>
<input type="hidden" id="joinedKeywords" name="joinedKeywords">
<!-- Ciclos --> <!-- Ciclos -->
<div class="form-group row"> <div class="form-group row">
@ -160,8 +163,23 @@
</div> </div>
</div> </div>
</form> </form>
<script> <script>
var tagify; // Declare tagify outside of the $(document).ready() function
$(document).ready(function() {
// Get the keywords from the Alumno object
var keywords = "[[${alumno.keywords}]]";
// Split the keywords string into an array of keywords
var keywordsArray = keywords.split(',');
// Set the value of the keywords input field
var tagifyInput = document.querySelector('input[name=tags]');
tagify = new Tagify(tagifyInput); // Initialize tagify
tagify.addTags(keywordsArray);
});
$(document).ready(function() { $(document).ready(function() {
$('#skills').select2(); $('#skills').select2();
}); });
@ -169,13 +187,22 @@
function goBack() { function goBack() {
window.history.back(); window.history.back();
} }
$(document).ready(function () { $(document).ready(function () {
$("form").on("submit", function (event) { $("form").on("submit", function (event) {
event.preventDefault(); event.preventDefault();
var formDataArray = $(this).serializeArray(); var formDataArray = $(this).serializeArray();
var tags = tagify.value.map(function(tagData) {
return tagData.value ? tagData.value.trim() : null;
}).filter(function(tag) { return tag; });
// Convert the tags array to a comma-separated string
var joinedKeywords = tags.join(',');
formDataArray.push({name: 'ciclo', value: $('#ciclo').val()}); formDataArray.push({name: 'ciclo', value: $('#ciclo').val()});
formDataArray.push({name: 'skills', value: $('#skills').val()}); formDataArray.push({name: 'skills', value: $('#skills').val()});
formDataArray.push({name: 'joinedKeywords', value: joinedKeywords});
$.ajax({ $.ajax({
url: '/alumno/update', url: '/alumno/update',

@ -8,6 +8,8 @@
<script src="https://cdnjs.cloudflare.com/ajax/libs/jqueryui/1.12.1/jquery-ui.min.js"></script> <script src="https://cdnjs.cloudflare.com/ajax/libs/jqueryui/1.12.1/jquery-ui.min.js"></script>
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.5.1/jquery.min.js"></script> <script src="https://ajax.googleapis.com/ajax/libs/jquery/3.5.1/jquery.min.js"></script>
<link rel="stylesheet" type="text/css" th:href="@{/top.css}"> <link rel="stylesheet" type="text/css" th:href="@{/top.css}">
<link rel="stylesheet" href="https://unpkg.com/@yaireo/tagify/dist/tagify.css">
<script src="https://unpkg.com/@yaireo/tagify"></script>
<style> <style>
form { form {
display: flex; display: flex;
@ -71,7 +73,7 @@
<div class ="form-group row"> <div class ="form-group row">
<label class="col-sm-3 col-form-label" for="correo">Correo</label> <label class="col-sm-3 col-form-label" for="correo">Correo</label>
<div class = "col-sm-9"> <div class = "col-sm-9">
<input type="text" th:field="*{correo}" required pattern="[a-z0-9._%+-]+@[a-z0-9.-]+\.[a-z]{2,}$" title="Entra en correo valido." class="form-control" id="correo"> <input type="email" th:field="*{correo}" required minlength="5" maxlength="100" title="Entra en correo valido." class="form-control" id="correo">
</div> </div>
</div> </div>
@ -85,9 +87,11 @@
<div class="form-group row"> <div class="form-group row">
<label class="col-sm-3 col-form-label" for="keywords">Keywords</label> <label class="col-sm-3 col-form-label" for="keywords">Keywords</label>
<div class="col-sm-9"> <div class="col-sm-9">
<input type="text" th:field="*{keywords}" required pattern="([a-zA-Z0-9]+,)*[a-zA-Z0-9]+" title="Los keywords tiene que ser separados por una ," class="form-control" id="keywords"> <input name="tags" id="keywords" placeholder="Introduce keywords">
</div> </div>
</div> </div>
<input type="hidden" id="joinedKeywords" name="joinedKeywords">
<div class ="form-group row"> <div class ="form-group row">
<label class="col-sm-3 col-form-label" for="sector">Sector</label> <label class="col-sm-3 col-form-label" for="sector">Sector</label>
@ -106,21 +110,38 @@
</form> </form>
<script> <script>
var tagify; // Declare tagify outside of the $(document).ready() function
$(document).ready(function() {
// Set the value of the keywords input field
var tagifyInput = document.querySelector('input[name=tags]');
tagify = new Tagify(tagifyInput); // Initialize tagify
});
function goBack() { function goBack() {
console.log("goBack function called"); console.log("goBack function called");
window.history.back(); window.history.back();
} }
$(document).ready(function () { $(document).ready(function () {
$("form").on("submit", function (event) { $("form").on("submit", function (event) {
event.preventDefault(); event.preventDefault();
var formData = $(this).serialize(); var formDataArray = $(this).serializeArray();
var sectorId = $('#sector').val(); var tags = tagify.value.map(function(tagData) {
formData += '&empresa=' + encodeURIComponent(sectorId); return tagData.value ? tagData.value.trim() : null;
}).filter(function(tag) { return tag; });
// Convert the tags array to a comma-separated string
var joinedKeywords = tags.join(',');
formDataArray.push({name: 'empresa', value: $('#sector').val()});
formDataArray.push({name: 'joinedKeywords', value: joinedKeywords});
$.ajax({ $.ajax({
url: '/empresa/save', url: '/empresa/save',
type: 'post', type: 'post',
data: formData, data: $.param(formDataArray),
success: function (message) { success: function (message) {
if(message === "La empresa fue guardado con exito") { if(message === "La empresa fue guardado con exito") {
alert("La empresa fue guardado con exito") alert("La empresa fue guardado con exito")
@ -140,8 +161,6 @@
}); });
}); });
}); });
</script> </script>
</body> </body>
</html> </html>

@ -8,6 +8,8 @@
<script src="https://cdnjs.cloudflare.com/ajax/libs/jqueryui/1.12.1/jquery-ui.min.js"></script> <script src="https://cdnjs.cloudflare.com/ajax/libs/jqueryui/1.12.1/jquery-ui.min.js"></script>
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.5.1/jquery.min.js"></script> <script src="https://ajax.googleapis.com/ajax/libs/jquery/3.5.1/jquery.min.js"></script>
<link rel="stylesheet" type="text/css" th:href="@{/top.css}"> <link rel="stylesheet" type="text/css" th:href="@{/top.css}">
<link rel="stylesheet" href="https://unpkg.com/@yaireo/tagify/dist/tagify.css">
<script src="https://unpkg.com/@yaireo/tagify"></script>
<style> <style>
form { form {
display: flex; display: flex;
@ -86,9 +88,10 @@
<div class="form-group row"> <div class="form-group row">
<label class="col-sm-3 col-form-label" for="keywords">Keywords</label> <label class="col-sm-3 col-form-label" for="keywords">Keywords</label>
<div class="col-sm-9"> <div class="col-sm-9">
<input type="text" th:field="*{keywords}" th:value="*{keywords}" required pattern="([a-zA-Z0-9]+,)*[a-zA-Z0-9]+" title="Los keywords tiene que ser separados por una ," class="form-control" id="keywords"> <input name="tags" id="keywords" placeholder="Introduce keywords">
</div> </div>
</div> </div>
<input type="hidden" id="joinedKeywords" name="joinedKeywords">
<div class ="form-group row"> <div class ="form-group row">
<label class="col-sm-3 col-form-label" for="sector">Sector</label> <label class="col-sm-3 col-form-label" for="sector">Sector</label>
@ -107,21 +110,41 @@
</form> </form>
<script> <script>
function goBack() { var tagify; // Declare tagify outside of the $(document).ready() function
console.log("goBack function called");
window.history.back(); $(document).ready(function() {
} // Get the keywords from the Empresa object
var keywords = "[[${empresa.keywords}]]";
// Split the keywords string into an array of keywords
var keywordsArray = keywords.split(',');
// Set the value of the keywords input field
var tagifyInput = document.querySelector('input[name=tags]');
tagify = new Tagify(tagifyInput); // Initialize tagify
tagify.addTags(keywordsArray);
});
$(document).ready(function () { $(document).ready(function () {
$("form").on("submit", function (event) { $("form").on("submit", function (event) {
event.preventDefault(); event.preventDefault();
var formData = $(this).serialize(); var formDataArray = $(this).serializeArray();
var sectorId = $('#sector').val(); var tags = tagify.value.map(function(tagData) {
formData += '&sector=' + encodeURIComponent(sectorId); return tagData.value ? tagData.value.trim() : null;
}).filter(function(tag) { return tag; });
// Convert the tags array to a comma-separated string
var joinedKeywords = tags.join(',');
formDataArray.push({name: 'empresa', value: $('#sector').val()});
formDataArray.push({name: 'joinedKeywords', value: joinedKeywords});
$.ajax({ $.ajax({
url: '/empresa/update', url: '/empresa/update',
type: 'post', type: 'post',
data: formData, data: $.param(formDataArray),
success: function (message) { success: function (message) {
if(message === "Los datos de la empresa fue renovados con exito") { if(message === "Los datos de la empresa fue renovados con exito") {
alert("Los datos de la empresa fue renovada con exito") alert("Los datos de la empresa fue renovada con exito")
@ -138,8 +161,6 @@
}); });
}); });
}); });
</script> </script>
</body> </body>
</html> </html>

@ -174,7 +174,7 @@
url: '/empresa/delete/' + rowId, url: '/empresa/delete/' + rowId,
type: 'GET', type: 'GET',
success: function (response) { success: function (response) {
if (response === "La empresa ha sido eliminada") { if (response === "La empresa ha sido eliminado") {
alert("Empresa borrada con exito"); alert("Empresa borrada con exito");
window.location.reload(); window.location.reload();
} else { } else {

Loading…
Cancel
Save

Powered by INFORMATICA.FP.EDU.ES.