Compare commits
	
		
			90 Commits
		
	
	
		
			wal/front/
			...
			bc87748b31
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| bc87748b31 | |||
| 7cdbf6de74 | |||
| be23c3ab91 | |||
| 0ffc8077db | |||
| bd1c236635 | |||
| c15ddccbb0 | |||
| 211bf77322 | |||
| 4e14370d4f | |||
| 10c1c6096d | |||
| 69fb4e881e | |||
| 25575fa4e0 | |||
| 5a57fc78f3 | |||
| 70a8e98a0e | |||
| a9e52d34d4 | |||
| 8a5a26e2ab | |||
| c9556e1eea | |||
| 78507f798f | |||
| f9b12a5061 | |||
| 8724748642 | |||
| f19236b3f7 | |||
| cba11d54ff | |||
| a27cf63daf | |||
| 1be7b4cdbe | |||
| 058c53dbbc | |||
| caa39696d2 | |||
| b9d7950e12 | |||
| c0233fce57 | |||
| a2be04bfb3 | |||
| 451944e4fb | |||
| c434b28fe3 | |||
| a89d1b192c | |||
| 61eac8959a | |||
| 05bff0fa77 | |||
| 9112004326 | |||
| 98c9d2d754 | |||
| 8ebedec689 | |||
| 4199663d64 | |||
| adaa828810 | |||
| 34c0a2bfe8 | |||
| 706481ed1a | |||
| 0c04bed799 | |||
| 95ef4023d6 | |||
| 9d0b3da9d3 | |||
| 76c3b76153 | |||
| 21a5dbdb22 | |||
| 142ea996d8 | |||
| e6e147af26 | |||
| 194b14f02b | |||
| aa3e1cb868 | |||
| 3c721de18b | |||
| 5bb7606721 | |||
| b049c46571 | |||
| 648b73b585 | |||
| 9937a7db39 | |||
| 443cf55784 | |||
| 7ca5c34afe | |||
| 2b9bdf8dac | |||
| ccb954e348 | |||
| 3761fa6f49 | |||
| cb36aa8a30 | |||
| 2b9493422d | |||
| 8442101c40 | |||
| bce53305b3 | |||
| 47e4fb2f8c | |||
| 2e2837fec4 | |||
| 0e26e1a0db | |||
| 4a314449ad | |||
| ce56e37a33 | |||
| 1c61a356a4 | |||
| 2bdffe6ab4 | |||
| a3c9d6a7c0 | |||
| 729d1ad504 | |||
| 1522d74ed3 | |||
| b4499e04c7 | |||
| 94f12f0a86 | |||
| 839ca414ce | |||
| eafff6ec2d | |||
| 914f6bdf36 | |||
| 66e7fa24a1 | |||
| 7b9f021c24 | |||
| 2dfa0a0ee0 | |||
| 9e0db361b8 | |||
| 621f568ba2 | |||
| 972d08a54d | |||
| 7a13d412f1 | |||
| 67fa630ecf | |||
| ad0e7b3e35 | |||
| 9de4b06e75 | |||
| 123fa97611 | |||
| acd1262955 | 
							
								
								
									
										29
									
								
								README.md
									
									
									
									
									
								
							
							
						
						
									
										29
									
								
								README.md
									
									
									
									
									
								
							| @ -9,10 +9,33 @@ Projet du groupe 01: | |||||||
| - William Karpinski: Extension gestion des horaires | - William Karpinski: Extension gestion des horaires | ||||||
| - Léo Moulin: Extension inscription des étudiants | - Léo Moulin: Extension inscription des étudiants | ||||||
|  |  | ||||||
|  | ## Running | ||||||
|  |  | ||||||
|  | Le projet peut être lancé grace à docker compose. | ||||||
|  |  | ||||||
|  | ```sh | ||||||
|  | $ docker compose up  | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | Dans le cas ou vous modifiers des fichiers, pour éviter que les images de docker soient recrées avec les changement | ||||||
|  |  | ||||||
|  | ```sh | ||||||
|  | $ docker compose up --force-recreate --build | ||||||
|  | ``` | ||||||
|  |  | ||||||
| ## Dévelopement | ## Dévelopement | ||||||
|  |  | ||||||
| ``` | Dans le cas ou vous êtes dans une phase de développement, il est plus simple d'utiliser gradle pour lancer le backend et frontend dans un mode de développement. | ||||||
| $ ./gradlew backend:run frontend:run --parallel | **Attention**: Ce mode n'est pas fait pour être utilisé en production! | ||||||
| ``` |  | ||||||
|  |  | ||||||
|  | ```sh | ||||||
|  | $ ./gradlew run --parallel | ||||||
|  | ``` | ||||||
| permet de lancer le frontend sur [http://localhost:5173](http://localhost:5173) ansi que le frontend sur [http://localhost:8080](http://localhost:8080)  | permet de lancer le frontend sur [http://localhost:5173](http://localhost:5173) ansi que le frontend sur [http://localhost:8080](http://localhost:8080)  | ||||||
|  |  | ||||||
|  | Ceci requière également docker pour lancer une instance de postgresql pris en charge par spring. | ||||||
|  |  | ||||||
|  | Il est possible de se passer entièrement de docker en supprimant la dépendance dans le fichier `backend/build.gradle.kts`: ~~`developmentOnly("org.springframework.boot:spring-boot-docker-compose")`~~ | ||||||
|  | Il est alors nécéssaire d'avoir une instance de postgresql tournant sur `localhost:5432` avec une table `clyde`, utilisateur: `devel` et password: `devel` | ||||||
|  | (cette configuration peut également être changée dans le fichier resources/application.properties de spring) | ||||||
|  |  | ||||||
|  | |||||||
| @ -1,6 +1,15 @@ | |||||||
|  | ## Building phase | ||||||
|  | FROM gradle:jdk21-alpine AS BUILD | ||||||
|  | WORKDIR /backend | ||||||
|  |    | ||||||
|  | COPY . . | ||||||
|  | RUN gradle build -x test | ||||||
|  |  | ||||||
|  | ## Running Phase | ||||||
| FROM eclipse-temurin:21-jdk-alpine | FROM eclipse-temurin:21-jdk-alpine | ||||||
| VOLUME /tmp | WORKDIR /backend | ||||||
| VOLUME /cdn | VOLUME /cdn | ||||||
| ENV SPRING_PROFILES_ACTIVE=prod | # ENV SPRING_PROFILES_ACTIVE=prod | ||||||
| COPY build/libs/backend-0.0.1-SNAPSHOT.jar /app.jar | COPY --from=BUILD /backend/build/libs/Clyde-0.0.1-SNAPSHOT.jar /backend/app.jar | ||||||
| ENTRYPOINT ["java", "-jar", "/app.jar"] | EXPOSE 8080 | ||||||
|  | ENTRYPOINT ["java", "-jar", "/backend/app.jar"] | ||||||
|  | |||||||
| @ -16,6 +16,8 @@ repositories { | |||||||
| } | } | ||||||
|  |  | ||||||
| dependencies { | dependencies { | ||||||
|  | 	compileOnly("org.projectlombok:lombok") | ||||||
|  | 	annotationProcessor("org.projectlombok:lombok") | ||||||
| 	implementation("org.springframework.boot:spring-boot-starter-jdbc") | 	implementation("org.springframework.boot:spring-boot-starter-jdbc") | ||||||
| 	implementation("org.springframework.boot:spring-boot-starter-data-jpa") | 	implementation("org.springframework.boot:spring-boot-starter-data-jpa") | ||||||
| 	implementation("org.springframework.boot:spring-boot-starter-mail") | 	implementation("org.springframework.boot:spring-boot-starter-mail") | ||||||
| @ -25,7 +27,6 @@ dependencies { | |||||||
| 	implementation("com.kohlschutter.junixsocket:junixsocket-core:2.9.0") | 	implementation("com.kohlschutter.junixsocket:junixsocket-core:2.9.0") | ||||||
| 	// implementation("org.springframework.session:spring-session-jdbc") | 	// implementation("org.springframework.session:spring-session-jdbc") | ||||||
| 	developmentOnly("org.springframework.boot:spring-boot-devtools") | 	developmentOnly("org.springframework.boot:spring-boot-devtools") | ||||||
| 	developmentOnly("org.springframework.boot:spring-boot-docker-compose") |  | ||||||
| 	runtimeOnly("org.postgresql:postgresql") | 	runtimeOnly("org.postgresql:postgresql") | ||||||
| 	testImplementation("org.springframework.boot:spring-boot-starter-test") | 	testImplementation("org.springframework.boot:spring-boot-starter-test") | ||||||
| 	testImplementation("org.springframework.boot:spring-boot-testcontainers") | 	testImplementation("org.springframework.boot:spring-boot-testcontainers") | ||||||
|  | |||||||
							
								
								
									
										13
									
								
								backend/settings.gradle.kts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										13
									
								
								backend/settings.gradle.kts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,13 @@ | |||||||
|  | /* | ||||||
|  |  * This file was generated by the Gradle 'init' task. | ||||||
|  |  * | ||||||
|  |  * The settings file is used to specify which projects to include in your build. | ||||||
|  |  * For more detailed information on multi-project builds, please refer to https://docs.gradle.org/8.6/userguide/multi_project_builds.html in the Gradle documentation. | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | plugins { | ||||||
|  |     // Apply the foojay-resolver plugin to allow automatic download of JDKs | ||||||
|  |     id("org.gradle.toolchains.foojay-resolver-convention") version "0.7.0" | ||||||
|  | } | ||||||
|  |  | ||||||
|  | rootProject.name = "Clyde" | ||||||
| @ -0,0 +1,34 @@ | |||||||
|  | package ovh.herisson.Clyde.DTO.Msg; | ||||||
|  |  | ||||||
|  | /****************************************************** | ||||||
|  |  * @file DiscussionDTO.java | ||||||
|  |  * @author Anthony Debucquoy | ||||||
|  |  * @scope Extension messagerie | ||||||
|  |  * | ||||||
|  |  * File to format a discussion using messageDTO  | ||||||
|  |  ******************************************************/ | ||||||
|  |  | ||||||
|  | import java.util.ArrayList; | ||||||
|  | import java.util.List; | ||||||
|  | import java.util.stream.Collectors; | ||||||
|  |  | ||||||
|  | import lombok.AllArgsConstructor; | ||||||
|  | import lombok.Data; | ||||||
|  | import ovh.herisson.Clyde.Tables.User; | ||||||
|  | import ovh.herisson.Clyde.Tables.Msg.Discussion; | ||||||
|  | import ovh.herisson.Clyde.DTO.Msg.MessagesDTO; | ||||||
|  |  | ||||||
|  | @Data | ||||||
|  | @AllArgsConstructor | ||||||
|  | public class DiscussionDTO { | ||||||
|  | 	private long id; | ||||||
|  | 	private String name; | ||||||
|  | 	private List<User> members; | ||||||
|  | 	private List<MessagesDTO> msgs; | ||||||
|  |  | ||||||
|  | 	public static DiscussionDTO construct(Discussion d, User u){ | ||||||
|  | 		List<MessagesDTO> msgsdto = new ArrayList<>(); | ||||||
|  | 		d.getMsgs().forEach(x -> msgsdto.add(MessagesDTO.construct(x, u))); | ||||||
|  | 		return new DiscussionDTO(d.getId(), d.getName(), d.getMembers(), msgsdto); | ||||||
|  | 	}  | ||||||
|  | } | ||||||
| @ -0,0 +1,33 @@ | |||||||
|  | package ovh.herisson.Clyde.DTO.Msg; | ||||||
|  |  | ||||||
|  | /****************************************************** | ||||||
|  |  * @file MessagesDTO.java | ||||||
|  |  * @author Anthony Debucquoy | ||||||
|  |  * @scope Extension messagerie | ||||||
|  |  * | ||||||
|  |  * File to Format the response adding the sender field | ||||||
|  |  ******************************************************/ | ||||||
|  |  | ||||||
|  | import lombok.AllArgsConstructor; | ||||||
|  | import lombok.Data; | ||||||
|  | import ovh.herisson.Clyde.Tables.User; | ||||||
|  | import ovh.herisson.Clyde.Tables.Msg.Message; | ||||||
|  | import java.util.Date; | ||||||
|  |  | ||||||
|  | @Data | ||||||
|  | @AllArgsConstructor | ||||||
|  | public class MessagesDTO { | ||||||
|  | 	private long id; | ||||||
|  | 	private String content;  | ||||||
|  | 	private User author; | ||||||
|  | 	private boolean sender; | ||||||
|  | 	private Date created; | ||||||
|  | 	//TODO: Attachment | ||||||
|  |  | ||||||
|  | 	public static MessagesDTO construct(Message m, User user){ | ||||||
|  | 		boolean sender = false; | ||||||
|  | 		if(m.getAuthor().equals(user)) | ||||||
|  | 			sender = true; | ||||||
|  | 		return new MessagesDTO(m.getId(), m.getContent(), m.getAuthor(), sender, m.getCreated()); | ||||||
|  | 	} | ||||||
|  | } | ||||||
| @ -47,6 +47,7 @@ public class ApplicationsController { | |||||||
|  |  | ||||||
|         //if unAuthed |         //if unAuthed | ||||||
|         authorizedApps.add(Applications.Login); |         authorizedApps.add(Applications.Login); | ||||||
|  |         authorizedApps.add(Applications.Schedule); | ||||||
|  |  | ||||||
| 		User user = authServ.getUserFromToken(token); | 		User user = authServ.getUserFromToken(token); | ||||||
| 		if(user == null) | 		if(user == null) | ||||||
| @ -60,16 +61,23 @@ public class ApplicationsController { | |||||||
|             authorizedApps.add(Applications.Rdv); |             authorizedApps.add(Applications.Rdv); | ||||||
|         } |         } | ||||||
|  |  | ||||||
|  |         if(!authServ.isNotIn(new Role[]{Role.Teacher,Role.Admin},token)) | ||||||
|  |             authorizedApps.add(Applications.ManageOwnedLessons); | ||||||
|         //if Teacher or Secretary or Admin add ManageCourses App |         //if Teacher or Secretary or Admin add ManageCourses App | ||||||
|         if (!authServ.isNotIn(new Role[]{Role.Teacher,Role.Secretary,Role.Admin},token)) |         if (!authServ.isNotIn(new Role[]{Role.Teacher,Role.Secretary,Role.Admin},token)) | ||||||
|             authorizedApps.add(Applications.ManageCourses); |             authorizedApps.add(Applications.ManageCourses); | ||||||
|  |  | ||||||
|         if (!authServ.isNotIn(new Role[]{Role.InscriptionService,Role.Admin},token)){ |         if (!authServ.isNotIn(new Role[]{Role.InscriptionService,Role.Admin, Role.Teacher},token)){ | ||||||
|             authorizedApps.add(Applications.Inscription); |             authorizedApps.add(Applications.Requests); | ||||||
|             authorizedApps.add(Applications.StudentsList);} |             authorizedApps.add(Applications.StudentsList);} | ||||||
|  |  | ||||||
|         if (!authServ.isNotIn(new Role[]{Role.Secretary,Role.Admin},token)){  |         if (!authServ.isNotIn(new Role[]{Role.Secretary,Role.Admin},token)){  | ||||||
|           authorizedApps.add(Applications.UsersList);} |           authorizedApps.add(Applications.UsersList); | ||||||
|  |           authorizedApps.add(Applications.ManageSchedules); | ||||||
|  |           authorizedApps.add(Applications.LessonRequests);} | ||||||
|  |  | ||||||
|  |         if (!authServ.isNotIn(new Role[]{Role.Secretary,Role.Admin, Role.InscriptionService},token)){ | ||||||
|  |             authorizedApps.add(Applications.Payments);} | ||||||
|         return authorizedApps; |         return authorizedApps; | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  | |||||||
| @ -74,11 +74,9 @@ public class CourseController { | |||||||
|     public ResponseEntity<Map<String ,Object>> postCourse(@RequestHeader("Authorization") String token, |     public ResponseEntity<Map<String ,Object>> postCourse(@RequestHeader("Authorization") String token, | ||||||
|                                              @RequestBody Course course) |                                              @RequestBody Course course) | ||||||
|     { |     { | ||||||
|         System.out.println(course); |  | ||||||
|         System.out.println(token); |  | ||||||
|         if (authServ.isNotIn(new Role[]{Role.Secretary,Role.Admin},token)) |         if (authServ.isNotIn(new Role[]{Role.Secretary,Role.Admin},token)) | ||||||
|             return new UnauthorizedResponse<>(null); |             return new UnauthorizedResponse<>(null); | ||||||
|  |         System.out.println(course.getOwner().getRegNo()); | ||||||
|         Course createdCourse = courseServ.save(course); |         Course createdCourse = courseServ.save(course); | ||||||
|         if (createdCourse == null) |         if (createdCourse == null) | ||||||
|             return new ResponseEntity<>(null,HttpStatus.BAD_REQUEST); |             return new ResponseEntity<>(null,HttpStatus.BAD_REQUEST); | ||||||
| @ -135,4 +133,5 @@ public class CourseController { | |||||||
|         courseServ.delete(courseServ.findById(id)); |         courseServ.delete(courseServ.findById(id)); | ||||||
|         return new ResponseEntity<>(HttpStatus.OK); |         return new ResponseEntity<>(HttpStatus.OK); | ||||||
|     } |     } | ||||||
|  |  | ||||||
| } | } | ||||||
|  | |||||||
| @ -4,11 +4,13 @@ package ovh.herisson.Clyde.EndPoints; | |||||||
| import org.springframework.http.HttpStatus; | import org.springframework.http.HttpStatus; | ||||||
| import org.springframework.http.ResponseEntity; | import org.springframework.http.ResponseEntity; | ||||||
| import org.springframework.web.bind.annotation.*; | import org.springframework.web.bind.annotation.*; | ||||||
|  | import ovh.herisson.Clyde.Repositories.Inscription.ExternalCurriculumRepository; | ||||||
|  | import ovh.herisson.Clyde.Repositories.Inscription.InscriptionRepository; | ||||||
| import ovh.herisson.Clyde.Responses.UnauthorizedResponse; | 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.*; | ||||||
| import ovh.herisson.Clyde.Tables.Role; |  | ||||||
|  |  | ||||||
|  | import java.util.HashMap; | ||||||
| import java.util.Map; | import java.util.Map; | ||||||
|  |  | ||||||
| @RestController | @RestController | ||||||
| @ -21,12 +23,18 @@ public class CurriculumController { | |||||||
|  |  | ||||||
|     private final UserCurriculumService userCurriculumServ; |     private final UserCurriculumService userCurriculumServ; | ||||||
|     private final CurriculumCourseService curriculumCourseServ; |     private final CurriculumCourseService curriculumCourseServ; | ||||||
|  |     private final InscriptionRepository ir; | ||||||
|  |     private final UserService userServ; | ||||||
|  |  | ||||||
|     public CurriculumController(CurriculumService curriculumServ, AuthenticatorService authServ, UserCurriculumService userCurriculumServ, CurriculumCourseService curriculumCourseServ){ |     private final ExternalCurriculumRepository ecr; | ||||||
|  |     public CurriculumController(CurriculumService curriculumServ, AuthenticatorService authServ, UserCurriculumService userCurriculumServ, CurriculumCourseService curriculumCourseServ, InscriptionRepository ir, UserService userServ, ExternalCurriculumRepository ecr){ | ||||||
|         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.ir = ir; | ||||||
|  |         this.userServ = userServ; | ||||||
|  |         this.ecr = ecr; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @GetMapping("/curriculum/{id}") |     @GetMapping("/curriculum/{id}") | ||||||
| @ -52,6 +60,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 +118,5 @@ public class CurriculumController { | |||||||
|         curriculumServ.delete(toDelete); |         curriculumServ.delete(toDelete); | ||||||
|         return new ResponseEntity<>(HttpStatus.OK); |         return new ResponseEntity<>(HttpStatus.OK); | ||||||
|     } |     } | ||||||
|  |  | ||||||
| } | } | ||||||
|  | |||||||
| @ -0,0 +1,62 @@ | |||||||
|  | package ovh.herisson.Clyde.EndPoints.Inscription; | ||||||
|  |  | ||||||
|  | import org.springframework.http.HttpStatus; | ||||||
|  | import org.springframework.http.ResponseEntity; | ||||||
|  | import org.springframework.web.bind.annotation.*; | ||||||
|  | import ovh.herisson.Clyde.Repositories.Inscription.ExternalCurriculumRepository; | ||||||
|  | import ovh.herisson.Clyde.Repositories.Inscription.InscriptionRepository; | ||||||
|  | import ovh.herisson.Clyde.Repositories.UserRepository; | ||||||
|  | import ovh.herisson.Clyde.Tables.Inscription.ExternalCurriculum; | ||||||
|  | import ovh.herisson.Clyde.Tables.Inscription.InscriptionRequest; | ||||||
|  | import ovh.herisson.Clyde.Tables.User; | ||||||
|  |  | ||||||
|  | import java.util.ArrayList; | ||||||
|  | import java.util.Map; | ||||||
|  |  | ||||||
|  | @RestController | ||||||
|  | @CrossOrigin(originPatterns = "*", allowCredentials = "true") | ||||||
|  | public class ExternalCurriculumController { | ||||||
|  |  | ||||||
|  |     public final ExternalCurriculumRepository ecr; | ||||||
|  |     public final InscriptionRepository inscriptionRepository; | ||||||
|  |     public final UserRepository userRepository; | ||||||
|  |  | ||||||
|  |     public ExternalCurriculumController(ExternalCurriculumRepository ecr, InscriptionRepository inscriptionRepository, UserRepository userRepository) { | ||||||
|  |         this.ecr = ecr; | ||||||
|  |         this.inscriptionRepository = inscriptionRepository; | ||||||
|  |         this.userRepository = userRepository; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     //everyone can post some externalcurriculums (the validity of the elements is assured by the inscription service) | ||||||
|  |     @PostMapping("/externalcurriculum") | ||||||
|  |     public ResponseEntity<ExternalCurriculum> postExternalCurriculum(@RequestBody Map<String, Object> externalCurrInfos){ | ||||||
|  |         //An external curriculum can either be linked to an User or to an InscriptionRequest | ||||||
|  |         InscriptionRequest ir = null; | ||||||
|  |         User user = null; | ||||||
|  |         if (externalCurrInfos.get("inscriptionRequestId") != null){ | ||||||
|  |             ir = inscriptionRepository.findById((Integer) externalCurrInfos.get("inscriptionRequestId")); | ||||||
|  |         }else{ | ||||||
|  |             user = userRepository.findById((Integer) externalCurrInfos.get("userRegNo")); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         ExternalCurriculum toSave = new ExternalCurriculum(ir, (String) externalCurrInfos.get("school"),(String) externalCurrInfos.get("formation"),(String) externalCurrInfos.get("completion"), (Integer)externalCurrInfos.get("startYear"), (Integer)externalCurrInfos.get("endYear"), (String)externalCurrInfos.get("justifDocUrl"), user); | ||||||
|  |  | ||||||
|  |         return new ResponseEntity<>(ecr.save(toSave), HttpStatus.OK); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @GetMapping("/externalcurriculum/{inscReqId}") | ||||||
|  |     public ResponseEntity<ArrayList<ExternalCurriculum>> getExternalCurrListByInscrReq(@PathVariable long inscReqId){ | ||||||
|  |         InscriptionRequest ir = inscriptionRepository.findById(inscReqId); | ||||||
|  |  | ||||||
|  |         ArrayList<ExternalCurriculum> toReturn = ecr.getExternalCurriculumByInscriptionRequest(ir); | ||||||
|  |         return new ResponseEntity<>(toReturn, HttpStatus.OK); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @GetMapping("/externalcurriculumbyuser/{userId}") | ||||||
|  |     public ResponseEntity<ArrayList<ExternalCurriculum>> getExternalCurrByUser(@PathVariable long userId){ | ||||||
|  |         User user = userRepository.findById(userId); | ||||||
|  |  | ||||||
|  |         ArrayList<ExternalCurriculum> toReturn = ecr.getExternalCurriculumByUser(user); | ||||||
|  |         return new ResponseEntity<>(toReturn, HttpStatus.OK); | ||||||
|  |     } | ||||||
|  | } | ||||||
| @ -1,13 +1,13 @@ | |||||||
| package ovh.herisson.Clyde.EndPoints; | package ovh.herisson.Clyde.EndPoints.Inscription; | ||||||
| 
 | 
 | ||||||
| import org.springframework.http.HttpStatus; | import org.springframework.http.HttpStatus; | ||||||
| import org.springframework.http.ResponseEntity; | import org.springframework.http.ResponseEntity; | ||||||
| import org.springframework.web.bind.annotation.*; | import org.springframework.web.bind.annotation.*; | ||||||
| import ovh.herisson.Clyde.Responses.UnauthorizedResponse; | import ovh.herisson.Clyde.Responses.UnauthorizedResponse; | ||||||
| import ovh.herisson.Clyde.Services.AuthenticatorService; | import ovh.herisson.Clyde.Services.AuthenticatorService; | ||||||
| import ovh.herisson.Clyde.Services.InscriptionService; | import ovh.herisson.Clyde.Services.Inscription.InscriptionService; | ||||||
| import ovh.herisson.Clyde.Services.ProtectionService; | import ovh.herisson.Clyde.Services.ProtectionService; | ||||||
| import ovh.herisson.Clyde.Tables.InscriptionRequest; | import ovh.herisson.Clyde.Tables.Inscription.InscriptionRequest; | ||||||
| import ovh.herisson.Clyde.Tables.RequestState; | import ovh.herisson.Clyde.Tables.RequestState; | ||||||
| import ovh.herisson.Clyde.Tables.Role; | import ovh.herisson.Clyde.Tables.Role; | ||||||
| import java.util.Map; | import java.util.Map; | ||||||
| @ -79,4 +79,22 @@ public class InscriptionController { | |||||||
|         return new ResponseEntity<>(HttpStatus.OK); |         return new ResponseEntity<>(HttpStatus.OK); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  | 
 | ||||||
|  |     //Allow teacher or admin to accept or refuse the equivalence | ||||||
|  |     @PatchMapping("/request/registerequiv/{id}/{newstate}") | ||||||
|  |     public ResponseEntity<Object> editRegisterEquiv(@RequestHeader("Authorization") String token, @PathVariable long id, @PathVariable RequestState newstate){ | ||||||
|  |         if (authServ.isNotIn(new Role[]{Role.Admin,Role.Teacher}, token)) | ||||||
|  |             return new UnauthorizedResponse<>(null); | ||||||
|  | 
 | ||||||
|  |         InscriptionRequest toEdit = inscriptionServ.getById(id); | ||||||
|  |         toEdit.setEquivalenceState(newstate); | ||||||
|  | 
 | ||||||
|  |         inscriptionServ.save(toEdit); | ||||||
|  | 
 | ||||||
|  |         if (toEdit.getState() == RequestState.Accepted && (toEdit.getEquivalenceState() == RequestState.Accepted || toEdit.getEquivalenceState() == RequestState.Unrequired)) | ||||||
|  |         { | ||||||
|  |             inscriptionServ.createUser(toEdit); | ||||||
|  |         } | ||||||
|  |         return new ResponseEntity<>(HttpStatus.OK); | ||||||
|  |     } | ||||||
| } | } | ||||||
| @ -0,0 +1,55 @@ | |||||||
|  | package ovh.herisson.Clyde.EndPoints.Inscription; | ||||||
|  |  | ||||||
|  | import org.springframework.http.HttpStatus; | ||||||
|  | import org.springframework.http.ResponseEntity; | ||||||
|  | import org.springframework.web.bind.annotation.*; | ||||||
|  | import ovh.herisson.Clyde.Repositories.Inscription.MinervalRepository; | ||||||
|  | import ovh.herisson.Clyde.Responses.UnauthorizedResponse; | ||||||
|  | import ovh.herisson.Clyde.Services.AuthenticatorService; | ||||||
|  | import ovh.herisson.Clyde.Tables.Inscription.Minerval; | ||||||
|  | import ovh.herisson.Clyde.Tables.Role; | ||||||
|  |  | ||||||
|  | import java.util.*; | ||||||
|  |  | ||||||
|  | @RestController | ||||||
|  | @CrossOrigin(originPatterns = "*", allowCredentials = "true") | ||||||
|  | public class MinervalController { | ||||||
|  |     private final AuthenticatorService authServ; | ||||||
|  |     private final MinervalRepository mr; | ||||||
|  |  | ||||||
|  |     public MinervalController(AuthenticatorService authServ, MinervalRepository mr) { | ||||||
|  |         this.authServ = authServ; | ||||||
|  |         this.mr = mr; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     //A new minerval entry is posted when the inscription service accept a registration request | ||||||
|  |     @PostMapping("/minerval/{studentRegNo}") | ||||||
|  |     public ResponseEntity<Object> postMinerval(@RequestHeader("Authorization") String token, @PathVariable long studentRegNo){ | ||||||
|  |         if (authServ.isNotIn(new Role[]{Role.Admin,Role.Secretary,Role.InscriptionService},token)) | ||||||
|  |             return new UnauthorizedResponse<>(null); | ||||||
|  |  | ||||||
|  |         Calendar c = new GregorianCalendar(); | ||||||
|  |  | ||||||
|  |         mr.save(new Minerval(studentRegNo, 0, 835, c.get(Calendar.YEAR))); | ||||||
|  |         return new ResponseEntity<>(HttpStatus.OK); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @GetMapping("/minerval/{studentRegNo}") | ||||||
|  |     public ResponseEntity<Minerval> getCurrentMinervalbyRegNo(@PathVariable long studentRegNo){ | ||||||
|  |         ArrayList<Minerval> mlist = mr.getMinervalsByStudentRegNoOrderByYearDesc(studentRegNo); | ||||||
|  |  | ||||||
|  |         //The list is ordered by year in descending order then the index 0 contains the actual minerval (for this year) | ||||||
|  |         Minerval m = mlist.get(0); | ||||||
|  |         return new ResponseEntity<>(m, HttpStatus.OK); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @PatchMapping("/minerval") | ||||||
|  |     public ResponseEntity<Object> updateMinerval(@RequestBody Minerval updatedMinerval){ | ||||||
|  |         Minerval minerval = mr.findById(updatedMinerval.getId()); | ||||||
|  |  | ||||||
|  |         minerval.setPaidAmount(updatedMinerval.getPaidAmount()); | ||||||
|  |         minerval.setToPay(updatedMinerval.getToPay()); | ||||||
|  |         mr.save(minerval); | ||||||
|  |         return new ResponseEntity<>(HttpStatus.OK); | ||||||
|  |     } | ||||||
|  | } | ||||||
| @ -0,0 +1,45 @@ | |||||||
|  | package ovh.herisson.Clyde.EndPoints.Inscription; | ||||||
|  |  | ||||||
|  |  | ||||||
|  | import org.springframework.http.HttpStatus; | ||||||
|  | import org.springframework.http.ResponseEntity; | ||||||
|  | import org.springframework.web.bind.annotation.*; | ||||||
|  | import ovh.herisson.Clyde.Repositories.Inscription.PaymentRepository; | ||||||
|  | import ovh.herisson.Clyde.Tables.Inscription.Payment; | ||||||
|  |  | ||||||
|  | import java.util.ArrayList; | ||||||
|  |  | ||||||
|  | @RestController | ||||||
|  | @CrossOrigin(originPatterns = "*", allowCredentials = "true") | ||||||
|  | public class PaymentController { | ||||||
|  |  | ||||||
|  |     private final PaymentRepository paymentRepository; | ||||||
|  |  | ||||||
|  |     public PaymentController(PaymentRepository paymentRepository){ | ||||||
|  |         this.paymentRepository = paymentRepository; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     //Post a payment record | ||||||
|  |     @PostMapping("/payment") | ||||||
|  |     public ResponseEntity<Object> postPayment(@RequestBody Payment payment){ | ||||||
|  |         paymentRepository.save(payment); | ||||||
|  |         return new ResponseEntity<>(HttpStatus.OK); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |  | ||||||
|  |     //Get all payment records of a student | ||||||
|  |     @GetMapping("/payment/{studentRegNo}") | ||||||
|  |     public ResponseEntity<ArrayList<Payment>> getPaymentsByUser(@PathVariable long studentRegNo){ | ||||||
|  |         ArrayList<Payment> toReturn = paymentRepository.getPaymentsByStudentRegNo(studentRegNo); | ||||||
|  |         return new ResponseEntity<>(toReturn, HttpStatus.OK); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @GetMapping("/payment") | ||||||
|  |     public ResponseEntity<ArrayList<Payment>> getAllPayments(){ | ||||||
|  |         ArrayList<Payment> toReturn = new ArrayList<Payment>(); | ||||||
|  |  | ||||||
|  |  | ||||||
|  |         paymentRepository.findAll().forEach(toReturn::add); | ||||||
|  |         return new ResponseEntity<>(toReturn, HttpStatus.OK); | ||||||
|  |     } | ||||||
|  | } | ||||||
| @ -0,0 +1,312 @@ | |||||||
|  | package ovh.herisson.Clyde.EndPoints.Inscription; | ||||||
|  |  | ||||||
|  | import org.springframework.http.HttpStatus; | ||||||
|  | import org.springframework.http.ResponseEntity; | ||||||
|  | import org.springframework.web.bind.annotation.*; | ||||||
|  | import ovh.herisson.Clyde.Repositories.CourseRepository; | ||||||
|  | import ovh.herisson.Clyde.Repositories.CurriculumRepository; | ||||||
|  | import ovh.herisson.Clyde.Repositories.Inscription.ChangeCurriculumRequestRepository; | ||||||
|  | import ovh.herisson.Clyde.Repositories.Inscription.ExemptionsRequestRepository; | ||||||
|  | import ovh.herisson.Clyde.Repositories.Inscription.ScholarshipRequestRepository; | ||||||
|  | import ovh.herisson.Clyde.Repositories.Inscription.UnregisterRequestRepository; | ||||||
|  | import ovh.herisson.Clyde.Repositories.UserCurriculumRepository; | ||||||
|  | import ovh.herisson.Clyde.Repositories.UserRepository; | ||||||
|  | import ovh.herisson.Clyde.Responses.UnauthorizedResponse; | ||||||
|  | import ovh.herisson.Clyde.Services.AuthenticatorService; | ||||||
|  | import ovh.herisson.Clyde.Services.UserService; | ||||||
|  | import ovh.herisson.Clyde.Tables.*; | ||||||
|  | import ovh.herisson.Clyde.Tables.Inscription.ExemptionsRequest; | ||||||
|  | import ovh.herisson.Clyde.Tables.Inscription.ScholarshipRequest; | ||||||
|  | import ovh.herisson.Clyde.Tables.Inscription.UnregisterRequest; | ||||||
|  |  | ||||||
|  | import java.util.ArrayList; | ||||||
|  | import java.util.Calendar; | ||||||
|  | import java.util.Date; | ||||||
|  | import java.util.Map; | ||||||
|  |  | ||||||
|  | @RestController | ||||||
|  | @CrossOrigin(originPatterns = "*", allowCredentials = "true") | ||||||
|  | public class RequestsController { | ||||||
|  |  | ||||||
|  |     public final ExemptionsRequestRepository err; | ||||||
|  |     public final ScholarshipRequestRepository srr; | ||||||
|  |     public final UserRepository userRepository; | ||||||
|  |     public final AuthenticatorService authServ; | ||||||
|  |     public final UnregisterRequestRepository unregisterRequestRepository; | ||||||
|  |     public final CourseRepository courseRepository; | ||||||
|  |     public final UserService userService; | ||||||
|  |     public final UserCurriculumRepository userCurriculumRepository; | ||||||
|  |     public final CurriculumRepository curriculumRepository; | ||||||
|  |  | ||||||
|  |     public final ChangeCurriculumRequestRepository changeCurriculumRequestRepository; | ||||||
|  |  | ||||||
|  |     public RequestsController(ExemptionsRequestRepository err, ScholarshipRequestRepository srr, UserRepository userRepository, AuthenticatorService authServ, UnregisterRequestRepository unregisterRequestRepository, CourseRepository courseRepository, UserService userService, UserCurriculumRepository userCurriculumRepository, CurriculumRepository curriculumRepository, ChangeCurriculumRequestRepository changeCurriculumRequestRepository) { | ||||||
|  |         this.err = err; | ||||||
|  |         this.srr = srr; | ||||||
|  |         this.userRepository = userRepository; | ||||||
|  |         this.authServ = authServ; | ||||||
|  |         this.unregisterRequestRepository = unregisterRequestRepository; | ||||||
|  |         this.courseRepository = courseRepository; | ||||||
|  |         this.userService = userService; | ||||||
|  |         this.userCurriculumRepository = userCurriculumRepository; | ||||||
|  |         this.curriculumRepository = curriculumRepository; | ||||||
|  |         this.changeCurriculumRequestRepository = changeCurriculumRequestRepository; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @PostMapping(value="/exemptionreq") | ||||||
|  |     public ResponseEntity<String> createExemptionReq(@RequestBody Map<String, Object> exemptionsRequestInfo){ | ||||||
|  |         User user = userRepository.findById((Integer) exemptionsRequestInfo.get("userRegNo")); | ||||||
|  |         Course course = courseRepository.findById((Integer) exemptionsRequestInfo.get("courseId")); | ||||||
|  |  | ||||||
|  |         ExemptionsRequest exemptionsRequest = new ExemptionsRequest(user, course, (String) exemptionsRequestInfo.get("justifDocument"), RequestState.Pending, new Date()); | ||||||
|  |  | ||||||
|  |         err.save(exemptionsRequest); | ||||||
|  |  | ||||||
|  |         return new ResponseEntity<>(HttpStatus.CREATED); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @PostMapping(value="/scholarshipreq") | ||||||
|  |     public ResponseEntity<String> createScholarshipReq(@RequestBody Map<String, Object> scholarshipRequestInfo){ | ||||||
|  |         User user = userRepository.findById((Integer)scholarshipRequestInfo.get("userId")); | ||||||
|  |         ScholarshipRequest toCreate = new ScholarshipRequest(user, RequestState.Pending, 0, new Date(), (String) scholarshipRequestInfo.get("taxDocUrl"), (String) scholarshipRequestInfo.get("residencyDocUrl")); | ||||||
|  |  | ||||||
|  |         srr.save(toCreate); | ||||||
|  |  | ||||||
|  |         return new ResponseEntity<>(HttpStatus.CREATED); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     //Get all the exemptions Request | ||||||
|  |     @GetMapping(value = "/exemptionsreq") | ||||||
|  |     public ResponseEntity<ArrayList<ExemptionsRequest>> getAllExemptionsRequests(@RequestHeader("Authorization") String token){ | ||||||
|  |         if (authServ.isNotIn(new Role[]{Role.Admin,Role.Secretary,Role.InscriptionService},token)) | ||||||
|  |             return new UnauthorizedResponse<>(null); | ||||||
|  |  | ||||||
|  |         ArrayList<ExemptionsRequest> toReturn = new ArrayList<>(); | ||||||
|  |  | ||||||
|  |         err.findAll().forEach(toReturn::add); | ||||||
|  |  | ||||||
|  |         return new ResponseEntity<>(toReturn, HttpStatus.OK); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @GetMapping(value = "/exemptionsreq/{id}") | ||||||
|  |     public ResponseEntity<ExemptionsRequest> getExemptionRequestbyId(@RequestHeader("Authorization") String token, @PathVariable long id){ | ||||||
|  |         if (authServ.isNotIn(new Role[]{Role.Admin,Role.Secretary,Role.InscriptionService},token)) | ||||||
|  |             return new UnauthorizedResponse<>(null); | ||||||
|  |  | ||||||
|  |         ExemptionsRequest exemptionsRequest = err.findById(id); | ||||||
|  |  | ||||||
|  |         return new ResponseEntity<>(exemptionsRequest, HttpStatus.OK); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @PatchMapping(value = "/exemptionsreq/{id}/{newstate}") | ||||||
|  |     public ResponseEntity<String> changeExemptionReqState(@RequestHeader("Authorization") String token, @PathVariable long id, @PathVariable RequestState newstate){ | ||||||
|  |         if (authServ.isNotIn(new Role[]{Role.Admin,Role.Secretary,Role.InscriptionService},token)) | ||||||
|  |             return new UnauthorizedResponse<>(null); | ||||||
|  |  | ||||||
|  |         ExemptionsRequest exemptionsRequest = err.findById(id); | ||||||
|  |         exemptionsRequest.setState(newstate); | ||||||
|  |         err.save(exemptionsRequest); | ||||||
|  |  | ||||||
|  |         return new ResponseEntity<>(HttpStatus.OK); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     //Get all the scholarships requests | ||||||
|  |     @GetMapping(value = "/scholarshipreq") | ||||||
|  |     public ResponseEntity<ArrayList<ScholarshipRequest>> getAllScholarshipRequests(@RequestHeader("Authorization") String token){ | ||||||
|  |         if (authServ.isNotIn(new Role[]{Role.Admin,Role.Secretary,Role.InscriptionService},token)) | ||||||
|  |             return new UnauthorizedResponse<>(null); | ||||||
|  |  | ||||||
|  |         ArrayList<ScholarshipRequest> toReturn = new ArrayList<>(); | ||||||
|  |  | ||||||
|  |         srr.findAll().forEach(toReturn::add); | ||||||
|  |  | ||||||
|  |         return new ResponseEntity<>(toReturn, HttpStatus.OK); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @PostMapping(value = "/unregister") | ||||||
|  |     public ResponseEntity<String> postUnregReq(@RequestBody Map<String,Object> uninscr){ | ||||||
|  |         User u = userRepository.findById((int) uninscr.get("userId")); | ||||||
|  |         Curriculum c; | ||||||
|  |  | ||||||
|  |         if (uninscr.get("curriculumId") == null){ | ||||||
|  |             c = null; | ||||||
|  |         }else{ | ||||||
|  |             c = curriculumRepository.findById((Integer) uninscr.get("curriculumId")); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         UnregisterRequest ur = new UnregisterRequest(RequestState.Pending, (String) uninscr.get("reason"), new Date(), u.getRegNo(), u.getFirstName(), u.getLastName(), u.getEmail(), c); | ||||||
|  |         unregisterRequestRepository.save(ur); | ||||||
|  |         return new ResponseEntity<>(HttpStatus.OK); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @PatchMapping(value = "/scholarshipreq/") | ||||||
|  |     public ResponseEntity<String> editScholReq(@RequestBody Map<String,Object> infos){ | ||||||
|  |         ScholarshipRequest scholarshipRequest = srr.findById((Integer) infos.get("id")); | ||||||
|  |  | ||||||
|  |         if (infos.get("state").equals("Accepted")){ | ||||||
|  |             scholarshipRequest.setState(RequestState.Accepted); | ||||||
|  |             scholarshipRequest.setAmount((int) infos.get("amount")); | ||||||
|  |         }else{ | ||||||
|  |             scholarshipRequest.setState(RequestState.Refused); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         srr.save(scholarshipRequest); | ||||||
|  |         return new ResponseEntity<>(HttpStatus.OK); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @GetMapping(value = "/scholarshipreq/{id}") | ||||||
|  |     public ResponseEntity<ScholarshipRequest> getScholReqbyId(@PathVariable long id){ | ||||||
|  |         ScholarshipRequest toReturn = srr.findById(id); | ||||||
|  |         return new ResponseEntity<>(toReturn, HttpStatus.OK); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @GetMapping(value = "/unregister") | ||||||
|  |     public ResponseEntity<ArrayList<UnregisterRequest>> getAllUnregReq(){ | ||||||
|  |         ArrayList<UnregisterRequest> toReturn = new ArrayList<>(); | ||||||
|  |         unregisterRequestRepository.findAll().forEach(toReturn::add); | ||||||
|  |         return new ResponseEntity<>(toReturn, HttpStatus.OK); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @GetMapping(value = "/unregister/{id}") | ||||||
|  |     public ResponseEntity<UnregisterRequest> getUnregbyId(@PathVariable long id){ | ||||||
|  |         UnregisterRequest unregisterRequest = unregisterRequestRepository.findById(id); | ||||||
|  |         return new ResponseEntity<>(unregisterRequest, HttpStatus.OK); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @PatchMapping(value = "/unregister/{id}/{newstate}") | ||||||
|  |     public ResponseEntity<String> pathUnregReq(@PathVariable long id, @PathVariable RequestState newstate){ | ||||||
|  |         UnregisterRequest unregisterRequest = unregisterRequestRepository.findById(id); | ||||||
|  |         User u = userRepository.findById(unregisterRequest.getRegNo()); | ||||||
|  |         unregisterRequest.setState(newstate); | ||||||
|  |  | ||||||
|  |         if (newstate == RequestState.Accepted){ | ||||||
|  |             if (unregisterRequest.getCurriculum() == null){ | ||||||
|  |                 ArrayList<UserCurriculum> userCurricula = userCurriculumRepository.findByUserOrderByCurriculum(u); | ||||||
|  |                 for (int i = 0; i < userCurricula.size(); i++){ | ||||||
|  |                     userCurricula.get(i).setActual(false); | ||||||
|  |                 } | ||||||
|  |                 userCurriculumRepository.saveAll(userCurricula); | ||||||
|  |             }else{ | ||||||
|  |                 //This usercurriculum will contain the usercurriculum to set false | ||||||
|  |                 UserCurriculum userCurriculum = userCurriculumRepository.findByUserAndCurriculumAndActual(u, unregisterRequest.getCurriculum(), true); | ||||||
|  |                 userCurriculum.setActual(false); | ||||||
|  |                 userCurriculumRepository.save(userCurriculum); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         unregisterRequestRepository.save(unregisterRequest); | ||||||
|  |         return new ResponseEntity<>(HttpStatus.OK); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     //We look in the usercursus table if the student has already the previous year of a curriculum | ||||||
|  |     public boolean studentHasPrevYear(Curriculum curriculum, User user){ | ||||||
|  |         ArrayList<UserCurriculum> userCurrList = userCurriculumRepository.findByUserOrderByCurriculum(user); | ||||||
|  |         for (int i = 0; i < userCurrList.size(); i++){ | ||||||
|  |             if (userCurrList.get(i).getCurriculum().getOption().equals(curriculum.getOption()) && userCurrList.get(i).getCurriculum().getYear() == curriculum.getYear()-1){ | ||||||
|  |                 return true; | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |         return false; | ||||||
|  |     } | ||||||
|  |     @PostMapping("/changecurriculumreq") | ||||||
|  |     public ResponseEntity<String> addChangeCurrReq(@RequestBody Map<String,Object> reqInfos){ | ||||||
|  |         User user = userRepository.findById((Integer) reqInfos.get("userId")); | ||||||
|  |  | ||||||
|  |         Curriculum actualCurriculum; | ||||||
|  |  | ||||||
|  |         //If null then it means we are in a supplementary cursus case | ||||||
|  |         if (reqInfos.get("actualcursus") == null){ | ||||||
|  |             actualCurriculum = null; | ||||||
|  |         }else{ | ||||||
|  |             actualCurriculum = curriculumRepository.findById((Integer) reqInfos.get("actualcursus")); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         Curriculum destinationCurriculum = curriculumRepository.findById((Integer) reqInfos.get("newcursus")); | ||||||
|  |  | ||||||
|  |         ChangeCurriculumRequest changeCurriculumRequest = new ChangeCurriculumRequest(user, actualCurriculum, destinationCurriculum, new Date(), RequestState.Pending, RequestState.Unrequired); | ||||||
|  |  | ||||||
|  |         //Si l'année du cursus est plus grande que 1 et que l'étudiant n'a pas dans sa liste de cursus l'année d'en dessous alors on demande l'accord du prof | ||||||
|  |         if (destinationCurriculum.getYear() > 1 && !studentHasPrevYear(destinationCurriculum, user)){ | ||||||
|  |             changeCurriculumRequest.setTeacherApprovalState(RequestState.Pending); | ||||||
|  |         } | ||||||
|  |         changeCurriculumRequestRepository.save(changeCurriculumRequest); | ||||||
|  |  | ||||||
|  |         return new ResponseEntity<>(HttpStatus.OK); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @GetMapping("/changecurriculumreq") | ||||||
|  |     public  ResponseEntity<ArrayList <ChangeCurriculumRequest>> getAllChangeCurrReq(@RequestHeader("Authorization") String token){ | ||||||
|  |         if (authServ.isNotIn(new Role[]{Role.Admin,Role.Secretary,Role.InscriptionService},token)) | ||||||
|  |             return new UnauthorizedResponse<>(null); | ||||||
|  |  | ||||||
|  |         ArrayList<ChangeCurriculumRequest> toReturn = new ArrayList<>(); | ||||||
|  |  | ||||||
|  |         changeCurriculumRequestRepository.findAll().forEach(toReturn::add); | ||||||
|  |  | ||||||
|  |         return new ResponseEntity<>(toReturn, HttpStatus.OK); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @GetMapping("/changecurriculumreq/{id}") | ||||||
|  |     public ResponseEntity<ChangeCurriculumRequest> getCCrbyId(@RequestHeader("Authorization") String token, @PathVariable long id){ | ||||||
|  |         if (authServ.isNotIn(new Role[]{Role.Admin,Role.Secretary,Role.InscriptionService},token)) | ||||||
|  |             return new UnauthorizedResponse<>(null); | ||||||
|  |  | ||||||
|  |         ChangeCurriculumRequest toReturn = changeCurriculumRequestRepository.findById(id); | ||||||
|  |         return new ResponseEntity<>(toReturn, HttpStatus.OK); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @PatchMapping("/changecurriculumreq/{id}/{newState}") | ||||||
|  |     public ResponseEntity<String> editCCReq(@RequestHeader("Authorization") String token, @PathVariable long id, @PathVariable RequestState newState){ | ||||||
|  |         if (authServ.isNotIn(new Role[]{Role.Admin,Role.Secretary,Role.InscriptionService},token)) | ||||||
|  |             return new UnauthorizedResponse<>(null); | ||||||
|  |  | ||||||
|  |         ChangeCurriculumRequest toEdit = changeCurriculumRequestRepository.findById(id); | ||||||
|  |  | ||||||
|  |         toEdit.setState(newState); | ||||||
|  |  | ||||||
|  |         if (newState == RequestState.Accepted && (toEdit.getTeacherApprovalState() == RequestState.Accepted || toEdit.getTeacherApprovalState() == RequestState.Unrequired)){ | ||||||
|  |             //If actual curriculum is not null then we need to set that the user doesn't follow it anymore | ||||||
|  |             acceptProcedure(toEdit); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         changeCurriculumRequestRepository.save(toEdit); | ||||||
|  |         return new ResponseEntity<>(HttpStatus.OK); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @PatchMapping("/changecurriculumreqteacher/{id}/{newteacherstate}") | ||||||
|  |     public ResponseEntity<String> editCCReqTeacherState(@RequestHeader("Authorization") String token, @PathVariable long id, @PathVariable RequestState newteacherstate){ | ||||||
|  |         if (authServ.isNotIn(new Role[]{Role.Admin,Role.Secretary,Role.InscriptionService},token)) | ||||||
|  |             return new UnauthorizedResponse<>(null); | ||||||
|  |  | ||||||
|  |         ChangeCurriculumRequest toEdit = changeCurriculumRequestRepository.findById(id); | ||||||
|  |  | ||||||
|  |         toEdit.setState(newteacherstate); | ||||||
|  |  | ||||||
|  |         if (newteacherstate == RequestState.Accepted && toEdit.getState() == RequestState.Accepted){ | ||||||
|  |             //If actual curriculum is not null then we need to set that the user doesn't follow it anymore | ||||||
|  |             acceptProcedure(toEdit); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         changeCurriculumRequestRepository.save(toEdit); | ||||||
|  |         return new ResponseEntity<>(HttpStatus.OK); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     private void acceptProcedure(ChangeCurriculumRequest toEdit) { | ||||||
|  |         User u = toEdit.getUser(); | ||||||
|  |         if (toEdit.getActualCurriculum() != null){ | ||||||
|  |             ArrayList<UserCurriculum> listcurr = userCurriculumRepository.findByUserOrderByCurriculum(u); | ||||||
|  |  | ||||||
|  |             for (int i = 0; i < listcurr.size(); i++){ | ||||||
|  |                 if (listcurr.get(i).getCurriculum() == toEdit.getActualCurriculum()){ | ||||||
|  |                     listcurr.get(i).setActual(false); | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |  | ||||||
|  |             userCurriculumRepository.saveAll(listcurr); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         Calendar c = Calendar.getInstance(); | ||||||
|  |         UserCurriculum userCurriculum = new UserCurriculum(u, toEdit.getDestinationCurriculum(), c.get(Calendar.YEAR), true); | ||||||
|  |         userCurriculumRepository.save(userCurriculum); | ||||||
|  |     } | ||||||
|  | } | ||||||
| @ -0,0 +1,129 @@ | |||||||
|  | package ovh.herisson.Clyde.EndPoints; | ||||||
|  |  | ||||||
|  | /****************************************************** | ||||||
|  |  * @file LessonController.java | ||||||
|  |  * @author William Karpinski | ||||||
|  |  * @scope Extension Horaire | ||||||
|  |  * | ||||||
|  |  * Controller of Lessons API | ||||||
|  |  ******************************************************/ | ||||||
|  |  | ||||||
|  | import org.springframework.http.HttpStatus; | ||||||
|  | import org.springframework.http.ResponseEntity; | ||||||
|  | import org.springframework.web.bind.annotation.*; | ||||||
|  | import ovh.herisson.Clyde.Responses.UnauthorizedResponse; | ||||||
|  | import ovh.herisson.Clyde.Services.AuthenticatorService; | ||||||
|  | import ovh.herisson.Clyde.Services.LessonService; | ||||||
|  | import ovh.herisson.Clyde.Services.ProtectionService; | ||||||
|  | import ovh.herisson.Clyde.Services.ScheduleLessonService; | ||||||
|  | import ovh.herisson.Clyde.Tables.Lesson; | ||||||
|  | import ovh.herisson.Clyde.Tables.Role; | ||||||
|  |  | ||||||
|  | import java.util.HashMap; | ||||||
|  | import java.util.Map; | ||||||
|  |  | ||||||
|  | @RestController | ||||||
|  | @CrossOrigin(originPatterns = "*", allowCredentials = "true") | ||||||
|  | public class LessonController { | ||||||
|  |     private final LessonService lessonServ; | ||||||
|  |  | ||||||
|  |     private final ScheduleLessonService scheduleLessonServ; | ||||||
|  |     private final AuthenticatorService authServ; | ||||||
|  |  | ||||||
|  |     public LessonController(LessonService lessonServ, ScheduleLessonService scheduleLessonService, AuthenticatorService authServ) { | ||||||
|  |         this.lessonServ = lessonServ; | ||||||
|  |         this.scheduleLessonServ = scheduleLessonService; | ||||||
|  |         this.authServ = authServ; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Return a lesson via its id | ||||||
|  |      */ | ||||||
|  |     @GetMapping("/lesson/{id}") | ||||||
|  |     public ResponseEntity<HashMap<String,Object>> getLesson(@PathVariable long id){ | ||||||
|  |         Lesson lesson = lessonServ.findById(id); | ||||||
|  |  | ||||||
|  |         if(lesson == null) | ||||||
|  |             return new ResponseEntity<>(HttpStatus.BAD_REQUEST); | ||||||
|  |  | ||||||
|  |         return new ResponseEntity<>(ProtectionService.lessonWithoutPassword(lesson),HttpStatus.OK); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Return all the lessons | ||||||
|  |      */ | ||||||
|  |     @GetMapping("/lessons") | ||||||
|  |     public ResponseEntity<Iterable<HashMap<String,Object>>> getAllLessons(@RequestHeader("Authorization") String token){ | ||||||
|  |         if(authServ.isNotIn(new Role[]{Role.Admin,Role.Secretary},token)) | ||||||
|  |             return new UnauthorizedResponse<>(null); | ||||||
|  |         return new ResponseEntity<>(ProtectionService.lessonsWithoutPassword(lessonServ.findAll()),HttpStatus.OK); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Return all the lessons of a teacher's courses | ||||||
|  |      */ | ||||||
|  |     @GetMapping("/lessons/owned") | ||||||
|  |     public ResponseEntity<Iterable<HashMap<String,Object>>> getOwnedLessons(@RequestHeader("Authorization") String token){ | ||||||
|  |         if (authServ.isNotIn(new Role[]{Role.Admin,Role.Teacher},token)){ | ||||||
|  |             return new UnauthorizedResponse<>(null);} | ||||||
|  |         return new ResponseEntity<>(ProtectionService.lessonsWithoutPassword(lessonServ.findAllOwnedLesson(authServ.getUserFromToken(token))),HttpStatus.OK); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      ⋅* Return all the lessons of a student | ||||||
|  |      */ | ||||||
|  |     @GetMapping("/lessons/OwnCurriculum") | ||||||
|  |     public ResponseEntity<Iterable<HashMap<String,Object>>> getOnesLessons(@RequestHeader("Authorization") String token){ | ||||||
|  |         if (authServ.isNotIn(new Role[]{Role.Admin,Role.Student},token)){ | ||||||
|  |             return new UnauthorizedResponse<>(null);} | ||||||
|  |         return new ResponseEntity<>(ProtectionService.lessonsWithoutPassword(lessonServ.findOnesLessons(authServ.getUserFromToken(token))),HttpStatus.OK); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Post a new lesson | ||||||
|  |      */ | ||||||
|  |     @PostMapping("/lesson") | ||||||
|  |     public ResponseEntity<HashMap<String, Object>> postLesson(@RequestHeader("Authorization") String token, | ||||||
|  |                                                               @RequestBody Map<String, Object> lessonInfos){ | ||||||
|  |         if(authServ.isNotIn(new Role[]{Role.Secretary,Role.Admin},token)) | ||||||
|  |             return new UnauthorizedResponse<>(null); | ||||||
|  |  | ||||||
|  |  | ||||||
|  |           Lesson lesson = lessonServ.createLesson(lessonInfos); | ||||||
|  |           Lesson createdLesson = lessonServ.save(lesson); | ||||||
|  |           scheduleLessonServ.saveToAllSchedule(lesson); | ||||||
|  |  | ||||||
|  |         if(createdLesson==null) | ||||||
|  |             return new ResponseEntity<>(null,HttpStatus.BAD_REQUEST); | ||||||
|  |         return new ResponseEntity<>(ProtectionService.lessonWithoutPassword(createdLesson), HttpStatus.OK); | ||||||
|  |     } | ||||||
|  |     /** | ||||||
|  |      * Modify a lesson | ||||||
|  |      */ | ||||||
|  |     @PatchMapping("/lesson/{id}") | ||||||
|  |     public ResponseEntity<Lesson> patchLesson(@RequestHeader("Authorization") String token, | ||||||
|  |                                               @RequestBody Map<String, Object> updates, | ||||||
|  |                                               @PathVariable long id){ | ||||||
|  |         if(authServ.isNotIn(new Role[]{Role.Admin,Role.Secretary},token)) | ||||||
|  |             return new UnauthorizedResponse<>(null); | ||||||
|  |         if(!lessonServ.modifyData(id, updates)){ | ||||||
|  |             return new ResponseEntity<>(HttpStatus.BAD_REQUEST); | ||||||
|  |           } | ||||||
|  |         return new ResponseEntity<>(HttpStatus.OK); | ||||||
|  |     } | ||||||
|  |     /** | ||||||
|  |      * Delete a lesson | ||||||
|  |      */ | ||||||
|  |     @DeleteMapping("lesson/{id}") | ||||||
|  |     public ResponseEntity<String> deleteLesson(@RequestHeader("Authorization") String token, | ||||||
|  |                                                @PathVariable Long id){ | ||||||
|  |         if (authServ.isNotIn(new Role[]{Role.Admin,Role.Secretary},token)) | ||||||
|  |             return new UnauthorizedResponse<>(null); | ||||||
|  |         Lesson toDelete = lessonServ.findById(id); | ||||||
|  |         if(toDelete == null) | ||||||
|  |             return new ResponseEntity<>(HttpStatus.BAD_REQUEST); | ||||||
|  |         lessonServ.delete(toDelete); | ||||||
|  |         return new ResponseEntity<>(HttpStatus.OK); | ||||||
|  |  | ||||||
|  |     } | ||||||
|  | } | ||||||
| @ -0,0 +1,150 @@ | |||||||
|  | package ovh.herisson.Clyde.EndPoints; | ||||||
|  |  | ||||||
|  | /****************************************************** | ||||||
|  |  * @file LessonRequestsController.java | ||||||
|  |  * @author William Karpinski | ||||||
|  |  * @scope Extension Horaire | ||||||
|  |  * | ||||||
|  |  * Controller of lesson requests API | ||||||
|  |  ******************************************************/ | ||||||
|  |  | ||||||
|  | import org.springframework.http.HttpStatus; | ||||||
|  | import org.springframework.http.ResponseEntity; | ||||||
|  | import org.springframework.web.bind.annotation.*; | ||||||
|  | import ovh.herisson.Clyde.Responses.UnauthorizedResponse; | ||||||
|  | import ovh.herisson.Clyde.Services.AuthenticatorService; | ||||||
|  | import ovh.herisson.Clyde.Services.LessonRequestService; | ||||||
|  | import ovh.herisson.Clyde.Services.LessonService; | ||||||
|  | import ovh.herisson.Clyde.Services.ProtectionService; | ||||||
|  | import ovh.herisson.Clyde.Tables.LessonChangesRequest; | ||||||
|  | import ovh.herisson.Clyde.Tables.RequestState; | ||||||
|  | import ovh.herisson.Clyde.Tables.Role; | ||||||
|  | import ovh.herisson.Clyde.Tables.User; | ||||||
|  |  | ||||||
|  | import java.util.Map; | ||||||
|  |  | ||||||
|  | @RestController | ||||||
|  | @CrossOrigin(originPatterns = "*", allowCredentials = "true") | ||||||
|  | public class LessonRequestsController { | ||||||
|  |     private final LessonRequestService lessonRequestServ; | ||||||
|  |     private final AuthenticatorService authServ; | ||||||
|  |  | ||||||
|  |     private final LessonService lessonServ; | ||||||
|  |     public LessonRequestsController(LessonRequestService lessonRequestServer, AuthenticatorService authServ, LessonService lessonServ) { | ||||||
|  |         this.lessonRequestServ = lessonRequestServer; | ||||||
|  |         this.authServ = authServ; | ||||||
|  |         this.lessonServ = lessonServ; | ||||||
|  |     } | ||||||
|  |     /** | ||||||
|  |      * Return a lesson request via its id | ||||||
|  |      */ | ||||||
|  |     @GetMapping("/requests/lessonRequest/{id}") | ||||||
|  |     public ResponseEntity<Map<String,Object>> getById(@RequestHeader("Authorization") String token, @PathVariable long id){ | ||||||
|  |         if (authServ.isNotIn(new Role[]{Role.Admin,Role.Secretary},token)) | ||||||
|  |             return new UnauthorizedResponse<>(null); | ||||||
|  |  | ||||||
|  |         LessonChangesRequest lessonRequest= lessonRequestServ.findById(id); | ||||||
|  |  | ||||||
|  |         return new ResponseEntity<>(ProtectionService.lessonRequestWithoutPassword(lessonRequest), HttpStatus.OK); | ||||||
|  |     } | ||||||
|  |     /** | ||||||
|  |      * return all the requests made by a user | ||||||
|  |      */ | ||||||
|  |     @GetMapping("/requests/lessonRequests/owned") | ||||||
|  |     public ResponseEntity<Iterable<Map<String, Object>>> getOwnedRequests(@RequestHeader("Authorization") String token){ | ||||||
|  |         if(authServ.isNotIn(new Role[]{Role.Admin,Role.Teacher},token)) | ||||||
|  |             return new UnauthorizedResponse<>(null); | ||||||
|  |         User user = authServ.getUserFromToken(token); | ||||||
|  |         Iterable<LessonChangesRequest> lessonChangesRequests = lessonRequestServ.findOwnRequests(user); | ||||||
|  |         return new ResponseEntity<>(ProtectionService.lessonRequestsWithoutPassword(lessonChangesRequests),HttpStatus.OK); | ||||||
|  |  | ||||||
|  |     } | ||||||
|  |     /** | ||||||
|  |      *  Return all the lesson requests | ||||||
|  |      */ | ||||||
|  |     @GetMapping("/requests/lessonRequests") | ||||||
|  |     public ResponseEntity<Iterable<Map<String,Object>>> getAllRequests(@RequestHeader("Authorization") String token){ | ||||||
|  |         if (authServ.isNotIn(new Role[]{Role.Admin,Role.Secretary},token)) | ||||||
|  |             return new UnauthorizedResponse<>(null); | ||||||
|  |  | ||||||
|  |         Iterable<LessonChangesRequest> lessonRequests= lessonRequestServ.getAll(); | ||||||
|  |  | ||||||
|  |         return new ResponseEntity<>(ProtectionService.lessonRequestsWithoutPassword(lessonRequests), HttpStatus.OK); | ||||||
|  |     } | ||||||
|  |     /** | ||||||
|  |      * Post a lesson request | ||||||
|  |      */ | ||||||
|  |     @PostMapping("/requests/lessonRequest") | ||||||
|  |     public ResponseEntity<Map<String, Object>> makeRequest(@RequestHeader("Authorization") String token, @RequestBody Map<String,Object> lessonRequestInfos){ | ||||||
|  |         if(authServ.isNotIn(new Role[]{Role.Admin,Role.Teacher},token)) | ||||||
|  |             return new UnauthorizedResponse<>(null); | ||||||
|  |         LessonChangesRequest lessonChangesRequest = lessonRequestServ.createLessonRequest(lessonRequestInfos); | ||||||
|  |         LessonChangesRequest createdRequest = lessonRequestServ.save(lessonChangesRequest); | ||||||
|  |         if(createdRequest == null) | ||||||
|  |             return new ResponseEntity<>(null, HttpStatus.BAD_REQUEST); | ||||||
|  |         return new ResponseEntity<>(ProtectionService.lessonRequestWithoutPassword(lessonChangesRequest),HttpStatus.OK); | ||||||
|  |     } | ||||||
|  |     /** | ||||||
|  |      * Modify a lesson Request | ||||||
|  |      */ | ||||||
|  |     @PatchMapping("/requests/lessonRequest/{id}") | ||||||
|  |     public ResponseEntity<LessonChangesRequest> changeRequestState(@PathVariable long id, | ||||||
|  |                                                                    @RequestHeader("Authorization") String token, | ||||||
|  |                                                                    @RequestBody Map<String , Object> infos){ | ||||||
|  |         if(authServ.isNotIn(new Role[]{Role.Secretary,Role.Admin},token)) | ||||||
|  |             return new UnauthorizedResponse<>(null); | ||||||
|  |  | ||||||
|  |         LessonChangesRequest lessonRequest = lessonRequestServ.findById(id); | ||||||
|  |             String local = ""; | ||||||
|  |             RequestState state = null; | ||||||
|  |             for (Map.Entry<String, Object> entry : infos.entrySet()) { | ||||||
|  |                 switch (entry.getKey()) { | ||||||
|  |                     case "local": | ||||||
|  |                         local = (String) entry.getValue(); | ||||||
|  |                         break; | ||||||
|  |                     case "state": | ||||||
|  |                         state = RequestState.valueOf((String)entry.getValue()); | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |  | ||||||
|  |             if (state == null) | ||||||
|  |                 return new ResponseEntity<>(HttpStatus.BAD_REQUEST); | ||||||
|  |  | ||||||
|  |         if(lessonRequest.getRequestType() == 0 ) { | ||||||
|  |             if (!lessonRequestServ.modifyCreateRequestState(lessonRequest, state, local)) | ||||||
|  |                 return new ResponseEntity<>(HttpStatus.BAD_REQUEST); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         else if(lessonRequest.getRequestType() == 1){ | ||||||
|  |             infos.put("lessonStart", lessonRequest.getLessonStart()); | ||||||
|  |             infos.put("lessonEnd", lessonRequest.getLessonEnd()); | ||||||
|  |             infos.put("lessonType",lessonRequest.getLessonType()); | ||||||
|  |             if(!lessonRequestServ.modifyChangeRequestState(infos,lessonRequest.getLessonId(),state)) | ||||||
|  |                 return new ResponseEntity<>(HttpStatus.BAD_REQUEST); | ||||||
|  |             lessonRequest.setState(state); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         else{ | ||||||
|  |             lessonRequestServ.modifyDeleteRequest(lessonRequest, state); | ||||||
|  |             lessonRequest.setState(state); | ||||||
|  |                | ||||||
|  |         } | ||||||
|  |         lessonRequestServ.save(lessonRequest); | ||||||
|  |         return new ResponseEntity<>(HttpStatus.OK); | ||||||
|  |  | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Delete a lesson request | ||||||
|  |      */ | ||||||
|  |     @DeleteMapping("/requests/lessonRequest/{id}") | ||||||
|  |     public ResponseEntity<String> deleteRequest(@RequestHeader("Authorization") String token, @PathVariable long id){ | ||||||
|  |         if(authServ.isNotIn(new Role[]{Role.Admin,Role.Secretary,Role.Teacher},token)) | ||||||
|  |             return new UnauthorizedResponse<>(null); | ||||||
|  |         LessonChangesRequest lessonChangesRequest = lessonRequestServ.findById(id); | ||||||
|  |         if (lessonChangesRequest == null) | ||||||
|  |             return new ResponseEntity<>(HttpStatus.BAD_REQUEST); | ||||||
|  |         lessonRequestServ.delete(lessonChangesRequest); | ||||||
|  |         return new ResponseEntity<>(HttpStatus.OK); | ||||||
|  |     } | ||||||
|  | } | ||||||
| @ -5,10 +5,14 @@ import org.springframework.http.HttpHeaders; | |||||||
| import org.springframework.http.HttpStatus; | import org.springframework.http.HttpStatus; | ||||||
| import org.springframework.http.ResponseEntity; | import org.springframework.http.ResponseEntity; | ||||||
| import org.springframework.web.bind.annotation.*; | import org.springframework.web.bind.annotation.*; | ||||||
|  | import ovh.herisson.Clyde.Repositories.CurriculumRepository; | ||||||
| import ovh.herisson.Clyde.Responses.UnauthorizedResponse; | import ovh.herisson.Clyde.Responses.UnauthorizedResponse; | ||||||
| import ovh.herisson.Clyde.Services.AuthenticatorService; | import ovh.herisson.Clyde.Services.AuthenticatorService; | ||||||
| import ovh.herisson.Clyde.Services.ProtectionService; | import ovh.herisson.Clyde.Services.ProtectionService; | ||||||
| import ovh.herisson.Clyde.Tables.InscriptionRequest; | import ovh.herisson.Clyde.Tables.Curriculum; | ||||||
|  | import ovh.herisson.Clyde.Tables.Inscription.InscriptionRequest; | ||||||
|  | import ovh.herisson.Clyde.Tables.RequestState; | ||||||
|  |  | ||||||
| import java.util.Date; | import java.util.Date; | ||||||
| import java.util.Map; | import java.util.Map; | ||||||
|  |  | ||||||
| @ -16,7 +20,7 @@ import java.util.Map; | |||||||
| @CrossOrigin(originPatterns = "*", allowCredentials = "true") | @CrossOrigin(originPatterns = "*", allowCredentials = "true") | ||||||
| public class LoginController { | public class LoginController { | ||||||
|     private final AuthenticatorService authServ; |     private final AuthenticatorService authServ; | ||||||
|  |     private final CurriculumRepository curriculumRepository; | ||||||
|     static public class RequestLogin{ |     static public class RequestLogin{ | ||||||
|         private final String identifier; |         private final String identifier; | ||||||
|         private final String password; |         private final String password; | ||||||
| @ -29,8 +33,9 @@ public class LoginController { | |||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public LoginController(AuthenticatorService authServ){ |     public LoginController(AuthenticatorService authServ, CurriculumRepository curriculumRepository){ | ||||||
|         this.authServ = authServ; |         this.authServ = authServ; | ||||||
|  |         this.curriculumRepository = curriculumRepository; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @PostMapping(value = "/login") |     @PostMapping(value = "/login") | ||||||
| @ -48,9 +53,18 @@ public class LoginController { | |||||||
|  |  | ||||||
|     @PostMapping("/register") |     @PostMapping("/register") | ||||||
|     public ResponseEntity<Map<String,Object>> register(@RequestBody InscriptionRequest inscriptionRequest){ |     public ResponseEntity<Map<String,Object>> register(@RequestBody InscriptionRequest inscriptionRequest){ | ||||||
|  |         //We ensure here that if the targeted cursus year is more than first grade then we need the teacher equivalence approval | ||||||
|  |         Curriculum curr = curriculumRepository.findById(inscriptionRequest.getCurriculumId()); | ||||||
|  |  | ||||||
|  |         if (curr.getYear() > 1){ | ||||||
|  |             inscriptionRequest.setEquivalenceState(RequestState.Pending); | ||||||
|  |         }else{ | ||||||
|  |             inscriptionRequest.setEquivalenceState(RequestState.Unrequired); | ||||||
|  |         } | ||||||
|  |  | ||||||
|         InscriptionRequest returnedInscriptionRequest = authServ.register(inscriptionRequest); |         InscriptionRequest returnedInscriptionRequest = authServ.register(inscriptionRequest); | ||||||
|  |  | ||||||
|  |  | ||||||
|         return new ResponseEntity<>(ProtectionService.requestWithoutPassword(returnedInscriptionRequest), HttpStatus.CREATED); |         return new ResponseEntity<>(ProtectionService.requestWithoutPassword(returnedInscriptionRequest), HttpStatus.CREATED); | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  | |||||||
| @ -2,10 +2,16 @@ 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.*; | ||||||
| import ovh.herisson.Clyde.Repositories.UserRepository; | import ovh.herisson.Clyde.Repositories.Inscription.ExternalCurriculumRepository; | ||||||
|  | import ovh.herisson.Clyde.Repositories.Inscription.MinervalRepository; | ||||||
|  | import ovh.herisson.Clyde.Repositories.Inscription.ScholarshipRequestRepository; | ||||||
|  | import ovh.herisson.Clyde.Repositories.Inscription.UnregisterRequestRepository; | ||||||
| import ovh.herisson.Clyde.Services.*; | import ovh.herisson.Clyde.Services.*; | ||||||
|  | import ovh.herisson.Clyde.Services.Inscription.InscriptionService; | ||||||
| import ovh.herisson.Clyde.Tables.*; | import ovh.herisson.Clyde.Tables.*; | ||||||
|  | import ovh.herisson.Clyde.Tables.Inscription.*; | ||||||
|  |  | ||||||
| import java.util.ArrayList; | import java.util.ArrayList; | ||||||
| import java.util.Arrays; | import java.util.Arrays; | ||||||
| import java.util.Date; | import java.util.Date; | ||||||
| @ -15,26 +21,48 @@ import java.util.Date; | |||||||
|  |  | ||||||
| public class MockController { | public class MockController { | ||||||
|     private final BCryptPasswordEncoder passwordEncoder = new BCryptPasswordEncoder(); |     private final BCryptPasswordEncoder passwordEncoder = new BCryptPasswordEncoder(); | ||||||
|  |     public final UserService userService; | ||||||
|     public final UserRepository userRepo; |     public final UserRepository userRepo; | ||||||
|     public final TokenRepository tokenRepo; |     public final TokenRepository tokenRepo; | ||||||
|     public final TokenService tokenService; |     public final TokenService tokenService; | ||||||
|     public final CurriculumCourseService CurriculumCourseService; |     public final CurriculumCourseService CurriculumCourseService; | ||||||
|     public final CurriculumService curriculumService; |     public final CurriculumService curriculumService; | ||||||
|     public final CourseService courseService; |     public final CourseService courseService; | ||||||
|  |     public final ExternalCurriculumRepository externalCurriculumRepository; | ||||||
|     public final InscriptionService inscriptionService; |     public final InscriptionService inscriptionService; | ||||||
|  |  | ||||||
|  |     public final LessonService lessonService; | ||||||
|  |     public final ScheduleService scheduleService; | ||||||
|  |     public final ScheduleLessonService scheduleLessonService; | ||||||
|  |  | ||||||
|  |     public final LessonRequestService lessonRequestService; | ||||||
|     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 final MinervalRepository minervalRepository; | ||||||
|  |  | ||||||
|  |     public final ScholarshipRequestRepository scholarshipRequestRepository; | ||||||
|  |  | ||||||
|  |     public final UnregisterRequestRepository uninscriptionRequestRepository; | ||||||
|  |     public MockController(UserService userService, UserRepository userRepo, TokenRepository tokenRepo, TokenService tokenService, CurriculumCourseService CurriculumCourseService, CurriculumService curriculumService, CourseService courseService, ExternalCurriculumRepository externalCurriculumRepository, InscriptionService inscriptionService, UserCurriculumRepository ucr, MinervalRepository minervalRepository, ScholarshipRequestRepository scholarshipRequestRepository, UnregisterRequestRepository unregisterRequestRepository, LessonService lessonService, ScheduleService scheduleService, ScheduleLessonService scheduleLessonService, LessonRequestService lessonRequestService){ | ||||||
|  |         this.userService = userService; | ||||||
|         this.tokenRepo = tokenRepo; |         this.tokenRepo = tokenRepo; | ||||||
|         this.userRepo = userRepo; |         this.userRepo = userRepo; | ||||||
|         this.tokenService = tokenService; |         this.tokenService = tokenService; | ||||||
|         this.CurriculumCourseService = CurriculumCourseService; |         this.CurriculumCourseService = CurriculumCourseService; | ||||||
|         this.curriculumService = curriculumService; |         this.curriculumService = curriculumService; | ||||||
|         this.courseService = courseService; |         this.courseService = courseService; | ||||||
|  |         this.externalCurriculumRepository = externalCurriculumRepository; | ||||||
|         this.inscriptionService = inscriptionService; |         this.inscriptionService = inscriptionService; | ||||||
|  |         this.lessonService = lessonService; | ||||||
|  |         this.scheduleService = scheduleService; | ||||||
|  |         this.scheduleLessonService = scheduleLessonService; | ||||||
|  |         this.lessonRequestService = lessonRequestService; | ||||||
|  |         this.ucr = ucr; | ||||||
|  |         this.minervalRepository = minervalRepository; | ||||||
|  |         this.scholarshipRequestRepository = scholarshipRequestRepository; | ||||||
|  |         this.uninscriptionRequestRepository = unregisterRequestRepository; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     /** Saves an example of each user type by : |     /** Saves an example of each user type by : | ||||||
| @ -47,28 +75,48 @@ 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); |         userService.saveAll(mockUsers); | ||||||
|  |  | ||||||
|  |         ExternalCurriculum externalCurriculum = new ExternalCurriculum(null, "HEH", "Bachelier en ingénieur", "completed", 2015, 2017, null, joe); | ||||||
|  |         externalCurriculumRepository.save(externalCurriculum); | ||||||
|  |  | ||||||
|  |         Minerval minerval = new Minerval(joe.getRegNo(), 0, 852, 2023); | ||||||
|  |         minervalRepository.save(minerval); | ||||||
|         // Course / Curriculum part |         // Course / Curriculum part | ||||||
|  |  | ||||||
|         Curriculum infoBab1 = new Curriculum(1,"info"); |         Curriculum infoBab1 = new Curriculum(1,"info", false); | ||||||
|         Curriculum chemistryBab1 = new Curriculum(1,"chemistry"); |         Curriculum chemistryBab1 = new Curriculum(1,"chemistry", false); | ||||||
|         Curriculum psychologyBab1 = new Curriculum(1,"psychology"); |         Curriculum psychologyBab1 = new Curriculum(1,"psychology", false); | ||||||
|  |         Curriculum infoBab2 = new Curriculum(2,"info", false); | ||||||
|  |         Curriculum masterinfo1 = new Curriculum(4, "info", false); | ||||||
|  |         Curriculum masterinfo2 = new Curriculum(5, "info", false); | ||||||
|  |         Curriculum chemistryBab2 = new Curriculum(2, "chemistry", false); | ||||||
|  |         Curriculum ingebab1 = new Curriculum(1, "ingénieur", true); | ||||||
|  |  | ||||||
|         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); | ||||||
|  |         curriculumService.save(chemistryBab2); | ||||||
|  |         curriculumService.save(ingebab1); | ||||||
|  |  | ||||||
|  |         ucr.save(new UserCurriculum(joe, infoBab1, 2022, false)); | ||||||
|  |         ucr.save(new UserCurriculum(joe, chemistryBab1, 2023, true)); | ||||||
|  |         ucr.save(new UserCurriculum(joe, infoBab1, 2023, true)); | ||||||
|  |         ucr.save(new UserCurriculum(joe, psychologyBab1, 2020, false)); | ||||||
|  |         ucr.save(new UserCurriculum(popo, infoBab1, 2022, false)); | ||||||
|  |         ucr.save(new UserCurriculum(popo, infoBab2, 2023, true)); | ||||||
|  |  | ||||||
|         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); | ||||||
| @ -80,10 +128,12 @@ public class MockController { | |||||||
|         courseService.save(psycho1); |         courseService.save(psycho1); | ||||||
|         courseService.save(commun); |         courseService.save(commun); | ||||||
|  |  | ||||||
|  |         ScholarshipRequest ssr1 = new ScholarshipRequest(joe, RequestState.Pending, 0, new Date(), "test", "test"); | ||||||
|  |         scholarshipRequestRepository.save(ssr1); | ||||||
|  |  | ||||||
|         CurriculumCourseService.save(new CurriculumCourse(infoBab1,progra1)); |         CurriculumCourseService.save(new CurriculumCourse(infoBab1,progra1)); | ||||||
|         CurriculumCourseService.save(new CurriculumCourse(infoBab1,commun)); |         CurriculumCourseService.save(new CurriculumCourse(infoBab1,commun)); | ||||||
|  |         CurriculumCourseService.save(new CurriculumCourse(infoBab1, psycho1)); | ||||||
|         CurriculumCourseService.save(new CurriculumCourse(psychologyBab1,psycho1)); |         CurriculumCourseService.save(new CurriculumCourse(psychologyBab1,psycho1)); | ||||||
|         CurriculumCourseService.save(new CurriculumCourse(psychologyBab1,commun)); |         CurriculumCourseService.save(new CurriculumCourse(psychologyBab1,commun)); | ||||||
|  |  | ||||||
| @ -91,11 +141,59 @@ public class MockController { | |||||||
|         CurriculumCourseService.save(new CurriculumCourse(chemistryBab1,commun)); |         CurriculumCourseService.save(new CurriculumCourse(chemistryBab1,commun)); | ||||||
|         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) 4,RequestState.Pending,"yes.png","password", null, new Date(), RequestState.Pending, null); | ||||||
|         InscriptionRequest inscriptionRequest = new InscriptionRequest("helen","prenom","non","helen@gmail.com","america",new Date(),(long) 1,RequestState.Pending,"yes.png","password"); |  | ||||||
|  |  | ||||||
|         inscriptionService.save(inscriptionRequest); |         inscriptionService.save(inscriptionRequest); | ||||||
|          |  | ||||||
|  |  | ||||||
|  |         //Schedule part | ||||||
|  |  | ||||||
|  |         Lesson lesson_0_progra1 = new Lesson(progra1, "Mon Apr 22 2024 08:15", "Mon Apr 22 2024 10:15","rgb(0,50,100)","A0B2","Course"); | ||||||
|  |         Lesson lesson_0_chemistry1 = new Lesson(chemistry1, "Wed Mar 27 2024 08:15", "Wed Mar 27 2024 09:15","rgb(100,50,0)","A0B2","TP"); | ||||||
|  |         Lesson lesson_0_psycho1 = new Lesson(psycho1, "Sun Mar 24 2024 10:30 ","Sun Mar 24 2024 12:30 ","rgb(100,50,100)", "A0B2","TD"); | ||||||
|  |         Lesson lesson_1_progra1 = new Lesson(progra1, "Mon Apr 02 2024 13:30", "Mon Apr 02 2024 15:30","rgb(0,50,100)","A0B2","TP"); | ||||||
|  |         Lesson lesson_0_commun = new Lesson(commun, "Mon Apr 01 2024 10:30", "Mon Apr 01 2024 12:30","rgb(0,50,100)","A0B2","Course"); | ||||||
|  |  | ||||||
|  |         LessonChangesRequest request1 = new LessonChangesRequest(joke,RequestState.Pending,null,null,null,null,2,null,1); | ||||||
|  |         LessonChangesRequest request2 = new LessonChangesRequest(joke,RequestState.Pending,"Fri Apr 19 2024 10:30 ","Fri Apr 19 2024 12:30 ",null,null,1,null,2); | ||||||
|  |         LessonChangesRequest request3 = new LessonChangesRequest(joke,RequestState.Pending,"Fri Apr 19 2024 13:30 ","Fri Apr 19 2024 15:30 ","Course",progra1,0,"rgb(27,49,100)",4); | ||||||
|  |  | ||||||
|  |  | ||||||
|  |         Schedule infoBab1Schedule = new Schedule(infoBab1); | ||||||
|  |         Schedule chemistryBab1Schedule = new Schedule(chemistryBab1); | ||||||
|  |         Schedule psychoBab1Schedule = new Schedule(psychologyBab1); | ||||||
|  |  | ||||||
|  |  | ||||||
|  |         scheduleService.save(infoBab1Schedule); | ||||||
|  |         scheduleService.save(chemistryBab1Schedule); | ||||||
|  |         scheduleService.save(psychoBab1Schedule); | ||||||
|  |  | ||||||
|  |         lessonService.save(lesson_0_progra1); | ||||||
|  |         lessonService.save(lesson_0_chemistry1); | ||||||
|  |         lessonService.save(lesson_0_commun); | ||||||
|  |         lessonService.save(lesson_0_psycho1); | ||||||
|  |         lessonService.save(lesson_1_progra1); | ||||||
|  |  | ||||||
|  |         scheduleLessonService.save(new ScheduleLesson(infoBab1Schedule,lesson_0_progra1)); | ||||||
|  |         scheduleLessonService.save(new ScheduleLesson(infoBab1Schedule,lesson_1_progra1)); | ||||||
|  |         scheduleLessonService.save(new ScheduleLesson(infoBab1Schedule,lesson_0_commun)); | ||||||
|  |  | ||||||
|  |         scheduleLessonService.save(new ScheduleLesson(chemistryBab1Schedule,lesson_0_chemistry1)); | ||||||
|  |         scheduleLessonService.save(new ScheduleLesson(chemistryBab1Schedule,lesson_0_commun)); | ||||||
|  |  | ||||||
|  |         scheduleLessonService.save(new ScheduleLesson(psychoBab1Schedule,lesson_0_psycho1)); | ||||||
|  |         scheduleLessonService.save(new ScheduleLesson(psychoBab1Schedule,lesson_0_commun)); | ||||||
|  |  | ||||||
|  |  | ||||||
|  |         lessonRequestService.save(request1); | ||||||
|  |         lessonRequestService.save(request2); | ||||||
|  |         lessonRequestService.save(request3); | ||||||
|  |  | ||||||
|  |         UnregisterRequest unregisterRequest = new UnregisterRequest(RequestState.Pending, "je veux partir", new Date(), joe.getRegNo(), joe.getFirstName(), joe.getLastName(), joe.getEmail(), null); | ||||||
|  |         uninscriptionRequestRepository.save(unregisterRequest); | ||||||
|  |  | ||||||
|  |         externalCurriculum = new ExternalCurriculum(inscriptionRequest, "HEH", "Bachelier en informatique", "Completed", 2015, 2018, null, null); | ||||||
|  |         externalCurriculumRepository.save(externalCurriculum); | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
|  | |||||||
| @ -0,0 +1,126 @@ | |||||||
|  | package ovh.herisson.Clyde.EndPoints.Msg; | ||||||
|  |  | ||||||
|  | /****************************************************** | ||||||
|  |  * @file MessagesController.java | ||||||
|  |  * @author Anthony Debucquoy | ||||||
|  |  * @scope Extension messagerie | ||||||
|  |  * | ||||||
|  |  * Entry point for the messages application | ||||||
|  |  ******************************************************/ | ||||||
|  |  | ||||||
|  | import org.springframework.beans.factory.annotation.Autowired; | ||||||
|  | import org.springframework.http.HttpStatus; | ||||||
|  | import org.springframework.http.ResponseEntity; | ||||||
|  | import org.springframework.web.bind.annotation.CrossOrigin; | ||||||
|  | import org.springframework.web.bind.annotation.GetMapping; | ||||||
|  | import org.springframework.web.bind.annotation.PatchMapping; | ||||||
|  | import org.springframework.web.bind.annotation.PathVariable; | ||||||
|  | import org.springframework.web.bind.annotation.PostMapping; | ||||||
|  | import org.springframework.web.bind.annotation.RequestBody; | ||||||
|  | import org.springframework.web.bind.annotation.RequestHeader; | ||||||
|  | import org.springframework.web.bind.annotation.RestController; | ||||||
|  |  | ||||||
|  | import lombok.AllArgsConstructor; | ||||||
|  | import ovh.herisson.Clyde.DTO.Msg.DiscussionDTO; | ||||||
|  | import ovh.herisson.Clyde.Repositories.UserRepository; | ||||||
|  | import ovh.herisson.Clyde.Repositories.Msg.DiscussionRepository; | ||||||
|  | import ovh.herisson.Clyde.Responses.UnauthorizedResponse; | ||||||
|  | import ovh.herisson.Clyde.Services.AuthenticatorService; | ||||||
|  | import ovh.herisson.Clyde.Services.UserService; | ||||||
|  | import ovh.herisson.Clyde.Services.Msg.DiscussionService; | ||||||
|  | import ovh.herisson.Clyde.Tables.User; | ||||||
|  | import ovh.herisson.Clyde.Tables.Msg.Discussion; | ||||||
|  | import ovh.herisson.Clyde.Tables.Msg.Message; | ||||||
|  |  | ||||||
|  | @RestController | ||||||
|  | @CrossOrigin(originPatterns = "*", allowCredentials = "true") | ||||||
|  | @AllArgsConstructor | ||||||
|  | public class MessagesController { | ||||||
|  |  | ||||||
|  | 	private AuthenticatorService authServ; | ||||||
|  | 	private DiscussionService discServ; | ||||||
|  | 	private DiscussionRepository discRepo; | ||||||
|  | 	private UserService userServ; | ||||||
|  |  | ||||||
|  | 	@GetMapping("/discussions") | ||||||
|  | 	public ResponseEntity<Iterable<Discussion>> getDiscussions(@RequestHeader("Authorization") String token ){ | ||||||
|  | 		User user = authServ.getUserFromToken(token); | ||||||
|  | 		if(user == null){ | ||||||
|  | 			return new UnauthorizedResponse<>(null); | ||||||
|  | 		} | ||||||
|  |  | ||||||
|  | 		Iterable<Discussion> mock = discServ.getOwned(authServ.getUserFromToken(token)); | ||||||
|  |  | ||||||
|  | 		return new ResponseEntity<>(mock, HttpStatus.OK);  | ||||||
|  | 	}  | ||||||
|  |  | ||||||
|  | 	@GetMapping("/discussion/{id}") | ||||||
|  | 	public ResponseEntity<DiscussionDTO> getDiscussion(@RequestHeader("Authorization") String token, @PathVariable long id){ | ||||||
|  | 		User user = authServ.getUserFromToken(token); | ||||||
|  | 		if(user == null || !discServ.hasDiscussion(user, id) ){ | ||||||
|  | 			return new UnauthorizedResponse<>(null); | ||||||
|  | 		} | ||||||
|  | 		return new ResponseEntity<>(DiscussionDTO.construct(discRepo.findById(id).orElse(null), authServ.getUserFromToken(token)), HttpStatus.OK); | ||||||
|  | 	}  | ||||||
|  |  | ||||||
|  | 	@PatchMapping("/discussion/{id}") | ||||||
|  | 	public ResponseEntity<Discussion> AlterDiscussion(@RequestHeader("Authorization") String token, @PathVariable long id, @RequestBody Discussion data){ | ||||||
|  | 		User user = authServ.getUserFromToken(token); | ||||||
|  | 		if(user == null){ | ||||||
|  | 			return new UnauthorizedResponse<>(null); | ||||||
|  | 		} | ||||||
|  |  | ||||||
|  | 		Discussion disc = discRepo.findById(id).orElse(null); | ||||||
|  | 		disc.setName(data.getName()); | ||||||
|  | 		discRepo.save(disc); | ||||||
|  | 		return new ResponseEntity<>(disc, HttpStatus.OK); | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	@PatchMapping("/discussion/{id}/add") | ||||||
|  | 	public ResponseEntity<Discussion> invite(@RequestHeader("Authorization") String token, @PathVariable long id, @RequestBody User data){ | ||||||
|  | 		User user = authServ.getUserFromToken(token); | ||||||
|  | 		if(user == null){ | ||||||
|  | 			return new UnauthorizedResponse<>(null); | ||||||
|  | 		} | ||||||
|  |  | ||||||
|  | 		Discussion disc = discRepo.findById(id).orElse(null); | ||||||
|  | 		User invited = userServ.getUserById(data.getRegNo()); | ||||||
|  | 		disc.addMember(invited); | ||||||
|  | 		discRepo.save(disc); | ||||||
|  | 		return new ResponseEntity<>(disc, HttpStatus.OK); | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	@PatchMapping("/discussion/{id}/remove") | ||||||
|  | 	public ResponseEntity<Discussion> removeMember(@RequestHeader("Authorization") String token, @PathVariable long id, @RequestBody User data){ | ||||||
|  | 		User user = authServ.getUserFromToken(token); | ||||||
|  | 		if(user == null){ | ||||||
|  | 			return new UnauthorizedResponse<>(null); | ||||||
|  | 		} | ||||||
|  |  | ||||||
|  | 		Discussion disc = discRepo.findById(id).orElse(null); | ||||||
|  | 		User member = userServ.getUserById(data.getRegNo()); | ||||||
|  | 		disc.delMember(member); | ||||||
|  | 		discRepo.save(disc); | ||||||
|  | 		return new ResponseEntity<>(disc, HttpStatus.OK); | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	@PostMapping("/discussion/{id}") | ||||||
|  | 	public ResponseEntity<Discussion> sendMessage(@RequestHeader("Authorization") String token, @PathVariable long id, @RequestBody Message msg){ | ||||||
|  | 		User user = authServ.getUserFromToken(token); | ||||||
|  | 		if(user == null){ | ||||||
|  | 			return new UnauthorizedResponse<>(null); | ||||||
|  | 		} | ||||||
|  |  | ||||||
|  | 		Discussion disc = discRepo.findById(id).orElse(null); | ||||||
|  | 		msg.setAuthor(user); | ||||||
|  | 		if(disc != null) | ||||||
|  | 			discServ.CreateMessage(disc, msg); | ||||||
|  | 		return new ResponseEntity<>(disc, HttpStatus.OK); | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  |  | ||||||
|  | 	@PostMapping("/discussion") | ||||||
|  | 	public ResponseEntity<Discussion> createDiscussion(@RequestHeader("Authorization") String token, @RequestBody Discussion data){ | ||||||
|  | 		return new ResponseEntity<>(discServ.create(data.getName(), authServ.getUserFromToken(token)), HttpStatus.OK); | ||||||
|  | 	} | ||||||
|  | } | ||||||
| @ -0,0 +1,119 @@ | |||||||
|  | package ovh.herisson.Clyde.EndPoints; | ||||||
|  |  | ||||||
|  | /****************************************************** | ||||||
|  |  * @file ScheduleController.java | ||||||
|  |  * @author William Karpinski | ||||||
|  |  * @scope Extension Horaire | ||||||
|  |  * | ||||||
|  |  * Controller of Schedule API | ||||||
|  |  ******************************************************/ | ||||||
|  |  | ||||||
|  |  | ||||||
|  | import org.springframework.http.HttpStatus; | ||||||
|  | import org.springframework.http.ResponseEntity; | ||||||
|  | import org.springframework.web.bind.annotation.*; | ||||||
|  | import ovh.herisson.Clyde.Responses.UnauthorizedResponse; | ||||||
|  | import ovh.herisson.Clyde.Services.AuthenticatorService; | ||||||
|  | import ovh.herisson.Clyde.Services.ScheduleLessonService; | ||||||
|  | import ovh.herisson.Clyde.Services.ScheduleService; | ||||||
|  | import ovh.herisson.Clyde.Services.UserCurriculumService; | ||||||
|  | import ovh.herisson.Clyde.Services.CurriculumService; | ||||||
|  | import ovh.herisson.Clyde.Tables.*; | ||||||
|  | import ovh.herisson.Clyde.Services.LessonService; | ||||||
|  |  | ||||||
|  | import java.util.Map; | ||||||
|  |  | ||||||
|  | @RestController | ||||||
|  | @CrossOrigin(originPatterns = "*", allowCredentials = "true") | ||||||
|  | public class ScheduleController { | ||||||
|  |  | ||||||
|  |     private final ScheduleService scheduleServ; | ||||||
|  |     private final LessonService lessonServ; | ||||||
|  |  | ||||||
|  |     private final UserCurriculumService userCurriculumService; | ||||||
|  |      | ||||||
|  |     private final CurriculumService curriculumServ; | ||||||
|  |     private final AuthenticatorService authServ; | ||||||
|  |  | ||||||
|  |     private final ScheduleLessonService scheduleLessonServ; | ||||||
|  |  | ||||||
|  |     public ScheduleController(ScheduleService scheduleServ, UserCurriculumService userCurriculumService, AuthenticatorService authServ, ScheduleLessonService scheduleLessonServ, CurriculumService curriculumServ,LessonService lessonServ) { | ||||||
|  |         this.scheduleServ = scheduleServ; | ||||||
|  |         this.userCurriculumService = userCurriculumService; | ||||||
|  |         this.authServ = authServ; | ||||||
|  |         this.scheduleLessonServ = scheduleLessonServ; | ||||||
|  |         this.curriculumServ = curriculumServ; | ||||||
|  |         this.lessonServ  = lessonServ; | ||||||
|  |     } | ||||||
|  |     /** | ||||||
|  |      * Return schedule via its id | ||||||
|  |      */ | ||||||
|  |     @GetMapping("/schedule/{id}") | ||||||
|  |     public ResponseEntity<Map<String,Object>> findById(@PathVariable long id){ | ||||||
|  |         Schedule schedule = scheduleServ.findById(id); | ||||||
|  |  | ||||||
|  |         if(schedule == null) | ||||||
|  |             return new ResponseEntity<>(HttpStatus.BAD_REQUEST); | ||||||
|  |         return new ResponseEntity<>(scheduleLessonServ.getDepthScheduleBySchedule(schedule),HttpStatus.OK); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      *  Return a schedule via its curriculum id | ||||||
|  |      */ | ||||||
|  |     @GetMapping("/schedule/curriculum/{id}") | ||||||
|  |     public ResponseEntity<Map<String, Object>> findCurriculumSchedule(@PathVariable Long id){ | ||||||
|  |       Schedule schedule = scheduleLessonServ.getScheduleByCurriculum(curriculumServ.findById(id)); | ||||||
|  |       if(schedule == null) | ||||||
|  |         return new ResponseEntity<>(HttpStatus.BAD_REQUEST); | ||||||
|  |       return new ResponseEntity<>(scheduleLessonServ.getDepthScheduleBySchedule(schedule),HttpStatus.OK); | ||||||
|  |   } | ||||||
|  |     /** | ||||||
|  |      * Return all schedules | ||||||
|  |      */ | ||||||
|  |     @GetMapping("/schedules") | ||||||
|  |     public ResponseEntity<Iterable<Map<String , Object>>> findAllSchedule(){ | ||||||
|  |         return new ResponseEntity<>(scheduleLessonServ.getAllSchedule(),HttpStatus.OK); | ||||||
|  |     } | ||||||
|  |     /** | ||||||
|  |      *  Post a new schedule | ||||||
|  |      */ | ||||||
|  |     @PostMapping("/schedule") | ||||||
|  |     public ResponseEntity<Schedule> postSchedule(@RequestHeader("Authorization") String token, | ||||||
|  |                                                  @RequestBody Schedule schedule){ | ||||||
|  |         if (authServ.isNotIn(new Role[]{Role.Admin,Role.Secretary},token)) | ||||||
|  |             return new UnauthorizedResponse<>(null); | ||||||
|  |         return new ResponseEntity<>(scheduleServ.save(schedule),HttpStatus.OK); | ||||||
|  |     } | ||||||
|  |     /** | ||||||
|  |      *  Post a lesson to a schedule | ||||||
|  |      */ | ||||||
|  |     @PostMapping("/schedule/{id}") | ||||||
|  |     public ResponseEntity<String> postLessonToSchedule(@RequestHeader("Authorization") String token, | ||||||
|  |                                                           @RequestBody Long lessonId, | ||||||
|  |                                                           @PathVariable long id) | ||||||
|  |     { | ||||||
|  |  | ||||||
|  |         if (authServ.isNotIn(new Role[]{Role.Admin,Role.Secretary},token)) | ||||||
|  |             return new UnauthorizedResponse<>(null); | ||||||
|  |  | ||||||
|  |         if (!scheduleLessonServ.save(new ScheduleLesson( scheduleServ.findById(id), lessonServ.findById(lessonId)))) | ||||||
|  |             return new ResponseEntity<>(HttpStatus.BAD_REQUEST); | ||||||
|  |  | ||||||
|  |         return new ResponseEntity<>(HttpStatus.OK); | ||||||
|  |     } | ||||||
|  |     /** | ||||||
|  |      * Delete a lesson from a schedule | ||||||
|  |      */ | ||||||
|  |     @DeleteMapping("/schedule/lesson/{id}") | ||||||
|  |     public ResponseEntity<String> deleteLessonFromSchedule(@RequestHeader("Authorization") String token, | ||||||
|  |                                                           @RequestBody Long lessonId, | ||||||
|  |                                                           @PathVariable Long id) | ||||||
|  |     { | ||||||
|  |         if (authServ.isNotIn(new Role[]{Role.Admin,Role.Secretary},token)) | ||||||
|  |             return new UnauthorizedResponse<>(null); | ||||||
|  |         if (!scheduleLessonServ.delete(lessonId)) | ||||||
|  |             return new ResponseEntity<>(HttpStatus.BAD_REQUEST); | ||||||
|  |  | ||||||
|  |         return new ResponseEntity<>(HttpStatus.OK); | ||||||
|  |     } | ||||||
|  | } | ||||||
| @ -103,9 +103,6 @@ public class UserController { | |||||||
|  |  | ||||||
|     @GetMapping("/teachers") |     @GetMapping("/teachers") | ||||||
|     public ResponseEntity<Iterable<HashMap<String,Object>>> getAllTeachers(@RequestHeader("Authorization") String token){ |     public ResponseEntity<Iterable<HashMap<String,Object>>> getAllTeachers(@RequestHeader("Authorization") String token){ | ||||||
|         if (authServ.getUserFromToken(token) == null) |  | ||||||
|             return new UnauthorizedResponse<>(null); |  | ||||||
|  |  | ||||||
|         Iterable<User> teachers = userService.getAllTeachers(); |         Iterable<User> teachers = userService.getAllTeachers(); | ||||||
|  |  | ||||||
|         return new ResponseEntity<>(ProtectionService.usersWithoutPasswords(teachers), HttpStatus.OK); |         return new ResponseEntity<>(ProtectionService.usersWithoutPasswords(teachers), HttpStatus.OK); | ||||||
|  | |||||||
| @ -1,37 +0,0 @@ | |||||||
| package ovh.herisson.Clyde; |  | ||||||
|  |  | ||||||
| import javax.sql.DataSource; |  | ||||||
|  |  | ||||||
| import org.springframework.context.annotation.Bean; |  | ||||||
| import org.springframework.context.annotation.Configuration; |  | ||||||
| import org.springframework.context.annotation.Profile; |  | ||||||
| import org.springframework.jdbc.datasource.DriverManagerDataSource; |  | ||||||
| import org.springframework.scheduling.annotation.EnableScheduling; |  | ||||||
|  |  | ||||||
| @Configuration |  | ||||||
| @EnableScheduling |  | ||||||
| public class JdbcConfig { |  | ||||||
|  |  | ||||||
| 	@Bean |  | ||||||
| 	@Profile("!prod") |  | ||||||
| 	public DataSource psqlSource(){ |  | ||||||
| 		DriverManagerDataSource source = new DriverManagerDataSource(); |  | ||||||
| 		source.setDriverClassName("org.postgresql.Driver"); |  | ||||||
| 		source.setUrl("jdbc:postgresql://localhost:5442/clyde"); |  | ||||||
| 		source.setUsername("devel"); |  | ||||||
| 		source.setPassword("devel"); |  | ||||||
|  |  | ||||||
| 		return source; |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	@Bean |  | ||||||
| 	@Profile("prod") |  | ||||||
| 	public DataSource psqlSourceProd(){ |  | ||||||
| 		DriverManagerDataSource source = new DriverManagerDataSource(); |  | ||||||
| 		source.setDriverClassName("org.postgresql.Driver"); |  | ||||||
| 		source.setUrl("jdbc:postgresql:clyde?socketFactory=org.newsclub.net.unix.AFUNIXSocketFactory$FactoryArg&socketFactoryArg=/var/run/postgresql/.s.PGSQL.5432"); |  | ||||||
| 		source.setUsername("clyde"); |  | ||||||
|  |  | ||||||
| 		return source; |  | ||||||
| 	} |  | ||||||
| } |  | ||||||
| @ -0,0 +1,9 @@ | |||||||
|  | package ovh.herisson.Clyde.Repositories.Inscription; | ||||||
|  |  | ||||||
|  | import org.springframework.data.repository.CrudRepository; | ||||||
|  | import ovh.herisson.Clyde.Tables.ChangeCurriculumRequest; | ||||||
|  |  | ||||||
|  | public interface ChangeCurriculumRequestRepository extends CrudRepository<ChangeCurriculumRequest, Long> { | ||||||
|  |     ChangeCurriculumRequest findById(long id); | ||||||
|  | } | ||||||
|  |  | ||||||
| @ -0,0 +1,8 @@ | |||||||
|  | package ovh.herisson.Clyde.Repositories.Inscription; | ||||||
|  |  | ||||||
|  | import org.springframework.data.repository.CrudRepository; | ||||||
|  | import ovh.herisson.Clyde.Tables.Inscription.ExemptionsRequest; | ||||||
|  |  | ||||||
|  | public interface ExemptionsRequestRepository extends CrudRepository<ExemptionsRequest, Long> { | ||||||
|  |     ExemptionsRequest findById(long id); | ||||||
|  | } | ||||||
| @ -0,0 +1,15 @@ | |||||||
|  | package ovh.herisson.Clyde.Repositories.Inscription; | ||||||
|  |  | ||||||
|  | import org.springframework.data.repository.CrudRepository; | ||||||
|  | import ovh.herisson.Clyde.Tables.Inscription.ExternalCurriculum; | ||||||
|  | import ovh.herisson.Clyde.Tables.Inscription.InscriptionRequest; | ||||||
|  | import ovh.herisson.Clyde.Tables.User; | ||||||
|  |  | ||||||
|  | import java.util.ArrayList; | ||||||
|  |  | ||||||
|  | public interface ExternalCurriculumRepository extends CrudRepository<ExternalCurriculum, Long> { | ||||||
|  |     ArrayList<ExternalCurriculum> getExternalCurriculumByInscriptionRequest(InscriptionRequest ir); | ||||||
|  |  | ||||||
|  |     ArrayList<ExternalCurriculum> getExternalCurriculumByUser(User user); | ||||||
|  |     ExternalCurriculum getExternalCurriculumById(long id); | ||||||
|  | } | ||||||
| @ -1,7 +1,7 @@ | |||||||
| package ovh.herisson.Clyde.Repositories; | package ovh.herisson.Clyde.Repositories.Inscription; | ||||||
| 
 | 
 | ||||||
| import org.springframework.data.repository.CrudRepository; | import org.springframework.data.repository.CrudRepository; | ||||||
| import ovh.herisson.Clyde.Tables.InscriptionRequest; | import ovh.herisson.Clyde.Tables.Inscription.InscriptionRequest; | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| public interface InscriptionRepository extends CrudRepository<InscriptionRequest,Long> { | public interface InscriptionRepository extends CrudRepository<InscriptionRequest,Long> { | ||||||
| @ -0,0 +1,12 @@ | |||||||
|  | package ovh.herisson.Clyde.Repositories.Inscription; | ||||||
|  |  | ||||||
|  | import org.springframework.data.repository.CrudRepository; | ||||||
|  | import ovh.herisson.Clyde.Tables.Inscription.Minerval; | ||||||
|  |  | ||||||
|  | import java.util.ArrayList; | ||||||
|  |  | ||||||
|  | public interface MinervalRepository extends CrudRepository<Minerval, Long> { | ||||||
|  |     public ArrayList<Minerval> getMinervalsByStudentRegNoOrderByYearDesc(Long studentRegNo); | ||||||
|  |  | ||||||
|  |     public Minerval findById(long id); | ||||||
|  | } | ||||||
| @ -0,0 +1,10 @@ | |||||||
|  | package ovh.herisson.Clyde.Repositories.Inscription; | ||||||
|  |  | ||||||
|  | import org.springframework.data.repository.CrudRepository; | ||||||
|  | import ovh.herisson.Clyde.Tables.Inscription.Payment; | ||||||
|  |  | ||||||
|  | import java.util.ArrayList; | ||||||
|  |  | ||||||
|  | public interface PaymentRepository extends CrudRepository<Payment, Long> { | ||||||
|  |     public ArrayList<Payment> getPaymentsByStudentRegNo(long regNo); | ||||||
|  | } | ||||||
| @ -0,0 +1,8 @@ | |||||||
|  | package ovh.herisson.Clyde.Repositories.Inscription; | ||||||
|  |  | ||||||
|  | import org.springframework.data.repository.CrudRepository; | ||||||
|  | import ovh.herisson.Clyde.Tables.Inscription.ScholarshipRequest; | ||||||
|  |  | ||||||
|  | public interface ScholarshipRequestRepository extends CrudRepository<ScholarshipRequest, Long> { | ||||||
|  |     public ScholarshipRequest findById(long id); | ||||||
|  | } | ||||||
| @ -0,0 +1,8 @@ | |||||||
|  | package ovh.herisson.Clyde.Repositories.Inscription; | ||||||
|  |  | ||||||
|  | import org.springframework.data.repository.CrudRepository; | ||||||
|  | import ovh.herisson.Clyde.Tables.Inscription.UnregisterRequest; | ||||||
|  |  | ||||||
|  | public interface UnregisterRequestRepository extends CrudRepository<UnregisterRequest, Long> { | ||||||
|  |     public UnregisterRequest findById(long l); | ||||||
|  | } | ||||||
| @ -0,0 +1,23 @@ | |||||||
|  | package ovh.herisson.Clyde.Repositories; | ||||||
|  |  | ||||||
|  | /****************************************************** | ||||||
|  |  * @file LessonChangesRequestRepository.java | ||||||
|  |  * @author William Karpinski | ||||||
|  |  * @scope Extension Horaire | ||||||
|  |  ******************************************************/ | ||||||
|  |  | ||||||
|  | import org.springframework.data.jpa.repository.Query; | ||||||
|  | import org.springframework.data.repository.CrudRepository; | ||||||
|  | import ovh.herisson.Clyde.Tables.LessonChangesRequest; | ||||||
|  | import ovh.herisson.Clyde.Tables.User; | ||||||
|  |  | ||||||
|  | public interface LessonChangesRequestRepository extends CrudRepository<LessonChangesRequest, Long> { | ||||||
|  |     LessonChangesRequest findById(long id); | ||||||
|  |      | ||||||
|  |  | ||||||
|  |     @Query("select lr from LessonChangesRequest lr where lr.user = ?1") | ||||||
|  |     Iterable<LessonChangesRequest> findOwnRequests(User user); | ||||||
|  |  | ||||||
|  |     @Query("select lr from LessonChangesRequest lr where lr.lessonId = ?1") | ||||||
|  |     Iterable<LessonChangesRequest> findRequestByLessonId(long id); | ||||||
|  | } | ||||||
| @ -0,0 +1,20 @@ | |||||||
|  | package ovh.herisson.Clyde.Repositories; | ||||||
|  |  | ||||||
|  | /****************************************************** | ||||||
|  |  * @file LessonRepository.java | ||||||
|  |  * @author William Karpinski | ||||||
|  |  * @scope Extension Horaire | ||||||
|  |  ******************************************************/ | ||||||
|  |  | ||||||
|  | import org.springframework.data.jpa.repository.Query; | ||||||
|  | import org.springframework.data.repository.CrudRepository; | ||||||
|  | import ovh.herisson.Clyde.Tables.Course; | ||||||
|  | import ovh.herisson.Clyde.Tables.Lesson; | ||||||
|  |  | ||||||
|  | public interface LessonRepository extends CrudRepository<Lesson, Long> { | ||||||
|  |  | ||||||
|  |     Lesson findById(long id); | ||||||
|  |  | ||||||
|  |     @Query("select l from Lesson l where l.course = ?1") | ||||||
|  |     Iterable<Lesson> findLessonByCourse(Course course); | ||||||
|  | } | ||||||
| @ -0,0 +1,23 @@ | |||||||
|  | package ovh.herisson.Clyde.Repositories.Msg; | ||||||
|  |  | ||||||
|  | /****************************************************** | ||||||
|  |  * @file DiscussionRepository.java | ||||||
|  |  * @author Anthony Debucquoy | ||||||
|  |  * @scope Extension messagerie | ||||||
|  |  * | ||||||
|  |  * Repository of Discussion allowing to fetch discussion by user  | ||||||
|  |  ******************************************************/ | ||||||
|  |  | ||||||
|  |  | ||||||
|  | import java.util.List; | ||||||
|  |  | ||||||
|  | import org.springframework.data.jpa.repository.Query; | ||||||
|  | import org.springframework.data.repository.CrudRepository; | ||||||
|  |  | ||||||
|  | import ovh.herisson.Clyde.Tables.Msg.Discussion; | ||||||
|  |  | ||||||
|  | public interface DiscussionRepository extends CrudRepository<Discussion, Long>{ | ||||||
|  |  | ||||||
|  | 	@Query("SELECT d FROM Discussion d INNER JOIN FETCH d.members dm WHERE dm.id = ?1") | ||||||
|  | 	List<Discussion> findByMembership(long userid); | ||||||
|  | } | ||||||
| @ -0,0 +1,14 @@ | |||||||
|  | package ovh.herisson.Clyde.Repositories.Msg; | ||||||
|  |  | ||||||
|  | /****************************************************** | ||||||
|  |  * @file MessageRepository.java | ||||||
|  |  * @author Anthony Debucquoy | ||||||
|  |  * @scope Extension messagerie | ||||||
|  |  ******************************************************/ | ||||||
|  |  | ||||||
|  |  | ||||||
|  | import org.springframework.data.repository.CrudRepository; | ||||||
|  |  | ||||||
|  | import ovh.herisson.Clyde.Tables.Msg.Message; | ||||||
|  |  | ||||||
|  | public interface MessageRepository extends CrudRepository<Message, Long> {} | ||||||
| @ -0,0 +1,30 @@ | |||||||
|  | package ovh.herisson.Clyde.Repositories; | ||||||
|  |  | ||||||
|  | /****************************************************** | ||||||
|  |  * @file ScheduleLessonRepository.java | ||||||
|  |  * @author William Karpinski | ||||||
|  |  * @scope Extension Horaire | ||||||
|  |  ******************************************************/ | ||||||
|  | import jakarta.transaction.Transactional; | ||||||
|  | import org.springframework.data.jpa.repository.Modifying; | ||||||
|  | import org.springframework.data.jpa.repository.Query; | ||||||
|  | import org.springframework.data.repository.CrudRepository; | ||||||
|  | import ovh.herisson.Clyde.Tables.Curriculum; | ||||||
|  | import ovh.herisson.Clyde.Tables.Lesson; | ||||||
|  | import ovh.herisson.Clyde.Tables.Schedule; | ||||||
|  | import ovh.herisson.Clyde.Tables.ScheduleLesson; | ||||||
|  |  | ||||||
|  | public interface ScheduleLessonRepository extends CrudRepository<ScheduleLesson,Long> { | ||||||
|  |  | ||||||
|  |     @Query("select distinct sl.lesson from ScheduleLesson sl where sl.schedule.curriculum = ?1") | ||||||
|  |     Iterable<Lesson> findLessonByCurriculum(Curriculum curriculum); | ||||||
|  |  | ||||||
|  |     @Query("select distinct sl.schedule from ScheduleLesson sl where sl.schedule.curriculum = ?1") | ||||||
|  |     Schedule findScheduleByCurriculum(Curriculum curriculum); | ||||||
|  |  | ||||||
|  |     @Modifying | ||||||
|  |     @Transactional | ||||||
|  |     @Query("delete from ScheduleLesson sl where sl.lesson =?1") | ||||||
|  |     void delete(Lesson lesson); | ||||||
|  |  | ||||||
|  | } | ||||||
| @ -0,0 +1,22 @@ | |||||||
|  | package ovh.herisson.Clyde.Repositories; | ||||||
|  |  | ||||||
|  | /****************************************************** | ||||||
|  |  * @file ScheduleRepository.java | ||||||
|  |  * @author William Karpinski | ||||||
|  |  * @scope Extension Horaire | ||||||
|  |  ******************************************************/ | ||||||
|  |  | ||||||
|  | import org.springframework.data.jpa.repository.Query; | ||||||
|  | import org.springframework.data.repository.CrudRepository; | ||||||
|  | import ovh.herisson.Clyde.Tables.Course; | ||||||
|  | import ovh.herisson.Clyde.Tables.Lesson; | ||||||
|  | import ovh.herisson.Clyde.Tables.Schedule; | ||||||
|  |  | ||||||
|  | public interface ScheduleRepository extends CrudRepository<Schedule,Long> { | ||||||
|  |  | ||||||
|  |     Schedule getById(long id); | ||||||
|  |  | ||||||
|  |  | ||||||
|  |     @Query("select distinct sl from Schedule sl where EXISTS (select c.curriculum from CurriculumCourse c where (sl.curriculum = c.curriculum) AND (c.course = ?1))") | ||||||
|  |     Iterable<Schedule> findAllLessonSchedule(Course course); | ||||||
|  | } | ||||||
| @ -6,8 +6,14 @@ 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); | ||||||
|  |     UserCurriculum findByUserAndCurriculumAndActual(User user, Curriculum curriculum, boolean actual); | ||||||
|  |  | ||||||
| } | } | ||||||
|  | |||||||
| @ -1,7 +1,10 @@ | |||||||
| package ovh.herisson.Clyde.Services; | package ovh.herisson.Clyde.Services; | ||||||
|  |  | ||||||
| import org.springframework.stereotype.Service; | import org.springframework.stereotype.Service; | ||||||
|  | import ovh.herisson.Clyde.Services.Inscription.InscriptionService; | ||||||
| import ovh.herisson.Clyde.Tables.*; | import ovh.herisson.Clyde.Tables.*; | ||||||
|  | import ovh.herisson.Clyde.Tables.Inscription.InscriptionRequest; | ||||||
|  |  | ||||||
| import java.util.Date; | import java.util.Date; | ||||||
|  |  | ||||||
| @Service | @Service | ||||||
|  | |||||||
| @ -46,7 +46,7 @@ public class CurriculumCourseService { | |||||||
|         toReturn.put("curriculumId", curriculum.getCurriculumId()); |         toReturn.put("curriculumId", curriculum.getCurriculumId()); | ||||||
|         toReturn.put("year", curriculum.getYear()); |         toReturn.put("year", curriculum.getYear()); | ||||||
|         toReturn.put("option", curriculum.getOption()); |         toReturn.put("option", curriculum.getOption()); | ||||||
|  |         toReturn.put("requireCertificate", curriculum.isRequireCertificate()); | ||||||
|  |  | ||||||
|         return  toReturn; |         return  toReturn; | ||||||
|     } |     } | ||||||
|  | |||||||
| @ -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); | ||||||
|     } |     } | ||||||
|  | |||||||
| @ -0,0 +1,109 @@ | |||||||
|  | package ovh.herisson.Clyde.Services.Inscription; | ||||||
|  |  | ||||||
|  | import org.springframework.security.crypto.bcrypt.BCryptPasswordEncoder; | ||||||
|  | import org.springframework.stereotype.Service; | ||||||
|  | import ovh.herisson.Clyde.Repositories.*; | ||||||
|  | import ovh.herisson.Clyde.Repositories.Inscription.ExternalCurriculumRepository; | ||||||
|  | import ovh.herisson.Clyde.Repositories.Inscription.InscriptionRepository; | ||||||
|  | import ovh.herisson.Clyde.Repositories.Inscription.MinervalRepository; | ||||||
|  | import ovh.herisson.Clyde.Services.UserService; | ||||||
|  | import ovh.herisson.Clyde.Tables.*; | ||||||
|  | import ovh.herisson.Clyde.Tables.Inscription.ExternalCurriculum; | ||||||
|  | import ovh.herisson.Clyde.Tables.Inscription.InscriptionRequest; | ||||||
|  | import ovh.herisson.Clyde.Tables.Inscription.Minerval; | ||||||
|  |  | ||||||
|  | import java.util.ArrayList; | ||||||
|  | import java.util.Calendar; | ||||||
|  |  | ||||||
|  | @Service | ||||||
|  | public class InscriptionService { | ||||||
|  |  | ||||||
|  |     private final InscriptionRepository inscriptionRepo; | ||||||
|  |  | ||||||
|  |     private final UserRepository userRepo; | ||||||
|  |  | ||||||
|  |     private final UserCurriculumRepository userCurriculumRepo; | ||||||
|  |  | ||||||
|  |     private final CurriculumRepository curriculumRepo; | ||||||
|  |  | ||||||
|  |     private final MinervalRepository minervalRepository; | ||||||
|  |     private final BCryptPasswordEncoder passwordEncoder = new BCryptPasswordEncoder(); | ||||||
|  |     private final ExternalCurriculumRepository externalCurriculumRepository; | ||||||
|  |     private final UserService userService; | ||||||
|  |     public InscriptionService(InscriptionRepository inscriptionRepo, UserRepository userRepo, UserCurriculumRepository userCurriculumRepo, CurriculumRepository curriculumRepo, MinervalRepository minervalRepository, ExternalCurriculumRepository externalCurriculumRepository, UserService userService){ | ||||||
|  |         this.inscriptionRepo = inscriptionRepo; | ||||||
|  |         this.userRepo = userRepo; | ||||||
|  |         this.userCurriculumRepo = userCurriculumRepo; | ||||||
|  |         this.curriculumRepo = curriculumRepo; | ||||||
|  |         this.minervalRepository = minervalRepository; | ||||||
|  |         this.externalCurriculumRepository = externalCurriculumRepository; | ||||||
|  |         this.userService = userService; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public InscriptionRequest save(InscriptionRequest inscriptionRequest){ | ||||||
|  |         inscriptionRequest.setPassword(passwordEncoder.encode(inscriptionRequest.getPassword())); | ||||||
|  |         return inscriptionRepo.save(inscriptionRequest); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public InscriptionRequest getById(long id){ | ||||||
|  |         return inscriptionRepo.findById(id); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public Iterable<InscriptionRequest> getAll(){ | ||||||
|  |         return inscriptionRepo.findAll(); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public boolean modifyState(long id, RequestState requestState) { | ||||||
|  |         InscriptionRequest inscrRequest = getById(id); | ||||||
|  |  | ||||||
|  |         if (inscrRequest == null) | ||||||
|  |             return false; | ||||||
|  |  | ||||||
|  |         inscrRequest.setState(requestState); | ||||||
|  |         save(inscrRequest); | ||||||
|  |  | ||||||
|  |         //saves the user from the request if accepted from teacher and inscription services | ||||||
|  |         if (requestState == RequestState.Accepted && (inscrRequest.getEquivalenceState() == RequestState.Accepted || inscrRequest.getEquivalenceState() == RequestState.Unrequired)) | ||||||
|  |         { | ||||||
|  |             return createUser(inscrRequest); | ||||||
|  |         } | ||||||
|  |         return true; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public boolean createUser(InscriptionRequest inscrRequest){ | ||||||
|  |         //We must send an email here | ||||||
|  |  | ||||||
|  |         if (curriculumRepo.findById(inscrRequest.getCurriculumId()) == null) | ||||||
|  |             return false; | ||||||
|  |  | ||||||
|  |         User userFromRequest = new User( | ||||||
|  |                 inscrRequest.getLastName(), | ||||||
|  |                 inscrRequest.getFirstName(), | ||||||
|  |                 inscrRequest.getEmail(), | ||||||
|  |                 inscrRequest.getAddress(), | ||||||
|  |                 inscrRequest.getCountry(), | ||||||
|  |                 inscrRequest.getBirthDate(), | ||||||
|  |                 inscrRequest.getProfilePicture(), | ||||||
|  |                 inscrRequest.getPassword() | ||||||
|  |         ); | ||||||
|  |  | ||||||
|  |         userService.save(userFromRequest); | ||||||
|  |         Calendar c = Calendar.getInstance(); | ||||||
|  |         userCurriculumRepo.save(new UserCurriculum(userFromRequest, curriculumRepo.findById(inscrRequest.getCurriculumId()),c.get(Calendar.YEAR), true)); | ||||||
|  |  | ||||||
|  |         //Create a minerval for the new student | ||||||
|  |         Minerval minerval = new Minerval(userFromRequest.getRegNo(), 0, 852, 2023); | ||||||
|  |         minervalRepository.save(minerval); | ||||||
|  |  | ||||||
|  |         //Assign the externals curriculums from the inscription request to newly created student | ||||||
|  |         ArrayList<ExternalCurriculum> extCurrList = externalCurriculumRepository.getExternalCurriculumByInscriptionRequest(inscrRequest); | ||||||
|  |         for (int i = 0; i < extCurrList.size(); i++){ | ||||||
|  |             extCurrList.get(i).setUser(userFromRequest); | ||||||
|  |             externalCurriculumRepository.save(extCurrList.get(i)); | ||||||
|  |         } | ||||||
|  |         return true; | ||||||
|  |     } | ||||||
|  |     public void delete(InscriptionRequest toDelete) { | ||||||
|  |         inscriptionRepo.delete(toDelete); | ||||||
|  |     } | ||||||
|  | } | ||||||
| @ -1,94 +0,0 @@ | |||||||
| package ovh.herisson.Clyde.Services; |  | ||||||
|  |  | ||||||
| import org.springframework.security.crypto.bcrypt.BCryptPasswordEncoder; |  | ||||||
| import org.springframework.stereotype.Service; |  | ||||||
| import ovh.herisson.Clyde.Repositories.CurriculumRepository; |  | ||||||
| import ovh.herisson.Clyde.Repositories.InscriptionRepository; |  | ||||||
| import ovh.herisson.Clyde.Repositories.UserCurriculumRepository; |  | ||||||
| import ovh.herisson.Clyde.Repositories.UserRepository; |  | ||||||
| import ovh.herisson.Clyde.Tables.InscriptionRequest; |  | ||||||
| import ovh.herisson.Clyde.Tables.RequestState; |  | ||||||
| import ovh.herisson.Clyde.Tables.User; |  | ||||||
| import ovh.herisson.Clyde.Tables.UserCurriculum; |  | ||||||
|  |  | ||||||
| @Service |  | ||||||
| public class InscriptionService { |  | ||||||
|  |  | ||||||
|     private final InscriptionRepository inscriptionRepo; |  | ||||||
|  |  | ||||||
|     private final UserRepository userRepo; |  | ||||||
|  |  | ||||||
|     private final UserCurriculumRepository userCurriculumRepo; |  | ||||||
|  |  | ||||||
|     private final CurriculumRepository curriculumRepo; |  | ||||||
|  |  | ||||||
|     private final BCryptPasswordEncoder passwordEncoder = new BCryptPasswordEncoder(); |  | ||||||
|  |  | ||||||
|  |  | ||||||
|     public InscriptionService(InscriptionRepository inscriptionRepo, UserRepository userRepo, UserCurriculumRepository userCurriculumRepo, CurriculumRepository curriculumRepo){ |  | ||||||
|         this.inscriptionRepo = inscriptionRepo; |  | ||||||
|         this.userRepo = userRepo; |  | ||||||
|         this.userCurriculumRepo = userCurriculumRepo; |  | ||||||
|         this.curriculumRepo = curriculumRepo; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     public InscriptionRequest save(InscriptionRequest inscriptionRequest){ |  | ||||||
|         inscriptionRequest.setPassword(passwordEncoder.encode(inscriptionRequest.getPassword())); |  | ||||||
|         return inscriptionRepo.save(inscriptionRequest); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     public InscriptionRequest getById(long id){ |  | ||||||
|         return inscriptionRepo.findById(id); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     public Iterable<InscriptionRequest> getAll(){ |  | ||||||
|         return inscriptionRepo.findAll(); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     public boolean modifyState(long id, RequestState requestState) { |  | ||||||
|         InscriptionRequest inscrRequest = getById(id); |  | ||||||
|  |  | ||||||
|         if (inscrRequest == null) |  | ||||||
|             return false; |  | ||||||
|  |  | ||||||
|         // if th state is the same we don't send an email |  | ||||||
|         if (requestState == inscrRequest.getState()) |  | ||||||
|             return false; |  | ||||||
|  |  | ||||||
|         /** todo send an email to tell the poster of the inscrRequest (inscrRequest.getEmail()) |  | ||||||
|          *  to notify them that the state of their request changed |  | ||||||
|          *  FooEmailFormat toSend = (String.format("Your request state changed from %s to %s"), |  | ||||||
|          *                                              inscrRequest.getState(), requestState) |  | ||||||
|          * FooEmailSender.send(toSend, inscrRequest.getEmail()) |  | ||||||
|          */ |  | ||||||
|  |  | ||||||
|  |  | ||||||
|         //saves the user from the request if accepted |  | ||||||
|         if (requestState == RequestState.Accepted) |  | ||||||
|         { |  | ||||||
|             if (curriculumRepo.findById(inscrRequest.getCurriculumId()) == null) |  | ||||||
|                 return false; |  | ||||||
|  |  | ||||||
|             User userFromRequest = new User( |  | ||||||
|                     inscrRequest.getLastName(), |  | ||||||
|                     inscrRequest.getFirstName(), |  | ||||||
|                     inscrRequest.getEmail(), |  | ||||||
|                     inscrRequest.getAddress(), |  | ||||||
|                     inscrRequest.getCountry(), |  | ||||||
|                     inscrRequest.getBirthDate(), |  | ||||||
|                     inscrRequest.getProfilePicture(), |  | ||||||
|                     inscrRequest.getPassword() |  | ||||||
|             ); |  | ||||||
|  |  | ||||||
|             userRepo.save(userFromRequest); |  | ||||||
|             userCurriculumRepo.save(new UserCurriculum(userFromRequest, curriculumRepo.findById(inscrRequest.getCurriculumId()))); |  | ||||||
|         } |  | ||||||
|         inscrRequest.setState(requestState); |  | ||||||
|         save(inscrRequest); |  | ||||||
|         return true; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     public void delete(InscriptionRequest toDelete) { |  | ||||||
|         inscriptionRepo.delete(toDelete); |  | ||||||
|     } |  | ||||||
| } |  | ||||||
| @ -0,0 +1,177 @@ | |||||||
|  | package ovh.herisson.Clyde.Services; | ||||||
|  |  | ||||||
|  | /****************************************************** | ||||||
|  |  * @file LeessonRequestService.java | ||||||
|  |  * @author William Karpinski | ||||||
|  |  * @scope Extension Horaire | ||||||
|  |  ******************************************************/ | ||||||
|  | import org.springframework.stereotype.Service; | ||||||
|  | import ovh.herisson.Clyde.Repositories.*; | ||||||
|  | import ovh.herisson.Clyde.Tables.*; | ||||||
|  |  | ||||||
|  | import java.util.Map; | ||||||
|  |  | ||||||
|  | @Service | ||||||
|  | public class LessonRequestService { | ||||||
|  |     private final LessonChangesRequestRepository lessonChangesRepo; | ||||||
|  |  | ||||||
|  |     private final UserRepository userRepo; | ||||||
|  |  | ||||||
|  |     private final LessonRepository lessonRepo; | ||||||
|  |  | ||||||
|  |     private final LessonService lessonServ; | ||||||
|  |  | ||||||
|  |     private final ScheduleLessonRepository scheduleLessonRepo; | ||||||
|  |  | ||||||
|  |     private final ScheduleRepository scheduleRepository; | ||||||
|  |  | ||||||
|  |     private final ScheduleLessonService scheduleLessonService; | ||||||
|  |  | ||||||
|  |     private final UserService userServ; | ||||||
|  |  | ||||||
|  |     private final CourseRepository courseRepository; | ||||||
|  |     public LessonRequestService(LessonChangesRequestRepository lessonChangesRepo, | ||||||
|  |                                 UserRepository userRepo, LessonRepository lessonRepo, | ||||||
|  |                                 LessonService lessonServ, ScheduleLessonRepository scheduleLessonRepo, | ||||||
|  |                                 ScheduleRepository scheduleRepository, ScheduleLessonService scheduleLessonService, | ||||||
|  |                                 UserService userServ, CourseRepository courseRepository) { | ||||||
|  |         this.lessonChangesRepo = lessonChangesRepo; | ||||||
|  |         this.userRepo = userRepo; | ||||||
|  |         this.lessonRepo = lessonRepo; | ||||||
|  |         this.lessonServ = lessonServ; | ||||||
|  |         this.scheduleLessonRepo = scheduleLessonRepo; | ||||||
|  |         this.scheduleRepository = scheduleRepository; | ||||||
|  |         this.scheduleLessonService = scheduleLessonService; | ||||||
|  |         this.userServ = userServ; | ||||||
|  |         this.courseRepository = courseRepository; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Create a new lesson request | ||||||
|  |      */ | ||||||
|  |     public LessonChangesRequest save(LessonChangesRequest lessonRequest){ | ||||||
|  |         return lessonChangesRepo.save(lessonRequest); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Find all the requests made by a user | ||||||
|  |      */ | ||||||
|  |     public Iterable<LessonChangesRequest> findOwnRequests(User user){ | ||||||
|  |         return lessonChangesRepo.findOwnRequests(user); | ||||||
|  |     } | ||||||
|  |     public LessonChangesRequest findById(long id){ | ||||||
|  |         return lessonChangesRepo.findById(id); | ||||||
|  |     } | ||||||
|  |     /** | ||||||
|  |      *  Return all the requests | ||||||
|  |      */ | ||||||
|  |     public Iterable<LessonChangesRequest> getAll(){return lessonChangesRepo.findAll();} | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Create a lesson if a request is accepted | ||||||
|  |      */ | ||||||
|  |     public boolean modifyCreateRequestState(LessonChangesRequest lessonRequest, RequestState state, String local ){ | ||||||
|  |         if(lessonRequest == null || state == lessonRequest.getState()  || state == null){ | ||||||
|  |             return false;} | ||||||
|  |         if (state == RequestState.Accepted){ | ||||||
|  |             Course course = courseRepository.findById(lessonRequest.getCourse().getCourseID()); | ||||||
|  |             if(courseRepository.findById(lessonRequest.getCourse().getCourseID())==null|| local == null){ | ||||||
|  |                 return false;} | ||||||
|  |             Lesson lesson = new Lesson(); | ||||||
|  |             lesson.setCourse(course); | ||||||
|  |             lesson.setLessonStart(lessonRequest.getLessonStart()); | ||||||
|  |             lesson.setLessonEnd(lessonRequest.getLessonEnd()); | ||||||
|  |             lesson.setColor(lessonRequest.getColor()); | ||||||
|  |             lesson.setLocal(local); | ||||||
|  |             lesson.setLessonType(lessonRequest.getLessonType()); | ||||||
|  |  | ||||||
|  |             lesson = lessonRepo.save(lesson); | ||||||
|  |             scheduleLessonService.saveToAllSchedule(lesson); | ||||||
|  |             } | ||||||
|  |         lessonRequest.setState(state); | ||||||
|  |         save(lessonRequest); | ||||||
|  |         return true; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public Iterable<LessonChangesRequest> findRequestByLessonId(long id){ | ||||||
|  |       return lessonChangesRepo.findRequestByLessonId(id); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      *  Refuse all the lesson request that depends on a certain lesson | ||||||
|  |      *  Used after the deletion of the lesson | ||||||
|  |      */ | ||||||
|  |     public void refuseAllByLessonId(long id){ | ||||||
|  |       Iterable<LessonChangesRequest> toRefuse = findRequestByLessonId(id); | ||||||
|  |       for(LessonChangesRequest element : toRefuse) | ||||||
|  |         element.setState(RequestState.Refused); | ||||||
|  |          | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      *  Modify a lesson if a request is accepted | ||||||
|  |      */ | ||||||
|  |     public boolean modifyChangeRequestState(Map<String, Object> updates, long lessonId,RequestState state){ | ||||||
|  |         if(state == RequestState.Accepted){ | ||||||
|  |             Lesson lesson = lessonServ.findById(lessonId); | ||||||
|  |             return lessonServ.modifyData(lesson.getLessonID(),updates); | ||||||
|  |         } | ||||||
|  |         return true; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      *  Delete a lesson if a request is accepted | ||||||
|  |      */ | ||||||
|  |     public void modifyDeleteRequest(LessonChangesRequest lessonChangesRequest, RequestState state){ | ||||||
|  |         if(state == RequestState.Accepted){ | ||||||
|  |             lessonServ.delete(lessonServ.findById(lessonChangesRequest.getLessonId())); | ||||||
|  |             refuseAllByLessonId(lessonChangesRequest.getLessonId()); | ||||||
|  |             } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Construct a lesson request | ||||||
|  |      */ | ||||||
|  |     public LessonChangesRequest createLessonRequest(Map<String,Object> lessonInfos) { | ||||||
|  |         LessonChangesRequest target = new LessonChangesRequest(); | ||||||
|  |  | ||||||
|  |         for (Map.Entry<String, Object> entry : lessonInfos.entrySet()) { | ||||||
|  |             System.out.println(entry.toString()); | ||||||
|  |             if(entry.getValue() != null){ | ||||||
|  |                 switch (entry.getKey()) { | ||||||
|  |                     case "requestType": | ||||||
|  |                     target.setRequestType((int) entry.getValue()); | ||||||
|  |                     break; | ||||||
|  |                     case "lessonStart": | ||||||
|  |                         target.setLessonStart((String) entry.getValue()); | ||||||
|  |                         break; | ||||||
|  |                     case "lessonEnd": | ||||||
|  |                         target.setLessonEnd((String) entry.getValue()); | ||||||
|  |                         break; | ||||||
|  |                     case "color": | ||||||
|  |                         target.setColor((String) entry.getValue()); | ||||||
|  |                         break; | ||||||
|  |                     case "user": | ||||||
|  |                         target.setUser(userServ.getUserById((int) entry.getValue())); | ||||||
|  |                         break; | ||||||
|  |                     case "lessonType": | ||||||
|  |                         target.setLessonType((String) entry.getValue()); | ||||||
|  |                         break; | ||||||
|  |                     case "course": | ||||||
|  |                         target.setCourse(courseRepository.findById((int) entry.getValue())); | ||||||
|  |                         break; | ||||||
|  |                     case "lessonId": | ||||||
|  |                         target.setLessonId((int) entry.getValue()); | ||||||
|  |                         break; | ||||||
|  |  | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |         target.setState(RequestState.Pending); | ||||||
|  |         return target; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public void delete (LessonChangesRequest toDelete) { | ||||||
|  |         lessonChangesRepo.delete(toDelete); | ||||||
|  |     } | ||||||
|  | } | ||||||
| @ -0,0 +1,147 @@ | |||||||
|  | package ovh.herisson.Clyde.Services; | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /****************************************************** | ||||||
|  |  * @file LessonService.java | ||||||
|  |  * @author William Karpinski | ||||||
|  |  * @scope Extension Horaire | ||||||
|  |  ******************************************************/ | ||||||
|  | import org.springframework.stereotype.Service; | ||||||
|  | import ovh.herisson.Clyde.Repositories.CourseRepository; | ||||||
|  | import ovh.herisson.Clyde.Repositories.CurriculumCourseRepository; | ||||||
|  | import ovh.herisson.Clyde.Repositories.LessonRepository; | ||||||
|  | import ovh.herisson.Clyde.Repositories.UserCurriculumRepository; | ||||||
|  | import ovh.herisson.Clyde.Tables.*; | ||||||
|  |  | ||||||
|  | import java.util.ArrayList; | ||||||
|  | import java.util.Map; | ||||||
|  |  | ||||||
|  | @Service | ||||||
|  | public class LessonService { | ||||||
|  |     private final LessonRepository lessonRepo; | ||||||
|  |     private final UserCurriculumRepository userCurriculumRepo; | ||||||
|  |     private final CourseRepository courseRepo; | ||||||
|  |  | ||||||
|  |     private final CurriculumCourseRepository curriculumCourseRepo; | ||||||
|  |     public LessonService(LessonRepository lessonRepo, UserCurriculumRepository userCurriculumRepo, CourseRepository courseRepo, CurriculumCourseRepository curriculumCourseRepo){ | ||||||
|  |         this.lessonRepo = lessonRepo; | ||||||
|  |         this.userCurriculumRepo = userCurriculumRepo; | ||||||
|  |         this.courseRepo = courseRepo; | ||||||
|  |         this.curriculumCourseRepo = curriculumCourseRepo; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Create a lesson | ||||||
|  |      */ | ||||||
|  |     public Lesson save(Lesson lesson){ | ||||||
|  |         return lessonRepo.save(lesson); | ||||||
|  |     } | ||||||
|  |     /** | ||||||
|  |      * Find a lesson by its id | ||||||
|  |      */ | ||||||
|  |     public Lesson findById(long id){ | ||||||
|  |         return lessonRepo.findById(id); | ||||||
|  |     } | ||||||
|  |     /** | ||||||
|  |      * Return all the lessons | ||||||
|  |      */ | ||||||
|  |     public Iterable<Lesson> findAll(){return lessonRepo.findAll();} | ||||||
|  |     /** | ||||||
|  |      * Return all a teacher's lessons | ||||||
|  |      */ | ||||||
|  |     public Iterable<Lesson> findAllOwnedLesson(User teacher){ | ||||||
|  |         ArrayList<Lesson> toReturn = new ArrayList<>(); | ||||||
|  |         ArrayList<Course> coursesOwned = (ArrayList<Course>) courseRepo.findAllOwnedCoures(teacher); | ||||||
|  |         for (Course element : coursesOwned) { | ||||||
|  |             for(Lesson lesson : lessonRepo.findLessonByCourse(element)) | ||||||
|  |                 toReturn.add(lesson); | ||||||
|  |         } | ||||||
|  |         return toReturn; | ||||||
|  |     } | ||||||
|  |     /** | ||||||
|  |      * Return all a student's lessons | ||||||
|  |      */ | ||||||
|  |      | ||||||
|  |   public Iterable<Lesson> findOnesLessons(User student){ | ||||||
|  |     ArrayList<Lesson> toReturn = new ArrayList<>(); | ||||||
|  |     ArrayList<Course> courses = new ArrayList<>(); | ||||||
|  |     ArrayList<UserCurriculum> userCurriculums = userCurriculumRepo.findByUserOrderByCurriculum(student); | ||||||
|  |     for(UserCurriculum uc: userCurriculums){ | ||||||
|  |       Curriculum c = uc.getCurriculum(); | ||||||
|  |       if(uc.isActual()) | ||||||
|  |         courses.addAll((ArrayList<Course>) curriculumCourseRepo.findCoursesByCurriculum(c)); | ||||||
|  |       } | ||||||
|  |     for (Course element : courses) { | ||||||
|  |           for(Lesson lesson : lessonRepo.findLessonByCourse(element)) | ||||||
|  |               toReturn.add(lesson); | ||||||
|  |       } | ||||||
|  |  | ||||||
|  |     return toReturn; | ||||||
|  |     } | ||||||
|  |     /** | ||||||
|  |      *  Construct a new lesson | ||||||
|  |      */ | ||||||
|  |     public Lesson createLesson(Map<String,Object> lessonInfos) { | ||||||
|  |         Lesson target = new Lesson(); | ||||||
|  |  | ||||||
|  |         for (Map.Entry<String, Object> entry : lessonInfos.entrySet()) { | ||||||
|  |             switch (entry.getKey()) { | ||||||
|  |                 case "lessonStart": | ||||||
|  |                     target.setLessonStart((String) entry.getValue()); | ||||||
|  |                     break; | ||||||
|  |                 case "lessonEnd": | ||||||
|  |                     target.setLessonEnd((String) entry.getValue()); | ||||||
|  |                 case "color": | ||||||
|  |                     target.setColor((String) entry.getValue()); | ||||||
|  |                     break; | ||||||
|  |                 case "local": | ||||||
|  |                     target.setLocal((String) entry.getValue()); | ||||||
|  |                     break; | ||||||
|  |                 case "lessonType": | ||||||
|  |                     target.setLessonType((String) entry.getValue()); | ||||||
|  |                     break; | ||||||
|  |                 case "courseId": | ||||||
|  |                     target.setCourse(courseRepo.findById((int) entry.getValue())); | ||||||
|  |                     break; | ||||||
|  |             } | ||||||
|  |  | ||||||
|  |         } | ||||||
|  |         return target; | ||||||
|  |     } | ||||||
|  |     /** | ||||||
|  |      * Modify a lesson | ||||||
|  |      */ | ||||||
|  |     public boolean modifyData(long id, Map<String ,Object> updates){ | ||||||
|  |         Lesson target = lessonRepo.findById(id); | ||||||
|  |  | ||||||
|  |         if(target == null) | ||||||
|  |             return false; | ||||||
|  |  | ||||||
|  |         for (Map.Entry<String , Object> entry: updates.entrySet()){ | ||||||
|  |             switch (entry.getKey()){ | ||||||
|  |                 case "lessonStart": | ||||||
|  |                     target.setLessonStart((String) entry.getValue()); | ||||||
|  |                     break; | ||||||
|  |                 case "lessonEnd": | ||||||
|  |                     target.setLessonEnd((String) entry.getValue()); | ||||||
|  |                     break;             | ||||||
|  |                 case "local": | ||||||
|  |                     target.setLocal((String) entry.getValue()); | ||||||
|  |                     break; | ||||||
|  |                 case "lessonType": | ||||||
|  |                     target.setLessonType((String) entry.getValue()); | ||||||
|  |                     break; | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |         lessonRepo.save(target); | ||||||
|  |         return true; | ||||||
|  |     } | ||||||
|  |     /** | ||||||
|  |      * Delete a lesson | ||||||
|  |      */ | ||||||
|  |     public void delete(Lesson lesson){ | ||||||
|  |         lessonRepo.delete(lesson); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |  | ||||||
|  | } | ||||||
| @ -0,0 +1,57 @@ | |||||||
|  | package ovh.herisson.Clyde.Services.Msg; | ||||||
|  |  | ||||||
|  | import java.util.List; | ||||||
|  |  | ||||||
|  | /****************************************************** | ||||||
|  |  * @file DiscussionService.java | ||||||
|  |  * @author Anthony Debucquoy | ||||||
|  |  * @scope Extension messagerie | ||||||
|  |  * | ||||||
|  |  * Various function utilised by the messages application | ||||||
|  |  ******************************************************/ | ||||||
|  |  | ||||||
|  |  | ||||||
|  | import org.springframework.beans.factory.annotation.Autowired; | ||||||
|  | import org.springframework.stereotype.Service; | ||||||
|  |  | ||||||
|  | import com.fasterxml.jackson.databind.util.JSONPObject; | ||||||
|  |  | ||||||
|  | import ovh.herisson.Clyde.Repositories.Msg.DiscussionRepository; | ||||||
|  | import ovh.herisson.Clyde.Tables.User; | ||||||
|  | import ovh.herisson.Clyde.Tables.Msg.Discussion; | ||||||
|  | import ovh.herisson.Clyde.Tables.Msg.Message; | ||||||
|  |  | ||||||
|  | @Service | ||||||
|  | public class DiscussionService { | ||||||
|  |  | ||||||
|  | 	@Autowired | ||||||
|  | 	private DiscussionRepository discRepo; | ||||||
|  |  | ||||||
|  | 	public Discussion create(String name, User author){ | ||||||
|  | 		return discRepo.save(new Discussion(name, author)); | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	/** | ||||||
|  | 	 * list discussions owned by a certain user | ||||||
|  | 	 */ | ||||||
|  | 	public Iterable<Discussion> getOwned(User author){ | ||||||
|  | 		return discRepo.findByMembership(author.getRegNo()); | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	/** | ||||||
|  | 	 * Create a message and link it to it's discussion | ||||||
|  | 	 */ | ||||||
|  | 	public Discussion CreateMessage(Discussion disc, Message msg){ | ||||||
|  | 		disc.addMessage(msg); | ||||||
|  | 		return discRepo.save(disc); | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	/** | ||||||
|  | 	 * Check if a user is in a discussion | ||||||
|  | 	 */ | ||||||
|  |     public boolean hasDiscussion(User user, long id) { | ||||||
|  | 		Discussion disc = discRepo.findById(id).orElse(null); | ||||||
|  | 		List<User> members = disc.getMembers(); | ||||||
|  | 		return members.contains(user); | ||||||
|  |     } | ||||||
|  | } | ||||||
| @ -1,8 +1,7 @@ | |||||||
| package ovh.herisson.Clyde.Services; | package ovh.herisson.Clyde.Services; | ||||||
|  |  | ||||||
| import ovh.herisson.Clyde.Tables.Course; | import ovh.herisson.Clyde.Tables.*; | ||||||
| import ovh.herisson.Clyde.Tables.InscriptionRequest; | import ovh.herisson.Clyde.Tables.Inscription.InscriptionRequest; | ||||||
| import ovh.herisson.Clyde.Tables.User; |  | ||||||
|  |  | ||||||
| import java.util.ArrayList; | import java.util.ArrayList; | ||||||
| import java.util.HashMap; | import java.util.HashMap; | ||||||
| @ -69,6 +68,33 @@ public class ProtectionService { | |||||||
|  |  | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     public static HashMap<String , Object> lessonWithoutPassword(Lesson lesson){ | ||||||
|  |         if(lesson == null) | ||||||
|  |             return null; | ||||||
|  |  | ||||||
|  |         HashMap<String, Object> toReturn = new HashMap<>(); | ||||||
|  |  | ||||||
|  |         toReturn.put("lessonID", lesson.getLessonID()); | ||||||
|  |         toReturn.put("lessonStart", lesson.getLessonStart()); | ||||||
|  |         toReturn.put("lessonEnd", lesson.getLessonEnd()); | ||||||
|  |         toReturn.put("course",courseWithoutPassword(lesson.getCourse())); | ||||||
|  |         toReturn.put("local",lesson.getLocal()); | ||||||
|  |         toReturn.put("color", lesson.getColor()); | ||||||
|  |         toReturn.put("lessonType",lesson.getLessonType()); | ||||||
|  |         return toReturn; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public static Iterable<HashMap<String ,Object>> lessonsWithoutPassword(Iterable<Lesson> lessons){ | ||||||
|  |         ArrayList<HashMap<String,Object>> toReturn = new ArrayList<>(); | ||||||
|  |  | ||||||
|  |         for (Lesson l: lessons){ | ||||||
|  |             toReturn.add(ProtectionService.lessonWithoutPassword(l)); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         return toReturn; | ||||||
|  |  | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |  | ||||||
|     public static Map<String, Object> requestWithoutPassword(InscriptionRequest inscriptionRequest) { |     public static Map<String, Object> requestWithoutPassword(InscriptionRequest inscriptionRequest) { | ||||||
|  |  | ||||||
| @ -87,10 +113,38 @@ 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()); | ||||||
|  |         toReturn.put("equivalenceState", inscriptionRequest.getEquivalenceState()); | ||||||
|  |         return toReturn; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public static Map<String, Object> lessonRequestWithoutPassword(LessonChangesRequest lessonRequest){ | ||||||
|  |         if (lessonRequest == null) | ||||||
|  |             return null; | ||||||
|  |         Map<String, Object> toReturn = new HashMap<>(); | ||||||
|  |         toReturn.put("id", lessonRequest.getId()); | ||||||
|  |         toReturn.put("lessonStart", lessonRequest.getLessonStart()); | ||||||
|  |         toReturn.put("lessonEnd", lessonRequest.getLessonEnd()); | ||||||
|  |         toReturn.put("lessonType",lessonRequest.getLessonType()); | ||||||
|  |         toReturn.put("course", courseWithoutPassword(lessonRequest.getCourse())); | ||||||
|  |         toReturn.put("user", userWithoutPassword(lessonRequest.getUser())); | ||||||
|  |         toReturn.put("requestType", lessonRequest.getRequestType()); | ||||||
|  |         toReturn.put("state", lessonRequest.getState()); | ||||||
|  |         toReturn.put("lessonId",lessonRequest.getLessonId()); | ||||||
|  |  | ||||||
|         return toReturn; |         return toReturn; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     public static Iterable<Map<String, Object>> lessonRequestsWithoutPassword(Iterable<LessonChangesRequest> lessonChangesRequests){ | ||||||
|  |        ArrayList<Map<String,Object>> toReturn = new ArrayList<>(); | ||||||
|  |  | ||||||
|  |        for(LessonChangesRequest lessonChangeRequest: lessonChangesRequests){ | ||||||
|  |            toReturn.add(lessonRequestWithoutPassword(lessonChangeRequest)); | ||||||
|  |        } | ||||||
|  |        return toReturn; | ||||||
|  |  | ||||||
|  |     } | ||||||
|     public static Iterable<Map<String ,Object>> requestsWithoutPasswords(Iterable<InscriptionRequest> inscriptionRequests){ |     public static Iterable<Map<String ,Object>> requestsWithoutPasswords(Iterable<InscriptionRequest> inscriptionRequests){ | ||||||
|  |  | ||||||
|         ArrayList<Map<String,Object>> toReturn = new ArrayList<>(); |         ArrayList<Map<String,Object>> toReturn = new ArrayList<>(); | ||||||
|  | |||||||
| @ -0,0 +1,93 @@ | |||||||
|  | package ovh.herisson.Clyde.Services; | ||||||
|  |  | ||||||
|  | /****************************************************** | ||||||
|  |  * @file ScheduleLessonService.java | ||||||
|  |  * @author William Karpinski | ||||||
|  |  * @scope Extension Horaire | ||||||
|  |  ******************************************************/ | ||||||
|  | import org.springframework.stereotype.Service; | ||||||
|  | import ovh.herisson.Clyde.Repositories.LessonRepository; | ||||||
|  | import ovh.herisson.Clyde.Repositories.ScheduleLessonRepository; | ||||||
|  | import ovh.herisson.Clyde.Repositories.ScheduleRepository; | ||||||
|  | import ovh.herisson.Clyde.Tables.*; | ||||||
|  |  | ||||||
|  | import java.util.ArrayList; | ||||||
|  | import java.util.HashMap; | ||||||
|  | import java.util.Map; | ||||||
|  | import java.util.Optional; | ||||||
|  |  | ||||||
|  | @Service | ||||||
|  | public class ScheduleLessonService { | ||||||
|  |  | ||||||
|  |     private final ScheduleLessonRepository scheduleLessonRepo; | ||||||
|  |  | ||||||
|  |     private final LessonRepository lessonRepo; | ||||||
|  |     private final ScheduleRepository scheduleRepo; | ||||||
|  |     public ScheduleLessonService(ScheduleLessonRepository scheduleLessonRepo, LessonRepository lessonRepo, ScheduleRepository scheduleRepo) { | ||||||
|  |         this.scheduleLessonRepo = scheduleLessonRepo; | ||||||
|  |         this.lessonRepo = lessonRepo; | ||||||
|  |         this.scheduleRepo = scheduleRepo; | ||||||
|  |     } | ||||||
|  |     public boolean save(ScheduleLesson scheduleLesson){ | ||||||
|  |         if(scheduleLesson == null) | ||||||
|  |           return false; | ||||||
|  |         scheduleLessonRepo.save(scheduleLesson); | ||||||
|  |         return true; | ||||||
|  |     } | ||||||
|  |     /** | ||||||
|  |      * Save a lesson to all the schedule it is linked | ||||||
|  |      */ | ||||||
|  |     public boolean saveToAllSchedule(Lesson lesson){ | ||||||
|  |         Iterable<Schedule> schedules = scheduleRepo.findAllLessonSchedule(lesson.getCourse()); | ||||||
|  |         if(schedules == null) | ||||||
|  |             return false; | ||||||
|  |         for (Schedule schedule : schedules){ | ||||||
|  |             save(new ScheduleLesson(schedule, lesson)); | ||||||
|  |         } | ||||||
|  |         return true; | ||||||
|  |     } | ||||||
|  |     /** | ||||||
|  |      * Delete a scheduleLesson via its lesson | ||||||
|  |      */ | ||||||
|  |     public boolean delete(long lessonId){ | ||||||
|  |         if(lessonId == 0) | ||||||
|  |             return false; | ||||||
|  |         scheduleLessonRepo.delete(lessonRepo.findById(lessonId)); | ||||||
|  |         return true; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public Schedule getScheduleByCurriculum(Curriculum curriculum){ | ||||||
|  |         return scheduleLessonRepo.findScheduleByCurriculum(curriculum); | ||||||
|  |     } | ||||||
|  |     /** | ||||||
|  |      *  Return a schedule and the list of lessons that corresponds | ||||||
|  |      */ | ||||||
|  |     public Map<String , Object> getDepthScheduleBySchedule(Schedule schedule){ | ||||||
|  |         if(schedule == null) | ||||||
|  |             return null; | ||||||
|  |  | ||||||
|  |         HashMap<String , Object> toReturn = new HashMap<>(); | ||||||
|  |         ArrayList<Map<String, Object>> lessons = new ArrayList<>(); | ||||||
|  |         Iterable<Lesson> foundLessons = scheduleLessonRepo.findLessonByCurriculum(schedule.getCurriculum()); | ||||||
|  |  | ||||||
|  |         for (Lesson l: foundLessons){ | ||||||
|  |             lessons.add(ProtectionService.lessonWithoutPassword(l)); | ||||||
|  |         } | ||||||
|  |         toReturn.put("lessons",lessons); | ||||||
|  |         toReturn.put("scheduleId" , schedule.getScheduleID()); | ||||||
|  |         toReturn.put("curriculum", schedule.getCurriculum()); | ||||||
|  |         return toReturn; | ||||||
|  |     } | ||||||
|  |     /** | ||||||
|  |      * Return all the schedules | ||||||
|  |      */ | ||||||
|  |     public Iterable<Map<String,Object>> getAllSchedule(){ | ||||||
|  |         ArrayList<Map<String,Object>> toReturn = new ArrayList<>(); | ||||||
|  |  | ||||||
|  |         for (Schedule schedule: scheduleRepo.findAll()){ | ||||||
|  |             toReturn.add(getDepthScheduleBySchedule(schedule)); | ||||||
|  |         } | ||||||
|  |         return toReturn; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  | } | ||||||
| @ -0,0 +1,24 @@ | |||||||
|  | package ovh.herisson.Clyde.Services; | ||||||
|  |  | ||||||
|  | import org.springframework.stereotype.Service; | ||||||
|  | import ovh.herisson.Clyde.Repositories.ScheduleRepository; | ||||||
|  | import ovh.herisson.Clyde.Tables.Schedule; | ||||||
|  |  | ||||||
|  | @Service | ||||||
|  | public class ScheduleService { | ||||||
|  |     private final ScheduleRepository scheduleRepo; | ||||||
|  |     public ScheduleService(ScheduleRepository scheduleRepo) { | ||||||
|  |         this.scheduleRepo = scheduleRepo; | ||||||
|  |     } | ||||||
|  |     public Schedule save(Schedule schedule){ | ||||||
|  |         return scheduleRepo.save(schedule); | ||||||
|  |     } | ||||||
|  |     public Schedule findById(long id){ | ||||||
|  |         return scheduleRepo.getById(id); | ||||||
|  |     } | ||||||
|  |     public void delete(Schedule schedule){ | ||||||
|  |         scheduleRepo.delete(schedule); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  | } | ||||||
|  |  | ||||||
| @ -1,20 +1,53 @@ | |||||||
| 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.Inscription.ExternalCurriculumRepository; | ||||||
| import ovh.herisson.Clyde.Repositories.UserCurriculumRepository; | import ovh.herisson.Clyde.Repositories.UserCurriculumRepository; | ||||||
| import ovh.herisson.Clyde.Tables.Curriculum; | import ovh.herisson.Clyde.Tables.*; | ||||||
| import ovh.herisson.Clyde.Tables.User; |  | ||||||
|  | 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()); | ||||||
|  |             element.put("actual", list.get(i).isActual()); | ||||||
|  |  | ||||||
|  |             curriculumlist.add(element); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         HashMap<String, Object> toReturn = new HashMap<String, Object>(); | ||||||
|  |         toReturn.put("curriculumList", curriculumlist); | ||||||
|  |         return toReturn; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |  | ||||||
| } | } | ||||||
|  | |||||||
| @ -2,6 +2,7 @@ package ovh.herisson.Clyde.Services; | |||||||
|  |  | ||||||
| import org.springframework.security.crypto.bcrypt.BCryptPasswordEncoder; | import org.springframework.security.crypto.bcrypt.BCryptPasswordEncoder; | ||||||
| import org.springframework.stereotype.Service; | import org.springframework.stereotype.Service; | ||||||
|  | import ovh.herisson.Clyde.Tables.RegNoGenerator; | ||||||
| import ovh.herisson.Clyde.Repositories.UserRepository; | import ovh.herisson.Clyde.Repositories.UserRepository; | ||||||
| import ovh.herisson.Clyde.Tables.Role; | import ovh.herisson.Clyde.Tables.Role; | ||||||
| import ovh.herisson.Clyde.Tables.User; | import ovh.herisson.Clyde.Tables.User; | ||||||
| @ -106,10 +107,17 @@ public class UserService { | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     public User save(User  user){ |     public User save(User  user){ | ||||||
|  |         RegNoGenerator.resetCount(); | ||||||
|         user.setPassword(passwordEncoder.encode(user.getPassword())); |         user.setPassword(passwordEncoder.encode(user.getPassword())); | ||||||
|         return userRepo.save(user); |         return userRepo.save(user); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     public void saveAll(ArrayList<User> list){ | ||||||
|  |         //S'assure que le compteur est bien a 0 | ||||||
|  |         RegNoGenerator.resetCount(); | ||||||
|  |         userRepo.saveAll(list); | ||||||
|  |     } | ||||||
|  |  | ||||||
|     public Iterable<User> getAll(){ |     public Iterable<User> getAll(){ | ||||||
|         return userRepo.findAll(); |         return userRepo.findAll(); | ||||||
|     } |     } | ||||||
|  | |||||||
| @ -3,6 +3,7 @@ package ovh.herisson.Clyde.Tables; | |||||||
| public enum Applications { | public enum Applications { | ||||||
|     // without any token |     // without any token | ||||||
|     Login, |     Login, | ||||||
|  |     Schedule, | ||||||
|  |  | ||||||
|     // with any token |     // with any token | ||||||
|     Profile, |     Profile, | ||||||
| @ -12,12 +13,20 @@ public enum Applications { | |||||||
|     Msg, |     Msg, | ||||||
|     Forum, |     Forum, | ||||||
|     Rdv, |     Rdv, | ||||||
|  |     // teachers authorization | ||||||
|  |  | ||||||
|  |     ManageOwnedLessons, | ||||||
|  |  | ||||||
|     // teachers and Secretary authorization |     // teachers and Secretary authorization | ||||||
|     ManageCourses, |     ManageCourses, | ||||||
|     UsersList, |     UsersList, | ||||||
|  |      | ||||||
|  |     //Secretary authorization | ||||||
|  |     ManageSchedules, | ||||||
|  |     LessonRequests, | ||||||
|  |  | ||||||
|     // InscriptionService authorization |     // InscriptionService authorization | ||||||
|     Inscription, |     Requests, | ||||||
|     StudentsList |     StudentsList, | ||||||
|  |     Payments | ||||||
| } | } | ||||||
|  | |||||||
| @ -0,0 +1,95 @@ | |||||||
|  | package ovh.herisson.Clyde.Tables; | ||||||
|  |  | ||||||
|  | import jakarta.persistence.*; | ||||||
|  |  | ||||||
|  | import java.util.Date; | ||||||
|  |  | ||||||
|  | @Entity | ||||||
|  | public class ChangeCurriculumRequest { | ||||||
|  |     @Id | ||||||
|  |     @GeneratedValue(strategy = GenerationType.AUTO) | ||||||
|  |     private int id; | ||||||
|  |  | ||||||
|  |     @ManyToOne | ||||||
|  |     @JoinColumn(name="Users") | ||||||
|  |     private User user; | ||||||
|  |  | ||||||
|  |     @ManyToOne | ||||||
|  |     @JoinColumn(name = "ActualCurriculum") | ||||||
|  |     private Curriculum actualCurriculum; | ||||||
|  |  | ||||||
|  |     @ManyToOne | ||||||
|  |     @JoinColumn(name = "DestCurriculum") | ||||||
|  |     private Curriculum destinationCurriculum; | ||||||
|  |  | ||||||
|  |     private Date date; | ||||||
|  |  | ||||||
|  |     private RequestState state; | ||||||
|  |  | ||||||
|  |     private RequestState teacherApprovalState; | ||||||
|  |     public ChangeCurriculumRequest(){} | ||||||
|  |  | ||||||
|  |     public ChangeCurriculumRequest(User user, Curriculum actualCurriculum, Curriculum destinationCurriculum, Date date, RequestState state, RequestState teacherApprovalState){ | ||||||
|  |         this.user = user; | ||||||
|  |         this.actualCurriculum = actualCurriculum; | ||||||
|  |         this.destinationCurriculum = destinationCurriculum; | ||||||
|  |         this.date = date; | ||||||
|  |         this.state = state; | ||||||
|  |         this.teacherApprovalState = teacherApprovalState; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public User getUser() { | ||||||
|  |         return user; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public void setUser(User user) { | ||||||
|  |         this.user = user; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |  | ||||||
|  |     public Curriculum getActualCurriculum() { | ||||||
|  |         return actualCurriculum; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public void setActualCurriculum(Curriculum actualCurriculum) { | ||||||
|  |         this.actualCurriculum = actualCurriculum; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public Curriculum getDestinationCurriculum() { | ||||||
|  |         return destinationCurriculum; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public void setDestinationCurriculum(Curriculum destinationCurriculum) { | ||||||
|  |         this.destinationCurriculum = destinationCurriculum; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public void setDate(Date date) { | ||||||
|  |         this.date = date; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public Date getDate() { | ||||||
|  |         return date; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public RequestState getState() { | ||||||
|  |         return state; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public void setState(RequestState state) { | ||||||
|  |         this.state = state; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public int getId() { | ||||||
|  |         return id; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public RequestState getTeacherApprovalState() { | ||||||
|  |         return teacherApprovalState; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public void setTeacherApprovalState(RequestState teacherApprovalState) { | ||||||
|  |         this.teacherApprovalState = teacherApprovalState; | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
| @ -8,7 +8,7 @@ import org.hibernate.annotations.OnDeleteAction; | |||||||
| public class Course { | public class Course { | ||||||
|     @Id |     @Id | ||||||
|     @GeneratedValue(strategy = GenerationType.AUTO) |     @GeneratedValue(strategy = GenerationType.AUTO) | ||||||
|     private int courseID; |     private int courseId; | ||||||
|     private int credits; |     private int credits; | ||||||
|     private String title; |     private String title; | ||||||
|  |  | ||||||
| @ -26,8 +26,11 @@ public class Course { | |||||||
|     public Course() {} |     public Course() {} | ||||||
|  |  | ||||||
|     public int getCourseID() { |     public int getCourseID() { | ||||||
|         return courseID; |         return courseId; | ||||||
|     } |     } | ||||||
|  |     public void setCourseID(int courseId){ | ||||||
|  |       this.courseId = courseId; | ||||||
|  |   } | ||||||
|  |  | ||||||
|     public int getCredits() { |     public int getCredits() { | ||||||
|         return credits; |         return credits; | ||||||
|  | |||||||
| @ -12,9 +12,13 @@ public class Curriculum { | |||||||
|     private int curriculumId; |     private int curriculumId; | ||||||
|     private int year; |     private int year; | ||||||
|     private String option; |     private String option; | ||||||
|     public Curriculum(int year, String option){ |  | ||||||
|  |     //True if the curriculum need an entry exam | ||||||
|  |     private boolean requireCertificate; | ||||||
|  |     public Curriculum(int year, String option, boolean requireCertificate){ | ||||||
|         this.year = year; |         this.year = year; | ||||||
|         this.option = option; |         this.option = option; | ||||||
|  |         this.requireCertificate = requireCertificate; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public Curriculum() {} |     public Curriculum() {} | ||||||
| @ -39,4 +43,11 @@ public class Curriculum { | |||||||
|         this.option = option; |         this.option = option; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     public void setRequireCertificate(boolean requireCertificate) { | ||||||
|  |         this.requireCertificate = requireCertificate; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public boolean isRequireCertificate() { | ||||||
|  |         return requireCertificate; | ||||||
|  |     } | ||||||
| } | } | ||||||
|  | |||||||
| @ -1,8 +1,8 @@ | |||||||
| package ovh.herisson.Clyde.Tables; | package ovh.herisson.Clyde.Tables; | ||||||
|  |  | ||||||
| public enum FileType { | public enum FileType { | ||||||
|  |  | ||||||
|     ProfilePicture, |     ProfilePicture, | ||||||
|  |     EducationCertificate, | ||||||
|     EducationCertificate |     JustificationDocument, | ||||||
|  |     IdentityCard, | ||||||
| } | } | ||||||
|  | |||||||
| @ -0,0 +1,87 @@ | |||||||
|  | package ovh.herisson.Clyde.Tables.Inscription; | ||||||
|  |  | ||||||
|  |  | ||||||
|  | import jakarta.persistence.*; | ||||||
|  | import org.hibernate.annotations.OnDelete; | ||||||
|  | import org.hibernate.annotations.OnDeleteAction; | ||||||
|  | import ovh.herisson.Clyde.Tables.Course; | ||||||
|  | import ovh.herisson.Clyde.Tables.RequestState; | ||||||
|  | import ovh.herisson.Clyde.Tables.User; | ||||||
|  |  | ||||||
|  | import java.util.Date; | ||||||
|  |  | ||||||
|  | @Entity | ||||||
|  | public class ExemptionsRequest { | ||||||
|  |     @Id | ||||||
|  |     @GeneratedValue(strategy = GenerationType.AUTO) | ||||||
|  |     private int id; | ||||||
|  |  | ||||||
|  |     @JoinColumn(name = "Users") | ||||||
|  |     @ManyToOne(fetch = FetchType.EAGER) | ||||||
|  |     private User user; | ||||||
|  |  | ||||||
|  |     @JoinColumn(name = "Course") | ||||||
|  |     @ManyToOne(fetch = FetchType.EAGER) | ||||||
|  |     private Course course; | ||||||
|  |     private String justifDocument; | ||||||
|  |  | ||||||
|  |     private RequestState state; | ||||||
|  |  | ||||||
|  |     private Date date; | ||||||
|  |  | ||||||
|  |     public ExemptionsRequest(User user, Course course, String justifDocument, RequestState state, Date date){ | ||||||
|  |         this.user = user; | ||||||
|  |         this.course = course; | ||||||
|  |         this.justifDocument = justifDocument; | ||||||
|  |         this.state = state; | ||||||
|  |         this.date = date; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |  | ||||||
|  |     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; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public Date getDate() { | ||||||
|  |         return date; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public void setDate(Date date) { | ||||||
|  |         this.date = date; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public int getId() { | ||||||
|  |         return id; | ||||||
|  |     } | ||||||
|  | } | ||||||
| @ -0,0 +1,114 @@ | |||||||
|  | package ovh.herisson.Clyde.Tables.Inscription; | ||||||
|  |  | ||||||
|  |  | ||||||
|  | import jakarta.persistence.*; | ||||||
|  | import ovh.herisson.Clyde.Tables.User; | ||||||
|  |  | ||||||
|  | //This table stores a student's curriculum from another university | ||||||
|  | @Entity | ||||||
|  | public class ExternalCurriculum { | ||||||
|  |     @Id | ||||||
|  |     @GeneratedValue(strategy = GenerationType.AUTO) | ||||||
|  |     private int id; | ||||||
|  |  | ||||||
|  |     //An external curriculum is first linked to an inscription request and when it is accepted and the user is created we link it to the user | ||||||
|  |     @ManyToOne(fetch = FetchType.EAGER) | ||||||
|  |     @JoinColumn(name="InscriptionRequest") | ||||||
|  |     private InscriptionRequest inscriptionRequest; | ||||||
|  |  | ||||||
|  |     @ManyToOne(fetch = FetchType.EAGER) | ||||||
|  |     @JoinColumn(name="Users") | ||||||
|  |     private User user; | ||||||
|  |  | ||||||
|  |     private String school; | ||||||
|  |  | ||||||
|  |     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; | ||||||
|  |  | ||||||
|  |     public ExternalCurriculum(){} | ||||||
|  |  | ||||||
|  |     public ExternalCurriculum(InscriptionRequest ir, String school, String formation, String completion, int startYear, int endYear, String justifdocUrl,User user){ | ||||||
|  |         this.inscriptionRequest = ir; | ||||||
|  |         this.school = school; | ||||||
|  |         this.formation = formation; | ||||||
|  |         this.completion = completion; | ||||||
|  |         this.startYear = startYear; | ||||||
|  |         this.endYear = endYear; | ||||||
|  |         this.justifdocUrl = justifdocUrl; | ||||||
|  |         this.user = user; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public int getId() { | ||||||
|  |         return id; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public InscriptionRequest getInscriptionRequest() { | ||||||
|  |         return inscriptionRequest; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public void setInscriptionRequest(InscriptionRequest inscriptionRequest) { | ||||||
|  |         this.inscriptionRequest = inscriptionRequest; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public String getSchool() { | ||||||
|  |         return school; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public void setSchool(String school) { | ||||||
|  |         this.school = school; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     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 void setUser(User user) { | ||||||
|  |         this.user = user; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public User getUser() { | ||||||
|  |         return user; | ||||||
|  |     } | ||||||
|  | } | ||||||
| @ -1,6 +1,8 @@ | |||||||
| package ovh.herisson.Clyde.Tables; | package ovh.herisson.Clyde.Tables.Inscription; | ||||||
| 
 | 
 | ||||||
| import jakarta.persistence.*; | import jakarta.persistence.*; | ||||||
|  | import ovh.herisson.Clyde.Tables.RequestState; | ||||||
|  | 
 | ||||||
| import java.util.Date; | import java.util.Date; | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| @ -15,14 +17,17 @@ public class InscriptionRequest { | |||||||
|     private String email; |     private String email; | ||||||
|     private String country; |     private String country; | ||||||
|     private Date birthDate; |     private Date birthDate; | ||||||
| 
 |  | ||||||
|     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 String admissionDocUrl; | ||||||
|  |     private Date submissionDate; | ||||||
|  |     private RequestState equivalenceState; | ||||||
|     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, RequestState equivalenceState, String admissionDocUrl){ | ||||||
|         this.lastName = lastName; |         this.lastName = lastName; | ||||||
|         this.firstName = firstName; |         this.firstName = firstName; | ||||||
|         this.address = address; |         this.address = address; | ||||||
| @ -33,6 +38,10 @@ 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; | ||||||
|  |         this.equivalenceState = equivalenceState; | ||||||
|  |         this.admissionDocUrl = admissionDocUrl; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     public int getId() { |     public int getId() { | ||||||
| @ -118,4 +127,36 @@ 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; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public RequestState getEquivalenceState() { | ||||||
|  |         return equivalenceState; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public void setEquivalenceState(RequestState equivalenceState) { | ||||||
|  |         this.equivalenceState = equivalenceState; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public String getAdmissionDocUrl() { | ||||||
|  |         return admissionDocUrl; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public void setAdmissionDocUrl(String admissionDocUrl) { | ||||||
|  |         this.admissionDocUrl = admissionDocUrl; | ||||||
|  |     } | ||||||
| } | } | ||||||
| @ -0,0 +1,64 @@ | |||||||
|  | package ovh.herisson.Clyde.Tables.Inscription; | ||||||
|  |  | ||||||
|  | import jakarta.persistence.Entity; | ||||||
|  | import jakarta.persistence.GeneratedValue; | ||||||
|  | import jakarta.persistence.GenerationType; | ||||||
|  | import jakarta.persistence.Id; | ||||||
|  |  | ||||||
|  | @Entity | ||||||
|  | public class Minerval { | ||||||
|  |     @Id | ||||||
|  |     @GeneratedValue(strategy = GenerationType.AUTO) | ||||||
|  |     private long id; | ||||||
|  |  | ||||||
|  |     private long studentRegNo; | ||||||
|  |     private int paidAmount; | ||||||
|  |     private int toPay; | ||||||
|  |  | ||||||
|  |     //If the academic year is 2023-2024 then 2023 will be stored here (we take the lowest year) | ||||||
|  |     private int year; | ||||||
|  |     public Minerval(){} | ||||||
|  |  | ||||||
|  |     public Minerval(long studentRegNo, int paidAmount, int toPay, int year){ | ||||||
|  |         this.studentRegNo = studentRegNo; | ||||||
|  |         this.paidAmount = paidAmount; | ||||||
|  |         this.toPay = toPay; | ||||||
|  |         this.year = year; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public long getStudentRegNo() { | ||||||
|  |         return studentRegNo; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public void setStudentRegNo(long studentRegNo) { | ||||||
|  |         this.studentRegNo = studentRegNo; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public int getPaidAmount() { | ||||||
|  |         return paidAmount; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public void setPaidAmount(int paidAmount) { | ||||||
|  |         this.paidAmount = paidAmount; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public int getToPay() { | ||||||
|  |         return toPay; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public void setToPay(int toPay) { | ||||||
|  |         this.toPay = toPay; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public int getYear() { | ||||||
|  |         return year; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public void setYear(int year) { | ||||||
|  |         this.year = year; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public long getId() { | ||||||
|  |         return id; | ||||||
|  |     } | ||||||
|  | } | ||||||
| @ -0,0 +1,83 @@ | |||||||
|  | package ovh.herisson.Clyde.Tables.Inscription; | ||||||
|  |  | ||||||
|  | import jakarta.persistence.Entity; | ||||||
|  | import jakarta.persistence.GeneratedValue; | ||||||
|  | import jakarta.persistence.GenerationType; | ||||||
|  | import jakarta.persistence.Id; | ||||||
|  |  | ||||||
|  | import java.util.Date; | ||||||
|  |  | ||||||
|  | @Entity | ||||||
|  | public class Payment { | ||||||
|  |     @Id | ||||||
|  |     @GeneratedValue(strategy = GenerationType.AUTO) | ||||||
|  |     private long id; | ||||||
|  |     private long studentRegNo; | ||||||
|  |     private String card; | ||||||
|  |     private String client; | ||||||
|  |     private Date expDate; | ||||||
|  |     private int amount; | ||||||
|  |     private Date date; | ||||||
|  |     public Payment(){} | ||||||
|  |  | ||||||
|  |     public Payment(long studentRegNo, String card, String client, Date expDate, int amount, Date date){ | ||||||
|  |         this.studentRegNo = studentRegNo; | ||||||
|  |         this.card = card; | ||||||
|  |         this.client = client; | ||||||
|  |         this.expDate = expDate; | ||||||
|  |         this.amount = amount; | ||||||
|  |         this.date = date; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public long getStudentRegNo() { | ||||||
|  |         return studentRegNo; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public void setStudentRegNo(long studentRegNo) { | ||||||
|  |         this.studentRegNo = studentRegNo; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public String getCard() { | ||||||
|  |         return card; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public void setCard(String card) { | ||||||
|  |         this.card = card; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public String getClient() { | ||||||
|  |         return client; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public void setClient(String client) { | ||||||
|  |         this.client = client; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public Date getExpDate() { | ||||||
|  |         return expDate; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public void setExpDate(Date expDate) { | ||||||
|  |         this.expDate = expDate; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public int getAmount() { | ||||||
|  |         return amount; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public void setAmount(int amount) { | ||||||
|  |         this.amount = amount; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public long getId() { | ||||||
|  |         return id; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public Date getDate() { | ||||||
|  |         return date; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public void setDate(Date date) { | ||||||
|  |         this.date = date; | ||||||
|  |     } | ||||||
|  | } | ||||||
| @ -0,0 +1,89 @@ | |||||||
|  | package ovh.herisson.Clyde.Tables.Inscription; | ||||||
|  |  | ||||||
|  | import jakarta.persistence.*; | ||||||
|  | import org.hibernate.annotations.OnDelete; | ||||||
|  | import org.hibernate.annotations.OnDeleteAction; | ||||||
|  | import ovh.herisson.Clyde.Tables.RequestState; | ||||||
|  | import ovh.herisson.Clyde.Tables.User; | ||||||
|  |  | ||||||
|  | import java.util.Date; | ||||||
|  | import java.util.Map; | ||||||
|  |  | ||||||
|  | @Entity | ||||||
|  | public class ScholarshipRequest { | ||||||
|  |     @Id | ||||||
|  |     @GeneratedValue(strategy = GenerationType.AUTO) | ||||||
|  |     private long id; | ||||||
|  |     @JoinColumn(name="Users") | ||||||
|  |     @ManyToOne(fetch = FetchType.EAGER) | ||||||
|  |     @OnDelete(action = OnDeleteAction.CASCADE) | ||||||
|  |     private User user; | ||||||
|  |     private RequestState state; | ||||||
|  |     private Date date; | ||||||
|  |     private int amount; | ||||||
|  |     private String taxDocUrl; | ||||||
|  |     private String residencyDocUrl; | ||||||
|  |  | ||||||
|  |     public ScholarshipRequest(User user, RequestState state, int amount, Date date, String taxDocUrl, String residencyDocUrl){ | ||||||
|  |         this.user = user; | ||||||
|  |         this.state = state; | ||||||
|  |         this.amount = amount; | ||||||
|  |         this.date = date; | ||||||
|  |         this.taxDocUrl = taxDocUrl; | ||||||
|  |         this.residencyDocUrl = residencyDocUrl; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     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 int getAmount() { | ||||||
|  |         return amount; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public void setAmount(int amount) { | ||||||
|  |         this.amount = amount; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public Date getDate() { | ||||||
|  |         return date; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public void setDate(Date date) { | ||||||
|  |         this.date = date; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public long getId() { | ||||||
|  |         return id; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public String getResidencyDocUrl() { | ||||||
|  |         return residencyDocUrl; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public void setResidencyDocUrl(String residencyDocUrl) { | ||||||
|  |         this.residencyDocUrl = residencyDocUrl; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public String getTaxDocUrl() { | ||||||
|  |         return taxDocUrl; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public void setTaxDocUrl(String taxDocUrl) { | ||||||
|  |         this.taxDocUrl = taxDocUrl; | ||||||
|  |     } | ||||||
|  | } | ||||||
| @ -0,0 +1,115 @@ | |||||||
|  | package ovh.herisson.Clyde.Tables.Inscription; | ||||||
|  |  | ||||||
|  | import jakarta.persistence.*; | ||||||
|  | import ovh.herisson.Clyde.Tables.Curriculum; | ||||||
|  | import ovh.herisson.Clyde.Tables.RequestState; | ||||||
|  | import ovh.herisson.Clyde.Tables.User; | ||||||
|  |  | ||||||
|  | import java.util.Date; | ||||||
|  |  | ||||||
|  | @Entity | ||||||
|  | public class UnregisterRequest { | ||||||
|  |     @Id | ||||||
|  |     @GeneratedValue(strategy = GenerationType.AUTO) | ||||||
|  |     private long id; | ||||||
|  |     private RequestState state; | ||||||
|  |     private String reason; | ||||||
|  |     private Date date; | ||||||
|  |  | ||||||
|  |     //We store these informations again so if the user is deleted we still have the informations for history | ||||||
|  |     private long regNo; | ||||||
|  |  | ||||||
|  |     private String firstName; | ||||||
|  |  | ||||||
|  |     private String lastName; | ||||||
|  |  | ||||||
|  |     private String email; | ||||||
|  |  | ||||||
|  |     //Null if the user unregister for the academic year, contains a curriculum if the user wants to unregister from a specific curriculum | ||||||
|  |     @ManyToOne | ||||||
|  |     @JoinColumn(name = "Curriculum") | ||||||
|  |     private Curriculum curriculum; | ||||||
|  |  | ||||||
|  |     public UnregisterRequest(RequestState state, String reason, Date date, long regNo, String firstName, String lastName, String email, Curriculum curriculum){ | ||||||
|  |         this.state = state; | ||||||
|  |         this.reason = reason; | ||||||
|  |         this.date = date; | ||||||
|  |         this.regNo = regNo; | ||||||
|  |         this.firstName = firstName; | ||||||
|  |         this.lastName = lastName; | ||||||
|  |         this.email = email; | ||||||
|  |         this.curriculum = curriculum; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public UnregisterRequest(){} | ||||||
|  |  | ||||||
|  |     public RequestState getState() { | ||||||
|  |         return state; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public void setState(RequestState state) { | ||||||
|  |         this.state = state; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public String getReason() { | ||||||
|  |         return reason; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public void setReason(String reason) { | ||||||
|  |         this.reason = reason; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public long getId() { | ||||||
|  |         return id; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public void setDate(Date date) { | ||||||
|  |         this.date = date; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public Date getDate() { | ||||||
|  |         return date; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public String getEmail() { | ||||||
|  |         return email; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public String getLastName() { | ||||||
|  |         return lastName; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public String getFirstName() { | ||||||
|  |         return firstName; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public void setEmail(String email) { | ||||||
|  |         this.email = email; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public void setLastName(String lastName) { | ||||||
|  |         this.lastName = lastName; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public void setFirstName(String firstName) { | ||||||
|  |         this.firstName = firstName; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public void setRegNo(long regNo) { | ||||||
|  |         this.regNo = regNo; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public long getRegNo() { | ||||||
|  |         return regNo; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public void setCurriculum(Curriculum curriculum) { | ||||||
|  |         this.curriculum = curriculum; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public Curriculum getCurriculum() { | ||||||
|  |         return curriculum; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  | } | ||||||
|  |  | ||||||
							
								
								
									
										101
									
								
								backend/src/main/java/ovh/herisson/Clyde/Tables/Lesson.java
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										101
									
								
								backend/src/main/java/ovh/herisson/Clyde/Tables/Lesson.java
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,101 @@ | |||||||
|  | package ovh.herisson.Clyde.Tables; | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /****************************************************** | ||||||
|  |  * @file Lesson.java | ||||||
|  |  * @author William Karpinski | ||||||
|  |  * @scope Extension Horaire | ||||||
|  |  * | ||||||
|  |  * Represent a course in a schedule | ||||||
|  |  ******************************************************/ | ||||||
|  |  | ||||||
|  | import jakarta.persistence.*; | ||||||
|  | import org.hibernate.annotations.OnDelete; | ||||||
|  | import org.hibernate.annotations.OnDeleteAction; | ||||||
|  |  | ||||||
|  |  | ||||||
|  | @Entity | ||||||
|  | public class Lesson { | ||||||
|  |   @Id | ||||||
|  |   @GeneratedValue(strategy = GenerationType.AUTO) | ||||||
|  |   private int lessonID; | ||||||
|  |  | ||||||
|  |   @ManyToOne(fetch = FetchType.EAGER) | ||||||
|  |   @OnDelete(action = OnDeleteAction.SET_NULL) | ||||||
|  |   @JoinColumn(name = "Course") | ||||||
|  |   private Course course; | ||||||
|  |  | ||||||
|  |   private String lessonStart; | ||||||
|  |  | ||||||
|  |   private String lessonEnd; | ||||||
|  |    | ||||||
|  |   private String color; | ||||||
|  |    | ||||||
|  |   private String lessonType; | ||||||
|  |  | ||||||
|  |   private String local; | ||||||
|  |  | ||||||
|  |   public Lesson(Course course,String start, String end ,String color,String local,String lessonType){ | ||||||
|  |     this.lessonEnd = end; | ||||||
|  |     this.course = course; | ||||||
|  |     this.lessonStart = start; | ||||||
|  |     this.color = color; | ||||||
|  |     this.local = local; | ||||||
|  |     this.lessonType = lessonType; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   public Lesson() { | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   public int getLessonID(){ | ||||||
|  |     return lessonID; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   public void setCourse(Course course) { | ||||||
|  |     this.course = course; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   public Course getCourse(){ | ||||||
|  |     return course; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   public String getLessonStart(){ | ||||||
|  |     return lessonStart; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   public String getLessonEnd() { | ||||||
|  |     return lessonEnd; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   public String getColor(){ | ||||||
|  |     return color; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   public String getLocal() { | ||||||
|  |     return local; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   public String getLessonType(){ | ||||||
|  |     return lessonType; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   public void setLessonStart(String start){ | ||||||
|  |     this.lessonStart = start; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   public void setLessonEnd(String lessonEnd) { | ||||||
|  |     this.lessonEnd = lessonEnd; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   public void setColor(String color){ | ||||||
|  |     this.color = color; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   public void setLocal(String local){ | ||||||
|  |     this.local = local; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   public void setLessonType(String lessonType){ | ||||||
|  |     this.lessonType = lessonType; | ||||||
|  |   } | ||||||
|  | } | ||||||
| @ -0,0 +1,148 @@ | |||||||
|  | package ovh.herisson.Clyde.Tables; | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /****************************************************** | ||||||
|  |  * @file LessonChangesRequest.java | ||||||
|  |  * @author William Karpinski | ||||||
|  |  * @scope Extension Horaire | ||||||
|  |  * | ||||||
|  |  * Represent a request about changes on schedules and lessons | ||||||
|  |  ******************************************************/ | ||||||
|  |  | ||||||
|  | import jakarta.persistence.*; | ||||||
|  | import org.hibernate.annotations.OnDelete; | ||||||
|  | import org.hibernate.annotations.OnDeleteAction; | ||||||
|  |  | ||||||
|  | @Entity | ||||||
|  | public class LessonChangesRequest { | ||||||
|  |  | ||||||
|  |     @Id | ||||||
|  |     @GeneratedValue(strategy = GenerationType.AUTO) | ||||||
|  |     private int id; | ||||||
|  |  | ||||||
|  |     @ManyToOne | ||||||
|  |     @JoinColumn(name = "Users") | ||||||
|  |     @OnDelete(action = OnDeleteAction.CASCADE) | ||||||
|  |     private User user; | ||||||
|  |  | ||||||
|  |     private long lessonId; | ||||||
|  |  | ||||||
|  |     private RequestState state; | ||||||
|  |  | ||||||
|  |     private String lessonStart; | ||||||
|  |  | ||||||
|  |     private String lessonEnd; | ||||||
|  |  | ||||||
|  |     private String color; | ||||||
|  |     @ManyToOne | ||||||
|  |     @JoinColumn(name ="Course") | ||||||
|  |     private Course course; | ||||||
|  |  | ||||||
|  |     private String lessonType; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Can take 3 values: | ||||||
|  |      * 0 : Request to CREATE a lesson | ||||||
|  |      * 1 : Request to MODIFY an existing lesson | ||||||
|  |      * 2 : Request to DELETE a lesson | ||||||
|  |      */ | ||||||
|  |     private int requestType; | ||||||
|  |  | ||||||
|  |     public LessonChangesRequest(User user, RequestState state, String lessonStart, | ||||||
|  |                                 String lessonEnd, String lessonType, Course course, | ||||||
|  |                                 int requestType, String color,long lessonId){ | ||||||
|  |         this.user = user; | ||||||
|  |         this.state = state; | ||||||
|  |         this.requestType = requestType; | ||||||
|  |         this.lessonType = lessonType; | ||||||
|  |         this.lessonStart = lessonStart; | ||||||
|  |         this.lessonEnd= lessonEnd; | ||||||
|  |         this.color = color; | ||||||
|  |         this.course = course; | ||||||
|  |         this.lessonId = lessonId; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public LessonChangesRequest() { | ||||||
|  |  | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public int getId() { | ||||||
|  |         return id; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |  | ||||||
|  |     public RequestState getState() { | ||||||
|  |         return state; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public User getUser() { | ||||||
|  |         return user; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public long getLessonId(){ | ||||||
|  |         return lessonId; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public String getLessonStart() { | ||||||
|  |         return lessonStart; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public String getLessonEnd() { | ||||||
|  |         return lessonEnd; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |     public int getRequestType() { | ||||||
|  |         return requestType; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public String getLessonType() { | ||||||
|  |         return lessonType; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public String getColor() { | ||||||
|  |         return color; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public Course getCourse() { | ||||||
|  |         return course; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public void setState(RequestState state) { | ||||||
|  |         this.state = state; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public void setUser(User user) { | ||||||
|  |         this.user = user; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public void setLessonStart(String lessonStart) { | ||||||
|  |         this.lessonStart = lessonStart; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public void setLessonType(String lessonType) { | ||||||
|  |         this.lessonType = lessonType; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public void setLessonEnd(String lessonEnd) { | ||||||
|  |         this.lessonEnd = lessonEnd; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public void setColor(String color) { | ||||||
|  |         this.color = color; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public void setRequestType(int requestType) { | ||||||
|  |         this.requestType = requestType; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |  | ||||||
|  |     public void setLessonId(long lessonId) { | ||||||
|  |         this.lessonId = lessonId; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public void setCourse(Course course){ | ||||||
|  |         this.course = course; | ||||||
|  |     } | ||||||
|  | } | ||||||
| @ -0,0 +1,72 @@ | |||||||
|  | package ovh.herisson.Clyde.Tables.Msg; | ||||||
|  |  | ||||||
|  | /****************************************************** | ||||||
|  |  * @file Discussion.java | ||||||
|  |  * @author Anthony Debucquoy | ||||||
|  |  * @scope Extension messagerie | ||||||
|  |  * | ||||||
|  |  * Discussion allow to regroupe multiple user in and message together | ||||||
|  |  * for the messages application to work | ||||||
|  |  ******************************************************/ | ||||||
|  |  | ||||||
|  |  | ||||||
|  | import java.util.List; | ||||||
|  |  | ||||||
|  | import jakarta.persistence.CascadeType; | ||||||
|  | import jakarta.persistence.Entity; | ||||||
|  | import jakarta.persistence.GeneratedValue; | ||||||
|  | import jakarta.persistence.GenerationType; | ||||||
|  | import jakarta.persistence.Id; | ||||||
|  | import jakarta.persistence.JoinColumn; | ||||||
|  | import jakarta.persistence.JoinTable; | ||||||
|  | import jakarta.persistence.ManyToMany; | ||||||
|  | import jakarta.persistence.OneToMany; | ||||||
|  | import lombok.Getter; | ||||||
|  | import lombok.NoArgsConstructor; | ||||||
|  | import lombok.Setter; | ||||||
|  | import ovh.herisson.Clyde.Tables.User; | ||||||
|  |  | ||||||
|  | @Entity | ||||||
|  | @Getter | ||||||
|  | @Setter | ||||||
|  | @NoArgsConstructor | ||||||
|  | public class Discussion{ | ||||||
|  |  | ||||||
|  | 	@Id | ||||||
|  |     @GeneratedValue(strategy = GenerationType.AUTO) | ||||||
|  | 	private long id; | ||||||
|  | 	private String name; | ||||||
|  |  | ||||||
|  |     @ManyToMany | ||||||
|  | 	@JoinTable( | ||||||
|  | 		name = "discussion_members", | ||||||
|  | 		joinColumns = @JoinColumn(name = "discussion_id"), | ||||||
|  | 		inverseJoinColumns = @JoinColumn(name = "user_id") | ||||||
|  | 	) | ||||||
|  | 	private List<User> members; | ||||||
|  |  | ||||||
|  | 	@OneToMany(mappedBy="discussion", orphanRemoval = true, cascade = CascadeType.ALL) | ||||||
|  | 	private List<Message> msgs; | ||||||
|  |  | ||||||
|  | 	public Discussion(String name){ | ||||||
|  | 		this.name = name; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	public Discussion(String name, User user){ | ||||||
|  | 		this.name = name; | ||||||
|  | 		this.members = List.of(user); | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	public void addMessage(Message msg){ | ||||||
|  | 		msg.setDiscussion(this); | ||||||
|  | 		msgs.add(msg); | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  |     public void addMember(User user) { | ||||||
|  | 		members.add(user); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public void delMember(User user) { | ||||||
|  | 		members.remove(user); | ||||||
|  |     } | ||||||
|  | } | ||||||
| @ -0,0 +1,66 @@ | |||||||
|  | package ovh.herisson.Clyde.Tables.Msg; | ||||||
|  |  | ||||||
|  | /****************************************************** | ||||||
|  |  * @file Message.java | ||||||
|  |  * @author Anthony Debucquoy | ||||||
|  |  * @scope Extension messagerie | ||||||
|  |  * | ||||||
|  |  * Represent a message sent to a discussion | ||||||
|  |  ******************************************************/ | ||||||
|  |  | ||||||
|  |  | ||||||
|  | import org.hibernate.annotations.CreationTimestamp; | ||||||
|  | import org.hibernate.annotations.UpdateTimestamp; | ||||||
|  |  | ||||||
|  | import com.fasterxml.jackson.annotation.JsonIgnore; | ||||||
|  | import java.util.Date; | ||||||
|  |  | ||||||
|  | import jakarta.persistence.CascadeType; | ||||||
|  | import jakarta.persistence.Column; | ||||||
|  | import jakarta.persistence.Entity; | ||||||
|  | import jakarta.persistence.GeneratedValue; | ||||||
|  | import jakarta.persistence.GenerationType; | ||||||
|  | import jakarta.persistence.Id; | ||||||
|  | import jakarta.persistence.ManyToOne; | ||||||
|  | import jakarta.persistence.OneToMany; | ||||||
|  | import jakarta.persistence.OneToOne; | ||||||
|  | import jakarta.persistence.PrePersist; | ||||||
|  | import jakarta.persistence.Temporal; | ||||||
|  | import jakarta.persistence.TemporalType; | ||||||
|  | import lombok.AllArgsConstructor; | ||||||
|  | import lombok.Getter; | ||||||
|  | import lombok.NoArgsConstructor; | ||||||
|  | import lombok.Setter; | ||||||
|  | import ovh.herisson.Clyde.Tables.User; | ||||||
|  |  | ||||||
|  | @Getter | ||||||
|  | @Setter | ||||||
|  | @NoArgsConstructor | ||||||
|  | @AllArgsConstructor | ||||||
|  | @Entity | ||||||
|  | public class Message { | ||||||
|  | 	 | ||||||
|  | 	@Id | ||||||
|  | 	@GeneratedValue(strategy = GenerationType.AUTO) | ||||||
|  | 	private long id; | ||||||
|  | 	private String content;  | ||||||
|  |  | ||||||
|  | 	@CreationTimestamp | ||||||
|  | 	@Column(nullable = false) | ||||||
|  | 	private Date created; | ||||||
|  |  | ||||||
|  | 	@ManyToOne | ||||||
|  | 	private User author; | ||||||
|  |  | ||||||
|  | 	public User getAuthor() { | ||||||
|  |         return author; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @OneToOne | ||||||
|  | 	private Message response; | ||||||
|  |  | ||||||
|  | 	@ManyToOne(optional = false) | ||||||
|  | 	@JsonIgnore | ||||||
|  | 	private Discussion discussion; | ||||||
|  | 	 | ||||||
|  | } | ||||||
| @ -1,78 +0,0 @@ | |||||||
| package ovh.herisson.Clyde.Tables; |  | ||||||
|  |  | ||||||
| import jakarta.persistence.*; |  | ||||||
| import org.hibernate.annotations.OnDelete; |  | ||||||
| import org.hibernate.annotations.OnDeleteAction; |  | ||||||
|  |  | ||||||
| @Entity |  | ||||||
| public class ReInscriptionRequest { |  | ||||||
|     @Id |  | ||||||
|     @GeneratedValue(strategy = GenerationType.AUTO) |  | ||||||
|     private int id; |  | ||||||
|  |  | ||||||
|     @ManyToOne |  | ||||||
|     @JoinColumn(name = "Users") |  | ||||||
|     @OnDelete(action = OnDeleteAction.CASCADE) |  | ||||||
|     private User user; |  | ||||||
|  |  | ||||||
|     @ManyToOne |  | ||||||
|     @JoinColumn(name = "Curriculum") |  | ||||||
|     @OnDelete(action = OnDeleteAction.CASCADE) |  | ||||||
|     private Curriculum newCurriculum; |  | ||||||
|     private RequestState state; |  | ||||||
|  |  | ||||||
|     //Permet de différencier les demandes de changement et une réinscription dans le même Curriculum |  | ||||||
|     //Pour la réinscription on va le mettre a 0 |  | ||||||
|     private boolean type = false; |  | ||||||
|  |  | ||||||
|     public ReInscriptionRequest(){} |  | ||||||
|  |  | ||||||
|     public ReInscriptionRequest(User user, Curriculum newCurriculum, RequestState state, boolean type){ |  | ||||||
|         this.user = user; |  | ||||||
|         this.newCurriculum = newCurriculum; |  | ||||||
|         this.state = state; |  | ||||||
|         this.type = type; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     public ReInscriptionRequest(User user, Curriculum newCurriculum, RequestState state){ |  | ||||||
|         this.user = user; |  | ||||||
|         this.newCurriculum = newCurriculum; |  | ||||||
|         this.state = state; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     public int getId() { |  | ||||||
|         return id; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     public User getUser() { |  | ||||||
|         return user; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     public void setUser(User user) { |  | ||||||
|         this.user = user; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     public Curriculum getNewCurriculum() { |  | ||||||
|         return newCurriculum; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     public void setNewCurriculum(Curriculum newCurriculum) { |  | ||||||
|         this.newCurriculum = newCurriculum; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     public RequestState getState() { |  | ||||||
|         return state; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     public void setState(RequestState state) { |  | ||||||
|         this.state = state; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     public boolean isType() { |  | ||||||
|         return type; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     public void setType(boolean type) { |  | ||||||
|         this.type = type; |  | ||||||
|     } |  | ||||||
| } |  | ||||||
| @ -0,0 +1,46 @@ | |||||||
|  | package ovh.herisson.Clyde.Tables; | ||||||
|  |  | ||||||
|  | import org.hibernate.engine.jdbc.connections.spi.JdbcConnectionAccess; | ||||||
|  | import org.hibernate.engine.spi.SharedSessionContractImplementor; | ||||||
|  | import org.hibernate.id.IdentifierGenerator; | ||||||
|  |  | ||||||
|  | import java.sql.*; | ||||||
|  | import java.util.Calendar; | ||||||
|  | import java.util.Date; | ||||||
|  | import java.util.GregorianCalendar; | ||||||
|  |  | ||||||
|  | public class RegNoGenerator implements IdentifierGenerator { | ||||||
|  |     private static int count = 0; | ||||||
|  |     @Override | ||||||
|  |     public Object generate(SharedSessionContractImplementor session, Object object) { | ||||||
|  |         try{ | ||||||
|  |             JdbcConnectionAccess jdbccon = session.getJdbcConnectionAccess(); | ||||||
|  |             Connection conn = jdbccon.obtainConnection(); | ||||||
|  |  | ||||||
|  |             Statement statement = conn.createStatement(); | ||||||
|  |  | ||||||
|  |             Calendar c = new GregorianCalendar(); | ||||||
|  |             int y = c.get(Calendar.YEAR); | ||||||
|  |             String query = "select count(reg_no) + "+count+" from Users where reg_no/10000 = " + y%1000; | ||||||
|  |  | ||||||
|  |             ResultSet set = statement.executeQuery(query); | ||||||
|  |             long resp = 0; | ||||||
|  |             if(set.next()){ | ||||||
|  |                 resp = set.getLong(1)+((y%1000)*10000); | ||||||
|  |                 count += 1; | ||||||
|  |             } | ||||||
|  |  | ||||||
|  |             conn.close(); | ||||||
|  |             statement.close(); | ||||||
|  |  | ||||||
|  |             return resp; | ||||||
|  |  | ||||||
|  |         } catch (SQLException e) { | ||||||
|  |             throw new RuntimeException(e); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public static void resetCount(){ | ||||||
|  |         count = 0; | ||||||
|  |     } | ||||||
|  | } | ||||||
| @ -3,5 +3,6 @@ package ovh.herisson.Clyde.Tables; | |||||||
| public enum RequestState { | public enum RequestState { | ||||||
|     Accepted, |     Accepted, | ||||||
|     Refused, |     Refused, | ||||||
|     Pending |     Pending, | ||||||
|  |     Unrequired | ||||||
| } | } | ||||||
|  | |||||||
| @ -0,0 +1,42 @@ | |||||||
|  |  | ||||||
|  | package ovh.herisson.Clyde.Tables; | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /****************************************************** | ||||||
|  |  * @file Schedule.java | ||||||
|  |  * @author William Karpinski | ||||||
|  |  * @scope Extension Horaire | ||||||
|  |  * | ||||||
|  |  * Represent a schedule linked to a curriculum | ||||||
|  |  ******************************************************/ | ||||||
|  | import jakarta.persistence.*; | ||||||
|  | import org.hibernate.annotations.OnDelete; | ||||||
|  | import org.hibernate.annotations.OnDeleteAction; | ||||||
|  |  | ||||||
|  | @Entity | ||||||
|  | public class Schedule { | ||||||
|  |   @Id | ||||||
|  |   @GeneratedValue(strategy = GenerationType.AUTO) | ||||||
|  |   private int scheduleID; | ||||||
|  |  | ||||||
|  |   @OneToOne | ||||||
|  |   @JoinColumn(name = "Curriculum") | ||||||
|  |   @OnDelete(action = OnDeleteAction.SET_NULL) | ||||||
|  |   private Curriculum curriculum; | ||||||
|  |  | ||||||
|  |   public Schedule(Curriculum curriculum){ | ||||||
|  |     this.curriculum = curriculum; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   public Schedule() {} | ||||||
|  |  | ||||||
|  |  | ||||||
|  |   public int getScheduleID(){ | ||||||
|  |   return scheduleID; | ||||||
|  | } | ||||||
|  |  | ||||||
|  |   public Curriculum getCurriculum(){ | ||||||
|  |   return curriculum; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | } | ||||||
| @ -0,0 +1,63 @@ | |||||||
|  | package ovh.herisson.Clyde.Tables; | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /****************************************************** | ||||||
|  |  * @file ScheduleLesson.java | ||||||
|  |  * @author William Karpinski | ||||||
|  |  * @scope Extension Horaire | ||||||
|  |  * | ||||||
|  |  * Used to link schedules and lessons to each others | ||||||
|  |  ******************************************************/ | ||||||
|  |  | ||||||
|  | import jakarta.persistence.*; | ||||||
|  | import org.hibernate.annotations.OnDelete; | ||||||
|  | import org.hibernate.annotations.OnDeleteAction; | ||||||
|  |  | ||||||
|  |  | ||||||
|  | @Entity | ||||||
|  | public class ScheduleLesson{ | ||||||
|  |   @Id | ||||||
|  |   @GeneratedValue(strategy = GenerationType.AUTO) | ||||||
|  |   private int id; | ||||||
|  |    | ||||||
|  |   @ManyToOne(fetch = FetchType.EAGER) | ||||||
|  |   @JoinColumn(name = "Schedule") | ||||||
|  |   @OnDelete(action = OnDeleteAction.SET_NULL) | ||||||
|  |   private Schedule schedule; | ||||||
|  |  | ||||||
|  |  | ||||||
|  |   @ManyToOne(fetch = FetchType.EAGER) | ||||||
|  |   @OnDelete(action = OnDeleteAction.SET_NULL) | ||||||
|  |   @JoinColumn(name = "Lesson") | ||||||
|  |   private Lesson lesson; | ||||||
|  |  | ||||||
|  |   public ScheduleLesson(Schedule schedule,Lesson lesson){ | ||||||
|  |     this.schedule = schedule; | ||||||
|  |     this.lesson = lesson; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   public ScheduleLesson() { | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   public int getID(){ | ||||||
|  |     return id; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   public Lesson getLesson(){ | ||||||
|  |     return lesson; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   public Schedule getSchedule(){ | ||||||
|  |     return schedule; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   public void setLesson(Lesson lesson){ | ||||||
|  |     this.lesson = lesson; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   public void setSchedule(Schedule schedule){ | ||||||
|  |     this.schedule = schedule; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |  | ||||||
|  | }  | ||||||
| @ -1,14 +1,22 @@ | |||||||
| package ovh.herisson.Clyde.Tables; | package ovh.herisson.Clyde.Tables; | ||||||
|  |  | ||||||
|  | import com.fasterxml.jackson.annotation.JsonIgnore; | ||||||
| import jakarta.persistence.*; | import jakarta.persistence.*; | ||||||
| import java.util.Date; | import org.hibernate.annotations.OnDelete; | ||||||
|  | import org.hibernate.annotations.OnDeleteAction; | ||||||
|  | import org.hibernate.annotations.GenericGenerator; | ||||||
|  | import ovh.herisson.Clyde.Tables.Msg.Discussion; | ||||||
|  | import ovh.herisson.Clyde.Tables.Msg.Message; | ||||||
|  |  | ||||||
|  | import java.util.Date; | ||||||
|  | import java.util.List; | ||||||
|  |  | ||||||
| @Entity | @Entity | ||||||
| @Table(name = "Users") | @Table(name = "Users") | ||||||
| public class User { | public class User { | ||||||
|     @Id |     @Id | ||||||
|     @GeneratedValue(strategy = GenerationType.AUTO) |     @GenericGenerator(name = "userGen", type = ovh.herisson.Clyde.Tables.RegNoGenerator.class) | ||||||
|  |     @GeneratedValue(generator = "userGen") | ||||||
|     private Long regNo; |     private Long regNo; | ||||||
|     private String lastName; |     private String lastName; | ||||||
|     private String firstName; |     private String firstName; | ||||||
| @ -18,8 +26,19 @@ public class User { | |||||||
|     private String country; |     private String country; | ||||||
|     private Date birthDate; |     private Date birthDate; | ||||||
|     private String profilePictureUrl; |     private String profilePictureUrl; | ||||||
|     private ovh.herisson.Clyde.Tables.Role role; |     private Role role; | ||||||
|  |  | ||||||
|  | 	@JsonIgnore | ||||||
|     private String password; |     private String password; | ||||||
|  |  | ||||||
|  | 	////// Extension Messagerie ///// | ||||||
|  | 	@OneToMany(mappedBy = "author", cascade = CascadeType.ALL) | ||||||
|  | 	private List<Message> msgs; | ||||||
|  | 	///////////////////////////////// | ||||||
|  |  | ||||||
|  | 	@ManyToMany( mappedBy = "members" ) | ||||||
|  | 	private List<Discussion> discussions; | ||||||
|  |  | ||||||
|     public User(String lastName, String firstName, String email, String address, |     public User(String lastName, String firstName, String email, String address, | ||||||
|                 String country, Date birthDate, String profilePictureUrl, Role role, String password) |                 String country, Date birthDate, String profilePictureUrl, Role role, String password) | ||||||
|     { |     { | ||||||
|  | |||||||
| @ -21,9 +21,16 @@ 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; | ||||||
|  |  | ||||||
|  |     //True if the user has that curriculum at the moment false if not | ||||||
|  |     private boolean actual; | ||||||
|  |  | ||||||
|  |     public UserCurriculum(User user, Curriculum curriculum, int year, boolean actual){ | ||||||
|         this.user = user; |         this.user = user; | ||||||
|         this.curriculum = curriculum; |         this.curriculum = curriculum; | ||||||
|  |         this.year = year; | ||||||
|  |         this.actual = actual; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public UserCurriculum() {} |     public UserCurriculum() {} | ||||||
| @ -47,4 +54,20 @@ 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; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public void setActual(boolean actual) { | ||||||
|  |         this.actual = actual; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public boolean isActual() { | ||||||
|  |         return actual; | ||||||
|  |     } | ||||||
| } | } | ||||||
|  | |||||||
| @ -1,3 +1,12 @@ | |||||||
| spring.jpa.hibernate.ddl-auto=create-drop | spring.jpa.hibernate.ddl-auto=create-drop | ||||||
| spring.jpa.database-platform=org.hibernate.dialect.PostgreSQLDialect | spring.jpa.database-platform=org.hibernate.dialect.PostgreSQLDialect | ||||||
| spring.sql.init.mode=always | spring.sql.init.mode=always | ||||||
|  |  | ||||||
|  | # spring.datasource.url=jdbc:postgresql://localhost:5442/clyde | ||||||
|  | spring.datasource.url=jdbc:postgresql://db:5432/clyde | ||||||
|  | spring.datasource.username=devel | ||||||
|  | spring.datasource.password=devel | ||||||
|  |  | ||||||
|  | # spring.config.activate.on-profile=prod | ||||||
|  | # spring.datasource.url=jdbc:postgresql:clyde?socketFactory=org.newsclub.net.unix.AFUNIXSocketFactory$FactoryArg&socketFactoryArg=/var/run/postgresql/.s.PGSQL.5432 | ||||||
|  | # spring.datasource.username=clyde | ||||||
|  | |||||||
| @ -24,6 +24,7 @@ public class UserRepoTest { | |||||||
|  |  | ||||||
|     @BeforeEach |     @BeforeEach | ||||||
|     public void setup(){ |     public void setup(){ | ||||||
|  |         userRepo.deleteAll(); | ||||||
|         User herobrine = new User("brine","hero","admin@admin.com","in your WalLs","ShadowsLand", new GregorianCalendar(2005, 4, 3).getTime(), null, Role.Admin,"admin"); |         User herobrine = new User("brine","hero","admin@admin.com","in your WalLs","ShadowsLand", new GregorianCalendar(2005, 4, 3).getTime(), null, Role.Admin,"admin"); | ||||||
|         userRepo.save(herobrine); |         userRepo.save(herobrine); | ||||||
|     } |     } | ||||||
| @ -34,8 +35,8 @@ public class UserRepoTest { | |||||||
|     } |     } | ||||||
|     @Test |     @Test | ||||||
|     public void usertest(){ |     public void usertest(){ | ||||||
|         Assert.assertEquals("brine", userRepo.findById(1).getLastName()); |         Assert.assertEquals("brine", userRepo.findByEmail("admin@admin.com").getLastName()); | ||||||
|         Assert.assertTrue(new GregorianCalendar(2005, 4, 3).getTime().equals(userRepo.findById(1).getBirthDate())); |         Assert.assertTrue(new GregorianCalendar(2005, 4, 3).getTime().equals(userRepo.findByEmail("admin@admin.com").getBirthDate())); | ||||||
|     } |     } | ||||||
|  |  | ||||||
| } | } | ||||||
|  | |||||||
							
								
								
									
										29
									
								
								compose.yaml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										29
									
								
								compose.yaml
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,29 @@ | |||||||
|  | services:  | ||||||
|  |   db: | ||||||
|  |     image: 'postgres:16' | ||||||
|  |     environment: | ||||||
|  |       - 'POSTGRES_DB=clyde' | ||||||
|  |       - 'POSTGRES_USER=devel' | ||||||
|  |       - 'POSTGRES_PASSWORD=devel' | ||||||
|  |     # Uncomment this to allow connections to the db from outside the container | ||||||
|  |     # ports:  | ||||||
|  |     #   - '5442:5432' | ||||||
|  |   back: | ||||||
|  |     build: backend/. | ||||||
|  |     ports: | ||||||
|  |       - "8080:8080" | ||||||
|  |     volumes: | ||||||
|  |       - cdn:/backend/cdn | ||||||
|  |     ulimits: | ||||||
|  |       nofile: | ||||||
|  |         soft: 65536 | ||||||
|  |         hard: 65536 | ||||||
|  |   front: | ||||||
|  |     build: frontend/. | ||||||
|  |     volumes: | ||||||
|  |       - cdn:/app/front/dist/cdn | ||||||
|  |     ports: | ||||||
|  |       - "8000:8080" | ||||||
|  |  | ||||||
|  | volumes: | ||||||
|  |   cdn: | ||||||
							
								
								
									
										11
									
								
								frontend/Dockerfile
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										11
									
								
								frontend/Dockerfile
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,11 @@ | |||||||
|  | # https://v2.vuejs.org/v2/cookbook/dockerize-vuejs-app | ||||||
|  | FROM node:lts-alpine | ||||||
|  | RUN npm install -g http-server | ||||||
|  | WORKDIR /app/front | ||||||
|  | COPY package*.json ./ | ||||||
|  | RUN npm install | ||||||
|  | COPY . . | ||||||
|  | ENV VITE_CLYDE_MODE=container | ||||||
|  | RUN npm run build | ||||||
|  | EXPOSE 8080 | ||||||
|  | CMD [ "http-server", "dist" ] | ||||||
| @ -22,12 +22,16 @@ app.settings=Settings | |||||||
| app.messages=Messages | app.messages=Messages | ||||||
| app.forum=Forum | app.forum=Forum | ||||||
| app.schedules=Schedules | app.schedules=Schedules | ||||||
|  | app.manageSchedules=Manage Schedules | ||||||
| app.inscription.requests=Inscription Requests | app.inscription.requests=Inscription Requests | ||||||
| app.manage.courses=Manage Courses | app.manage.courses=Manage Courses | ||||||
| app.language=Language | app.language=Language | ||||||
| app.manage.profile=Manage profile | app.manage.profile=Manage profile | ||||||
| app.studentList=Students List | app.studentList=Students List | ||||||
| app.users=Users | app.users=Users | ||||||
|  | app.manageOwnLessons=Manage Owned Courses Schedule | ||||||
|  | app.lessonRequests=Schedule Requests | ||||||
|  | app.payments = Payments | ||||||
| request.moreInfos=More Infos | request.moreInfos=More Infos | ||||||
| request.accept=Accept | request.accept=Accept | ||||||
| request.refuse=Refuse | request.refuse=Refuse | ||||||
|  | |||||||
| @ -22,12 +22,16 @@ app.settings=Options | |||||||
| app.messages=Messages | app.messages=Messages | ||||||
| app.forum=Forum | app.forum=Forum | ||||||
| app.schedules=Horaires | app.schedules=Horaires | ||||||
|  | app.manageSchedules=Gérer les horaires | ||||||
| app.inscription.requests=Demandes d'Inscription | app.inscription.requests=Demandes d'Inscription | ||||||
| app.manage.courses=Gérer les cours | app.manage.courses=Gérer les cours | ||||||
| app.language=Langue | app.language=Langue | ||||||
| app.manage.profile=Gérer le profil | app.manage.profile=Gérer le profil | ||||||
| app.studentList=Liste des étudiants | app.studentList=Liste des étudiants | ||||||
| app.users=Utilisateurs | app.users=Utilisateurs | ||||||
|  | app.manageOwnLessons=Gérer ses horaires de cours | ||||||
|  | app.lessonRequests=Requêtes d'horaire | ||||||
|  | app.payments = Payements | ||||||
| request.moreInfos=Plus d'Infos | request.moreInfos=Plus d'Infos | ||||||
| request.accept=Accepter | request.accept=Accepter | ||||||
| request.refuse=Refuser | request.refuse=Refuser | ||||||
| @ -52,3 +56,4 @@ Curriculum=Cursus | |||||||
| Credits=Credits | Credits=Credits | ||||||
| InscriptionService=S.I. | InscriptionService=S.I. | ||||||
| faculty=Faculté | faculty=Faculté | ||||||
|  |  | ||||||
|  | |||||||
| @ -25,7 +25,6 @@ window.addEventListener('hashchange', () => { | |||||||
|   const login=ref(i18n("app.login")) |   const login=ref(i18n("app.login")) | ||||||
|   const active=ref(false) |   const active=ref(false) | ||||||
|  |  | ||||||
|  |  | ||||||
| 	const apps = ref([]) | 	const apps = ref([]) | ||||||
| 	appList().then(e => apps.value = e) | 	appList().then(e => apps.value = e) | ||||||
|  |  | ||||||
| @ -33,7 +32,6 @@ window.addEventListener('hashchange', () => { | |||||||
|  |  | ||||||
| <template> | <template> | ||||||
|   <div class="container"> |   <div class="container"> | ||||||
|  |  | ||||||
|     <div class="topBar"> |     <div class="topBar"> | ||||||
|       <ul class="horizontal"> |       <ul class="horizontal"> | ||||||
|         <li title=home> |         <li title=home> | ||||||
| @ -69,7 +67,6 @@ window.addEventListener('hashchange', () => { | |||||||
|                     {{i18n("app.manage.profile")}} |                     {{i18n("app.manage.profile")}} | ||||||
|                   </a> |                   </a> | ||||||
|                   </div> |                   </div> | ||||||
|  |  | ||||||
|                 </div> |                 </div> | ||||||
|             </a></li> |             </a></li> | ||||||
|       </ul> |       </ul> | ||||||
| @ -87,8 +84,7 @@ window.addEventListener('hashchange', () => { | |||||||
|     </div> |     </div> | ||||||
|     <div class="page"> |     <div class="page"> | ||||||
|         <Suspense> |         <Suspense> | ||||||
|          | 				<component :is="currentView" /> | ||||||
| 		<component :is="currentView" /> |  | ||||||
|         </Suspense> |         </Suspense> | ||||||
|     </div> |     </div> | ||||||
|   </div> |   </div> | ||||||
| @ -97,19 +93,22 @@ window.addEventListener('hashchange', () => { | |||||||
| <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-rows:[firstRow-start]61px[firstRow-end secondRow-start] auto [endRow]; |     grid-template-columns:[firstCol-start]70px[firstCol-end secondCol-start] auto [endCol]; | ||||||
|  |     grid-template-rows:[firstRow-start] var(--header-size) [firstRow-end secondRow-start] calc(100% - var(--header-size)) [endRow]; | ||||||
|     grid-template-areas: |     grid-template-areas: | ||||||
|     "topBar topBar"  |     "topBar topBar"  | ||||||
|     "leftBar page"; |     "leftBar page"; | ||||||
|     row-gap:0px; |  | ||||||
|     column-gap:0px; |  | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   .page { |   .page { | ||||||
|     grid-area:page; |     grid-area:page; | ||||||
|     place-self:center; | 		height: 100%; | ||||||
|  | 		width: 100%; | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   .topBar{ |   .topBar{ | ||||||
| @ -152,7 +151,7 @@ window.addEventListener('hashchange', () => { | |||||||
|  |  | ||||||
| 	ul.vertical{ | 	ul.vertical{ | ||||||
| 		list-style-type: none; | 		list-style-type: none; | ||||||
| 		margin-top: 61px; | 		margin-top: var(--header-size); | ||||||
|     top:0; |     top:0; | ||||||
|     left:0; |     left:0; | ||||||
| 		padding: 25px 0 0; | 		padding: 25px 0 0; | ||||||
| @ -200,7 +199,7 @@ window.addEventListener('hashchange', () => { | |||||||
|     left:0; |     left:0; | ||||||
|      |      | ||||||
| 		position: fixed; | 		position: fixed; | ||||||
| 		height:61px; | 		height:var(--header-size); | ||||||
| 		width: 100%; | 		width: 100%; | ||||||
| 		background-color: rgb(24, 24, 24); | 		background-color: rgb(24, 24, 24); | ||||||
| 	} | 	} | ||||||
| @ -232,6 +231,7 @@ window.addEventListener('hashchange', () => { | |||||||
| 	  .text { | 	  .text { | ||||||
| 		right: 0%; | 		right: 0%; | ||||||
| 		width: 0%; | 		width: 0%; | ||||||
|  | 		visibility: collapse; | ||||||
| 		opacity: 0; | 		opacity: 0; | ||||||
| 		color: white; | 		color: white; | ||||||
| 		font-size: 1.2em; | 		font-size: 1.2em; | ||||||
| @ -240,7 +240,8 @@ window.addEventListener('hashchange', () => { | |||||||
| 	  } | 	  } | ||||||
|  |  | ||||||
| 	  ul.vertical:hover .text { | 	  ul.vertical:hover .text { | ||||||
| 		opacity: 1; | 		opacity:1; | ||||||
|  | 		visibility:visible; | ||||||
| 		width: 60%; | 		width: 60%; | ||||||
| 		transition-duration: .3s; | 		transition-duration: .3s; | ||||||
| 		padding-left: 15px; | 		padding-left: 15px; | ||||||
|  | |||||||
| @ -1,113 +0,0 @@ | |||||||
| <script setup> |  | ||||||
|   import i18n from "@/i18n.js" |  | ||||||
|   import {ref} from 'vue' |  | ||||||
|   import {validateRegister, getAllRegisters } from '@/rest/ServiceInscription.js' |  | ||||||
|  |  | ||||||
|   const requests = ref(await getAllRegisters()); |  | ||||||
|   console.log(requests); |  | ||||||
|  |  | ||||||
|   async function upPage(id,review){ |  | ||||||
|     await validateRegister(id,review); |  | ||||||
|     requests.value = await getAllRegisters(); |  | ||||||
|  |  | ||||||
|   } |  | ||||||
| </script> |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| <template>  |  | ||||||
|   <div  v-for="item of requests"> |  | ||||||
|   <div class="bodu" v-if="item.state === 'Pending'"> |  | ||||||
|   <div class="container"> |  | ||||||
|   |  | ||||||
|     <div class="id"><a>{{item.id}}</a></div> |  | ||||||
|     <div class="surname"><a>{{item.lastName}}</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="accept"><button @click="upPage(item.id,'Accepted')" style="background-color:rgb(0,105,50);">{{i18n("request.accept")}}</button></div> |  | ||||||
|     <div class="refuse"><button @click="upPage(item.id,'Refused')" style="background-color:rgb(105,0,0);">{{i18n("request.refuse")}}</button></div> |  | ||||||
|   </div> |  | ||||||
|   </div> |  | ||||||
|   </div> |  | ||||||
| </template> |  | ||||||
|  |  | ||||||
| <style scoped> |  | ||||||
|   .container{ |  | ||||||
|     color:white; |  | ||||||
|     height:100px; |  | ||||||
|     font-size:20px; |  | ||||||
|     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-areas: |  | ||||||
|     "id type surname firstname infos accept refuse";  |  | ||||||
|     column-gap:10px; |  | ||||||
|      |  | ||||||
|   } |  | ||||||
|    |  | ||||||
|   .infos { |  | ||||||
|     grid-area:infos; |  | ||||||
|     align-self:center; |  | ||||||
|   } |  | ||||||
|  |  | ||||||
|   .accept{ |  | ||||||
|     grid-area:accept; |  | ||||||
|     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; |  | ||||||
|   } |  | ||||||
|  |  | ||||||
|   .type{ |  | ||||||
|     grid-area:type; |  | ||||||
|     align-self:center; |  | ||||||
|   } |  | ||||||
|  |  | ||||||
|   .surname{ |  | ||||||
|     grid-area:surname; |  | ||||||
|     align-self:center; |  | ||||||
|     white-space: nowrap; |  | ||||||
|     overflow: hidden; |  | ||||||
|     text-overflow:ellipsis; |  | ||||||
|   } |  | ||||||
|  |  | ||||||
|   .firstname{ |  | ||||||
|     grid-area:firstname; |  | ||||||
|     align-self:center; |  | ||||||
|     white-space: nowrap; |  | ||||||
|     overflow: hidden; |  | ||||||
|     text-overflow:ellipsis; |  | ||||||
|   } |  | ||||||
|  |  | ||||||
|   button{ |  | ||||||
|     font-size:15px; |  | ||||||
|      height:50px; |  | ||||||
|      width:100px; |  | ||||||
|     border:none; |  | ||||||
|     border-radius:20px; |  | ||||||
|  |  | ||||||
|   } |  | ||||||
|  |  | ||||||
|   .bodu { |  | ||||||
|     width:100%; |  | ||||||
|     margin-bottom:10px; |  | ||||||
|     border:2px solid black; |  | ||||||
|     border-radius:9px; |  | ||||||
|     background-color:rgb(50,50,50); |  | ||||||
|   } |  | ||||||
|  |  | ||||||
|  |  | ||||||
| </style> |  | ||||||
|  |  | ||||||
|  |  | ||||||
							
								
								
									
										128
									
								
								frontend/src/Apps/Inscription/AboutChangeCurriculum.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										128
									
								
								frontend/src/Apps/Inscription/AboutChangeCurriculum.vue
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,128 @@ | |||||||
|  | <script setup> | ||||||
|  |  | ||||||
|  | import { | ||||||
|  |   addUninscReq, editChangeCurrReq, editChangeCurrReqTeacherState, | ||||||
|  |   editScholarshipReq, | ||||||
|  |   editUnregReq, getChangeCurrReqById, | ||||||
|  |   getScholarshipReqById, | ||||||
|  |   getUnregisterbyId | ||||||
|  | } from "@/rest/requests.js"; | ||||||
|  | import i18n from "@/i18n.js"; | ||||||
|  | import {getSelf, getUser} from "@/rest/Users.js"; | ||||||
|  | import {reactive, ref} from "vue"; | ||||||
|  | import AboutStudent from "@/Apps/Inscription/AboutStudent.vue"; | ||||||
|  |  | ||||||
|  | const props = defineProps(["reqId"]) | ||||||
|  | const req = ref(await getChangeCurrReqById(props.reqId)) | ||||||
|  |  | ||||||
|  | const user = await getSelf() | ||||||
|  | //0 liste, 1 profil | ||||||
|  | const localwindowstate = ref(0); | ||||||
|  |  | ||||||
|  | const tag = req.value.user.regNo | ||||||
|  |  | ||||||
|  | const windowState = defineModel("windowState") | ||||||
|  |  | ||||||
|  | async function uploadandrefreshChangeRequest(state){ | ||||||
|  |     await editChangeCurrReq(req.value.id, state); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | async function editChangeCurrReqTeacherApproval(state){ | ||||||
|  |     await editChangeCurrReqTeacherState(req.value.id, state) | ||||||
|  | } | ||||||
|  | </script> | ||||||
|  |  | ||||||
|  |  | ||||||
|  | <template> | ||||||
|  |   <div class="body" v-if="localwindowstate === 0"> | ||||||
|  |     <div class="container"> | ||||||
|  |       <div class="globalInfos"> | ||||||
|  |         <div class="infosContainer"> | ||||||
|  |           <div> | ||||||
|  |             Firstname/Name : {{req.user.firstName}} {{req.user.lastName}} | ||||||
|  |           </div> | ||||||
|  |           <div> | ||||||
|  |             regNo : {{req.user.regNo}} | ||||||
|  |           </div> | ||||||
|  |           <div v-if="req.actualCurriculum !== null"> | ||||||
|  |             From : Bac {{req.actualCurriculum.year}} {{req.actualCurriculum.option}} | ||||||
|  |             To : Bac {{req.destinationCurriculum.year}} {{req.destinationCurriculum.option}} | ||||||
|  |           </div> | ||||||
|  |           <div v-else> | ||||||
|  |             Wanted cursus : Bac {{req.destinationCurriculum.year}} {{req.destinationCurriculum.option}} | ||||||
|  |           </div> | ||||||
|  |           <div> | ||||||
|  |             <button @click="localwindowstate++"> See profile </button> | ||||||
|  |           </div> | ||||||
|  |           <div> | ||||||
|  |             <button v-if="req.state === 'Pending'" @click="req.state='Accepted';uploadandrefreshChangeRequest('Accepted')">Accept</button> | ||||||
|  |             <button v-if="req.state === 'Pending'" @click="req.state='Refused';uploadandrefreshChangeRequest('Refused')" style="margin-left: 2%;">Refuse</button> | ||||||
|  |           </div> | ||||||
|  |           <div v-if="user.role === 'Teacher' || user.role === 'Admin'"> | ||||||
|  |             <button v-if="req.teacherApprovalState === 'Pending'" @click="req.teacherApprovalState='Accepted';editChangeCurrReqTeacherApproval('Accepted')">Accept equivalence</button> | ||||||
|  |             <button v-if="req.teacherApprovalState === 'Pending'" @click="req.teacherApprovalState='Refused';editChangeCurrReqTeacherApproval('Refused')">Refuse equivalence</button> | ||||||
|  |           </div> | ||||||
|  |         </div> | ||||||
|  |       </div> | ||||||
|  |     </div> | ||||||
|  |   </div> | ||||||
|  |   <div v-if="localwindowstate === 0"> | ||||||
|  |     <button @click="windowState = 0" style="margin-left: 10%">Back</button> | ||||||
|  |   </div> | ||||||
|  |   <div v-if="localwindowstate === 1"> | ||||||
|  |     <AboutStudent :target="tag"></AboutStudent> | ||||||
|  |     <button @click="localwindowstate--;">Back</button> | ||||||
|  |   </div> | ||||||
|  | </template> | ||||||
|  |  | ||||||
|  | <style scoped> | ||||||
|  | .container{ | ||||||
|  |   min-width:675px; | ||||||
|  |   display:grid; | ||||||
|  |   grid-template-columns:10vw 50vw; | ||||||
|  |   grid-template-rows:200px auto; | ||||||
|  |   column-gap:2.7%; | ||||||
|  |   row-gap:45px; | ||||||
|  |   grid-template-areas: | ||||||
|  |   "profilPic globalInfos" | ||||||
|  |   "minfos minfos"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .profilPic{ | ||||||
|  |   width:100%; | ||||||
|  |   grid-area:profilPic; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .globalInfos { | ||||||
|  |   grid-area:globalInfos; | ||||||
|  |   align-self :center; | ||||||
|  |  | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .body { | ||||||
|  |   min-width:960px; | ||||||
|  |   width:100%; | ||||||
|  |   display:flex; | ||||||
|  |   align-items:center; | ||||||
|  |   justify-content:center; | ||||||
|  |   margin-top:7%; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .subContainter{ | ||||||
|  |   width:100%; | ||||||
|  |   background-color:rgb(50,50,50); | ||||||
|  |   border-radius:20px; | ||||||
|  |   border:4px solid black; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .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; | ||||||
|  | } | ||||||
|  | </style> | ||||||
							
								
								
									
										116
									
								
								frontend/src/Apps/Inscription/AboutExemption.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										116
									
								
								frontend/src/Apps/Inscription/AboutExemption.vue
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,116 @@ | |||||||
|  | <script setup> | ||||||
|  |  | ||||||
|  | import { | ||||||
|  |   addUninscReq, | ||||||
|  |   editExempReqState, | ||||||
|  |   editScholarshipReq, | ||||||
|  |   getExempReq, | ||||||
|  |   getScholarshipReqById | ||||||
|  | } from "@/rest/requests.js"; | ||||||
|  | import i18n from "@/i18n.js"; | ||||||
|  | import {getUser} from "@/rest/Users.js"; | ||||||
|  | import {reactive, ref} from "vue"; | ||||||
|  | import AboutStudent from "@/Apps/Inscription/AboutStudent.vue"; | ||||||
|  |  | ||||||
|  | const props = defineProps(["reqId"]) | ||||||
|  |  | ||||||
|  | const req = ref(await getExempReq(props.reqId)) | ||||||
|  |  | ||||||
|  | const profile = ref(false) | ||||||
|  |  | ||||||
|  | const windowState = defineModel("windowState") | ||||||
|  |  | ||||||
|  | async function editExemp(newstate){ | ||||||
|  |   await editExempReqState(req.value.id, newstate) | ||||||
|  | } | ||||||
|  | </script> | ||||||
|  |  | ||||||
|  |  | ||||||
|  | <template> | ||||||
|  |   <div class="body" v-if="profile === false"> | ||||||
|  |     <div class="container"> | ||||||
|  |       <div class="globalInfos"> | ||||||
|  |         <div class="infosContainer"> | ||||||
|  |           <div> | ||||||
|  |             Firstname/Name : {{req.user.firstName}} {{req.user.lastName}} | ||||||
|  |           </div> | ||||||
|  |           <div> | ||||||
|  |             Course: {{req.course.title}} | ||||||
|  |           </div> | ||||||
|  |           <div> | ||||||
|  |             State : {{req.state}} | ||||||
|  |           </div> | ||||||
|  |           <div> | ||||||
|  |             <button @click="profile = !profile">Voir le profil</button> | ||||||
|  |           </div> | ||||||
|  |           <div> | ||||||
|  |             <button>Download justification document</button> | ||||||
|  |           </div> | ||||||
|  |           <div> | ||||||
|  |             <button v-if="req.state === 'Pending'" @click="req.state='Accepted';editExemp('Accepted')">Accept</button> | ||||||
|  |             <button v-if="req.state === 'Pending'" @click="req.state='Refused';editExemp('Refused')" style="margin-left: 2%;">Refuse</button> | ||||||
|  |           </div> | ||||||
|  |         </div> | ||||||
|  |       </div> | ||||||
|  |     </div> | ||||||
|  |   </div> | ||||||
|  |   <div v-else> | ||||||
|  |     <AboutStudent :target="req.user.regNo"></AboutStudent> | ||||||
|  |     <button @click="profile=!profile">Back</button> | ||||||
|  |   </div> | ||||||
|  |   <div> | ||||||
|  |     <button v-if="profile===false" @click="windowState = 0" style="margin-left: 30%">Back</button> | ||||||
|  |   </div> | ||||||
|  | </template> | ||||||
|  |  | ||||||
|  | <style scoped> | ||||||
|  | .container{ | ||||||
|  |   min-width:675px; | ||||||
|  |   display:grid; | ||||||
|  |   grid-template-columns:10vw 50vw; | ||||||
|  |   grid-template-rows:200px auto; | ||||||
|  |   column-gap:2.7%; | ||||||
|  |   row-gap:45px; | ||||||
|  |   grid-template-areas: | ||||||
|  |   "profilPic globalInfos" | ||||||
|  |   "minfos minfos"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .profilPic{ | ||||||
|  |   width:100%; | ||||||
|  |   grid-area:profilPic; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .globalInfos { | ||||||
|  |   grid-area:globalInfos; | ||||||
|  |   align-self :center; | ||||||
|  |  | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .body { | ||||||
|  |   min-width:960px; | ||||||
|  |   width:100%; | ||||||
|  |   display:flex; | ||||||
|  |   align-items:center; | ||||||
|  |   justify-content:center; | ||||||
|  |   margin-top:7%; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .subContainter{ | ||||||
|  |   width:100%; | ||||||
|  |   background-color:rgb(50,50,50); | ||||||
|  |   border-radius:20px; | ||||||
|  |   border:4px solid black; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .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; | ||||||
|  | } | ||||||
|  | </style> | ||||||
							
								
								
									
										137
									
								
								frontend/src/Apps/Inscription/AboutRequest.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										137
									
								
								frontend/src/Apps/Inscription/AboutRequest.vue
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,137 @@ | |||||||
|  | <script setup> | ||||||
|  | import i18n from "@/i18n.js" | ||||||
|  | import {getSelf, getUser} from '../../rest/Users.js' | ||||||
|  | import {getcurriculum,getSomeonesCurriculumList} from "@/rest/curriculum.js"; | ||||||
|  | import {getRegisters} from "@/rest/ServiceInscription.js"; | ||||||
|  | import {get} from "jsdom/lib/jsdom/named-properties-tracker.js"; | ||||||
|  | import {getExternalCurriculumByInscrReq} from "@/rest/externalCurriculum.js"; | ||||||
|  | import {ref} from "vue"; | ||||||
|  | import ExternalCurriculumList from "@/Apps/Inscription/ExternalCurriculumList.vue"; | ||||||
|  | import {editEquivalenceState} from "@/rest/requests.js"; | ||||||
|  |  | ||||||
|  | const props = defineProps(['target']); | ||||||
|  | const request = await getRegisters(props.target); | ||||||
|  | const cursus = await getcurriculum(request.curriculum); | ||||||
|  | const user = await getSelf(); | ||||||
|  | const list = ref(false); | ||||||
|  | const externalCurriculum = await getExternalCurriculumByInscrReq(request.id) | ||||||
|  |  | ||||||
|  | //Get the parent page windowState to display the correct button | ||||||
|  | const windowState = defineModel("windowState") | ||||||
|  | function getPP(){ | ||||||
|  |   if(request.profilePictureUrl === null){ | ||||||
|  |     return "/Clyde.png" | ||||||
|  |   } | ||||||
|  |   return request.profilePictureUrl; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | async function editEquivalence(id, newstate){ | ||||||
|  |   await editEquivalenceState(id, newstate) | ||||||
|  | } | ||||||
|  | </script> | ||||||
|  |  | ||||||
|  | <template> | ||||||
|  |   <div class="body" v-if="list == false"> | ||||||
|  |     <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 v-if="cursus.year > 1"> | ||||||
|  |             <button style="background-color:rgb(105,05,105);margin-left: 5%" @click="list=!list" v-if="(user.role == 'Teacher' || user.role == 'Admin')&& request.equivalenceState == 'Pending'">See external curriculums</button> | ||||||
|  |           </div> | ||||||
|  |         </div> | ||||||
|  |       </div> | ||||||
|  |     </div> | ||||||
|  |   </div> | ||||||
|  |   <div v-if="list == false"> | ||||||
|  |     <button @click="windowState = 0">Back</button> | ||||||
|  |   </div> | ||||||
|  |   <div v-if="list==true"> | ||||||
|  |     <ExternalCurriculumList :ext-curr-list="externalCurriculum" :mode="0"></ExternalCurriculumList> | ||||||
|  |     <div style="margin-left: 15%;margin-top: 5%;"> | ||||||
|  |       <button style="margin-left: 2%" @click="list = false;editEquivalence(request.id, 'Accepted'); request.equivalenceState='Accepted'">Accept Equivalence</button> | ||||||
|  |       <button style="margin-left: 2%" @click="list = false;editEquivalence(request.id, 'Refused'); request.equivalenceState='Refused'">Refuse Equivalence</button> | ||||||
|  |       <button style="margin-left: 2%" @click="list=false">Back</button> | ||||||
|  |     </div> | ||||||
|  |   </div> | ||||||
|  | </template> | ||||||
|  |  | ||||||
|  |  | ||||||
|  | <style scoped> | ||||||
|  | .container{ | ||||||
|  |   min-width:675px; | ||||||
|  |   display:grid; | ||||||
|  |   grid-template-columns:10vw 50vw; | ||||||
|  |   grid-template-rows:200px auto; | ||||||
|  |   column-gap:2.7%; | ||||||
|  |   row-gap:45px; | ||||||
|  |   grid-template-areas: | ||||||
|  |   "profilPic globalInfos" | ||||||
|  |   "minfos minfos"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .profilPic{ | ||||||
|  |   grid-area:profilPic; | ||||||
|  |   width:100%; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .globalInfos { | ||||||
|  |   grid-area:globalInfos; | ||||||
|  |   align-self :center; | ||||||
|  |  | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .body { | ||||||
|  |   min-width:960px; | ||||||
|  |   width:100%; | ||||||
|  |   display:flex; | ||||||
|  |   align-items:center; | ||||||
|  |   justify-content:center; | ||||||
|  |   margin-top:5%; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .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; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | button{ | ||||||
|  |   font-size:15px; | ||||||
|  |   height:50px; | ||||||
|  |   width:100px; | ||||||
|  |   border:none; | ||||||
|  |   border-radius:20px; | ||||||
|  | } | ||||||
|  | </style> | ||||||
							
								
								
									
										124
									
								
								frontend/src/Apps/Inscription/AboutScholarship.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										124
									
								
								frontend/src/Apps/Inscription/AboutScholarship.vue
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,124 @@ | |||||||
|  | <script setup> | ||||||
|  |  | ||||||
|  | import {addUninscReq, editScholarshipReq, getScholarshipReqById} from "@/rest/requests.js"; | ||||||
|  | import i18n from "@/i18n.js"; | ||||||
|  | import {getUser} from "@/rest/Users.js"; | ||||||
|  | import {reactive, ref} from "vue"; | ||||||
|  |  | ||||||
|  | const props = defineProps(["reqId"]) | ||||||
|  | const req = ref(await getScholarshipReqById(props.reqId)) | ||||||
|  |  | ||||||
|  | const user = req.value.user; | ||||||
|  |  | ||||||
|  | const scholarshipData = reactive({ | ||||||
|  |   amount : 0, | ||||||
|  |   id : req.value.id, | ||||||
|  |   state : "" | ||||||
|  | }) | ||||||
|  |  | ||||||
|  | function getPP(){ | ||||||
|  |   if(user.profilePictureUrl === null){ | ||||||
|  |     return "/Clyde.png" | ||||||
|  |   } | ||||||
|  |   return user.profilePictureUrl | ||||||
|  | } | ||||||
|  |  | ||||||
|  | async function uploadandrefreshScholarshipRequest(){ | ||||||
|  |   await editScholarshipReq(scholarshipData); | ||||||
|  |   req.value = await getScholarshipReqById(props.reqId); | ||||||
|  | } | ||||||
|  | </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> | ||||||
|  |             Country : {{user.country}} | ||||||
|  |           </div> | ||||||
|  |           <div> | ||||||
|  |             Birthdate : {{user.birthDate.slice(0,10)}} | ||||||
|  |           </div> | ||||||
|  |           <div> | ||||||
|  |             <button>Download tax justif document</button> | ||||||
|  |             <button style="margin-left: 2%">Download residency justif document</button> | ||||||
|  |           </div> | ||||||
|  |           <div v-if="req.state == 'Pending'"> | ||||||
|  |             Please enter the amount to provide : | ||||||
|  |             <input type="number" v-model="scholarshipData.amount"> | ||||||
|  |           </div> | ||||||
|  |           <div> | ||||||
|  |             <button v-if="req.state === 'Pending'" @click="scholarshipData.state='Accepted';uploadandrefreshScholarshipRequest()">Accept</button> | ||||||
|  |             <button v-if="req.state === 'Pending'" @click="scholarshipData.state='Refused';uploadandrefreshScholarshipRequest()" style="margin-left: 2%;">Refuse</button> | ||||||
|  |           </div> | ||||||
|  |         </div> | ||||||
|  |       </div> | ||||||
|  |     </div> | ||||||
|  |   </div> | ||||||
|  | </template> | ||||||
|  |  | ||||||
|  | <style scoped> | ||||||
|  | .container{ | ||||||
|  |   min-width:675px; | ||||||
|  |   display:grid; | ||||||
|  |   grid-template-columns:10vw 50vw; | ||||||
|  |   grid-template-rows:200px auto; | ||||||
|  |   column-gap:2.7%; | ||||||
|  |   row-gap:45px; | ||||||
|  |   grid-template-areas: | ||||||
|  |   "profilPic globalInfos" | ||||||
|  |   "minfos minfos"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .profilPic{ | ||||||
|  |   width:100%; | ||||||
|  |   grid-area:profilPic; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .globalInfos { | ||||||
|  |   grid-area:globalInfos; | ||||||
|  |   align-self :center; | ||||||
|  |  | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .body { | ||||||
|  |   min-width:960px; | ||||||
|  |   width:100%; | ||||||
|  |   display:flex; | ||||||
|  |   align-items:center; | ||||||
|  |   justify-content:center; | ||||||
|  |   margin-top:7%; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .subContainter{ | ||||||
|  |   width:100%; | ||||||
|  |   background-color:rgb(50,50,50); | ||||||
|  |   border-radius:20px; | ||||||
|  |   border:4px solid black; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .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; | ||||||
|  | } | ||||||
|  | </style> | ||||||
							
								
								
									
										192
									
								
								frontend/src/Apps/Inscription/AboutStudent.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										192
									
								
								frontend/src/Apps/Inscription/AboutStudent.vue
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,192 @@ | |||||||
|  | <script setup> | ||||||
|  |   import i18n from "@/i18n.js" | ||||||
|  |   import {getUser} from '../../rest/Users.js' | ||||||
|  |   import {getSomeonesCurriculumList} from "@/rest/curriculum.js"; | ||||||
|  |   import {ref} from "vue"; | ||||||
|  |   import ExternalCurriculumList from "@/Apps/Inscription/ExternalCurriculumList.vue"; | ||||||
|  |   import {getExternalCurriculumByUser} from "@/rest/externalCurriculum.js"; | ||||||
|  |  | ||||||
|  |   const props = defineProps(['target']) | ||||||
|  |   const user = await getUser(props.target) | ||||||
|  |   const UserCurriculum = await getSomeonesCurriculumList(props.target) | ||||||
|  |   const externalcurrlist = await getExternalCurriculumByUser(user.regNo) | ||||||
|  |   const extercurrlist = ref(false) | ||||||
|  |  | ||||||
|  |   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" v-if="extercurrlist==false"> | ||||||
|  |     <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> | ||||||
|  |             <button @click="extercurrlist=!extercurrlist">See external curriculums</button> | ||||||
|  |           </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="item.actual === false">Bac {{item.year}}</div> | ||||||
|  |               <div class="option" v-if="item.actual === false">{{item.option}}</div> | ||||||
|  |               <div class="dateyear" v-if="item.actual === false">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="item.actual === true">Bac {{item.year}}</div> | ||||||
|  |                 <div class="option" v-if="item.actual === true">{{item.option}}</div> | ||||||
|  |                 <div class="dateyear" v-if="item.actual === true">Année {{item.dateyear}}-{{item.dateyear+1}}</div> | ||||||
|  |             </div> | ||||||
|  |           </div> | ||||||
|  |         </div> | ||||||
|  |       </div> | ||||||
|  |     </div> | ||||||
|  |   </div> | ||||||
|  |   <div v-if="extercurrlist==true"> | ||||||
|  |       <ExternalCurriculumList :ext-curr-list="externalcurrlist" :mode="1"></ExternalCurriculumList> | ||||||
|  |   </div> | ||||||
|  | </template> | ||||||
|  |  | ||||||
|  |  | ||||||
|  | <style scoped> | ||||||
|  | .container{ | ||||||
|  |   min-width:675px; | ||||||
|  |   display:grid; | ||||||
|  |   grid-template-columns:10vw 50vw; | ||||||
|  |   grid-template-rows:200px auto; | ||||||
|  |   column-gap:2.7%; | ||||||
|  |   row-gap:45px; | ||||||
|  |   grid-template-areas: | ||||||
|  |   "profilPic globalInfos" | ||||||
|  |   "minfos minfos"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .profilPic{ | ||||||
|  |   grid-area:profilPic; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .globalInfos { | ||||||
|  |   grid-area:globalInfos; | ||||||
|  |   align-self :center; | ||||||
|  |  | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .body { | ||||||
|  |   min-width:960px; | ||||||
|  |   width:100%; | ||||||
|  |   display:flex; | ||||||
|  |   align-items:center; | ||||||
|  |   justify-content:center; | ||||||
|  |   margin-top:5%; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .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; | ||||||
|  |   align-items:center; | ||||||
|  |   justify-content:center; | ||||||
|  |   margin-left: 320%; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .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> | ||||||
							
								
								
									
										109
									
								
								frontend/src/Apps/Inscription/AboutUnregister.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										109
									
								
								frontend/src/Apps/Inscription/AboutUnregister.vue
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,109 @@ | |||||||
|  | <script setup> | ||||||
|  |  | ||||||
|  | import { | ||||||
|  |   addUninscReq, | ||||||
|  |   editScholarshipReq, | ||||||
|  |   editUnregReq, | ||||||
|  |   getScholarshipReqById, | ||||||
|  |   getUnregisterbyId | ||||||
|  | } from "@/rest/requests.js"; | ||||||
|  | import i18n from "@/i18n.js"; | ||||||
|  | import {getUser} from "@/rest/Users.js"; | ||||||
|  | import {reactive, ref} from "vue"; | ||||||
|  |  | ||||||
|  | const props = defineProps(["reqId"]) | ||||||
|  | const req = ref(await getUnregisterbyId(props.reqId)) | ||||||
|  |  | ||||||
|  | function getPP(){ | ||||||
|  |   if(user.profilePictureUrl === null){ | ||||||
|  |     return "/Clyde.png" | ||||||
|  |   } | ||||||
|  |   return user.profilePictureUrl | ||||||
|  | } | ||||||
|  |  | ||||||
|  | async function uploadandrefreshUnregRequest(state){ | ||||||
|  |   await editUnregReq(req.value.id, state) | ||||||
|  |   req.value.state = state | ||||||
|  | } | ||||||
|  | </script> | ||||||
|  |  | ||||||
|  |  | ||||||
|  | <template> | ||||||
|  |   <div class="body"> | ||||||
|  |     <div class="container"> | ||||||
|  |       <div class="globalInfos"> | ||||||
|  |         <div class="infosContainer"> | ||||||
|  |           <div> | ||||||
|  |             Firstname/Name : {{req.firstName}} {{req.lastName}} | ||||||
|  |           </div> | ||||||
|  |           <div> | ||||||
|  |             E-mail: {{req.email}} | ||||||
|  |           </div> | ||||||
|  |           <div> | ||||||
|  |             regNo : {{req.regNo}} | ||||||
|  |           </div> | ||||||
|  |           <div> | ||||||
|  |             Reason : | ||||||
|  |             <input type="text" v-model="req.reason" readonly/> | ||||||
|  |           </div> | ||||||
|  |           <div> | ||||||
|  |             <button v-if="req.state === 'Pending'" @click="req.state='Accepted';uploadandrefreshUnregRequest('Accepted')">Accept</button> | ||||||
|  |             <button v-if="req.state === 'Pending'" @click="req.state='Refused';uploadandrefreshUnregRequest('Refused')" style="margin-left: 2%;">Refuse</button> | ||||||
|  |           </div> | ||||||
|  |         </div> | ||||||
|  |       </div> | ||||||
|  |     </div> | ||||||
|  |   </div> | ||||||
|  | </template> | ||||||
|  |  | ||||||
|  | <style scoped> | ||||||
|  | .container{ | ||||||
|  |   min-width:675px; | ||||||
|  |   display:grid; | ||||||
|  |   grid-template-columns:10vw 50vw; | ||||||
|  |   grid-template-rows:200px auto; | ||||||
|  |   column-gap:2.7%; | ||||||
|  |   row-gap:45px; | ||||||
|  |   grid-template-areas: | ||||||
|  |   "profilPic globalInfos" | ||||||
|  |   "minfos minfos"; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .profilPic{ | ||||||
|  |   width:100%; | ||||||
|  |   grid-area:profilPic; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .globalInfos { | ||||||
|  |   grid-area:globalInfos; | ||||||
|  |   align-self :center; | ||||||
|  |  | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .body { | ||||||
|  |   min-width:960px; | ||||||
|  |   width:100%; | ||||||
|  |   display:flex; | ||||||
|  |   align-items:center; | ||||||
|  |   justify-content:center; | ||||||
|  |   margin-top:7%; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .subContainter{ | ||||||
|  |   width:100%; | ||||||
|  |   background-color:rgb(50,50,50); | ||||||
|  |   border-radius:20px; | ||||||
|  |   border:4px solid black; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .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; | ||||||
|  | } | ||||||
|  | </style> | ||||||
							
								
								
									
										139
									
								
								frontend/src/Apps/Inscription/CourseList.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										139
									
								
								frontend/src/Apps/Inscription/CourseList.vue
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,139 @@ | |||||||
|  | <script setup> | ||||||
|  |  | ||||||
|  | import {reactive, ref} from "vue"; | ||||||
|  | import i18n from "@/i18n.js"; | ||||||
|  | import {getCourse} from "@/rest/courses.js"; | ||||||
|  | import {getcurriculum} from "@/rest/curriculum.js"; | ||||||
|  | import {uploadFile, uploadProfilePicture} from "@/rest/uploads.js"; | ||||||
|  | import {createExemptionsRequest} from "@/rest/requests.js"; | ||||||
|  | import {getSelf} from "@/rest/Users.js"; | ||||||
|  |  | ||||||
|  | const props = defineProps(["cursuslist"]) | ||||||
|  | const selectedCurriculum = ref(props.cursuslist[0]) | ||||||
|  | const user = await getSelf() | ||||||
|  |  | ||||||
|  | const courseslist = ref(await getcurriculum(selectedCurriculum.value.curriculumId)) | ||||||
|  | const list = ref(true) | ||||||
|  |  | ||||||
|  | const ppData = ref({}) | ||||||
|  | async function updateCourseList(){ | ||||||
|  |   courseslist.value = await getcurriculum(selectedCurriculum.value.curriculumId) | ||||||
|  | } | ||||||
|  |  | ||||||
|  | async function postExemptionRequest(file, type){ | ||||||
|  |   const a = await uploadFile(file, type); | ||||||
|  |   exemptReq.justifDocument = a.url | ||||||
|  |   await createExemptionsRequest(exemptReq) | ||||||
|  | } | ||||||
|  | const exemptReq = reactive({ | ||||||
|  |   userRegNo : user.regNo, | ||||||
|  |   courseId : null, | ||||||
|  |   justifDocument : "", | ||||||
|  | }) | ||||||
|  | </script> | ||||||
|  |  | ||||||
|  | <template style="margin-top:5%;"> | ||||||
|  |   <div v-if="list == true"> | ||||||
|  |     <span>Selected Cursus :   </span> | ||||||
|  |     <select v-model="selectedCurriculum" @change="updateCourseList"> | ||||||
|  |       <option v-for="item in props.cursuslist" :value="item">Bac {{item.year}} {{item.option}}</option> | ||||||
|  |     </select> | ||||||
|  |     <div style="display:flex; justify-content:center;" v-for="item in courseslist.courses"> | ||||||
|  |       <div class="bodu"> | ||||||
|  |         <div class="container"> | ||||||
|  |           <div class="title">{{item.title}}</div> | ||||||
|  |           <div class="firstname">{{item.owner.firstName}}</div> | ||||||
|  |           <div class="lastname">{{item.owner.lastName}}</div> | ||||||
|  |           <div class="credits">credits : {{item.credits}}</div> | ||||||
|  |           <div class="askexemption"><button style="background-color:rgb(105,0,0);" @click="list= !list;exemptReq.courseId=item.courseId">Ask exemption</button></div> | ||||||
|  |         </div> | ||||||
|  |       </div> | ||||||
|  |     </div> | ||||||
|  |   </div> | ||||||
|  |   <div v-else> | ||||||
|  |       <p>Please upload the justification document for the exemption </p> | ||||||
|  |     <label class="browser"> | ||||||
|  |       <input  type="file" @change="ppData.value = $event.target.files" accept="image/*" ref="filepath"> | ||||||
|  |     </label> | ||||||
|  |     <button style="width:15%; margin-top: 5%;" @click="postExemptionRequest(ppData.value, 'JustificationDocument');"> | ||||||
|  |       Submit exemption request | ||||||
|  |     </button> | ||||||
|  |   </div> | ||||||
|  | </template> | ||||||
|  |  | ||||||
|  | <style scoped> | ||||||
|  | .container{ | ||||||
|  |   color:white; | ||||||
|  |   height:100px; | ||||||
|  |   font-size:30px; | ||||||
|  |   display:grid; | ||||||
|  |   grid-template-columns:30% 20% 15% 15% 15%; | ||||||
|  |   grid-template-areas:"title firstname lastname credits askexemption"; | ||||||
|  |   column-gap:10px; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .title { | ||||||
|  |   grid-area:title; | ||||||
|  |   align-self:center; | ||||||
|  |   white-space: nowrap; | ||||||
|  |   overflow: hidden; | ||||||
|  |   text-overflow:ellipsis; | ||||||
|  |   font-size: 50%; | ||||||
|  |   margin-left:30px; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .credits { | ||||||
|  |   grid-area:credits; | ||||||
|  |   align-self:center; | ||||||
|  |   white-space: nowrap; | ||||||
|  |   overflow: hidden; | ||||||
|  |   text-overflow:ellipsis; | ||||||
|  |   font-size: 50%; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .askexemption { | ||||||
|  |   grid-area:askexemption; | ||||||
|  |   align-self:center; | ||||||
|  |   white-space: nowrap; | ||||||
|  |   overflow: hidden; | ||||||
|  |   text-overflow:ellipsis; | ||||||
|  | } | ||||||
|  | .lastname{ | ||||||
|  |   grid-area:lastname; | ||||||
|  |   align-self:center; | ||||||
|  |   white-space: nowrap; | ||||||
|  |   overflow: hidden; | ||||||
|  |   text-overflow:ellipsis; | ||||||
|  |   font-size: 50%; | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  | .firstname{ | ||||||
|  |   grid-area:firstname; | ||||||
|  |   align-self:center; | ||||||
|  |   white-space: nowrap; | ||||||
|  |   overflow: hidden; | ||||||
|  |   text-overflow:ellipsis; | ||||||
|  |   font-size: 50%; | ||||||
|  |   padding-left: 30%; | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  | .bodu { | ||||||
|  |   margin-top:2%; | ||||||
|  |   width:100%; | ||||||
|  |   border:2px solid black; | ||||||
|  |   border-radius:9px; | ||||||
|  |   background-color:rgb(50,50,50); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | button{ | ||||||
|  |   border:none; | ||||||
|  |   background-color:rgb(239, 60, 168); | ||||||
|  |   border-radius:10px; | ||||||
|  |   height:35px; | ||||||
|  |   margin-top:10px; | ||||||
|  |  | ||||||
|  | } | ||||||
|  | </style> | ||||||
|  |  | ||||||
							
								
								
									
										231
									
								
								frontend/src/Apps/Inscription/ExternalCurriculumList.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										231
									
								
								frontend/src/Apps/Inscription/ExternalCurriculumList.vue
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,231 @@ | |||||||
|  | <script setup> | ||||||
|  |   import i18n from "@/i18n.js"; | ||||||
|  |   import {reactive, ref} from "vue"; | ||||||
|  |   import {getSelf} from "@/rest/Users.js"; | ||||||
|  |   import {createExternalCurriculum, getExternalCurriculumByUser} from "@/rest/externalCurriculum.js"; | ||||||
|  |  | ||||||
|  |   //mode 0 = externalcurr related to inscrreq, 1 = externalcurr related to user, 2 inscription procedure | ||||||
|  |   const props = defineProps(["extCurrList", "mode"]) | ||||||
|  |  | ||||||
|  |   //Only usefull to pass the external curr array in the inscription procedure | ||||||
|  |   const externalCurrTab = defineModel(); | ||||||
|  |  | ||||||
|  |   const extCurrList = ref({}) | ||||||
|  |   let extNum = 0 | ||||||
|  |   const User = ref({}) | ||||||
|  |  | ||||||
|  |   if (props.mode === 1){ | ||||||
|  |     User.value = await getSelf() | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |  | ||||||
|  |   const list = ref(true) | ||||||
|  |   const editmode = ref(false) | ||||||
|  |   const notcompletedCheck = ref(false); | ||||||
|  |  | ||||||
|  |   const externalCurr = reactive({ | ||||||
|  |     inscriptionRequestId : null, | ||||||
|  |     school:null, | ||||||
|  |     formation :null, | ||||||
|  |     completion : "completed", | ||||||
|  |     startYear : 0, | ||||||
|  |     endYear: 0, | ||||||
|  |     justifdocUrl : null, | ||||||
|  |     userRegNo : null | ||||||
|  |   }) | ||||||
|  |  | ||||||
|  |   if (props.mode === 1){ | ||||||
|  |     externalCurr.userRegNo = props.extCurrList[0].user.regNo | ||||||
|  |   }else if(props.mode === 2){ | ||||||
|  |     extCurrList.value = externalCurrTab.value | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   if(props.mode !== 2){ | ||||||
|  |     extCurrList.value = props.extCurrList | ||||||
|  |     console.log("oe") | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   function deleteExtCursus(extcursus){ | ||||||
|  |     externalCurrTab.value.splice(externalCurrTab.value.indexOf(extcursus),1) | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   async function postExternalCurr(){ | ||||||
|  |     if (props.mode === 1){ | ||||||
|  |       await createExternalCurriculum(externalCurr.inscriptionRequestId, externalCurr.school, externalCurr.formation, externalCurr.completion, externalCurr.startYear, externalCurr.endYear, externalCurr.justifdocUrl, externalCurr.userRegNo); | ||||||
|  |       //We refresh the list | ||||||
|  |       extCurrList.value = await getExternalCurriculumByUser(externalCurr.userRegNo); | ||||||
|  |       list.value = !list.value; | ||||||
|  |     }else if (props.mode === 2){ | ||||||
|  |       externalCurrTab.value.push({ | ||||||
|  |         inscriptionRequestId : externalCurr.inscriptionRequestId, | ||||||
|  |           school:externalCurr.school, | ||||||
|  |           formation :externalCurr.formation, | ||||||
|  |           completion : externalCurr.completion, | ||||||
|  |           startYear : externalCurr.startYear, | ||||||
|  |           endYear: externalCurr.endYear, | ||||||
|  |           justifdocUrl : externalCurr.justifdocUrl, | ||||||
|  |           userRegNo : externalCurr.userRegNo | ||||||
|  |       }); | ||||||
|  |       extCurrList.value = externalCurrTab.value | ||||||
|  |       list.value = !list.value; | ||||||
|  |       console.log(externalCurrTab.value) | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | </script> | ||||||
|  |  | ||||||
|  | <template style="margin-top:5%;"> | ||||||
|  |   <div v-if="list"> | ||||||
|  |     <div v-if="props.mode === 2||User.regNo === externalCurr.userRegNo" style="margin-left: 2%;margin-top: 2%"> | ||||||
|  |       <button @click="list = !list">Add external curriculum</button> | ||||||
|  |     </div> | ||||||
|  |     <div style="display:flex; justify-content:center; " v-for="(item, index) in extCurrList"> | ||||||
|  |       <div class="bodu"> | ||||||
|  |         <div class="container"> | ||||||
|  |           <div class="status"><a style="margin-left:30px">{{item.state}}</a></div> | ||||||
|  |           <div class="school"><a>{{item.school}}</a></div> | ||||||
|  |           <div class="formation"><a>{{item.formation}}</a></div> | ||||||
|  |           <div class="completion"><a>{{item.completion}}</a></div> | ||||||
|  |           <div class="download"><button>Download document</button></div> | ||||||
|  |           <div class="edit" v-if="props.mode === 2"><button @click="list=!list;externalCurr.justifdocUrl=item.justifDocUrl; externalCurr.endYear = item.endYear; externalCurr.startYear = item.startYear; externalCurr.school = item.school;externalCurr.completion = item.completion;externalCurr.formation=item.formation;editmode=!editmode;extNum=index">Edit</button></div> | ||||||
|  |           <div class="delete" v-if="props.mode === 2"><button @click="deleteExtCursus(item)">Delete</button></div> | ||||||
|  |         </div> | ||||||
|  |       </div> | ||||||
|  |     </div> | ||||||
|  |   </div> | ||||||
|  |   <div v-else class="loginbox" style="margin-left: 35%; margin-top: 3%"> | ||||||
|  |     <form class="form"> | ||||||
|  |       <div class="inputBox"> | ||||||
|  |         <p>Ecole</p> | ||||||
|  |         <input type="text" v-model="externalCurr.school"> | ||||||
|  |       </div> | ||||||
|  |       <div class="inputBox"> | ||||||
|  |         <p>Formation</p> | ||||||
|  |         <input type="text" v-model="externalCurr.formation"> | ||||||
|  |       </div> | ||||||
|  |       <div class="inputBox"> | ||||||
|  |         <p>Cochez la case si vous n'avez terminé cette formation</p> | ||||||
|  |         <input v-model="notcompletedCheck" type="checkbox" id="checkboxformation"> | ||||||
|  |         <div v-if="notcompletedCheck"> | ||||||
|  |           <p>En quelle année de la formation vous êtes vous arrété (exemple: 3ème) ?</p> | ||||||
|  |           <input type="text" v-model="externalCurr.completion"> | ||||||
|  |         </div> | ||||||
|  |       </div> | ||||||
|  |       <div class="inputBox"> | ||||||
|  |         <p>Année de début</p> | ||||||
|  |         <input type="number" v-model="externalCurr.startYear"> | ||||||
|  |       </div> | ||||||
|  |       <div class="inputBox"> | ||||||
|  |         <p>Année de fin</p> | ||||||
|  |         <input type="number" v-model="externalCurr.endYear"> | ||||||
|  |       </div> | ||||||
|  |       <div class="inputBox" style="margin-top: 3%; margin-bottom: 3%"> | ||||||
|  |         <input v-if="!editmode" type="submit" value="Upload curriculum" @click="postExternalCurr()"> | ||||||
|  |         <input v-else type="submit" value="Edit curriculum" @click="externalCurrTab[extNum] = {inscriptionRequestId : externalCurr.inscriptionRequestId,school:externalCurr.school,formation :externalCurr.formation,completion : externalCurr.completion,startYear : externalCurr.startYear,endYear: externalCurr.endYear,justifdocUrl : externalCurr.justifdocUrl,userRegNo : externalCurr.userRegNo};editmode=!editmode;list=!list"> | ||||||
|  |       </div> | ||||||
|  |     </form> | ||||||
|  |   </div> | ||||||
|  | </template> | ||||||
|  |  | ||||||
|  | <style scoped> | ||||||
|  | .container{ | ||||||
|  |   color:white; | ||||||
|  |   height:100px; | ||||||
|  |   font-size:30px; | ||||||
|  |   display:grid; | ||||||
|  |   grid-template-columns:5% 10% 20% 15% 20% 10%; | ||||||
|  |   grid-template-areas: | ||||||
|  |     "status school formation completion download edit delete"; | ||||||
|  |   column-gap:10px; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .status { | ||||||
|  |   grid-area:status; | ||||||
|  |   align-self:center; | ||||||
|  |   font-size: 70%; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .edit{ | ||||||
|  |   grid-area: edit; | ||||||
|  |   align-self: center; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .delete{ | ||||||
|  |   grid-area: delete; | ||||||
|  |   align-self: center; | ||||||
|  | } | ||||||
|  | .school{ | ||||||
|  |   grid-area:school; | ||||||
|  |   align-self:center; | ||||||
|  |   font-size: 70%; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .formation{ | ||||||
|  |   grid-area:formation; | ||||||
|  |   align-self:center; | ||||||
|  |   font-size: 70%; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .completion{ | ||||||
|  |   grid-area:completion; | ||||||
|  |   align-self:center; | ||||||
|  |   white-space: nowrap; | ||||||
|  |   overflow: hidden; | ||||||
|  |   text-overflow:ellipsis; | ||||||
|  |   font-size: 70%; | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  | .download{ | ||||||
|  |   grid-area: download; | ||||||
|  |   align-self:center; | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  | .bodu { | ||||||
|  |   margin-top:2%; | ||||||
|  |   width:66%; | ||||||
|  |   border:2px solid black; | ||||||
|  |   border-radius:9px; | ||||||
|  |   background-color:rgb(50,50,50); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .loginbox { | ||||||
|  |   background-color: rgb(24,24,24); | ||||||
|  |   width: 400px; | ||||||
|  |   display:flex; | ||||||
|  |   justify-content: center; | ||||||
|  |   border-radius: 5%; | ||||||
|  |   box-shadow:0 5px 25px #000000; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .form { | ||||||
|  |   position:relative; | ||||||
|  |   width:100%; | ||||||
|  |   display: flex; | ||||||
|  |   flex-direction: column; | ||||||
|  |   align-items:center; | ||||||
|  |   gap: 3%; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .inputBox input,select { | ||||||
|  |   width:100%; | ||||||
|  |   border: none; | ||||||
|  |   margin-right: 12.5%; | ||||||
|  |   padding-left: 2.5%; | ||||||
|  |   padding-top:2.5%; | ||||||
|  |   padding-bottom:2.5%; | ||||||
|  |   outline:none; | ||||||
|  |   border-radius: 10px; | ||||||
|  |   font-size:1.35em; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .inputBox p{ | ||||||
|  |   position:relative; | ||||||
|  |   z-index: 100; | ||||||
|  |   font-family:sans-serif ; | ||||||
|  |   color:rgb(239,60,168); | ||||||
|  |   transition: 0.5; | ||||||
|  |  | ||||||
|  | } | ||||||
|  | </style> | ||||||
|  |  | ||||||
							
								
								
									
										255
									
								
								frontend/src/Apps/Inscription/ManageRequests.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										255
									
								
								frontend/src/Apps/Inscription/ManageRequests.vue
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,255 @@ | |||||||
|  | <script setup> | ||||||
|  |   import i18n from "@/i18n.js" | ||||||
|  |   import {ref, vModelSelect} from 'vue' | ||||||
|  |   import {validateRegister, getAllRegisters } from '@/rest/ServiceInscription.js' | ||||||
|  |   import AboutRequest from "@/Apps/Inscription/AboutRequest.vue"; | ||||||
|  |   import { | ||||||
|  |     getAllChangeCurrReq, | ||||||
|  |     getAllExemptionsRequest, | ||||||
|  |     getAllScholarShipsRequest, | ||||||
|  |     getAllUnregisters | ||||||
|  |   } from "@/rest/requests.js"; | ||||||
|  |   import AboutScholarship from "@/Apps/Inscription/AboutScholarship.vue"; | ||||||
|  |   import AboutUnregister from "@/Apps/Inscription/AboutUnregister.vue"; | ||||||
|  |   import AboutChangeCurriculum from "@/Apps/Inscription/AboutChangeCurriculum.vue"; | ||||||
|  |   import AboutExemption from "@/Apps/Inscription/AboutExemption.vue"; | ||||||
|  |  | ||||||
|  |   const requests = ref(await getAllRegisters()); | ||||||
|  |   let targetId = ""; | ||||||
|  |  | ||||||
|  |   const requestType = ref("inscription"); | ||||||
|  |   const filterType = ref("None"); | ||||||
|  |  | ||||||
|  |   //0 = liste, 1 = détails, 2 = sure?, 3 = manage scholarship, 4 manage unregister, 5 = manage curriculum change, 6 = manage exemptions | ||||||
|  |   const windowsState = ref(0); | ||||||
|  |  | ||||||
|  |   async function upPage(id,review){ | ||||||
|  |     await validateRegister(id,review); | ||||||
|  |  | ||||||
|  |     requests.value = await getAllRegisters(); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   async function loadRequests(){ | ||||||
|  |     switch (requestType.value){ | ||||||
|  |       case "inscription": | ||||||
|  |         requests.value = await getAllRegisters(); | ||||||
|  |         break; | ||||||
|  |       case "scholarship": | ||||||
|  |         requests.value = await getAllScholarShipsRequest(); | ||||||
|  |         break; | ||||||
|  |       case "exemption": | ||||||
|  |         requests.value = await getAllExemptionsRequest(); | ||||||
|  |         break; | ||||||
|  |       case "unregister": | ||||||
|  |         requests.value = await getAllUnregisters(); | ||||||
|  |         break; | ||||||
|  |       case "curriculum change": | ||||||
|  |         requests.value = await getAllChangeCurrReq(); | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | </script> | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | <template> | ||||||
|  |   <div v-if="windowsState === 1"> | ||||||
|  |     <AboutRequest :target="targetId" v-model:window-state="windowsState"></AboutRequest> | ||||||
|  |   </div> | ||||||
|  |   <div v-if="windowsState === 0"> | ||||||
|  |     <div style="margin-top: 2%;margin-left: 2%"> | ||||||
|  |       <span>Request type :   </span> | ||||||
|  |       <select v-model="requestType" @change="loadRequests()"> | ||||||
|  |         <option>inscription</option> | ||||||
|  |         <option>scholarship</option> | ||||||
|  |         <option>exemption</option> | ||||||
|  |         <option>unregister</option> | ||||||
|  |         <option>curriculum change</option> | ||||||
|  |       </select> | ||||||
|  |       <span style="margin-left: 5%"> | ||||||
|  |         Filter : | ||||||
|  |         <select v-model="filterType"> | ||||||
|  |           <option>None</option> | ||||||
|  |           <option>Pending</option> | ||||||
|  |           <option>Accepted</option> | ||||||
|  |           <option>Refused</option> | ||||||
|  |       </select> | ||||||
|  |       </span> | ||||||
|  |     </div> | ||||||
|  |     <div style='display:flex; justify-content:center; min-width:1140px;' v-for="item of requests"> | ||||||
|  |       <div class="bodu" style="width: 95%" v-if="filterType == 'None' || filterType == item.state"> | ||||||
|  |         <div class="container" style="grid-template-columns:11% 15% 20% 10% 10% 9% 9%;grid-template-areas:'date state equivalencestate surname firstname accept refuse infos';" v-if="requestType === 'inscription'"> | ||||||
|  |           <!-- | ||||||
|  |             The condition below avoids an error occuring because loadRequests() finishes after the vue refresh | ||||||
|  |             then submissionDate is undefined an it triggers an error in the console despite the fact that it is working | ||||||
|  |             properly at the end. | ||||||
|  |            --> | ||||||
|  |           <div class="date" v-if="item.submissionDate !== undefined">{{item.submissionDate.slice(0, 10)}}</div> | ||||||
|  |           <div class="state" style="font-size: 80%">Approval : {{item.state}}</div> | ||||||
|  |           <div class="equivalencestate" style="font-size: 80%">Teacher approval : {{item.equivalenceState}}</div> | ||||||
|  |           <div class="surname">{{item.lastName}}</div> | ||||||
|  |           <div class="firstname">{{item.firstName}}</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="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="infos"><button style="background-color:rgb(105,05,105);" @click="targetId=item.id;windowsState=1;">{{i18n("request.moreInfos")}}</button></div> | ||||||
|  |         </div> | ||||||
|  |         <div class="container" style="grid-template-columns:25% 15% 15% 25% 14.2%;grid-template-areas:'date reqState studentfirstname studentlastname  infos';" v-if="requestType === 'scholarship'"> | ||||||
|  |           <div class="date" v-if="item.date !== undefined"> {{item.date.slice(0,10)}}</div> | ||||||
|  |           <div class="studentfirstname">{{item.user.firstName}}</div> | ||||||
|  |           <div class="studentlastname">{{item.user.lastName}}</div> | ||||||
|  |           <div class="reqState">{{item.state}}</div> | ||||||
|  |           <div class="infos" @click="windowsState = 3; targetId=item.id;"><button>More infos</button></div> | ||||||
|  |         </div> | ||||||
|  |         <div class="container" style="grid-template-columns:17% 15% 12% 15% 25%;grid-template-areas:'date reqState studentfirstname studentlastname course infos';"v-if="requestType === 'exemption'"> | ||||||
|  |           <div class="date" v-if="item.date != undefined">{{item.date.slice(0,10)}}</div> | ||||||
|  |           <div class="studentfirstname">{{item.user.firstName}}</div> | ||||||
|  |           <div class="studentlastname">{{item.user.lastName}}</div> | ||||||
|  |           <div class="course">{{item.course.title}}</div> | ||||||
|  |           <div class="reqState">{{item.state}}</div> | ||||||
|  |           <div class="infos"><button @click="windowsState=6;targetId=item.id">More infos</button></div> | ||||||
|  |         </div> | ||||||
|  |         <div class="container" v-if="requestType === 'unregister'" style="grid-template-columns:17% 15% 12% 15%;grid-template-areas:'date reqState regno studentfirstname studentlastname infos';"> | ||||||
|  |           <div class="date" v-if="item.date != undefined">{{item.date.slice(0,10)}}</div> | ||||||
|  |           <div class="studentfirstname">{{item.firstName}}</div> | ||||||
|  |           <div class="studentlastname">{{item.lastName}}</div> | ||||||
|  |           <div class="regno">id : {{item.regNo}}</div> | ||||||
|  |           <div class="reqState">{{item.state}}</div> | ||||||
|  |           <div class="infos"><button @click="windowsState=4;targetId=item.id">More infos</button></div> | ||||||
|  |         </div> | ||||||
|  |         <div class="container" v-if="requestType === 'curriculum change'" style="grid-template-columns:17% 20% 15% 5%;grid-template-areas:'date reqState teacherApproval regno studentfirstname studentlastname infos';"> | ||||||
|  |           <div class="date" v-if="item.date != undefined">{{item.date.slice(0,10)}}</div> | ||||||
|  |           <div class="studentfirstname">{{item.user.firstName}}</div> | ||||||
|  |           <div class="studentlastname">{{item.user.lastName}}</div> | ||||||
|  |           <div class="reqState">IS approval : {{item.state}}</div> | ||||||
|  |           <div class="teacherApproval">Teacher approval : {{item.teacherApprovalState}}</div> | ||||||
|  |           <div class="infos"><button @click="windowsState=5;targetId=item.id">More infos</button></div> | ||||||
|  |         </div> | ||||||
|  |       </div> | ||||||
|  |     </div> | ||||||
|  |   </div> | ||||||
|  |   <div style='display:flex; justify-content:center; min-width:1140px;margin-top: 10%' 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> | ||||||
|  |   <div v-if="windowsState === 3"> | ||||||
|  |     <AboutScholarship :req-id="targetId"></AboutScholarship> | ||||||
|  |     <div> | ||||||
|  |       <button style="margin-left: 30%" @click="loadRequests();windowsState=0">Back</button> | ||||||
|  |     </div> | ||||||
|  |   </div> | ||||||
|  |   <div v-if="windowsState === 4"> | ||||||
|  |     <AboutUnregister :req-id="targetId"></AboutUnregister> | ||||||
|  |     <button @click="windowsState=0">Back</button> | ||||||
|  |   </div> | ||||||
|  |   <div v-if="windowsState === 5"> | ||||||
|  |     <AboutChangeCurriculum :req-id="targetId" v-model:window-state="windowsState"></AboutChangeCurriculum> | ||||||
|  |   </div> | ||||||
|  |   <div v-if="windowsState === 6"> | ||||||
|  |     <AboutExemption :req-id="targetId" v-model:window-state="windowsState"></AboutExemption> | ||||||
|  |   </div> | ||||||
|  | </template> | ||||||
|  |  | ||||||
|  | <style scoped> | ||||||
|  |   .container{ | ||||||
|  |     color:white; | ||||||
|  |     height:100px; | ||||||
|  |     font-size:20px; | ||||||
|  |     display:grid; | ||||||
|  |     column-gap:10px; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   .equivalencestate{ | ||||||
|  |     grid-area: equivalencestate; | ||||||
|  |     align-self: center; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   .teacherApproval{ | ||||||
|  |     grid-area: teacherApproval; | ||||||
|  |     align-self: center; | ||||||
|  |   } | ||||||
|  |   .studentfirstname{ | ||||||
|  |     grid-area: studentfirstname; | ||||||
|  |     align-self: center; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   .studentlastname{ | ||||||
|  |     grid-area: studentlastname; | ||||||
|  |     align-self: center; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   .course{ | ||||||
|  |     grid-area: course; | ||||||
|  |     align-self: center; | ||||||
|  |   } | ||||||
|  |   .reqState{ | ||||||
|  |     grid-area: reqState; | ||||||
|  |     align-self: center; | ||||||
|  |   } | ||||||
|  |   .infos { | ||||||
|  |     grid-area:infos; | ||||||
|  |     align-self:center; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   .accept{ | ||||||
|  |     grid-area:accept; | ||||||
|  |     align-self:center; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   .refuse{ | ||||||
|  |     grid-area:refuse; | ||||||
|  |     align-self:center; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   .date{ | ||||||
|  |     grid-area:date; | ||||||
|  |     margin-left:40px; | ||||||
|  |     align-self:center; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   .regno{ | ||||||
|  |     grid-area: regno; | ||||||
|  |     align-self: center; | ||||||
|  |   } | ||||||
|  |   .state{ | ||||||
|  |     grid-area:state; | ||||||
|  |     margin-left:40px; | ||||||
|  |     align-self:center; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   .surname{ | ||||||
|  |     grid-area:surname; | ||||||
|  |     align-self:center; | ||||||
|  |     white-space: nowrap; | ||||||
|  |     overflow: hidden; | ||||||
|  |     text-overflow:ellipsis; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   .firstname{ | ||||||
|  |     grid-area:firstname; | ||||||
|  |     align-self:center; | ||||||
|  |     white-space: nowrap; | ||||||
|  |     overflow: hidden; | ||||||
|  |     text-overflow:ellipsis; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   button{ | ||||||
|  |     font-size:15px; | ||||||
|  |      height:50px; | ||||||
|  |      width:100px; | ||||||
|  |     border:none; | ||||||
|  |     border-radius:20px; | ||||||
|  |  | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   .bodu { | ||||||
|  |     margin-top:2%; | ||||||
|  |     width:66%; | ||||||
|  |     border:2px solid black; | ||||||
|  |     border-radius:9px; | ||||||
|  |     background-color:rgb(50,50,50); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |  | ||||||
|  | </style> | ||||||
|  |  | ||||||
|  |  | ||||||
							
								
								
									
										77
									
								
								frontend/src/Apps/Inscription/PaymentInfo.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										77
									
								
								frontend/src/Apps/Inscription/PaymentInfo.vue
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,77 @@ | |||||||
|  | <script setup> | ||||||
|  | import i18n from "@/i18n.js"; | ||||||
|  | import {ref} from "vue"; | ||||||
|  | import {getAllPayments} from "@/rest/requests.js"; | ||||||
|  |  | ||||||
|  | const paymentsList = await getAllPayments() | ||||||
|  | </script> | ||||||
|  |  | ||||||
|  | <template style="margin-top:5%;"> | ||||||
|  |   <div style="display:flex; justify-content:center; " v-for="item in paymentsList"> | ||||||
|  |     <div class="bodu"> | ||||||
|  |       <div class="container"> | ||||||
|  |         <div class="regNo"><a style="margin-left:30px">RegNo : {{item.studentRegNo}}</a></div> | ||||||
|  |         <div class="client"><a>Client : {{item.client}}</a></div> | ||||||
|  |         <div class="amount"><a>Amount : {{item.amount}}</a></div> | ||||||
|  |         <div class="date" style="margin-left: 10%">{{item.date.slice(0,10)}}</div> | ||||||
|  |       </div> | ||||||
|  |     </div> | ||||||
|  |   </div> | ||||||
|  | </template> | ||||||
|  |  | ||||||
|  | <style scoped> | ||||||
|  | .container{ | ||||||
|  |   color:white; | ||||||
|  |   height:100px; | ||||||
|  |   font-size:30px; | ||||||
|  |   display:grid; | ||||||
|  |   grid-template-columns:20% 25% 15% 17%; | ||||||
|  |   grid-template-areas: | ||||||
|  |     "date regNo client amount"; | ||||||
|  |   column-gap:10px; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .regNo { | ||||||
|  |   grid-area:regNo; | ||||||
|  |   align-self:center; | ||||||
|  |   font-size: 70%; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .client{ | ||||||
|  |   grid-area:client; | ||||||
|  |   align-self:center; | ||||||
|  |   font-size: 70%; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .amount{ | ||||||
|  |   grid-area:amount; | ||||||
|  |   align-self:center; | ||||||
|  |   font-size: 70%; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .date{ | ||||||
|  |   grid-area:date; | ||||||
|  |   align-self:center; | ||||||
|  |   font-size: 70%; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | button{ | ||||||
|  |   font-size:15px; | ||||||
|  |   height:50px; | ||||||
|  |   width:75%; | ||||||
|  |   border:none; | ||||||
|  |   border-radius:20px; | ||||||
|  |  | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .bodu { | ||||||
|  |   margin-top:2%; | ||||||
|  |   width:66%; | ||||||
|  |   border:2px solid black; | ||||||
|  |   border-radius:9px; | ||||||
|  |   background-color:rgb(50,50,50); | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  | </style> | ||||||
|  |  | ||||||
							
								
								
									
										225
									
								
								frontend/src/Apps/LessonRequests.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										225
									
								
								frontend/src/Apps/LessonRequests.vue
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,225 @@ | |||||||
|  |  | ||||||
|  | <script setup> | ||||||
|  | import i18n from "@/i18n.js" | ||||||
|  | import {ref} from 'vue' | ||||||
|  | import {changeRequestState, getAllRequests} from "@/rest/LessonRequests.js"; | ||||||
|  | import {getLesson} from "@/rest/lessonSchedule.js"; | ||||||
|  | import {getCourse} from "@/rest/courses.js" | ||||||
|  | import {formatDate, getHoursMinutes} from "@/scheduleFunctions.js"; | ||||||
|  |  | ||||||
|  | const requests = ref(await getAllRequests()); | ||||||
|  |  | ||||||
|  | const AcceptMod = ref(false); | ||||||
|  | const moreInfosMod = ref(false); | ||||||
|  | const requestTypes = ["Create", "Modify", "Delete"] | ||||||
|  | const editElementID = ref(''); | ||||||
|  | const chosenLocal = ref(""); | ||||||
|  | const locals = ["A0B1","A1B1","A2B1","A0B2"]; | ||||||
|  | const moreInfos = ref({}); | ||||||
|  | async function upPage(id,review){ | ||||||
|  |   await changeRequestState(id, review) ; | ||||||
|  |   requests.value = await getAllRequests(); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | async function AcceptSetup(id,type){ | ||||||
|  |   if(type !== 2 ){ | ||||||
|  |     editElementID.value = id | ||||||
|  |     AcceptMod.value = true; | ||||||
|  |   } | ||||||
|  |   else{ | ||||||
|  |     await upPage(id,{local: null,state:'Accepted'}); | ||||||
|  |   } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function editItem(item){ | ||||||
|  |   editElementID.value = item.id; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | async function setMoreInfos(item){ | ||||||
|  |      | ||||||
|  |     moreInfos.value = Object.assign({},{}) | ||||||
|  |     moreInfos.value["requestType"] = requestTypes[item.requestType] | ||||||
|  |     if(item.requestType == 0 || item.requestType == 1){ | ||||||
|  |     moreInfos.value["day"] = item.lessonStart == null ? null : formatDate(new Date(item.lessonStart)) | ||||||
|  |     moreInfos.value["start"] = item.lessonStart == null ? null : getHoursMinutes(new Date(item.lessonStart)) | ||||||
|  |     moreInfos.value["end"] = item.lessonEnd == null ? null :  getHoursMinutes(new Date(item.lessonEnd)) | ||||||
|  |     moreInfos.value["lessonType"] = item.lessonType; | ||||||
|  |     moreInfos.value["course"] = item["course"] == null ? null:item.course.title} | ||||||
|  |   if (item.requestType==1 || item.requestType == 2){ | ||||||
|  |       let temp = await getLesson(item.lessonId); | ||||||
|  |     if(item.requestType == 1 || item.requestType == 2){ | ||||||
|  |     moreInfos.value["course"] = temp.course.title; | ||||||
|  |     moreInfos.value[item.requestType == 2 ? "day" : "old_day"] =  formatDate(new Date(temp.lessonStart)); | ||||||
|  |     moreInfos.value[item.requestType == 2 ? "start" : "old_start"] = getHoursMinutes(new Date(temp.lessonStart)); | ||||||
|  |     moreInfos.value[item.requestType == 2 ? "end":"old_end"] = getHoursMinutes(new Date(temp.lessonEnd)); | ||||||
|  |     moreInfos.value[item.requestType == 2 ? "lessonType":"old_type"] = temp.lessonType; | ||||||
|  |   }} | ||||||
|  |   editElementID.value = item.id ; | ||||||
|  |   moreInfosMod.value =true; | ||||||
|  | } | ||||||
|  | </script> | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | <template> | ||||||
|  |  | ||||||
|  |     <div  class="body"> | ||||||
|  |     <div v-for="item of requests" :key="item.id" :style="{width:[moreInfosMod ? 95:70] + '%'}" class="centerer"> | ||||||
|  |  | ||||||
|  |       <button v-if="moreInfosMod && editElementID == item.id" @click="moreInfosMod = false; editElementID = ''; moreInfos='';">back</button> | ||||||
|  |       <div v-if ="item.state === 'Pending'" class="listElement"> | ||||||
|  |       <div class="containerElement" v-if="editElementID !== item.id"> | ||||||
|  |           <div class="id">{{requestTypes[item.requestType]}}</div> | ||||||
|  |           <div class="surname">{{item.state}}</div> | ||||||
|  |           <div class="firstname">{{item.user.lastName}}</div> | ||||||
|  |            | ||||||
|  |           <div class="infos"> | ||||||
|  |             <button @click=" setMoreInfos(item); console.log(item);" style="background-color:rgb(105,05,105);" > | ||||||
|  |               {{i18n("request.moreInfos")}} | ||||||
|  |             </button></div> | ||||||
|  |           <div class="accept"><button @click="AcceptSetup(item.id,item.requestType);" style="background-color:rgb(0,105,50);">{{i18n("request.accept")}}</button></div> | ||||||
|  |           <div class="refuse"><button @click="upPage(item.id,{local: null,state:'Refused'})" style="background-color:rgb(105,0,0);">{{i18n("request.refuse")}}</button></div> | ||||||
|  |         </div> | ||||||
|  |  | ||||||
|  |       <div v-else class="containerElement" style="width:auto; height:auto;"> | ||||||
|  |           <div v-if="AcceptMod" style="margin-left:20%;"> | ||||||
|  |             Local: | ||||||
|  |             <select v-model="chosenLocal"> | ||||||
|  |               <option v-for="item in locals">{{item}}</option> | ||||||
|  |             </select> | ||||||
|  |             <button @click="AcceptMod = false;upPage(item.id,{local: chosenLocal, state:'Accepted'})">Accept</button> | ||||||
|  |           </div> | ||||||
|  |           <template  v-if="moreInfosMod" v-for="(key,value) in moreInfos"> | ||||||
|  |  | ||||||
|  |             <div class="container" v-if="key != null" style="align-self:center;"> | ||||||
|  |               <div style="margin:0 auto 0 auto"> | ||||||
|  |                 {{value}}: | ||||||
|  |               {{key}} | ||||||
|  |               </div> | ||||||
|  |               </div> | ||||||
|  |           </template> | ||||||
|  |       </div> | ||||||
|  |       </div> | ||||||
|  |       </div> | ||||||
|  |   </div> | ||||||
|  | </template> | ||||||
|  |  | ||||||
|  | <style scoped> | ||||||
|  | .centerer{ | ||||||
|  |   margin:0 auto 0 auto; | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  | .containerElement{ | ||||||
|  |    justify-content:center; | ||||||
|  |    display:grid; | ||||||
|  |     grid-template-columns:10% 14.2% 19% 14.2% 14.2% 14.2% 14.2%; | ||||||
|  |   grid-template-areas: | ||||||
|  |     "id type surname firstname infos accept refuse"; | ||||||
|  |    column-gap:10px;  } | ||||||
|  |  | ||||||
|  | .container{ | ||||||
|  |   padding-left:50px; | ||||||
|  |   font-size:.8em; | ||||||
|  |   justify-content:center; | ||||||
|  |   display: grid; | ||||||
|  |   grid-template-columns: repeat(6, 1fr); | ||||||
|  |   grid-template-rows: repeat(auto-fill, 120px); | ||||||
|  |   grid-row-gap: 1em; | ||||||
|  |  | ||||||
|  |   grid-column-gap: 0.2em; | ||||||
|  |  | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .listElement{ | ||||||
|  |   min-width:625px; | ||||||
|  |   border:2px solid black; | ||||||
|  |   font-size:25px; | ||||||
|  |   color:white; | ||||||
|  |   padding:20px; | ||||||
|  |   background-color:rgb(50,50,50); | ||||||
|  |   border-radius:20px; | ||||||
|  |   margin-bottom:10px; | ||||||
|  |  | ||||||
|  | } | ||||||
|  | .infos { | ||||||
|  |   grid-area:infos; | ||||||
|  |   align-self:center; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .accept{ | ||||||
|  |   grid-area:accept; | ||||||
|  |   align-self:center; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .refuse{ | ||||||
|  |   grid-area:refuse; | ||||||
|  |   align-self:center; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .id{ | ||||||
|  |   grid-area:id; | ||||||
|  |   margin-left:40px; | ||||||
|  |   align-self:center; | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  | .surname{ | ||||||
|  |   grid-area:surname; | ||||||
|  |   align-self:center; | ||||||
|  |   white-space: nowrap; | ||||||
|  |   overflow: hidden; | ||||||
|  |   text-overflow:ellipsis; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .firstname{ | ||||||
|  |   grid-area:firstname; | ||||||
|  |   align-self:center; | ||||||
|  |   white-space: nowrap; | ||||||
|  |   overflow: hidden; | ||||||
|  |   text-overflow:ellipsis; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | button{ | ||||||
|  |   font-size:15px; | ||||||
|  |   height:50px; | ||||||
|  |   width:100px; | ||||||
|  |   border:none; | ||||||
|  |   border-radius:20px; | ||||||
|  |  | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .body { | ||||||
|  |   width:100%; | ||||||
|  |   margin-top:3.5%; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .buttonGrid{ | ||||||
|  |   display:grid; | ||||||
|  |   grid-template-columns: auto auto; | ||||||
|  |   column-gap:50px; | ||||||
|  |   grid-template-areas: | ||||||
|  |       "create delete"; | ||||||
|  | }.listTitle{ | ||||||
|  |    min-width:380px; | ||||||
|  |    display: flex; | ||||||
|  |    justify-content: center; | ||||||
|  |    align-items: center; | ||||||
|  |    width:25%; | ||||||
|  |    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; | ||||||
|  |  | ||||||
|  |    button:hover{ | ||||||
|  |      opacity:0.8; | ||||||
|  |    } | ||||||
|  |  } | ||||||
|  |  | ||||||
|  | </style> | ||||||
|  |  | ||||||
| @ -1,16 +1,18 @@ | |||||||
| <script setup> | <script setup> | ||||||
|   import {reactive, ref } from 'vue' |   import {reactive, ref } from 'vue' | ||||||
|   import i18n from '@/i18n.js' |   import i18n from '@/i18n.js' | ||||||
|   import { login , register , disconnect, isLogged} from '@/rest/Users.js' |   import {login, register, disconnect, isLogged} from '@/rest/Users.js' | ||||||
|   import { getAllCurriculums } from '@/rest/curriculum.js' |   import {getAllCurriculums, getcurriculum} from '@/rest/curriculum.js' | ||||||
|   import { uploadProfilePicture } from '@/rest/uploads.js' |   import {uploadFile, uploadProfilePicture} from '@/rest/uploads.js' | ||||||
|   import {toast} from 'vue3-toastify' |   import {toast} from 'vue3-toastify' | ||||||
|   import 'vue3-toastify/dist/index.css'; |   import 'vue3-toastify/dist/index.css'; | ||||||
|  |   import {createExternalCurriculum} from "@/rest/externalCurriculum.js"; | ||||||
|  |   import ManageCourses from "@/Apps/ManageCourses.vue"; | ||||||
|  |   import ExternalCurriculumList from "@/Apps/Inscription/ExternalCurriculumList.vue"; | ||||||
|  |  | ||||||
|   const loginPage= ref(true) |   const loginPage= ref(true) | ||||||
|   const page = ref(0) |   const page = ref(0) | ||||||
|    |  | ||||||
|   const outputs = reactive({ |   const outputs = reactive({ | ||||||
|     surname:null, |     surname:null, | ||||||
|     firstname:null, |     firstname:null, | ||||||
| @ -20,13 +22,35 @@ | |||||||
|     address:null, |     address:null, | ||||||
|     country:null, |     country:null, | ||||||
|     curriculum:null, |     curriculum:null, | ||||||
|  |     equivalenceState: "Unrequired" | ||||||
|   }) |   }) | ||||||
|  |  | ||||||
|  |   const notcompletedCheck = ref(false); | ||||||
|  |  | ||||||
|  |   const externalCurr = reactive({ | ||||||
|  |     inscriptionRequestId : null, | ||||||
|  |     school:null, | ||||||
|  |     formation :null, | ||||||
|  |     completion : null, | ||||||
|  |     startYear : null, | ||||||
|  |     endYear: null, | ||||||
|  |     justifdocUrl : null | ||||||
|  |   }) | ||||||
|  |  | ||||||
|  |   //Stores some externalCurriculums in order to upload them all at the confirmation of the registration request | ||||||
|  |   const externalCurrTab = ref([]); | ||||||
|  |  | ||||||
|   const submitValue= ref(i18n("login.guest.submit")) |   const submitValue= ref(i18n("login.guest.submit")) | ||||||
|   const passwordConfirm=ref("") |   const passwordConfirm=ref("") | ||||||
|   |   | ||||||
|   const imageSaved = ref(false) |   const imageSaved = ref(false) | ||||||
|   const ppData = ref(false) |   let ppData = "" | ||||||
|  |   let requiredCertif = false | ||||||
|  |   //Contains the id of the newly created request (useful to link the student's formations informations to the request) | ||||||
|  |   let requestId = "" | ||||||
|  |  | ||||||
|  |   const idcardfile = ref({}) | ||||||
|  |   const justifcardfile = ref({}) | ||||||
|  |  | ||||||
|   const curricula= await getAllCurriculums(); |   const curricula= await getAllCurriculums(); | ||||||
|    |    | ||||||
| @ -34,7 +58,7 @@ | |||||||
|     setTimeout(() => { |     setTimeout(() => { | ||||||
|       window.location.href="#/home"; |       window.location.href="#/home"; | ||||||
|       }, "500"); |       }, "500"); | ||||||
|  }  |   } | ||||||
|   function verifyInputs(pass){ |   function verifyInputs(pass){ | ||||||
|     if(pass==passwordConfirm.value){ |     if(pass==passwordConfirm.value){ | ||||||
|       page.value++; |       page.value++; | ||||||
| @ -50,15 +74,51 @@ | |||||||
|   disconnect(); |   disconnect(); | ||||||
|   window.location.reload();} |   window.location.reload();} | ||||||
|  |  | ||||||
|    |   async function uploadPP(arg){ | ||||||
|  |     const data = await uploadProfilePicture(arg); | ||||||
|  |     ppData = data.url; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   //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; | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   //Post the register request and return the id of the newly created request and also post the external curriculum list in the database | ||||||
|  |   async function postRegisterReq(){ | ||||||
|  |     //We upload the two files and we get their paths on the server | ||||||
|  |     const identityCardFile = await uploadFile(idcardfile.value, "IdentityCard") | ||||||
|  |     const justifFile = ref(null) | ||||||
|  |  | ||||||
|  |     if (curricula[outputs.curriculum-1].requireCertificate){ | ||||||
|  |       justifFile.value = await uploadFile(justifcardfile.value, "JustificationDocument") | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     let justif; | ||||||
|  |     if (justifFile.value !== null){ | ||||||
|  |       justif = justifFile.value.url | ||||||
|  |     }else{ | ||||||
|  |       justif = null | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     const val = await register(outputs.firstname, outputs.surname, outputs.birthday, outputs.password, outputs.email, outputs.address, outputs.country, outputs.curriculum, ppData, identityCardFile.url, new Date(), outputs.equivalenceState, justif); | ||||||
|  |  | ||||||
|  |     for (let item in externalCurrTab.value){ | ||||||
|  |       await createExternalCurriculum(val.id, externalCurrTab.value[item].school, externalCurrTab.value[item].formation, externalCurrTab.value[item].completion, externalCurrTab.value[item].startYear, externalCurrTab.value[item].endYear, externalCurrTab.value[item].justifdocUrl); | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  |  | ||||||
| </script> | </script> | ||||||
|  |  | ||||||
|  |  | ||||||
| <template style="background-color:rgba(255,255,255,0.05); border-radius:50px" > | <template> | ||||||
|       <div class='loginBox'> |     <div class="setup" v-if="page !== 4"> | ||||||
|  |       <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,14 +134,15 @@ | |||||||
|             <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> | ||||||
|           <form class="form"> |           <div class='loginBox' style="margin-top:30%; margin-bottom:50%;"> | ||||||
|  |             <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")}} | ||||||
|             </h1> |             </h1> | ||||||
| @ -115,7 +176,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 +189,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" :value="item.curriculumId">{{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++;"> | ||||||
|                   {{i18n("login.guest.submit")}} |                   {{i18n("login.guest.nextpage")}} | ||||||
|                 </button> |                 </button> | ||||||
|               </div> |               </div> | ||||||
|               <div  class="switchpage"> |               <div  class="switchpage"> | ||||||
| @ -151,22 +222,61 @@ | |||||||
|                 <a>{{i18n("login.guest.alregister")}}</a> |                 <a>{{i18n("login.guest.alregister")}}</a> | ||||||
|               </div> |               </div> | ||||||
|             </div> |             </div> | ||||||
|  |             <div v-if="page === 2"> | ||||||
|  |               <p style="color:rgb(239,60,168);">Carte d'indentité :</p> | ||||||
|  |               <label class="browser"> | ||||||
|  |                 Parcourir . . . | ||||||
|  |                 <input  type="file" @change="idcardfile = $event.target.files"> | ||||||
|  |               </label> | ||||||
|  |               <div v-if="curricula[outputs.curriculum-1].requireCertificate === true" style="margin-top: 3%; margin-bottom: 4%"> | ||||||
|  |                 <p style="color:rgb(239,60,168);">Ce cursus requiert une attestation de réussite d'un examen d'entrée</p> | ||||||
|  |                 <div style="margin-top: 2%"> | ||||||
|  |                   <p style="color:rgb(239,60,168);">Attestation:</p> | ||||||
|  |                   <label class="browser"> | ||||||
|  |                     Parcourir . . . | ||||||
|  |                     <input  type="file" @change="justifcardfile = $event.target.files"> | ||||||
|  |                   </label> | ||||||
|  |                 </div> | ||||||
|  |               </div> | ||||||
|  |               <button @click="page++;">{{i18n("login.guest.nextpage")}}</button> | ||||||
|  |  | ||||||
|  |             </div> | ||||||
|  |             <div v-if="page === 3"> | ||||||
|  |               <p> | ||||||
|  |                 Vous avez séléctionné un cursus qui possède des prérequis veuillez ajouter vos formations antérieures | ||||||
|  |                 dans l'enseignement supérieur, votre dossier sera vérifié par un membre du service d'inscription. | ||||||
|  |               </p> | ||||||
|  |               <button @click="page++">Gèrer mon parcours extérieur</button> | ||||||
|  |               <button @click="postRegisterReq();">Envoyer la demande d'inscription</button> | ||||||
|  |             </div> | ||||||
|           </form> |           </form> | ||||||
|          </div> |          </div> | ||||||
|         </div> |     </div> | ||||||
|  |   </div> | ||||||
|  |   <div v-if="page===4"> | ||||||
|  |     <ExternalCurriculumList v-model="externalCurrTab" :mode="2"></ExternalCurriculumList> | ||||||
|  |     <button style="margin-top: 2%;width: 5%; margin-left: 2%" @click="page--">Back</button> | ||||||
|  |   </div> | ||||||
| </template> | </template> | ||||||
|  |  | ||||||
| <style scoped> | <style scoped> | ||||||
|  |  | ||||||
|  | .setup { | ||||||
|  |   margin-left: auto; | ||||||
|  |   margin-right:auto; | ||||||
|  |   min-width:400px; | ||||||
|  |   width:25%; | ||||||
|  |   height:50%; | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
| .loginBox { | .loginBox { | ||||||
|   background-color: rgb(24,24,24); |   background-color: rgb(24,24,24); | ||||||
|   width: 100%; |   width: 400px; | ||||||
|   height:100%; |   display:flex; | ||||||
|   justify-content: center; |   justify-content: center; | ||||||
|   padding: 10%; |  | ||||||
|   border-radius: 5%; |   border-radius: 5%; | ||||||
|   box-shadow:0 5px 25px #000000; |   box-shadow:0 5px 25px #000000; | ||||||
|    |  | ||||||
| } | } | ||||||
| .form { | .form { | ||||||
|   position:relative; |   position:relative; | ||||||
| @ -196,20 +306,28 @@ | |||||||
|   z-index: 100; |   z-index: 100; | ||||||
|   font-family:sans-serif ;  |   font-family:sans-serif ;  | ||||||
|   color:rgb(239,60,168); |   color:rgb(239,60,168); | ||||||
|   transition:0.5; |   transition: 0.5; | ||||||
|  |  | ||||||
| } | } | ||||||
|  |  | ||||||
| .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; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | .bodu { | ||||||
|  |   margin-top:2%; | ||||||
|  |   width:50%; | ||||||
|  |   border:2px solid black; | ||||||
|  |   border-radius:9px; | ||||||
|  |   background-color:rgb(50,50,50); | ||||||
|  | } | ||||||
|  |  | ||||||
| .switchpage{ | .switchpage{ | ||||||
|   width:100px; |   width:100px; | ||||||
|   background:rgb(255, 0 255); |  | ||||||
|   border: none; |   border: none; | ||||||
|   padding-right:0; |   padding-right:0; | ||||||
|   padding-top:10px; |   padding-top:10px; | ||||||
| @ -217,7 +335,7 @@ | |||||||
|   outline:none; |   outline:none; | ||||||
|   border-radius: 4px; |   border-radius: 4px; | ||||||
|   font-size:0.8em; |   font-size:0.8em; | ||||||
|   align-self:right; |   align-self: right; | ||||||
|  |  | ||||||
| } | } | ||||||
|  |  | ||||||
| @ -232,11 +350,37 @@ 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; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .container{ | ||||||
|  |   margin-top: 2%; | ||||||
|  |   color:white; | ||||||
|  |   height:60px; | ||||||
|  |   font-size:30px; | ||||||
|  |   display:grid; | ||||||
|  |   grid-template-columns:30% 30% 20% 20%; | ||||||
|  |   grid-template-areas: | ||||||
|  |     "school formation completion edit remove"; | ||||||
|  |   column-gap:10px; | ||||||
|  | } | ||||||
|  |  | ||||||
| button:active ,.switchpage:active{ | button:active ,.switchpage:active{ | ||||||
|   opacity:0.8; |   opacity:0.8; | ||||||
|  |  | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| </style> | </style> | ||||||
|  | |||||||
| @ -17,7 +17,7 @@ | |||||||
|   const editElementID = ref("") |   const editElementID = ref("") | ||||||
|  |  | ||||||
|   function editItem(id){ |   function editItem(id){ | ||||||
|     editElementID = id; |     editElementID.value = id; | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   //Juste pour montrer le Create Mode |   //Juste pour montrer le Create Mode | ||||||
| @ -35,7 +35,6 @@ | |||||||
|     let isnull= false; |     let isnull= false; | ||||||
|       |       | ||||||
|     for(const [key, value] of Object.entries(toAdd)){ |     for(const [key, value] of Object.entries(toAdd)){ | ||||||
|       console.log(toAdd.owner); |  | ||||||
|       if(value === null){ |       if(value === null){ | ||||||
|         isnull=true; |         isnull=true; | ||||||
|       } |       } | ||||||
| @ -64,9 +63,6 @@ | |||||||
|  |  | ||||||
|   async function patchCourse(course){ |   async function patchCourse(course){ | ||||||
|     for (let element in toModify){ |     for (let element in toModify){ | ||||||
|         console.log(toModify,1) |  | ||||||
|         console.log(toModify[element],2) |  | ||||||
|        |  | ||||||
|         if (element =="owner" && (toModify[element].regNo != course.owner.regNo)){ |         if (element =="owner" && (toModify[element].regNo != course.owner.regNo)){ | ||||||
|           await alterCourse(course.courseId,{owner:toModify[element].regNo}); |           await alterCourse(course.courseId,{owner:toModify[element].regNo}); | ||||||
|         } |         } | ||||||
| @ -105,7 +101,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 +122,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 +135,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")}} | ||||||
| @ -148,7 +145,8 @@ | |||||||
|         <button @click="editElementID= '';patchCourse(item)"> {{i18n("courses.confirm")}} </button> |         <button @click="editElementID= '';patchCourse(item)"> {{i18n("courses.confirm")}} </button> | ||||||
|         <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> | ||||||
| @ -157,11 +155,11 @@ | |||||||
|       </div> |       </div> | ||||||
|       <div class="containerElement"v-else> |       <div class="containerElement"v-else> | ||||||
|         <input style="max-width:200px;" class="name" v-model="toModify.title"> |         <input style="max-width:200px;" class="name" v-model="toModify.title"> | ||||||
|         <select v-if="self.role === 'Secretary'" style="max-width:200px;" class="teacher" v-model="toModify.owner"> |         <select v-if="self.role != 'Secretary'" style="max-width:200px;" class="teacher" v-model="toModify.owner"> | ||||||
|           <option v-for="(item,index) in profList" :value='item'>{{item.lastName}}</option> |           <option v-for="(item,index) in profList" :value='item'>{{item.lastName}}</option> | ||||||
|         </select> |         </select> | ||||||
|         <div v-else class="teacher">{{item.owner.lastName}}</div>  |         <div v-else class="teacher">{{item.owner.lastName}}</div>  | ||||||
|         <input v-if="self.role==='Secretary'"style="max-width:100px;"class="credits" v-model="toModify.credits">   |         <input v-if="self.role !='Secretary'"style="max-width:100px;"class="credits" v-model="toModify.credits">   | ||||||
|         <div v-else class="credits">{{i18n("Credits")}}:{{item.credits}}</div>   |         <div v-else class="credits">{{i18n("Credits")}}:{{item.credits}}</div>   | ||||||
|       </div> |       </div> | ||||||
|     </div> |     </div> | ||||||
| @ -172,17 +170,16 @@ | |||||||
| <style scoped> | <style scoped> | ||||||
| .body { | .body { | ||||||
|     width:100%; |     width:100%; | ||||||
|     margin-bottom:10px; |     margin-top:3.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;  } | ||||||
|      |  | ||||||
|   } |  | ||||||
|    |    | ||||||
|   .name { |   .name { | ||||||
|     grid-area:name; |     grid-area:name; | ||||||
| @ -200,6 +197,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 +205,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 +254,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 +266,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; | ||||||
|  | |||||||
							
								
								
									
										278
									
								
								frontend/src/Apps/ManageOwnLessons.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										278
									
								
								frontend/src/Apps/ManageOwnLessons.vue
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,278 @@ | |||||||
|  | <script setup> | ||||||
|  | import { ref } from 'vue' | ||||||
|  | import i18n from '@/i18n.js' | ||||||
|  | import {formatDate,getHoursMinutes,sortByDate} from '../scheduleFunctions.js' | ||||||
|  | import {getOwnedLessons} from "@/rest/lessonSchedule.js"; | ||||||
|  | import {getSelf} from "@/rest/Users.js"; | ||||||
|  | import {createRequest} from "@/rest/LessonRequests.js" | ||||||
|  | import {getcurriculum} from "@/rest/curriculum.js"; | ||||||
|  | import {getAllSchedule} from "@/rest/scheduleRest.js"; | ||||||
|  |  | ||||||
|  |  | ||||||
|  | const curriculum = ref(); | ||||||
|  | const allSchedules = ref(await getAllSchedule()); | ||||||
|  | const schedule = ref(await getOwnedLessons()); | ||||||
|  | schedule.value.sort((a,b) => sortByDate(b,a)) | ||||||
|  | const createMod = ref(false); | ||||||
|  | const user = await getSelf(); | ||||||
|  | const editElementID = ref(); | ||||||
|  | const requestType = ref(0); | ||||||
|  | const currentDate = new Date(); | ||||||
|  | const types = ["TP","TD","Course","Exam"]; | ||||||
|  | const colors = {"TP":"rgb(36,175,255)","TD":"rgb(255,36,175)","Exam":"rgb(175,255,36)","Course":"rgb(255,36,175)"} | ||||||
|  | const courses = ref(); | ||||||
|  | function inFuture(lesson){ | ||||||
|  |   let toCompare = new Date(lesson.lessonStart); | ||||||
|  |   let current = new Date(); | ||||||
|  |   return (current < toCompare) | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  | async function setCourses(){ | ||||||
|  |   courses.value = (await getcurriculum(curriculum.value.curriculumId)).courses | ||||||
|  | } | ||||||
|  | function invertedFormatDate(date) { | ||||||
|  |   var d = new Date(date), | ||||||
|  |       month = '' + (d.getMonth() + 1), | ||||||
|  |       day = '' + d.getDate(), | ||||||
|  |       year = d.getFullYear(); | ||||||
|  |  | ||||||
|  |   if (month.length < 2) | ||||||
|  |     month = '0' + month; | ||||||
|  |   if (day.length < 2) | ||||||
|  |     day = '0' + day; | ||||||
|  |  | ||||||
|  |   return [year, month, day].join('-'); | ||||||
|  | } | ||||||
|  | function createLessonEvent(date,hour){ | ||||||
|  |   const str = date.concat(' ',hour); | ||||||
|  |   return new Date(str); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | const maxDate = ref(invertedFormatDate(new Date([currentDate.getMonth()<7 ? currentDate.getFullYear() : (currentDate.getFullYear())+1],7,31))); | ||||||
|  |  | ||||||
|  | const minDate = ref(invertedFormatDate((new Date()).setDate(currentDate.getDate()+1))) | ||||||
|  |  | ||||||
|  |  | ||||||
|  | const pattern = { | ||||||
|  |   "lessonId":null, | ||||||
|  |   "course": null, | ||||||
|  |   "day":null, | ||||||
|  |   "lessonStart": null, | ||||||
|  |   "lessonEnd": null, | ||||||
|  |   "lessonType": null, | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  | const patternRequest ={ | ||||||
|  |   "user": user.regNo, | ||||||
|  |   "state": "Pending", | ||||||
|  |   "requestType": 0, | ||||||
|  |   "lessonId":null, | ||||||
|  |   "lessonType":null, | ||||||
|  |   "lessonStart":null, | ||||||
|  |   "lessonEnd":null, | ||||||
|  |   "color":null, | ||||||
|  |   "course":0,} | ||||||
|  |  | ||||||
|  | const toModify = ref(Object.assign({}, pattern)); | ||||||
|  | const requestBuffer = ref(Object.assign({},patternRequest)); | ||||||
|  |  | ||||||
|  | function setModify(lesson){ | ||||||
|  |   toModify.value.lessonId = editElementID.value; | ||||||
|  |   toModify.value.day = invertedFormatDate(new Date(lesson.lessonStart)); | ||||||
|  |   toModify.value.lessonStart = getHoursMinutes(lesson.lessonStart); | ||||||
|  |   toModify.value.lessonEnd = getHoursMinutes(lesson.lessonEnd); | ||||||
|  |   toModify.value.lessonType = lesson.lessonType | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function setCreate(){ | ||||||
|  |   toModify.value = ref(Object.assign({},pattern)); | ||||||
|  |   createMod.value = !createMod.value; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | async function createLessonRequest(){ | ||||||
|  |   if(requestType.value === 0 || requestType.value === 1){ | ||||||
|  |     //modify | ||||||
|  |     requestBuffer.value.color = colors[toModify.value.lessonType] ; | ||||||
|  |     requestBuffer.value.requestType = requestType.value; | ||||||
|  |     requestBuffer.value.course = toModify.value.course; | ||||||
|  |     let start = createLessonEvent(toModify.value.day,toModify.value.lessonStart) | ||||||
|  |     let end = createLessonEvent(toModify.value.day,toModify.value.lessonEnd) | ||||||
|  |     for (let element in toModify.value){ | ||||||
|  |       if(element !== "day" && element !== "lessonStart" && element !== "lessonEnd"){ | ||||||
|  |         requestBuffer.value[element] = toModify.value[element]; | ||||||
|  |       } | ||||||
|  |       if(element === "lessonStart"){ | ||||||
|  |         requestBuffer.value.lessonStart = start; | ||||||
|  |       } | ||||||
|  |       if(element === "lessonEnd"){ | ||||||
|  |        requestBuffer.value.lessonEnd = end; | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |   } | ||||||
|  |   else if(requestType.value === 2 || requestType.value === 1) { | ||||||
|  |     //delete | ||||||
|  |     requestBuffer.value.lessonId = editElementID; | ||||||
|  |     requestBuffer.value.requestType = requestType.value; | ||||||
|  |   } | ||||||
|  |   await createRequest(requestBuffer.value); | ||||||
|  |   editElementID.value = ''; | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  | async function askChanges(i){ | ||||||
|  |   requestType.value= i; | ||||||
|  |   await createLessonRequest() | ||||||
|  | } | ||||||
|  |  | ||||||
|  | </script> | ||||||
|  |  | ||||||
|  | <template> | ||||||
|  |  | ||||||
|  |   <div class="body"> | ||||||
|  |     <div v-if="createMod"> | ||||||
|  |     <form class="listElement" style="width:40%; margin:0 auto 0 auto;"> | ||||||
|  |       <div style="margin-bottom:20px;"> | ||||||
|  |         Schedule : | ||||||
|  |         <select @change="setCourses()"v-model="curriculum"> | ||||||
|  |           <option v-for="item in allSchedules" :value='item.curriculum'>{{item.curriculum.option}}</option> | ||||||
|  |         </select> | ||||||
|  |       </div> | ||||||
|  |       <div style="margin-bottom:20px;"> | ||||||
|  |         Lesson : | ||||||
|  |         <select v-if="curriculum != null" v-model="toModify.course"> | ||||||
|  |           <option v-for="item in courses" :value='item.courseId'>{{item.title}}</option> | ||||||
|  |         </select> | ||||||
|  |       </div> | ||||||
|  |       <div style="margin-bottom:20px;"> | ||||||
|  |         Day: | ||||||
|  |         <input type="date" :min="minDate" :max="maxDate" v-model="toModify.day"> | ||||||
|  |       </div> | ||||||
|  |       <div style="margin-bottom:20px;"> | ||||||
|  |         Start: | ||||||
|  |         <input v-model="toModify.lessonStart" type="time" min="08:00" max="18:00" required /> | ||||||
|  |       </div> | ||||||
|  |       <div style="margin-bottom:20px;"> | ||||||
|  |         End: | ||||||
|  |         <input v-model="toModify.lessonEnd" type="time" min="10:00" max="20:00" required /> | ||||||
|  |       </div> | ||||||
|  |       <div style="margin-bottom:20px;"> | ||||||
|  |         Type: | ||||||
|  |         <select v-model="toModify.lessonType"> | ||||||
|  |           <option v-for="item in types" :value='item'>{{item}}</option> | ||||||
|  |         </select> | ||||||
|  |       </div> | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |       <button class="create" @click="createMod=!createMod; askChanges(0);"> {{i18n("courses.confirm")}} </button> | ||||||
|  |       <button style="float:right;" @click="createMod=!createMod">{{i18n("courses.back")}}</button> | ||||||
|  |     </form> | ||||||
|  |   </div> | ||||||
|  |  | ||||||
|  |  | ||||||
|  |      | ||||||
|  |     <button v-if="!createMod" @click="setCreate()" style="display:flex; margin:0 auto 0 auto;">Ask Create Request</button> | ||||||
|  |     <div v-if="!createMod"v-for="element in schedule" style="width:50%;margin-left:auto; margin-right:auto;" > | ||||||
|  |       <div  v-if="editElementID !== element.lessonID" style ="padding:15px 15px 15px 15px;"> | ||||||
|  |         <button  v-if="inFuture(element)" @click="editElementID = element.lessonID;setModify(element);"> | ||||||
|  |           Ask Changes | ||||||
|  |         </button> | ||||||
|  |       </div> | ||||||
|  |       <div v-else> | ||||||
|  |         <button @click="askChanges(1);"> {{i18n("courses.confirm")}} </button> | ||||||
|  |         <button @click="editElementID= '';"> {{i18n("courses.back")}} </button> | ||||||
|  |       </div> | ||||||
|  |       <div class="listElement"> | ||||||
|  |         <div  v-if="editElementID !== element.lessonID"> | ||||||
|  |           <div> | ||||||
|  |             {{element.course.title}} | ||||||
|  |           </div> | ||||||
|  |           <div>{{formatDate(element.lessonStart)}}</div> | ||||||
|  |           <div>{{getHoursMinutes(element.lessonStart)}}-{{getHoursMinutes(element.lessonEnd)}} | ||||||
|  |           </div> | ||||||
|  |           <div>{{element.local}}</div> | ||||||
|  |           <div>{{element.lessonType}}</div> | ||||||
|  |         </div> | ||||||
|  |  | ||||||
|  |         <div v-else> | ||||||
|  |           <div>{{element.course.title}}</div> | ||||||
|  |           <div style="margin-bottom:20px;"> | ||||||
|  |             Day: | ||||||
|  |             <input type="date" :min="minDate" :max="maxDate" v-model="toModify.day"> | ||||||
|  |           </div> | ||||||
|  |           <div style="margin-bottom:20px;"> | ||||||
|  |             Start: | ||||||
|  |             <input v-model="toModify.lessonStart" type="time" min="8:00" max="20:00"/> | ||||||
|  |           </div> | ||||||
|  |           <div style="margin-bottom:20px;"> | ||||||
|  |             End: | ||||||
|  |             <input v-model="toModify.lessonEnd" type="time" min="10:00" max="20:00" required /> | ||||||
|  |           </div> | ||||||
|  |           <div style="margin-bottom:20px;"> | ||||||
|  |             Type: | ||||||
|  |             <select v-model="toModify.lessonType"> | ||||||
|  |               <option v-for="item in types" :value='item'>{{item}}</option> | ||||||
|  |             </select> | ||||||
|  |           </div> | ||||||
|  |           <div style="margin-bottom:20px;"> | ||||||
|  |             Local: | ||||||
|  |             {{element.local}} | ||||||
|  |             <div  style="float:right;"> | ||||||
|  |               <button @click="askChanges(2)" class="delete"> ask Deletion </button> | ||||||
|  |             </div> | ||||||
|  |  | ||||||
|  |           </div> | ||||||
|  |         </div> | ||||||
|  |       </div> | ||||||
|  |     </div> | ||||||
|  |   </div> | ||||||
|  |  | ||||||
|  |  | ||||||
|  | </template> | ||||||
|  |  | ||||||
|  | <style scoped> | ||||||
|  | .body { | ||||||
|  |   width:100%; | ||||||
|  |   margin-top:3.5%; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .listElement{ | ||||||
|  |   min-width:625px; | ||||||
|  |   border:2px solid black; | ||||||
|  |   font-size:25px; | ||||||
|  |   color:white; | ||||||
|  |   padding:20px; | ||||||
|  |   background-color:rgb(50,50,50); | ||||||
|  |   border-radius:20px; | ||||||
|  |   margin-bottom:10px; | ||||||
|  |  | ||||||
|  | } | ||||||
|  |  | ||||||
|  | input, select{ | ||||||
|  |   padding:10px 10px 10px 10px; | ||||||
|  |   font-size:25px; | ||||||
|  |   cursor: pointer; | ||||||
|  |   border:none; | ||||||
|  |   border-radius:15px; | ||||||
|  | } | ||||||
|  | button{ | ||||||
|  |   font-size:15px; | ||||||
|  |   height:50px; | ||||||
|  |   width:100px; | ||||||
|  |   border:none; | ||||||
|  |   border-radius:20px; | ||||||
|  |  | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .delete{ | ||||||
|  |   grid-area:delete; | ||||||
|  |   background-color:rgb(200,0,0); | ||||||
|  | } | ||||||
|  |   button:hover{ | ||||||
|  |     opacity:0.8; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  | </style> | ||||||
							
								
								
									
										465
									
								
								frontend/src/Apps/ManageSchedule.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										465
									
								
								frontend/src/Apps/ManageSchedule.vue
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,465 @@ | |||||||
|  | <script setup> | ||||||
|  | import { ref } from 'vue' | ||||||
|  | import i18n from '@/i18n.js' | ||||||
|  |   import {formatDate,getHoursMinutes} from '../scheduleFunctions.js' | ||||||
|  |   import {getAllSchedule, deleteLessonFromSchedule ,getSchedule, getCurriculumSchedule,addLessonToSchedule} from "@/rest/scheduleRest.js"; | ||||||
|  |   import {getLessons , createLesson, alterLesson , deleteLesson} from "@/rest/lessonSchedule.js" | ||||||
|  |   import {getTeachers} from "@/rest/Users.js" | ||||||
|  |   import { getcurriculum} from "@/rest/curriculum.js" | ||||||
|  |  | ||||||
|  |   const trueSchedule = ref() | ||||||
|  |   const schedule = ref(); | ||||||
|  |   const lessonFinder = ref(); | ||||||
|  |   const curriculum = ref(); | ||||||
|  |   const allSchedules = ref(await getAllSchedule()); | ||||||
|  |   const filter = ref("null"); | ||||||
|  |   const subFilter = ref("null"); | ||||||
|  |   const filters = ["Type","Teacher","Course"]; | ||||||
|  |   const types = ["TP","TD","Course","Exam"]; | ||||||
|  |   const locals = ["A0B1","A1B1","A2B1","A0B2"] | ||||||
|  |   const teachers = await getTeachers() ; | ||||||
|  |   const courses = ref(); | ||||||
|  |    | ||||||
|  |   const createMod = ref(false); | ||||||
|  |   const deleteMod = ref(false); | ||||||
|  |  | ||||||
|  | const colors = {"TP":"rgb(36,175,255)","TD":"rgb(255,36,175)","Exam":"rgb(175,255,36)","Course":"rgb(255,36,175)"} | ||||||
|  | const currentDate = new Date(); | ||||||
|  |  | ||||||
|  | const editElementID = ref() | ||||||
|  |  | ||||||
|  |  | ||||||
|  | function invertedFormatDate(date) { | ||||||
|  |     var d = new Date(date), | ||||||
|  |         month = '' + (d.getMonth() + 1), | ||||||
|  |         day = '' + d.getDate(), | ||||||
|  |         year = d.getFullYear(); | ||||||
|  |  | ||||||
|  |     if (month.length < 2)  | ||||||
|  |         month = '0' + month; | ||||||
|  |     if (day.length < 2)  | ||||||
|  |         day = '0' + day; | ||||||
|  |  | ||||||
|  |     return [year, month, day].join('-'); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  | const maxDate = ref(invertedFormatDate(new Date([currentDate.getMonth()<7 ? currentDate.getFullYear() : (currentDate.getFullYear())+1],7,31))); | ||||||
|  |  | ||||||
|  | const minDate = ref(invertedFormatDate((new Date()).setDate(currentDate.getDate()+1))) | ||||||
|  |  | ||||||
|  | function createLessonEvent(date,hour){ | ||||||
|  |     const str = date.concat(' ',hour); | ||||||
|  |     return new Date(str); | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |   const pattern = { | ||||||
|  |     "course": null, | ||||||
|  |     "day":null, | ||||||
|  |     "lessonStart": null, | ||||||
|  |     "lessonEnd": null, | ||||||
|  |     "lessonType": null, | ||||||
|  |     "local": null, | ||||||
|  |     "color": null, | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   const lessonCreator = { | ||||||
|  |     "courseId" : null, | ||||||
|  |     "lessonStart":null, | ||||||
|  |     "lessonEnd":null, | ||||||
|  |     "lessonType":null, | ||||||
|  |     "local":null, | ||||||
|  |     "color":null, | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   const patternModify = { | ||||||
|  |     "day": null, | ||||||
|  |     "lessonStart": null, | ||||||
|  |     "lesssonEnd": null, | ||||||
|  |     "local":null, | ||||||
|  |     "lessonType":null, | ||||||
|  |   } | ||||||
|  |    | ||||||
|  | const toModify = ref(Object.assign({}, pattern)); | ||||||
|  |   const lessonBuffer = ref(Object.assign({}, pattern)); | ||||||
|  |   const lessonCreatorBuffer = ref(Object.assign({},lessonCreator)); | ||||||
|  |  | ||||||
|  |  | ||||||
|  |   function setModify(lesson){ | ||||||
|  |     toModify.value.day = invertedFormatDate(new Date(lesson.lessonStart)); | ||||||
|  |     toModify.value.lessonStart = getHoursMinutes(lesson.lessonStart); | ||||||
|  |     toModify.value.lessonEnd = getHoursMinutes(lesson.lessonEnd); | ||||||
|  |     toModify.value.local = lesson.local; | ||||||
|  |     toModify.value.lessonType = lesson.lessonType; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   function inFuture(lesson){ | ||||||
|  |     let toCompare = new Date(lesson.lessonStart); | ||||||
|  |     let current = new Date(); | ||||||
|  |     return (current < toCompare) | ||||||
|  | } | ||||||
|  |  | ||||||
|  | async function setCourses(){ | ||||||
|  |   courses.value = (await getcurriculum(curriculum.value.curriculumId)).courses | ||||||
|  | } | ||||||
|  |  | ||||||
|  |   function sortSchedule(){ | ||||||
|  |     schedule.value =trueSchedule.value.lessons; | ||||||
|  |     if(filter.value =="Teacher"){ | ||||||
|  |       schedule.value = sortByTeacher(schedule.value,subFilter.value); | ||||||
|  |  | ||||||
|  |     } | ||||||
|  |     else if(filter.value =="Type"){ | ||||||
|  |       schedule.value = sortByType(schedule.value,subFilter.value); | ||||||
|  |     } | ||||||
|  |     else if(filter.value =="Course"){ | ||||||
|  |       schedule.value = sortByCourse(schedule.value,subFilter.value); | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   function sortByType(lessons,type){ | ||||||
|  |     if(type == null){ | ||||||
|  |       return lessons; | ||||||
|  |     } | ||||||
|  |     const matrix = []; | ||||||
|  |     for (let element in lessons){ | ||||||
|  |       if(lessons[element].lessonType == type){ | ||||||
|  |         matrix.push(lessons[element]) | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |     return matrix | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   function sortByCourse(lessons,course){ | ||||||
|  |     if(course == null){ | ||||||
|  |       return lessons; | ||||||
|  |     } | ||||||
|  |     const matrix = []; | ||||||
|  |     for (let element in lessons){ | ||||||
|  |       if(lessons[element].course.courseId == course.courseId){ | ||||||
|  |         matrix.push(lessons[element]) | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |     return matrix | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   function sortByTeacher(lessons, teacher){ | ||||||
|  |     if(teacher == null){ | ||||||
|  |       return lessons; | ||||||
|  |     } | ||||||
|  |     const matrix = []; | ||||||
|  |     for (let element in lessons){ | ||||||
|  |       if(lessons[element].course.owner.regNo == teacher.regNo){ | ||||||
|  |         matrix.push(lessons[element]) | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |     return matrix | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |      | ||||||
|  |   async function changeSchedule(){ | ||||||
|  |       schedule.value =trueSchedule.value.lessons; | ||||||
|  |       curriculum.value = trueSchedule.value.curriculum; | ||||||
|  |            | ||||||
|  |       courses.value = (await getcurriculum(curriculum.value.curriculumId)).courses; | ||||||
|  |       filter.value = "null"; | ||||||
|  |       subFilter.value = "null" | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  async function newLesson(){ | ||||||
|  |     let isnull = false; | ||||||
|  |     if (lessonBuffer.value.lessonType != null){ | ||||||
|  |       lessonBuffer.value.color = colors[lessonBuffer.value.lessonType]; | ||||||
|  |       for(let element in lessonBuffer.value){ | ||||||
|  |         if(lessonBuffer.value[element] == null){ | ||||||
|  |           isnull=true; | ||||||
|  |           break; | ||||||
|  |         } | ||||||
|  |         } | ||||||
|  |       if(!isnull){ | ||||||
|  |  | ||||||
|  |         let start = createLessonEvent(lessonBuffer.value.day,lessonBuffer.value.lessonStart) | ||||||
|  |         let end = createLessonEvent(lessonBuffer.value.day,lessonBuffer.value.lessonEnd) | ||||||
|  |  | ||||||
|  |         lessonCreatorBuffer.value.lessonStart = start; | ||||||
|  |         lessonCreatorBuffer.value.lessonEnd = end; | ||||||
|  |         lessonCreatorBuffer.value.color = lessonBuffer.value.color; | ||||||
|  |         lessonCreatorBuffer.value.lessonType =lessonBuffer.value.lessonType; | ||||||
|  |         lessonCreatorBuffer.value.local = lessonBuffer.value.local; | ||||||
|  |         lessonCreatorBuffer.value.courseId = lessonBuffer.value.course.courseId; | ||||||
|  |          | ||||||
|  |        await createLesson(lessonCreatorBuffer.value); | ||||||
|  |  | ||||||
|  |         lessonFinder.value = await getLessons(); | ||||||
|  |  | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |     lessonBuffer.value = Object.assign({}, pattern); | ||||||
|  |     lessonFinder.value = null; | ||||||
|  |     lessonCreatorBuffer.value = Object.assign({},lessonCreator) | ||||||
|  |     trueSchedule.value = null; | ||||||
|  |  | ||||||
|  |   } | ||||||
|  |  | ||||||
|  | async function patchLesson(lesson){ | ||||||
|  |    | ||||||
|  |   for (let element in toModify.value){ | ||||||
|  |       if (element =="lessonType" && (toModify.value[element] != lesson[element])){ | ||||||
|  |         await alterLesson(lesson.lessonID,{lessonType:toModify.value[element]}); | ||||||
|  |       } | ||||||
|  |       if (element =="local" && (toModify.value[element] != lesson[element])){ | ||||||
|  |         await alterLesson(lesson.lessonID,{local:toModify.value[element]}); | ||||||
|  |       } | ||||||
|  |       if (element =="lessonStart" && (toModify.value[element] != lesson[element])){ | ||||||
|  |         await alterLesson(lesson.lessonID,{lessonStart:createLessonEvent(toModify.value.day,toModify.value[element]) | ||||||
|  | }); | ||||||
|  |       } | ||||||
|  |       if (element =="lessonEnd" && (toModify.value[element] != lesson[element])){ | ||||||
|  |         await alterLesson(lesson.lessonID,{lessonEnd:createLessonEvent(toModify.value.day,toModify.value[element]) | ||||||
|  | }); | ||||||
|  |       } | ||||||
|  |       if(element == "day" && (toModify.value[element] != invertedFormatDate(new Date(lesson.lessonStart))) ){ | ||||||
|  |          | ||||||
|  |        if(toModify.value.lessonStart == lesson.lessonStart){ | ||||||
|  |         await alterLesson(lesson.lessonID,{lessonStart:createLessonEvent(toModify.value.day,lesson.lessonStart) | ||||||
|  |       });} | ||||||
|  |        if(toModify.value.lessonEnd == lesson.lessonEnd){ | ||||||
|  |           await alterLesson(lesson.lessonID,{lessonStart:createLessonEvent(toModify.value.day,lesson.lessonStart)}); | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |        } | ||||||
|  |     toModify.value= Object.assign({},patternModify); | ||||||
|  |     trueSchedule.value = await getSchedule(trueSchedule.value.scheduleId); | ||||||
|  |     schedule.value =trueSchedule.value.lessons; | ||||||
|  |     editElementID.value= ''; | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |   async function removeLesson() { | ||||||
|  |       await deleteLessonFromSchedule(trueSchedule.value.scheduleId, editElementID.value) | ||||||
|  |       await deleteLesson(editElementID.value); | ||||||
|  |       trueSchedule.value = await getSchedule(trueSchedule.value.scheduleId); | ||||||
|  |       schedule.value =trueSchedule.value.lessons; | ||||||
|  |       editElementID.value= ''; | ||||||
|  |  | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  | </script> | ||||||
|  | <template> | ||||||
|  |   <div class="body"> | ||||||
|  |     <div class="listTitle buttonGrid"v-if="!createMod" > | ||||||
|  |       <button class="create" @click="createMod = true;">Create</button> | ||||||
|  |       <button class="delete" @click="deleteMod = !deleteMod;">{{!deleteMod ? "Delete" : "Remove Delete"}}</button> | ||||||
|  |  | ||||||
|  |     </div> | ||||||
|  |     <div v-if="createMod"> | ||||||
|  |       <form class="listElement" style="width:40%; margin:0 auto 0 auto;"> | ||||||
|  |         <div style="margin-bottom:20px;"> | ||||||
|  |          Schedule :  | ||||||
|  |           <select @change="setCourses()"v-model="curriculum"> | ||||||
|  |             <option v-for="item in allSchedules" :value='item.curriculum'>{{item.curriculum.option}}</option> | ||||||
|  |           </select> | ||||||
|  |         </div> | ||||||
|  |         <div style="margin-bottom:20px;"> | ||||||
|  |           Lesson :  | ||||||
|  |          <select v-if="curriculum != null" v-model="lessonBuffer.course"> | ||||||
|  |             <option v-for="item in courses" :value='item'>{{item.title}}</option> | ||||||
|  |           </select> | ||||||
|  |         </div> | ||||||
|  |         <div style="margin-bottom:20px;"> | ||||||
|  |           Day: | ||||||
|  |           <input type="date" :min="minDate" :max="maxDate" v-model="lessonBuffer.day"> | ||||||
|  |         </div> | ||||||
|  |         <div style="margin-bottom:20px;"> | ||||||
|  |           Start:  | ||||||
|  |           <input v-model="lessonBuffer.lessonStart" type="time" min="08:00" max="18:00" required /> | ||||||
|  |         </div> | ||||||
|  |         <div style="margin-bottom:20px;"> | ||||||
|  |           End:  | ||||||
|  |           <input v-model="lessonBuffer.lessonEnd" type="time" min="10:00" max="20:00" required /> | ||||||
|  |         </div> | ||||||
|  |         <div style="margin-bottom:20px;"> | ||||||
|  |           Type:  | ||||||
|  |           <select v-model="lessonBuffer.lessonType"> | ||||||
|  |            <option v-for="item in types" :value='item'>{{item}}</option> | ||||||
|  |           </select> | ||||||
|  |         </div> | ||||||
|  |         <div style="margin-bottom:20px;"> | ||||||
|  |           Local:  | ||||||
|  |           <select v-model="lessonBuffer.local"> | ||||||
|  |            <option v-for="item in locals" :value='item'>{{item}}</option> | ||||||
|  |           </select> | ||||||
|  |  | ||||||
|  |  | ||||||
|  |         </div> | ||||||
|  |         <div></div> | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |       <button class="create" @click="createMod=!createMod; newLesson();"> {{i18n("courses.confirm")}} </button> | ||||||
|  |       <button style="float:right;" @click="createMod=!createMod">{{i18n("courses.back")}}</button> | ||||||
|  |       </form> | ||||||
|  |     </div> | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |     <div v-if="!createMod"> | ||||||
|  |       <select @change="changeSchedule()" v-model="trueSchedule"> | ||||||
|  |         <option v-for="item in allSchedules" :value='item'>{{item.curriculum.option}}</option> | ||||||
|  |       </select> | ||||||
|  |       <select v-if="schedule != null" @change="subFilter = 'null'" v-model="filter"> | ||||||
|  |         <option :value ="null">No Filter</option> | ||||||
|  |         <option v-for="item in filters" :value="item">{{item}}</option> | ||||||
|  |       </select> | ||||||
|  |       <select @change="sortSchedule()" v-if="filter == 'Teacher'" v-model="subFilter"> | ||||||
|  |         <option :value ="null">No Filter</option> | ||||||
|  |         <option v-for="item in teachers" :value=item>{{item.lastName}}</option> | ||||||
|  |       </select> | ||||||
|  |       <select @change="sortSchedule()"  v-if="filter == 'Course'" v-model="subFilter"> | ||||||
|  |         <option :value ="null">No Filter</option> | ||||||
|  |         <option v-for="item in courses" :value=item>{{item.title}}</option> | ||||||
|  |       </select> | ||||||
|  |       <select @change="sortSchedule()" v-if="filter == 'Type'" v-model="subFilter"> | ||||||
|  |         <option :value ="null">No Filter</option> | ||||||
|  |         <option v-for="item in types" :value='item'>{{item}}</option> | ||||||
|  |       </select> | ||||||
|  |  | ||||||
|  |     </div> | ||||||
|  |     <div v-if="!createMod " :key="element.lessonID" v-for="element in schedule" style="width:50%;margin-left:auto; margin-right:auto;" > | ||||||
|  |         <div  v-if="editElementID !== element.lessonID" style ="padding:15px 15px 15px 15px;"> | ||||||
|  |         <button  v-if="inFuture(element)" @click="editElementID = element.lessonID;setModify(element);"> | ||||||
|  |         {{i18n("courses.modify")}} | ||||||
|  |         </button> | ||||||
|  |       </div> | ||||||
|  |       <div v-else> | ||||||
|  |         <button @click="patchLesson(element);"> {{i18n("courses.confirm")}} </button> | ||||||
|  |         <button @click="editElementID= '';"> {{i18n("courses.back")}} </button> | ||||||
|  |       </div> | ||||||
|  |       <div class="listElement"> | ||||||
|  |         <div  v-if="editElementID != element.lessonID"> | ||||||
|  |           <div> | ||||||
|  |           {{element.course.title}} | ||||||
|  |           </div> | ||||||
|  |           <div>{{formatDate(element.lessonStart)}}</div> | ||||||
|  |           <div>{{getHoursMinutes(element.lessonStart)}}-{{getHoursMinutes(element.lessonEnd)}} | ||||||
|  |           </div> | ||||||
|  |           <div>{{element.local}}</div> | ||||||
|  |           <div>{{element.lessonType}}</div> | ||||||
|  |         </div> | ||||||
|  |  | ||||||
|  |         <div v-else> | ||||||
|  |          <div>{{element.course.title}}</div> | ||||||
|  |         <div style="margin-bottom:20px;"> | ||||||
|  |           Day: | ||||||
|  |           <input type="date" :min="minDate" :max="maxDate" v-model="toModify.day"> | ||||||
|  |         </div> | ||||||
|  |         <div style="margin-bottom:20px;"> | ||||||
|  |           Start:  | ||||||
|  |           <input v-model="toModify.lessonStart" type="time" min="8:00" max="20:00"/> | ||||||
|  |         </div> | ||||||
|  |         <div style="margin-bottom:20px;"> | ||||||
|  |           End:  | ||||||
|  |           <input v-model="toModify.lessonEnd" type="time" min="10:00" max="20:00" required /> | ||||||
|  |         </div> | ||||||
|  |         <div style="margin-bottom:20px;"> | ||||||
|  |           Type:  | ||||||
|  |           <select v-model="toModify.lessonType"> | ||||||
|  |            <option v-for="item in types" :value='item'>{{item}}</option> | ||||||
|  |           </select> | ||||||
|  |         </div> | ||||||
|  |         <div style="margin-bottom:20px;"> | ||||||
|  |           Local:  | ||||||
|  |           <select v-model="toModify.local"> | ||||||
|  |            <option v-for="item in locals" :value='item'>{{item}}</option> | ||||||
|  |           </select> | ||||||
|  |         <div v-if="deleteMod" style="float:right;"> | ||||||
|  |             <button class="delete" @click="removeLesson(element);"> {{i18n("courses.deleteCourse")}} </button> | ||||||
|  |         </div> | ||||||
|  |          | ||||||
|  |         </div> | ||||||
|  |         </div> | ||||||
|  |       </div> | ||||||
|  |     </div> | ||||||
|  |   </div> | ||||||
|  |  | ||||||
|  |  | ||||||
|  | </template> | ||||||
|  | <style scoped> | ||||||
|  | .body { | ||||||
|  |     width:100%; | ||||||
|  |     margin-top:3.5%; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  | .listElement{ | ||||||
|  |  min-width:625px; | ||||||
|  |   border:2px solid black; | ||||||
|  |   font-size:25px; | ||||||
|  |   color:white; | ||||||
|  |   padding:20px; | ||||||
|  |   background-color:rgb(50,50,50); | ||||||
|  |   border-radius:20px; | ||||||
|  |   margin-bottom:10px; | ||||||
|  |  | ||||||
|  | } | ||||||
|  |  | ||||||
|  |   input, select{ | ||||||
|  |   padding:10px 10px 10px 10px;  | ||||||
|  |   font-size:25px; | ||||||
|  |   cursor: pointer; | ||||||
|  |   border:none; | ||||||
|  |   border-radius:15px; | ||||||
|  |   } | ||||||
|  |   button{ | ||||||
|  |     font-size:15px; | ||||||
|  |      height:50px; | ||||||
|  |      width:100px; | ||||||
|  |     border:none; | ||||||
|  |     border-radius:20px; | ||||||
|  |  | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   .buttonGrid{ | ||||||
|  |     display:grid; | ||||||
|  |     grid-template-columns: auto auto; | ||||||
|  |     column-gap:50px; | ||||||
|  |     grid-template-areas: | ||||||
|  |       "create delete"; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   .create{ | ||||||
|  |     grid-area:create; | ||||||
|  |      | ||||||
|  |     background-color:rgb(0,200,0); | ||||||
|  |  | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   .delete{ | ||||||
|  |     grid-area:delete; | ||||||
|  |     background-color:rgb(200,0,0); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   .listTitle{ | ||||||
|  |     min-width:380px; | ||||||
|  |     display: flex; | ||||||
|  |     justify-content: center; | ||||||
|  |     align-items: center; | ||||||
|  |     width:25%; | ||||||
|  |     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; | ||||||
|  |  | ||||||
|  |     button:hover{ | ||||||
|  |       opacity:0.8; | ||||||
|  |     } | ||||||
|  | } | ||||||
|  | </style> | ||||||
							
								
								
									
										213
									
								
								frontend/src/Apps/Msg.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										213
									
								
								frontend/src/Apps/Msg.vue
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,213 @@ | |||||||
|  | <!---------------------------------------------------- | ||||||
|  | 	File:  Msg.vue | ||||||
|  | 	Author: Anthony Debucquoy | ||||||
|  | 	Scope: Extension messagerie | ||||||
|  | 	Description: Main msg page | ||||||
|  | -----------------------------------------------------> | ||||||
|  |  | ||||||
|  | <script setup> | ||||||
|  | 	import { ref, reactive } from 'vue' | ||||||
|  | 	import { discussionsList, currentDiscussion, fetchDiscussion, createDiscussion, sendMessage, updateDiscussionName, invite, removeMember} from '@/rest/msg.js' | ||||||
|  |  | ||||||
|  | 	const msgContent = ref(""); | ||||||
|  | 	const addMember = ref(false); | ||||||
|  | 	const currentTitle = ref(""); | ||||||
|  |  | ||||||
|  | 	function formatTime(date){ | ||||||
|  | 		return date.getHours() + ":" + date.getMinutes() + " " + date.getDate() + "/" + date.getMonth(); | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | </script> | ||||||
|  |  | ||||||
|  | <template> | ||||||
|  | 	<div id="msg"> | ||||||
|  | 		<div id="discList"> | ||||||
|  | 			<div @click="fetchDiscussion(discussion.id).then(e => currentTitle = currentDiscussion.name)" class="discItem" v-for="discussion in discussionsList" :key="discussion.id">{{ discussion.name }}</div> | ||||||
|  | 			<button id="createDiscussion" @click="createDiscussion('New Discussion')">+</button> | ||||||
|  | 		</div> | ||||||
|  | 		<div id="discussion" v-if="currentDiscussion.length != 0"> | ||||||
|  | 			<h1 id=msgName ><input class="InputTitle" type="text" @change="updateDiscussionName(currentDiscussion.id, currentTitle)" v-model="currentTitle"></h1> | ||||||
|  | 			<div id=msgs> | ||||||
|  | 				<div class="msg" v-for="msg in currentDiscussion.msgs" :sender="msg.sender" :key="msg.id"> | ||||||
|  | 					{{ msg.content }}<br/> | ||||||
|  | 					<span class="sender"><span v-if="!msg.sender">{{ msg.author.firstName }} {{ msg.author.lastName.toUpperCase() }}</span> {{formatTime(new Date(msg.created))}}</span> | ||||||
|  | 				</div> | ||||||
|  | 			</div> | ||||||
|  | 			<div id=messageBox> | ||||||
|  | 				<input type="text" @keyup.enter="sendMessage(currentDiscussion.id, msgContent, null); msgContent = ''" v-model="msgContent"> | ||||||
|  | 				<input type="submit" @click="sendMessage(currentDiscussion.id, msgContent, null); msgContent = ''" value="send"> | ||||||
|  | 			</div> | ||||||
|  | 		</div> | ||||||
|  | 		<div id="members" v-if="currentDiscussion.length != 0"> | ||||||
|  | 			<div class="memberItem" v-for="member in currentDiscussion.members" @click="removeMember(currentDiscussion.id, member.regNo)" :key="member.id"><span>{{ member.firstName }} {{ member.lastName.toUpperCase() }}</span></div> | ||||||
|  | 			<input type=text id="addMembers" @focus="addMember = true" @blur="addMember = false;$event.target.value = ''" @change="invite(currentDiscussion.id, $event.target.value)" :placeholder="addMember ? 'Regno' : '+'"/> | ||||||
|  | 		</div> | ||||||
|  | 	</div> | ||||||
|  | </template> | ||||||
|  |  | ||||||
|  | <style scoped> | ||||||
|  |  | ||||||
|  | div#msg{ | ||||||
|  | 	position: relative; | ||||||
|  | 	width: 100%; | ||||||
|  | 	height: 100%; | ||||||
|  |  | ||||||
|  | 	display: grid; | ||||||
|  | 	grid-template-columns: 20% auto 10%; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | div#discList{ | ||||||
|  | 	margin: 30px 0 30px 30px; | ||||||
|  | 	background-color: rgba(255, 255, 255, 0.05); | ||||||
|  | 	border-radius: 10px; | ||||||
|  | 	overflow: hidden; | ||||||
|  | 	padding: 10px; | ||||||
|  | 	display: flex; | ||||||
|  | 	flex-direction: column; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | div#members{ | ||||||
|  | 	margin: 30px 0; | ||||||
|  | 	border-radius: 10px 0 0 10px; | ||||||
|  | 	background-color: red; | ||||||
|  | 	background-color: rgba(255, 255, 255, 0.05); | ||||||
|  | 	overflow: hidden; | ||||||
|  | 	display: flex; | ||||||
|  | 	padding: 10px 0 0 10px; | ||||||
|  | 	flex-direction: column; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .InputTitle{ | ||||||
|  | 	all: inherit; | ||||||
|  | 	margin: auto; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .discItem{ | ||||||
|  | 	color: darkorange; | ||||||
|  | 	display: flex; | ||||||
|  | 	font-family: sans-serif; | ||||||
|  | 	font-weight: bold; | ||||||
|  | 	height: 4vh; | ||||||
|  | 	margin: 5px; | ||||||
|  | 	border-radius: 0 30px 30px 0; | ||||||
|  | 	align-items: center; | ||||||
|  | 	justify-content: center; | ||||||
|  | 	border: 1px solid darkorange; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .memberItem{ | ||||||
|  | 	color: darkorange; | ||||||
|  | 	display: flex; | ||||||
|  | 	font-family: sans-serif; | ||||||
|  | 	font-weight: bold; | ||||||
|  | 	height: 4vh; | ||||||
|  | 	margin: 5px; | ||||||
|  | 	border-radius: 30px 0 0 30px; | ||||||
|  | 	align-items: center; | ||||||
|  | 	justify-content: center; | ||||||
|  | 	border: 1px solid darkorange; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .memberItem:hover span{ | ||||||
|  | 	display: none; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .memberItem:hover{ | ||||||
|  | 	background-color: red; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .memberItem:hover:before{ | ||||||
|  | 	color: white; | ||||||
|  | 	content: "X" | ||||||
|  | } | ||||||
|  |  | ||||||
|  | #createDiscussion{ | ||||||
|  | 	height: 4vh; | ||||||
|  | 	margin: 5px; | ||||||
|  | 	color: white; | ||||||
|  | 	background-color: green; | ||||||
|  | 	border-radius: 0 30px 30px 0; | ||||||
|  | 	border: none; | ||||||
|  | 	font-weight: 900; | ||||||
|  | 	font-size: 2em; | ||||||
|  | } | ||||||
|  | #addMembers{ | ||||||
|  | 	height: 4vh; | ||||||
|  | 	margin: 5px; | ||||||
|  | 	text-align: center; | ||||||
|  | 	color: white; | ||||||
|  | 	background-color: green; | ||||||
|  | 	border-radius: 30px 0 0 30px; | ||||||
|  | 	border: none; | ||||||
|  | 	font-weight: 900; | ||||||
|  | 	font-size: 2em; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | div#discussion{ | ||||||
|  | 	display: flex; | ||||||
|  | 	flex-direction: column; | ||||||
|  | 	margin: 30px; | ||||||
|  | 	background-color: rgba(255, 255, 255, 0.05); | ||||||
|  | 	border-radius: 10px; | ||||||
|  | 	overflow: hidden; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | #msgName{ | ||||||
|  | 	text-align: center; | ||||||
|  | 	display: block; | ||||||
|  | 	background-color: #2a1981; | ||||||
|  | 	border-radius: 5px; | ||||||
|  | 	color: white; | ||||||
|  | 	width: 75%; | ||||||
|  | 	margin: 30px auto; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .discItem:hover{ | ||||||
|  | 	background-color: gray; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | #msgs{ | ||||||
|  | 	display: flex; | ||||||
|  | 	flex-grow: 1; | ||||||
|  | 	flex-direction: column; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .msg { | ||||||
|  | 	background-color: aliceblue; | ||||||
|  | 	font-family: sans-serif; | ||||||
|  | 	margin: 10px; | ||||||
|  | 	padding: 5px; | ||||||
|  | 	border-radius: 3px; | ||||||
|  | 	max-width: 50%; | ||||||
|  | 	align-self: start; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .sender{ | ||||||
|  | 	display: inline-block; | ||||||
|  | 	color: gray; | ||||||
|  | 	font-size: 0.5em; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .msg[sender=true]{ | ||||||
|  | 	background-color: darkorange; | ||||||
|  | 	align-self: end; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | #messageBox{ | ||||||
|  | 	width: 100%; | ||||||
|  | 	height: 30px; | ||||||
|  | 	background-color: white; | ||||||
|  | 	display: flex; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | #messageBox input[type="text"]{ | ||||||
|  | 	all: inherit; | ||||||
|  | 	padding: 0 10px; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | #messageBox input[type="submit"]{ | ||||||
|  | 	border: inherit; | ||||||
|  | 	padding: 0 10px; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | </style> | ||||||
| @ -1,24 +1,39 @@ | |||||||
| <script setup> | <script setup> | ||||||
|   import {reactive, ref } from 'vue' |   import {reactive, ref } from 'vue' | ||||||
|   import {getSelf,alterSelf,disconnect,deleteUser} from '../rest/Users.js' |   import {getSelf,alterSelf,disconnect,deleteUser} from '../rest/Users.js' | ||||||
|   import {getSelfCurriculum, getAllCurriculums} from '../rest/curriculum.js' |   import {getSelfCurriculum, getAllCurriculums, getSomeonesCurriculumList, getcurriculum} from '../rest/curriculum.js' | ||||||
|   import {getCourses} from "../rest/courses.js" |   import {getCourses} from "../rest/courses.js" | ||||||
|   import i18n from "@/i18n.js" |   import i18n from "@/i18n.js" | ||||||
|   import { uploadProfilePicture } from '@/rest/uploads.js' |   import {uploadFile, uploadProfilePicture} from '@/rest/uploads.js' | ||||||
|  |   import CourseList from "@/Apps/Inscription/CourseList.vue"; | ||||||
|  |   import {editMinerval, getCurrentMinerval} from "@/rest/minerval.js"; | ||||||
|  |   import {postPayment} from "@/rest/payment.js"; | ||||||
|  |   import {addUninscReq, createScholarshipRequest, postChangeCurrReq} from "@/rest/requests.js"; | ||||||
|  |   import ExternalCurriculumList from "@/Apps/Inscription/ExternalCurriculumList.vue"; | ||||||
|  |   import {getExternalCurriculumByUser} from "@/rest/externalCurriculum.js"; | ||||||
|  |  | ||||||
|   const user = ref(await getSelf()); |   const user = ref(await getSelf()); | ||||||
|   const UserCurriculum = ref("");  |   const UserCurriculum = ref("");  | ||||||
|   const curricula = ref (await getAllCurriculums()); |   const curricula = ref (await getAllCurriculums()); | ||||||
|  |   const minerv = ref({}); | ||||||
|  |   const extcurrlist = ref(await getExternalCurriculumByUser(user.value.regNo)) | ||||||
|  |  | ||||||
|   if(user.value.role === "Student"){ |   if(user.value.role === "Student"){ | ||||||
|     UserCurriculum.value = await getSelfCurriculum(); |     minerv.value = ref(await getCurrentMinerval(user.value.regNo)); | ||||||
|  |     UserCurriculum.value = await getSomeonesCurriculumList(user.value.regNo); | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   if(user.role === "Teacher"){ |   if(user.role === "Teacher"){ | ||||||
|     UserCurriculum.value = await getCourses("Teacher"); |     UserCurriculum.value = await getCourses("Teacher"); | ||||||
|   } |   } | ||||||
|   const modif = ref(false); |  | ||||||
|   const curric = ref(false); |   const sure = ref(0); | ||||||
|   const reg = ref(false); |  | ||||||
|  |   //0 base, 1 modif, 2 curriculum, 3 register, 4 courselist, 5 minerval, 6 payment, 7 scholarship, 8 scholarshipinfos, 9 unregister, 10 sure, 11 aboutunregister, 12 manage external curriculums | ||||||
|  |   const windowState = ref(0); | ||||||
|  |  | ||||||
|  |   const isChecked = ref(false); | ||||||
|  |   const reRegState = ref(0); | ||||||
|  |  | ||||||
|   const pattern = { |   const pattern = { | ||||||
|     profilPictureUrl:null, |     profilPictureUrl:null, | ||||||
| @ -34,27 +49,61 @@ | |||||||
|     id:null, |     id:null, | ||||||
|   } |   } | ||||||
|  |  | ||||||
|    |   //Used to modelize a payment | ||||||
|  |   const paymentData={ | ||||||
|  |     studentRegNo: user.value.regNo, | ||||||
|  |     date:null, | ||||||
|  |     card:null, | ||||||
|  |     client:null, | ||||||
|  |     expDate:null, | ||||||
|  |     amount: null | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   //Used to modelize a scholarship request | ||||||
|  |   const scholarshipData=reactive({ | ||||||
|  |     userId: user.value.regNo, | ||||||
|  |     state:null, | ||||||
|  |     date:null, | ||||||
|  |     amount:0, | ||||||
|  |     taxDocUrl : "", | ||||||
|  |     residencyDocUrl : "" | ||||||
|  |   }) | ||||||
|  |  | ||||||
|  |   const changecurrdata = reactive({ | ||||||
|  |     userId : user.value.regNo, | ||||||
|  |     actualcursus:null, | ||||||
|  |     newcursus:1 | ||||||
|  |   }) | ||||||
|  |  | ||||||
|  |   //Used to post a uninscription request | ||||||
|  |   const uninscriptionData = reactive({ | ||||||
|  |     reason : null, | ||||||
|  |     userId : user.value.regNo, | ||||||
|  |     curriculumId:null | ||||||
|  |   }) | ||||||
|  |   const paymentAmount = ref(0); | ||||||
|   let toModify= Object.assign({}, pattern); |   let toModify= Object.assign({}, pattern); | ||||||
|   let personnalInfos =  Object.assign({}, patternInfos); |   let personnalInfos =  Object.assign({}, patternInfos); | ||||||
|    |  | ||||||
|  |   //Used to store the year of the new cursus selected in change cursus feature | ||||||
|  |   const selectedYear = ref(0); | ||||||
|   function resetInputs(inputs,list){ |   function resetInputs(inputs,list){ | ||||||
|     inputs=Object.assign({},list);  |     inputs=Object.assign({},list);  | ||||||
|   } |   } | ||||||
|    |    | ||||||
|   async function ChangeInfos(){ |   async function ChangeInfos(){ | ||||||
|     for (let element in toModify){ |     for (let element in toModify){ | ||||||
|          if (element =="email" && (toModify[element] !== null)){ |          if (element ==="email" && (toModify[element] !== null)){ | ||||||
|           await  alterSelf(user.value.regNo,{email : toModify[element]}); |           await  alterSelf(user.value.regNo,{email : toModify[element]}); | ||||||
|         }       |         }       | ||||||
|  |  | ||||||
|         if (element =="profilPictureUrl" && (toModify[element] !== null)){ |         if (element ==="profilPictureUrl" && (toModify[element] !== null)){ | ||||||
|           await  alterSelf(user.value.regNo,{ profilPictureUrl : toModify[element]}); |           await  alterSelf(user.value.regNo,{ profilPictureUrl : toModify[element]}); | ||||||
|         } |         } | ||||||
|         else if(element == "address" && (toModify[element] !== null)){ |         else if(element === "address" && (toModify[element] !== null)){ | ||||||
|           await  alterSelf(user.value.regNo,{address : toModify[element]}); |           await  alterSelf(user.value.regNo,{address : toModify[element]}); | ||||||
|         } |         } | ||||||
|         else if(element == "password" && (toModify[element] !== null)){ |         else if(element === "password" && (toModify[element] !== null)){ | ||||||
|           await  alterSelf(user.value.regNo,{password : toModify[element]}); |           await  alterSelf(user.value.regNo,{password : toModify[element]}); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| @ -86,17 +135,75 @@ | |||||||
|     } |     } | ||||||
|     return user.profilePictureUrl |     return user.profilePictureUrl | ||||||
|   } |   } | ||||||
|  |  | ||||||
|  |   function getYear(){ | ||||||
|  |     let date = new Date(); | ||||||
|  |     if (date.getMonth() <= 6){ | ||||||
|  |       return date.getFullYear()-1 | ||||||
|  |     } | ||||||
|  |     return date.getFullYear() | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   async function refreshExtCurrList(){ | ||||||
|  |     extcurrlist.value = await getExternalCurriculumByUser(user.value.regNo) | ||||||
|  |   } | ||||||
|  |   //This function travels through the student cursus array and extract the current cursus of the student | ||||||
|  |   function getActualCurriculumList(){ | ||||||
|  |     let actualCurriculumList = []; | ||||||
|  |     for (let i = 0; i < UserCurriculum.value.curriculumList.length; i++){ | ||||||
|  |       if (UserCurriculum.value.curriculumList[i].actual === true){ | ||||||
|  |         actualCurriculumList.push(UserCurriculum.value.curriculumList[i]); | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |     return actualCurriculumList | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   async function postScholarshipRequest(file1, type1, file2, type2){ | ||||||
|  |     const a = await uploadFile(file1, type1) | ||||||
|  |     scholarshipData.taxDocUrl =  a.url; | ||||||
|  |  | ||||||
|  |     const b = await uploadFile(file2, type2) | ||||||
|  |     scholarshipData.residencyDocUrl = b.url; | ||||||
|  |  | ||||||
|  |     scholarshipData.date = Date.now(); | ||||||
|  |  | ||||||
|  |     await createScholarshipRequest(scholarshipData) | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   //1 = previous 0 = next | ||||||
|  |   function getCurriculumsNextYear(){ | ||||||
|  |     const currlist = getActualCurriculumList() | ||||||
|  |     let list = [] | ||||||
|  |  | ||||||
|  |     for (let i = 0; i < currlist.length; i++){ | ||||||
|  |       for (let j = 0; j < curricula.value.length; j++){ | ||||||
|  |         if (curricula.value[j].option === currlist[i].option && curricula.value[j].year === currlist[i].year + 1){ | ||||||
|  |           list.push(curricula.value[j]) | ||||||
|  |         } | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |     return list | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   async function getActualCurr(curr){ | ||||||
|  |     const cursus = await getcurriculum(curr); | ||||||
|  |     for (let i = 0; i < curricula.value.length; i++){ | ||||||
|  |       if (curricula.value[i].option === cursus.option && curricula.value[i].year === cursus.year - 1){ | ||||||
|  |         changecurrdata.actualcursus = curricula.value[i].curriculumId; | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  |  | ||||||
| </script> | </script> | ||||||
|  |  | ||||||
| <template> | <template> | ||||||
|   <div class="body"> |   <div class="body" v-if="windowState !== 12"> | ||||||
|   <div class="container"> |   <div class="container" v-if="windowState!==4"> | ||||||
|     <div class="profilPic"> |     <div class="profilPic" v-if="windowState===0"> | ||||||
|       <img class="subContainter" :src=getPP()> |       <img class="subContainter" :src=getPP()> | ||||||
|  |  | ||||||
|     </div> |     </div> | ||||||
|       <div class="globalInfos"> |       <div class="globalInfos"> | ||||||
|         <div v-if="modif==false && curric==false && reg==false " class="infosContainer" > |         <div v-if="windowState === 0" class="infosContainer"> | ||||||
|           <div> |           <div> | ||||||
|             {{user.firstName}} {{user.lastName}}    |             {{user.firstName}} {{user.lastName}}    | ||||||
|           </div> |           </div> | ||||||
| @ -110,24 +217,111 @@ | |||||||
|             Role:  {{i18n((user.role))}}  |             Role:  {{i18n((user.role))}}  | ||||||
|           </div> |           </div> | ||||||
|           <div> |           <div> | ||||||
|             <button @click="modif=!modif; setModify(user)"> {{i18n("profile.modify.data")}} </button> |             <button @click="windowState=1; setModify(user)"> {{i18n("profile.modify.data")}} </button> | ||||||
|           </div> |           </div> | ||||||
|           <div v-if="(user.role==='Student')"> |           <div v-if="(user.role==='Student')"> | ||||||
|             <button @click="reg=!reg">{{i18n("profile.reRegister")}}</button> |             <button @click="windowState=3">{{i18n("profile.reRegister")}}</button> | ||||||
|             <button @click="unRegister()" style="float:right;background-color:rgb(150,0,0);">{{i18n("profile.unRegister")}}</button> |             <button @click="windowState=9" style="float:right;background-color:rgb(150,0,0);">{{i18n("profile.unRegister")}}</button> | ||||||
|           </div> |           </div> | ||||||
|           <div v-if="(user.role==='Student')"> |           <div v-if="(user.role==='Student')"> | ||||||
|             <button @click="curric=!curric">{{i18n("profile.change.curriculum")}}</button> |             <button @click="windowState=2">{{i18n("profile.change.curriculum")}}</button> | ||||||
|  |             <button @click="windowState=12;refreshExtCurrList() ">Manage external curriculums</button> | ||||||
|  |           </div> | ||||||
|  |           <div v-if="(user.role==='Student')"> | ||||||
|  |             <button @click="windowState=4">Manage Courses</button> | ||||||
|  |             <button @click="windowState=5" style="margin-left: 2%">Manage minerval</button> | ||||||
|           </div> |           </div> | ||||||
|         </div> |         </div> | ||||||
|         <div v-else-if="modif" class="infosContainer"> |         <div v-else-if="windowState === 9" class="infosContainer"> | ||||||
|  |             <div v-if="sure !== 2">Please enter the reason you leave</div> | ||||||
|  |             <textarea v-if="sure !== 2" v-model="uninscriptionData.reason"></textarea> | ||||||
|  |             <div v-if="sure !== 2"> | ||||||
|  |             I only want to unregister from a specific cursus | ||||||
|  |             <input type="checkbox" v-model="isChecked"> | ||||||
|  |             </div> | ||||||
|  |             <div v-if="sure !== 2 && isChecked"> | ||||||
|  |               Please select that cursus | ||||||
|  |               <select v-model="uninscriptionData.curriculumId"> | ||||||
|  |                 <option v-for="item in getActualCurriculumList()" :value="item.curriculumId">Bac {{item.year}} {{item.option}}</option> | ||||||
|  |               </select> | ||||||
|  |             </div> | ||||||
|  |             <div v-if="sure !== 2"> | ||||||
|  |               <button @click="sure++">Submit</button> | ||||||
|  |             </div> | ||||||
|  |             <div v-if="sure==1"> | ||||||
|  |               Are you sure that you want to unregister ? | ||||||
|  |               <button @click="addUninscReq(uninscriptionData.userId, uninscriptionData.reason, uninscriptionData.curriculumId);sure++">Yes</button> | ||||||
|  |               <button @click="sure=0">No</button> | ||||||
|  |             </div> | ||||||
|  |             <p v-if="sure==2">You request has been send !</p> | ||||||
|  |         </div> | ||||||
|  |         <div v-else-if="windowState === 5" class="infosContainer"> | ||||||
|  |           <div v-if="minerv.value.toPay !== 0"> | ||||||
|  |             Payment : {{minerv.value.toPay}}€ left to pay | ||||||
|  |             <div v-if="minerv.value.paidAmount <= 50"> | ||||||
|  |               <button @click="windowState=6; paymentAmount = 50">Pay deposit (50€)</button> | ||||||
|  |             </div> | ||||||
|  |             <div> | ||||||
|  |               <button @click="windowState=6; paymentAmount = minerv.value.toPay">Pay all the rest ({{minerv.value.toPay}}€)</button> | ||||||
|  |             </div> | ||||||
|  |           </div> | ||||||
|  |           <div v-else> | ||||||
|  |             Payment : School fees have already been paid this year | ||||||
|  |           </div> | ||||||
|  |           <div> | ||||||
|  |             <button @click="windowState=7">Ask for a scholarship</button> | ||||||
|  |           </div> | ||||||
|  |         </div> | ||||||
|  |         <div v-else-if="windowState === 7" class="infosContainer"> | ||||||
|  |           <p>Please upload the required documents</p> | ||||||
|  |           <div> | ||||||
|  |             Tax justification document : | ||||||
|  |             <input type="file" @change="scholarshipData.taxDocUrl = $event.target.files"> | ||||||
|  |           </div> | ||||||
|  |           <div> | ||||||
|  |             Residency justification document : | ||||||
|  |             <input type="file" style="margin-top:2%" @change="scholarshipData.residencyDocUrl = $event.target.files"> | ||||||
|  |           </div> | ||||||
|  |           <button style="margin-top: 5%" @click="windowState=8;postScholarshipRequest(scholarshipData.taxDocUrl, 'JustificationDocument',scholarshipData.residencyDocUrl, 'JustificationDocument');">Submit scholarship request</button> | ||||||
|  |         </div> | ||||||
|  |         <div v-else-if="windowState === 8" class="infosContainer"> | ||||||
|  |           <div> | ||||||
|  |             Your request has been sent to the inscription service you will get notified when | ||||||
|  |             the request is reviewed. | ||||||
|  |           </div> | ||||||
|  |           <button @click="windowState = 0"> | ||||||
|  |             Go back to profile | ||||||
|  |           </button> | ||||||
|  |         </div> | ||||||
|  |         <div v-else-if="windowState === 6" class="infosContainer"> | ||||||
|  |           Proceed to payment of {{paymentAmount}}€ | ||||||
|  |           <div style="margin-top: 1%"> | ||||||
|  |             Client: | ||||||
|  |             <input type="text" v-model="paymentData.client"> | ||||||
|  |           </div> | ||||||
|  |           <div style="margin-top: 1%"> | ||||||
|  |             Card: | ||||||
|  |             <input type="text" v-model="paymentData.card"> | ||||||
|  |           </div> | ||||||
|  |           <div style="margin-top: 1%"> | ||||||
|  |             ExpDate: | ||||||
|  |             <input type="date" v-model="paymentData.expDate"> | ||||||
|  |           </div> | ||||||
|  |           <div style="margin-top: 1%"> | ||||||
|  |             <button @click="windowState=5;paymentData.amount=paymentAmount;paymentData.date=new Date();postPayment(paymentData);minerv.value.toPay -= paymentAmount; minerv.value.paidAmount += paymentAmount; editMinerval(minerv.value)">Process Payment</button> | ||||||
|  |           </div> | ||||||
|  |           <div> | ||||||
|  |             <button @click="windowState = 5">Back</button> | ||||||
|  |           </div> | ||||||
|  |         </div> | ||||||
|  |         <div v-else-if="windowState === 1" class="infosContainer"> | ||||||
|           <div> |           <div> | ||||||
|             {{i18n("profile.picture")}}: |             {{i18n("profile.picture")}}: | ||||||
|             <input type="file" @change="user.profilPicture = uploadProfilePicture($event.target.files);" accept="image/*"> |             <input type="file" @change="user.profilPicture = uploadProfilePicture($event.target.files);" accept="image/*"> | ||||||
|           </div> |           </div> | ||||||
|           <div> |           <div> | ||||||
|             E-mail:   |             E-mail:   | ||||||
|             <input type="mail" v-model="toModify.email" /> |             <input type="email" v-model="toModify.email" /> | ||||||
|           </div> |           </div> | ||||||
|           <div> |           <div> | ||||||
|             {{i18n("profile.address")}}: |             {{i18n("profile.address")}}: | ||||||
| @ -142,27 +336,53 @@ | |||||||
|             <input type="password" v-model="toModify.passwordConfirm"> |             <input type="password" v-model="toModify.passwordConfirm"> | ||||||
|           </div> |           </div> | ||||||
|           <div> |           <div> | ||||||
|             <button @click=" modif=!modif; ChangeInfos();">{{i18n("courses.confirm")}}</button> |             <button @click="windowState = 0; ChangeInfos();">{{i18n("courses.confirm")}}</button> | ||||||
|             <button @click="modif=!modif; resetInputs(toModify,pattern);" style="float:right;">{{i18n("courses.back")}}</button> |             <button @click="windowState = 0; resetInputs(toModify,pattern);" style="float:right;">{{i18n("courses.back")}}</button> | ||||||
|           </div> |           </div> | ||||||
|         </div> |         </div> | ||||||
|         <div v-else-if="curric" class="infosContainer"> |         <div v-else-if="windowState === 2" class="infosContainer"> | ||||||
|           <div style="height:40px;"> |           <div> | ||||||
|             {{i18n("Curriculum")}}:   |             I would like to : | ||||||
|             <select v-model="curriculum" > |             <select v-model="reRegState"> | ||||||
|               <option v-for="item in curricula" style="font-size:20px;" :value="item">{{item.option}}</option>         |               <option :value="1">Reregister in the next year of one of my cursus</option> | ||||||
|  |               <option :value="2">Register for a supplementary cursus</option> | ||||||
|  |               <option :value="3">Change from a cursus to another</option> | ||||||
|             </select> |             </select> | ||||||
|           </div> |           </div> | ||||||
|  |           <div style="height:40px;" v-if="reRegState === 3"> | ||||||
|  |             {{i18n("Curriculum")}}: | ||||||
|  |             <select v-model="changecurrdata.actualcursus" style="margin-right: 3%"> | ||||||
|  |               <option v-for="item in getActualCurriculumList()" style="font-size:20px;" :value="item.curriculumId">Bac {{item.year}} {{item.option}}</option> | ||||||
|  |             </select> | ||||||
|  |             New Curriculum : | ||||||
|  |             <select v-model="changecurrdata.newcursus"> | ||||||
|  |               <option v-for="item in curricula"  :value="item.curriculumId">Bac {{item.year}} {{item.option}}</option> | ||||||
|  |             </select> | ||||||
|  |           </div> | ||||||
|  |           <div style="height:40px;" v-if="reRegState === 2"> | ||||||
|  |             New Curriculum : | ||||||
|  |             <select v-model="changecurrdata.newcursus"> | ||||||
|  |               <option v-for="item in curricula"  :value="item.curriculumId">Bac {{item.year}} {{item.option}}</option> | ||||||
|  |             </select> | ||||||
|  |           </div> | ||||||
|  |           <div style="height:40px;" v-if="reRegState === 1"> | ||||||
|  |             New Curriculum : | ||||||
|  |             <select v-model="changecurrdata.newcursus" @change="getActualCurr(changecurrdata.newcursus);"> | ||||||
|  |               <option v-for="item in getCurriculumsNextYear()" :value="item.curriculumId">Bac {{item.year}} {{item.option}}</option> | ||||||
|  |             </select> | ||||||
|  |           </div> | ||||||
|  |           <div v-if="curricula[changecurrdata.newcursus-1].year > 1 && reRegState !== 1"> | ||||||
|  |             The cursus you selected has some prerequisites | ||||||
|  |           </div> | ||||||
|           <div> |           <div> | ||||||
|             <button @click=" curric=!curric;">{{i18n("courses.confirm")}}</button> |             <button @click=" windowState = 0;postChangeCurrReq(changecurrdata);changecurrdata.actualcursus=null;changecurrdata.newcursus=1">{{i18n("courses.confirm")}}</button> | ||||||
|             <button @click="curric=!curric; resetInputs(personnalInfos,patternInfos);" style="float:right;">{{i18n("courses.back")}}</button> |             <button @click="windowState = 0; resetInputs(personnalInfos,patternInfos);" style="float:right;">{{i18n("courses.back")}}</button> | ||||||
|           </div> |           </div> | ||||||
|         </div> |         </div> | ||||||
|         <div v-else-if="reg" class="infosContainer"> |         <div v-else-if="windowState === 3" class="infosContainer"> | ||||||
|           <div> |           <div> | ||||||
|             E-mail:   |             E-mail:   | ||||||
|             <input type="mail" v-model="toModify.email" /> |             <input type="email" v-model="toModify.email" /> | ||||||
|           </div> |           </div> | ||||||
|           <div> |           <div> | ||||||
|             ID : |             ID : | ||||||
| @ -178,43 +398,56 @@ | |||||||
|           </div> |           </div> | ||||||
|  |  | ||||||
|           <div> |           <div> | ||||||
|             <button @click=" reg=!reg;">{{i18n("courses.confirm")}}</button> |             <button @click=" windowState=0;">{{i18n("courses.confirm")}}</button> | ||||||
|             <button @click=" reg=!reg; resetInputs(personnalInfos,patternInfos);" style="float:right;">{{i18n("courses.back")}}</button> |             <button @click=" windowState=0; resetInputs(personnalInfos,patternInfos);" style="float:right;">{{i18n("courses.back")}}</button> | ||||||
|           </div> |           </div> | ||||||
|         </div> |         </div> | ||||||
|  |  | ||||||
|       </div> |       </div> | ||||||
|        |       <div v-if="windowState === 0" class="moreInfos"> | ||||||
|       <div v-if="modif==false && curric==false && reg==false "class="moreInfos"> |         <div class = "oldcursus"> | ||||||
|  |             <div class="listTitle"> | ||||||
|         <div v-if="(user.role ==='Student')"> |               Anciens Cursus | ||||||
|           <div class="listTitle"> |             </div> | ||||||
|             {{i18n("profile.course.list")}} |             <div  class="listElement"> | ||||||
|  |               <div class=" containerElement" v-for="item in UserCurriculum.curriculumList"> | ||||||
|  |                 <div class="year" v-if="item.actual === false">Bac {{item.year}}</div> | ||||||
|  |                 <div class="option" v-if="item.actual === false">{{item.option}}</div> | ||||||
|  |                 <div class="dateyear" v-if="item.actual === false">Année {{item.dateyear}}-{{item.dateyear+1}}</div> | ||||||
|  |               </div> | ||||||
|  |             </div> | ||||||
|           </div> |           </div> | ||||||
|           <div  class="listElement" v-for="item in UserCurriculum.courses"> |           <div class="actualcursus"> | ||||||
|           <div class=" containerElement"> |             <div class="listTitle"> | ||||||
|             <div class="name"> {{item.title}} </div> |               Cursus Actuel | ||||||
|             <div class="teacher">{{item.owner.lastName}}</div>  |             </div> | ||||||
|             <div class="credits">Credits:{{item.credits}}</div>   |             <div  class="listElement"> | ||||||
|  |               <div class=" containerElement" v-for="item in UserCurriculum.curriculumList" > | ||||||
|  |                 <div class="year" v-if="item.actual === true">Bac {{item.year}}</div> | ||||||
|  |                 <div class="option" v-if="item.actual === true">{{item.option}}</div> | ||||||
|  |                 <div class="dateyear" v-if="item.actual === true">Année {{item.dateyear}}-{{item.dateyear+1}}</div> | ||||||
|  |               </div> | ||||||
|  |             </div> | ||||||
|           </div> |           </div> | ||||||
|           </div> |  | ||||||
|         </div> |  | ||||||
|          |  | ||||||
|         <div> |  | ||||||
|         </div> |  | ||||||
|      |  | ||||||
|       </div> |       </div> | ||||||
|   </div> |   </div> | ||||||
|  |     <div v-if="windowState===4" style="width: 80%"> | ||||||
|  |       <CourseList :cursuslist="getActualCurriculumList()"/> | ||||||
|  |       <button style="width: 10%; margin-top: 5%" @click="windowState = 0">Return to profile</button> | ||||||
|  |     </div> | ||||||
| </div> | </div> | ||||||
|  |   <div v-if="windowState === 12"> | ||||||
|  |     <ExternalCurriculumList :ext-curr-list="extcurrlist" :mode="1"></ExternalCurriculumList> | ||||||
|  |     <button @click="windowState = 0;refreshExtCurrList()">Back to profile</button> | ||||||
|  |   </div> | ||||||
| </template> | </template> | ||||||
| <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 +455,7 @@ | |||||||
| } | } | ||||||
|  |  | ||||||
| .profilPic{ | .profilPic{ | ||||||
|  |   width:100%; | ||||||
|   grid-area:profilPic; |   grid-area:profilPic; | ||||||
| } | } | ||||||
|  |  | ||||||
| @ -239,51 +473,52 @@ | |||||||
| } | } | ||||||
|  |  | ||||||
| .moreInfos { | .moreInfos { | ||||||
|   grid-area:minfos; |   margin-top: 50%; | ||||||
|  |   display:grid; | ||||||
|  |   grid-template-rows:200px auto; | ||||||
|  |   column-gap:50px; | ||||||
|  |   row-gap:45px; | ||||||
|  |   grid-template-areas: | ||||||
|  |   "minfos minfos"; | ||||||
|  |   grid-template-columns:600px 600px; | ||||||
|  |   align-items:center; | ||||||
|  |   justify-content:center; | ||||||
|  |   margin-left: 320%; | ||||||
| } | } | ||||||
| .body { |  | ||||||
|     width:100%; |  | ||||||
|     margin-bottom:10px; |  | ||||||
|   } |  | ||||||
|  .containerElement{  |  | ||||||
|    justify-content:center; |  | ||||||
|     display:grid; |  | ||||||
|     grid-template-columns:350px 350px 200px; |  | ||||||
|     grid-template-areas: |  | ||||||
|     "name teacher credits";  |  | ||||||
|     column-gap:10px; |  | ||||||
|      |  | ||||||
|   } |  | ||||||
|    |  | ||||||
|   .name { |  | ||||||
|     grid-area:name; |  | ||||||
|     align-self:center; |  | ||||||
|   } |  | ||||||
|  |  | ||||||
|   .teacher{ |  | ||||||
|     grid-area:teacher; |  | ||||||
|     align-self:center; |  | ||||||
|   } |  | ||||||
|  |  | ||||||
|   .credits{ |  | ||||||
|     grid-area:credits; |  | ||||||
|     align-self:center; |  | ||||||
|   } |  | ||||||
|  |  | ||||||
| .listTitle{ | .listTitle{ | ||||||
|     display: flex; |   display: flex; | ||||||
|     justify-content: center; |   justify-content: center; | ||||||
|     align-items: center; |   align-items: center; | ||||||
|     width:200px; |   width:250px; | ||||||
|     margin-left:auto; |   margin-left:auto; | ||||||
|     margin-right:auto; |   margin-right:auto; | ||||||
|     border:2px solid black; |   border:2px solid black; | ||||||
|     font-size:25px; |   font-size:25px; | ||||||
|     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; | ||||||
| } | } | ||||||
|  | .body { | ||||||
|  |     min-width:960px; | ||||||
|  |     width:100%; | ||||||
|  |     display:flex; | ||||||
|  |     align-items:center; | ||||||
|  |     justify-content:center; | ||||||
|  |     margin-top:7%; | ||||||
|  |   } | ||||||
|  |  .containerElement{ | ||||||
|  |    justify-content:center; | ||||||
|  |    display:grid; | ||||||
|  |    grid-template-columns:100px 100px 300px; | ||||||
|  |    grid-template-areas: | ||||||
|  |     "year option dateyear"; | ||||||
|  |    column-gap:40px; | ||||||
|  |    padding-left: 25px; | ||||||
|  |      | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |  | ||||||
| .listElement{ | .listElement{ | ||||||
|   border:2px solid black; |   border:2px solid black; | ||||||
| @ -296,6 +531,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; | ||||||
|  | |||||||
							
								
								
									
										775
									
								
								frontend/src/Apps/Schedule.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										775
									
								
								frontend/src/Apps/Schedule.vue
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,775 @@ | |||||||
|  | <script setup> | ||||||
|  |   import { ref } from 'vue' | ||||||
|  |   import {getDifferenceTime,lastDateOfMonth,formatDate,getFirstDay,sortByDate,matrixFromList,sundayToTheEnd,getMarginTop,getHoursMinutes, monthFromList} from '../scheduleFunctions.js' | ||||||
|  |   import {getAllSchedule} from "@/rest/scheduleRest.js"; | ||||||
|  |   import {getOnesLessons, getOwnedLessons } from "@/rest/lessonSchedule.js" | ||||||
|  |   import {isLogged, getSelf,getTeachers} from "@/rest/Users.js" | ||||||
|  |  | ||||||
|  |   const trueSchedule = ref() | ||||||
|  |   const log = await isLogged(); | ||||||
|  |   const schedule = ref(); | ||||||
|  |   const importedJSON = ref();   | ||||||
|  |   const jsonSchedule = ref(); | ||||||
|  |   const jsonMod = ref(false); | ||||||
|  |   const curriculum = ref(); | ||||||
|  |   const shift = ref(getFirstDay(new Date()).getDay()); | ||||||
|  |   let value = 1; | ||||||
|  |   let done = false; | ||||||
|  |   const len = ref(lastDateOfMonth(new Date())); | ||||||
|  |   const scheduleByWeek = ref(); | ||||||
|  |   const month = ref(); | ||||||
|  |   const mondayOfWeek =ref(getMonday(new Date())) | ||||||
|  |   const currentDate = ref(new Date()) | ||||||
|  |   const allSchedules = await getAllSchedule(); | ||||||
|  |   let counter = 0; | ||||||
|  |   const ownSchedule = ref(); | ||||||
|  |   const filter = ref("null"); | ||||||
|  |   const subFilter = ref("null"); | ||||||
|  |   const focus = ref(); | ||||||
|  |   const focusLessons = ref(); | ||||||
|  |   let user; | ||||||
|  |    | ||||||
|  |   if(log){ | ||||||
|  |     user = await getSelf(); | ||||||
|  |     if(user.role == "Admin" || user.role == "Secretary" || user.role == "InscriptionService"){ | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     else{ | ||||||
|  |  | ||||||
|  |       if(user.role == "Teacher"){ | ||||||
|  |          ownSchedule.value  = await getOwnedLessons();  | ||||||
|  |       } | ||||||
|  |  | ||||||
|  |       if(user.role == "Student"){ | ||||||
|  |         ownSchedule.value = await getOnesLessons();} | ||||||
|  |  | ||||||
|  |       schedule.value = ownSchedule.value; | ||||||
|  |  | ||||||
|  |       schedule.value.sort((a,b) => sortByDate(a,b)); | ||||||
|  |       scheduleByWeek.value = sundayToTheEnd(matrixFromList(schedule.value,mondayOfWeek.value)); | ||||||
|  |       month.value = monthFromList(schedule.value,new Date().getMonth()); | ||||||
|  |        | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |  | ||||||
|  |     | ||||||
|  |   const display =ref("Week"); | ||||||
|  |   const format = ref("Grid"); | ||||||
|  |    | ||||||
|  |   const filters = ["Type","Teacher","Course"]; | ||||||
|  |   const types = ["TP","TD","Course","Exam"]; | ||||||
|  |   const teachers = await getTeachers() ; | ||||||
|  |   const courses = ref(); | ||||||
|  |   if(curriculum.value != null){ | ||||||
|  |     courses.value = curriculum.value.courses; | ||||||
|  |   } | ||||||
|  |   const days = ["Lundi","Mardi","Mercredi","Jeudi","Vendredi","Samedi","Dimanche"]; | ||||||
|  |   const months = ["Janvier","Fevrier","Mars","Avril",'Mai',"Juin","Juillet","Aout","Septembre","Octobre","Novembre","Decembre"] | ||||||
|  |   const firstDayOfMonth = ref(getFirstDay(new Date())) | ||||||
|  |   const monthDone = ref(false); | ||||||
|  |   function getMonday(d) { | ||||||
|  |     d = new Date(d); | ||||||
|  |     d.setHours(0,0,0); | ||||||
|  |     var day = d.getDay(), | ||||||
|  |     diff = d.getDate() - day + (day == 0 ? -6 : 1); | ||||||
|  |     return new Date(d.setDate(diff)); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   function getAnyDays(d){ | ||||||
|  |     var day = new Date(mondayOfWeek.value); | ||||||
|  |     day.setDate(day.getDate() + d ); | ||||||
|  |     return day; | ||||||
|  |   } | ||||||
|  |    | ||||||
|  |  | ||||||
|  |   function verifUser(){ | ||||||
|  |     if(log) | ||||||
|  |       return (user.role == "Student" || user.role == "Teacher"); | ||||||
|  |     return false | ||||||
|  |   } | ||||||
|  |   function isNotCourse(element){ | ||||||
|  |     return element==null; | ||||||
|  |   } | ||||||
|  |    | ||||||
|  |  | ||||||
|  |   function durationCourse(element){ | ||||||
|  |     const hour = element.lessonEnd.substring(3,5) -element.lessonStart.substring(3,5); | ||||||
|  |     return (element.lessonEnd - element.lessonStart)%2; | ||||||
|  |   } | ||||||
|  |    | ||||||
|  |   function displayOwnSchedule(){ | ||||||
|  |     schedule.value = ownSchedule.value; | ||||||
|  |     scheduleByWeek.value = sundayToTheEnd(matrixFromList(schedule.value,mondayOfWeek.value)); | ||||||
|  |       month.value = monthFromList(schedule.value,currentDate.value.getMonth()); | ||||||
|  |       value = 1; | ||||||
|  |       counter=0; | ||||||
|  |       done = false; | ||||||
|  |  | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   function createJSON(){ | ||||||
|  |     const json = {"data":[]}; | ||||||
|  |     for(let element in schedule.value){ | ||||||
|  |       let item = {}; | ||||||
|  |       item["title"] = schedule.value[element].course.title + "\n" + schedule.value[element].course.owner.lastName+ "\n" + schedule.value[element].local  | ||||||
|  |       item["start"] = schedule.value[element].lessonStart; | ||||||
|  |       item["end"] = schedule.value[element].lessonEnd; | ||||||
|  |       item["color"] = schedule.value[element].color; | ||||||
|  |       json.data.push(item) | ||||||
|  |     } | ||||||
|  |     return json | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   function exportJSON(){ | ||||||
|  |     let json = createJSON(); | ||||||
|  |     const data = JSON.stringify(json); | ||||||
|  |     const blob = new Blob([data], {type:"application/json"}); | ||||||
|  |     const a = document.createElement('a'); | ||||||
|  |           a.href = URL.createObjectURL(blob); | ||||||
|  |           a.download = "Schedule.json"; | ||||||
|  |           a.click(); | ||||||
|  |  | ||||||
|  |   } | ||||||
|  |     function onFileChange(e) { | ||||||
|  |      let files = e.target.files || e.dataTransfer.files; | ||||||
|  |      if (!files.length) return; | ||||||
|  |       readFile(files[0]); | ||||||
|  |    } | ||||||
|  |    function readFile(file) { | ||||||
|  |      let reader = new FileReader(); | ||||||
|  |      reader.onload = e => { | ||||||
|  |        let json = JSON.parse(e.target.result); | ||||||
|  |       importedJSON.value = json | ||||||
|  |      createScheduleFromJSON(); | ||||||
|  |       jsonMod.value= true; | ||||||
|  |      }; | ||||||
|  |      reader.readAsText(file); | ||||||
|  |         | ||||||
|  |     | ||||||
|  |    } | ||||||
|  |    | ||||||
|  |   function createScheduleFromJSON(){ | ||||||
|  |     let jsonBrut = importedJSON.value; | ||||||
|  |     let toEventList = []; | ||||||
|  |     for(let element in jsonBrut["data"]){ | ||||||
|  |       let temp = {} | ||||||
|  |       temp["title"] = jsonBrut["data"][element].title; | ||||||
|  |       temp["lessonStart"] = jsonBrut["data"][element].start; | ||||||
|  |       temp["lessonEnd"] = jsonBrut["data"][element].end; | ||||||
|  |       temp["color"] = jsonBrut["data"][element].color; | ||||||
|  |       toEventList.push(temp); | ||||||
|  |     } | ||||||
|  |     jsonSchedule.value = toEventList; | ||||||
|  |     scheduleByWeek.value = sundayToTheEnd(matrixFromList(jsonSchedule.value,mondayOfWeek.value)); | ||||||
|  |     month.value = monthFromList(jsonSchedule.value,new Date().getMonth()); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   function switchToJSON(){ | ||||||
|  |     jsonMod.value = true; | ||||||
|  |     scheduleByWeek.value = sundayToTheEnd(matrixFromList(jsonSchedule.value,mondayOfWeek.value)); | ||||||
|  |     month.value = monthFromList(jsonSchedule.value,new Date().getMonth()); | ||||||
|  |  | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |   function lessonFocus(element){ | ||||||
|  |     if(!jsonMod.value){ | ||||||
|  |     focus.value = element; | ||||||
|  |     var lessonsList = []; | ||||||
|  |     for (let element in schedule.value){ | ||||||
|  |       if (schedule.value[element].course.courseId == focus.value.course.courseId){ | ||||||
|  |         lessonsList.push(schedule.value[element]);   | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |       focusLessons.value = lessonsList;} | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |  | ||||||
|  |   function dateOfMonth(i){ | ||||||
|  |  | ||||||
|  |     return new Date(currentDate.value.getFullYear(),currentDate.value.getMonth(),i); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   function sortSchedule(){ | ||||||
|  |     schedule.value =trueSchedule.value.lessons; | ||||||
|  |     if(filter.value =="Teacher"){ | ||||||
|  |       schedule.value = sortByTeacher(schedule.value,subFilter.value); | ||||||
|  |       scheduleByWeek.value = sundayToTheEnd(matrixFromList(schedule.value,mondayOfWeek.value)); | ||||||
|  |       month.value = monthFromList(schedule.value,currentDate.value.getMonth()); | ||||||
|  |       value = 1; | ||||||
|  |       counter=0; | ||||||
|  |  | ||||||
|  |  | ||||||
|  |     } | ||||||
|  |     else if(filter.value =="Type"){ | ||||||
|  |       schedule.value = sortByType(schedule.value,subFilter.value); | ||||||
|  |       scheduleByWeek.value = sundayToTheEnd(matrixFromList(schedule.value,mondayOfWeek.value)); | ||||||
|  |       month.value = monthFromList(schedule.value,currentDate.value.getMonth()); | ||||||
|  |       value = 1; | ||||||
|  |       counter=0; | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |     } | ||||||
|  |     else if(filter.value =="Course"){ | ||||||
|  |       schedule.value = sortByCourse(schedule.value,subFilter.value); | ||||||
|  |       scheduleByWeek.value = sundayToTheEnd(matrixFromList(schedule.value,mondayOfWeek.value)); | ||||||
|  |       month.value = monthFromList(schedule.value,currentDate.value.getMonth()); | ||||||
|  |       value = 1; | ||||||
|  |       counter=0; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     if(focus.value != null){ | ||||||
|  |       lessonFocus(focus.value) | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   function sortByType(lessons,type){ | ||||||
|  |     if(type == null){ | ||||||
|  |       return lessons; | ||||||
|  |     } | ||||||
|  |     const matrix = []; | ||||||
|  |     for (let element in lessons){ | ||||||
|  |       if(lessons[element].lessonType == type){ | ||||||
|  |         matrix.push(lessons[element]) | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |     return matrix | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |  | ||||||
|  |    | ||||||
|  |  | ||||||
|  |   function sortByCourse(lessons,course){ | ||||||
|  |     if(course == null){ | ||||||
|  |       return lessons; | ||||||
|  |     } | ||||||
|  |     const matrix = []; | ||||||
|  |     for (let element in lessons){ | ||||||
|  |       if(lessons[element].course.courseId == course.courseId){ | ||||||
|  |         matrix.push(lessons[element]) | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |     return matrix | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   function sortByTeacher(lessons, teacher){ | ||||||
|  |     if(teacher == null){ | ||||||
|  |       return lessons; | ||||||
|  |     } | ||||||
|  |     const matrix = []; | ||||||
|  |     for (let element in lessons){ | ||||||
|  |       if(lessons[element].course.owner.regNo == teacher.regNo){ | ||||||
|  |         matrix.push(lessons[element]) | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |     return matrix | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |      | ||||||
|  |   async function changeSchedule(){ | ||||||
|  |       schedule.value =trueSchedule.value.lessons; | ||||||
|  |       curriculum.value = trueSchedule.value.curriculum; | ||||||
|  |            | ||||||
|  |       scheduleByWeek.value = sundayToTheEnd(matrixFromList(schedule.value,mondayOfWeek.value)); | ||||||
|  |       month.value = monthFromList(schedule.value,currentDate.value.getMonth()); | ||||||
|  |       value = 1; | ||||||
|  |       counter=0; | ||||||
|  |       done = false; | ||||||
|  |       courses.value = (await getcurriculum(curriculum.value.curriculumId)).courses; | ||||||
|  |       filter.value = "null"; | ||||||
|  |       subFilter.value = "null" | ||||||
|  |       focus.value = null; | ||||||
|  |       focusLessons.value = null; | ||||||
|  |       jsonMod.value = false; | ||||||
|  |   } | ||||||
|  |    | ||||||
|  |   function changeWeek(i){ | ||||||
|  |     const temp = getAnyDays(i); | ||||||
|  |     mondayOfWeek.value = temp; | ||||||
|  |     if(scheduleByWeek.value != null) | ||||||
|  |       if(jsonMod.value){ | ||||||
|  |         scheduleByWeek.value = sundayToTheEnd(matrixFromList(jsonSchedule.value, mondayOfWeek.value))} | ||||||
|  |       else{ | ||||||
|  |         scheduleByWeek.value = sundayToTheEnd(matrixFromList(schedule.value, mondayOfWeek.value))} | ||||||
|  |        | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   function changeMonth(i){ | ||||||
|  |     const temp = currentDate.value; | ||||||
|  |     currentDate.value = new Date( ( 0< temp.getMonth()+i < 13 ? temp.getFullYear() : temp.getFullYear()+i), (0< temp.getMonth()+i <13 ? temp.getMonth()+i :  12 ),1); | ||||||
|  |     shift.value= getFirstDay(currentDate.value).getDay(); | ||||||
|  |     len.value= lastDateOfMonth(currentDate.value); | ||||||
|  |     value = 1; | ||||||
|  |     counter = 0; | ||||||
|  |     done=false; | ||||||
|  |     if(month.value != null){ | ||||||
|  |       if(jsonMod.value){ | ||||||
|  |         month.value = monthFromList(jsonSchedule.value,currentDate.value.getMonth())} | ||||||
|  |       } | ||||||
|  |     else{ | ||||||
|  |       month.value = monthFromList(schedule.value,currentDate.value.getMonth())} | ||||||
|  |    | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |  | ||||||
|  |   function isAValue(){ | ||||||
|  |     if(value-shift.value<0 ){ | ||||||
|  |       counter++; | ||||||
|  |       value++; | ||||||
|  |       return false; | ||||||
|  |     } | ||||||
|  |     if(value-shift.value<len.value){ | ||||||
|  |       value++; | ||||||
|  |       counter++; | ||||||
|  |       return true;} | ||||||
|  |      | ||||||
|  |     if(value-shift.value==len.value){ | ||||||
|  |       done = true; | ||||||
|  |       counter++; | ||||||
|  |         | ||||||
|  |        | ||||||
|  |       if(counter> 35){ | ||||||
|  |         counter=1; | ||||||
|  |         value = 2; | ||||||
|  |         done = false; | ||||||
|  |         return true; } | ||||||
|  |       return false; | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | </script> | ||||||
|  | <template> | ||||||
|  |   <div class="grid"> | ||||||
|  |     <div class="schedule" v-if="format == 'Grid'"> | ||||||
|  |     <template v-if="display=='Week'"> | ||||||
|  |       <table class="table"> | ||||||
|  |         <tr style="background-color:rgb(24,24,24)"> | ||||||
|  |           <th> | ||||||
|  |             <button @click="changeWeek(-7)">Previous</button> | ||||||
|  |             <button @click="changeWeek(7)">Next</button> | ||||||
|  |             <button @click="mondayOfWeek = getMonday(new Date());  | ||||||
|  |                 scheduleByWeek != null ? scheduleByWeek = sundayToTheEnd(matrixFromList(schedule.value, mondayOfWeek)) : null;">Current</button> | ||||||
|  |              | ||||||
|  |           </th> | ||||||
|  |           <th class="header" v-for='d,index in 7' > | ||||||
|  |             <p class="childHeader"> | ||||||
|  |             {{days[index]}}              | ||||||
|  |             </p> | ||||||
|  |             <p class="childHeader"> | ||||||
|  |               {{formatDate(getAnyDays(index))}} | ||||||
|  |             </p> | ||||||
|  |           </th> | ||||||
|  |            | ||||||
|  |  | ||||||
|  |         </tr> | ||||||
|  |         <tr v-for="(n,index) in 12"> | ||||||
|  |           <th class="hour">{{8 + index}}:00-{{9+index}}:00</th> | ||||||
|  |             <td v-for="m in 7"></td> | ||||||
|  |         </tr> | ||||||
|  |         </table> | ||||||
|  |       <div v-if="scheduleByWeek != null " class="courseGrid"> | ||||||
|  |         <div class="dayCourse" v-for="element in scheduleByWeek"> | ||||||
|  |           <template v-for="i,index in element.length"> | ||||||
|  |               <div class="course" @click.native="lessonFocus(element[index])" v-bind:style="{background:element[index].color, | ||||||
|  |  | ||||||
|  |               height:((getDifferenceTime(element[index].lessonEnd,element[index].lessonStart)/7.2)-0.5)+'%', top:((getMarginTop(element, index, index-1)/7.20))+'%'}">       | ||||||
|  |               <div class="hourStart"> | ||||||
|  |                 {{getHoursMinutes(element[index].lessonStart)}} | ||||||
|  |  | ||||||
|  |               </div> | ||||||
|  |               <div class="infos"> | ||||||
|  |                 <p class="childInfos" >{{jsonMod ? element[index].title : element[index].course.title}}</p> | ||||||
|  |                 <p class="childInfos"v-if="!jsonMod">{{element[index].local}}</p> | ||||||
|  |                 <p class="childInfos"v-if="!jsonMod">{{element[index].lessonType}}</p> | ||||||
|  |                 <p class="childInfos"v-if="!jsonMod">{{element[index].course.owner.lastName}}</p> | ||||||
|  |  | ||||||
|  |               </div>  | ||||||
|  |               <div class="hourEnd"> | ||||||
|  |                 {{getHoursMinutes(element[index].lessonEnd)}} | ||||||
|  |               </div> | ||||||
|  |            </div> | ||||||
|  |           </template> | ||||||
|  |         </div> | ||||||
|  |       </div> | ||||||
|  |       </template> | ||||||
|  |  | ||||||
|  |       <template v-else> | ||||||
|  |         <table class="table"> | ||||||
|  |           <tr style="background-color:rgb(24,24,24); height:8.33%;"> | ||||||
|  |             <th colspan="7" class="header"> | ||||||
|  |               <div>{{months[currentDate.getMonth()]}} {{currentDate.getFullYear()}}</div>             | ||||||
|  |             <button style="position:absolute; top:0; left:0;" @click="changeMonth(-1)">previous</button> | ||||||
|  |             <button  style="position:absolute; bottom:0; left:0;"@click="changeMonth(1)">next</button> | ||||||
|  |  | ||||||
|  |             </th> | ||||||
|  |  | ||||||
|  |           </tr> | ||||||
|  |           <tr style="background-color:rgb(24,24,24); height:8.33%;" > | ||||||
|  |           <th class="header"  v-for='d,index in 7' > | ||||||
|  |             {{days[index]}}              | ||||||
|  |           </th> | ||||||
|  |           </tr> | ||||||
|  |           <tr v-for="n in 5" style="height:16.67%;"> | ||||||
|  |             <td v-for="m,i in 7" style="height:16.67%; position:relative;"> | ||||||
|  |               <div v-if="isAValue()" style="top:0; right:2%; border-radius:20%;color:rgb(200,200,200) ; position:absolute;z-index:50;">{{value-shift}}</div>           | ||||||
|  |               <div v-if="month != null" style="overflow-y:scroll; height:100%;" > | ||||||
|  |               <template v-for="element in month[value-shift]"> | ||||||
|  |                   <div v-if="!done"class="course" @click.native="lessonFocus(element)" v-bind:style="{background:element.color, height:100+'%'}"> | ||||||
|  |                    | ||||||
|  |               <div class="hourStart"> | ||||||
|  |                 {{getHoursMinutes(element.lessonStart)}} | ||||||
|  |               </div> | ||||||
|  |               <div class="infos"> | ||||||
|  |                 <p class="childInfos" >{{jsonMod ? element.title : element.course.title}}</p> | ||||||
|  |                 <p class="childInfos"v-if="!jsonMod">{{element.local}}</p> | ||||||
|  |                 <p class="childInfos"v-if="!jsonMod">{{element.lessonType}}</p> | ||||||
|  |                 <p class="childInfos"v-if="!jsonMod">{{element.course.owner.lastName}}</p> | ||||||
|  |  | ||||||
|  |               </div>  | ||||||
|  |               <div class="hourEnd"> | ||||||
|  |                 {{getHoursMinutes(element.lessonEnd)}} | ||||||
|  |               </div> | ||||||
|  |               </div> | ||||||
|  |               </template> | ||||||
|  |               </div> | ||||||
|  |             </td> | ||||||
|  |         </tr>  | ||||||
|  |         </table> | ||||||
|  |       </template> | ||||||
|  |     </div> | ||||||
|  |     <div class="schedule" v-else> | ||||||
|  |        | ||||||
|  |       <div v-if="display == 'Week'"> | ||||||
|  |         <button @click="changeWeek(-7)">Previous</button> | ||||||
|  |       <button @click="changeWeek(7)">Next</button> | ||||||
|  |       <button @click="mondayOfWeek = getMonday(new Date());  | ||||||
|  |                 scheduleByWeek != null ? scheduleByWeek = sundayToTheEnd(matrixFromList(schedule.value, mondayOfWeek)) : null;">Current</button> | ||||||
|  |              | ||||||
|  |  | ||||||
|  |         <template  v-for="i,index in 7"> | ||||||
|  |           <div class="body" style="background-color:#181818;">{{days[index]}} {{formatDate(getAnyDays(index))}} | ||||||
|  | </div> | ||||||
|  |           <template v-if="scheduleByWeek != null"> | ||||||
|  |           <div class="body" style="background-color:#353535;" > | ||||||
|  |           <div  class="containerList"v-for="n,j in scheduleByWeek[index].length"  @click.native="lessonFocus(scheduleByWeek[index][j])" >     | ||||||
|  |             <div class="colorList" v-bind:style="{background:scheduleByWeek[index][j].color}"></div> | ||||||
|  |             <div class="hoursList">{{ getHoursMinutes(scheduleByWeek[index][j].lessonStart)}}-{{getHoursMinutes(scheduleByWeek[index][j].lessonEnd)}}</div> | ||||||
|  |             <div class="titleList">{{scheduleByWeek[index][j].course.title}}</div> | ||||||
|  |             <div class="teacherList">{{scheduleByWeek[index][j].course.owner.lastName}}</div> | ||||||
|  |             <div class="localList">{{scheduleByWeek[index][j].local}}</div> | ||||||
|  |             <div class="typeList">{{scheduleByWeek[index][j].lessonType}}</div> | ||||||
|  |           </div> | ||||||
|  |           </div> | ||||||
|  |           </template> | ||||||
|  |         </template> | ||||||
|  |       </div> | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |       <div v-if="display == 'Month'"> | ||||||
|  |         <button @click="changeMonth(-1)">Previous</button> | ||||||
|  |         <button @click="changeMonth(1)">Next</button> | ||||||
|  |         <div class="body" >{{months[currentDate.getMonth()]}} {{currentDate.getFullYear()}}</div>       | ||||||
|  |          | ||||||
|  |         <template   v-for="i,index in lastDateOfMonth(currentDate.getMonth())-1"> | ||||||
|  |           <div class="body" style="background-color:#181818;">{{ dateOfMonth(i).getDay()-1== -1 ? days[6] : days[dateOfMonth(i).getDay()-1] }} {{formatDate(dateOfMonth(i))}} | ||||||
|  | </div> | ||||||
|  |           <template v-if="scheduleByWeek != null"> | ||||||
|  |           <div  class="body" style="background-color:#353535;" > | ||||||
|  |           <div  class="containerList"  v-for="n,j in month[i].length" @click.native="lessonFocus( month[i][j])">     | ||||||
|  |             <div class="colorList" v-bind:style="{background:month[i][j].color}"></div> | ||||||
|  |             <div class="hoursList">{{ getHoursMinutes(month[i][j].lessonStart)}}-{{getHoursMinutes(month[i][j].lessonEnd)}}</div> | ||||||
|  |             <div class="titleList">{{month[i][j].course.title}}</div> | ||||||
|  |             <div class="teacherList">{{month[i][j].course.owner.lastName}}</div> | ||||||
|  |             <div class="localList">{{month[i][j].local}}</div> | ||||||
|  |             <div class="typeList">{{month[i][j].lessonType}}</div> | ||||||
|  |           </div> | ||||||
|  |           </div> | ||||||
|  |           </template> | ||||||
|  |           </template> | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |       </div> | ||||||
|  |     </div> | ||||||
|  |  | ||||||
|  |     <div class="options"> | ||||||
|  |       <div class="settings"> | ||||||
|  |       <div class="body"  style="background-color:rgb(50,50,50);margin:5% 0 5% 0;">Settings</div> | ||||||
|  |       <select @change="changeSchedule()" v-model="trueSchedule"> | ||||||
|  |         <option v-for="item in allSchedules" :value='item'>{{item.curriculum.option}}-{{item.curriculum.year}}</option> | ||||||
|  |       </select> | ||||||
|  |       <button v-if="display=='Week'" @click="display='Month'">Week</button> | ||||||
|  |       <button v-if="display=='Month'" @click="display='Week'; value=1;">Month</button> | ||||||
|  |       <button v-if="format == 'Grid'" @click="format ='List'">Grid</button> | ||||||
|  |       <button v-if="format == 'List'" @click ="format = 'Grid'">List</button> | ||||||
|  |       <button v-if="verifUser()" @click="jsonMod=false ;displayOwnSchedule();">OwnSchedule</button> | ||||||
|  |       <button v-if="importedJSON != null" @click="switchToJSON()">Switch to JSON FILE</button> | ||||||
|  |  | ||||||
|  |       <select v-if="schedule != null && !jsonMod" @change="subFilter = 'null'" v-model="filter"> | ||||||
|  |         <option :value ="null">No Filter</option> | ||||||
|  |         <option v-for="item in filters" :value="item">{{item}}</option> | ||||||
|  |       </select> | ||||||
|  |       <select @change="sortSchedule()" v-if="filter == 'Teacher'" v-model="subFilter"> | ||||||
|  |         <option :value ="null">No Filter</option> | ||||||
|  |         <option v-for="item in teachers" :value=item>{{item.lastName}}</option> | ||||||
|  |       </select> | ||||||
|  |       <select @change="sortSchedule()"  v-if="filter == 'Course'" v-model="subFilter"> | ||||||
|  |         <option :value ="null">No Filter</option> | ||||||
|  |         <option v-for="item in courses" :value=item>{{item.title}}</option> | ||||||
|  |       </select> | ||||||
|  |       <select @change="sortSchedule()" v-if="filter == 'Type'" v-model="subFilter"> | ||||||
|  |         <option :value ="null">No Filter</option> | ||||||
|  |         <option v-for="item in types" :value='item'>{{item}}</option> | ||||||
|  |       </select> | ||||||
|  |         <button @click="exportJSON()" >Export JSON</button> | ||||||
|  |          | ||||||
|  |       <div style="color:white;">IMPORT JSON</div> | ||||||
|  |       <input type="file" @change="onFileChange" accept="application/JSON" ></input> | ||||||
|  |          | ||||||
|  |  | ||||||
|  |       </div> | ||||||
|  |       <div v-if="focus != null && !jsonMod" class="moreInfos"> | ||||||
|  |         <div class="body" style="background-color:rgb(50,50,50); height:10%; font-size:2em;" >More infos</div> | ||||||
|  |         <div class="body" :style="{background:focus.color,height:auto,fontSize:1.2+'em', alignItems:center}"> | ||||||
|  |           {{focus.course.title}}</div> | ||||||
|  |  | ||||||
|  |         <div class="body"  style="background-color:rgb(50,50,50);">Teacher(s)</div> | ||||||
|  |         <div class="body" style="background-color:#484848;"> | ||||||
|  |           <div>{{focus.course.owner.lastName}}</div> | ||||||
|  |           <div v-for="element in focus.course.owner.assistants"> | ||||||
|  |             {{element.lastName}} | ||||||
|  |           </div> | ||||||
|  |         </div> | ||||||
|  |         <div class="body"  style="background-color:rgb(50,50,50);">Lessons</div> | ||||||
|  |        <div class="body" style="background-color:#484848;"v-for="lesson in focusLessons"> | ||||||
|  |           {{ getHoursMinutes(lesson.lessonStart)}}-{{getHoursMinutes(lesson.lessonEnd)}} | ||||||
|  |           {{ lesson.local}} | ||||||
|  |           {{lesson.lessonType}} | ||||||
|  |         </div>   | ||||||
|  |  | ||||||
|  |       </div> | ||||||
|  |     </div> | ||||||
|  |   </div> | ||||||
|  | </template> | ||||||
|  | <style scoped> | ||||||
|  |   .grid{ | ||||||
|  |     min-width:1200px; | ||||||
|  |     display:grid; | ||||||
|  |     margin-top:2%; | ||||||
|  |     align-items:center; | ||||||
|  |     justify-content:center; | ||||||
|  |     grid-template-columns:72% 14.5%; | ||||||
|  |     column-gap:2vw; | ||||||
|  |     overflow:hidden; | ||||||
|  |     grid-template-areas:"schedule options"; | ||||||
|  |   } | ||||||
|  |   .schedule{ | ||||||
|  |     min-width:900px; | ||||||
|  |     position:relative;  | ||||||
|  |     overflow-y:scroll; | ||||||
|  |     border-radius:20px; | ||||||
|  |     grid-area:schedule; | ||||||
|  |     width:100%; | ||||||
|  |     height:85vh; | ||||||
|  |     background-color:rgba(255,255,255,0.1);     | ||||||
|  |   } | ||||||
|  |   .options{ | ||||||
|  |     display:grid; | ||||||
|  |     border-radius:20px; | ||||||
|  |     grid-area:options; | ||||||
|  |     background-color:rgba(255,255,255,0.1); | ||||||
|  |     width:100%; | ||||||
|  |     height:85vh; | ||||||
|  |     min-width:240px; | ||||||
|  |  | ||||||
|  |     grid-template-rows:40% 60%; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   .settings{ | ||||||
|  |     display:flex; | ||||||
|  |     flex-direction:column; | ||||||
|  |     width:80%; | ||||||
|  |     margin:0 auto 0 auto; | ||||||
|  |   } | ||||||
|  |    | ||||||
|  |  | ||||||
|  |   .settings select,.settings button{ | ||||||
|  |     margin-top:2%; | ||||||
|  |     width:100%; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   .moreInfos{ | ||||||
|  |     width:90%; | ||||||
|  |     display:flex; | ||||||
|  |     flex-direction:column; | ||||||
|  |     margin:0 auto 0 auto; | ||||||
|  |     overflow-y:scroll; | ||||||
|  |     overflow-x:hidden; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   .table{ | ||||||
|  |     width:100%; | ||||||
|  |     height:100%; | ||||||
|  |     border-spacing:0; | ||||||
|  |     border-collapse:separate; | ||||||
|  |     border-radius: 20px; | ||||||
|  |     border: 2px solid black | ||||||
|  |   } | ||||||
|  |    | ||||||
|  |   .hour{ | ||||||
|  |     background-color:rgb(72,72,72) | ||||||
|  |  | ||||||
|  |   } | ||||||
|  |    | ||||||
|  |   .header{ | ||||||
|  |     width:12.5%; | ||||||
|  |     color:#FFFFFF; | ||||||
|  |     position:relative; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |  | ||||||
|  |   .childHeader{ | ||||||
|  |     margin-top:0; | ||||||
|  |     margin-bottom:0; | ||||||
|  |     max-height:14.28% | ||||||
|  |  | ||||||
|  |   } | ||||||
|  |   table th:not(:last-child), | ||||||
|  |   table td:not(:last-child) { | ||||||
|  |   border-right: 1px solid black; | ||||||
|  |   } | ||||||
|  |    | ||||||
|  |   table tr:not(:last-child)>td, | ||||||
|  |   table tr:not(:last-child)>th | ||||||
|  |   { | ||||||
|  |     border-bottom:1px solid black; | ||||||
|  |   } | ||||||
|  |    | ||||||
|  |   .courseGrid{ | ||||||
|  |     top:13.75%;    | ||||||
|  |     left:12.5%; | ||||||
|  |     position:absolute; | ||||||
|  |     width:87.5%; | ||||||
|  |     height:86.25%;  | ||||||
|  |     display:grid; | ||||||
|  |     grid-template-columns:repeat(7,1fr); | ||||||
|  |       } | ||||||
|  |    | ||||||
|  |    | ||||||
|  |   .course{ | ||||||
|  |     position:relative; | ||||||
|  |     border: 1px solid black; | ||||||
|  |     border-radius:10px; | ||||||
|  |     width:90%; | ||||||
|  |     margin-left:auto; | ||||||
|  |     margin-right:auto; | ||||||
|  |     display:grid; | ||||||
|  |     grid-template-rows:1fr 1fr 1fr; | ||||||
|  |     } | ||||||
|  |    | ||||||
|  |   .dayCourse{ | ||||||
|  |     display:block;  | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   .infos{ | ||||||
|  |     height:100%; | ||||||
|  |     width:100%; | ||||||
|  |     font-size:0.75em; | ||||||
|  |     display:flex; | ||||||
|  |     flex-direction:column; | ||||||
|  |     align-items:center; | ||||||
|  |     justify-content:center; | ||||||
|  |     position:absolute; | ||||||
|  |   } | ||||||
|  |    | ||||||
|  |   .childInfos{ | ||||||
|  |     text-align:center; | ||||||
|  |     margin-top:0%; | ||||||
|  |     margin-bottom:0%; | ||||||
|  |     overflow:hidden; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   .hourStart{ | ||||||
|  |     background-color:rgb(200,200,200); | ||||||
|  |     border-radius:5px; | ||||||
|  |     position:absolute; | ||||||
|  |     top:2%; | ||||||
|  |     left:2%; | ||||||
|  |     font-size:0.75em; | ||||||
|  |      | ||||||
|  |     border: 1px solid black; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   .hourEnd{ | ||||||
|  |     background-color:rgb(200,200,200); | ||||||
|  |     border-radius:3px; | ||||||
|  |     position:absolute; | ||||||
|  |     bottom:2%; | ||||||
|  |     left:2%; | ||||||
|  |     font-size:0.7em; | ||||||
|  |   } | ||||||
|  |      | ||||||
|  |   .containerList{ | ||||||
|  |     color:white; | ||||||
|  |     height:100px; | ||||||
|  |     font-size:20px; | ||||||
|  |     display:grid; | ||||||
|  |     grid-template-columns:5vw auto auto auto auto auto; | ||||||
|  |     grid-template-areas: | ||||||
|  |     "color hours title teacher local type";  | ||||||
|  |      | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   .colorList{ | ||||||
|  |     grid-area:color; | ||||||
|  |     align-self:center; | ||||||
|  |      | ||||||
|  |     width:75%; | ||||||
|  |     height:75%; | ||||||
|  |     border:1px solid black; | ||||||
|  |     border-radius:20%; | ||||||
|  |   } | ||||||
|  |    | ||||||
|  |   .hoursList{ | ||||||
|  |     grid-area:hours; | ||||||
|  |     align-self:center; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |  | ||||||
|  |   .titleList{ | ||||||
|  |     grid-area:title; | ||||||
|  |     align-self:center; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   .teacherList { | ||||||
|  |     grid-area:teacher; | ||||||
|  |     align-self:center; | ||||||
|  |   } | ||||||
|  |   .localList{ | ||||||
|  |     grid-area:local; | ||||||
|  |     align-self:center; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   .typeList{ | ||||||
|  |     grid-area:type; | ||||||
|  |     align-self:center; | ||||||
|  |   } | ||||||
|  | .body { | ||||||
|  |     color:white; | ||||||
|  |     margin-top:2%; | ||||||
|  |     width:98%; | ||||||
|  |     border:2px solid black; | ||||||
|  |     border-radius:9px; | ||||||
|  |     text-align:center; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |  | ||||||
|  | </style> | ||||||
| @ -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/Inscription/AboutStudent.vue"; | ||||||
|   const users = await getStudents(); |   const users = await getStudents(); | ||||||
| </script>  |  | ||||||
| <template> |   let targetRegNo = ""; | ||||||
|   <div v-for="item in users"> |   let list = ref(true); | ||||||
|  | </script> | ||||||
|  |  | ||||||
|  | <template style="margin-top:5%;"> | ||||||
|  |   <div v-if="list === false"> | ||||||
|  |     <AboutStudent :target=targetRegNo /> | ||||||
|  |     <button style="background-color:rgb(105,05,105);width:5%; margin-left: 10%;" @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% 20% 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; | ||||||
| @ -80,16 +74,16 @@ | |||||||
|  |  | ||||||
|   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); | ||||||
|  | |||||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user