POK1 - Complesims, l'interface web pour gérer des objectifs

Tags :
  • POK
  • 2024-2025
  • temps 1
  • info
Auteurs :
  • Inès Kebbab

Ce premier POK vise à créer un petit site web pour suivre l'avancée dans une liste d'objectifs dans un jeu vidéo (Les Sims 4).

L'objectif de ce POK est de revoir les notions de base de développement web en réalisant un POK.

Autres POK ou MON en lien :

Objectifs

Ayant déjà de bases du dev web (front end, back end...), les objectifs principaux de ce projet est :

  1. Se raffraichir la mémoire sur les notions utiles, notamment en vu de suivre (peut-être) le CS "Dev Web : Zero to hero" au temps 2.
  2. Se perfectionner en front, sur HTML/CSS/JS et approfondir la compréhension du back (notamment avec des requêtes et la gestion d'une base de données simple).
  3. Finir mon premier projet concret en solo de A à Z (ou presque), sur un site complètement solo, du début à la fin.

Tâches

Sprint 1 - Rodage et premiers tests

  1. [X] Maquette express (avec des wireframes ?) de l'interface et choix de premières catégories à implémenter pour le sprint.
  2. [X] Remise à niveau / rappels HTML et CSS.
  3. [X] Remise à niveau / rappels en JS et analyse du code de site de James Turner pour comprendre la structure. (réalisé au Sprint 2)
  4. [X] Implémentation du premier bloc de checklist "simple", en front end VS en back puis front end. (réalisé au Sprint 2)

Sprint 2 - Ajout des autres blocs et informations

  1. [X] Implémentation de blocs à checklist à niveau d'avancement (1,2,3... Fait).
  2. [ ] Gestion des filtres d'affichages (DLCs et non terminé/terminé).
  3. [X] Affichage des pourcentages d'avancement par catégorie.
  4. [X] Affichage d'informations au survol des informations sur l'item.
  5. [/] Sauvegarde et/ou mise en cache.
  6. [ ] Etudier l'évolution vers une base de donnée (+ rappels back). (abandonné à la fin du sprint 1)
  7. [ ] (Bonus : Animation / pop up si la checklist est complétée.)

Horodatage

Toutes les séances et le nombre d'heure que l'on y a passé.

Date Heures passées Indications
Dimanche 15/09 10h Rappels HTML/CSS, réalisation du front en parallèle, recherches JS et premiers tests (infructueux) - Sprint 1
Dimanche 13/10 4h Apprentissage des bases JS et premiers tests pour la checklist "Mort" - Sprint 2
Lundi 14/10 5h Fin de la checklist "Mort", ajout checklist avec progression, essais infobulle, recherches stockage local avec Javascript - Sprint 2
Mardi 15/10 1h Finalisation projet et rédaction POK - Sprint 2

Contenu

L'idée du projet

Ce projet est inspiré par ma propre expérience de jeu sur les Sims 4 où je me mets au défi de "finir le jeu à 100%", au travers d'une partie et donc obtenir toutes les réussites du jeu, compléter toutes les collections, atteindre le niveau maximal de toutes les compétences, etc.

La liste de choses à découvrir est longue et pour suivre mon avancement, j'utilise le site du joueur James Turner qui répond partiellement au besoin (et m'ayant ainsi inspiré ce POK), un Google Doc avec des checklists, ainsi qu'une liste papier selon les items.

L'objectif serait donc d'avoir une interface web pour suivre au même endroit les items réalisés rangés par catégorie, à l'instar du site d'inspiration, avec quelques filtres supplémentaires (éléments manquants,...) et l'enregistrement de la progression sans connexion.

Une fonctionnalité supplémentaire (pour explorer plus de fonctionnalités) serait d'afficher des informations d'aide pour réaliser l'item de la checklist.

Premier Sprint

Rappels HTML et CSS

Pour commencer, j'ai repris mes bases en HTML et CSS pour faire un site "agréable" en partant de zéro. Je me suis aidée des formations du GInfo et du cours HTML/CSS d'Open Classroom pour me rafraîchir la mémoire.

Ayant créé un site Wordpress récemment, j'ai pu faire beaucoup de liens entre les options des components et les valeurs de style ce que j'ai trouvé assez amusant.

Les notions principales que je garde en mémoire :

Même si j'ai survolé le cours OpenClassrooms (et que l'ordre d'apprentissage ne correspondait pas à ce que je souhaitais réaliser), j'ai tout de même pu apprendre quelques notions supplémentaires notamment en CSS. De plus, cela m'a forcé a quasiment écrire toutes mes lignes à la main.

Il y a encore des ajouts HTML et CSS à faire, mais la version actuelle permet d'avoir une première section avec les données pour tester et incorporer le JS.

