Solo gli elementi che hanno un valore maggiore o uguale alla soglia deve essere conservato in un array. Poi un nuovo array dovrà essere creata con il quale conterrà diversi oggetti. Ognuno di questi oggetti hanno due proprietà, l'inizio e la fine.
Se ci sono diversi elementi in una riga (che hanno un timestamp a distanza di 10 minuti), saranno raggruppati in uno stesso oggetto. In cui il valore di partenza sarà il timestamp del primo elemento e il valore finale sarà il valore del timestamp dell'ultimo elemento del gruppo, oltre a 10 min.
Se non ci sono più elementi di seguito, il valore di partenza sarà il timestamp e la fine sarà il timestamp più di 10 minuti.
const data = [{
timestamp: '2021-11-23T14:00:00+0000',
amount: 21
},
{
timestamp: '2021-11-23T14:10:00+0000',
amount: 27
},
{
timestamp: '2021-11-23T14:20:00+0000',
amount: 31
},
{
timestamp: '2021-11-23T14:30:00+0000',
amount: 29
},
{
timestamp: '2021-11-23T14:40:00+0000',
amount: 18
},
{
timestamp: '2021-11-23T14:50:00+0000',
amount: 17
},
{
timestamp: '2021-11-23T15:00:00+0000',
amount: 25
},
{
timestamp: '2021-11-23T15:10:00+0000',
amount: 21
}
]
const threshold = 25
const aboveThreshold = data.filter(element => element.amount >= threshold)
const workSchedule = []
for (let i = 0; i < aboveThreshold.length; i++) {
if (i === 0) {
workSchedule.push({
start: aboveThreshold[i].timestamp,
end: aboveThreshold[i + 1].timestamp
})
}
if (i > 0 && i < aboveThreshold.length - 1) {
if (aboveThreshold[i].timestamp.slice(11, 13) === aboveThreshold[i + 1].timestamp.slice(11, 13)) {
workSchedule.push({
start: aboveThreshold[i].timestamp,
end: aboveThreshold[i + 1].timestamp
})
}
}
if (i === aboveThreshold.length - 1) {
workSchedule.push({
start: aboveThreshold[i].timestamp,
end: aboveThreshold[i].timestamp
})
}
}
console.log(workSchedule)
Ma alla fine il risultato che cerco è la seguente:
[
{
start: '2021-11-23T14:10:00+0000',
end: '2021-11-23T14:40:00+0000'
},
{
start: '2021-11-23T15:00:00+0000',
end: '2021-11-23T15:10:00+0000'
}
]
Spero di essere stato chiaro
1