Giter VIP home page Giter VIP logo

p2's People

Contributors

andreasahlbeck avatar aosnes avatar bisgaard01 avatar mikejensen0 avatar sigurd00 avatar victordore avatar

Stargazers

 avatar  avatar  avatar

p2's Issues

Use Redux for state handling

Right now the cookies needs to be force rerendered all the time, which is not an elegant way of handling states on the site, as opposed to Redux, which makes the states persist automatically in the cookies.

Sidebar component rendering alt efter bruger type

Issue #22 er nødvendig før dette kan gøres

Der er lavet en sidebart efter det mockup der er lavet, nice.
Nu skal det gøres så sidebar render forskellige muligheder for navigering på siden alt efter hvilken type user der er logget ind.

Lav read operations til promises og fjern await

Lige nu venter funktionen på at find og findOne resolver. Ved at lave det til promises kan det fyres i event queue i stedet og andet lort kan laves imens. Ville være pog at have men det er ikke livsnødvendigt.

HTTP response på login

Lige nu svarer serveren bare med oplysningerne på brugeren hvis den kunne findes i databasen.

Det skal laves så en autoriseret session bliver oprettet.

Skema component skal render skemabrikker

Dette skal ske efter vi har fået et 200 OK response med skema brikkerne fra serveren i JSON.

Jeg forestiller mig noget i denne retning:

response.foreach(skemabrik =>{ <Skemabrik props=skemabrik/> })
Hvor response er JSON resultatet af vores fetch på /getSchedule

Vi skal finde ud af hvordan vi håndetere session

Lige nu er der dårligt nok persistens på clienten og serveren.

Vi skal finde ud af den bedste metode til at gøre dette. Det kræver nok en del undersøgelse at få gjort ORDENTLIGT og ikke bare totalt yolo.

Der skal nok være session på serveren så serveren kan se om brugeren har tilladelse til at lave de http requests som de laver. fx skal

GET og PATCH /userinfo være restricted så man ikke bare kan opdatere alles passwords eller se alles informationer, hvis man har deres ID, men at man først skal være logget ind, og derefter at session passer med den ID man prøver at GET / PATCH

Begræns timeIndicator til kun at blive renderet indenfor skemaet

Pt er timeIndicatoren ikke begrænset til kun at blive renderet indenfor schedule og ender derfor med at bevæge sig udenfor skemaet, når klokken er mindre end 8 eller mere end 16. Se billede. Dette kan formentlig fixes ved kun at render timeIndicatoren, hvis currentTime er indenfor skemaets rammer (currentTime >= 8 && currentTime <= 16)
image

Tests af server

https://trello.com/c/Kfnn6XgR/5-unit-testing

Der er en række funktioner på server siden som kan blive testet nu hvor jest er sat op til at virke på /server directory

  • authenticate
  • getSchedule
  • createLesson
  • updateLesson

Derudover er der en række endpoints som også kan blive testet

  • POST /login
  • POST /classes
  • GET /classes
    Samt mange flere meget snart...

Fix client.connect i util

Serveren virker ikke lige nu fordi vi har flyttet funktionerne over i en util fil.

Derfor skal vi få client.connect til at virke

MAN KAN IKKE BARE SMIDE DET OVER I UTIL, for så virker tests ikke længere

Løsningsforslag:
Check om der er en connection i starten af alle funktioner, hvis der ikke er, kør en funktion der kører client.connect.
Sørg for at client.connect ikke kører hvis der bliver kørt test af filen

Elever kan tilgå redigerSkema gennem url

Det burde ikke være muligt for elever at tilgå rediger skema, hvilket er undgået i første omgang ved at fjerne knappen med link til redigerSkema. De kan dog blot indtaste /redigerSkema og dermed tilgå redigerskema. Det var dog ikke muligt at oprette en skemabrik, da der skal være flere klasser for at kunne sætte værdien for staten (sættes på ændring af form value).
image

Lav view controller component

Der skal laves et component som bestemmer om der skal være 5 day view eller 1 day view.

Den kan bare bestemme hvilket component det bliver rendered ud fra dens state. Som default vil den have 1 day view i sin state, og slideren vil så bare toggle frem og tilbage mellem 1 og 5 dag view. Det kan være en boolean.

Hvilket component der bliver renderet kan bestemmes med en conditional statement:

dayView ? <OneDayView/> : <FiveDayView/>

Test fetch using mock

Det ser ud til at der enten er noget galt med den måde vi prøver at mock fetch, eller at der er noget galt med submit (Måske skal dette også mockes)

Prøver man at køre det uden mock på linje 58-62, så virker det fint.

HMM SKAL VI LADE VÆRE MED AT MOCK? TILTER FUCKING HÅRDT REEEE

HVORFOR FÅR VI OVERHOVEDET ERROR VED l26, den burde MOCK DET LORT

AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA

billede
billede

Skemabrik modals visning når man trykker på flere skemabrikker

Man kan trykke på flere skemabrikke imens man har modals oppe, dette gør at man kan åbne flere modals ovenpå hinanden.

Man skal enten gøre så man ikke kan trykke på skemabrikker når man har en modal oppe, eller man skal gøre så det er tydeligt at flere modals bliver åbnet.

Hvis man vil lave den anden løsning skal man nok også sørge for at modals bliver renderet ordentligt ovenpå hinanden så de ikke cucker hinandens display tilfældigt.

Man skal kunne upload aflevering på assignment brik

#189 Skal nok ske først

  • skemabrikModal skal laves om så den kan bruges til måde skemabrikker og til 'assignmentbrikker'.
  • Assignmentbrikker skal indikere at der er blevet afleveret.
  • Lige nu smider vi skemabrik._id over, det skal ændres til at være assignment._id så serveren kan finde ud af hvilken assignment den skal markere som afleveret på databasen

På serveren:

  • Sørg for at der kommer ordentlig http response codes.
  • Sørg for at assignment i database får koblet et fileID på sig (Det her bliver resolved fra saveFile funktionen.)

App.js skal give skema et prop efter hvilken side man er på

Hvis man er på /skema skal den vise skemabrikker
Hvis man er på /afleveringer skal den vise afleveringerne.

Der er et par ting som skal fixes i Skema komponent for at dette kan ske eksempelvis:

  • Der skal laves fetch til to forskellige endpoints (Det kan løses ved at ændre i request string)
  • Der skal mappes af to forskellige arrays (Man kan nok bare smide alle brikkerne ind i det samme array og på denne måde generalisere over skema.map)
  • Modal skal renders på forskellige måder

Lærer skal kunne se en side med afleveret afleveringer

  • Der skal laves en route på serveren fx localhost:5000/assignments/handedIn
  • Der skal laves et view på front-end der viser et overblik over alle afleveret afleveringer
  • Man skal kunne trykke på en aflevering for at se den afleveret fil og for at give feedback.
    billede
  • For at brugeren kan se den aflevert fil skal serveren få den relevante fil fra databasen og sende den til brugeren
  • Man skal kunne give en reaktion, og man skal kunne upload en fil

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.