Compare commits
	
		
			15 Commits
		
	
	
		
			tonitch/ma
			...
			bce53305b3
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| bce53305b3 | |||
| 47e4fb2f8c | |||
| 4a314449ad | |||
| a3c9d6a7c0 | |||
| 94f12f0a86 | |||
| 839ca414ce | |||
| eafff6ec2d | |||
| 9e0db361b8 | |||
| 7a13d412f1 | |||
| 67fa630ecf | |||
| ad0e7b3e35 | |||
| 9de4b06e75 | |||
| 123fa97611 | |||
| 1fad792be7 | |||
| 
						
						
							
						
						acd1262955
	
				 | 
					
					
						
@ -8,7 +8,9 @@ import ovh.herisson.Clyde.Responses.UnauthorizedResponse;
 | 
				
			|||||||
import ovh.herisson.Clyde.Services.*;
 | 
					import ovh.herisson.Clyde.Services.*;
 | 
				
			||||||
import ovh.herisson.Clyde.Tables.Curriculum;
 | 
					import ovh.herisson.Clyde.Tables.Curriculum;
 | 
				
			||||||
import ovh.herisson.Clyde.Tables.Role;
 | 
					import ovh.herisson.Clyde.Tables.Role;
 | 
				
			||||||
 | 
					import ovh.herisson.Clyde.Tables.User;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import java.util.HashMap;
 | 
				
			||||||
import java.util.Map;
 | 
					import java.util.Map;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@RestController
 | 
					@RestController
 | 
				
			||||||
