persons-list.html 4.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576
  1. <!-- show the list of Persons -->
  2. <div class="container">
  3. <div class="container">
  4. <div class="row">
  5. <div class="col-md-7 col-xs-7 vcenter">
  6. <h1>{{'Persons' | translate}}
  7. <button ng-click="$state.go('person.new')" class="btn btn-success">
  8. <span class="glyphicon glyphicon-plus-sign"></span>
  9. {{'Add person' | translate}}
  10. </button>
  11. <button ng-click="$state.go('import.persons')" class="btn btn-success">
  12. <span class="glyphicon glyphicon-plus-sign"></span>
  13. {{'Import persons' | translate}}
  14. </button>
  15. </h1>
  16. </div><!--
  17. --><div class="col-md-5 col-xs-5 vcenter">
  18. <div class="row">
  19. <div class="col-md-6">
  20. <h2><div class="label label-info vcenter">{{'Persons:' | translate}} {{persons.length || 0}}</div></h2>
  21. </div>
  22. </div>
  23. </div>
  24. </div>
  25. <div class="panel panel-primary table-striped top5">
  26. <div class="panel-heading">{{'Persons' | translate}}</div>
  27. <div class="panel-body">
  28. <form class="form-inline">
  29. <div class="form-group">
  30. <label for="query-persons">{{'Search:' | translate}}</label>
  31. <input eventman-focus type="text" id="query-persons" class="form-control" placeholder="{{'Name or email' | translate}}" ng-model="query">
  32. </div>
  33. <div class="form-group">
  34. <label for="persons-order">{{'Sort by:' | translate}}</label>
  35. <select id="persons-order" class="form-control" ng-model="personsOrderProp">
  36. <option value="name" ng-selected="selected">{{'Name' | translate}}</option>
  37. <option value="-name" ng-selected="selected">{{'Name (descending)' | translate}}</option>
  38. <option value="surname" ng-selected="selected">{{'Surname' | translate}}</option>
  39. <option value="-surname" ng-selected="selected">{{'Surname (descending)' | translate}}</option>
  40. </select>
  41. </div>
  42. </form>
  43. <table class="table table-striped">
  44. <thead>
  45. <tr>
  46. <th><strong>{{'Name' | translate}}</strong></th>
  47. <th ng-repeat="col in customFields">
  48. <strong>{{col.label | translate}}</strong>
  49. </th>
  50. <th><strong>{{'Delete' | translate}}</strong></th>
  51. </tr>
  52. </thead>
  53. <tbody>
  54. <tr ng-repeat="person in persons | splittedFilter:query | orderBy:personsOrderProp">
  55. <td>
  56. <span><strong><a ui-sref="person.info({id: person._id})"><span>{{person.name}}</span>&nbsp;<span>{{person.surname}}</span></a></strong></span><span ng-if="person.email">&nbsp;&lt;{{person.email}}&gt;</span>
  57. <p ng-if="person.company || person.job_title"><i ng-if="person.job_title">{{person.job_title}}</i><span ng-if="person.company && person.job_title">&nbsp;@&nbsp;</span><i ng-if="person.company">{{person.company}}</i></p>
  58. </td>
  59. <td ng-repeat="col in customFields">
  60. <span ng-if="col.type == 'boolean'">
  61. <button class="btn btn-link" ng-click="setAttribute(person, col.key, !person[col.key])"><span class="glyphicon {{(person[col.key]) && 'glyphicon-ok-sign text-success' || 'glyphicon-remove-sign text-danger'}}"></span></button>
  62. </span>
  63. <span ng-if="col.type != 'boolean'">
  64. {{person[col.key]}}
  65. </span>
  66. </td>
  67. <td>
  68. <button ng-click="remove(person._id)" type="button" class="btn btn-link glyphicon glyphicon-trash"></button>
  69. </td>
  70. </tr>
  71. </tbody>
  72. </table>
  73. </div>
  74. </div>
  75. </div>