Compare commits
	
		
			8 Commits
		
	
	
		
			jalonA
			...
			9de4b06e75
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 9de4b06e75 | |||
| 123fa97611 | |||
| 1fad792be7 | |||
| 
						
						
							
						
						acd1262955
	
				 | 
					
					
						|||
| 
						
						
							
						
						3d6941ab93
	
				 | 
					
					
						|||
| 
						
						
							
						
						de72bd800c
	
				 | 
					
					
						|||
| b465dcfa92 | |||
| 73f3df0bc6 | 
@ -45,7 +45,7 @@ jobs:
 | 
				
			|||||||
        distribution: 'temurin'
 | 
					        distribution: 'temurin'
 | 
				
			||||||
    - uses: gradle/gradle-build-action@v3
 | 
					    - uses: gradle/gradle-build-action@v3
 | 
				
			||||||
    - name: building
 | 
					    - name: building
 | 
				
			||||||
      run: ./gradlew backend:build
 | 
					      run: ./gradlew backend:build -x test
 | 
				
			||||||
    - name: pushing to the server
 | 
					    - name: pushing to the server
 | 
				
			||||||
      run: |
 | 
					      run: |
 | 
				
			||||||
        echo "${{ secrets.SSH_KEY }}" > key
 | 
					        echo "${{ secrets.SSH_KEY }}" > key
 | 
				
			||||||
 | 
				
			|||||||
@ -1,5 +1,6 @@
 | 
				
			|||||||
FROM eclipse-temurin:21-jdk-alpine
 | 
					FROM eclipse-temurin:21-jdk-alpine
 | 
				
			||||||
VOLUME /tmp
 | 
					VOLUME /tmp
 | 
				
			||||||
 | 
					VOLUME /cdn
 | 
				
			||||||
ENV SPRING_PROFILES_ACTIVE=prod
 | 
					ENV SPRING_PROFILES_ACTIVE=prod
 | 
				
			||||||
COPY build/libs/backend-0.0.1-SNAPSHOT.jar /app.jar
 | 
					COPY build/libs/backend-0.0.1-SNAPSHOT.jar /app.jar
 | 
				
			||||||
ENTRYPOINT ["java", "-jar", "/app.jar"]
 | 
					ENTRYPOINT ["java", "-jar", "/app.jar"]
 | 
				
			||||||
 | 
				
			|||||||
