Compare commits
2 Commits
cb750b8505
...
7bd745fd5e
Author | SHA1 | Date | |
---|---|---|---|
7bd745fd5e | |||
a96609d2ef |
@ -99,20 +99,19 @@ window.addEventListener('hashchange', () => {
|
|||||||
height: 100%;
|
height: 100%;
|
||||||
width: 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] var(--header-size) [firstRow-end secondRow-start] calc(100% - var(--header-size)) [endRow];
|
||||||
grid-template-areas:
|
grid-template-areas:
|
||||||
"topBar topBar"
|
"topBar topBar"
|
||||||
"leftBar page";
|
"leftBar page";
|
||||||
row-gap:0px;
|
|
||||||
column-gap:0px;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
.page {
|
.page {
|
||||||
grid-area:page;
|
grid-area:page;
|
||||||
height: 100%;
|
height: 100%;
|
||||||
width: 100%;
|
width: 100%;
|
||||||
place-self:center;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
.topBar{
|
.topBar{
|
||||||
@ -155,7 +154,7 @@ window.addEventListener('hashchange', () => {
|
|||||||
|
|
||||||
ul.vertical{
|
ul.vertical{
|
||||||
list-style-type: none;
|
list-style-type: none;
|
||||||
margin-top: 61px;
|
margin-top: var(--header-size);
|
||||||
top:0;
|
top:0;
|
||||||
left:0;
|
left:0;
|
||||||
padding: 25px 0 0;
|
padding: 25px 0 0;
|
||||||
@ -203,7 +202,7 @@ window.addEventListener('hashchange', () => {
|
|||||||
left:0;
|
left:0;
|
||||||
|
|
||||||
position: fixed;
|
position: fixed;
|
||||||
height:61px;
|
height:var(--header-size);
|
||||||
width: 100%;
|
width: 100%;
|
||||||
background-color: rgb(24, 24, 24);
|
background-color: rgb(24, 24, 24);
|
||||||
}
|
}
|
||||||
|
138
frontend/src/Apps/Forums.vue
Normal file
138
frontend/src/Apps/Forums.vue
Normal file
@ -0,0 +1,138 @@
|
|||||||
|
<!----------------------------------------------------
|
||||||
|
File: Forums.vue
|
||||||
|
Author: Anthony Debucquoy
|
||||||
|
Scope: Extension messagerie
|
||||||
|
Description: Forum des étudiants
|
||||||
|
----------------------------------------------------->
|
||||||
|
|
||||||
|
<script setup>
|
||||||
|
import { ref, reactive } from 'vue'
|
||||||
|
import { getCourses } from '@/rest/courses.js'
|
||||||
|
import { ForumsOfCurrentCourse, getForumsOfCourse } from '@/rest/forum.js'
|
||||||
|
import { PostsOfCurrentForum, getPostsOfForum } from '@/rest/forum.js'
|
||||||
|
import { fetchedPost, fetchPost } from '@/rest/forum.js'
|
||||||
|
|
||||||
|
const courses = await reactive(getCourses());
|
||||||
|
const selectedCourse = ref();
|
||||||
|
const selectedForum = ref();
|
||||||
|
|
||||||
|
</script>
|
||||||
|
|
||||||
|
<template>
|
||||||
|
<div id="app">
|
||||||
|
<div id="ForumSelector">
|
||||||
|
<select id="cours" value="" v-model="selectedCourse" @change="getForumsOfCourse(selectedCourse)">
|
||||||
|
<option v-for="course in courses" :value="course.courseId">{{course.title}}</option>
|
||||||
|
</select>
|
||||||
|
|
||||||
|
<select id="forum" value="" v-model="selectedForum" @change="getPostsOfForum(selectedForum)" v-if="ForumsOfCurrentCourse != null">
|
||||||
|
<option v-for="forum in ForumsOfCurrentCourse" :value=forum.id>{{forum.name}}</option>
|
||||||
|
</select>
|
||||||
|
</div>
|
||||||
|
<div id="PostSelector" v-if="PostsOfCurrentForum != null">
|
||||||
|
<div @click="fetchPost(post.id)" class="postItem" v-for="post in PostsOfCurrentForum" :key="post.id">{{ post.name }}</div>
|
||||||
|
<!--button id="createPost" @click="createPost()">+</button-->
|
||||||
|
</div>
|
||||||
|
<div id="PostViewer" v-if="fetchedPost != null">
|
||||||
|
<div id="Post">
|
||||||
|
<h1>{{ fetchedPost.subject }}</h1>
|
||||||
|
{{fetchedPost.content}}
|
||||||
|
</div>
|
||||||
|
<div id="Messages">
|
||||||
|
<p v-for="msg in fetchedPost.messages">{{msg.author}} - {{msg.content}}</p>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</template>
|
||||||
|
|
||||||
|
<style scoped>
|
||||||
|
|
||||||
|
#app{
|
||||||
|
display: grid;
|
||||||
|
width: 100%;
|
||||||
|
height: 100%;
|
||||||
|
grid-template: 5em auto / 25% 75%;
|
||||||
|
}
|
||||||
|
|
||||||
|
#ForumSelector{
|
||||||
|
background-color: #FFFFFF0E;
|
||||||
|
grid-column: 1 / 3;
|
||||||
|
border-radius: 100px;
|
||||||
|
margin: 10px;
|
||||||
|
display: flex;
|
||||||
|
justify-content: space-around;
|
||||||
|
}
|
||||||
|
|
||||||
|
#ForumSelector select{
|
||||||
|
background-color: #ffa000;
|
||||||
|
border: none;
|
||||||
|
margin: 10px;
|
||||||
|
border-radius: 10px;
|
||||||
|
width: 200px;
|
||||||
|
text-align: center;
|
||||||
|
}
|
||||||
|
|
||||||
|
#ForumSelector button{
|
||||||
|
background-color: green;
|
||||||
|
border: none;
|
||||||
|
border-radius: 25%;
|
||||||
|
margin: 10px;
|
||||||
|
}
|
||||||
|
|
||||||
|
#PostSelector{
|
||||||
|
background-color: #FFFFFF0E;
|
||||||
|
border-radius: 0 25px 25px 0;
|
||||||
|
margin: 10px 0 10px 10px;
|
||||||
|
overflow: hidden;
|
||||||
|
padding: 10px;
|
||||||
|
|
||||||
|
display: flex;
|
||||||
|
flex-direction: column;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
.postItem{
|
||||||
|
color: darkorange;
|
||||||
|
display: flex;
|
||||||
|
font-family: sans-serif;
|
||||||
|
font-weight: bold;
|
||||||
|
height: 4vh;
|
||||||
|
margin: 5px;
|
||||||
|
border-radius: 0 30px 30px 0;
|
||||||
|
align-items: center;
|
||||||
|
justify-content: center;
|
||||||
|
border: 1px solid darkorange;
|
||||||
|
}
|
||||||
|
|
||||||
|
.postItem:hover{
|
||||||
|
background-color: gray;
|
||||||
|
}
|
||||||
|
|
||||||
|
#PostViewer{
|
||||||
|
background-color: #FFFFFF0E;
|
||||||
|
border-radius: 25px;
|
||||||
|
margin: 10px;
|
||||||
|
|
||||||
|
max-height: 100%;
|
||||||
|
|
||||||
|
overflow: scroll;
|
||||||
|
}
|
||||||
|
|
||||||
|
#Post{
|
||||||
|
padding: 25px;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
#Messages{
|
||||||
|
padding: 25px;
|
||||||
|
border-top: 3px dotted white;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
#Messages > p {
|
||||||
|
|
||||||
|
background-color: orange;
|
||||||
|
}
|
||||||
|
|
||||||
|
</style>
|
||||||
|
|
@ -1,3 +1,7 @@
|
|||||||
|
:root {
|
||||||
|
--header-size: 61px;
|
||||||
|
}
|
||||||
|
|
||||||
body {
|
body {
|
||||||
background-color: rgb(53, 25, 60);
|
background-color: rgb(53, 25, 60);
|
||||||
margin:0;
|
margin:0;
|
||||||
|
@ -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 Forums from '@/Apps/Forums.vue'
|
||||||
|
|
||||||
const apps = {
|
const apps = {
|
||||||
'/login': LoginPage,
|
'/login': LoginPage,
|
||||||
@ -17,12 +18,13 @@ const apps = {
|
|||||||
'/manage-courses' : Courses,
|
'/manage-courses' : Courses,
|
||||||
'/users-list' : Users,
|
'/users-list' : Users,
|
||||||
'/students-list' : Students,
|
'/students-list' : Students,
|
||||||
|
'/forums': Forums,
|
||||||
}
|
}
|
||||||
|
|
||||||
const appsList = {
|
const appsList = {
|
||||||
'Msg': { path: '#/msg', icon: 'fa-comment', text: i18n("app.messages") },
|
'Msg': { path: '#/msg', icon: 'fa-comment', text: i18n("app.messages") },
|
||||||
'Notification': { path: '#/notifs', icon: 'fa-bell', text: i18n("app.notifications") },
|
'Notification': { path: '#/notifs', icon: 'fa-bell', text: i18n("app.notifications") },
|
||||||
'Forum': { path: '#/forum', icon: 'fa-envelope', text: i18n("app.forum") },
|
'Forum': { path: '#/forums', icon: 'fa-envelope', text: i18n("app.forum") },
|
||||||
'Schedule': { path: '#/schedule', icon: 'fa-calendar-days', text: i18n("app.schedules") },
|
'Schedule': { path: '#/schedule', icon: 'fa-calendar-days', text: i18n("app.schedules") },
|
||||||
'Inscription': { path: '#/inscription', icon: 'fa-users', text: i18n("app.inscription.requests") },
|
'Inscription': { path: '#/inscription', icon: 'fa-users', text: i18n("app.inscription.requests") },
|
||||||
'ManageCourses': { path: '#/manage-courses', icon: 'fa-book', text: i18n("app.manage.courses") },
|
'ManageCourses': { path: '#/manage-courses', icon: 'fa-book', text: i18n("app.manage.courses") },
|
||||||
|
71
frontend/src/rest/forum.js
Normal file
71
frontend/src/rest/forum.js
Normal file
@ -0,0 +1,71 @@
|
|||||||
|
import { ref } from 'vue'
|
||||||
|
import { restGet, restPost, restDelete, restPatch } from './restConsumer.js'
|
||||||
|
|
||||||
|
/**
|
||||||
|
* List forums of a course
|
||||||
|
*/
|
||||||
|
export async function getForumsOfCourse(id){
|
||||||
|
ForumsOfCurrentCourse.value = [
|
||||||
|
{
|
||||||
|
id: 1,
|
||||||
|
name: "forum~1"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
id: 2,
|
||||||
|
name: "forum~2"
|
||||||
|
},
|
||||||
|
]
|
||||||
|
// ForumsOfCurrentCourse = await restGet("/forums/" + id)
|
||||||
|
}
|
||||||
|
|
||||||
|
export const ForumsOfCurrentCourse = ref();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* List post of a specified forum
|
||||||
|
*/
|
||||||
|
export async function getPostsOfForum(id){
|
||||||
|
PostsOfCurrentForum.value = [
|
||||||
|
{
|
||||||
|
id: 1,
|
||||||
|
name: "Post~1"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
id: 2,
|
||||||
|
name: "Post~2"
|
||||||
|
},
|
||||||
|
]
|
||||||
|
// PostsCurrentForum.value = await restGet("/forum/" + id);
|
||||||
|
}
|
||||||
|
|
||||||
|
export const PostsOfCurrentForum = ref();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get a post and its responses
|
||||||
|
*/
|
||||||
|
export async function fetchPost(id){
|
||||||
|
fetchedPost.value = {
|
||||||
|
id: 1,
|
||||||
|
subject: "This is the subject of the post",
|
||||||
|
content: "Lorem ipsum dolor sit amet, consetetur sadipscing elitr, sed diam nonumy eirmod tempor invidunt ut labore et dolore magna aliquyam erat, sed diam voluptua. At vero eos et accusam et justo duo dolores et ea rebum. Stet clita kasd gubergren, no sea takimata sanctus est Lorem ipsum dolor sit amet.",
|
||||||
|
messages: [
|
||||||
|
{
|
||||||
|
id: 1,
|
||||||
|
author: "author~1",
|
||||||
|
content: "J'ai pas copris le message !"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
id: 2,
|
||||||
|
author: "author~2",
|
||||||
|
content: "tu as fait une faute dans ton message..."
|
||||||
|
},
|
||||||
|
{
|
||||||
|
id: 3,
|
||||||
|
author: null,
|
||||||
|
content: "I'm anonymous noww..."
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
// fetchedPost.value = await restGet("/forum/post/" + id);
|
||||||
|
}
|
||||||
|
|
||||||
|
export const fetchedPost = ref();
|
Loading…
Reference in New Issue
Block a user