aboutsummaryrefslogtreecommitdiffstats
path: root/server/sonar-web/src/main/js/apps/groups/list-item-view.js
blob: c09af127003de32ee49bc00ebb3db4ec7774b011 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
define([
  './update-view',
  './delete-view',
  './users-view',
  './templates'
], function (UpdateView, DeleteView, UsersView) {

  return Marionette.ItemView.extend({
    tagName: 'li',
    className: 'panel panel-vertical',
    template: Templates['groups-list-item'],

    events: {
      'click .js-group-update': 'onUpdateClick',
      'click .js-group-delete': 'onDeleteClick',
      'click .js-group-users': 'onUsersClick'
    },

    onRender: function () {
      this.$el.attr('data-id', this.model.id);
      this.$('[data-toggle="tooltip"]').tooltip({ container: 'body', placement: 'bottom' });
    },

    onDestroy: function () {
      this.$('[data-toggle="tooltip"]').tooltip('destroy');
    },

    onUpdateClick: function (e) {
      e.preventDefault();
      this.updateGroup();
    },

    onDeleteClick: function (e) {
      e.preventDefault();
      this.deleteGroup();
    },

    onUsersClick: function (e) {
      e.preventDefault();
      this.showUsers();
    },

    updateGroup: function () {
      new UpdateView({
        model: this.model,
        collection: this.model.collection
      }).render();
    },

    deleteGroup: function () {
      new DeleteView({ model: this.model }).render();
    },

    showUsers: function () {
      new UsersView({ model: this.model }).render();
    }
  });

});