From 6b171210ae723b3d22dcaf99bcbb184458c71d11 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Leonardo=20Mur=C3=A7a?= Date: Wed, 17 Aug 2022 21:18:57 -0300 Subject: [PATCH] Add desktop assignments tab layout without loading --- src/screens/Classroom/AssignmentsTab/index.js | 168 +++++++++++++++++- src/screens/Classroom/View.js | 5 +- src/services/mocks.js | 9 + 3 files changed, 176 insertions(+), 6 deletions(-) diff --git a/src/screens/Classroom/AssignmentsTab/index.js b/src/screens/Classroom/AssignmentsTab/index.js index a71574d..ce7b9e3 100644 --- a/src/screens/Classroom/AssignmentsTab/index.js +++ b/src/screens/Classroom/AssignmentsTab/index.js @@ -1,8 +1,166 @@ -function AssignmentsTab({ assignmentsTabData }) { - return assignmentsTabData && assignmentsTabData.state === 'loading' ? ( -

Loading..

- ) : assignmentsTabData.state === 'gone' ? null : ( -

Assignments Tab

+import { Container, Link, Stack, Typography } from '@mui/material'; +import dayjs from 'dayjs'; +import { capitalizeFirstLetter } from '../../../utils/capitalizeFirstLetter'; + +function AssignmentsTab({ assignmentsTabData, layoutType }) { + console.log(assignmentsTabData); + const layoutResolver = (state, assignments, layoutType) => { + if (layoutType === 'desktop') { + switch (state) { + case 'loading': + return

Loading...

; + + case 'idle': + return ( + + + + Provas + + + {assignments + .filter(a => a.type === 'assessment') + .map(a => ( + + + + {a.title} + + + + Data de entrega: {' '} + {capitalizeFirstLetter( + dayjs(a.dueDate).format('dddd, DD/MM | HH:mm[h]') + )} + + + Valor: + {a.scores.map(s => s.value).join(', ')} pts + + + ))} + + + + + + Trabalhos + + + {assignments + .filter(a => a.type === 'project') + .map(a => ( + + + + {a.title} + + + + Data de entrega: {' '} + {capitalizeFirstLetter( + dayjs(a.dueDate).format('dddd, DD/MM | HH:mm[h]') + )} + + + Valor: + {a.scores.map(s => s.value).join(', ')} pts + + + ))} + + + + ); + + case 'gone': + return null; + + default: + return null; + } + } else if (layoutType === 'mobile') { + switch (state) { + case 'loading': + return

Loading...

; + + case 'idle': + return

Assignments Tab

; + + case 'gone': + return null; + + default: + return null; + } + } + }; + + return layoutResolver( + assignmentsTabData && assignmentsTabData.state, + assignmentsTabData && assignmentsTabData.assignments, + layoutType ); } diff --git a/src/screens/Classroom/View.js b/src/screens/Classroom/View.js index d559917..69af2d7 100644 --- a/src/screens/Classroom/View.js +++ b/src/screens/Classroom/View.js @@ -28,7 +28,10 @@ function View({ announcementsTabData={announcementsTabData} classroom={classroom && classroom} /> - + ); } diff --git a/src/services/mocks.js b/src/services/mocks.js index d6bed3b..d358ef7 100644 --- a/src/services/mocks.js +++ b/src/services/mocks.js @@ -98,6 +98,7 @@ const allClassrooms = [ const allAssignments = [ { id: '5435', + type: 'assessment', title: 'Prova 1 - Armazenamento de Dados. Python em CD. Armazenamento Analítico', dueDate: '2022-07-01 23:59', @@ -111,6 +112,7 @@ const allAssignments = [ }, { id: '0128', + type: 'assessment', title: 'Prova 2 - Visualização de Dados. Matemática e Estatística em CD. Análise de Dados', dueDate: '2022-09-01 23:59', @@ -124,6 +126,7 @@ const allAssignments = [ }, { id: '1234', + type: 'project', title: 'Trabalho NoSQL', dueDate: '2022-06-29 22:00', scores: [ @@ -136,6 +139,7 @@ const allAssignments = [ }, { id: '1234', + type: 'assessment', title: 'Atividade 2 - Estudo de caso Sapiens Informática', dueDate: '2022-06-25 23:59', scores: [ @@ -148,6 +152,7 @@ const allAssignments = [ }, { id: '3671', + type: 'assessment', title: 'AA08 - Atividade de Aprendizagem 08 - Componentes de rateio de custos', dueDate: '2022-07-23 10:00', @@ -161,6 +166,7 @@ const allAssignments = [ }, { id: '1717', + type: 'project', title: 'Trabalho interdisciplinar', dueDate: '2022-08-20 23:59', scores: [ @@ -294,6 +300,7 @@ const allClassroomAnnouncements = [ const allUpcomingAssignments = [ { id: '5435', + type: 'assessment', title: 'Prova 1 - Armazenamento de Dados. Python em CD. Armazenamento Analítico', dueDate: '2022-07-01 23:59', @@ -307,6 +314,7 @@ const allUpcomingAssignments = [ }, { id: '0128', + type: 'assessment', title: 'Prova 2 - Visualização de Dados. Matemática e Estatística em CD. Análise de Dados', dueDate: '2022-09-01 23:59', @@ -320,6 +328,7 @@ const allUpcomingAssignments = [ }, { id: '1234', + type: 'project', title: 'Trabalho NoSQL', dueDate: '2022-06-29 22:00', scores: [