In your example you have showfarebut1
and showfarebut2
shared across all the rows, that causes one button clicked affect all rows. You should use something bound to the current row: row.showfarebut1
and row.showfarebut2
.
However, there is a more efficient way to make toggle buttons. You can reuse the same button and set classes and text according to the state of the record. Here is a simple example:
HTML
<ul class="list-group" ng-controller="ctrl">
<li class="list-group-item" ng-repeat="row in rowList">
<span>{{row.col1.value}}</span>
<span>{{row.col2.value}}</span>
<button type="button" ng-click="row.selected=!row.selected" class="pull-right btn btn-xs">
<span ng-class="{'glyphicon':true, 'glyphicon-ok':row.selected, 'glyphicon-plus':!row.selected}"></span>
{{row.selected?'Selected':''}}
</button>
</li>
</ul>
You can use ng-class
directive to toggle classes and condition like {{row.selected?'Selected':''}}
to toggle text of the button.
JavaScript
angular.module('app', []).
controller('ctrl', function($scope) {
$scope.rowList = [{
col1: { value: 'r1c1'},
col2: {value: 'r1c2'}
}, {
col1: {value: 'r2c1'},
col2: {value: 'r2c2'}
}, {
col1: {value: 'r3c1'},
col2: {value: 'r3c2'}
}];
});
You even don't need some special function for selecting an item, you can do simple things directly in ng-click
Screenshot
Plunker: http://plnkr.co/edit/ZFRIWOe2HxMq8K11FBk4?p=preview
Edit (adapted version):
HTML
<table ng-controller="ctrl" class="table">
<tr ng-repeat="row in rowList">
<td>{{row.col1.value}}</td>
<td>
<span class="price">PRICE:
<strong class="amount">{{row.col2.value}}</strong>
</span>
<button id="btn{{$index}}" type="button" class="btn pull-right" ng-click="select(row)">
<span class="text pull-left" name="fareOption" value="{{row.col3.value}}">{{row.selected?'Selected':'Select'}}</span>
<i ng-class="{'icon-placeholder':!row.selected, 'selected-icon':row.selected, 'pull-right':row.selected}"></i>
</button>
</td>
</tr>
</table>
JavaScript
angular.module('app', []).
controller('ctrl', function($scope) {
$scope.rowList = [{
col1: {value: 'Orange'},
col2: {value: '10'},
col3: {value: 'x1'},
col4: {value: 'y1'}
}, {
col1: {value: 'Apple'},
col2: {value: '20'},
col3: {value: 'x2'},
col4: {value: 'y2'}
}, {
col1: {value: 'Banana'},
col2: {value: '15'},
col3: {value: 'x3'},
col4: {value: 'y3'}
}];
$scope.select = function(row) {
row.selected=!row.selected;
// Do something with row.col3.value and row.col4.value
}
});
Plunker: http://plnkr.co/edit/DdO1zBXxkyXWSLA6Gv2x?p=preview