event-info.html 6.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111
  1. <!-- show details of an Event -->
  2. <div class="container">
  3. <h1>{{event.title}}
  4. <button ng-if="event._id" ng-click="$state.go('event.edit', {id: event._id})" class="btn btn-success">
  5. <span class="glyphicon glyphicon-edit"></span>
  6. {{'Edit' | translate}}
  7. </button>
  8. </h1>
  9. <div class="container">
  10. <div class="row">
  11. <div class="col-md-8">
  12. <div class="panel panel-primary table-striped top5">
  13. <div class="panel-heading">{{'Persons' | translate}}</div>
  14. <div class="panel-body">
  15. <form class="form-inline">
  16. <div class="form-group">
  17. <label for="query-persons">{{'Search:' | translate}}</label>
  18. <input type="text" id="query-persons" class="form-control" placeholder="{{'Name or email' | translate}}" ng-model="query">
  19. </div>
  20. <div class="form-group">
  21. <label for="persons-order">{{'Sort by:' | translate}}</label>
  22. <select id="persons-order" class="form-control" ng-model="personsOrderProp">
  23. <option value="name" ng-selected="selected">{{'Name' | translate}}</option>
  24. <option value="-name" ng-selected="selected">{{'Name (descending)' | translate}}</option>
  25. <option value="surname" ng-selected="selected">{{'Surname' | translate}}</option>
  26. <option value="-surname" ng-selected="selected">{{'Surname (descending)' | translate}}</option>
  27. </select>
  28. </div>
  29. </form>
  30. <table class="table table-striped">
  31. <thead>
  32. <tr>
  33. <th>{{'Person' | translate}}</th>
  34. <th>{{'Email' | translate}}</th>
  35. <th>{{'Attended' | translate}}</th>
  36. <th>{{'Actions' | translate}}</th>
  37. </tr>
  38. </thead>
  39. <tbody>
  40. <tr ng-repeat="person in event.persons | splittedFilter:query | orderBy:personsOrderProp">
  41. <td><strong><a ui-sref="person.info({id: person.person_id})">{{person.name}} {{person.surname}}</a></strong></td>
  42. <td>{{person.email}}</td>
  43. <td>
  44. <button class="btn btn-link" name="switch-attended" ng-click="updateAttendee(person, !person.attended)"><span class="glyphicon {{(person.attended) && 'glyphicon-ok-sign text-success' || 'glyphicon-remove-sign text-danger'}}"></span></button>
  45. </td>
  46. <td>
  47. <button ng-click="removeAttendee(person)" type="button" class="btn btn-link glyphicon glyphicon-trash"></button>
  48. </td>
  49. </tr>
  50. </tbody>
  51. </table>
  52. </div>
  53. </div>
  54. </div>
  55. <div class="col-md-4">
  56. <div class="panel panel-info table-striped top5">
  57. <div class="panel-heading">{{'Fast add' | translate}}</div>
  58. <div class="panel-body">
  59. <form>
  60. <div class="input-group input-group-sm">
  61. <span class="input-group-addon">{{'Name' | translate}}</span>
  62. <input type="text" class="form-control" placeholder="{{'Name' | translate}}" ng-model="newPerson.name" ng-required="1">
  63. </div>
  64. <div class="input-group input-group-sm top5">
  65. <span class="input-group-addon">{{'Surname' | translate}}</span>
  66. <input type="text" class="form-control" placeholder="{{'Surname' | translate}}" ng-model="newPerson.surname">
  67. </div>
  68. <div class="input-group top5">
  69. <span class="input-group-addon">{{'Email' | translate}}</span>
  70. <input type="email" name="email" class="form-control" placeholder="{{'name.surname@example.com' | translate}}" ng-model="newPerson.email">
  71. </div>
  72. <button ng-disabled="!(newPerson.name && newPerson.surname)" ng-click="fastAddPerson(newPerson, true)" class="btn btn-success top5">
  73. <span class="glyphicon glyphicon-plus-sign"></span>
  74. {{'Add' | translate}}
  75. </button>
  76. </form>
  77. </div>
  78. </div>
  79. <div class="panel panel-info table-striped top5">
  80. <div class="panel-heading">{{'Unregistered persons' | translate}}</div>
  81. <div class="panel-body" style="height:200px;overflow:auto;">
  82. <table class="table table-striped table-condensed">
  83. <thead>
  84. <tr>
  85. <th>{{'Person' | translate}}</th>
  86. <th>{{'Add' | translate}}</th>
  87. </tr>
  88. </thead>
  89. <tbody>
  90. <tr ng-repeat="person in allPersons | filter:newPerson | personRegistered:{event: event, present: false}">
  91. <td>
  92. <strong><a ui-sref="person.info({id: person._id})">{{person.name}} {{person.surname}}</a></strong>
  93. <br />
  94. {{person.email}}
  95. </td>
  96. <td>
  97. <button ng-click="fastAddPerson(person)" type="button" class="btn btn-link glyphicon glyphicon-plus-sign"></button>
  98. </td>
  99. </tr>
  100. </tbody>
  101. </table>
  102. </div>
  103. </div>
  104. </div>
  105. </div>
  106. </div>
  107. </div>