event-info.html 9.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149
  1. <!-- show details of an Event -->
  2. <div class="container">
  3. <div eventman-message="eventman-message" control="message" ng-class="{'eventman-message': true, clearfix: true, alert: true, 'alert-success': !dControl.isError, 'alert-danger': dControl.isError}"></div>
  4. <div class="container">
  5. <div class="row">
  6. <div class="col-md-7 col-xs-7 vcenter">
  7. <h1>{{event.title}}
  8. <button ng-if="event._id" ng-click="$state.go('event.edit', {id: event._id})" class="btn btn-success">
  9. <span class="glyphicon glyphicon-edit"></span>
  10. {{'Edit' | translate}}
  11. </button>
  12. </h1>
  13. </div><!--
  14. --><div class="col-md-5 col-xs-5 vcenter">
  15. <div class="row">
  16. <div class="col-md-6">
  17. <h2><div class="label label-warning vcenter">{{'Registered:' | translate}} {{event.persons.length || 0}}</div></h2>
  18. </div>
  19. <div class="col-md-6">
  20. <h2><div class="label label-info vcenter">{{'Attendees:' | translate}} {{countAttendees}}</div></h2>
  21. </div>
  22. </div>
  23. </div>
  24. </div>
  25. </div>
  26. <div class="container">
  27. <div class="row">
  28. <div class="col-md-8">
  29. <div class="panel panel-primary table-striped top5">
  30. <div class="panel-heading">{{'Persons' | translate}}</div>
  31. <div class="panel-body">
  32. <form class="form-inline">
  33. <div class="form-group">
  34. <label for="query-persons">{{'Search:' | translate}}</label>
  35. <input eventman-focus type="text" id="query-persons" class="form-control" placeholder="{{'Name or email' | translate}}" ng-model="query">
  36. </div>
  37. <div class="form-group">
  38. <label for="persons-order">{{'Sort by:' | translate}}</label>
  39. <select id="persons-order" class="form-control" ng-model="personsOrderProp">
  40. <option value="name" ng-selected="selected">{{'Name' | translate}}</option>
  41. <option value="-name" ng-selected="selected">{{'Name (descending)' | translate}}</option>
  42. <option value="surname" ng-selected="selected">{{'Surname' | translate}}</option>
  43. <option value="-surname" ng-selected="selected">{{'Surname (descending)' | translate}}</option>
  44. </select>
  45. </div>
  46. </form>
  47. <table class="table table-striped">
  48. <thead>
  49. <tr>
  50. <th>{{'Person' | translate}}</th>
  51. <th>{{'Attended' | translate}}</th>
  52. <th ng-repeat="col in customFields">
  53. <strong>{{col.label | translate}}</strong>
  54. </th>
  55. <th>{{'Delete' | translate}}</th>
  56. </tr>
  57. </thead>
  58. <tbody>
  59. <tr ng-repeat="person in event.persons | splittedFilter:query | orderBy:personsOrderProp">
  60. <td>
  61. <span><strong><a ui-sref="person.info({id: person.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>
  62. <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>
  63. </td>
  64. <td>
  65. <button class="btn btn-link" reset-focus name="switch-attended" ng-click="setPersonAttributeAndRefocus(person, 'attended', !person.attended)"><span class="glyphicon {{(person.attended) && 'glyphicon-ok-sign text-success' || 'glyphicon-remove-sign text-danger'}}"></span></button>
  66. </td>
  67. <td ng-repeat="col in customFields">
  68. <span ng-if="col.type == 'boolean'">
  69. <button class="btn btn-link" ng-click="setPersonAttribute(person, col.key, !person[col.key])"><span class="glyphicon {{(person[col.key]) && 'glyphicon-ok-sign text-success' || 'glyphicon-remove-sign text-danger'}}"></span></button>
  70. </span>
  71. <span ng-if="col.type != 'boolean'">
  72. {{person[col.key]}}
  73. </span>
  74. </td>
  75. <td>
  76. <button ng-click="removeAttendee(person)" type="button" class="btn btn-link glyphicon glyphicon-trash"></button>
  77. </td>
  78. </tr>
  79. </tbody>
  80. </table>
  81. </div>
  82. </div>
  83. </div>
  84. <div class="col-md-4">
  85. <div class="panel panel-info table-striped top5">
  86. <div class="panel-heading">{{'Quick add' | translate}}</div>
  87. <div class="panel-body">
  88. <form>
  89. <div class="input-group input-group-sm">
  90. <span class="input-group-addon">{{'Name' | translate}}</span>
  91. <input type="text" class="form-control" placeholder="{{'Name' | translate}}" ng-model="newPerson.name" ng-required="1">
  92. </div>
  93. <div class="input-group input-group-sm top5">
  94. <span class="input-group-addon">{{'Surname' | translate}}</span>
  95. <input type="text" class="form-control" placeholder="{{'Surname' | translate}}" ng-model="newPerson.surname">
  96. </div>
  97. <div class="input-group top5">
  98. <span class="input-group-addon">{{'Email' | translate}}</span>
  99. <input type="email" name="email" class="form-control" placeholder="{{'name.surname@example.com' | translate}}" ng-model="newPerson.email">
  100. </div>
  101. <div class="input-group top5">
  102. <span class="input-group-addon">{{'Company' | translate}}</span>
  103. <input name="company" class="form-control" placeholder="{{'Acme Corporation' | translate}}" ng-model="newPerson.company">
  104. </div>
  105. <div class="input-group top5">
  106. <span class="input-group-addon">{{'Job' | translate}}</span>
  107. <input name="job_title" class="form-control" placeholder="{{'Evil Ruler' | translate}}" ng-model="newPerson.job_title">
  108. </div>
  109. <button reset-focus ng-disabled="!(newPerson.name && newPerson.surname)" ng-click="fastAddPerson(newPerson, true)" class="btn btn-success top5">
  110. <span class="glyphicon glyphicon-plus-sign"></span>
  111. {{'Add' | translate}}
  112. </button>
  113. </form>
  114. </div>
  115. </div>
  116. <div class="panel panel-info table-striped top5">
  117. <div class="panel-heading">{{'Unregistered persons' | translate}}</div>
  118. <div class="panel-body" style="height:200px;overflow:auto;">
  119. <table class="table table-striped table-condensed">
  120. <thead>
  121. <tr>
  122. <th>{{'Person' | translate}}</th>
  123. <th>{{'Add' | translate}}</th>
  124. </tr>
  125. </thead>
  126. <tbody>
  127. <tr ng-repeat="person in allPersons | splittedFilter:query | personRegistered:{event: event, present: false}">
  128. <td>
  129. <strong><a ui-sref="person.info({id: person._id})">{{person.name}} {{person.surname}}</a></strong>
  130. <br />
  131. {{person.email}}
  132. </td>
  133. <td>
  134. <button reset-focus ng-click="fastAddPerson(person)" type="button" class="btn btn-link glyphicon glyphicon-plus-sign"></button>
  135. </td>
  136. </tr>
  137. </tbody>
  138. </table>
  139. </div>
  140. </div>
  141. </div>
  142. </div>
  143. </div>
  144. </div>