Skip to content

Vivanne

Vivanne edited this page Jun 14, 2024 · 18 revisions

Elk teamlid maakt een eigen persoonlijke pagina.

Verslag per week

Week 3

Wat heb ik deze week gedaan per competentie?

Prototypen en uitwerken: MongoDB aangemaakt! Ontwerpen: UI doorgenomen(mijn groepje heeft het ontworpen)

Welke hulpvragen heb ik?

Wat is MongoDB precies. Database?

Week 4

Herhaal deze structuur voor elke projectweek

Wat heb ik deze week gedaan per competentie?

Verbeelden en conceptualiseren: Ik heb onderzoek gedaan naar de Spotify API. En vanuit het perspectief van de gebruiker bepaald welke endpoints en requests we allemaal nodig gingen hebben. En daar een lijstje van gemaakt. Dit zal er voor zorgen dat we tijdens het bouwen makkelijker weten wat we wel en niet kunnen bouwen en linkjes naar de info ervan hebben. Op deze manier ben ik ook bekender geworden met de termen uit de api.

Ook hebben we wat schetsen gemaakt om duidelijker te krijgen hoe we het menu eruit wilde laten zien, en hoe het swipen eruit zou zien. Zie bijlage hieronder.

image image

Oriënteren en begrijpen: We hebben deze week gespard over ons concept en schermen flow, zodat iedereen op een lijn zat met welke pagina's we zouden gaan maken en wisten wat wel en niet mogelijk was met de app. Bijvoorbeeld muziek swipen gebaseerd op genre. We hebben dus de keuze gemaakt om alleen te kunnen swipen op tracks en artiesten.

Welke feedbackvragen heb ik?

Hoe moet ik nu verder? Ik heb nooit eerder met backend code gewerkt en het is me niet duidelijk waar ik nu moet beginnen. Vooral omdat Sep ook wel al wat dingen had opgezet. Hier was ik nog maar een klein beetje over ingelicht.

Welke feedback heb ik ontvangen?

Sep heeft wat uitleg gegeven over hoe verder en wat hij al had opgezet qua code. Ook heb ik gehoord dat het handig was om de uitleg video over Github te kijken. Dit zou later in het project minder chaos veroorzaken.

Week 5

Wat heb ik deze week gedaan per competentie?

Prototypen en uitwerken: MongoDB aangemaakt! (als oefening) Samen ontwerpen / Oriënteren en begrijpen: Ik heb samen met Sep de User Requirement list opgesteld. Om daaruit prioriteiten te stellen hebben we de MoSCoW methode toegepast op de lijst. (zie hieronder)

User requirement list:

M -> Must have

S -> Should have

C -> Could have

W -> Won't have

Aanmeldings- en Gebruikersbeheer

(M) Gebruikers moeten zich kunnen aanmelden met hun Spotify-account. (M) Gebruikers moeten hun profiel kunnen bekijken. (M) Gebruikers moeten zich kunnen afmelden van de web-app. Muziekaanbevelingen

(M) Aanbevelingen op Basis van Luistergeschiedenis: De web-app moet aanbevelingen doen op basis van de recente luistergeschiedenis van de gebruiker op Spotify. (M) Aanbevelingen op Basis van persoonlijke top Nummers: De web-app moet aanbevelingen doen op basis van de top nummers van de gebruiker op Spotify. (C) Populaire Aanbevelingen: De web-app moet populaire nummers aanbevelen die veel worden beluisterd door andere gebruikers met vergelijkbare smaak. Interactie met Aanbevelingen

(M) Swipe Functie: Gebruikers moeten nummers naar rechts kunnen swipen als ze het nummer leuk vinden en naar links kunnen swipen als ze het nummer niet leuk vinden. (M) Nummer Opslaan: Gebruikers moeten de optie hebben om een nummer dat ze leuk vinden op te slaan in een Spotify-afspeellijst. (M) Nummer Overslaan: Gebruikers moeten de optie hebben om een nummer over te slaan als ze het niet leuk vinden. Gebruikerservaring

