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