Как фильтровать в сетке UI, чтобы он мог выполнять фильтры в 2 столбца
Можно ли иметь фильтр (не уникальный фильтр, а фильтр сверху каждого столбца) в столбце age1, который одновременно фильтрует столбец age2 с условием "ИЛИ"?
Так, например, если я отфильтрую от 20 до 21 и в результате получу Nives, Terry и Bishop...
http://plnkr.co/Jv3zUSDK1zlzPvArmFje
{ field: 'phone', enableFiltering: false },
{ field: 'age1', filters: [
{
condition: uiGridConstants.filter.GREATER_THAN,
placeholder: 'greater than'
},
{
condition: uiGridConstants.filter.LESS_THAN,
placeholder: 'less than'
}
Спасибо за вашу помощь:)
1 ответ
Если вы хотите найти возраст от "от" до "до", я думаю, что вы ищете SingleFilter в UI-Grid:
Ниже приведен код, описывающий, как фильтровать столбцы ['name', 'company', 'email']:
var app = angular.module('app', ['ngTouch', 'ui.grid']);
app.controller('MainCtrl', ['$scope', '$http', function ($scope, $http) {
var today = new Date();
$scope.gridOptions = {
enableFiltering: false,
onRegisterApi: function(gridApi){
$scope.gridApi = gridApi;
//Use singleFilter option
$scope.gridApi.grid.registerRowsProcessor( $scope.singleFilter, 200 );
},
columnDefs: [
{ field: 'name' },
{ field: 'gender', cellFilter: 'mapGender' },
{ field: 'company' },
{ field: 'email' },
{ field: 'phone' },
{ field: 'age' },
{ field: 'mixedDate' }
]
};
$http.get('/data/500_complex.json')
.success(function(data) {
$scope.gridOptions.data = data;
$scope.gridOptions.data[0].age = -5;
data.forEach( function addDates( row, index ){
row.mixedDate = new Date();
row.mixedDate.setDate(today.getDate() + ( index % 14 ) );
row.gender = row.gender==='male' ? '1' : '2';
});
});
$scope.filter = function() {
$scope.gridApi.grid.refresh();
};
$scope.singleFilter = function( renderableRows ){
var matcher = new RegExp($scope.filterValue);
renderableRows.forEach( function( row ) {
var match = false;
[ 'name', 'company', 'email' ].forEach(function( field ){
if ( row.entity[field].match(matcher) ){
match = true;
}
});
if ( !match ){
row.visible = false;
}
});
return renderableRows;
};
}])
.filter('mapGender', function() {
var genderHash = {
1: 'male',
2: 'female'
};
return function(input) {
if (!input){
return '';
} else {
return genderHash[input];
}
};
});