aboutsummaryrefslogtreecommitdiffstats
path: root/server/sonar-web/src/main/js/components/navigator/workspace-header-view.js
blob: 593fe55ae83806ed1a2c1d8fe9bc7e8bf0472c66 (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
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
import _ from 'underscore';
import Marionette from 'backbone.marionette';

export default Marionette.ItemView.extend({

  collectionEvents: function () {
    return {
      'all': 'shouldRender',
      'limitReached': 'flashPagination'
    };
  },

  events: function () {
    return {
      'click .js-bulk-change': 'onBulkChangeClick',
      'click .js-reload': 'reload',
      'click .js-next': 'selectNext',
      'click .js-prev': 'selectPrev'
    };
  },

  initialize: function (options) {
    this.listenTo(options.app.state, 'change', this.render);
  },

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

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

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

  onBulkChangeClick: function (e) {
    e.preventDefault();
    this.bulkChange();
  },

  bulkChange: function () {

  },

  shouldRender: function (event) {
    if (event !== 'limitReached') {
      this.render();
    }
  },

  reload: function () {
    this.options.app.controller.fetchList();
  },

  selectNext: function () {
    this.options.app.controller.selectNext();
  },

  selectPrev: function () {
    this.options.app.controller.selectPrev();
  },

  flashPagination: function () {
    var flashElement = this.$('.search-navigator-header-pagination');
    flashElement.addClass('in');
    setTimeout(function () {
      flashElement.removeClass('in');
    }, 2000);
  },

  serializeData: function () {
    return _.extend(Marionette.ItemView.prototype.serializeData.apply(this, arguments), {
      state: this.options.app.state.toJSON()
    });
  }
});