org_users_ctrl.ts 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114
  1. ///<reference path="../../headers/common.d.ts" />
  2. import config from 'app/core/config';
  3. import coreModule from 'app/core/core_module';
  4. import Remarkable from 'remarkable';
  5. export class OrgUsersCtrl {
  6. user: any;
  7. users: any;
  8. pendingInvites: any;
  9. editor: any;
  10. navModel: any;
  11. externalUserMngLinkUrl: string;
  12. externalUserMngLinkName: string;
  13. externalUserMngInfo: string;
  14. addUsersBtnName: string;
  15. /** @ngInject */
  16. constructor(private $scope, private backendSrv, navModelSrv, $sce) {
  17. this.user = {
  18. loginOrEmail: '',
  19. role: 'Viewer',
  20. };
  21. this.navModel = navModelSrv.getNav('cfg', 'users');
  22. this.get();
  23. this.editor = { index: 0 };
  24. this.externalUserMngLinkUrl = config.externalUserMngLinkUrl;
  25. this.externalUserMngLinkName = config.externalUserMngLinkName;
  26. // render external user management info markdown
  27. if (config.externalUserMngInfo) {
  28. this.externalUserMngInfo = new Remarkable({
  29. linkTarget: '__blank',
  30. }).render(config.externalUserMngInfo);
  31. }
  32. this.addUsersBtnName = this.getAddUserBtnName();
  33. }
  34. getAddUserBtnName(): string {
  35. if (this.externalUserMngLinkName) {
  36. return this.externalUserMngLinkName;
  37. }
  38. return "Add Members";
  39. }
  40. get() {
  41. this.backendSrv.get('/api/org/users')
  42. .then((users) => {
  43. this.users = users;
  44. });
  45. this.backendSrv.get('/api/org/invites')
  46. .then((pendingInvites) => {
  47. this.pendingInvites = pendingInvites;
  48. });
  49. }
  50. updateOrgUser(user) {
  51. this.backendSrv.patch('/api/org/users/' + user.userId, user);
  52. }
  53. removeUser(user) {
  54. this.$scope.appEvent('confirm-modal', {
  55. title: 'Delete',
  56. text: 'Are you sure you want to delete user ' + user.login + '?',
  57. yesText: "Delete",
  58. icon: "fa-warning",
  59. onConfirm: () => {
  60. this.removeUserConfirmed(user);
  61. }
  62. });
  63. }
  64. removeUserConfirmed(user) {
  65. this.backendSrv.delete('/api/org/users/' + user.userId)
  66. .then(this.get.bind(this));
  67. }
  68. revokeInvite(invite, evt) {
  69. evt.stopPropagation();
  70. this.backendSrv.patch('/api/org/invites/' + invite.code + '/revoke')
  71. .then(this.get.bind(this));
  72. }
  73. copyInviteToClipboard(evt) {
  74. evt.stopPropagation();
  75. }
  76. getInviteUrl(invite) {
  77. return invite.url;
  78. }
  79. openAddUsersView() {
  80. var modalScope = this.$scope.$new();
  81. modalScope.invitesSent = this.get.bind(this);
  82. var src = config.disableLoginForm
  83. ? 'public/app/features/org/partials/add_user.html'
  84. : 'public/app/features/org/partials/invite.html';
  85. this.$scope.appEvent('show-modal', {
  86. src: src,
  87. modalClass: 'invite-modal',
  88. scope: modalScope
  89. });
  90. }
  91. }
  92. coreModule.controller('OrgUsersCtrl', OrgUsersCtrl);