I have 2 array of date ranges I'm trying to find the difference between. Let's use numbers for example:
I have 2 ranges [1-7, 9-16]
and I want to subtract [2-3, 7-9, 14-20]
and get the result ranges of [1-1, 4-6, 10-13]
I'm getting caught in a bit of a rut trying to figure it out. Surely there's a common solution to this that I'm unaware of?
diffDateRangesArray(rangesArray1, rangesArray2) {
//rangesArray = [{startDate, endDate}]
let diffedRanges = [];
rangesArray1.forEach(function(range1){
//loop through rangesArray2 removing from range1
rangesArray2.forEach(function(range2){
// breaks if array returned
// perhaps should always return array and flatten?
range1 = diffDateRanges(range1, range2);
});
diffedRanges.push(range1);
});
//probably should do some sort of union here
return diffedRanges;
}
diffDateRanges(range1, range2) {
//range = {startDate, endDate}
let diffedRange = {};
// if not in range
if(range2.endDate <= range1.startDate || range2.startDate >= range1.endDate){
return range1;
//if envelops range
} else if(range2.endDate >= range1.endDate && range2.startDate <= range1.startDate){
return null;
//if cuts off end of range
} else if(range2.startDate <= range1.endDate && range2.endDate >= range1.endDate){
return {startDate:range1.startDate, endDate: range2.startDate};
// if cuts off start of range
} else if(range2.endDate >= range1.startDate && range2.startDate <= range1.startDate){
return {startDate:range2.endDate, endDate: range1.endDate};
// if inside of range - should better handle arrays
} else if(range2.startDate >= range1.startDate && range2.endDate <= range1.endDate){
return [
{startDate:range1.startDate, endDate: range2.startDate},
{startDate:range2.endDate, endDate: range1.endDate},
];
}
}