-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathfilterService.js
53 lines (45 loc) · 1.99 KB
/
filterService.js
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
48
49
50
51
52
53
const applyFilters = (filters, responses) => {
if (!filters || !filters.length) return responses;
return responses.filter((response) => {
// Assume all conditions are met until proven otherwise
let conditionsMet = true;
// Apply each filter as an AND condition
filters.forEach(filter => {
const question = response.questions.find(q => q.id === filter.id);
if (!question) {
conditionsMet = false;
return;
}
const value = question.value;
const filterValue = filter.value;
switch(filter.condition) {
case 'equals':
if (question.type === 'DatePicker') {
conditionsMet = new Date(value).toISOString().split('T')[0] === new Date(filterValue).toISOString().split('T')[0];
} else {
conditionsMet = value === filterValue;
}
break;
case 'does_not_equal':
if (question.type === 'DatePicker') {
conditionsMet = new Date(value).toISOString().split('T')[0] !== new Date(filterValue).toISOString().split('T')[0];
} else {
conditionsMet = value !== filterValue;
}
break;
case 'greater_than':
conditionsMet = question.type === 'DatePicker' ? new Date(value) > new Date(filterValue) : value > filterValue;
break;
case 'less_than':
conditionsMet = question.type === 'DatePicker' ? new Date(value) < new Date(filterValue) : value < filterValue;
break;
default:
// Invalid condition
conditionsMet = false;
}
});
// Only include response if all conditions are met
return conditionsMet;
});
};
module.exports = { applyFilters };