Compare commits

..

No commits in common. "58a4895d3353e01527e2683dcf9e3eea86fdd1bb" and "d95da5c2ee7ae1fffab34ff0609cda032dd62842" have entirely different histories.

3 changed files with 15 additions and 62 deletions

View file

@ -14,19 +14,8 @@
<hr> <hr>
<label for="nom">Nom de la tâche</label> <label for="nom">Nom de la tâche</label>
<input type="text" id="nom" name ="nom"/> <input type="text" id="nom" name ="nom"/>
<label for="duree">Durée de la tâche (en h)</label> <label for="duree">Durée de la tâche (en h)</label>
<input type="number" id="duree" name ="duree"/> <input type="number" id="duree" name ="duree"/>
<label for="datedebut">Date de début</label>
<input type="date" id="datedebut" name ="datedebut"/>
<label for="datefin">Date de fin</label>
<input type="date" id="datefin" name ="datefin"/>
<div class="separateur"></div>
<button type="button" onclick="createtask()">Créer</button> <button type="button" onclick="createtask()">Créer</button>
<div class="separateur"></div> <div class="separateur"></div>

View file

@ -24,9 +24,9 @@ class Tache {
duree = 0.0; duree = 0.0;
//Date de début - date //Date de début - date
//par défaut, c'est la date du jour //par défaut, c'est la date du jour
datedebut; date_debut;
//Date de fin - date //Date de fin - date
datefin; date_fin;
//Tache à faire avant la tâche courante - instance de classe //Tache à faire avant la tâche courante - instance de classe
//TODO implémenter cette fonctionnalité //TODO implémenter cette fonctionnalité
est_bloque_par; est_bloque_par;
@ -34,18 +34,9 @@ class Tache {
priorite = 0; priorite = 0;
//l'utilisateur définit le nom de la tâche et sa durée //l'utilisateur définit le nom de la tâche et sa durée
constructor(nom, duree, datedebut, datefin) { constructor(nom, duree) {
this.nom = nom; this.nom = nom;
this.duree = duree; this.duree = duree;
this.datedebut = datedebut;
this.datefin = datefin;
}
//fonction qui ajoute une date de début ou de fin en fonction des inputs disponibles
ajoute_date(debut, fin, duree){
if (this.debut != None){
}
} }
} }
@ -65,10 +56,7 @@ function update_postit(table) {
var longueur = table.length; var longueur = table.length;
for (let i = 0; i < longueur; i++ ) { for (let i = 0; i < longueur; i++ ) {
let displayname = table[i].nom; let displayname = table[i].nom;
let displayduration = table[i].duree; let displayduration = table[i].duree;
let displaystartdate = table[i].datedebut;
let displayenddate = table[i].datefin;
//crée une div qui contient les éléments de la tâche //crée une div qui contient les éléments de la tâche
let balise = document.createElement("div"); let balise = document.createElement("div");
balise.classList.add("tache"); balise.classList.add("tache");
@ -77,57 +65,34 @@ function update_postit(table) {
let textetitre = document.createTextNode(displayname); let textetitre = document.createTextNode(displayname);
titre.appendChild(textetitre); titre.appendChild(textetitre);
titre.classList.add("titre_tache"); titre.classList.add("titre_tache");
//on ajoute le titre à la page HTML dans la div conteneur
balise.appendChild(titre);
//puis on rajoute un séparateur
let separator = document.createElement("hr");
balise.appendChild(separator);
//corps de la tâche //corps de la tâche
let duree = "durée " + displayduration + "h"; let corps = document.createElement("p");
let datedebut = "du " + displaystartdate; let textecorps = document.createTextNode("durée " + displayduration + "h");
let datefin = "au " + displayenddate; corps.appendChild(textecorps);
//liste qui contient les éléments à ajouter corps.classList.add("corps_tache")
var liste = [duree, datedebut, datefin];
//boucle de création des élémets à ajouter
for (let p = 0; p < liste.length; p++){
//ajoute le texte courant
let chunck = document.createTextNode(liste[p]);
let paragraph = document.createElement("p");
paragraph.appendChild(chunck);
paragraph.classList.add("corps_tache")
//ajoute l'élément au corps de texte de la tâche
balise.appendChild(paragraph);
}
//on ajoute le contenu au div de la tâche
balise.appendChild(titre);
balise.appendChild(corps);
//ajoute la div de la tâche au conteneur //ajoute la div de la tâche au conteneur
element.appendChild(balise); element.appendChild(balise);
} }
} }
//-----INTERACTIVITÉ------ //-----INTERRACTIVITÉ------
function createtask(){ function createtask(){
//on récupère l'input de l'utilisateur.ice //on récupère l'input de l'utilisateur.ice
let taskname = document.getElementById("nom").value; let taskname = document.getElementById("nom").value;
let taskduration = document.getElementById("duree").value; let taskduration = document.getElementById("duree").value;
let taskdatedebut = document.getElementById("datedebut").value;
let taskdatefin = document.getElementById("datefin").value;
//on instancie une tâche avec les valeurs de l'utilisateur.ice //on instancie une tâche avec les valeurs de l'utilisateur.ice
let tache = new Tache(taskname, taskduration, taskdatedebut, taskdatefin); let tache = new Tache(taskname, taskduration);
//on ajoute la nouvelle tâche à la fin au tableau de tâches //on ajoute la nouvelle tâche à la fin au tableau de tâches
tableau_taches.push(tache); tableau_taches.push(tache);
//on calcule les dates de début et de fin de la tâche en fonction
//des inputs envoyés
//tache.ajoute_date(taskdatedebut, taskdatefin, taskduration);
//-----TRI PAR DÉFAUT
//appel de la fonction qui trie les tâches dans le tableau //appel de la fonction qui trie les tâches dans le tableau
// de la plus longue à la plus courte // de la plus longue à la plus courte
tri_duree_descend(tableau_taches); tri_duree_descend(tableau_taches);
//update de l'affichage de la liste des tâches en HTML //update de l'affichage de la liste des tâches en HTML
update_postit(tableau_taches); update_postit(tableau_taches);

View file

@ -58,7 +58,7 @@ input{
background-color: lightyellow; background-color: lightyellow;
border: none; border: none;
margin-top: 5px; margin-top: 5px;
margin-bottom: 5px; margin-bottom: 25px;
box-shadow: rgba(60, 64, 67, 0.3) 0px 1px 2px 0px, rgba(60, 64, 67, 0.15) 0px 2px 6px 2px; box-shadow: rgba(60, 64, 67, 0.3) 0px 1px 2px 0px, rgba(60, 64, 67, 0.15) 0px 2px 6px 2px;
} }
@ -127,8 +127,7 @@ button:hover{
} }
.corps_tache{ .corps.tache{
margin: 0; margin: 0;
padding: 5px;
} }