orgUsers.html 2.8 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091
  1. <topnav title="Organization" icon="fa fa-fw fa-users" subnav="true">
  2. <ul class="nav">
  3. <li class="active"><a href="org/users">Users</a></li>
  4. </ul>
  5. </topnav>
  6. <div class="page-container" style="background: transparent; border: 0;">
  7. <div class="page-wide">
  8. <h2>Organization users</h2>
  9. <button class="btn btn-success pull-right" ng-click="openInviteModal()">
  10. <i class="fa fa-plus"></i>
  11. Add or Invite
  12. </button>
  13. <br>
  14. <tabset>
  15. <tab heading="Users ({{users.length}})">
  16. <table class="filter-table form-inline">
  17. <thead>
  18. <tr>
  19. <th>Login</th>
  20. <th>Email</th>
  21. <th>Role</th>
  22. <th style="width: 34px;"></th>
  23. </tr>
  24. </thead>
  25. <tr ng-repeat="user in users">
  26. <td>{{user.login}}</td>
  27. <td><span class="ellipsis">{{user.email}}</span></td>
  28. <td>
  29. <select type="text" ng-model="user.role" class="input-medium" ng-options="f for f in ['Viewer', 'Editor', 'Read Only Editor', 'Admin']" ng-change="updateOrgUser(user)">
  30. </select>
  31. </td>
  32. <td>
  33. <a ng-click="removeUser(user)" class="btn btn-danger btn-mini">
  34. <i class="fa fa-remove"></i>
  35. </a>
  36. </td>
  37. </tr>
  38. </table>
  39. </tab>
  40. <tab heading="Pending Invitations ({{pendingInvites.length}})">
  41. <table class="filter-table form-inline">
  42. <thead>
  43. <tr>
  44. <th>Email</th>
  45. <th>Name</th>
  46. <th></th>
  47. </tr>
  48. </thead>
  49. <tbody ng-repeat="invite in pendingInvites">
  50. <tr ng-click="invite.expanded = !invite.expanded" ng-class="{'expanded': invite.expanded}">
  51. <td>{{invite.email}}</td>
  52. <td>{{invite.name}}</td>
  53. <td class="text-right">
  54. <button class="btn btn-inverse btn-mini " data-clipboard-text="{{invite.url}}" clipboard-button ng-click="copyInviteToClipboard($event)">
  55. <i class="fa fa-clipboard"></i> Copy Invite
  56. </button>
  57. &nbsp;
  58. <button class="btn btn-inverse btn-mini">
  59. Details
  60. <i ng-show="!invite.expanded" class="fa fa-caret-right"></i>
  61. <i ng-show="invite.expanded" class="fa fa-caret-down"></i>
  62. </button>
  63. </td>
  64. </tr>
  65. <tr ng-show="invite.expanded">
  66. <td colspan="3">
  67. <a href="{{invite.url}}">{{invite.url}}</a><br><br>
  68. <button class="btn btn-inverse btn-mini">
  69. <i class="fa fa-envelope-o"></i> Resend invite
  70. </button>
  71. &nbsp;
  72. <button class="btn btn-inverse btn-mini" ng-click="revokeInvite(invite, $event)">
  73. <i class="fa fa-remove" style="color: red"></i> Revoke invite
  74. </button>
  75. <span style="padding-left: 15px">
  76. Invited: <em> {{invite.createdOn | date: 'shortDate'}} by {{invite.invitedBy}} </em>
  77. </span>
  78. </td>
  79. </tr>
  80. </tbody>
  81. </table>
  82. </tab>
  83. </tabset>
  84. </div>
  85. </div>