In your example, you have showfarebut1 and showfarebut2 separated by all lines, which causes a single click on all lines. You should use something related to the current line: row.showfarebut1 and row.showfarebut2 .
However, there is a more efficient way to create toggle buttons. You can use the same button and set the 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 to switch classes and conditions like {{row.selected?'Selected':''}} to switch the button text.
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 donβt even need a special function to select an element, 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;
Plunker: http://plnkr.co/edit/DdO1zBXxkyXWSLA6Gv2x?p=preview