Перечислил весь массив объектов в виде списков, используя ng-repeat и добавив флажок для каждого значения.
Здесь я хочу отфильтровать флажок и сформировать новый JSON при нажатии Применить фильтр на основе проверки / снятия флажка (флажки).
Фактический
Я попытался добавить выбранный и невыбранный флажок в объект области действия модели ($ scope.models), объединив имя фильтра и его значения
(т.е.): данные1 (имя фильтра) +1 (значение) = данные11
При нажатии применить фильтр зацикливание существующего массива фильтров, сравнить его с объектом модели и вставить совпадения в новый массив.
Plunker
Применить функцию фильтра
HTML
<li ng-repeat="(key, filter) in filters">
<a href="" data-target="#{{filter.name}}" data-toggle="collapse" aria-expanded="{{enableShow.indexOf(filter.name) > -1 ? true : false}}">
{{filter.name}}
</a>
<ul class="collapse list-unstyled" id="{{filter.name}}" ng-class="{show : enableShow.indexOf(filter.name) > -1}">
<li ng-repeat="v in filter.values">
<label class="w-100" ng-show="filter.type == 'CheckBox'">
<span class="ml-3 p-1 d-block">
{{v.value}}
<input type="checkbox" ng-model="models[filter.name + v.value]" class="pull-right mt-1 ml-1" style="margin-right: 7%" />
</span>
</label>
</li>
</ul>
JS
$scope.applyFilters = function() {
var arr = [];
_.map($scope.filters, function(d) {
_.map(d.values, function(v) {
var name = d.name + v.value;
for (key in $scope.models) {
if (key == name) {
arr.push({
name: d.name,
values: v
});
}
}
});
});
console.log(arr);
};
Ожидаемое
При нажатии на кнопку применить фильтр хотите сформировать новый JSON, который содержит только выбранные значения в соответствующем объекте.
{
"results": [
{
"name": "data1",
"type": "CheckBox",
"values": [
{
"value": "1"
},
{
"value": "4"
}
]
},
{
"name": "data2",
"type": "CheckBox",
"values": [
{
"value": "1"
}
]
},
{
"name": "data5",
"type": "CheckBox",
"values": [
{
"value": "3"
}
]
},
{
"name": "data6",
"type": "CheckBox",
"values": [
{
"value": "2"
}
]
}
]
}
Заранее спасибо.