event-tickets.html 8.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122
  1. <!-- show details of an Event -->
  2. <div class="container">
  3. <div class="container">
  4. <div class="row">
  5. <div class="col-md-8">
  6. <div class="panel panel-primary table-striped top5">
  7. <div class="panel-heading">
  8. <h1>{{event.title}} - {{'tickets' | translate}}
  9. <button ng-if="event._id" ng-click="$state.go('event.edit', {id: event._id})" class="btn btn-success">
  10. <span class="fa fa-gear vcenter"></span>
  11. {{'Edit event' | translate}}
  12. </button>
  13. &nbsp;
  14. <button ng-if="event._id" ng-click="openQuickAddTicket()" class="btn btn-success">
  15. <span class="fa fa-user-plus vcenter"></span>
  16. {{'Quick add ticket' | translate}}
  17. </button>
  18. <span>
  19. <span class="label label-info vcenter pull-right">{{'Attendees:' | translate}} {{countAttendees}}</span>
  20. &nbsp;
  21. <span class="label label-warning vcenter pull-right registered-counter">{{'Registered:' | translate}} {{((event.tickets || []) | registeredFilter).length}}</span>
  22. </span>
  23. </h1>
  24. </div>
  25. <div class="panel-body">
  26. <div>
  27. <div style="float:left;">
  28. <form class="form-inline">
  29. <div class="form-group">
  30. <label for="query-tickets">{{'Search:' | translate}}</label>
  31. <input eventman-focus type="text" id="query-tickets" class="form-control query-input" placeholder="{{'Name or email or key:value' | translate}}" ng-model="query" ng-model-options="{debounce: 350}" esc-key="resetInput()">
  32. </div>&nbsp;<label>&nbsp;<input type="checkbox" ng-model="registeredFilterOptions.all" /> {{'Show cancelled tickets' | translate}}</label>
  33. </form>
  34. </div>
  35. <div style="float:right;">
  36. <span style="color:#9e9e9e;">({{filteredLength}} {{'filtered item/s' | translate}})</span>&nbsp;
  37. <a download="eventman.csv" ng-href="{{downloadURL}}" class="btn btn-primary" ng-class="{disabled: !filteredLength}"><span class="fa fa-download"></span> {{'export CSV' | translate}}</a>
  38. </div>
  39. </div>
  40. <div class="clearfix"></div>
  41. <uib-pagination ng-model="currentPage" total-items="filteredLength" items-per-page="itemsPerPage"
  42. direction-links="false" boundary-links="true" boundary-link-numbers="true" max-size="maxPaginationSize">
  43. </uib-pagination>
  44. <table class="table table-striped">
  45. <thead>
  46. <tr>
  47. <th class="text-right nowrap">#</th>
  48. <th class="nowrap"><a ng-click="updateOrded('name')" href=""><i class="fa fa-caret-up"></i></a>{{'Name' | translate}}<a ng-click="updateOrded('-name')" href=""><i class="fa fa-caret-down"></i></a> <a ng-click="updateOrded('surname')" href=""><i class="fa fa-caret-up"></i></a>{{'Surname' | translate}}<a ng-click="updateOrded('-surname')" href=""><i class="fa fa-caret-down"></i></a></th>
  49. <th class="text-center nowrap"><a ng-click="updateOrded('-attended')" href=""><i class="fa fa-caret-up"></i></a>{{'Attended' | translate}}<a ng-click="updateOrded('attended')" href=""><i class="fa fa-caret-down"></i></a></th>
  50. <th class="text-center nowrap" ng-repeat="col in customFields">
  51. <a ng-click="updateOrded(col.key)" href=""><i class="fa fa-caret-up"></i></a>{{col.label | translate}}<a ng-click="updateOrded('-' + col.key)" href=""><i class="fa fa-caret-down"></i></a>
  52. </th>
  53. <th class="text-center nowrap">{{'Delete' | translate}}</th>
  54. </tr>
  55. </thead>
  56. <tbody>
  57. <tr ng-repeat="ticket in shownItems">
  58. <td class="text-right">{{$index + 1 + ((currentPage-1)*itemsPerPage)}}</td>
  59. <td>
  60. <span>
  61. <strong>
  62. <a ui-sref="event.ticket.edit({id: event._id, ticket_id: ticket._id})"><span>{{ticket.name}}</span>&nbsp;<span>{{ticket.surname}}</span></a>
  63. </strong>
  64. </span>
  65. <span ng-if="ticket.email">&nbsp;&lt;{{ticket.email}}&gt;</span><span ng-if="ticket.cancelled">&nbsp;({{'cancelled' | translate}})</span>
  66. <p ng-if="ticket.company || ticket['job title']"><i ng-if="ticket['job title']">{{ticket['job title']}}</i><span ng-if="ticket.company && ticket['job title']">&nbsp;@&nbsp;</span><i ng-if="ticket.company">{{ticket.company}}</i></p>
  67. </td>
  68. <td class="text-center">
  69. <button class="btn btn-link" reset-focus name="switch-attended" ng-click="setTicketAttributeAndRefocus(ticket, 'attended', !ticket.attended)"><span class="fa {{(ticket.attended) && 'fa-check-circle text-success' || 'fa-times-circle text-danger'}}"></span></button>
  70. </td>
  71. <td class="text-center" ng-repeat="col in customFields">
  72. <span ng-if="col.type == 'boolean'">
  73. <button class="btn btn-link" ng-click="setTicketAttribute(ticket, col.key, !ticket[col.key])"><span class="fa {{(ticket[col.key]) && 'fa-check-circle text-success' || 'fa-times-circle text-danger'}}"></span></button>
  74. </span>
  75. <span ng-if="col.type != 'boolean'">
  76. {{ticket[col.key]}}
  77. </span>
  78. </td>
  79. <td class="text-center">
  80. <button ng-click="deleteTicket(ticket)" type="button" class="btn btn-link fa fa-trash"></button>
  81. </td>
  82. </tr>
  83. </tbody>
  84. </table>
  85. <uib-pagination ng-model="currentPage" total-items="filteredLength" items-per-page="itemsPerPage"
  86. direction-links="false" boundary-links="true" boundary-link-numbers="true" max-size="maxPaginationSize">
  87. </uib-pagination>
  88. </div>
  89. </div>
  90. </div>
  91. <div class="col-md-4">
  92. <div class="panel panel-info top5">
  93. <div class="panel-heading"><h1>{{'Unregistered persons' | translate}}</h1></div>
  94. <div class="panel-body small-table">
  95. <table class="table table-striped table-condensed">
  96. <thead>
  97. <tr>
  98. <th>{{'Person' | translate}}</th>
  99. <th class="text-left">{{'Add' | translate}}</th>
  100. </tr>
  101. </thead>
  102. <tbody>
  103. <tr ng-repeat="person in (query ? allPersons : []) | splittedFilter:query | personRegistered:{event: event, present: false} | limitTo:maxAllPersons">
  104. <td>
  105. <strong>{{person.name}} {{person.surname}}</strong>
  106. <br />
  107. {{person.email}}
  108. </td>
  109. <td class="text-left">
  110. <button reset-focus ng-click="addTicket(person)" type="button" class="btn btn-link fa fa-user-plus vcenter"></button>
  111. </td>
  112. </tr>
  113. </tbody>
  114. </table>
  115. </div>
  116. </div>
  117. </div>
  118. </div>
  119. </div>
  120. </div>