(S) Zoekfunctie: Gebruikers moeten handmatig naar nummers of artiesten kunnen zoeken binnen de web-app. (M) Afspelen van Fragmenten: Gebruikers moeten een fragment van elk aanbevolen nummer kunnen beluisteren voordat ze besluiten het leuk te vinden of over te slaan. Feedback en Optimalisatie

(W) Feedback Functie: Gebruikers moeten feedback kunnen geven over de nauwkeurigheid van de aanbevelingen. (C) Voorkeuren Instellen: Gebruikers moeten hun muziekvoorkeuren kunnen instellen of aanpassen voor betere aanbevelingen. Integratie met Spotify

(S) Synchronisatie met Spotify: De web-app moet naadloos synchroniseren met de Spotify-bibliotheek van de gebruiker. (C) Afspelen op Spotify: Gebruikers moeten de mogelijkheid hebben om een aanbevolen nummer direct af te spelen op Spotify. (C) Afspeellijsten Beheren: Gebruikers moeten hun Spotify-afspeellijsten kunnen beheren binnen de web-app. Beveiliging en Privacy

(S) Gegevensbescherming: De web-app moet voldoen aan de GDPR en andere relevante regelgeving omtrent gegevensbescherming. (S) Privacy Instellingen: Gebruikers moeten hun privacy-instellingen kunnen beheren, zoals welke gegevens worden gedeeld en hoe hun gegevens worden gebruikt. Ondersteuning en Hulp

(C) Helpsectie: De web-app moet een helpsectie bevatten waar gebruikers antwoorden kunnen vinden op veelgestelde vragen. (C) Contact Ondersteuning: Gebruikers moeten contact kunnen opnemen met de ondersteuningsteam voor hulp en technische ondersteuning.

Welke hulpvragen heb ik?

Wat is MongoDB precies. Database?

Week 6

Wat heb ik deze week gedaan per competentie?

Evalueren: Sep en ik hebben geïttereerd over wat handig zou zijn met swipen. Alleen op je toptracks en artiesten (wat we al aan het bouwen waren > "is dit goed genoeg?"), of ook op eventuele zoekresultaten, zodat je je beeld meer kan verbreden in de app. Omdat de gebruiker zijn/haar doel is om nieuwe muziek te leren kennen, vonden we het een goed idee om swipen gebaseerd op zoekresultaten, in onze website toe te voegen. Zo kan de gebruiker evt nog nieuwe genres leren kennen die hij/zij in eerste instantie nooit zou beluisteren, en zijn 'muziekscope' verbreden.

Prototypen en uitwerken: Deze week heb ik gewerkt aan wat simpele functies waarvan we ook zeker wisten dat we dit wilde verwerken in de website. Denk aan een logout button, het ophalen van profielgegevens en ik heb een begin gemaakt aan het toevoegen van een nummer in een playlist.

Logout:

Scherm­afbeelding 2024-06-13 om 17 14 08

Profielgegevens opvragen:

Scherm­afbeelding 2024-06-13 om 17 15 37

Recommendations: Sep had het voor elkaar gekregen om de toptracks aan te vragen, dus ben ik aan de slag gegaan met het opvragen recommendations op basis van die toptracks. Dit is me uiteindelijk goed gelukt. Wel had ik wat errors die ik uiteindelijk in chatGPT heb gezet. Zie bron: https://chatgpt.com/share/11f59830-5e14-43c0-b184-7dfb79c088b2.

Scherm­afbeelding 2024-06-13 om 17 53 51 Scherm­afbeelding 2024-06-13 om 17 55 47 Scherm­afbeelding 2024-06-13 om 17 56 49

Recommendations vervolg > like + dislike + playPreview Begin gemaakt aan het liken en disliken van nummers (het lukte me nog niet helemaal. Sep heeft het uiteindelijk wel helemaal werkend gemaakt met zijn verdere code): zie ChatGPT chat: https://chatgpt.com/share/e4259390-f82a-41b0-bd90-670ce1cda0e1. Terwijl Sep bezig was met dat te fixen ben ik verder gegaan met een playPreview function. Om nieuwe muziek te leren kennen moet je wel de muziek kunnen horen tijdens het swipen. Zie code hieronder.

Scherm­afbeelding 2024-06-13 om 20 11 45