J'ai passé davantage de temps que prévu pour affiner et m'approprier le design de mon site. Je n'étais d'abord pas convaincue de la direction (dans les tons verts) avant de me décider sur un dark mode qui me permettait d'avoir des contrastes plus appréciables.

Rappels Javascript

Contrairement au HTML et CSS, je n'avais plus de souvenirs du JS. Un rappel théorique a été de rigueur, avec la formation du GInfo sur le Javascript. Cela m'a permis d'avoir déjà quelques intuitions sur les outils que j'utiliserais dans le second sprint (notamment pour la mise en cache au local).

J'ai aussi pu analyser et mieux comprendre comment été construit le site de James Turner. Cela m'a semblé lourd et peu flexible pour un jeu très complexe de données, avec de nombreuses informations redondantes. J'aimerais en discuter avant mon prochain sprint pour savoir si poursuivre en JS est le plus optimal pour "gérer la base de données" (d'autant plus, que JS ne communique pas entre les pages du site).

J'ai fait des premiers tests à partir d'exemples de codes de "to do list" trouvé sur le net et réadapté pour mon besoin, afin de sélectionner les items de la to do (et les marquer comme réalisé) pour la première catégorie d'item ("Morts")... Mais ils n'ont pas été fructueux. En fait, je me suis rendue compte que c'était comme si j'avais essayé de me lancer dans ma propre recette de cuisine improvisée avec tous les ingrédients en main... sauf que je ne m'étais pas rendue compte que je n'avais aucun ustensile dans ma cuisine. Bref, survoler le concept ne suffira pas ici avant de s'amuser, il me faut creuser davantage et éclaircir les zones de floues qu'il me reste en suivant pas à pas quelques tutos basiques.

J'ai fini ce POK en me documentant sur JS et en recherchant les ressources utiles conseillées sur les autres MON/POK sur le sujet. Avant le début du sprint 2, je souhaite ainsi me pencher et faire quelques tests en dehors de ce projet avec :

J'ai été quelque peu perdue dans la quantité de ressources pour démarrer et dans le choix de celle qui sera la plus adaptée à mon besoin (avoir une bonne compréhension, sans prétendre à maîtriser l'outil).