@ -22,11 +24,14 @@ public class CurriculumController {
 | 
				
			|||||||
    private final UserCurriculumService userCurriculumServ;
 | 
					    private final UserCurriculumService userCurriculumServ;
 | 
				
			||||||
    private final CurriculumCourseService curriculumCourseServ;
 | 
					    private final CurriculumCourseService curriculumCourseServ;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    public CurriculumController(CurriculumService curriculumServ, AuthenticatorService authServ, UserCurriculumService userCurriculumServ, CurriculumCourseService curriculumCourseServ){
 | 
					    private final UserService userServ;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public CurriculumController(CurriculumService curriculumServ, AuthenticatorService authServ, UserCurriculumService userCurriculumServ, CurriculumCourseService curriculumCourseServ, UserService userServ){
 | 
				
			||||||
        this.curriculumServ = curriculumServ;
 | 
					        this.curriculumServ = curriculumServ;
 | 
				
			||||||
        this.authServ = authServ;
 | 
					        this.authServ = authServ;
 | 
				
			||||||
        this.userCurriculumServ = userCurriculumServ;
 | 
					        this.userCurriculumServ = userCurriculumServ;
 | 
				
			||||||
        this.curriculumCourseServ = curriculumCourseServ;
 | 
					        this.curriculumCourseServ = curriculumCourseServ;
 | 
				
			||||||
 | 
					        this.userServ = userServ;
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    @GetMapping("/curriculum/{id}")
 | 
					    @GetMapping("/curriculum/{id}")
 | 
				
			||||||
@ -52,6 +57,22 @@ public class CurriculumController {
 | 
				
			|||||||
        return new ResponseEntity<>(curriculumCourseServ.getDepthCurriculum(curriculum),HttpStatus.OK);
 | 
					        return new ResponseEntity<>(curriculumCourseServ.getDepthCurriculum(curriculum),HttpStatus.OK);
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    //Return the list of all curicullums of an user
 | 
				
			||||||
 | 
					    @GetMapping("/onescurriculum/{userId}")
 | 
				
			||||||
 | 
					    public ResponseEntity<Map<String ,Object>> findOnesCurriculum(@RequestHeader("Authorization") String token, @PathVariable String userId){
 | 
				
			||||||
 | 
					        if (authServ.getUserFromToken(token) == null)
 | 
				
			||||||
 | 
					            return new UnauthorizedResponse<>(null);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        User u = userServ.getUserById(Long.parseLong(userId));
 | 
				
			||||||
 | 
					        HashMap<String,Object> toReturn = userCurriculumServ.findAllCurriculumByStudent(u);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        if (toReturn == null)
 | 
				
			||||||
 | 
					            return new ResponseEntity<>(HttpStatus.BAD_REQUEST);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        return new ResponseEntity<>(toReturn,HttpStatus.OK);
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    @GetMapping("/curriculums")
 | 
					    @GetMapping("/curriculums")
 | 
				
			||||||
    public ResponseEntity<Iterable<Map<String, Object>>> findAllIndDepth(){
 | 
					    public ResponseEntity<Iterable<Map<String, Object>>> findAllIndDepth(){
 | 
				
			||||||
        return new ResponseEntity<>(curriculumCourseServ.getAllDepthCurriculum(),HttpStatus.OK);
 | 
					        return new ResponseEntity<>(curriculumCourseServ.getAllDepthCurriculum(),HttpStatus.OK);
 | 
				
			||||||
@ -94,4 +115,20 @@ public class CurriculumController {
 | 
				
			|||||||
        curriculumServ.delete(toDelete);
 | 
					        curriculumServ.delete(toDelete);
 | 
				
			||||||
        return new ResponseEntity<>(HttpStatus.OK);
 | 
					        return new ResponseEntity<>(HttpStatus.OK);
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    @GetMapping("/externalcurriculum/{userId}")
 | 
				
			||||||
 | 
					    public ResponseEntity<Map<String,Object>> getStudentsExternalCurriculum(@RequestHeader("Authorization") String token, @PathVariable String userId){
 | 
				
			||||||
 | 
					        if (authServ.isNotIn(new Role[]{Role.Secretary,Role.Admin, Role.Teacher},token))
 | 
				
			||||||
 | 
					            return new UnauthorizedResponse<>(null);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        User u = userServ.getUserById(Long.parseLong(userId));
 | 
				
			||||||
 | 
					        HashMap<String,Object> toReturn = userCurriculumServ.findAllExternalCurriculumByStudent(u);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        if (toReturn == null)
 | 
				
			||||||
 | 
					            return new ResponseEntity<>(HttpStatus.BAD_REQUEST);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        return new ResponseEntity<>(toReturn,HttpStatus.OK);
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
				
			|||||||
@ -3,6 +3,7 @@ package ovh.herisson.Clyde.EndPoints;
 | 
				
			|||||||
import org.springframework.security.crypto.bcrypt.BCryptPasswordEncoder;
 | 
					import org.springframework.security.crypto.bcrypt.BCryptPasswordEncoder;
 | 
				
			||||||
import org.springframework.web.bind.annotation.*;
 | 
					import org.springframework.web.bind.annotation.*;
 | 
				
			||||||
import ovh.herisson.Clyde.Repositories.TokenRepository;
 | 
					import ovh.herisson.Clyde.Repositories.TokenRepository;
 | 
				
			||||||
 | 
					import ovh.herisson.Clyde.Repositories.UserCurriculumRepository;
 | 
				
			||||||
import ovh.herisson.Clyde.Repositories.UserRepository;
 | 
					import ovh.herisson.Clyde.Repositories.UserRepository;
 | 
				
			||||||
import ovh.herisson.Clyde.Services.*;
 | 
					import ovh.herisson.Clyde.Services.*;
 | 
				
			||||||
import ovh.herisson.Clyde.Tables.*;
 | 
					import ovh.herisson.Clyde.Tables.*;
 | 
				
			||||||
@ -26,8 +27,9 @@ public class MockController {
 | 
				
			|||||||
    public final InscriptionService inscriptionService;
 | 
					    public final InscriptionService inscriptionService;
 | 
				
			||||||
    ArrayList<User> mockUsers;
 | 
					    ArrayList<User> mockUsers;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public final UserCurriculumRepository ucr;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    public MockController(UserRepository userRepo, TokenRepository tokenRepo, TokenService tokenService, CurriculumCourseService CurriculumCourseService, CurriculumService curriculumService, CourseService courseService, InscriptionService inscriptionService){
 | 
					    public MockController(UserRepository userRepo, TokenRepository tokenRepo, TokenService tokenService, CurriculumCourseService CurriculumCourseService, CurriculumService curriculumService, CourseService courseService, InscriptionService inscriptionService, UserCurriculumRepository ucr){
 | 
				
			||||||
        this.tokenRepo = tokenRepo;
 | 
					        this.tokenRepo = tokenRepo;
 | 
				
			||||||
        this.userRepo = userRepo;
 | 
					        this.userRepo = userRepo;
 | 
				
			||||||
        this.tokenService = tokenService;
 | 
					        this.tokenService = tokenService;
 | 
				
			||||||
@ -35,6 +37,7 @@ public class MockController {
 | 
				
			|||||||
        this.curriculumService = curriculumService;
 | 
					        this.curriculumService = curriculumService;
 | 
				
			||||||
        this.courseService = courseService;
 | 
					        this.courseService = courseService;
 | 
				
			||||||
        this.inscriptionService = inscriptionService;
 | 
					        this.inscriptionService = inscriptionService;
 | 
				
			||||||
 | 
					        this.ucr = ucr;
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    /** Saves an example of each user type by :
 | 
					    /** Saves an example of each user type by :
 | 
				
			||||||
@ -47,15 +50,14 @@ public class MockController {
 | 
				
			|||||||
    public void postMock(){
 | 
					    public void postMock(){
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        // user part
 | 
					        // user part
 | 
				
			||||||
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        User herobrine = new User("brine","hero","admin@admin.com","behind","ShadowsLand",new Date(0), null,Role.Admin,passwordEncoder.encode("admin"));
 | 
					        User herobrine = new User("brine","hero","admin@admin.com","behind","ShadowsLand",new Date(0), null,Role.Admin,passwordEncoder.encode("admin"));
 | 
				
			||||||
        User joe = new User("Mama","Joe","student@student.com","roundabout","England",new Date(0), null,Role.Student,passwordEncoder.encode("student"));
 | 
					        User joe = new User("Mama","Joe","student@student.com","roundabout","England",new Date(0), null,Role.Student,passwordEncoder.encode("student"));
 | 
				
			||||||
        User meh = new User("Polo","Marco","secretary@secretary.com","a Box","Monaco",new Date(0), null,Role.Secretary,passwordEncoder.encode("secretary"));
 | 
					        User meh = new User("Polo","Marco","secretary@secretary.com","a Box","Monaco",new Date(0), null,Role.Secretary,passwordEncoder.encode("secretary"));
 | 
				
			||||||
        User joke = new User("Gaillard","Corentin","teacher@teacher.com","lab","faculty",new Date(0), null,Role.Teacher,passwordEncoder.encode("teacher"));
 | 
					        User joke = new User("Gaillard","Corentin","teacher@teacher.com","lab","faculty",new Date(0), null,Role.Teacher,passwordEncoder.encode("teacher"));
 | 
				
			||||||
        User jojo = new User("Bridoux","Justin","teacher2@teacher2.com","lab","faculty",new Date(0), null,Role.Teacher,passwordEncoder.encode("teacher"));
 | 
					        User jojo = new User("Bridoux","Justin","teacher2@teacher2.com","lab","faculty",new Date(0), null,Role.Teacher,passwordEncoder.encode("teacher"));
 | 
				
			||||||
        User lena = new User("Louille","Lena","inscriptionService@InscriptionService.com","no","yes",new Date(0), null,Role.InscriptionService,passwordEncoder.encode("inscriptionService"));
 | 
					        User lena = new User("Louille","Lena","inscriptionService@InscriptionService.com","no","yes",new Date(0), null,Role.InscriptionService,passwordEncoder.encode("inscriptionService"));
 | 
				
			||||||
        mockUsers = new ArrayList<>(Arrays.asList(herobrine,joe,meh,joke,lena,jojo));
 | 
					        User popo = new User("Smith", "Paul", "paulsmith@gmail.com", "306 rue du poulet", "belgique", new Date(0), null, Role.Student, passwordEncoder.encode("jesuispaulleroi"));
 | 
				
			||||||
 | 
					        mockUsers = new ArrayList<>(Arrays.asList(herobrine,joe,meh,joke,lena,jojo, popo));
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        userRepo.saveAll(mockUsers);
 | 
					        userRepo.saveAll(mockUsers);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@ -64,11 +66,22 @@ public class MockController {
 | 
				
			|||||||
        Curriculum infoBab1 = new Curriculum(1,"info");
 | 
					        Curriculum infoBab1 = new Curriculum(1,"info");
 | 
				
			||||||
        Curriculum chemistryBab1 = new Curriculum(1,"chemistry");
 | 
					        Curriculum chemistryBab1 = new Curriculum(1,"chemistry");
 | 
				
			||||||
        Curriculum psychologyBab1 = new Curriculum(1,"psychology");
 | 
					        Curriculum psychologyBab1 = new Curriculum(1,"psychology");
 | 
				
			||||||
 | 
					        Curriculum infoBab2 = new Curriculum(2,"info");
 | 
				
			||||||
 | 
					        Curriculum masterinfo1 = new Curriculum(4, "info");
 | 
				
			||||||
 | 
					        Curriculum masterinfo2 = new Curriculum(5, "info");
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        curriculumService.save(infoBab1);
 | 
					        curriculumService.save(infoBab1);
 | 
				
			||||||
        curriculumService.save(chemistryBab1);
 | 
					        curriculumService.save(chemistryBab1);
 | 
				
			||||||
        curriculumService.save(psychologyBab1);
 | 
					        curriculumService.save(psychologyBab1);
 | 
				
			||||||
 | 
					        curriculumService.save(infoBab2);
 | 
				
			||||||
 | 
					        curriculumService.save(masterinfo1);
 | 
				
			||||||
 | 
					        curriculumService.save(masterinfo2);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        ucr.save(new UserCurriculum(joe, infoBab1, 2022));
 | 
				
			||||||
 | 
					        ucr.save(new UserCurriculum(joe, chemistryBab1, 2023));
 | 
				
			||||||
 | 
					        ucr.save(new UserCurriculum(joe, psychologyBab1, 2020));
 | 
				
			||||||
 | 
					        ucr.save(new UserCurriculum(popo, infoBab1, 2022));
 | 
				
			||||||
 | 
					        ucr.save(new UserCurriculum(popo, infoBab2, 2023));
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        Course progra1 = new Course(5,"Programmation et algorithmique 1",joke);
 | 
					        Course progra1 = new Course(5,"Programmation et algorithmique 1",joke);
 | 
				
			||||||
        Course chemistry1 = new Course(12, "Thermochimie",joke);
 | 
					        Course chemistry1 = new Course(12, "Thermochimie",joke);
 | 
				
			||||||
@ -92,10 +105,9 @@ public class MockController {
 | 
				
			|||||||
        CurriculumCourseService.save(new CurriculumCourse(chemistryBab1,chemistry1));
 | 
					        CurriculumCourseService.save(new CurriculumCourse(chemistryBab1,chemistry1));
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        InscriptionRequest inscriptionRequest = new InscriptionRequest("helen","prenom","non","helen@gmail.com","america",new Date(),(long) 1,RequestState.Pending,"yes.png","password");
 | 
					        InscriptionRequest inscriptionRequest = new InscriptionRequest("helen","prenom","non","helen@gmail.com","america",new Date(),(long) 1,RequestState.Pending,"yes.png","password", null, new Date());
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        inscriptionService.save(inscriptionRequest);
 | 
					        inscriptionService.save(inscriptionRequest);
 | 
				
			||||||
        
 | 
					 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
				
			|||||||
@ -0,0 +1,11 @@
 | 
				
			|||||||
 | 
					package ovh.herisson.Clyde.Repositories;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import org.springframework.data.repository.CrudRepository;
 | 
				
			||||||
 | 
					import ovh.herisson.Clyde.Tables.ExternalCurriculum;
 | 
				
			||||||
 | 
					import ovh.herisson.Clyde.Tables.User;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import java.util.ArrayList;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					public interface ExternalCurriculumRepository extends CrudRepository<ExternalCurriculum, Long> {
 | 
				
			||||||
 | 
					    ArrayList<ExternalCurriculum> getExternalCurriculumByUser(User user);
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
@ -6,8 +6,12 @@ import ovh.herisson.Clyde.Tables.Curriculum;
 | 
				
			|||||||
import ovh.herisson.Clyde.Tables.User;
 | 
					import ovh.herisson.Clyde.Tables.User;
 | 
				
			||||||
import ovh.herisson.Clyde.Tables.UserCurriculum;
 | 
					import ovh.herisson.Clyde.Tables.UserCurriculum;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import java.util.ArrayList;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
public interface UserCurriculumRepository extends CrudRepository<UserCurriculum, Long> {
 | 
					public interface UserCurriculumRepository extends CrudRepository<UserCurriculum, Long> {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    @Query("select uc.curriculum from UserCurriculum uc where uc.user = ?1")
 | 
					    @Query("select uc.curriculum from UserCurriculum uc where uc.user = ?1")
 | 
				
			||||||
    Curriculum findByUser(User student);
 | 
					    Curriculum findByUser(User student);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    ArrayList<UserCurriculum> findByUserOrderByCurriculum(User student);
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
				
			|||||||
@ -18,7 +18,6 @@ public class CurriculumService {
 | 
				
			|||||||
    public Curriculum findById(long id){
 | 
					    public Curriculum findById(long id){
 | 
				
			||||||
        return curriculumRepo.findById(id);
 | 
					        return curriculumRepo.findById(id);
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					 | 
				
			||||||
    public void delete(Curriculum curriculum) {
 | 
					    public void delete(Curriculum curriculum) {
 | 
				
			||||||
        curriculumRepo.delete(curriculum);
 | 
					        curriculumRepo.delete(curriculum);
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
				
			|||||||
@ -81,7 +81,7 @@ public class InscriptionService {
 | 
				
			|||||||
            );
 | 
					            );
 | 
				
			||||||
 | 
					
 | 
				
			||||||
            userRepo.save(userFromRequest);
 | 
					            userRepo.save(userFromRequest);
 | 
				
			||||||
            userCurriculumRepo.save(new UserCurriculum(userFromRequest, curriculumRepo.findById(inscrRequest.getCurriculumId())));
 | 
					            userCurriculumRepo.save(new UserCurriculum(userFromRequest, curriculumRepo.findById(inscrRequest.getCurriculumId()),0));
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
        inscrRequest.setState(requestState);
 | 
					        inscrRequest.setState(requestState);
 | 
				
			||||||
        save(inscrRequest);
 | 
					        save(inscrRequest);
 | 
				
			||||||
 | 
				
			|||||||
@ -87,7 +87,8 @@ public class ProtectionService {
 | 
				
			|||||||
        toReturn.put("curriculum", inscriptionRequest.getCurriculumId());
 | 
					        toReturn.put("curriculum", inscriptionRequest.getCurriculumId());
 | 
				
			||||||
        toReturn.put("state", inscriptionRequest.getState());
 | 
					        toReturn.put("state", inscriptionRequest.getState());
 | 
				
			||||||
        toReturn.put("profilePictureUrl", inscriptionRequest.getProfilePicture());
 | 
					        toReturn.put("profilePictureUrl", inscriptionRequest.getProfilePicture());
 | 
				
			||||||
 | 
					        toReturn.put("identityCard", inscriptionRequest.getIdentityCard());
 | 
				
			||||||
 | 
					        toReturn.put("submissionDate", inscriptionRequest.getSubmissionDate());
 | 
				
			||||||
        return toReturn;
 | 
					        return toReturn;
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
				
			|||||||
@ -1,20 +1,79 @@
 | 
				
			|||||||
package ovh.herisson.Clyde.Services;
 | 
					package ovh.herisson.Clyde.Services;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
import org.springframework.stereotype.Service;
 | 
					import org.springframework.stereotype.Service;
 | 
				
			||||||
 | 
					import ovh.herisson.Clyde.Repositories.CurriculumRepository;
 | 
				
			||||||
 | 
					import ovh.herisson.Clyde.Repositories.ExternalCurriculumRepository;
 | 
				
			||||||
import ovh.herisson.Clyde.Repositories.UserCurriculumRepository;
 | 
					import ovh.herisson.Clyde.Repositories.UserCurriculumRepository;
 | 
				
			||||||
import ovh.herisson.Clyde.Tables.Curriculum;
 | 
					import ovh.herisson.Clyde.Tables.Curriculum;
 | 
				
			||||||
 | 
					import ovh.herisson.Clyde.Tables.ExternalCurriculum;
 | 
				
			||||||
import ovh.herisson.Clyde.Tables.User;
 | 
					import ovh.herisson.Clyde.Tables.User;
 | 
				
			||||||
 | 
					import ovh.herisson.Clyde.Tables.UserCurriculum;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import java.util.ArrayList;
 | 
				
			||||||
 | 
					import java.util.HashMap;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@Service
 | 
					@Service
 | 
				
			||||||
public class UserCurriculumService {
 | 
					public class UserCurriculumService {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    private final UserCurriculumRepository userCurriculumRepository;
 | 
					    private final UserCurriculumRepository userCurriculumRepository;
 | 
				
			||||||
 | 
					    private final CurriculumRepository curriculumRepo;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    public UserCurriculumService(UserCurriculumRepository userCurriculumRepository) {
 | 
					    private final ExternalCurriculumRepository externalCurriculumRepo;
 | 
				
			||||||
 | 
					    public UserCurriculumService(UserCurriculumRepository userCurriculumRepository, CurriculumRepository curriculumRepo, ExternalCurriculumRepository externalCurriculumRepo) {
 | 
				
			||||||
        this.userCurriculumRepository = userCurriculumRepository;
 | 
					        this.userCurriculumRepository = userCurriculumRepository;
 | 
				
			||||||
 | 
					        this.curriculumRepo = curriculumRepo;
 | 
				
			||||||
 | 
					        this.externalCurriculumRepo = externalCurriculumRepo;
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    public Curriculum findByUser(User student){
 | 
					    public Curriculum findByUser(User student){
 | 
				
			||||||
        return userCurriculumRepository.findByUser(student);
 | 
					        return userCurriculumRepository.findByUser(student);
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public HashMap<String,Object> findAllCurriculumByStudent(User student) {
 | 
				
			||||||
 | 
					        ArrayList<UserCurriculum> list = userCurriculumRepository.findByUserOrderByCurriculum(student);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        ArrayList<HashMap<String, Object>> curriculumlist = new ArrayList<HashMap<String, Object>>();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        for (int i = 0; i < list.size(); i++) {
 | 
				
			||||||
 | 
					            HashMap<String, Object> element = new HashMap<>();
 | 
				
			||||||
 | 
					            Curriculum c = list.get(i).getCurriculum();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					            element.put("curriculumId", c.getCurriculumId());
 | 
				
			||||||
 | 
					            element.put("year", c.getYear());
 | 
				
			||||||
 | 
					            element.put("option", c.getOption());
 | 
				
			||||||
 | 
					            element.put("dateyear", list.get(i).getYear());
 | 
				
			||||||
 | 
					            curriculumlist.add(element);
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        HashMap<String, Object> toReturn = new HashMap<String, Object>();
 | 
				
			||||||
 | 
					        toReturn.put("curriculumList", curriculumlist);
 | 
				
			||||||
 | 
					        return toReturn;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public HashMap<String,Object> findAllExternalCurriculumByStudent(User student) {
 | 
				
			||||||
 | 
					        ArrayList<ExternalCurriculum> list = externalCurriculumRepo.getExternalCurriculumByUser(student);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        ArrayList<HashMap<String, Object>> externalCurriculumList = new ArrayList<HashMap<String, Object>>();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        for (int i = 0; i < list.size(); i++) {
 | 
				
			||||||
 | 
					            HashMap<String, Object> element = new HashMap<>();
 | 
				
			||||||
 | 
					            element.put("id", list.get(0).getId());
 | 
				
			||||||
 | 
					            element.put("user", list.get(0).getUser());
 | 
				
			||||||
 | 
					            element.put("university", list.get(0).getUniversity());
 | 
				
			||||||
 | 
					            element.put("formation", list.get(0).getFormation());
 | 
				
			||||||
 | 
					            element.put("completion", list.get(0).getCompletion());
 | 
				
			||||||
 | 
					            element.put("startYear", list.get(0).getStartYear());
 | 
				
			||||||
 | 
					            element.put("endYear", list.get(0).getEndYear());
 | 
				
			||||||
 | 
					            element.put("justifDocUrl", list.get(0).getJustifdocUrl());
 | 
				
			||||||
 | 
					            element.put("state", list.get(0).getState());
 | 
				
			||||||
 | 
					            externalCurriculumList.add(element);
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        HashMap<String, Object> toReturn = new HashMap<String, Object>();
 | 
				
			||||||
 | 
					        toReturn.put("externalCurriculumList", externalCurriculumList);
 | 
				
			||||||
 | 
					        return toReturn;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
				
			|||||||
@ -0,0 +1,66 @@
 | 
				
			|||||||
 | 
					package ovh.herisson.Clyde.Tables;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import jakarta.persistence.*;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					@Entity
 | 
				
			||||||
 | 
					public class ExemptionsRequest {
 | 
				
			||||||
 | 
					    @Id
 | 
				
			||||||
 | 
					    @GeneratedValue(strategy = GenerationType.AUTO)
 | 
				
			||||||
 | 
					    private int id;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    @ManyToOne
 | 
				
			||||||
 | 
					    @JoinColumn(name = "Users")
 | 
				
			||||||
 | 
					    private User user;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    @ManyToOne
 | 
				
			||||||
 | 
					    @JoinColumn(name = "Course")
 | 
				
			||||||
 | 
					    private Course course;
 | 
				
			||||||
 | 
					    private String justifDocument;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    private RequestState state;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public ExemptionsRequest(User user, Course course, String justifDocument, RequestState state){
 | 
				
			||||||
 | 
					        this.user = user;
 | 
				
			||||||
 | 
					        this.course = course;
 | 
				
			||||||
 | 
					        this.justifDocument = justifDocument;
 | 
				
			||||||
 | 
					        this.state = state;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public ExemptionsRequest(){}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public User getUser() {
 | 
				
			||||||
 | 
					        return user;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public void setUser(User user) {
 | 
				
			||||||
 | 
					        this.user = user;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public Course getCourse() {
 | 
				
			||||||
 | 
					        return course;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public void setCourse(Course course) {
 | 
				
			||||||
 | 
					        this.course = course;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public String getJustifDocument() {
 | 
				
			||||||
 | 
					        return justifDocument;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public void setJustifDocument(String justifDocument) {
 | 
				
			||||||
 | 
					        this.justifDocument = justifDocument;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public RequestState getState() {
 | 
				
			||||||
 | 
					        return state;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public void setState(RequestState state) {
 | 
				
			||||||
 | 
					        this.state = state;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
@ -0,0 +1,113 @@
 | 
				
			|||||||
 | 
					package ovh.herisson.Clyde.Tables;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import jakarta.persistence.*;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					//This table stores a student's curriculum from another university
 | 
				
			||||||
 | 
					@Entity
 | 
				
			||||||
 | 
					public class ExternalCurriculum {
 | 
				
			||||||
 | 
					    @Id
 | 
				
			||||||
 | 
					    @GeneratedValue(strategy = GenerationType.AUTO)
 | 
				
			||||||
 | 
					    private int id;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    @ManyToOne
 | 
				
			||||||
 | 
					    @JoinColumn(name="Users")
 | 
				
			||||||
 | 
					    private User user;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    @ManyToOne
 | 
				
			||||||
 | 
					    @JoinColumn(name="University")
 | 
				
			||||||
 | 
					    private University university;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    private String formation;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    //This string denotes the completion of the external formation or the last year completed by the student in this formation
 | 
				
			||||||
 | 
					    private String completion;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    private int startYear;
 | 
				
			||||||
 | 
					    private int endYear;
 | 
				
			||||||
 | 
					    private String justifdocUrl;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    //Accepted if the document justifies the claimed formation
 | 
				
			||||||
 | 
					    private RequestState state;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public ExternalCurriculum(){}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public ExternalCurriculum(User user, University university, String formation, String completion, int startYear, int endYear, String justifdocUrl, RequestState state){
 | 
				
			||||||
 | 
					        this.user = user;
 | 
				
			||||||
 | 
					        this.university = university;
 | 
				
			||||||
 | 
					        this.formation = formation;
 | 
				
			||||||
 | 
					        this.completion = completion;
 | 
				
			||||||
 | 
					        this.startYear = startYear;
 | 
				
			||||||
 | 
					        this.endYear = endYear;
 | 
				
			||||||
 | 
					        this.justifdocUrl = justifdocUrl;
 | 
				
			||||||
 | 
					        this.state = state;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public int getId() {
 | 
				
			||||||
 | 
					        return id;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public User getUser() {
 | 
				
			||||||
 | 
					        return user;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public void setUser(User user) {
 | 
				
			||||||
 | 
					        this.user = user;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public University getUniversity() {
 | 
				
			||||||
 | 
					        return university;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public void setUniversity(University university) {
 | 
				
			||||||
 | 
					        this.university = university;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public String getFormation() {
 | 
				
			||||||
 | 
					        return formation;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public void setFormation(String formation) {
 | 
				
			||||||
 | 
					        this.formation = formation;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public String getCompletion(){
 | 
				
			||||||
 | 
					        return completion;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public void setCompletion(String completion) {
 | 
				
			||||||
 | 
					        this.completion = completion;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public int getStartYear() {
 | 
				
			||||||
 | 
					        return startYear;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public void setStartYear(int startYear) {
 | 
				
			||||||
 | 
					        this.startYear = startYear;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public int getEndYear() {
 | 
				
			||||||
 | 
					        return endYear;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public void setEndYear(int endYear) {
 | 
				
			||||||
 | 
					        this.endYear = endYear;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public void setJustifdocUrl(String justifdocUrl) {
 | 
				
			||||||
 | 
					        this.justifdocUrl = justifdocUrl;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public String getJustifdocUrl() {
 | 
				
			||||||
 | 
					        return justifdocUrl;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public RequestState getState() {
 | 
				
			||||||
 | 
					        return state;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public void setState(RequestState state) {
 | 
				
			||||||
 | 
					        this.state = state;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
@ -19,10 +19,12 @@ public class InscriptionRequest {
 | 
				
			|||||||
    private Long curriculumId;
 | 
					    private Long curriculumId;
 | 
				
			||||||
    private RequestState state;
 | 
					    private RequestState state;
 | 
				
			||||||
    private String profilePicture;
 | 
					    private String profilePicture;
 | 
				
			||||||
 | 
					 | 
				
			||||||
    private String password;
 | 
					    private String password;
 | 
				
			||||||
 | 
					    private String identityCard;
 | 
				
			||||||
 | 
					    private Date submissionDate;
 | 
				
			||||||
    public InscriptionRequest(){}
 | 
					    public InscriptionRequest(){}
 | 
				
			||||||
    public InscriptionRequest(String lastName, String firstName, String address, String email, String country, Date birthDate,Long curriculumId, RequestState state, String profilePicture, String password){
 | 
					
 | 
				
			||||||
 | 
					    public InscriptionRequest(String lastName, String firstName, String address, String email, String country, Date birthDate,Long curriculumId, RequestState state, String profilePicture, String password, String identityCard, Date submissionDate){
 | 
				
			||||||
        this.lastName = lastName;
 | 
					        this.lastName = lastName;
 | 
				
			||||||
        this.firstName = firstName;
 | 
					        this.firstName = firstName;
 | 
				
			||||||
        this.address = address;
 | 
					        this.address = address;
 | 
				
			||||||
@ -33,6 +35,8 @@ public class InscriptionRequest {
 | 
				
			|||||||
        this.state = state;
 | 
					        this.state = state;
 | 
				
			||||||
        this.profilePicture = profilePicture;
 | 
					        this.profilePicture = profilePicture;
 | 
				
			||||||
        this.password = password;
 | 
					        this.password = password;
 | 
				
			||||||
 | 
					        this.identityCard = identityCard;
 | 
				
			||||||
 | 
					        this.submissionDate = submissionDate;
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    public int getId() {
 | 
					    public int getId() {
 | 
				
			||||||
@ -118,4 +122,20 @@ public class InscriptionRequest {
 | 
				
			|||||||
    public void setPassword(String password) {
 | 
					    public void setPassword(String password) {
 | 
				
			||||||
        this.password = password;
 | 
					        this.password = password;
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public String getIdentityCard() {
 | 
				
			||||||
 | 
					        return identityCard;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public void setIdentityCard(String identityCard) {
 | 
				
			||||||
 | 
					        this.identityCard = identityCard;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public Date getSubmissionDate() {
 | 
				
			||||||
 | 
					        return submissionDate;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public void setSubmissionDate(Date submissionDate) {
 | 
				
			||||||
 | 
					        this.submissionDate = submissionDate;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
				
			|||||||
@ -0,0 +1,59 @@
 | 
				
			|||||||
 | 
					package ovh.herisson.Clyde.Tables;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import jakarta.persistence.*;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					@Entity
 | 
				
			||||||
 | 
					public class ScholarshipRequest {
 | 
				
			||||||
 | 
					    @Id
 | 
				
			||||||
 | 
					    @GeneratedValue(strategy = GenerationType.AUTO)
 | 
				
			||||||
 | 
					    private int id;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    @ManyToOne
 | 
				
			||||||
 | 
					    @JoinColumn(name = "Users")
 | 
				
			||||||
 | 
					    private User user;
 | 
				
			||||||
 | 
					    private RequestState state;
 | 
				
			||||||
 | 
					    private String requestForm;
 | 
				
			||||||
 | 
					    private int amount;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public ScholarshipRequest(User user, RequestState state, String requestForm, int amount){
 | 
				
			||||||
 | 
					        this.user = user;
 | 
				
			||||||
 | 
					        this.state = state;
 | 
				
			||||||
 | 
					        this.requestForm = requestForm;
 | 
				
			||||||
 | 
					        this.amount = amount;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public ScholarshipRequest(){}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public User getUser() {
 | 
				
			||||||
 | 
					        return user;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public void setUser(User user) {
 | 
				
			||||||
 | 
					        this.user = user;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public RequestState getState() {
 | 
				
			||||||
 | 
					        return state;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public void setState(RequestState state) {
 | 
				
			||||||
 | 
					        this.state = state;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public String getRequestForm() {
 | 
				
			||||||
 | 
					        return requestForm;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public void setRequestForm(String requestForm) {
 | 
				
			||||||
 | 
					        this.requestForm = requestForm;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public int getAmount() {
 | 
				
			||||||
 | 
					        return amount;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public void setAmount(int amount) {
 | 
				
			||||||
 | 
					        this.amount = amount;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
@ -0,0 +1,28 @@
 | 
				
			|||||||
 | 
					package ovh.herisson.Clyde.Tables;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import jakarta.persistence.Entity;
 | 
				
			||||||
 | 
					import jakarta.persistence.GeneratedValue;
 | 
				
			||||||
 | 
					import jakarta.persistence.GenerationType;
 | 
				
			||||||
 | 
					import jakarta.persistence.Id;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					@Entity
 | 
				
			||||||
 | 
					public class UninscriptionRequest {
 | 
				
			||||||
 | 
					    @Id
 | 
				
			||||||
 | 
					    @GeneratedValue(strategy = GenerationType.AUTO)
 | 
				
			||||||
 | 
					    private int id;
 | 
				
			||||||
 | 
					    private RequestState state;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public UninscriptionRequest(RequestState state){
 | 
				
			||||||
 | 
					        this.state = state;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public UninscriptionRequest(){}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public RequestState getState() {
 | 
				
			||||||
 | 
					        return state;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public void setState(RequestState state) {
 | 
				
			||||||
 | 
					        this.state = state;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
@ -0,0 +1,27 @@
 | 
				
			|||||||
 | 
					package ovh.herisson.Clyde.Tables;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import jakarta.persistence.*;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					@Entity
 | 
				
			||||||
 | 
					public class University {
 | 
				
			||||||
 | 
					    @Id
 | 
				
			||||||
 | 
					    @GeneratedValue(strategy = GenerationType.AUTO)
 | 
				
			||||||
 | 
					    private int id;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    private String name;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public University(){}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public University(String name){
 | 
				
			||||||
 | 
					        this.name = name;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public String getName() {
 | 
				
			||||||
 | 
					        return name;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public void setName(String name) {
 | 
				
			||||||
 | 
					        this.name = name;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
@ -21,9 +21,12 @@ public class UserCurriculum {
 | 
				
			|||||||
    @OnDelete(action = OnDeleteAction.CASCADE)
 | 
					    @OnDelete(action = OnDeleteAction.CASCADE)
 | 
				
			||||||
    private Curriculum curriculum;
 | 
					    private Curriculum curriculum;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    public UserCurriculum(User user, Curriculum curriculum){
 | 
					    private int year;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public UserCurriculum(User user, Curriculum curriculum, int year){
 | 
				
			||||||
        this.user = user;
 | 
					        this.user = user;
 | 
				
			||||||
        this.curriculum = curriculum;
 | 
					        this.curriculum = curriculum;
 | 
				
			||||||
 | 
					        this.year = year;
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    public UserCurriculum() {}
 | 
					    public UserCurriculum() {}
 | 
				
			||||||
@ -47,4 +50,12 @@ public class UserCurriculum {
 | 
				
			|||||||
    public void setCurriculum(Curriculum curriculum) {
 | 
					    public void setCurriculum(Curriculum curriculum) {
 | 
				
			||||||
        this.curriculum = curriculum;
 | 
					        this.curriculum = curriculum;
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public int getYear() {
 | 
				
			||||||
 | 
					        return year;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public void setYear(int year) {
 | 
				
			||||||
 | 
					        this.year = year;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
				
			|||||||
@ -86,19 +86,18 @@ window.addEventListener('hashchange', () => {
 | 
				
			|||||||
    </ul>
 | 
					    </ul>
 | 
				
			||||||
    </div>
 | 
					    </div>
 | 
				
			||||||
    <div class="page">
 | 
					    <div class="page">
 | 
				
			||||||
      <div style=" margin:50px;">
 | 
					 | 
				
			||||||
        <Suspense>
 | 
					        <Suspense>
 | 
				
			||||||
        
 | 
					 | 
				
			||||||
				<component :is="currentView" />
 | 
									<component :is="currentView" />
 | 
				
			||||||
        </Suspense>
 | 
					        </Suspense>
 | 
				
			||||||
    </div>
 | 
					    </div>
 | 
				
			||||||
  </div>
 | 
					  </div>
 | 
				
			||||||
  </div>
 | 
					 | 
				
			||||||
</template>
 | 
					</template>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
<style scoped>
 | 
					<style scoped>
 | 
				
			||||||
  
 | 
					  
 | 
				
			||||||
  .container{
 | 
					  .container{
 | 
				
			||||||
 | 
								height: 100%;
 | 
				
			||||||
 | 
								width: 100%;
 | 
				
			||||||
    display:grid;
 | 
					    display:grid;
 | 
				
			||||||
    grid-template-columns:[firstCol-start]70px[firstCol-end secondCol-start]auto[endCol];
 | 
					    grid-template-columns:[firstCol-start]70px[firstCol-end secondCol-start]auto[endCol];
 | 
				
			||||||
    grid-template-rows:[firstRow-start]61px[firstRow-end secondRow-start] auto [endRow];
 | 
					    grid-template-rows:[firstRow-start]61px[firstRow-end secondRow-start] auto [endRow];
 | 
				
			||||||
@ -111,6 +110,8 @@ window.addEventListener('hashchange', () => {
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
  .page {
 | 
					  .page {
 | 
				
			||||||
    grid-area:page;
 | 
					    grid-area:page;
 | 
				
			||||||
 | 
							height: 100%;
 | 
				
			||||||
 | 
							width: 100%;
 | 
				
			||||||
    place-self:center;
 | 
					    place-self:center;
 | 
				
			||||||
  }
 | 
					  }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
				
			|||||||
							
								
								
									
										141
									
								
								frontend/src/Apps/AboutRequest.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										141
									
								
								frontend/src/Apps/AboutRequest.vue
									
									
									
									
									
										Normal file
									
								
							@ -0,0 +1,141 @@
 | 
				
			|||||||
 | 
					<script setup>
 | 
				
			||||||
 | 
					import i18n from "@/i18n.js"
 | 
				
			||||||
 | 
					import {getUser} from '../rest/Users.js'
 | 
				
			||||||
 | 
					import {getcurriculum, getSomeonesCurriculumList} from "@/rest/curriculum.js";
 | 
				
			||||||
 | 
					import {getRegisters} from "@/rest/ServiceInscription.js";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					const props = defineProps(['target']);
 | 
				
			||||||
 | 
					let request = await getRegisters(props.target);
 | 
				
			||||||
 | 
					const cursus = await getcurriculum(request.curriculum);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					function getPP(){
 | 
				
			||||||
 | 
					  if(request.profilePictureUrl === null){
 | 
				
			||||||
 | 
					    return "/Clyde.png"
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					  return request.profilePictureUrl;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					</script>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					<template>
 | 
				
			||||||
 | 
					  <div class="body">
 | 
				
			||||||
 | 
					    <div class="container">
 | 
				
			||||||
 | 
					      <div class="profilPic">
 | 
				
			||||||
 | 
					        <img class="subContainter" :src=getPP()>
 | 
				
			||||||
 | 
					      </div>
 | 
				
			||||||
 | 
					      <div class = "globalInfos">
 | 
				
			||||||
 | 
					        <div class="infosContainer">
 | 
				
			||||||
 | 
					          <div>
 | 
				
			||||||
 | 
					            FirstName/Name : {{request.firstName}} {{request.lastName}}
 | 
				
			||||||
 | 
					          </div>
 | 
				
			||||||
 | 
					          <div>
 | 
				
			||||||
 | 
					            E-mail: {{request.email}}
 | 
				
			||||||
 | 
					          </div>
 | 
				
			||||||
 | 
					          <div>
 | 
				
			||||||
 | 
					            Adresse : {{request.address}}
 | 
				
			||||||
 | 
					          </div>
 | 
				
			||||||
 | 
					          <div>
 | 
				
			||||||
 | 
					            Pays : {{request.country}}
 | 
				
			||||||
 | 
					          </div>
 | 
				
			||||||
 | 
					          <div>
 | 
				
			||||||
 | 
					            Date de naissance : {{request.birthDate}}
 | 
				
			||||||
 | 
					          </div>
 | 
				
			||||||
 | 
					          <div>
 | 
				
			||||||
 | 
					            Cursus voulu : BAB {{cursus.year}} {{cursus.option}}
 | 
				
			||||||
 | 
					          </div>
 | 
				
			||||||
 | 
					        </div>
 | 
				
			||||||
 | 
					      </div>
 | 
				
			||||||
 | 
					    </div>
 | 
				
			||||||
 | 
					  </div>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					</template>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					<style scoped>
 | 
				
			||||||
 | 
					.container{
 | 
				
			||||||
 | 
					  display:grid;
 | 
				
			||||||
 | 
					  grid-template-columns:200px 900px;
 | 
				
			||||||
 | 
					  grid-template-rows:200px auto;
 | 
				
			||||||
 | 
					  column-gap:30px;
 | 
				
			||||||
 | 
					  row-gap:45px;
 | 
				
			||||||
 | 
					  grid-template-areas:
 | 
				
			||||||
 | 
					  "profilPic globalInfos"
 | 
				
			||||||
 | 
					  "minfos minfos";
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					.profilPic{
 | 
				
			||||||
 | 
					  grid-area:profilPic;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					.globalInfos {
 | 
				
			||||||
 | 
					  grid-area:globalInfos;
 | 
				
			||||||
 | 
					  align-self :center;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					.body {
 | 
				
			||||||
 | 
					  width:100%;
 | 
				
			||||||
 | 
					  margin-bottom:10px;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					.subContainter{
 | 
				
			||||||
 | 
					  width:100%;
 | 
				
			||||||
 | 
					  background-color:rgb(50,50,50);
 | 
				
			||||||
 | 
					  border-radius:20px;
 | 
				
			||||||
 | 
					  border:4px solid black;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					.infosContainer {
 | 
				
			||||||
 | 
					  padding-bottom:50px;
 | 
				
			||||||
 | 
					  border:2px solid black;
 | 
				
			||||||
 | 
					  font-size:25px;
 | 
				
			||||||
 | 
					  color:white;
 | 
				
			||||||
 | 
					  padding:20px;
 | 
				
			||||||
 | 
					  background-color:rgb(50,50,50);
 | 
				
			||||||
 | 
					  border-radius:20px;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					.moreInfos {
 | 
				
			||||||
 | 
					  display:grid;
 | 
				
			||||||
 | 
					  grid-template-rows:200px auto;
 | 
				
			||||||
 | 
					  column-gap:50px;
 | 
				
			||||||
 | 
					  row-gap:45px;
 | 
				
			||||||
 | 
					  grid-template-areas:
 | 
				
			||||||
 | 
					  "minfos minfos";
 | 
				
			||||||
 | 
					  grid-template-columns:600px 600px;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					.listTitle{
 | 
				
			||||||
 | 
					  display: flex;
 | 
				
			||||||
 | 
					  justify-content: center;
 | 
				
			||||||
 | 
					  align-items: center;
 | 
				
			||||||
 | 
					  width:250px;
 | 
				
			||||||
 | 
					  margin-left:auto;
 | 
				
			||||||
 | 
					  margin-right:auto;
 | 
				
			||||||
 | 
					  border:2px solid black;
 | 
				
			||||||
 | 
					  font-size:25px;
 | 
				
			||||||
 | 
					  color:white;
 | 
				
			||||||
 | 
					  padding:20px;
 | 
				
			||||||
 | 
					  background-color:rgb(50,50,50);
 | 
				
			||||||
 | 
					  border-radius:20px;margin-bottom:10px;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					.listElement{
 | 
				
			||||||
 | 
					  border:2px solid black;
 | 
				
			||||||
 | 
					  font-size:25px;
 | 
				
			||||||
 | 
					  color:white;
 | 
				
			||||||
 | 
					  padding:20px;
 | 
				
			||||||
 | 
					  background-color:rgb(50,50,50);
 | 
				
			||||||
 | 
					  border-radius:20px;
 | 
				
			||||||
 | 
					  margin-bottom:10px;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					.containerElement{
 | 
				
			||||||
 | 
					  justify-content:center;
 | 
				
			||||||
 | 
					  display:grid;
 | 
				
			||||||
 | 
					  grid-template-columns:100px 100px 300px;
 | 
				
			||||||
 | 
					  grid-template-areas:
 | 
				
			||||||
 | 
					    "year option dateyear";
 | 
				
			||||||
 | 
					  column-gap:40px;
 | 
				
			||||||
 | 
					  padding-left: 25px;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					</style>
 | 
				
			||||||
							
								
								
									
										174
									
								
								frontend/src/Apps/AboutStudent.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										174
									
								
								frontend/src/Apps/AboutStudent.vue
									
									
									
									
									
										Normal file
									
								
							@ -0,0 +1,174 @@
 | 
				
			|||||||
 | 
					<script setup>
 | 
				
			||||||
 | 
					  import i18n from "@/i18n.js"
 | 
				
			||||||
 | 
					  import {getUser} from '../rest/Users.js'
 | 
				
			||||||
 | 
					  import {getSomeonesCurriculumList} from "@/rest/curriculum.js";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  const props = defineProps(['target']);
 | 
				
			||||||
 | 
					  let user = await getUser(props.target);
 | 
				
			||||||
 | 
					  let UserCurriculum = await getSomeonesCurriculumList(props.target);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  function getPP(){
 | 
				
			||||||
 | 
					    if(user.profilePictureUrl === null){
 | 
				
			||||||
 | 
					      return "/Clyde.png"
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					    return user.profilePictureUrl
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  //Cette function renvoie l'année académique concernée si on est dans l'année 2023-2024 elle renvoie 2023
 | 
				
			||||||
 | 
					  //car dans la db l'année scolaire 2023-2024 est representée juste par 2023 (le même système s'applique pour chaque années on prend la borne inférieure
 | 
				
			||||||
 | 
					  function getYear(){
 | 
				
			||||||
 | 
					    let date = new Date();
 | 
				
			||||||
 | 
					    if (date.getMonth() <= 6){
 | 
				
			||||||
 | 
					      return date.getFullYear()-1
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					    return date.getFullYear()
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					</script>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					<template>
 | 
				
			||||||
 | 
					  <div class="body">
 | 
				
			||||||
 | 
					    <div class="container">
 | 
				
			||||||
 | 
					      <div class="profilPic">
 | 
				
			||||||
 | 
					        <img class="subContainter" :src=getPP()>
 | 
				
			||||||
 | 
					      </div>
 | 
				
			||||||
 | 
					      <div class = "globalInfos">
 | 
				
			||||||
 | 
					        <div class="infosContainer">
 | 
				
			||||||
 | 
					          <div>
 | 
				
			||||||
 | 
					            FirstName/Name : {{user.firstName}} {{user.lastName}}
 | 
				
			||||||
 | 
					          </div>
 | 
				
			||||||
 | 
					          <div>
 | 
				
			||||||
 | 
					            E-mail: {{user.email}}
 | 
				
			||||||
 | 
					          </div>
 | 
				
			||||||
 | 
					          <div>
 | 
				
			||||||
 | 
					            Adresse : {{user.address}}
 | 
				
			||||||
 | 
					          </div>
 | 
				
			||||||
 | 
					          <div>
 | 
				
			||||||
 | 
					            Pays : {{user.country}}
 | 
				
			||||||
 | 
					          </div>
 | 
				
			||||||
 | 
					          <div>
 | 
				
			||||||
 | 
					            Date de naissance : {{user.birthDate}}
 | 
				
			||||||
 | 
					          </div>
 | 
				
			||||||
 | 
					        </div>
 | 
				
			||||||
 | 
					      </div>
 | 
				
			||||||
 | 
					      <div class="moreInfos">
 | 
				
			||||||
 | 
					        <div class = "oldcursus">
 | 
				
			||||||
 | 
					          <div class="listTitle">
 | 
				
			||||||
 | 
					            Anciens Cursus
 | 
				
			||||||
 | 
					          </div>
 | 
				
			||||||
 | 
					          <div  class="listElement">
 | 
				
			||||||
 | 
					            <div class=" containerElement" v-for="item in UserCurriculum.curriculumList">
 | 
				
			||||||
 | 
					              <div class="year" v-if="parseInt(item.dateyear) !== getYear()">Bac {{item.year}}</div>
 | 
				
			||||||
 | 
					              <div class="option" v-if="parseInt(item.dateyear) !== getYear()">{{item.option}}</div>
 | 
				
			||||||
 | 
					              <div class="dateyear" v-if="parseInt(item.dateyear) !== getYear()">Année {{item.dateyear}}-{{item.dateyear+1}}</div>
 | 
				
			||||||
 | 
					            </div>
 | 
				
			||||||
 | 
					          </div>
 | 
				
			||||||
 | 
					        </div>
 | 
				
			||||||
 | 
					        <div class="newcursus"  >
 | 
				
			||||||
 | 
					          <div class="listTitle">
 | 
				
			||||||
 | 
					            Cursus Actuel
 | 
				
			||||||
 | 
					          </div>
 | 
				
			||||||
 | 
					          <div  class="listElement">
 | 
				
			||||||
 | 
					            <div class=" containerElement" v-for="item in UserCurriculum.curriculumList" >
 | 
				
			||||||
 | 
					                <div class="year" v-if="parseInt(item.dateyear) === getYear()">Bac {{item.year}}</div>
 | 
				
			||||||
 | 
					                <div class="option" v-if="parseInt(item.dateyear) === getYear()">{{item.option}}</div>
 | 
				
			||||||
 | 
					                <div class="dateyear" v-if="parseInt(item.dateyear) === getYear()">Année {{item.dateyear}}-{{item.dateyear+1}}</div>
 | 
				
			||||||
 | 
					            </div>
 | 
				
			||||||
 | 
					          </div>
 | 
				
			||||||
 | 
					        </div>
 | 
				
			||||||
 | 
					      </div>
 | 
				
			||||||
 | 
					    </div>
 | 
				
			||||||
 | 
					  </div>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					</template>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					<style scoped>
 | 
				
			||||||
 | 
					.container{
 | 
				
			||||||
 | 
					  display:grid;
 | 
				
			||||||
 | 
					  grid-template-columns:200px 900px;
 | 
				
			||||||
 | 
					  grid-template-rows:200px auto;
 | 
				
			||||||
 | 
					  column-gap:30px;
 | 
				
			||||||
 | 
					  row-gap:45px;
 | 
				
			||||||
 | 
					  grid-template-areas:
 | 
				
			||||||
 | 
					  "profilPic globalInfos"
 | 
				
			||||||
 | 
					  "minfos minfos";
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					.profilPic{
 | 
				
			||||||
 | 
					  grid-area:profilPic;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					.globalInfos {
 | 
				
			||||||
 | 
					  grid-area:globalInfos;
 | 
				
			||||||
 | 
					  align-self :center;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					.body {
 | 
				
			||||||
 | 
					  width:100%;
 | 
				
			||||||
 | 
					  margin-bottom:10px;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					.subContainter{
 | 
				
			||||||
 | 
					  width:100%;
 | 
				
			||||||
 | 
					  background-color:rgb(50,50,50);
 | 
				
			||||||
 | 
					  border-radius:20px;
 | 
				
			||||||
 | 
					  border:4px solid black;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					.infosContainer {
 | 
				
			||||||
 | 
					  padding-bottom:50px;
 | 
				
			||||||
 | 
					  border:2px solid black;
 | 
				
			||||||
 | 
					  font-size:25px;
 | 
				
			||||||
 | 
					  color:white;
 | 
				
			||||||
 | 
					  padding:20px;
 | 
				
			||||||
 | 
					  background-color:rgb(50,50,50);
 | 
				
			||||||
 | 
					  border-radius:20px;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					.moreInfos {
 | 
				
			||||||
 | 
					  display:grid;
 | 
				
			||||||
 | 
					  grid-template-rows:200px auto;
 | 
				
			||||||
 | 
					  column-gap:50px;
 | 
				
			||||||
 | 
					  row-gap:45px;
 | 
				
			||||||
 | 
					  grid-template-areas:
 | 
				
			||||||
 | 
					  "minfos minfos";
 | 
				
			||||||
 | 
					  grid-template-columns:600px 600px;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					.listTitle{
 | 
				
			||||||
 | 
					  display: flex;
 | 
				
			||||||
 | 
					  justify-content: center;
 | 
				
			||||||
 | 
					  align-items: center;
 | 
				
			||||||
 | 
					  width:250px;
 | 
				
			||||||
 | 
					  margin-left:auto;
 | 
				
			||||||
 | 
					  margin-right:auto;
 | 
				
			||||||
 | 
					  border:2px solid black;
 | 
				
			||||||
 | 
					  font-size:25px;
 | 
				
			||||||
 | 
					  color:white;
 | 
				
			||||||
 | 
					  padding:20px;
 | 
				
			||||||
 | 
					  background-color:rgb(50,50,50);
 | 
				
			||||||
 | 
					  border-radius:20px;margin-bottom:10px;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					.listElement{
 | 
				
			||||||
 | 
					  border:2px solid black;
 | 
				
			||||||
 | 
					  font-size:25px;
 | 
				
			||||||
 | 
					  color:white;
 | 
				
			||||||
 | 
					  padding:20px;
 | 
				
			||||||
 | 
					  background-color:rgb(50,50,50);
 | 
				
			||||||
 | 
					  border-radius:20px;
 | 
				
			||||||
 | 
					  margin-bottom:10px;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					.containerElement{
 | 
				
			||||||
 | 
					  justify-content:center;
 | 
				
			||||||
 | 
					  display:grid;
 | 
				
			||||||
 | 
					  grid-template-columns:100px 100px 300px;
 | 
				
			||||||
 | 
					  grid-template-areas:
 | 
				
			||||||
 | 
					    "year option dateyear";
 | 
				
			||||||
 | 
					  column-gap:40px;
 | 
				
			||||||
 | 
					  padding-left: 25px;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					</style>
 | 
				
			||||||
@ -2,33 +2,47 @@
 | 
				
			|||||||
  import i18n from "@/i18n.js"
 | 
					  import i18n from "@/i18n.js"
 | 
				
			||||||
  import {ref} from 'vue'
 | 
					  import {ref} from 'vue'
 | 
				
			||||||
  import {validateRegister, getAllRegisters } from '@/rest/ServiceInscription.js'
 | 
					  import {validateRegister, getAllRegisters } from '@/rest/ServiceInscription.js'
 | 
				
			||||||
 | 
					  import AboutRequest from "@/Apps/AboutRequest.vue";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  const requests = ref(await getAllRegisters());
 | 
					  const requests = ref(await getAllRegisters());
 | 
				
			||||||
  console.log(requests);
 | 
					  let targetId = "";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  //0 = liste, 1 = détails, 2 = sure?
 | 
				
			||||||
 | 
					  let windowsState = ref(0);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  async function upPage(id,review){
 | 
					  async function upPage(id,review){
 | 
				
			||||||
    await validateRegister(id,review);
 | 
					    await validateRegister(id,review);
 | 
				
			||||||
    requests.value = await getAllRegisters();
 | 
					    requests.value = await getAllRegisters();
 | 
				
			||||||
 | 
					 | 
				
			||||||
  }
 | 
					  }
 | 
				
			||||||
</script>
 | 
					</script>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
<template>
 | 
					<template>
 | 
				
			||||||
 | 
					  <div v-if="windowsState === 1">
 | 
				
			||||||
 | 
					    <AboutRequest :target="targetId"></AboutRequest>
 | 
				
			||||||
 | 
					    <button style="background-color:rgb(105,05,105);" @click="windowsState=0;">Retour</button>
 | 
				
			||||||
 | 
					  </div>
 | 
				
			||||||
 | 
					  <div v-if="windowsState === 0">
 | 
				
			||||||
    <div  v-for="item of requests">
 | 
					    <div  v-for="item of requests">
 | 
				
			||||||
  <div class="bodu" v-if="item.state === 'Pending'">
 | 
					    <div class="bodu">
 | 
				
			||||||
    <div class="container">
 | 
					    <div class="container">
 | 
				
			||||||
 
 | 
					      <div class="date">{{item.submissionDate.slice(0, 10)}}</div>
 | 
				
			||||||
    <div class="id"><a>{{item.id}}</a></div>
 | 
					      <div class="state">{{item.state}}</div>
 | 
				
			||||||
    <div class="surname"><a>{{item.lastName}}</a></div>
 | 
					      <div class="surname">{{item.lastName}}</div>
 | 
				
			||||||
    <div class="firstname"><a>{{item.firstName}}</a></div>
 | 
					      <div class="firstname">{{item.firstName}}</div>
 | 
				
			||||||
    <div class="infos"><button style="background-color:rgb(105,05,105);" >{{i18n("request.moreInfos")}}</button></div>
 | 
					      <div class="accept" v-if="item.state === 'Pending'"><button @click="windowsState=2;targetId=item.id;" style="background-color:rgb(0,105,50);">{{i18n("request.accept")}}</button></div>
 | 
				
			||||||
    <div class="accept"><button @click="upPage(item.id,'Accepted')" style="background-color:rgb(0,105,50);">{{i18n("request.accept")}}</button></div>
 | 
					      <div class="refuse" v-if="item.state === 'Pending'"><button @click="upPage(item.id,'Refused')" style="background-color:rgb(105,0,0);">{{i18n("request.refuse")}}</button></div>
 | 
				
			||||||
    <div class="refuse"><button @click="upPage(item.id,'Refused')" style="background-color:rgb(105,0,0);">{{i18n("request.refuse")}}</button></div>
 | 
					      <div class="infos"><button style="background-color:rgb(105,05,105);" @click="targetId=item.id;windowsState=1;">{{i18n("request.moreInfos")}}</button></div>
 | 
				
			||||||
    </div>
 | 
					    </div>
 | 
				
			||||||
    </div>
 | 
					    </div>
 | 
				
			||||||
    </div>
 | 
					    </div>
 | 
				
			||||||
 | 
					  </div>
 | 
				
			||||||
 | 
					  <div v-if="windowsState === 2">
 | 
				
			||||||
 | 
					    <p>Etes vous sur de vouloir accepter cette demande ?</p>
 | 
				
			||||||
 | 
					    <button style="background-color:rgb(105,05,105);" @click="upPage(targetId,'Accepted');windowsState=0;">Valider</button>
 | 
				
			||||||
 | 
					    <button style="background-color:rgb(105,05,105);" @click="windowsState=0;">Retour</button>
 | 
				
			||||||
 | 
					  </div>
 | 
				
			||||||
</template>
 | 
					</template>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
<style scoped>
 | 
					<style scoped>
 | 
				
			||||||
@ -37,11 +51,10 @@
 | 
				
			|||||||
    height:100px;
 | 
					    height:100px;
 | 
				
			||||||
    font-size:20px;
 | 
					    font-size:20px;
 | 
				
			||||||
    display:grid;
 | 
					    display:grid;
 | 
				
			||||||
    grid-template-columns:[firstCol-start]100px[firstCol-end secondCol-start]150px[secondCol-end thirdCol-start]200px[thirdCol-end fourthCol-start]150px[fourthCol-end]150px[fifthCol-end]150px[sixthCol-end]150px[endCol];
 | 
					    grid-template-columns:[firstCol-start]150px[firstCol-end secondCol-start]200px[secondCol-end thirdCol-start]200px[thirdCol-end fourthCol-start]150px[fourthCol-end]150px[fifthCol-end]150px[sixthCol-end]150px[endCol];
 | 
				
			||||||
    grid-template-areas:
 | 
					    grid-template-areas:
 | 
				
			||||||
    "id type surname firstname infos accept refuse"; 
 | 
					    "date state surname firstname accept refuse infos";
 | 
				
			||||||
    column-gap:10px;
 | 
					    column-gap:10px;
 | 
				
			||||||
    
 | 
					 | 
				
			||||||
  }
 | 
					  }
 | 
				
			||||||
  
 | 
					  
 | 
				
			||||||
  .infos {
 | 
					  .infos {
 | 
				
			||||||
@ -63,8 +76,14 @@
 | 
				
			|||||||
    grid-area:titles;
 | 
					    grid-area:titles;
 | 
				
			||||||
    background-color:rgb(215,215,215);
 | 
					    background-color:rgb(215,215,215);
 | 
				
			||||||
  }
 | 
					  }
 | 
				
			||||||
  .id{
 | 
					  .date{
 | 
				
			||||||
    grid-area:id;
 | 
					    grid-area:date;
 | 
				
			||||||
 | 
					    margin-left:40px;
 | 
				
			||||||
 | 
					    align-self:center;
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  .state{
 | 
				
			||||||
 | 
					    grid-area:state;
 | 
				
			||||||
    margin-left:40px;
 | 
					    margin-left:40px;
 | 
				
			||||||
    align-self:center;
 | 
					    align-self:center;
 | 
				
			||||||
  }
 | 
					  }
 | 
				
			||||||
 | 
				
			|||||||
@ -26,7 +26,7 @@
 | 
				
			|||||||
  const passwordConfirm=ref("")
 | 
					  const passwordConfirm=ref("")
 | 
				
			||||||
 
 | 
					 
 | 
				
			||||||
  const imageSaved = ref(false)
 | 
					  const imageSaved = ref(false)
 | 
				
			||||||
  const ppData = ref(false)
 | 
					  let ppData = ""
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  const curricula= await getAllCurriculums();
 | 
					  const curricula= await getAllCurriculums();
 | 
				
			||||||
  
 | 
					  
 | 
				
			||||||
@ -50,15 +50,28 @@
 | 
				
			|||||||
  disconnect();
 | 
					  disconnect();
 | 
				
			||||||
  window.location.reload();}
 | 
					  window.location.reload();}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  async function uploadPP(arg){
 | 
				
			||||||
 | 
					    const data = await uploadProfilePicture(arg);
 | 
				
			||||||
 | 
					    ppData = data.url;
 | 
				
			||||||
 | 
					    console.log(ppData);
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  //This functions makes the distinction between a master cursus (year 4 or more) and a bachelor cursus (year 3 or less)
 | 
				
			||||||
 | 
					  function getCursusDisplay(cursus){
 | 
				
			||||||
 | 
					    if (cursus.year <= 3){
 | 
				
			||||||
 | 
					      return "BAB " + cursus.year + " " + cursus.option;
 | 
				
			||||||
 | 
					    }else{
 | 
				
			||||||
 | 
					      return "MA" + (parseInt(cursus.year)-3).toString() + " " + cursus.option;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
</script>
 | 
					</script>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
<template>
 | 
					<template>
 | 
				
			||||||
      <div class='loginBox'>
 | 
					    <div class="setup">
 | 
				
			||||||
 | 
					 | 
				
			||||||
        <div v-if="loginPage">
 | 
					        <div v-if="loginPage">
 | 
				
			||||||
 | 
					      <div class='loginBox' style="margin-top:30%;">
 | 
				
			||||||
          <form @submit.prevent="login(outputs.email,outputs.password);goBackHome();"class="form">
 | 
					          <form @submit.prevent="login(outputs.email,outputs.password);goBackHome();"class="form">
 | 
				
			||||||
            <h1 style="color:rgb(239,60,168); font-family: sans-serif;">
 | 
					            <h1 style="color:rgb(239,60,168); font-family: sans-serif;">
 | 
				
			||||||
              {{i18n("login.guest.signin")}}
 | 
					              {{i18n("login.guest.signin")}}
 | 
				
			||||||
@ -74,13 +87,14 @@
 | 
				
			|||||||
            <div class="register">
 | 
					            <div class="register">
 | 
				
			||||||
              <a @click="loginPage=!loginPage">{{i18n("login.guest.register")}}</a>
 | 
					              <a @click="loginPage=!loginPage">{{i18n("login.guest.register")}}</a>
 | 
				
			||||||
            </div>
 | 
					            </div>
 | 
				
			||||||
            <div class="inputBox">
 | 
					            <div class="inputBox" style="margin-bottom:35px;">
 | 
				
			||||||
              <input type="submit" v-model="submitValue">
 | 
					              <input type="submit" v-model="submitValue">
 | 
				
			||||||
            </div>
 | 
					            </div>
 | 
				
			||||||
          </form>
 | 
					          </form>
 | 
				
			||||||
        </div>
 | 
					        </div>
 | 
				
			||||||
 | 
					      </div>
 | 
				
			||||||
        <div v-else>
 | 
					        <div v-else>
 | 
				
			||||||
 | 
					          <div class='loginBox' style="margin-top:30%; margin-bottom:50%;">
 | 
				
			||||||
            <form class="form">
 | 
					            <form class="form">
 | 
				
			||||||
            <h1 style="color:rgb(239,60,168); font-family: sans-serif; text-align:center;">
 | 
					            <h1 style="color:rgb(239,60,168); font-family: sans-serif; text-align:center;">
 | 
				
			||||||
              {{i18n("login.guest.welcome")}}
 | 
					              {{i18n("login.guest.welcome")}}
 | 
				
			||||||
@ -115,7 +129,7 @@
 | 
				
			|||||||
                <a>{{i18n("login.guest.alregister")}}</a>
 | 
					                <a>{{i18n("login.guest.alregister")}}</a>
 | 
				
			||||||
              </div>
 | 
					              </div>
 | 
				
			||||||
            </div>
 | 
					            </div>
 | 
				
			||||||
            <div v-else>
 | 
					            <div v-if="page === 1">
 | 
				
			||||||
              <div class="inputBox">
 | 
					              <div class="inputBox">
 | 
				
			||||||
                <p>{{i18n("login.guest.email")}}</p>
 | 
					                <p>{{i18n("login.guest.email")}}</p>
 | 
				
			||||||
                <input type="mail" v-model="outputs.email">
 | 
					                <input type="mail" v-model="outputs.email">
 | 
				
			||||||
@ -128,20 +142,30 @@
 | 
				
			|||||||
                <p>{{i18n("login.guest.country")}}</p>
 | 
					                <p>{{i18n("login.guest.country")}}</p>
 | 
				
			||||||
                <input type="text" v-model="outputs.country">
 | 
					                <input type="text" v-model="outputs.country">
 | 
				
			||||||
              </div>
 | 
					              </div>
 | 
				
			||||||
 | 
					              <form class="inputBox" novalidate enctype="multipart/form-data">
 | 
				
			||||||
 | 
					              	<p>{{i18n("profile.picture").toUpperCase()}}</p>
 | 
				
			||||||
 | 
					              </form>
 | 
				
			||||||
 | 
					              <label class="browser">
 | 
				
			||||||
 | 
					                Parcourir . . .
 | 
				
			||||||
 | 
									        <input  type="file" :disabled="imageSaved" @change="ppData = uploadProfilePicture($event.target.files); imageSaved = true;" accept="image/*">
 | 
				
			||||||
 | 
					              </label>
 | 
				
			||||||
              <form novalidate enctype="multipart/form-data" class="inputBox">
 | 
					              <form novalidate enctype="multipart/form-data" class="inputBox">
 | 
				
			||||||
              	<p>{{i18n("profile.picture").toUpperCase()}}</p>
 | 
					              	<p>{{i18n("profile.picture").toUpperCase()}}</p>
 | 
				
			||||||
				<input type="file" :disabled="imageSaved" @change="ppData = uploadProfilePicture($event.target.files); imageSaved = true;" accept="image/*">
 | 
									        <input type="file" @change="uploadPP($event.target.files); imageSaved = true;" accept="image/*">
 | 
				
			||||||
              </form>
 | 
					              </form>
 | 
				
			||||||
              <div class="inputBox">
 | 
					              <div class="inputBox">
 | 
				
			||||||
                <p>{{i18n("Curriculum").toUpperCase()}}</p> 
 | 
					                <p>{{i18n("Curriculum").toUpperCase()}}</p> 
 | 
				
			||||||
                  <select v-model="outputs.curriculum">
 | 
					                  <select v-model="outputs.curriculum">
 | 
				
			||||||
                    <option v-for="item in curricula">{{item.curriculumId}}</option>
 | 
					                    <option v-for="item in curricula">{{getCursusDisplay(item)}}</option>
 | 
				
			||||||
                    
 | 
					 | 
				
			||||||
                  </select>
 | 
					                  </select>
 | 
				
			||||||
              </div>
 | 
					              </div>
 | 
				
			||||||
 | 
					              <p style="color:rgb(239,60,168);">
 | 
				
			||||||
 | 
					                Si vous êtes déja inscrits dans cette université veuillez vous connecter a votre compte et utilisez les fonctions
 | 
				
			||||||
 | 
					                changer de cursus/réinscription sinon continuez ici.
 | 
				
			||||||
 | 
					              </p>
 | 
				
			||||||
              <div style="align-self:center;" class="inputBox">
 | 
					              <div style="align-self:center;" class="inputBox">
 | 
				
			||||||
                <button style="margin-top:25px;" @click="register(outputs.firstname, outputs.surname, outputs.birthday, outputs.password, outputs.email, outputs.address, outputs.country, outputs.curriculum, ppData);">
 | 
					                <button style="margin-top:25px;" @click="page++; register(outputs.firstname, outputs.surname, outputs.birthday, outputs.password, outputs.email, outputs.address, outputs.country, outputs.curriculum, ppData, null, new Date());">
 | 
				
			||||||
                  {{i18n("login.guest.submit")}}
 | 
					                  {{i18n("login.guest.nextpage")}}
 | 
				
			||||||
                </button>
 | 
					                </button>
 | 
				
			||||||
              </div>
 | 
					              </div>
 | 
				
			||||||
              <div  class="switchpage">
 | 
					              <div  class="switchpage">
 | 
				
			||||||
@ -151,27 +175,26 @@
 | 
				
			|||||||
                <a>{{i18n("login.guest.alregister")}}</a>
 | 
					                <a>{{i18n("login.guest.alregister")}}</a>
 | 
				
			||||||
              </div>
 | 
					              </div>
 | 
				
			||||||
            </div>
 | 
					            </div>
 | 
				
			||||||
 | 
					            <div v-if="page === 2">
 | 
				
			||||||
 | 
					              <form novalidate enctype="multipart/form-data" class="inputBox">
 | 
				
			||||||
 | 
					                Carte d'identité :
 | 
				
			||||||
              </form>
 | 
					              </form>
 | 
				
			||||||
            </div>
 | 
					            </div>
 | 
				
			||||||
 | 
					          </form>
 | 
				
			||||||
 | 
					         </div>
 | 
				
			||||||
 | 
					    </div>
 | 
				
			||||||
  </div>
 | 
					  </div>
 | 
				
			||||||
</template>
 | 
					</template>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
<style scoped>
 | 
					<style scoped>
 | 
				
			||||||
.Home{
 | 
					 | 
				
			||||||
  position:absolute;
 | 
					 | 
				
			||||||
 	display: flex;
 | 
					 | 
				
			||||||
  z-index: 100;
 | 
					 | 
				
			||||||
	padding: 8px 16px;
 | 
					 | 
				
			||||||
	color:rgb(255, 255, 255);
 | 
					 | 
				
			||||||
	text-decoration: none;
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
.Home:hover{
 | 
					.setup {
 | 
				
			||||||
  width:40px;
 | 
					  margin-left: auto;
 | 
				
			||||||
  background-color: black;
 | 
					  margin-right:auto;
 | 
				
			||||||
	border-radius:6px;
 | 
					  min-width:400px;
 | 
				
			||||||
	color:white;
 | 
					
 | 
				
			||||||
  transform: translate(0px ,1px);
 | 
					  width:25%;
 | 
				
			||||||
 | 
					  height:60%;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@ -180,8 +203,7 @@
 | 
				
			|||||||
  width: 400px;
 | 
					  width: 400px;
 | 
				
			||||||
  display:flex;
 | 
					  display:flex;
 | 
				
			||||||
  justify-content: center;
 | 
					  justify-content: center;
 | 
				
			||||||
  padding: 40px;
 | 
					  border-radius: 5%;
 | 
				
			||||||
  border-radius: 20px;
 | 
					 | 
				
			||||||
  box-shadow:0 5px 25px #000000;
 | 
					  box-shadow:0 5px 25px #000000;
 | 
				
			||||||
  
 | 
					  
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
@ -190,9 +212,8 @@
 | 
				
			|||||||
  width:100%;
 | 
					  width:100%;
 | 
				
			||||||
  display: flex;
 | 
					  display: flex;
 | 
				
			||||||
  flex-direction: column;
 | 
					  flex-direction: column;
 | 
				
			||||||
  justify-content: center;
 | 
					 | 
				
			||||||
  align-items:center;
 | 
					  align-items:center;
 | 
				
			||||||
  gap: 15px;
 | 
					  gap: 3%;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@ -200,12 +221,12 @@
 | 
				
			|||||||
  
 | 
					  
 | 
				
			||||||
  width:100%;
 | 
					  width:100%;
 | 
				
			||||||
  border: none;
 | 
					  border: none;
 | 
				
			||||||
  margin-right: 50px;
 | 
					  margin-right: 12.5%;
 | 
				
			||||||
  padding-left: 10px;
 | 
					  padding-left: 2.5%;
 | 
				
			||||||
  padding-top:10px;
 | 
					  padding-top:2.5%;
 | 
				
			||||||
  padding-bottom:10px;
 | 
					  padding-bottom:2.5%;
 | 
				
			||||||
  outline:none;
 | 
					  outline:none;
 | 
				
			||||||
  border-radius: 4px;
 | 
					  border-radius: 10px;
 | 
				
			||||||
  font-size:1.35em;
 | 
					  font-size:1.35em;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@ -220,14 +241,15 @@
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
.register{
 | 
					.register{
 | 
				
			||||||
  color:rgb(239,60,168);
 | 
					  color:rgb(239,60,168);
 | 
				
			||||||
  width: 100%;
 | 
					  width:70%;
 | 
				
			||||||
  display:flex;
 | 
					  margin-bottom:20px;
 | 
				
			||||||
 | 
					  margin-top:20px;
 | 
				
			||||||
  cursor: pointer;
 | 
					  cursor: pointer;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
.switchpage{
 | 
					.switchpage{
 | 
				
			||||||
  width:100px;
 | 
					  width:100px;
 | 
				
			||||||
  background:rgb(255, 0 255);
 | 
					  background:rgb(255, 0,255);
 | 
				
			||||||
  border: none;
 | 
					  border: none;
 | 
				
			||||||
  padding-right:0;
 | 
					  padding-right:0;
 | 
				
			||||||
  padding-top:10px;
 | 
					  padding-top:10px;
 | 
				
			||||||
@ -250,6 +272,21 @@ input[type=submit],button,select{
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					input[type=file]{
 | 
				
			||||||
 | 
					  display:none;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					.browser{
 | 
				
			||||||
 | 
					  display:inline-block;
 | 
				
			||||||
 | 
					  cursor:pointer;
 | 
				
			||||||
 | 
					  border-radius:20px;
 | 
				
			||||||
 | 
					  background-color:rgb(239,60,168);
 | 
				
			||||||
 | 
					  padding:5%;
 | 
				
			||||||
 | 
					  font-size:1.35em;
 | 
				
			||||||
 | 
					  font-family:sans-serif;
 | 
				
			||||||
 | 
					  background:#FFFFFF;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
button:active ,.switchpage:active{
 | 
					button:active ,.switchpage:active{
 | 
				
			||||||
  opacity:0.8;
 | 
					  opacity:0.8;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
				
			|||||||
@ -105,7 +105,8 @@
 | 
				
			|||||||
      </button>
 | 
					      </button>
 | 
				
			||||||
    </div>
 | 
					    </div>
 | 
				
			||||||
    <div v-if="createMod">
 | 
					    <div v-if="createMod">
 | 
				
			||||||
      <form class="listElement">
 | 
					      <form class="listElement" style="width:40%;margin-right:auto;margin-left:auto;">
 | 
				
			||||||
 | 
					        
 | 
				
			||||||
        <div style="margin-bottom:20px;">
 | 
					        <div style="margin-bottom:20px;">
 | 
				
			||||||
         {{i18n("name")}} : 
 | 
					         {{i18n("name")}} : 
 | 
				
			||||||
        <input v-model="toAdd.title">
 | 
					        <input v-model="toAdd.title">
 | 
				
			||||||
@ -125,7 +126,7 @@
 | 
				
			|||||||
      </form>
 | 
					      </form>
 | 
				
			||||||
    </div>
 | 
					    </div>
 | 
				
			||||||
    <div v-if="deleteMod">
 | 
					    <div v-if="deleteMod">
 | 
				
			||||||
      <form class="listElement">
 | 
					      <form class="listElement" style="width:40%;margin-right:auto;margin-left:auto;">
 | 
				
			||||||
        <div style="margin-bottom:20px;">
 | 
					        <div style="margin-bottom:20px;">
 | 
				
			||||||
          {{i18n("courses.toDelete")}} :
 | 
					          {{i18n("courses.toDelete")}} :
 | 
				
			||||||
         <select style="max-width:200px;" class="teacher" v-model="toRemove">
 | 
					         <select style="max-width:200px;" class="teacher" v-model="toRemove">
 | 
				
			||||||
@ -138,7 +139,7 @@
 | 
				
			|||||||
      </form>
 | 
					      </form>
 | 
				
			||||||
    </div>
 | 
					    </div>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    <div v-if="!createMod && !deleteMod" v-for="item in curriculum" :key="item.title">
 | 
					    <div v-if="!createMod && !deleteMod" v-for="item in curriculum" :key="item.title" style="width:50%;margin-left:auto; margin-right:auto;">
 | 
				
			||||||
      <div  v-if="editElementID !== item.title" style ="padding:15px 15px 15px 15px;">
 | 
					      <div  v-if="editElementID !== item.title" style ="padding:15px 15px 15px 15px;">
 | 
				
			||||||
        <button   @click="editElementID = item.title; setModify(item); ">
 | 
					        <button   @click="editElementID = item.title; setModify(item); ">
 | 
				
			||||||
        {{i18n("courses.modify")}}
 | 
					        {{i18n("courses.modify")}}
 | 
				
			||||||
@ -149,6 +150,7 @@
 | 
				
			|||||||
        <button @click="editElementID= '';"> {{i18n("courses.back")}} </button>
 | 
					        <button @click="editElementID= '';"> {{i18n("courses.back")}} </button>
 | 
				
			||||||
      </div>
 | 
					      </div>
 | 
				
			||||||
      <div  class="listElement" >
 | 
					      <div  class="listElement" >
 | 
				
			||||||
 | 
					
 | 
				
			||||||
      <div class="containerElement" v-if="editElementID !== item.title" >
 | 
					      <div class="containerElement" v-if="editElementID !== item.title" >
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        <div class="name"> {{item.title}} </div>
 | 
					        <div class="name"> {{item.title}} </div>
 | 
				
			||||||
@ -172,17 +174,27 @@
 | 
				
			|||||||
<style scoped>
 | 
					<style scoped>
 | 
				
			||||||
.body {
 | 
					.body {
 | 
				
			||||||
    width:100%;
 | 
					    width:100%;
 | 
				
			||||||
    margin-bottom:10px;
 | 
					    margin-top:3.5%;
 | 
				
			||||||
  }
 | 
					  }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					.infosContainer {
 | 
				
			||||||
 | 
					  min-width:350px;
 | 
				
			||||||
 | 
					  padding-bottom:50px;
 | 
				
			||||||
 | 
					  border:2px solid black;
 | 
				
			||||||
 | 
					  font-size:25px;
 | 
				
			||||||
 | 
					  color:white;
 | 
				
			||||||
 | 
					  padding:20px;
 | 
				
			||||||
 | 
					  background-color:rgb(50,50,50);
 | 
				
			||||||
 | 
					  border-radius:20px;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 .containerElement{ 
 | 
					 .containerElement{ 
 | 
				
			||||||
    justify-content:center;
 | 
					    justify-content:center;
 | 
				
			||||||
    display:grid;
 | 
					    display:grid;
 | 
				
			||||||
    grid-template-columns:350px 350px 200px;
 | 
					    grid-template-columns:38.8% 38.8% 22.4%;
 | 
				
			||||||
    grid-template-areas:
 | 
					    grid-template-areas:
 | 
				
			||||||
    "name teacher credits"; 
 | 
					    "name teacher credits"; 
 | 
				
			||||||
    column-gap:10px;
 | 
					    column-gap:10px;  }
 | 
				
			||||||
    
 | 
					 | 
				
			||||||
  }
 | 
					 | 
				
			||||||
  
 | 
					  
 | 
				
			||||||
  .name {
 | 
					  .name {
 | 
				
			||||||
    grid-area:name;
 | 
					    grid-area:name;
 | 
				
			||||||
@ -200,6 +212,7 @@
 | 
				
			|||||||
  }
 | 
					  }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
.listElement{
 | 
					.listElement{
 | 
				
			||||||
 | 
					 min-width:625px;
 | 
				
			||||||
  border:2px solid black;
 | 
					  border:2px solid black;
 | 
				
			||||||
  font-size:25px;
 | 
					  font-size:25px;
 | 
				
			||||||
  color:white;
 | 
					  color:white;
 | 
				
			||||||
@ -207,6 +220,7 @@
 | 
				
			|||||||
  background-color:rgb(50,50,50);
 | 
					  background-color:rgb(50,50,50);
 | 
				
			||||||
  border-radius:20px;
 | 
					  border-radius:20px;
 | 
				
			||||||
  margin-bottom:10px;
 | 
					  margin-bottom:10px;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
.modify{
 | 
					.modify{
 | 
				
			||||||
@ -255,10 +269,11 @@
 | 
				
			|||||||
  }
 | 
					  }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  .listTitle{
 | 
					  .listTitle{
 | 
				
			||||||
 | 
					    min-width:380px;
 | 
				
			||||||
    display: flex;
 | 
					    display: flex;
 | 
				
			||||||
    justify-content: center;
 | 
					    justify-content: center;
 | 
				
			||||||
    align-items: center;
 | 
					    align-items: center;
 | 
				
			||||||
    width:400px;
 | 
					    width:25%;
 | 
				
			||||||
    margin-left:auto;
 | 
					    margin-left:auto;
 | 
				
			||||||
    margin-right:auto;
 | 
					    margin-right:auto;
 | 
				
			||||||
    border:2px solid black;
 | 
					    border:2px solid black;
 | 
				
			||||||
@ -266,7 +281,8 @@
 | 
				
			|||||||
    color:white;
 | 
					    color:white;
 | 
				
			||||||
    padding:20px;
 | 
					    padding:20px;
 | 
				
			||||||
    background-color:rgb(50,50,50);
 | 
					    background-color:rgb(50,50,50);
 | 
				
			||||||
    border-radius:20px;margin-bottom:10px;
 | 
					    border-radius:20px;
 | 
				
			||||||
 | 
					    margin-bottom:10px;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    button:hover{
 | 
					    button:hover{
 | 
				
			||||||
      opacity:0.8;
 | 
					      opacity:0.8;
 | 
				
			||||||
 | 
				
			|||||||
@ -210,11 +210,11 @@
 | 
				
			|||||||
<style scoped>
 | 
					<style scoped>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
.container{
 | 
					.container{
 | 
				
			||||||
  
 | 
					  min-width:675px;
 | 
				
			||||||
  display:grid;
 | 
					  display:grid;
 | 
				
			||||||
  grid-template-columns:200px 900px;
 | 
					  grid-template-columns:10vw 50vw;
 | 
				
			||||||
  grid-template-rows:200px auto;
 | 
					  grid-template-rows:200px auto;
 | 
				
			||||||
  column-gap:30px;
 | 
					  column-gap:2.7%;
 | 
				
			||||||
  row-gap:45px;
 | 
					  row-gap:45px;
 | 
				
			||||||
  grid-template-areas:
 | 
					  grid-template-areas:
 | 
				
			||||||
  "profilPic globalInfos"
 | 
					  "profilPic globalInfos"
 | 
				
			||||||
@ -222,6 +222,7 @@
 | 
				
			|||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
.profilPic{
 | 
					.profilPic{
 | 
				
			||||||
 | 
					  width:100%;
 | 
				
			||||||
  grid-area:profilPic;
 | 
					  grid-area:profilPic;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@ -242,13 +243,17 @@
 | 
				
			|||||||
  grid-area:minfos;
 | 
					  grid-area:minfos;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
.body {
 | 
					.body {
 | 
				
			||||||
 | 
					    min-width:960px;
 | 
				
			||||||
    width:100%;
 | 
					    width:100%;
 | 
				
			||||||
    margin-bottom:10px;
 | 
					    display:flex;
 | 
				
			||||||
 | 
					    align-items:center;
 | 
				
			||||||
 | 
					    justify-content:center;
 | 
				
			||||||
 | 
					    margin-top:5%;
 | 
				
			||||||
  }
 | 
					  }
 | 
				
			||||||
 .containerElement{ 
 | 
					 .containerElement{ 
 | 
				
			||||||
   justify-content:center;
 | 
					   justify-content:center;
 | 
				
			||||||
    display:grid;
 | 
					    display:grid;
 | 
				
			||||||
    grid-template-columns:350px 350px 200px;
 | 
					    grid-template-columns:38.8% 38.8% 22.4%;
 | 
				
			||||||
    grid-template-areas:
 | 
					    grid-template-areas:
 | 
				
			||||||
    "name teacher credits"; 
 | 
					    "name teacher credits"; 
 | 
				
			||||||
    column-gap:10px;
 | 
					    column-gap:10px;
 | 
				
			||||||
@ -271,10 +276,11 @@
 | 
				
			|||||||
  }
 | 
					  }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
.listTitle{
 | 
					.listTitle{
 | 
				
			||||||
 | 
					    min-width:197px;
 | 
				
			||||||
    display: flex;
 | 
					    display: flex;
 | 
				
			||||||
    justify-content: center;
 | 
					    justify-content: center;
 | 
				
			||||||
    align-items: center;
 | 
					    align-items: center;
 | 
				
			||||||
    width:200px;
 | 
					    width:8vw;
 | 
				
			||||||
    margin-left:auto;
 | 
					    margin-left:auto;
 | 
				
			||||||
    margin-right:auto;
 | 
					    margin-right:auto;
 | 
				
			||||||
    border:2px solid black;
 | 
					    border:2px solid black;
 | 
				
			||||||
@ -286,6 +292,7 @@
 | 
				
			|||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
.listElement{
 | 
					.listElement{
 | 
				
			||||||
 | 
					  min-width:625px;
 | 
				
			||||||
  border:2px solid black;
 | 
					  border:2px solid black;
 | 
				
			||||||
  font-size:25px;
 | 
					  font-size:25px;
 | 
				
			||||||
  color:white;
 | 
					  color:white;
 | 
				
			||||||
@ -296,6 +303,7 @@
 | 
				
			|||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
.infosContainer {
 | 
					.infosContainer {
 | 
				
			||||||
 | 
					min-width:350px;
 | 
				
			||||||
padding-bottom:50px;
 | 
					padding-bottom:50px;
 | 
				
			||||||
border:2px solid black;
 | 
					border:2px solid black;
 | 
				
			||||||
font-size:25px;
 | 
					font-size:25px;
 | 
				
			||||||
 | 
				
			|||||||
@ -1,19 +1,29 @@
 | 
				
			|||||||
<script setup>
 | 
					<script setup>
 | 
				
			||||||
  import i18n from "@/i18n.js"
 | 
					  import i18n from "@/i18n.js"
 | 
				
			||||||
  import { reactive  } from 'vue'
 | 
					  import {provide, reactive, ref} from 'vue'
 | 
				
			||||||
  import { getStudents } from '../rest/Users.js'
 | 
					  import { getStudents } from '../rest/Users.js'
 | 
				
			||||||
 | 
					  import AboutStudent from "@/Apps/AboutStudent.vue";
 | 
				
			||||||
  const users = await getStudents();
 | 
					  const users = await getStudents();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  let targetRegNo = "";
 | 
				
			||||||
 | 
					  let list = ref(true);
 | 
				
			||||||
</script>
 | 
					</script>
 | 
				
			||||||
<template>
 | 
					
 | 
				
			||||||
  <div v-for="item in users">
 | 
					<template style="margin-top:5%;">
 | 
				
			||||||
 | 
					  <div v-if="list === false">
 | 
				
			||||||
 | 
					    <AboutStudent :target=targetRegNo />
 | 
				
			||||||
 | 
					    <button style="background-color:rgb(105,05,105);" @click="list = true;">Back</button>
 | 
				
			||||||
 | 
					  </div>
 | 
				
			||||||
 | 
					  <div style="display:flex; justify-content:center; " v-for="item in users" v-if="list === true">
 | 
				
			||||||
    <div class="bodu">
 | 
					    <div class="bodu">
 | 
				
			||||||
      <div class="container">
 | 
					      <div class="container">
 | 
				
			||||||
        <div class="status"><a style="margin-left:30px">{{item.status}}</a></div>
 | 
					        <div class="status"><a style="margin-left:30px">{{item.status}}</a></div>
 | 
				
			||||||
        <div class="option"><a>{{item.role}}</a></div>
 | 
					        <div class="option"><a>{{item.role}}</a></div>
 | 
				
			||||||
        <div class="surname"><a>{{item.lastName}}</a></div>
 | 
					        <div class="surname"><a>{{item.lastName}}</a></div>
 | 
				
			||||||
        <div class="firstname"><a>{{item.firstName}}</a></div>
 | 
					        <div class="firstname"><a>{{item.firstName}}</a></div>
 | 
				
			||||||
        <div class="infos"><button style="background-color:rgb(105,05,105);" >{{i18n("request.moreInfos")}}   </button></div>
 | 
					        <div class="infos">
 | 
				
			||||||
 | 
					          <button style="background-color:rgb(105,05,105);" @click="list = false; targetRegNo = item.regNo;">{{i18n("request.moreInfos")}} </button>
 | 
				
			||||||
 | 
					        </div>
 | 
				
			||||||
    </div>
 | 
					    </div>
 | 
				
			||||||
    </div>
 | 
					    </div>
 | 
				
			||||||
  </div>
 | 
					  </div>
 | 
				
			||||||
@ -25,11 +35,10 @@
 | 
				
			|||||||
    height:100px;
 | 
					    height:100px;
 | 
				
			||||||
    font-size:30px;
 | 
					    font-size:30px;
 | 
				
			||||||
    display:grid;
 | 
					    display:grid;
 | 
				
			||||||
    grid-template-columns:250px 250px 250px 250px 150px;
 | 
					    grid-template-columns:21.7% 21.7% 21.7% 21.7% 13.1%;
 | 
				
			||||||
    grid-template-areas:
 | 
					    grid-template-areas:
 | 
				
			||||||
    "status option surname firstname infos"; 
 | 
					    "status option surname firstname infos"; 
 | 
				
			||||||
    column-gap:10px;
 | 
					    column-gap:10px;
 | 
				
			||||||
    
 | 
					 | 
				
			||||||
  }
 | 
					  }
 | 
				
			||||||
  
 | 
					  
 | 
				
			||||||
  .infos {
 | 
					  .infos {
 | 
				
			||||||
@ -42,21 +51,6 @@
 | 
				
			|||||||
    align-self:center;
 | 
					    align-self:center;
 | 
				
			||||||
  }
 | 
					  }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  .refuse{
 | 
					 | 
				
			||||||
    grid-area:refuse;
 | 
					 | 
				
			||||||
    align-self:center;
 | 
					 | 
				
			||||||
  }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  .titles {
 | 
					 | 
				
			||||||
    grid-area:titles;
 | 
					 | 
				
			||||||
    background-color:rgb(215,215,215);
 | 
					 | 
				
			||||||
  }
 | 
					 | 
				
			||||||
  .id{
 | 
					 | 
				
			||||||
    grid-area:id;
 | 
					 | 
				
			||||||
    margin-left:40px;
 | 
					 | 
				
			||||||
    align-self:center;
 | 
					 | 
				
			||||||
  }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  .status{
 | 
					  .status{
 | 
				
			||||||
    grid-area:status;
 | 
					    grid-area:status;
 | 
				
			||||||
    align-self:center;
 | 
					    align-self:center;
 | 
				
			||||||
@ -81,15 +75,15 @@
 | 
				
			|||||||
  button{
 | 
					  button{
 | 
				
			||||||
    font-size:15px;
 | 
					    font-size:15px;
 | 
				
			||||||
     height:50px;
 | 
					     height:50px;
 | 
				
			||||||
     width:100px;
 | 
					     width:75%;
 | 
				
			||||||
    border:none;
 | 
					    border:none;
 | 
				
			||||||
    border-radius:20px;
 | 
					    border-radius:20px;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  }
 | 
					  }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  .bodu {
 | 
					  .bodu {
 | 
				
			||||||
    width:100%;
 | 
					    margin-top:2%;
 | 
				
			||||||
    margin-bottom:10px;
 | 
					    width:66%;
 | 
				
			||||||
    border:2px solid black;
 | 
					    border:2px solid black;
 | 
				
			||||||
    border-radius:9px;
 | 
					    border-radius:9px;
 | 
				
			||||||
    background-color:rgb(50,50,50);
 | 
					    background-color:rgb(50,50,50);
 | 
				
			||||||
 | 
				
			|||||||
@ -7,8 +7,8 @@
 | 
				
			|||||||
  const users = await getAllUsers();
 | 
					  const users = await getAllUsers();
 | 
				
			||||||
  
 | 
					  
 | 
				
			||||||
</script> 
 | 
					</script> 
 | 
				
			||||||
<template>
 | 
					<template style="margin-top:5%;">
 | 
				
			||||||
  <div v-for="item in users">
 | 
					  <div style="display:flex; justify-content:center; min-width:1140px;" v-for="item in users">
 | 
				
			||||||
    <div class="bodu">
 | 
					    <div class="bodu">
 | 
				
			||||||
      <div class="container">
 | 
					      <div class="container">
 | 
				
			||||||
        <div class="role"><a style="margin-left:30px">{{i18n(item.role)}}</a></div>
 | 
					        <div class="role"><a style="margin-left:30px">{{i18n(item.role)}}</a></div>
 | 
				
			||||||
@ -22,23 +22,20 @@
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
<style scoped>
 | 
					<style scoped>
 | 
				
			||||||
  .container{
 | 
					  .container{
 | 
				
			||||||
    justify-content:center;
 | 
					 | 
				
			||||||
    align-items:center;
 | 
					 | 
				
			||||||
    color:white;
 | 
					    color:white;
 | 
				
			||||||
    height:100px;
 | 
					    height:100px;
 | 
				
			||||||
    font-size:30px;
 | 
					    font-size:30px;
 | 
				
			||||||
    display:grid;
 | 
					    display:grid;
 | 
				
			||||||
    grid-template-columns:250px 250px 250px 150px;
 | 
					    grid-template-columns:27.7% 27.7% 27.7% 16.9%;
 | 
				
			||||||
    grid-template-areas:
 | 
					    grid-template-areas:
 | 
				
			||||||
    "role surname firstname infos"; 
 | 
					    "role surname firstname infos"; 
 | 
				
			||||||
    column-gap:10px;
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
  }
 | 
					  }
 | 
				
			||||||
  
 | 
					  
 | 
				
			||||||
  .infos {
 | 
					  .infos {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    grid-area:infos;
 | 
					    grid-area:infos;
 | 
				
			||||||
    align-items:center;
 | 
					    align-self:center;
 | 
				
			||||||
  }
 | 
					  }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  .role {
 | 
					  .role {
 | 
				
			||||||
@ -67,20 +64,18 @@
 | 
				
			|||||||
  button{
 | 
					  button{
 | 
				
			||||||
    font-size:15px;
 | 
					    font-size:15px;
 | 
				
			||||||
     height:50px;
 | 
					     height:50px;
 | 
				
			||||||
     width:100px;
 | 
					     width:75%;
 | 
				
			||||||
    border:none;
 | 
					    border:none;
 | 
				
			||||||
    border-radius:20px;
 | 
					    border-radius:20px;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  }
 | 
					  }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  .bodu {
 | 
					  .bodu {
 | 
				
			||||||
    width:100%;
 | 
					    margin-top:2%;
 | 
				
			||||||
    margin-bottom:10px;
 | 
					    width:66%;
 | 
				
			||||||
    border:2px solid black;
 | 
					    border:2px solid black;
 | 
				
			||||||
    border-radius:9px;
 | 
					    border-radius:9px;
 | 
				
			||||||
    background-color:rgb(50,50,50);
 | 
					    background-color:rgb(50,50,50);
 | 
				
			||||||
  }
 | 
					  }
 | 
				
			||||||
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
</style>
 | 
					</style>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
				
			|||||||
@ -1,4 +1,11 @@
 | 
				
			|||||||
body {
 | 
					body {
 | 
				
			||||||
   background-color: rgb(53, 25, 60);
 | 
					   background-color: rgb(53, 25, 60);
 | 
				
			||||||
   margin:0;
 | 
					   margin:0;
 | 
				
			||||||
 | 
					   width: 100vw;
 | 
				
			||||||
 | 
					   height: 100vh;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#app {
 | 
				
			||||||
 | 
					   width: 100%;
 | 
				
			||||||
 | 
					   height: 100%;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
				
			|||||||
@ -26,7 +26,7 @@ export function disconnect(){
 | 
				
			|||||||
 * @param curriculum 
 | 
					 * @param curriculum 
 | 
				
			||||||
 * @param imageId	id of the image in database returned when uploaded
 | 
					 * @param imageId	id of the image in database returned when uploaded
 | 
				
			||||||
 */
 | 
					 */
 | 
				
			||||||
export async function register(firstname, lastname, birthDate, password, email, address, country, curriculumId, imageId){
 | 
					export async function register(firstname, lastname, birthDate, password, email, address, country, curriculumId, imageId, identityCardId, submissionDate){
 | 
				
			||||||
	return restPost("/register", {
 | 
						return restPost("/register", {
 | 
				
			||||||
		firstName: firstname,
 | 
							firstName: firstname,
 | 
				
			||||||
		lastName: lastname,
 | 
							lastName: lastname,
 | 
				
			||||||
@ -36,7 +36,9 @@ export async function register(firstname, lastname, birthDate, password, email,
 | 
				
			|||||||
		address: address,
 | 
							address: address,
 | 
				
			||||||
		country: country,
 | 
							country: country,
 | 
				
			||||||
		curriculumId: curriculumId,
 | 
							curriculumId: curriculumId,
 | 
				
			||||||
    profilePictureUrl: imageId,
 | 
					    	profilePicture: imageId,
 | 
				
			||||||
 | 
							identityCard : identityCardId,
 | 
				
			||||||
 | 
							submissionDate : submissionDate
 | 
				
			||||||
	});
 | 
						});
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@ -52,7 +54,7 @@ export async function register(firstname, lastname, birthDate, password, email,
 | 
				
			|||||||
 * @param country
 | 
					 * @param country
 | 
				
			||||||
 * @param imageId	id of the image in database returned when uploaded
 | 
					 * @param imageId	id of the image in database returned when uploaded
 | 
				
			||||||
 *
 | 
					 *
 | 
				
			||||||
 * PS: the password is not is not required as it is generated by the backend and sent to the user
 | 
					 * PS: the password is not required as it is generated by the backend and sent to the user
 | 
				
			||||||
 * by mail. it's up to the user to change it if he cares about security
 | 
					 * by mail. it's up to the user to change it if he cares about security
 | 
				
			||||||
 */
 | 
					 */
 | 
				
			||||||
export async function createUser(firstname, lastname, birthDate, email, address, country, role, imageId){
 | 
					export async function createUser(firstname, lastname, birthDate, email, address, country, role, imageId){
 | 
				
			||||||
 | 
				
			|||||||
@ -9,6 +9,7 @@ import Profil from "@/Apps/Profil.vue"
 | 
				
			|||||||
import Courses from "@/Apps/ManageCourses.vue"
 | 
					import Courses from "@/Apps/ManageCourses.vue"
 | 
				
			||||||
import Users from "@/Apps/UsersList.vue"
 | 
					import Users from "@/Apps/UsersList.vue"
 | 
				
			||||||
import Students from "@/Apps/StudentsList.vue"
 | 
					import Students from "@/Apps/StudentsList.vue"
 | 
				
			||||||
 | 
					import AboutStudent from "@/Apps/AboutStudent.vue";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
const apps = {
 | 
					const apps = {
 | 
				
			||||||
		'/login': LoginPage,
 | 
							'/login': LoginPage,
 | 
				
			||||||
 | 
				
			|||||||
@ -48,3 +48,7 @@ export async function altercurriculum(id, courses){
 | 
				
			|||||||
export async function getSelfCurriculum(){
 | 
					export async function getSelfCurriculum(){
 | 
				
			||||||
  return restGet("/curriculum");
 | 
					  return restGet("/curriculum");
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					export async function getSomeonesCurriculumList(user){
 | 
				
			||||||
 | 
						return restGet("/onescurriculum/"+user)
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
				
			|||||||
@ -7,5 +7,17 @@ import { restPostFile } from '@/rest/restConsumer.js'
 | 
				
			|||||||
export async function uploadProfilePicture(file){
 | 
					export async function uploadProfilePicture(file){
 | 
				
			||||||
	const formData = new FormData();
 | 
						const formData = new FormData();
 | 
				
			||||||
	formData.append("file", file[0]);
 | 
						formData.append("file", file[0]);
 | 
				
			||||||
	return restPostFile("/upload/ProfilePicture", formData)
 | 
					
 | 
				
			||||||
 | 
						return restPostFile("/upload/ProfilePicture", formData);
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * More generic version of the upload method
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					export async function uploadFile(file, type){
 | 
				
			||||||
 | 
						const formData = new FormData();
 | 
				
			||||||
 | 
						formData.append("file", file[0]);
 | 
				
			||||||
 | 
						return restPostFile("/upload/"+type, formData)
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
		Reference in New Issue
	
	Block a user