Na deze code te hebben geschreven en het werkte kwam ik erachter dat niet elk nummer een preview heeft. Ik heb voorgesteld aan sep om dat ergens eruit te filteren. Vervolgens heeft Sep de filterRecommendations functie geschreven in de server.js. image

Searchbar op de zoek.ejs: Aan het eind van de week ben ik ook nog begonnen aan de searchResults en zoek pagina. Allereerst heb ik bij verkennen een zoekbalk erin gecodeerd. We hebben er voor besloten om dit niet met list.js te doen, maar via de backend. List.js hebben we uiteindelijk wel op andere plekken nog toe kunnen passen (Joost zijn code).

zie searchbar code: Scherm­afbeelding 2024-06-13 om 17 30 35

Scherm­afbeelding 2024-06-13 om 17 29 46

Searchresults.ejs: Scherm­afbeelding 2024-06-13 om 20 44 53

Nu zou ik alleen nog de "get recommendations" knop op de searchResults pagina moeten laten werken door de track.id mee te geven in de parameter.

Week 7

Wat heb ik deze week gedaan per competentie?

Prototypen en uitwerken:

searchRecommendations Ik heb het voor elkaar gekregen om te kunnen swipen gebaseerd op een searchResult. Maar tot nu toe alleen voor een nummer. En niet een artiest. Dit zou moeten werken maar hij doet het niet. Ik snap ook niet goed waarom hij het niet doet.

image image

update: Ik heb Sep zijn hulp gevraagd en die heeft wat aanpassingen gemaakt in de code gebaseerd op de code die ik al had geschreven. Van een tag heeft hij een form method: get. gemaakt, en de benodigde aanpassingen in de server.js en handleSwiping.js gemaakt. Zie sep zijn WIKI voor alle aanpassingen.

Week 8

Deze week heb ik de hele profiel pagina werkend gekregen. Code die ik heb geschreven:

Opvragen top genres opvragen Liked en disliked vanuit de database het unliken en liken van nummers (en ze laten overspringen naar de dislike of like pagina)

topgenres:

Scherm­afbeelding 2024-06-14 om 10 39 18

unliken:

Op de profiel pagina stond eerst de activiteit zonder dat je er iets mee kon, naast het zien van de geswipte nummers. Toen zijn Annika Joost en ik ons af gaan vragen of we daar niet iets meer mee konden en het toch net iets makkelijker maken voor de gebruiker om zijn/haar ‘errors’ te herstellen. Uiteindelijk kwamen we op de conclusie om vanuit de activiteit de tracks alsnog te kunnen liken en disliken, in samenhang met de playlist in Spotify.

image image

Technisch onderzoek

Genres

ik heb onderzoek gedaan naar de verschillende manieren om te swipen. Op basis van zoekresultaten, artiesten, tracks en je toptracks. Het enige probleem was dat we eigenlijk genres er ook in wilde verwerken. Nou was ik daar al twijfelachtig over vanwege het nut: op een genre swipen leek me wat te algemeen, en hetzelfde zou je bereiken als je zou swipen gebaseerd op een artiest(die dan een bepaald genre gevoel zou hebben). Maar na wat onderzoek gedaan te hebben kwam ik er ook achter dat je niet kon swipen genre. Vanuit de API stond er alleen bij een artiest een genre aangegeven. Niet bij tracks. Dit zou dus net te moeilijk worden. Wel wilden we heel graag ergens je topgenres aangeven. Toen heb ik er samen met Annika en Joost voor gekozen om dit alleen op de profiel pagina te doen. En niet op de zoekpagina, net als topartiesten en top nummers (die dus wel worden getoond op de zoekpagina). Het ophalen van topgenres zou ik dan via de topartiesten moeten vinden. Waaraan dus genres staan gekoppeld vanuit de API.

Evaluatie

Beschrijf het volgende:

  • Op welke manieren heb je je prototype geevalueerd? Benoem gebruikte CMD methods
  • Beschrijf de aanpak van je test / evaluatie
  • Beschrijf de resultaten van je test / evaluatie
  • Hoe ga je deze resultaten gebruiken om je prototype verder te verbeteren?
Clone this wiki locally