How can i sort the data by date and find maximum value count between consecutive dates ? Example data:
const data = {
'addias':{
'2022-1-10': ['a', 'b', 'c', 'd', 'e', 'f', 'g'],
'2022-1-09': ['a', 'b', 'c', 'd', 'e', 'f', 'g'],
'2021-12-29': ['a'],
'2021-12-28': ['y', 'u', 'v', 'd', 'f', 'f', 'g'],
'2021-1-08': ['x', 't', 's', 'd', 'e', 'f', 'g'],
},
'nike':{
'2022-1-20': ['a', 'b', 'c', 'd', 'e', 'f', 'g'],
'2022-1-15': ['a', 'b', 'c'],
'2022-1-14': ['a', 'b'],
'2022-1-10': ['y', 'b', 'x', 'z', 'e', 'f', 'g'],
}
}
result be like
const result = {
'addias':{
'firstDate': '2022-1-09',
'secondDate':'2022-1-10',
'total':14 ,
},
'nike':{
'firstDate': '2022-1-14',
'secondDate':'2022-1-15',
'total':5,
}
}
Attempt:
Object.entries(data).forEach((item) => {
const [ brand, dates ] = item; /** {'2022-1-10': array } */
let sorted = Object.entries(dates).sort((a,b) => new Date(a[0]) - new Date(b[0]))
/** find value count for each sorted date */
/** find if the dates are consecutive */
/** build new object with result property */
})