event-tickets.html 7.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113
  1. <!-- show details of an Event -->
  2. <div class="container">
  3. <div eventman-message="eventman-message" control="message"></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="fa fa-pencil-square-o vcenter"></span>
  10. {{'Edit' | translate}}
  11. </button>
  12. &nbsp;
  13. <button ng-if="event._id" ng-click="openQuickAddTicket()" class="btn btn-success">
  14. <span class="fa fa-user-plus vcenter"></span>
  15. {{'Quick add ticket' | translate}}
  16. </button>
  17. </h1>
  18. </div><!--
  19. --><div class="col-md-5 col-xs-5 vcenter">
  20. <div class="row">
  21. <div class="col-md-6">
  22. <h2><div class="label label-warning vcenter">{{'Registered:' | translate}} {{((event.persons || []) | registeredFilter).length}}</div></h2>
  23. </div>
  24. <div class="col-md-6">
  25. <h2><div class="label label-info vcenter">{{'Attendees:' | translate}} {{countAttendees}}</div></h2>
  26. </div>
  27. </div>
  28. </div>
  29. </div>
  30. </div>
  31. <div class="container">
  32. <div class="row">
  33. <div class="col-md-8">
  34. <div class="panel panel-primary table-striped top5">
  35. <div class="panel-heading">{{'Persons' | translate}}</div>
  36. <div class="panel-body">
  37. <form class="form-inline">
  38. <div class="form-group">
  39. <label for="query-persons">{{'Search:' | translate}}</label>
  40. <input eventman-focus type="text" id="query-persons" class="form-control" placeholder="{{'Name or email' | translate}}" ng-model="query" ng-model-options="{debounce: 600}">
  41. </div>
  42. </form>
  43. <table class="table table-striped">
  44. <thead>
  45. <tr>
  46. <th class="text-right nowrap">#</th>
  47. <th class="nowrap">{{'Person' | translate}} <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>
  48. <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>
  49. <th class="text-center nowrap" ng-repeat="col in customFields">
  50. <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>
  51. </th>
  52. <th class="text-center nowrap">{{'Delete' | translate}}</th>
  53. </tr>
  54. </thead>
  55. <tbody>
  56. <tr ng-repeat="person in (event.persons || []) | splittedFilter:query | registeredFilter | orderBy:personsOrder">
  57. <td class="text-right">{{$index+1}}</td>
  58. <td>
  59. <span><strong><a ui-sref="person.info({id: person.person_id})"><span class="fa fa-lg fa-user"></span></a>&nbsp;<a ui-sref="event.ticket.edit({id: event._id, ticket_id: person._id})" ng-if="person._id"><span>{{person.name}}</span>&nbsp;<span>{{person.surname}}</span></a></strong></span><span ng-if="!person._id"><span>{{person.name}}</span>&nbsp;<span>{{person.surname}}</span></a></strong></span></span><span ng-if="person.email">&nbsp;&lt;{{person.email}}&gt;</span>
  60. <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>
  61. </td>
  62. <td class="text-center">
  63. <button class="btn btn-link" reset-focus name="switch-attended" ng-click="setPersonAttributeAndRefocus(person, 'attended', !person.attended)"><span class="fa fa-lg {{(person.attended) && 'fa-check-circle text-success' || 'fa-times-circle text-danger'}}"></span></button>
  64. </td>
  65. <td class="text-center" ng-repeat="col in customFields">
  66. <span ng-if="col.type == 'boolean'">
  67. <button class="btn btn-link" ng-click="setPersonAttribute(person, col.key, !person[col.key])"><span class="fa fa-lg {{(person[col.key]) && 'fa-check-circle text-success' || 'fa-times-circle text-danger'}}"></span></button>
  68. </span>
  69. <span ng-if="col.type != 'boolean'">
  70. {{person[col.key]}}
  71. </span>
  72. </td>
  73. <td class="text-center">
  74. <button ng-click="removeAttendee(person)" type="button" class="btn btn-link fa fa-lg fa-trash"></button>
  75. </td>
  76. </tr>
  77. </tbody>
  78. </table>
  79. </div>
  80. </div>
  81. </div>
  82. <div class="col-md-4">
  83. <div class="panel panel-info top5">
  84. <div class="panel-heading">{{'Unregistered persons' | translate}}</div>
  85. <div class="panel-body small-table">
  86. <table class="table table-striped table-condensed">
  87. <thead>
  88. <tr>
  89. <th>{{'Person' | translate}}</th>
  90. <th class="text-left">{{'Add' | translate}}</th>
  91. </tr>
  92. </thead>
  93. <tbody>
  94. <tr ng-repeat="person in allPersons | splittedFilter:query | personRegistered:{event: event, present: false}">
  95. <td>
  96. <strong><a ui-sref="person.info({id: person._id})">{{person.name}} {{person.surname}}</a></strong>
  97. <br />
  98. {{person.email}}
  99. </td>
  100. <td class="text-left">
  101. <button reset-focus ng-click="fastAddAttendee(person)" type="button" class="btn btn-link fa fa-plus-circle vcenter"></button>
  102. </td>
  103. </tr>
  104. </tbody>
  105. </table>
  106. </div>
  107. </div>
  108. </div>
  109. </div>
  110. </div>
  111. </div>