user_groups_ctrl.ts 2.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778
  1. ///<reference path="../../headers/common.d.ts" />
  2. import coreModule from 'app/core/core_module';
  3. export default class UserGroupsCtrl {
  4. userGroups: any;
  5. pages = [];
  6. perPage = 50;
  7. page = 1;
  8. totalPages: number;
  9. showPaging = false;
  10. query: any = '';
  11. userGroupName: any = '';
  12. /** @ngInject */
  13. constructor(private $scope, private $http, private backendSrv, private $location) {
  14. this.get();
  15. }
  16. get() {
  17. this.backendSrv.get(`/api/user-groups/search?perpage=${this.perPage}&page=${this.page}&query=${this.query}`)
  18. .then((result) => {
  19. this.userGroups = result.userGroups;
  20. this.page = result.page;
  21. this.perPage = result.perPage;
  22. this.totalPages = Math.ceil(result.totalCount / result.perPage);
  23. this.showPaging = this.totalPages > 1;
  24. this.pages = [];
  25. for (var i = 1; i < this.totalPages+1; i++) {
  26. this.pages.push({ page: i, current: i === this.page});
  27. }
  28. });
  29. }
  30. navigateToPage(page) {
  31. this.page = page.page;
  32. this.get();
  33. }
  34. createUserGroup() {
  35. this.backendSrv.post('/api/user-groups', {name: this.userGroupName}).then((result) => {
  36. if (result.userGroupId) {
  37. this.$location.path('/org/user-groups/edit/' + result.userGroupId);
  38. }
  39. });
  40. }
  41. deleteUserGroup(userGroup) {
  42. this.$scope.appEvent('confirm-modal', {
  43. title: 'Delete',
  44. text: 'Are you sure you want to delete User Group ' + userGroup.name + '?',
  45. yesText: "Delete",
  46. icon: "fa-warning",
  47. onConfirm: () => {
  48. this.deleteUserGroupConfirmed(userGroup);
  49. }
  50. });
  51. }
  52. deleteUserGroupConfirmed(userGroup) {
  53. this.backendSrv.delete('/api/user-groups/' + userGroup.id)
  54. .then(this.get.bind(this));
  55. }
  56. openUserGroupModal() {
  57. var modalScope = this.$scope.$new();
  58. modalScope.createUserGroup = this.createUserGroup.bind(this);
  59. this.$scope.appEvent('show-modal', {
  60. src: 'public/app/features/org/partials/create_user_group.html',
  61. modalClass: 'user-group-modal',
  62. scope: modalScope
  63. });
  64. }
  65. }
  66. coreModule.controller('UserGroupsCtrl', UserGroupsCtrl);