@ -49,11 +49,11 @@ public class MockController {
 | 
				
			|||||||
        // user part
 | 
					        // user part
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        User herobrine = new User("brine","hero","admin@admin.com","in your WalLs","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","DaWarudo",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("Inspiration","lackOf","secretary@secretary.com","a Box","the street",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("CthemBalls","Lemme","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("hhoo","yeay","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));
 | 
					        mockUsers = new ArrayList<>(Arrays.asList(herobrine,joe,meh,joke,lena,jojo));
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@ -72,7 +72,7 @@ public class MockController {
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
        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);
 | 
				
			||||||
        Course psycho1 = new Course(21, "rien faire t'as cru c'est psycho",joke);
 | 
					        Course psycho1 = new Course(21, "Neuroreaction of isolated brain cells",joke);
 | 
				
			||||||
        Course commun = new Course(2, "cours commun",joke);
 | 
					        Course commun = new Course(2, "cours commun",joke);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        courseService.save(progra1);
 | 
					        courseService.save(progra1);
 | 
				
			||||||
 | 
				
			|||||||
@ -88,14 +88,14 @@ public class UserControllerTest {
 | 
				
			|||||||
        tokenService.saveToken(godToken);
 | 
					        tokenService.saveToken(godToken);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        //Can god post herobrine himself ?
 | 
					        //Can god post herobrine himself ?
 | 
				
			||||||
        User herobrine = new User("brine","hero","herobrine@admin.com","in your WalLs","ShadowsLand",new Date(0), null,Role.Student,"test");
 | 
					        User herobrine = new User("brine","hero","herobrine@student.com","in your WalLs","ShadowsLand",new Date(0), null,Role.Student,"test");
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        with().body(herobrine).contentType(ContentType.JSON).header("Authorization", godToken.getToken()).when().request("POST", "/user").then().statusCode(201);
 | 
					        with().body(herobrine).contentType(ContentType.JSON).header("Authorization", godToken.getToken()).when().request("POST", "/user").then().statusCode(201);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        userRepository.delete(herobrine);
 | 
					        userRepository.delete(herobrine);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        //Can noob post herobrine without authorizations (no)
 | 
					        //Can noob post herobrine without authorizations (no)
 | 
				
			||||||
        User noob = new User("boon","noob","noob@admintkt.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);
 | 
					        userRepository.save(noob);
 | 
				
			||||||
        tokenService.saveToken(noobToken);
 | 
					        tokenService.saveToken(noobToken);
 | 
				
			||||||
@ -105,7 +105,7 @@ public class UserControllerTest {
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
    @Test
 | 
					    @Test
 | 
				
			||||||
    public void userGetTest(){
 | 
					    public void userGetTest(){
 | 
				
			||||||
        User herobrine = new User("brine","hero","herobrine@admin.com","in your WalLs","ShadowsLand",new Date(0), null,Role.Student,"test");
 | 
					        User herobrine = new User("brine","hero","herobrine@student.com","in your WalLs","ShadowsLand",new Date(0), null,Role.Student,"test");
 | 
				
			||||||
        userRepository.save(herobrine);
 | 
					        userRepository.save(herobrine);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        Token t = new Token(herobrine, tokenService.generateNewToken(), new Date());
 | 
					        Token t = new Token(herobrine, tokenService.generateNewToken(), new Date());
 | 
				
			||||||
 | 
				
			|||||||
@ -70,7 +70,7 @@ class TokenServiceTest {
 | 
				
			|||||||
        ArrayList<Token> tokenList = new ArrayList<>();
 | 
					        ArrayList<Token> tokenList = new ArrayList<>();
 | 
				
			||||||
        GregorianCalendar gc = new GregorianCalendar();
 | 
					        GregorianCalendar gc = new GregorianCalendar();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        User malveillant = new User("mechant", "veutdestoken", "donnezmoidestoken@mail.com", "secret", "secret", null, null, null, "secret");
 | 
					        User malveillant = new User("Cargo", "John", "CargoJ@mail.com", "secret", "secret", null, null, null, "secret");
 | 
				
			||||||
        userRepository.save(malveillant);
 | 
					        userRepository.save(malveillant);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        for (int i = 0; i < 20; i++){
 | 
					        for (int i = 0; i < 20; i++){
 | 
				
			||||||
 | 
				
			|||||||
@ -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,12 +86,9 @@ 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>
 | 
				
			||||||
@ -99,6 +96,8 @@ window.addEventListener('hashchange', () => {
 | 
				
			|||||||
<style scoped>
 | 
					<style scoped>
 | 
				
			||||||
  
 | 
					  
 | 
				
			||||||
  .container{
 | 
					  .container{
 | 
				
			||||||
 | 
								height: 100%;
 | 
				
			||||||
 | 
								width: 100%;
 | 
				
			||||||
    display:grid;
 | 
					    display:grid;
 | 
				
			||||||
    grid-template-columns:[firstCol-start]70px[firstCol-end secondCol-start]auto[endCol];
 | 
					    grid-template-columns:[firstCol-start]70px[firstCol-end secondCol-start]auto[endCol];
 | 
				
			||||||
    grid-template-rows:[firstRow-start]61px[firstRow-end secondRow-start] auto [endRow];
 | 
					    grid-template-rows:[firstRow-start]61px[firstRow-end secondRow-start] auto [endRow];
 | 
				
			||||||
@ -111,6 +110,8 @@ window.addEventListener('hashchange', () => {
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
  .page {
 | 
					  .page {
 | 
				
			||||||
    grid-area:page;
 | 
					    grid-area:page;
 | 
				
			||||||
 | 
							height: 100%;
 | 
				
			||||||
 | 
							width: 100%;
 | 
				
			||||||
    place-self:center;
 | 
					    place-self:center;
 | 
				
			||||||
  }
 | 
					  }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
				
			|||||||
@ -56,10 +56,10 @@
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
<template>
 | 
					<template>
 | 
				
			||||||
      <div class='loginBox'>
 | 
					    <div class="setup">
 | 
				
			||||||
 | 
					 | 
				
			||||||
        <div v-if="loginPage">
 | 
					        <div v-if="loginPage">
 | 
				
			||||||
          <form @submit.prevent=" login(outputs.email,outputs.password);goBackHome();"class="form">
 | 
					      <div class='loginBox' style="margin-top:30%;">
 | 
				
			||||||
 | 
					          <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,15 @@
 | 
				
			|||||||
            <div class="register">
 | 
					            <div class="register">
 | 
				
			||||||
              <a @click="loginPage=!loginPage">{{i18n("login.guest.register")}}</a>
 | 
					              <a @click="loginPage=!loginPage">{{i18n("login.guest.register")}}</a>
 | 
				
			||||||
            </div>
 | 
					            </div>
 | 
				
			||||||
            <div class="inputBox">
 | 
					            <div class="inputBox" style="margin-bottom:35px;">
 | 
				
			||||||
              <input type="submit" v-model="submitValue">
 | 
					              <input type="submit" v-model="submitValue">
 | 
				
			||||||
            </div>
 | 
					            </div>
 | 
				
			||||||
          </form>
 | 
					          </form>
 | 
				
			||||||
        </div>
 | 
					        </div>
 | 
				
			||||||
 | 
					      </div>
 | 
				
			||||||
        <div v-else>
 | 
					        <div v-else>
 | 
				
			||||||
          <form class="form">
 | 
					          <div class='loginBox' style="margin-top:30%; margin-bottom:50%;">
 | 
				
			||||||
 | 
					            <form class="form">
 | 
				
			||||||
            <h1 style="color:rgb(239,60,168); font-family: sans-serif; text-align:center;">
 | 
					            <h1 style="color:rgb(239,60,168); font-family: sans-serif; text-align:center;">
 | 
				
			||||||
              {{i18n("login.guest.welcome")}}
 | 
					              {{i18n("login.guest.welcome")}}
 | 
				
			||||||
            </h1>
 | 
					            </h1>
 | 
				
			||||||
@ -128,9 +129,12 @@
 | 
				
			|||||||
                <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 novalidate enctype="multipart/form-data" class="inputBox">
 | 
					              <form class="inputBox"novalidate enctype="multipart/form-data">
 | 
				
			||||||
              	<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/*">
 | 
					              <label class="browser">
 | 
				
			||||||
 | 
					                Parcourir . . .
 | 
				
			||||||
 | 
									        <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> 
 | 
				
			||||||
@ -153,35 +157,26 @@
 | 
				
			|||||||
            </div>
 | 
					            </div>
 | 
				
			||||||
          </form>
 | 
					          </form>
 | 
				
			||||||
         </div>
 | 
					         </div>
 | 
				
			||||||
        </div>
 | 
					    </div>
 | 
				
			||||||
 | 
					  </div>
 | 
				
			||||||
</template>
 | 
					</template>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
<style scoped>
 | 
					<style scoped>
 | 
				
			||||||
.Home{
 | 
					 | 
				
			||||||
  position:absolute;
 | 
					 | 
				
			||||||
 	display: flex;
 | 
					 | 
				
			||||||
  z-index: 100;
 | 
					 | 
				
			||||||
	padding: 8px 16px;
 | 
					 | 
				
			||||||
	color:rgb(255, 255, 255);
 | 
					 | 
				
			||||||
	text-decoration: none;
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
.Home:hover{
 | 
					.setup {
 | 
				
			||||||
  width:40px;
 | 
					  margin-left: auto;
 | 
				
			||||||
  background-color: black;
 | 
					  margin-right:auto;
 | 
				
			||||||
	border-radius:6px;
 | 
					  min-width:400px;
 | 
				
			||||||
	color:white;
 | 
					 | 
				
			||||||
  transform: translate(0px ,1px);
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  width:25%;
 | 
				
			||||||
 | 
					  height:60%;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
.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;
 | 
				
			||||||
  padding: 40px;
 | 
					  border-radius: 5%;
 | 
				
			||||||
  border-radius: 20px;
 | 
					 | 
				
			||||||
  box-shadow:0 5px 25px #000000;
 | 
					  box-shadow:0 5px 25px #000000;
 | 
				
			||||||
  
 | 
					  
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
@ -190,9 +185,8 @@
 | 
				
			|||||||
  width:100%;
 | 
					  width:100%;
 | 
				
			||||||
  display: flex;
 | 
					  display: flex;
 | 
				
			||||||
  flex-direction: column;
 | 
					  flex-direction: column;
 | 
				
			||||||
  justify-content: center;
 | 
					 | 
				
			||||||
  align-items:center;
 | 
					  align-items:center;
 | 
				
			||||||
  gap: 15px;
 | 
					  gap: 3%;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@ -200,12 +194,12 @@
 | 
				
			|||||||
  
 | 
					  
 | 
				
			||||||
  width:100%;
 | 
					  width:100%;
 | 
				
			||||||
  border: none;
 | 
					  border: none;
 | 
				
			||||||
  margin-right: 50px;
 | 
					  margin-right: 12.5%;
 | 
				
			||||||
  padding-left: 10px;
 | 
					  padding-left: 2.5%;
 | 
				
			||||||
  padding-top:10px;
 | 
					  padding-top:2.5%;
 | 
				
			||||||
  padding-bottom:10px;
 | 
					  padding-bottom:2.5%;
 | 
				
			||||||
  outline:none;
 | 
					  outline:none;
 | 
				
			||||||
  border-radius: 4px;
 | 
					  border-radius: 10px;
 | 
				
			||||||
  font-size:1.35em;
 | 
					  font-size:1.35em;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@ -220,8 +214,9 @@
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
.register{
 | 
					.register{
 | 
				
			||||||
  color:rgb(239,60,168);
 | 
					  color:rgb(239,60,168);
 | 
				
			||||||
  width: 100%;
 | 
					  width:70%;
 | 
				
			||||||
  display:flex;
 | 
					  margin-bottom:20px;
 | 
				
			||||||
 | 
					  margin-top:20px;
 | 
				
			||||||
  cursor: pointer;
 | 
					  cursor: pointer;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@ -250,6 +245,21 @@ input[type=submit],button,select{
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					input[type=file]{
 | 
				
			||||||
 | 
					  display:none;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					.browser{
 | 
				
			||||||
 | 
					  display:inline-block;
 | 
				
			||||||
 | 
					  cursor:pointer;
 | 
				
			||||||
 | 
					  border-radius:20px;
 | 
				
			||||||
 | 
					  background-color:rgb(239,60,168);
 | 
				
			||||||
 | 
					  padding:5%;
 | 
				
			||||||
 | 
					  font-size:1.35em;
 | 
				
			||||||
 | 
					  font-family:sans-serif;
 | 
				
			||||||
 | 
					  background:#FFFFFF;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
button:active ,.switchpage:active{
 | 
					button:active ,.switchpage:active{
 | 
				
			||||||
  opacity:0.8;
 | 
					  opacity:0.8;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
				
			|||||||
@ -1,4 +1,11 @@
 | 
				
			|||||||
body {
 | 
					body {
 | 
				
			||||||
   background-color: rgb(53, 25, 60);
 | 
					   background-color: rgb(53, 25, 60);
 | 
				
			||||||
   margin:0;
 | 
					   margin:0;
 | 
				
			||||||
 | 
					   width: 100vw;
 | 
				
			||||||
 | 
					   height: 100vh;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#app {
 | 
				
			||||||
 | 
					   width: 100%;
 | 
				
			||||||
 | 
					   height: 100%;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
				
			|||||||
		Reference in New Issue
	
	Block a user