diff --git a/src/stateFilters.js b/src/stateFilters.js index 9156e6f42..4ef014a91 100644 --- a/src/stateFilters.js +++ b/src/stateFilters.js @@ -27,8 +27,8 @@ function $IsStateFilter($state) { */ $IncludedByStateFilter.$inject = ['$state']; function $IncludedByStateFilter($state) { - var includesFilter = function (state) { - return $state.includes(state); + var includesFilter = function (state, params, options) { + return $state.includes(state, params, options); }; includesFilter.$stateful = true; return includesFilter; diff --git a/test/stateFiltersSpec.js b/test/stateFiltersSpec.js index a3aa93f06..8d9fb2e3b 100644 --- a/test/stateFiltersSpec.js +++ b/test/stateFiltersSpec.js @@ -38,7 +38,8 @@ describe('includedByState filter', function() { $stateProvider .state('a', { url: '/' }) .state('a.b', { url: '/b' }) - .state('c', { url: '/c' }); + .state('c', { url: '/c' }) + .state('d', { url: '/d/:id' }); })); it('should return true if the current state exactly matches the input state', inject(function($parse, $state, $q, $rootScope) { @@ -58,4 +59,16 @@ describe('includedByState filter', function() { $q.flush(); expect($parse('"a" | includedByState')($rootScope)).toBe(false); })); + + it('should return true if the current state include input state and params', inject(function($parse, $state, $q, $rootScope) { + $state.go('d', { id: 123 }); + $q.flush(); + expect($parse('"d" | includedByState:{ id: 123 }')($rootScope)).toBe(true); + })); + + it('should return false if the current state does not include input state and params', inject(function($parse, $state, $q, $rootScope) { + $state.go('d', { id: 2377 }); + $q.flush(); + expect($parse('"d" | includedByState:{ id: 123 }')($rootScope)).toBe(false); + })); });