Sorting data in AngularJS table by column - angularjs

I'm working on a web application in AngularJS. Basically, it makes an HTTP request to a database server and displays information for all the claims in a table. The table shows 100 claims per page and there are ~131 pages. My problem is, when I try to sort the claim info by columns, it only sorts the claim information for each page and not for all the data (it's only working for the createdDate). Any ideas on how I con sort the data for the entire table (all pages) by column?
I'm very new to AngularJS MVC, am on a tight deadline, and haven't been able to implement ngTable (mainly because I don't understand where the $data and $dataset is coming from).
This is my view (HTML):
<div class="row" id="dvData">
<table class="table table-striped table-hover " >
<thead>
<tr>
<th>
<a href="" ng-click="sortType = 'userName'; sortReverse = !sortReverse">
Pass Code
<span ng-show="sortType == 'userName' && sortReverse" class="fa fa-caret-down"></span>
<span ng-show="sortType == 'userName' && !sortReverse" class="fa fa-caret-up"></span>
</a>
</th>
<th>
<a href="" ng-click="sortType = 'claimNumber'; sortReverse =! sortReverse">
Claim Number
<span ng-show="sortType == 'claimNumber' && sortReverse" class="fa fa-caret-down"></span>
<span ng-show="sortType == 'claimNumber' && !sortReverse" class="fa fa-caret-up"></span>
</a>
</th>
<th>Vehicle</th>
<th>Status</th>
<th>Company Name</th>
<th>
<a href="" ng-click="sortType = 'createdDate'; sortReverse = !sortReverse">
Created
<span ng-show="sortType == 'createdDate' && sortReverse" class="fa fa-caret-down"></span>
<span ng-show="sortType == 'createdDate' && !sortReverse" class="fa fa-caret-up"></span>
</a>
</th>
</tr>
</thead>
<tbody>
<tr ng-repeat="claim in claimList | filter:{claimNumber:searchClaimNumber} | orderBy:sortType:sortReverse">
<td>{{claim.userName==null?'Not Assigned':claim.userName}}</td>
<td>{{claim.claimNumber}}</td>
<td>{{getVehicle(claim)}}</td>
<td>{{getClaimStatus(claim)}}</td>
<td>{{getClientName(claim)}}</td>
<td>{{claim.createdDate| date:'MM/dd/yyyy h:mma'}}</td>
</tr>
</tbody>
</table>
controller:
angular
.module('mbeapp')
.controller('DashboardController', [
'$scope', 'ClaimService', 'SurveyDataService', '$state', '$http', 'NavigateService',
function($scope, ClaimService, SurveyDataService, $state, $http, NavigateService) {
[...]
$scope.sortType = 'createdDate'; // set the default sort type
$scope.sortReverse = true;
}
]);

In order to sort the entire data, you have two options.
You can load all data from backend at once and create a front-end pagination. Sort/Search will filter the whole data set and change the pagination accordingly.
When user wants to sort/search, you can pass that information to backend and get a new set of data based on the criteria.
Option 1 is easy to implement but it's a bad choice when you have a large data set. Option 2 is the ideal way to achieve your goal.
Sample Code
In your controller, you can write a function like the following:
$scope.sortBy = function(keyName){
$scope.sortReverse = !$scope.sortReverse;
$scope.sortType = keyName;
var reqParams = {
sortBy: keyName,
sortReverse: $scope.sortReverse
};
// do a $http request
$http.get('http://apiUrl', reqParams).then(function(response){
$scope.claimList = response.data; // update the claimList data
});
};
Sample table header may be like this:
<th>
<a href="" ng-click="sortBy('userName')">Pass Code
<span ng-show="sortType == 'userName' && sortReverse" class="fa fa-caret-down"></span>
<span ng-show="sortType == 'userName' && !sortReverse" class="fa fa-caret-up"></span>
</a>
</th>
You also need to change the following:
<tr ng-repeat="claim in claimList>

Related

angularjs: orderBy sort not working correctly for multiple field types

I have a table that contains multiple field types (string, dates, addresses). The orderBy seems to be working for Dates and Case Number, which contains both letters and numbers, however it doesn't seem to be working correctly for addresses and strings.
<thead>
<tr>
<th>
<input type="checkbox" id="selectAll" ng-model="selectAll" ng-click="checkAll()"/>
</th>
<th>
<a href="javascript:void(0)" ng-click="sortType = 'case_num'; sortReverse = !sortReverse">
<span ng-show="sortType == 'case_num' && !sortReverse" class="fa fa-arrow-down"></span>
<span ng-show="sortType == 'case_num' && sortReverse" class="fa fa-arrow-up"></span>
${Case Number}
</a>
</th>
<th>
<a href="javascript:void(0)" ng-click="sortType = 'short_desc'; sortReverse = !sortReverse">
<span ng-show="sortType == 'short_desc' && !sortReverse" class="fa fa-arrow-down"></span>
<span ng-show="sortType == 'short_desc' && sortReverse" class="fa fa-arrow-up"></span>
${Short Description}
</a>
</th>
<th>
<a href="javascript:void(0)" ng-click="sortType = 'start_date'; sortReverse = !sortReverse">
<span ng-show="sortType == 'start_date' && !sortReverse" class="fa fa-arrow-down"></span>
<span ng-show="sortType == 'start_date' && sortReverse" class="fa fa-arrow-up"></span>
${Start Date}
</a>
</th>
<th>
<a href="javascript:void(0)" ng-click="sortType = 'work_location'; sortReverse = !sortReverse">
<span ng-show="sortType == 'work_location' && !sortReverse" class="fa fa-arrow-down"></span>
<span ng-show="sortType == 'work_location' && sortReverse" class="fa fa-arrow-up"></span>
${Work Location}
</a>
</th>
</tr>
</thead>
<tbody>
<tr ng-repeat="item in c.onbCase | orderBy:sortType:sortReverse | filter:searchTable track by $index" ng-if="item.case_visible">
td><input type="checkbox" id={{item.number}} ng-click="checkboxFunc(item)" ng-model="item.checked" ng-checked="selectAll || item.checked"/></td>
<td>{{item.number}}</td>
<td>{{item.short_description}}</td>
<td>{{item.start_date}}</td>
<td>{{item.location}}</td>
</tr>
</tbody>
When I sort by Case Number and Start Date, the entries order correctly. However, when I try to sort by Short Description or Location, it doesn't seem to ordering it correctly:
Am I missing something? THanks!

Sorting Table with JSON key with a space

I am trying to implement a sort functionality on a table.
I am able to sort table headers with json(no spaces). However, I am unable to sort table headers with JSON key with spaces
How to solve this problem?
Script:
$scope.sortType = 'Age';
$scope.sortReverse = false;
HTML:
<table border="1" class="table table-striped">
<thead>
<tr>
<th>
<a href="#" ng-click="sortType = x[First Name]">First Name
<span ng-show="sortType == x[First Name] && !sortReverse" class="fa fa-caret-down"></span>
<span ng-show="sortType == x[First Name] && sortReverse" class="fa fa-caret-up"></span>
</a>
</th>
<th>
<a href="#" ng-click="sortType = x[Last Name;sortReverse = !sortReverse">
Last Name
<span ng-show="sortType == x[Last Name] && !sortReverse" class="fa fa-caret-down"></span>
<span ng-show="sortType == x[Last Name] && sortReverse" class="fa fa-caret-up"></span>
</a>
</th>
<th>
<a href="#" ng-click="sortType = 'Age';sortReverse = !sortReverse">
Age
<span ng-show="sortType == 'Age' && !sortReverse" class="fa fa-caret-down"></span>
<span ng-show="sortType == 'Age' && sortReverse" class="fa fa-caret-up"></span>
</a>
</th>
<th>
<a href="#" ng-click="sortType = 'Address';sortReverse = !sortReverse">Address
<span ng-show="sortType == 'Address' && !sortReverse" class="fa fa-caret-down"></span>
<span ng-show="sortType == 'Address' && sortReverse" class="fa fa-caret-up"></span>
</a>
</th>
</tr>
</thead>
<tbody>
<tr ng-repeat="x in result | filter:searchText | orderBy:sortType:sortReverse">
<td>{{x['First Name']}}</td>
<td>{{x['Last Name']}}</td>
<td>{{x.Age}}</td>
<td>{{x.Address}}</td>
</tr>
</tbody>
</table>
You have syntax errors in your code which you should be seeing in your browser console.
Example:
<th>
<a href="#" ng-click="sortType = x[First Name]">First Name
<span ng-show="sortType == x[First Name] && !sortReverse" class="fa fa-caret-down"></span>
<span ng-show="sortType == x[First Name] && sortReverse" class="fa fa-caret-up"></span>
</a>
</th>
It seems like you should be using the string literal 'First Name' and not x[First Name] which is a syntax error and an undefined variable.
Try changing the above to:
<th>
<a href="#" ng-click="sortType = 'First Name'">First Name
<span ng-show="sortType == 'First Name' && !sortReverse" class="fa fa-caret-down"></span>
<span ng-show="sortType == 'First Name' && sortReverse" class="fa fa-caret-up"></span>
</a>
</th>
That should help with the syntactical issues which you should be seeing in your browser console right now and may solve the issue altogether.

Displaying a value from a JSON array to a table in HTML5

I am doing a function of reading a content of csv file (test.csv) and store it in a variable (dataArray) and I have to display the values in this dataArray as a table in HTML5. I move those values from dataArray to $scope.sushi and created a HTML table with this variable but the data is not displaying in a table.
app.js:
$.get("test.csv").then(function(data) {
//window.alert($scope.rowSplit(data,"#"));
var rows = data.split("\r\n");
// var array = string.split('#');
// window.alert("Rows"+rows[0]);
window.alert("inside datasplit"+rows[1]);
if(rows.length > 0){
var firstRowCells = rows[0].split(",");
var dataArray = new Array();
for (var i=1; i < rows.length; i++)
{
var cells = rows[i].split(",");
var obj = {};
for(var j=0; j < cells.length; j++)
{
obj[firstRowCells[j]] = cells[j];
}
dataArray.push(obj);
}
//window.alert(dataArray);
$scope.sushi=dataArray;
// window.alert("$scope.sushi*********************8"+JSON.stringify($scope.sushi));
}
html file sampletableangular.html
<div class="container">
<form>
<div class="form-group">
<div class="input-group">
<input type="text" class="form-control" placeholder="Filter" ng-model="searchcon">
</div>
</div>
</form>
<div id="exportdata">
<table class="table table-bordered table-striped tablelink">
<thead>
<tr>
<td>
<a href="#" ng-click="sortType = 'issueno'; sortReverse = !sortReverse">
issue no
<span ng-show="sortType == 'issueno' && !sortReverse" class="fa fa-caret-down"></span>
<span ng-show="sortType == 'issueno' && sortReverse" class="fa fa-caret-up"></span>
</a>
</td>
<td>
<a href="#" ng-click="sortType = 'dateassigned'; sortReverse = !sortReverse">
date assigned
<span ng-show="sortType == 'dateassigned' && !sortReverse" class="fa fa-caret-down"></span>
<span ng-show="sortType == 'dateassigned' && sortReverse" class="fa fa-caret-up"></span>
</a>
</td>
<td>
<a href="#" ng-click="sortType = 'assignedby'; sortReverse = !sortReverse">
assigned by
<span ng-show="sortType == 'assignedby' && !sortReverse" class="fa fa-caret-down"></span>
<span ng-show="sortType == 'assignedby' && sortReverse" class="fa fa-caret-up"></span>
</a>
</td>
<td>
<a href="#" ng-click="sortType = 'description'; sortReverse = !sortReverse">
description
<span ng-show="sortType == 'description' && !sortReverse" class="fa fa-caret-down"></span>
<span ng-show="sortType == 'description' && sortReverse" class="fa fa-caret-up"></span>
</a>
</td>
<td>
<a href="#" ng-click="sortType = 'priority'; sortReverse = !sortReverse">
priority
<span ng-show="sortType == 'priority' && !sortReverse" class="fa fa-caret-down"></span>
<span ng-show="sortType == 'priority' && sortReverse" class="fa fa-caret-up"></span>
</a>
</td>
<td>
<a href="#" ng-click="sortType = 'targetdate'; sortReverse = !sortReverse">
target date
<span ng-show="sortType == 'targetdate' && !sortReverse" class="fa fa-caret-down"></span>
<span ng-show="sortType == 'targetdate' && sortReverse" class="fa fa-caret-up"></span>
</a>
</td>
<td>
<a href="#" ng-click="sortType = 'status'; sortReverse = !sortReverse">
status
<span ng-show="sortType == 'status' && !sortReverse" class="fa fa-caret-down"></span>
<span ng-show="sortType == 'status' && sortReverse" class="fa fa-caret-up"></span>
</a>
</td>
<td>
<a href="#" ng-click="sortType = 'attachment'; sortReverse = !sortReverse">
attachment
<span ng-show="sortType == 'attachment' && !sortReverse" class="fa fa-caret-down"></span>
<span ng-show="sortType == 'attachment' && sortReverse" class="fa fa-caret-up"></span>
</a>
</td>
</tr>
</thead>
<tbody>
<tr ng-repeat="roll in sushi | orderBy:sortType:sortReverse | filter:searchcon">
<td ng-click="display(roll.issueno);">{{ roll.issueno }}</td>
<td>{{ roll.dateassigned }}</td>
<td>{{ roll.assignedby }}</td>
<td>{{ roll.description}}</td>
<td>{{ roll.priority}}</td>
<td>{{ roll.targetdate}}</td>
<td>{{ roll.status}}</td>
<td>{{ roll.attachment}}</td>
</tr>
</tbody>
</table>
</div>
and the contents in test.csv:
issue no ,date assigned ,assigned by ,description ,priority ,target date ,status ,attachment
1001,1/24/2015,TE_002,Dev,1,3/4/2016,pending,file1
1002,2/20/2016,TE_002,Dev,1,3/4/2016,pending,file52
1003,4/5/2016,SD_003,Des,2,3/1/2016,pending,file4
1004,2/1/2016,TE_002,Test,1,5/19/2016,completed,file23
1005,8/27/2016,TL_001,Des,3,12/18/2016,pending,file41
1006,10/16/2016,TE_002,Dev,3,10/25/2016,completed,file35
1007,7/13/2016,TE_003,Test,5,8/7/2016,pending,file12
I have to display the value in a csv file as a table in HTML using $scope.sushi variable.
It looks like you are mixing jQuery and Angular.
You make the request with jQuery $.get("test.csv"), then update the angular $scope. When you do this angular doesn't notice the change.
Try wrapping the $scope update with apply to force the angular digest:
$scope.$apply(function () {
$scope.sushi=dataArray;
});
Or use the angular $http service to make the request.

Why works wrong the angular filter?

PictureFilter
Angular's filter not works correctly, as you see in the picture, for seach 'shi' it is also find the abc-sea , nnnn-road row...
I tried with this:
<div flex="30">
<label>Search: <input ng-model="searchText"></label>
<table class="table table-hover" id="shipmentTable">
<thead>
<tr>
<th>
<a href="#" ng-click="sortType = 'name'; sortReverse = !sortReverse">
shipment name
<i ng-show="sortType == 'name' && !sortReverse"
class="fa fa-angle-up"></i>
<i ng-show="sortType == 'name' && sortReverse"
class="fa fa-angle-down"></i>
</a>
</th>
<th>
<a href="#" ng-click="sortType = 'transportMode'; sortReverse = !sortReverse">
transport mode
<i ng-show="sortType == 'transportMode' && !sortReverse"
class="fa fa-angle-up"></i>
<i ng-show="sortType == 'transportMode' && sortReverse"
class="fa fa-angle-down"></i>
</a>
</th>
</tr>
</thead>
<tbody class="member">
<tr ng-class='{selected: $index==selectedRow}'
ng-click="selectRow($index);getSelected(shipment);"
ng-repeat="shipment in shipments | orderBy:sortType:sortReverse | filter:searchText">
<td>{{shipment.name}}</td>
<td>{{shipment.transportMode}}</td>
</tr>
</tbody>
</table>
But its not working correctly....what can be a problem?
Currently you filter searching for contains in through out the object shipment, so current filter filter has shi somewhere there in there property. Do apply filter on specific property of object like {name: searchText},
ng-repeat="shipment in shipments | orderBy:sortType:sortReverse | filter:{name:searchText}"

selecting checkbox id from table in Angularjs

I am new to Angularjs. I have created a table using Angularjs. I am populating the content of the table from the controller and using ng-repeat in the html to render the data.
I also need to handle the checkbox check event and populate the array in the controller. I have added the checkboxes in the view. I am able to bind the content but when I am not able to handle the the checkbox event when checked. How to handle this in Angularjs. I have added the ng-change and ng-model but I want to populate the selected checkbox id from the $scopr.update function. Currently whenever there is change event, the function is called with the id, but I don't know if the checkbox is checked on unchecked. Where I am going wrong?
Code for the UI
<div class="ibox-content">
<div class="row">
<div class="col-sm-4 m-b-xs">
<div data-toggle="buttons" class="btn-group">
<label class="btn btn-sm btn-white"> <input type="radio" id="option1" name="options">10</label>
<label class="btn btn-sm btn-white"> <input type="radio" id="option2" name="options">25</label>
<label class="btn btn-sm btn-white"> <input type="radio" id="option3" name="options">50</label>
</div>
</div>
<div class="col-sm-3 pull-right">
<div class="input-group">
<div class="input-group-addon"><i class="fa fa-search"></i></div>
<input type="text" class="form-control" placeholder="Search Host" ng-model="name">
</div>
</div>
</div>
<div class="table-responsive">
<table class="table table-striped table-bordered">
<thead>
<tr>
<td>Select</td>
<td>
<a href="#" ng-click="sortType = 'name'; sortReverse = !sortReverse">
Hostname
<span ng-show="sortType == 'name' && !sortReverse" class="fa fa-caret-down"></span>
<span ng-show="sortType == 'name' && sortReverse" class="fa fa-caret-up"></span>
</a>
</td>
<td>
<a href="#" ng-click="sortType = 'application'; sortReverse = !sortReverse">
Application
<span ng-show="sortType == 'application' && !sortReverse" class="fa fa-caret-down"></span>
<span ng-show="sortType == 'application' && sortReverse" class="fa fa-caret-up"></span>
</a>
</td>
<td>
<a href="#" ng-click="sortType = 'environment'; sortReverse = !sortReverse">
Environment
<span ng-show="sortType == 'environment' && !sortReverse" class="fa fa-caret-down"></span>
<span ng-show="sortType == 'environment' && sortReverse" class="fa fa-caret-up"></span>
</a>
</td>
</tr>
</thead>
<tbody>
<tr dir-paginate="host in newHosts | orderBy:sortType:sortReverse | filter:name | itemsPerPage: 10
" pagination-id="host">
<td><input type="checkbox" ng-change="update(host.id)" ng-model="host_id"/></td>
<td>{{host.name}}</td>
<td>{{host.application}}</td>
<td>{{host.environment}}</td>
</tr>
</tbody>
</table>
</div>
</div>
In the controller:
$scope.selectedHost=[];
$scope.sortType = 'name'; // set the default sort type
$scope.sortReverse = false; // set the default sort order
$scope.searchHost = ''; // set the default search/filter term
$scope.newHosts=[
{
"name": "Pradeep",
"application": "MMC",
"environment": "Prod"
},
{
"name": "Praveen",
"application": "TTC",
"environment": "Pre"
}
]
$scope.update=function(hostId){
console.log(hostId);
}
First, add the ng-click into your checkbox
<td><input type="checkbox" ng-click=update(host)/></td>
Then call the update function in the controller
$scope.update = function(host){
var hostIndex = $scope.selectedHost.indexOf(host);
if(hostIndex == -1) {
$scope.selectedHost.push(host); //Add the selected host into array
} else {
$scope.selectedHost.splice(hostIndex, 1); //Remove the selected host
}
}
U could send inde as well by using $index to the function and it will give you the
exact index of the selected row, so that u can get it from your array,
as well as u can do more code by using this, u are not required to get
index ( a probability to not to get right index in some cases)
<td><input type="checkbox" ng-click=update($index)/></td>
$scope.update = function(hostIndex){
var host= $scope.selectedHost[hostIndex];
if(hostIndex == -1) {
$scope.selectedHost.push(host); //Add the selected host into array
} else {
$scope.selectedHost.splice(hostIndex, 1); //Remove the selected host
}
}

Resources