Pour clôturer le sprint 1, j'ai réussi à faire une catégorie ouverte/fermée comme prévue en JS lors du sprint 2... mais sans JS, avec l'aide de la balise "details" en HTML ! Il reste néanmoins quelques sujets de style à régler et corriger (et notamment avec l'affichage de la balise "summary", qui entre en conflit avec mon titre H3 et les marges internes de mes boîtes).

Quid d'une base de données ?

J'avais hésité dès le départ à créer une base de données dans laquelle il serait facile d'ajouter un élément via l'interface plus tard. Pour me forcer à explorer au maximum Javascript, j'ai décidé de faire sans. Néanmoins, au vu du code sur le site d'inspiration, la rédaction est lourde et si l'on souhaite à terme avoir les mêmes données sur différentes pages, la donnée sera plutôt redondante (voire pire, une usine à gaz ?).

En me rendant finalement compte des timings réels d'un sprint, je pense revoir le back sur mon temps libre ainsi que les bases de données. La base de données pourra comprendre la "catégorie" d'items, le nom, son statut (réalisé ou non) et éventuellement d'autres informations complémentaires / utiles (pex : des infos sur comment compléter tel item).

Conclusion du sprint 1

J'étais finalement plus rouillée que je le pensais, mais cela m'a permis de repartir sur des bases solides en HTML et CSS... J'espère néanmoins rattraper ce léger retard sur le sprint 2.

Second Sprint

Premiers pas en JS : changement de couleur d'une box

  1. Récupération et identification de l'élément HTML.

Ayant retenu la leçon du sprint 1, j'ai d'abord repris de zéro les bases du Javascript pour comprendre comment l'intégrer dans mon code existant.

Le language est assez proche de Python et fonctionne sur un système de variables, de fonctions et de méthodes... Ce système de propriétés sera intéressant plus tard pour identifier les différents items de la checklist selon des critères (DLCs possédés par le joueur, l'âge de l'avatar, mais aussi pour la catégorie de l'item ) et enregistrer la progression de la liste (avec la mise en cache local notamment).

Après avoir revu et compris les bases, j'ai enfin réussi à comprendre pourquoi les bouts de code que j'essayais de forcer lors du sprint 1 ne marchaient pas : pour accéder aux objets dans le corps du HTML, il faut au préalable différé l'exécution du script et laisser le HTML de la charge se charger grâce à l'attribut defer à ajouter dans la balise <script src="scripts/script.js" defer>.

Après avoir bien lié le HTML, on peut enfin songer à récupérer des éléments dans le HTML. J'ai pu testé deux méthodes pour commencer (les objets étant identifiables par leur classe CSS): querySelector et querySelectorAll. Voici en quelques exemples les effets, pour récupérer les components de mes boxs:

Test 1 (via l'affichage dans la console)

const listeBox = document.querySelectorAll(".conteneur div");
console.log(listeBox);

On obtient une liste d'objects HMTL, qui contient bien toutes les div "box" de la div de classe Conteneur.

Problème? L'accès aux propriétés est moins direct : comme les propriétés liées au style sont à deux échellons, autant s'éviter des peines.

Test 2 (idem)

const box = document.querySelector(".box");
console.log(box);

Problème? Il ne sélectionne que la première div sur la page qui est de la classe ".box".

Test 3 (idem)

const listeBox = document.querySelectorAll(".box");
console.log(listeBox);

Cette fois-ci, c'est la bonne, maintenant qu'on a vérifié que cela fonctionne et qu'on peut accéder à une liste contenant les boxs, et ainsi à leurs propriétés.

  1. Modification des propriétés d'un élément avec JS

Ensuite, il me fallait tester la modification des propriétés du component, l'objectif étant de modifier la "background-color" d'une boîte (au clic), soit un élément de style. Après quelques tests à l'aveugle (avec la méthode setAttribute), je teste avec des éléments plus simple et aboutit à ce type de code :

const listeBox = document.querySelectorAll(".box");
listeBox[0].style.backgroundColor ="rgb(219, 188, 252)";

Ici, on modifie en permanence la couleur d'une case ; on voudrait la modifier uniquement au clic. Pour cela, on peut utiliser la méthode JS qui déclenche le script selon un événement (ici au clic) :

listeBox[0].addEventListener('click',
    () => {
        listeBox[0].style.backgroundColor ="rgb(219, 188, 252)";
    });
  1. Finalisation des cases à cocher

Le problème est que le changement est permanant après le clic, alors même que l'on souhaiterait pouvoir décocher la case. De plus, pour le moment, le script est effectif uniquement sur une unique case (toutes répertoriées dans listeBox qui est un tableau).

Pour résoudre le premier, on peut imaginer avoir deux classes "box" distinctes : une pour la case décochée (celle actuelle), et une nouvelle lorsque la case est cochée. On pourra ainsi modifier la classe de la boîte. On peut aussi ajouter un booléen à chaque box pour indiquer si la case est cochée ou non. Cette variable sera aussi pertinente pour la mise en cache.

Pour résoudre le second problème, il faut mettre en place une boucle for pour que toutes les box puissent avoir de l'interaction.

Ainsi, je suis arrivée à la fonction JS suivante, qui permet de cocher ou décocher les cases librement d'un simple clic :

const listeBox = document.querySelectorAll(".box");

for (let i = 0; i < listeBox.length; i++ ) {
    listeBox[i].notChecked = true ;
    listeBox[i].addEventListener('click',
        () => {
            if (listeBox[i].notChecked){
                listeBox[i].className ="box_checked";
                listeBox[i].notChecked = false ;

            } else {
                listeBox[i].className ="box";
                listeBox[i].notChecked = true ;
            }
        });
}

Affichage du décompte d'items complétés

J'ai ajouté dans la boucle précédente le décompte du nombre total d'items complétés (avec une variable dédiée). Ensuite pour l'affichage, après avoir créé une nouvelle div dans le fichier HTML, j'ai ajouté ces quelques lignes pour avoir l'affichage du décompte :

let totalMort = 0;
let divTotalMort = document.getElementById("totalMort");
let spanTotalMort = `Morts obtenues : ${totalMort} sur ${listeBox.length}`;
divTotalMort.innerText = spanTotalMort;

Ces lignes correspondent à l'initialisation de l'affichage, mais l'idée est la même à la fin de la fonction relative au clic (pour mettre à jour avec les nouveaux éléments).

Autres ajouts du sprint 2

Conclusion et suites possibles

Souhaitant aborder d'autres sujets au cours de mes prochains POK & MON, je ne pense pas continuer ce projet dans ce cadre. Néanmoins, je souhaite poursuivre l'amélioration de cette page et du site dans le cadre de mon utilisation personnelle.

Je reste assez perplexe par rapport à la définition d'une "base de données" (ou grande quantité de données) de cette façon à la main. Il est possible néanmoins de réaliser une base JSS à partir d'un fichier CSV ou d'un Json, ce qui peut être intéressant à creuser.

Je suis satisfaite de constater par moi-même le grand potentiel du trio HTML/CSS/JavaScript pour faire un site web, potentiel qui mérite encore à être largement exploré. Notamment, de nombreuses librairies en ligne permettent de faire économiser du temps en nous épargnant des lignes de style à rédiger pour les components et permettent de gérer facilement le responsive (mobile, mais aussi par rapport à la taille de la fenêtre).

Ce que j'ai appris :

Les erreurs à éviter :

Lien vers le projet Github