javascript - Angular.js paginate filtered data and display total items without duplicating code in view/controller -
let's have filter implemented in view this:
<input data-ng-model="statementfilter" /> <ul> <li data-ng-repeat="statement in statements | filter: statementfilter"> {{ statement.name }} </li> </ul>
this case insensitive partial match statements properties contain statementfilter
.
i need implement in controller instead of in view. understand can create custom filters in angular, want filter generic case insensitive partial matching on complex object built-in angular filter in view does. if create custom filter, have filtering using javascript require library afaik.
how can leverage generic case insensitive partial matching comes angular's "view" filter in code?
thanks
update
here plunker of i'm trying do.
solution: http://plnkr.co/edit/acap437ojgmgmugctxt3?p=preview
basically, problem controller doing knew accomplished inside of view... made more difficult other cases you're trying paginate same data you're filtering , displaying length... means data must manipulated in order:
- filtered data based on search item
- capture length of filtered items
- paginate filtered items , display
the first thing know had done rework ng-repeat
filtering. goal use build in angular filtering.
originally, looked this. did filtering , paging, used custom code in controller.
data-ng-repeat="statement in pagedstatementdata()"
step 1: use angular filter
the filtering posted in question easier way without writing custom filtering code... first step. easy enough.
data-ng-repeat="statement in statements | filter:statementfilter"
step 2: pagination back
at point, list filtered correctly, displays of filtered items , not break them pages. pagination buttons work should , total records update accordingly. next step insert pagination filtered list.
in script, added begin , end scope. these variables created inside of pagedstatementdata()
. using values, can slice filtered array pagination going.
note: this $scope.begin $scope.end code removed in step 5, because it's calculated on initial render , didn't update after then. bug didn't notice until step 5.
$scope.begin = ($scope.currentpage-1)*$scope.numperpage; $scope.end = ($scope.begin + $scope.numperpage); data-ng-repeat="statement in (statements | filter:statementfilter).slice(begin, end)"
step 3: remove controller code not wanted/needed
at point, works... goal remove custom filtering code... removed $scope.filteredstatementdata
method , $scope.totalfilteredstatementitems
method called it. $scope.pagedstatementdata
can deleted also.. called in ng-repeat
modified in step 1.
removed:
- $scope.filteredstatementdata // custom filter code.. removed
- $scope.totalfilteredstatementitems // called filteredstatementdata... removed
- $scope.pagedstatementdata // called original ng-repeat... removed
step 4: fix total items # , pagination buttons. both depend on same .length
at point... view broken, because it's still making few calls methods removed. (totalfilteredstatementitems) goal replace functionality have in view. totalfilteredstatementitems used run custom filtering logic , got length without paginating data.
we have items being filtered, need save them scope (before they're paginated) can accessed elsewhere. can save filtered array inside of ng-repeat, actually. long syntax remains item in items
... items
can assigned scope variable... item in (items = (/*filter*/)).slice(x,y)
data-ng-repeat="statement in (filtereditems = (statements | filter:statementfilter)).slice(being, end)" <div>total records: {{ filtereditems.length }}</div> <pagination data-ng-model="currentpage" total-items="filtereditems.length"
okay. ng-repeat starting crazy, it's still working. parens real magic here. code executed in desired order.
// filtered data based on search item $scope.filtereditems = $scope.statements.filter(/*statementfilter magic*/); // paginate filtered items var _temp = filtereditems.slice($scope.begin, $scope.end), _i, statement; // display page of filtered items (var _i in _temp) { statement = _temp[_i]; // render each row w/ statement }
also, i'm sure there's angular $scope magic going on update filtereditems.length since it's used in total records:
div before list filtered... angular! or maybe prioritizes ng-repeat , executes block first. idk. works.
step 5: pagination broken. pagination component update begin , end variables list depends on.
deleted $scope.begin , $scope.end code in controller. create them inside of ng-init
when component first created, , on data-ng-change
event, recalculate values.
<pagination data-ng-model="currentpage" total-items="filtereditems.length" items-per-page="numperpage" data-max-size="maxsize" data-boundary-links="true" ng-init="begin = (currentpage-1)*numperpage; end = begin + numperpage" data-ng-change="begin = (currentpage-1)*numperpage; end = begin + numperpage">
Comments
Post a Comment