orgUsers.html 2.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475
  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">
  7. <div class="page">
  8. <h2>Organization users</h2>
  9. <button class="btn btn-success pull-right" ng-click="openInviteModal()">
  10. Invite Users
  11. </button>
  12. <br>
  13. <tabset>
  14. <tab heading="Users ({{users.length}})">
  15. <table class="grafana-options-table form-inline">
  16. <tr>
  17. <th>Login</th>
  18. <th>Email</th>
  19. <th>Role</th>
  20. <th></th>
  21. </tr>
  22. <tr ng-repeat="user in users">
  23. <td>{{user.login}}</td>
  24. <td>{{user.email}}</td>
  25. <td>
  26. <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)">
  27. </select>
  28. </td>
  29. <td style="width: 1%">
  30. <a ng-click="removeUser(user)" class="btn btn-danger btn-mini">
  31. <i class="fa fa-remove"></i>
  32. </a>
  33. </td>
  34. </tr>
  35. </table>
  36. </tab>
  37. <tab heading="Pending Invitations ({{pendingInvites.length}})">
  38. <div class="grafana-list-item" ng-repeat="invite in pendingInvites" ng-click="invite.expanded = !invite.expanded">
  39. {{invite.email}}
  40. <span ng-show="invite.name" style="padding-left: 20px"> {{invite.name}}</span>
  41. <span class="pull-right">
  42. <button class="btn btn-inverse btn-mini " data-clipboard-text="{{invite.url}}" clipboard-button ng-click="copyInviteToClipboard($event)"
  43. <i class="fa fa-clipboard"></i> Copy Invite
  44. </button>
  45. &nbsp;
  46. <a class="pointer">
  47. <i ng-show="!invite.expanded" class="fa fa-caret-right"></i>
  48. <i ng-show="invite.expanded" class="fa fa-caret-down"></i>
  49. </a>
  50. </span>
  51. <div ng-show="invite.expanded">
  52. <a href="{{invite.url}}">{{invite.url}}</a><br>
  53. <button class="btn btn-inverse btn-mini">
  54. <i class="fa fa-envelope-o"></i> Resend invite
  55. </button>
  56. &nbsp;
  57. <button class="btn btn-inverse btn-mini" ng-click="revokeInvite(invite, $event)">
  58. <i class="fa fa-remove" style="color: red"></i> Revoke invite
  59. </button>
  60. <span style="padding-left: 15px">
  61. Invited: <em> {{invite.createdOn | date: 'shortDate'}} by {{invite.invitedBy}} </em>
  62. </span>
  63. <div>
  64. </div>
  65. </tab>
  66. </tabset>
  67. </div>
  68. </div>