Manage course + delete course END
This commit is contained in:
		@ -1,14 +1,13 @@
 | 
			
		||||
<script setup>
 | 
			
		||||
  import i18n from "@/i18n.js"
 | 
			
		||||
  import {ref} from 'vue'
 | 
			
		||||
  import {reactive , ref} from 'vue'
 | 
			
		||||
  import { getCourses,deleteCourse,alterCourse,createCourse } from "@/rest/courses.js"
 | 
			
		||||
  import {getUser, getSelf, getTeachers } from "@/rest/Users.js"
 | 
			
		||||
  
 | 
			
		||||
  
 | 
			
		||||
  const self = await getSelf();
 | 
			
		||||
 | 
			
		||||
  let curriculum = await getCourses(self.role);
 | 
			
		||||
 | 
			
		||||
  const curriculum = ref(await getCourses(self.role));
 | 
			
		||||
  const profList = await getTeachers();
 | 
			
		||||
 | 
			
		||||
  console.log(curriculum)
 | 
			
		||||
@ -34,7 +33,7 @@
 | 
			
		||||
  let toModify = Object.assign({},pattern);
 | 
			
		||||
  let toAdd = Object.assign({}, pattern);
 | 
			
		||||
 | 
			
		||||
  function addToCourse(){
 | 
			
		||||
  async function addToCourse(){
 | 
			
		||||
    let isnull= false;
 | 
			
		||||
     
 | 
			
		||||
    for(const [key, value] of Object.entries(toAdd)){
 | 
			
		||||
@ -45,13 +44,13 @@
 | 
			
		||||
      
 | 
			
		||||
    }
 | 
			
		||||
    if (!isnull){
 | 
			
		||||
       createCourse(toAdd.title,toAdd.credits,toAdd.owner);
 | 
			
		||||
       await createCourse(toAdd.title,toAdd.credits,toAdd.owner);
 | 
			
		||||
       toAdd= Object.assign({},pattern);
 | 
			
		||||
       setTimeout(() => {
 | 
			
		||||
      window.location.reload();
 | 
			
		||||
      }, "250");
 | 
			
		||||
      }  
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
       curriculum.value = await getCourses(self.role);
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
    }}
 | 
			
		||||
  
 | 
			
		||||
  function setModify(item){
 | 
			
		||||
     for(const el in profList){
 | 
			
		||||
@ -65,35 +64,36 @@
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
  function patchCourse(course){
 | 
			
		||||
  async function patchCourse(course){
 | 
			
		||||
    for (let element in toModify){
 | 
			
		||||
        console.log(toModify,1)
 | 
			
		||||
        console.log(toModify[element],2)
 | 
			
		||||
      
 | 
			
		||||
        if (element =="owner" && (toModify[element].regNo != course.owner.regNo)){
 | 
			
		||||
           alterCourse(course.courseId,{owner:toModify[element].regNo});
 | 
			
		||||
          await alterCourse(course.courseId,{owner:toModify[element].regNo});
 | 
			
		||||
        }
 | 
			
		||||
        else if(element == "title" && (toModify[element] != course.title)){
 | 
			
		||||
        alterCourse(course.courseId,{title:toModify[element]});
 | 
			
		||||
         await alterCourse(course.courseId,{title:toModify[element]});
 | 
			
		||||
        }
 | 
			
		||||
        else if(element == "credits" && (parseInt(toModify[element]) != course.credits)){
 | 
			
		||||
          alterCourse(course.courseId,{credits:parseInt(toModify[element])});
 | 
			
		||||
         await alterCourse(course.courseId,{credits:parseInt(toModify[element])});
 | 
			
		||||
        }
 | 
			
		||||
         
 | 
			
		||||
      
 | 
			
		||||
    
 | 
			
		||||
    }toModify = Object.assign({},pattern);
 | 
			
		||||
    }
 | 
			
		||||
      toModify= Object.assign({},pattern);
 | 
			
		||||
 | 
			
		||||
    setTimeout(() => {
 | 
			
		||||
      window.location.reload();
 | 
			
		||||
      }, "500");
 | 
			
		||||
      curriculum.value = await getCourses(self.role);
 | 
			
		||||
 | 
			
		||||
    
 | 
			
		||||
  }
 | 
			
		||||
  //Juste pour montrer le Delete Mode
 | 
			
		||||
  let toRemove;
 | 
			
		||||
 | 
			
		||||
  function removeCourse(course) {
 | 
			
		||||
     deleteCourse(course.id)
 | 
			
		||||
        }
 | 
			
		||||
  let toRemove = null;
 | 
			
		||||
  
 | 
			
		||||
  async function removeCourse(course) {
 | 
			
		||||
      
 | 
			
		||||
     await deleteCourse(course.courseId)
 | 
			
		||||
    curriculum.value = await getCourses(self.role);
 | 
			
		||||
    toRemove = null;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
</script>
 | 
			
		||||
<template>
 | 
			
		||||
@ -131,19 +131,11 @@
 | 
			
		||||
        <div style="margin-bottom:20px;">
 | 
			
		||||
          {{i18n("courses.toDelete")}} :
 | 
			
		||||
         <select style="max-width:200px;" class="teacher" v-model="toRemove">
 | 
			
		||||
          <option v-for="item in curriculum">{{item.title}}</option>
 | 
			
		||||
          <option v-for="item in curriculum" :value='item'>{{item.title}}</option>
 | 
			
		||||
          
 | 
			
		||||
        </select>
 | 
			
		||||
        </div>
 | 
			
		||||
        <div style="margin-bottom:20px;">
 | 
			
		||||
          {{i18n("login.password")}}: 
 | 
			
		||||
        <input >
 | 
			
		||||
        </div>
 | 
			
		||||
        <div style="margin-bottom:20px;">
 | 
			
		||||
          {{i18n("login.cPassword")}} : 
 | 
			
		||||
        <input>
 | 
			
		||||
        </div>
 | 
			
		||||
        <button class="delete" @click="deleteMod=!deleteMod;removeCourse(toRemove);"> {{i18n("courses.deleteCourse")}} </button>
 | 
			
		||||
        <button class="delete" @click="deleteMod=!deleteMod; removeCourse(toRemove);"> {{i18n("courses.deleteCourse")}} </button>
 | 
			
		||||
        <button style="float:right;" @click="deleteMod=!deleteMod"> {{i18n("courses.back")}}</button>
 | 
			
		||||
      </form>
 | 
			
		||||
    </div>
 | 
			
		||||
 | 
			
		||||
@ -16,8 +16,8 @@ export async function restPostFile(endPoint, file){
 | 
			
		||||
	return await _rest(endPoint, {method: "POST", credentials: 'include', body: file, headers: headers });
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
export async function restDelete(endPoint, data) {
 | 
			
		||||
	return await _rest(endPoint, {method: "DELETE", credentials: 'include', body: JSON.stringify(data)});
 | 
			
		||||
export async function restDelete(endPoint) {
 | 
			
		||||
	return await _rest(endPoint, {method: "DELETE"});
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
export async function restPatch(endPoint, data) {
 | 
			
		||||
 | 
			
		||||
		Reference in New Issue
	
	Block a user