1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47
| // exemple format des alarmes
const dataAlarmes = [
{"date": "", "time": 0, "mess": "Il est l'heure de se réveiller !"},
{"date": "", "time": 0, "mess": "Ton petit déjeuner t'attend !"},
{"date": "", "time": 0, "mess": "La brosse à dents s'impatiente !"},
{"date": "", "time": 0, "mess": "Comme d'hab tu es en retard !"},
{"date": "", "time": 0, "mess": "Oups !! sorry on est dimanche !"}
];
/**
* Affichage écran du message
*/
function showAlarm(data) {
const oDest = document.getElementById("alarm");
const codeHTML = "<p><i><sup>" + data.date.toLocaleString() + "</sup></i><br>" + data.mess;
oDest.insertAdjacentHTML("beforeend",codeHTML)
}
/**
* Une façon de gérer les alarmes
*/
function getAlarm() {
const time = new Date().getTime();
dataAlarmes.forEach((al, ind) => {
const alarmTime = al.time;
if (time >= alarmTime) {
// affichage écran
showAlarm(al);
// supprime de la liste
dataAlarmes.splice(ind, 1);
}
else {
// supprime timer en cours
if (al.timer) clearTimeout(al.timer);
// relance la demande
const delai = (alarmTime - time);
al.timer = setTimeout(getAlarm, delai);
}
});
}
// initialisation data pour test
dataAlarmes.forEach((al, ind) => {
const date = new Date();
date.setTime(date.getTime() + (3000 * (ind + 1)));
al.date = date;
al.time = date.getTime();
});
// lance l'action
getAlarm(); |
Partager