Compare commits
	
		
			4 Commits
		
	
	
		
			Schedule/m
			...
			9328601d2d
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 9328601d2d | |||
| 79f4b84b70 | |||
| 0c73f6f44d | |||
| a1bdae9e83 | 
							
								
								
									
										1
									
								
								Clyde
									
									
									
									
									
								
							
							
								
								
								
								
								
							
						
						
									
										1
									
								
								Clyde
									
									
									
									
									
								
							 Submodule Clyde deleted from bd27ffd3cb
									
								
							| @ -25,6 +25,7 @@ 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") | ||||||
|  | |||||||
| @ -47,7 +47,6 @@ 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) | ||||||
|  | |||||||
| @ -15,7 +15,7 @@ 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; | ||||||
| @ -27,7 +27,8 @@ public class MockController { | |||||||
|     ArrayList<User> mockUsers; |     ArrayList<User> mockUsers; | ||||||
|  |  | ||||||
|  |  | ||||||
|     public MockController(UserRepository userRepo, TokenRepository tokenRepo, TokenService tokenService, CurriculumCourseService CurriculumCourseService, CurriculumService curriculumService, CourseService courseService, InscriptionService inscriptionService){ |     public MockController(UserService userService, UserRepository userRepo, TokenRepository tokenRepo, TokenService tokenService, CurriculumCourseService CurriculumCourseService, CurriculumService curriculumService, CourseService courseService, InscriptionService inscriptionService){ | ||||||
|  |         this.userService = userService; | ||||||
|         this.tokenRepo = tokenRepo; |         this.tokenRepo = tokenRepo; | ||||||
|         this.userRepo = userRepo; |         this.userRepo = userRepo; | ||||||
|         this.tokenService = tokenService; |         this.tokenService = tokenService; | ||||||
| @ -45,21 +46,21 @@ public class MockController { | |||||||
|  |  | ||||||
|     @PostMapping("/mock") |     @PostMapping("/mock") | ||||||
|     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)); |  | ||||||
|  |  | ||||||
|         userRepo.saveAll(mockUsers); |         mockUsers = new ArrayList<>(Arrays.asList(joke, herobrine, joe, meh, jojo)); | ||||||
|  |         userService.saveAll(mockUsers); | ||||||
|  |         userService.save(lena); | ||||||
|  |  | ||||||
|         // Course / Curriculum part |  | ||||||
|  |         //Course / Curriculum part | ||||||
|  |  | ||||||
|         Curriculum infoBab1 = new Curriculum(1,"info"); |         Curriculum infoBab1 = new Curriculum(1,"info"); | ||||||
|         Curriculum chemistryBab1 = new Curriculum(1,"chemistry"); |         Curriculum chemistryBab1 = new Curriculum(1,"chemistry"); | ||||||
|  | |||||||
							
								
								
									
										42
									
								
								backend/src/main/java/ovh/herisson/Clyde/RegNoGenerator.java
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										42
									
								
								backend/src/main/java/ovh/herisson/Clyde/RegNoGenerator.java
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,42 @@ | |||||||
|  | package ovh.herisson.Clyde; | ||||||
|  |  | ||||||
|  | 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 final UserSaveCounter usv = UserSaveCounter.getInstance(); | ||||||
|  |     @Override | ||||||
|  |     public Object generate(SharedSessionContractImplementor session, Object object) { | ||||||
|  |         try{ | ||||||
|  |             JdbcConnectionAccess jdbccon = session.getJdbcConnectionAccess(); | ||||||
|  |             Connection conn = jdbccon.obtainConnection(); | ||||||
|  |  | ||||||
|  |             Statement statement = conn.createStatement(); | ||||||
|  |  | ||||||
|  |             int n = usv.getCount(); | ||||||
|  |             String query = "select count(reg_no)+"+n+" from Users"; | ||||||
|  |             usv.increment(); | ||||||
|  |  | ||||||
|  |             ResultSet set = statement.executeQuery(query); | ||||||
|  |             long resp = 0; | ||||||
|  |             Calendar c = new GregorianCalendar(); | ||||||
|  |             if(set.next()){ | ||||||
|  |                 resp = set.getLong(1)+((c.get(Calendar.YEAR)%1000)*10000); | ||||||
|  |             } | ||||||
|  |  | ||||||
|  |             conn.close(); | ||||||
|  |             statement.close(); | ||||||
|  |  | ||||||
|  |             return resp; | ||||||
|  |  | ||||||
|  |         } catch (SQLException e) { | ||||||
|  |             throw new RuntimeException(e); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | } | ||||||
| @ -5,13 +5,10 @@ import org.springframework.data.repository.CrudRepository; | |||||||
| import ovh.herisson.Clyde.Tables.User; | import ovh.herisson.Clyde.Tables.User; | ||||||
|  |  | ||||||
| public interface UserRepository extends CrudRepository<User, Long> { | public interface UserRepository extends CrudRepository<User, Long> { | ||||||
|  |  | ||||||
|     User findById(long id); |     User findById(long id); | ||||||
|  |  | ||||||
|     User findByEmail(String email); |     User findByEmail(String email); | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|     @Query("select u from User u where u.role = ovh.herisson.Clyde.Tables.Role.Teacher") |     @Query("select u from User u where u.role = ovh.herisson.Clyde.Tables.Role.Teacher") | ||||||
|     Iterable<User> findAllTeachers(); |     Iterable<User> findAllTeachers(); | ||||||
|  |  | ||||||
|  | |||||||
| @ -5,13 +5,15 @@ import org.springframework.stereotype.Service; | |||||||
| 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; | ||||||
|  | import ovh.herisson.Clyde.UserSaveCounter; | ||||||
|  |  | ||||||
| import java.util.*; | import java.util.*; | ||||||
|  |  | ||||||
| @Service | @Service | ||||||
| public class UserService { | public class UserService { | ||||||
|     private final UserRepository userRepo; |     private final UserRepository userRepo; | ||||||
|     private final BCryptPasswordEncoder passwordEncoder = new BCryptPasswordEncoder(); |     private final BCryptPasswordEncoder passwordEncoder = new BCryptPasswordEncoder(); | ||||||
|  |     private final UserSaveCounter usc = UserSaveCounter.getInstance(); | ||||||
|     public UserService(UserRepository userRepo){ |     public UserService(UserRepository userRepo){ | ||||||
|         this.userRepo = userRepo; |         this.userRepo = userRepo; | ||||||
|     } |     } | ||||||
| @ -106,10 +108,19 @@ public class UserService { | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     public User save(User  user){ |     public User save(User  user){ | ||||||
|  |         usc.reset(); | ||||||
|         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 | ||||||
|  |         usc.reset(); | ||||||
|  |         userRepo.saveAll(list); | ||||||
|  |         //Reset le compteur a zero pour les futurs ajouts | ||||||
|  |         usc.reset(); | ||||||
|  |     } | ||||||
|  |  | ||||||
|     public Iterable<User> getAll(){ |     public Iterable<User> getAll(){ | ||||||
|         return userRepo.findAll(); |         return userRepo.findAll(); | ||||||
|     } |     } | ||||||
| @ -131,4 +142,5 @@ public class UserService { | |||||||
|     public void delete(User user) { |     public void delete(User user) { | ||||||
|         userRepo.delete(user); |         userRepo.delete(user); | ||||||
|     } |     } | ||||||
|  |  | ||||||
| } | } | ||||||
|  | |||||||
| @ -3,7 +3,6 @@ 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, | ||||||
|  | |||||||
| @ -1,6 +1,8 @@ | |||||||
| package ovh.herisson.Clyde.Tables; | package ovh.herisson.Clyde.Tables; | ||||||
|  |  | ||||||
| import jakarta.persistence.*; | import jakarta.persistence.*; | ||||||
|  | import org.hibernate.annotations.GenericGenerator; | ||||||
|  |  | ||||||
| import java.util.Date; | import java.util.Date; | ||||||
|  |  | ||||||
|  |  | ||||||
| @ -8,7 +10,8 @@ import java.util.Date; | |||||||
| @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.RegNoGenerator.class) | ||||||
|  |     @GeneratedValue(generator = "userGen") | ||||||
|     private Long regNo; |     private Long regNo; | ||||||
|     private String lastName; |     private String lastName; | ||||||
|     private String firstName; |     private String firstName; | ||||||
|  | |||||||
| @ -0,0 +1,25 @@ | |||||||
|  | package ovh.herisson.Clyde; | ||||||
|  |  | ||||||
|  | public final class UserSaveCounter { | ||||||
|  |     private static UserSaveCounter instance; | ||||||
|  |     private int count = 0; | ||||||
|  |  | ||||||
|  |     public void increment() { | ||||||
|  |         this.count+=1; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public int getCount() { | ||||||
|  |         return count; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public void reset(){ | ||||||
|  |         this.count = 0; | ||||||
|  |     } | ||||||
|  |     public static UserSaveCounter getInstance(){ | ||||||
|  |         if (instance == null){ | ||||||
|  |             instance = new UserSaveCounter(); | ||||||
|  |             return instance; | ||||||
|  |         } | ||||||
|  |         return instance; | ||||||
|  |     } | ||||||
|  | } | ||||||
| @ -1,3 +1,2 @@ | |||||||
| 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 |  | ||||||
| @ -23,6 +23,7 @@ import ovh.herisson.Clyde.Repositories.TokenRepository; | |||||||
| import ovh.herisson.Clyde.Repositories.UserRepository; | import ovh.herisson.Clyde.Repositories.UserRepository; | ||||||
| import ovh.herisson.Clyde.Responses.UnauthorizedResponse; | import ovh.herisson.Clyde.Responses.UnauthorizedResponse; | ||||||
| import ovh.herisson.Clyde.Services.TokenService; | import ovh.herisson.Clyde.Services.TokenService; | ||||||
|  | import ovh.herisson.Clyde.Services.UserService; | ||||||
| import ovh.herisson.Clyde.Tables.Role; | import ovh.herisson.Clyde.Tables.Role; | ||||||
| import ovh.herisson.Clyde.Tables.Token; | import ovh.herisson.Clyde.Tables.Token; | ||||||
| import ovh.herisson.Clyde.Tables.User; | import ovh.herisson.Clyde.Tables.User; | ||||||
| @ -47,6 +48,8 @@ public class UserControllerTest { | |||||||
|     @Autowired |     @Autowired | ||||||
|     private TokenService tokenService; |     private TokenService tokenService; | ||||||
|  |  | ||||||
|  |     @Autowired | ||||||
|  |     private UserService userService; | ||||||
|     @Autowired |     @Autowired | ||||||
|     private UserRepository userRepository; |     private UserRepository userRepository; | ||||||
|     @Autowired |     @Autowired | ||||||
| @ -79,12 +82,13 @@ public class UserControllerTest { | |||||||
|         tokenRepository.deleteAll(); |         tokenRepository.deleteAll(); | ||||||
|         userRepository.deleteAll(); |         userRepository.deleteAll(); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @Test |     @Test | ||||||
|     //Verifie qu'un user qui n'a pas les permissions admin ou secretaire ne peut pas post |     //Verifie qu'un user qui n'a pas les permissions admin ou secretaire ne peut pas post | ||||||
|     public void userPostTest(){ |     public void userPostTest(){ | ||||||
|         User god = new User("god","god","admin@admin.com","everywhere","every",new Date(0), null, Role.Admin,"goddoesntneedpassword"); |         User god = new User("god","god","admin@admin.com","everywhere","every",new Date(0), null, Role.Admin,"goddoesntneedpassword"); | ||||||
|         Token godToken = new Token(god, tokenService.generateNewToken(), new Date()); |         Token godToken = new Token(god, tokenService.generateNewToken(), new Date()); | ||||||
|         userRepository.save(god); |         userService.save(god); | ||||||
|         tokenService.saveToken(godToken); |         tokenService.saveToken(godToken); | ||||||
|  |  | ||||||
|         //Can god post herobrine himself ? |         //Can god post herobrine himself ? | ||||||
| @ -97,7 +101,7 @@ public class UserControllerTest { | |||||||
|         //Can noob post herobrine without authorizations (no) |         //Can noob post herobrine without authorizations (no) | ||||||
|         User noob = new User("boon","noob","noob@student.com","everywhere","every",new Date(0), null, Role.Student,"noob"); |         User noob = new User("boon","noob","noob@student.com","everywhere","every",new Date(0), null, Role.Student,"noob"); | ||||||
|         Token noobToken = new Token(noob, tokenService.generateNewToken(), new Date()); |         Token noobToken = new Token(noob, tokenService.generateNewToken(), new Date()); | ||||||
|         userRepository.save(noob); |         userService.save(noob); | ||||||
|         tokenService.saveToken(noobToken); |         tokenService.saveToken(noobToken); | ||||||
|  |  | ||||||
|         with().body(herobrine).contentType(ContentType.JSON).header("Authorization", noobToken.getToken()).when().request("POST", "/user").then().statusCode(401); |         with().body(herobrine).contentType(ContentType.JSON).header("Authorization", noobToken.getToken()).when().request("POST", "/user").then().statusCode(401); | ||||||
|  | |||||||
| @ -7,6 +7,7 @@ import org.junit.jupiter.api.Test; | |||||||
| import org.springframework.beans.factory.annotation.Autowired; | import org.springframework.beans.factory.annotation.Autowired; | ||||||
| import org.springframework.boot.test.autoconfigure.orm.jpa.DataJpaTest; | import org.springframework.boot.test.autoconfigure.orm.jpa.DataJpaTest; | ||||||
| import org.springframework.test.context.TestPropertySource; | import org.springframework.test.context.TestPropertySource; | ||||||
|  | import ovh.herisson.Clyde.Services.UserService; | ||||||
| import ovh.herisson.Clyde.Tables.Role; | import ovh.herisson.Clyde.Tables.Role; | ||||||
| import ovh.herisson.Clyde.Tables.User; | import ovh.herisson.Clyde.Tables.User; | ||||||
|  |  | ||||||
| @ -24,6 +25,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 +36,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())); | ||||||
|     } |     } | ||||||
|  |  | ||||||
| } | } | ||||||
|  | |||||||
| @ -25,6 +25,7 @@ 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) | ||||||
|  |  | ||||||
| @ -85,18 +86,19 @@ window.addEventListener('hashchange', () => { | |||||||
|     </ul> |     </ul> | ||||||
|     </div> |     </div> | ||||||
|     <div class="page"> |     <div class="page"> | ||||||
|  |       <div style=" margin:50px;"> | ||||||
|         <Suspense> |         <Suspense> | ||||||
|  |          | ||||||
| 		<component :is="currentView" /> | 		<component :is="currentView" /> | ||||||
|         </Suspense> |         </Suspense> | ||||||
|       </div> |       </div> | ||||||
|     </div> |     </div> | ||||||
|  |   </div> | ||||||
| </template> | </template> | ||||||
|  |  | ||||||
| <style scoped> | <style scoped> | ||||||
|    |    | ||||||
|   .container{ |   .container{ | ||||||
| 			height: 100%; |  | ||||||
| 			width: 100%; |  | ||||||
|     display:grid; |     display:grid; | ||||||
|     grid-template-columns:[firstCol-start]70px[firstCol-end secondCol-start]auto[endCol]; |     grid-template-columns:[firstCol-start]70px[firstCol-end secondCol-start]auto[endCol]; | ||||||
|     grid-template-rows:[firstRow-start]61px[firstRow-end secondRow-start] auto [endRow]; |     grid-template-rows:[firstRow-start]61px[firstRow-end secondRow-start] auto [endRow]; | ||||||
| @ -109,8 +111,6 @@ window.addEventListener('hashchange', () => { | |||||||
|  |  | ||||||
|   .page { |   .page { | ||||||
|     grid-area:page; |     grid-area:page; | ||||||
| 		height: 100%; |  | ||||||
| 		width: 100%; |  | ||||||
|     place-self:center; |     place-self:center; | ||||||
|   } |   } | ||||||
|  |  | ||||||
|  | |||||||
| @ -16,9 +16,10 @@ | |||||||
|  |  | ||||||
|  |  | ||||||
| <template>  | <template>  | ||||||
|   <div style='display:flex; justify-content:center; min-width:1140px;' v-for="item of requests"> |   <div  v-for="item of requests"> | ||||||
|   <div class="bodu" v-if="item.state === 'Pending'"> |   <div class="bodu" v-if="item.state === 'Pending'"> | ||||||
|   <div class="container"> |   <div class="container"> | ||||||
|  |   | ||||||
|     <div class="id"><a>{{item.id}}</a></div> |     <div class="id"><a>{{item.id}}</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> | ||||||
| @ -36,9 +37,10 @@ | |||||||
|     height:100px; |     height:100px; | ||||||
|     font-size:20px; |     font-size:20px; | ||||||
|     display:grid; |     display:grid; | ||||||
|     grid-template-columns:10% 14.2% 19% 14.2% 14.2% 14.2% 14.2%; |     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: |     grid-template-areas: | ||||||
|     "id type surname firstname infos accept refuse";  |     "id type surname firstname infos accept refuse";  | ||||||
|  |     column-gap:10px; | ||||||
|      |      | ||||||
|   } |   } | ||||||
|    |    | ||||||
| @ -98,8 +100,8 @@ | |||||||
|   } |   } | ||||||
|  |  | ||||||
|   .bodu { |   .bodu { | ||||||
|     margin-top:2%; |     width:100%; | ||||||
|     width:66%; |     margin-bottom:10px; | ||||||
|     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); | ||||||
|  | |||||||
| @ -56,10 +56,10 @@ | |||||||
|  |  | ||||||
|  |  | ||||||
| <template> | <template> | ||||||
|     <div class="setup"> |       <div class='loginBox'> | ||||||
|  |  | ||||||
|         <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")}} | ||||||
|             </h1> |             </h1> | ||||||
| @ -74,14 +74,13 @@ | |||||||
|             <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" style="margin-bottom:35px;"> |             <div class="inputBox"> | ||||||
|               <input type="submit" v-model="submitValue"> |               <input type="submit" v-model="submitValue"> | ||||||
|             </div> |             </div> | ||||||
|           </form> |           </form> | ||||||
|         </div> |         </div> | ||||||
|       </div> |  | ||||||
|         <div v-else> |         <div v-else> | ||||||
|           <div class='loginBox' style="margin-top:30%; margin-bottom:50%;"> |  | ||||||
|           <form class="form"> |           <form class="form"> | ||||||
|             <h1 style="color:rgb(239,60,168); font-family: sans-serif; text-align:center;"> |             <h1 style="color:rgb(239,60,168); font-family: sans-serif; text-align:center;"> | ||||||
|               {{i18n("login.guest.welcome")}} |               {{i18n("login.guest.welcome")}} | ||||||
| @ -129,12 +128,9 @@ | |||||||
|                 <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"> |               <form novalidate enctype="multipart/form-data" class="inputBox"> | ||||||
|               	<p>{{i18n("profile.picture").toUpperCase()}}</p>  |               	<p>{{i18n("profile.picture").toUpperCase()}}</p>  | ||||||
|               <label class="browser"> |  | ||||||
|                 Parcourir . . . |  | ||||||
| 				<input type="file" :disabled="imageSaved" @change="ppData = uploadProfilePicture($event.target.files); imageSaved = true;" accept="image/*"> | 				<input type="file" :disabled="imageSaved" @change="ppData = uploadProfilePicture($event.target.files); imageSaved = true;" accept="image/*"> | ||||||
|               </label> |  | ||||||
|               </form> |               </form> | ||||||
|               <div class="inputBox"> |               <div class="inputBox"> | ||||||
|                 <p>{{i18n("Curriculum").toUpperCase()}}</p>  |                 <p>{{i18n("Curriculum").toUpperCase()}}</p>  | ||||||
| @ -158,25 +154,34 @@ | |||||||
|           </form> |           </form> | ||||||
|          </div> |          </div> | ||||||
|         </div> |         </div> | ||||||
|   </div> |  | ||||||
| </template> | </template> | ||||||
|  |  | ||||||
| <style scoped> | <style scoped> | ||||||
|  | .Home{ | ||||||
| .setup { |   position:absolute; | ||||||
|   margin-left: auto; |  	display: flex; | ||||||
|   margin-right:auto; |   z-index: 100; | ||||||
|   min-width:400px; | 	padding: 8px 16px; | ||||||
|  | 	color:rgb(255, 255, 255); | ||||||
|   width:25%; | 	text-decoration: none; | ||||||
|   height:60%; |  | ||||||
| } | } | ||||||
|  |  | ||||||
|  | .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: 400px; | ||||||
|   display:flex; |   display:flex; | ||||||
|   justify-content: center; |   justify-content: center; | ||||||
|   border-radius: 5%; |   padding: 40px; | ||||||
|  |   border-radius: 20px; | ||||||
|   box-shadow:0 5px 25px #000000; |   box-shadow:0 5px 25px #000000; | ||||||
|    |    | ||||||
| } | } | ||||||
| @ -185,8 +190,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; | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| @ -194,12 +200,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; | ||||||
| } | } | ||||||
|  |  | ||||||
| @ -214,9 +220,8 @@ | |||||||
|  |  | ||||||
| .register{ | .register{ | ||||||
|   color:rgb(239,60,168); |   color:rgb(239,60,168); | ||||||
|   width:70%; |   width: 100%; | ||||||
|   margin-bottom:20px; |   display:flex; | ||||||
|   margin-top:20px; |  | ||||||
|   cursor: pointer; |   cursor: pointer; | ||||||
| } | } | ||||||
|  |  | ||||||
| @ -245,21 +250,6 @@ input[type=submit],button,select{ | |||||||
|  |  | ||||||
| } | } | ||||||
|  |  | ||||||
| input[type=file]{ |  | ||||||
|   display:none; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| .browser{ |  | ||||||
|   display:inline-block; |  | ||||||
|   cursor:pointer; |  | ||||||
|   border-radius:20px; |  | ||||||
|   background-color:rgb(239,60,168); |  | ||||||
|   padding:5%; |  | ||||||
|   font-size:1.35em; |  | ||||||
|   font-family:sans-serif; |  | ||||||
|   background:#FFFFFF; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| button:active ,.switchpage:active{ | button:active ,.switchpage:active{ | ||||||
|   opacity:0.8; |   opacity:0.8; | ||||||
|  |  | ||||||
|  | |||||||
| @ -105,8 +105,7 @@ | |||||||
|       </button> |       </button> | ||||||
|     </div> |     </div> | ||||||
|     <div v-if="createMod"> |     <div v-if="createMod"> | ||||||
|       <form class="listElement" style="width:40%;margin-right:auto;margin-left:auto;"> |       <form class="listElement"> | ||||||
|          |  | ||||||
|         <div style="margin-bottom:20px;"> |         <div style="margin-bottom:20px;"> | ||||||
|          {{i18n("name")}} :  |          {{i18n("name")}} :  | ||||||
|         <input v-model="toAdd.title"> |         <input v-model="toAdd.title"> | ||||||
| @ -126,7 +125,7 @@ | |||||||
|       </form> |       </form> | ||||||
|     </div> |     </div> | ||||||
|     <div v-if="deleteMod"> |     <div v-if="deleteMod"> | ||||||
|       <form class="listElement" style="width:40%;margin-right:auto;margin-left:auto;"> |       <form class="listElement"> | ||||||
|         <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"> | ||||||
| @ -139,7 +138,7 @@ | |||||||
|       </form> |       </form> | ||||||
|     </div> |     </div> | ||||||
|  |  | ||||||
|     <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="!createMod && !deleteMod" v-for="item in curriculum" :key="item.title"> | ||||||
|       <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")}} | ||||||
| @ -150,7 +149,6 @@ | |||||||
|         <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> | ||||||
| @ -174,27 +172,17 @@ | |||||||
| <style scoped> | <style scoped> | ||||||
| .body { | .body { | ||||||
|     width:100%; |     width:100%; | ||||||
|     margin-top:3.5%; |     margin-bottom:10px; | ||||||
|   } |   } | ||||||
|  |  | ||||||
| .infosContainer { |  | ||||||
|   min-width:350px; |  | ||||||
|   padding-bottom:50px; |  | ||||||
|   border:2px solid black; |  | ||||||
|   font-size:25px; |  | ||||||
|   color:white; |  | ||||||
|   padding:20px; |  | ||||||
|   background-color:rgb(50,50,50); |  | ||||||
|   border-radius:20px; |  | ||||||
| } |  | ||||||
|  |  | ||||||
|  .containerElement{  |  .containerElement{  | ||||||
|    justify-content:center; |    justify-content:center; | ||||||
|     display:grid; |     display:grid; | ||||||
|     grid-template-columns:38.8% 38.8% 22.4%; |     grid-template-columns:350px 350px 200px; | ||||||
|     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; | ||||||
| @ -212,7 +200,6 @@ | |||||||
|   } |   } | ||||||
|  |  | ||||||
| .listElement{ | .listElement{ | ||||||
|  min-width:625px; |  | ||||||
|   border:2px solid black; |   border:2px solid black; | ||||||
|   font-size:25px; |   font-size:25px; | ||||||
|   color:white; |   color:white; | ||||||
| @ -220,7 +207,6 @@ | |||||||
|   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{ | ||||||
| @ -269,11 +255,10 @@ | |||||||
|   } |   } | ||||||
|  |  | ||||||
|   .listTitle{ |   .listTitle{ | ||||||
|     min-width:380px; |  | ||||||
|     display: flex; |     display: flex; | ||||||
|     justify-content: center; |     justify-content: center; | ||||||
|     align-items: center; |     align-items: center; | ||||||
|     width:25%; |     width:400px; | ||||||
|     margin-left:auto; |     margin-left:auto; | ||||||
|     margin-right:auto; |     margin-right:auto; | ||||||
|     border:2px solid black; |     border:2px solid black; | ||||||
| @ -281,8 +266,7 @@ | |||||||
|     color:white; |     color:white; | ||||||
|     padding:20px; |     padding:20px; | ||||||
|     background-color:rgb(50,50,50); |     background-color:rgb(50,50,50); | ||||||
|     border-radius:20px; |     border-radius:20px;margin-bottom:10px; | ||||||
|     margin-bottom:10px; |  | ||||||
|  |  | ||||||
|     button:hover{ |     button:hover{ | ||||||
|       opacity:0.8; |       opacity:0.8; | ||||||
|  | |||||||
| @ -210,11 +210,11 @@ | |||||||
| <style scoped> | <style scoped> | ||||||
|  |  | ||||||
| .container{ | .container{ | ||||||
|   min-width:675px; |    | ||||||
|   display:grid; |   display:grid; | ||||||
|   grid-template-columns:10vw 50vw; |   grid-template-columns:200px 900px; | ||||||
|   grid-template-rows:200px auto; |   grid-template-rows:200px auto; | ||||||
|   column-gap:2.7%; |   column-gap:30px; | ||||||
|   row-gap:45px; |   row-gap:45px; | ||||||
|   grid-template-areas: |   grid-template-areas: | ||||||
|   "profilPic globalInfos" |   "profilPic globalInfos" | ||||||
| @ -222,7 +222,6 @@ | |||||||
| } | } | ||||||
|  |  | ||||||
| .profilPic{ | .profilPic{ | ||||||
|   width:100%; |  | ||||||
|   grid-area:profilPic; |   grid-area:profilPic; | ||||||
| } | } | ||||||
|  |  | ||||||
| @ -243,17 +242,13 @@ | |||||||
|   grid-area:minfos; |   grid-area:minfos; | ||||||
| } | } | ||||||
| .body { | .body { | ||||||
|     min-width:960px; |  | ||||||
|     width:100%; |     width:100%; | ||||||
|     display:flex; |     margin-bottom:10px; | ||||||
|     align-items:center; |  | ||||||
|     justify-content:center; |  | ||||||
|     margin-top:5%; |  | ||||||
|   } |   } | ||||||
|  .containerElement{  |  .containerElement{  | ||||||
|    justify-content:center; |    justify-content:center; | ||||||
|     display:grid; |     display:grid; | ||||||
|     grid-template-columns:38.8% 38.8% 22.4%; |     grid-template-columns:350px 350px 200px; | ||||||
|     grid-template-areas: |     grid-template-areas: | ||||||
|     "name teacher credits";  |     "name teacher credits";  | ||||||
|     column-gap:10px; |     column-gap:10px; | ||||||
| @ -276,11 +271,10 @@ | |||||||
|   } |   } | ||||||
|  |  | ||||||
| .listTitle{ | .listTitle{ | ||||||
|     min-width:197px; |  | ||||||
|     display: flex; |     display: flex; | ||||||
|     justify-content: center; |     justify-content: center; | ||||||
|     align-items: center; |     align-items: center; | ||||||
|     width:8vw; |     width:200px; | ||||||
|     margin-left:auto; |     margin-left:auto; | ||||||
|     margin-right:auto; |     margin-right:auto; | ||||||
|     border:2px solid black; |     border:2px solid black; | ||||||
| @ -292,7 +286,6 @@ | |||||||
| } | } | ||||||
|  |  | ||||||
| .listElement{ | .listElement{ | ||||||
|   min-width:625px; |  | ||||||
|   border:2px solid black; |   border:2px solid black; | ||||||
|   font-size:25px; |   font-size:25px; | ||||||
|   color:white; |   color:white; | ||||||
| @ -303,7 +296,6 @@ | |||||||
| } | } | ||||||
|  |  | ||||||
| .infosContainer { | .infosContainer { | ||||||
| min-width:350px; |  | ||||||
| padding-bottom:50px; | padding-bottom:50px; | ||||||
| border:2px solid black; | border:2px solid black; | ||||||
| font-size:25px; | font-size:25px; | ||||||
|  | |||||||
| @ -1,211 +0,0 @@ | |||||||
| <script setup> |  | ||||||
|   import { ref } from 'vue' |  | ||||||
|   |  | ||||||
|   const schedule = [ |  | ||||||
|     {course:"Math Pour L'info", |  | ||||||
|      start:"Wed Mar 27 2024 10:15 GMT+0100", |  | ||||||
|      end:"Wed Mar 27 2024 12:15 GMT+0100"}, |  | ||||||
|     { |  | ||||||
|       course:"Calculus", |  | ||||||
|       start:"Wed Mar 27 2024 08:00 GMT+0100", |  | ||||||
|       end:"Wed Mar 27 2024 10:00 GMT+0100" |  | ||||||
|        |  | ||||||
|   }, |  | ||||||
|   { |  | ||||||
|       course:"Physique II", |  | ||||||
|       start:"Tue Mar 26 2024 10:15 GMT+0100", |  | ||||||
|       end:"Tue Mar 26 2024 12:15 GMT+0100"       |  | ||||||
|   }, |  | ||||||
|     { |  | ||||||
|       course:"Math Pour L'info", |  | ||||||
|       start:"Thu Mar 28 2024 10:15 GMT+0100", |  | ||||||
|       end:"Thu Mar 28 2024 12:15 GMT+0100"       |  | ||||||
|   }] |  | ||||||
|   function formatDate(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 [day, month, year].join('-'); |  | ||||||
|   } |  | ||||||
|   function getMonday(d) { |  | ||||||
|     d = new Date(d); |  | ||||||
|     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; |  | ||||||
|   } |  | ||||||
|  |  | ||||||
|   const mondayOfWeek=ref(getMonday(new Date(schedule[1].start))) |  | ||||||
|  |  | ||||||
|   function isNotCourse(element){ |  | ||||||
|     return element==null; |  | ||||||
|   } |  | ||||||
|  |  | ||||||
|   function durationCourse(element){ |  | ||||||
|     const hour = element.end.substring(3,5) -element.start.substring(3,5); |  | ||||||
|      |  | ||||||
|      |  | ||||||
|     return (element.end - element.start)%2; |  | ||||||
|   } |  | ||||||
|   function sortByDate(a, b) { |  | ||||||
|     const nameA = a.start; // ignore upper and lowercase |  | ||||||
|     const nameB = b.start; // ignore upper and lowercase |  | ||||||
|      |  | ||||||
|     if (nameA < nameB) { |  | ||||||
|       return -1; |  | ||||||
|     } |  | ||||||
|     if (nameA > nameB) { |  | ||||||
|       return 1; |  | ||||||
|     } |  | ||||||
|     return 0;  |  | ||||||
|       } |  | ||||||
|  |  | ||||||
|   function transpose(a) { |  | ||||||
|     const trans = [[],[],[],[],[],[]]; |  | ||||||
|     for(let i = 0; i < 6;i++){ |  | ||||||
|       for(let j=0; j< 7; j++){ |  | ||||||
|         if(a[j][i] !== null){ |  | ||||||
|           trans[i].push(a[j][i]); |  | ||||||
|         } |  | ||||||
|       } |  | ||||||
|     } |  | ||||||
|     return trans; |  | ||||||
| } |  | ||||||
|  |  | ||||||
|   function matrixFromList(list){ |  | ||||||
|     const matrix = [[],[],[],[],[],[],[]]; |  | ||||||
|     for(let key in list){ |  | ||||||
|       const temp = []; |  | ||||||
|       const day = new Date(list[key].start); |  | ||||||
|       matrix[day.getDay()].push(list[key]); |  | ||||||
|       matrix[day.getDay()].sort((a,b) => sortByDate(a,b)); |  | ||||||
|     } |  | ||||||
|       return matrix; |  | ||||||
|   } |  | ||||||
|  |  | ||||||
|    |  | ||||||
|   const schedule2 = matrixFromList(schedule); |  | ||||||
|   const scheduleByWeek = transpose(schedule2); |  | ||||||
|    |  | ||||||
|   console.log(scheduleByWeek) |  | ||||||
|  |  | ||||||
| </script> |  | ||||||
| <template> |  | ||||||
|   <div class="grid"> |  | ||||||
|     <div class="options" > |  | ||||||
|     </div> |  | ||||||
|     <div class="schedule"> |  | ||||||
|       <table class="table"> |  | ||||||
|         <tr style="background-color:rgb(24,24,24)"> |  | ||||||
|           <th/> |  | ||||||
|           <th class="header">Lundi {{formatDate(getAnyDays(0))}}</th> |  | ||||||
|           <th class="header">Mardi {{formatDate(getAnyDays(1))}}</th> |  | ||||||
|           <th class="header">Mercredi {{formatDate(getAnyDays(2))}}</th> |  | ||||||
|           <th class="header">Jeudi {{formatDate(getAnyDays(3))}}</th> |  | ||||||
|           <th class="header">Vendredi {{formatDate(getAnyDays(4))}}</th> |  | ||||||
|           <th class="header">Samedi {{formatDate(getAnyDays(5))}}</th> |  | ||||||
|           <th class="header">Dimanche {{formatDate(getAnyDays(6))}}</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 class="courseGrid"> |  | ||||||
|         <div v-for="i in 7"> |  | ||||||
|           Test |  | ||||||
|         </div> |  | ||||||
|       </div> |  | ||||||
|     </div> |  | ||||||
|   </div> |  | ||||||
| </template> |  | ||||||
| <style scoped> |  | ||||||
|   .grid{ |  | ||||||
|     display:grid; |  | ||||||
|     margin-top:2%; |  | ||||||
|     align-items:center; |  | ||||||
|     justify-content:center; |  | ||||||
|     grid-template-columns:15vw 70vw; |  | ||||||
|     column-gap:2.5vw; |  | ||||||
|  |  | ||||||
|     grid-template-areas:"options schedule"; |  | ||||||
|   } |  | ||||||
|   .schedule{ |  | ||||||
|     position:relative;   |  | ||||||
|     border-radius:20px; |  | ||||||
|     grid-area:schedule; |  | ||||||
|     width:100%; |  | ||||||
|     height:85vh; |  | ||||||
|     background-color:rgba(255,255,255,0.1);     |  | ||||||
|   } |  | ||||||
|   .options{ |  | ||||||
|     border-radius:20px; |  | ||||||
|     grid-area:options; |  | ||||||
|     background-color:rgba(255,255,255,0.1); |  | ||||||
|     width:100%; |  | ||||||
|     height:85vh; |  | ||||||
|   } |  | ||||||
|  |  | ||||||
|   .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{ |  | ||||||
|     align-items:center; |  | ||||||
|     width:12.5%; |  | ||||||
|     color:#FFFFFF; |  | ||||||
|   } |  | ||||||
|   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{ |  | ||||||
|     width:100%; |  | ||||||
|     height:100%; |  | ||||||
|     background-color:rgb(100,0,100); |  | ||||||
|   } |  | ||||||
|  |  | ||||||
|    |  | ||||||
| </style> |  | ||||||
| @ -5,8 +5,8 @@ | |||||||
|  |  | ||||||
|   const users = await getStudents(); |   const users = await getStudents(); | ||||||
| </script>  | </script>  | ||||||
| <template style="margin-top:5%;"> | <template> | ||||||
|   <div style="display:flex; justify-content:center; " v-for="item in users"> |   <div v-for="item in users"> | ||||||
|     <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> | ||||||
| @ -25,9 +25,10 @@ | |||||||
|     height:100px; |     height:100px; | ||||||
|     font-size:30px; |     font-size:30px; | ||||||
|     display:grid; |     display:grid; | ||||||
|     grid-template-columns:21.7% 21.7% 21.7% 21.7% 13.1%; |     grid-template-columns:250px 250px 250px 250px 150px; | ||||||
|     grid-template-areas: |     grid-template-areas: | ||||||
|     "status option surname firstname infos";  |     "status option surname firstname infos";  | ||||||
|  |     column-gap:10px; | ||||||
|      |      | ||||||
|   } |   } | ||||||
|    |    | ||||||
| @ -41,6 +42,21 @@ | |||||||
|     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; | ||||||
| @ -65,15 +81,15 @@ | |||||||
|   button{ |   button{ | ||||||
|     font-size:15px; |     font-size:15px; | ||||||
|      height:50px; |      height:50px; | ||||||
|      width:75%; |      width:100px; | ||||||
|     border:none; |     border:none; | ||||||
|     border-radius:20px; |     border-radius:20px; | ||||||
|  |  | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   .bodu { |   .bodu { | ||||||
|     margin-top:2%; |     width:100%; | ||||||
|     width:66%; |     margin-bottom:10px; | ||||||
|     border:2px solid black; |     border:2px solid black; | ||||||
|     border-radius:9px; |     border-radius:9px; | ||||||
|     background-color:rgb(50,50,50); |     background-color:rgb(50,50,50); | ||||||
|  | |||||||
| @ -7,8 +7,8 @@ | |||||||
|   const users = await getAllUsers(); |   const users = await getAllUsers(); | ||||||
|    |    | ||||||
| </script>  | </script>  | ||||||
| <template style="margin-top:5%;"> | <template> | ||||||
|   <div style="display:flex; justify-content:center; min-width:1140px;" v-for="item in users"> |   <div v-for="item in users"> | ||||||
|     <div class="bodu"> |     <div class="bodu"> | ||||||
|       <div class="container"> |       <div class="container"> | ||||||
|         <div class="role"><a style="margin-left:30px">{{i18n(item.role)}}</a></div> |         <div class="role"><a style="margin-left:30px">{{i18n(item.role)}}</a></div> | ||||||
| @ -22,20 +22,23 @@ | |||||||
|  |  | ||||||
| <style scoped> | <style scoped> | ||||||
|   .container{ |   .container{ | ||||||
|  |     justify-content:center; | ||||||
|  |     align-items:center; | ||||||
|     color:white; |     color:white; | ||||||
|     height:100px; |     height:100px; | ||||||
|     font-size:30px; |     font-size:30px; | ||||||
|     display:grid; |     display:grid; | ||||||
|     grid-template-columns:27.7% 27.7% 27.7% 16.9%; |     grid-template-columns:250px 250px 250px 150px; | ||||||
|     grid-template-areas: |     grid-template-areas: | ||||||
|     "role surname firstname infos";  |     "role surname firstname infos";  | ||||||
|  |     column-gap:10px; | ||||||
|      |      | ||||||
|   } |   } | ||||||
|    |    | ||||||
|   .infos { |   .infos { | ||||||
|  |  | ||||||
|     grid-area:infos; |     grid-area:infos; | ||||||
|     align-self:center; |     align-items:center; | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   .role { |   .role { | ||||||
| @ -64,18 +67,20 @@ | |||||||
|   button{ |   button{ | ||||||
|     font-size:15px; |     font-size:15px; | ||||||
|      height:50px; |      height:50px; | ||||||
|      width:75%; |      width:100px; | ||||||
|     border:none; |     border:none; | ||||||
|     border-radius:20px; |     border-radius:20px; | ||||||
|  |  | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   .bodu { |   .bodu { | ||||||
|     margin-top:2%; |     width:100%; | ||||||
|     width:66%; |     margin-bottom:10px; | ||||||
|     border:2px solid black; |     border:2px solid black; | ||||||
|     border-radius:9px; |     border-radius:9px; | ||||||
|     background-color:rgb(50,50,50); |     background-color:rgb(50,50,50); | ||||||
|   } |   } | ||||||
|  |  | ||||||
|  |  | ||||||
| </style> | </style> | ||||||
|  |  | ||||||
|  | |||||||
| @ -1,11 +1,4 @@ | |||||||
| body { | body { | ||||||
|    background-color: rgb(53, 25, 60); |    background-color: rgb(53, 25, 60); | ||||||
|    margin:0; |    margin:0; | ||||||
|    width: 100vw; |  | ||||||
|    height: 100vh; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| #app { |  | ||||||
|    width: 100%; |  | ||||||
|    height: 100%; |  | ||||||
| } | } | ||||||
|  | |||||||
| @ -9,10 +9,8 @@ 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 Schedule from "@/Apps/Schedule.vue" |  | ||||||
|  |  | ||||||
| const apps = { | const apps = { | ||||||
| 		'/schedule': Schedule, |  | ||||||
| 		'/login': LoginPage, | 		'/login': LoginPage, | ||||||
| 		'/inscription': Inscription, | 		'/inscription': Inscription, | ||||||
| 		'/profil': Profil, | 		'/profil': Profil, | ||||||
|  | |||||||
		Reference in New Issue
	
	Block a user