Need to filter array based on a filter object having multiple values consisting arrays
var vendors = [
{
vendor_name: "John",
region: ["APAC", "UKDE"],
scanned_status: "Yes",
channel: ["FILE", "API"],
pii_attributes: ["A", "B"]
},
{
vendor_name: "Onir",
region: ["APAC", "LATAM"],
scanned_status: "No",
channel: ["FILE"],
pii_attributes: ["A", "C"]
},
{
vendor_name: "Suresh",
region: ["UKDE", "NA"],
scanned_status: "Yes",
channel: ["API"],
pii_attributes: ["C", "B"]
}
];
var filterCriteria = {
region: ["APAC", "LATAM"], // 'APAC', 'LATAM', 'NA', 'UKDE'
channel: ["API"], // 'API', 'FILE'
attributes: ["A", "B"],
scan_status: "Yes" // 'Yes', 'No', 'All'
};
let filtered_vendors = [];
var result = vendors.filter((el, index, arr) => {
if (
filterCriteria["region"].includes(el["region"]) &&
filterCriteria["channel"].includes(el["channel"]) &&
filterCriteria["attributes"].includes(el["pii_attributes"])
) {
filtered_vendors.push(el);
return true;
}
return false;
});
console.log(result);
console.log(filtered_vendors);
But I am not able to apply multiple iteration at the filter level for including the elements. WOuld like to know efficient way to filter the array.
filterCriteria.regionhave to include all values fromvendors[].regionor any of them?