aboutsummaryrefslogtreecommitdiffstats
path: root/server/sonar-web/src/main/js/apps/update-center/list-item-view.js
blob: 2287e41e6156c76a61f29a57420336831e7d9a97 (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
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
/*
 * SonarQube
 * Copyright (C) 2009-2016 SonarSource SA
 * mailto:contact AT sonarsource DOT com
 *
 * This program is free software; you can redistribute it and/or
 * modify it under the terms of the GNU Lesser General Public
 * License as published by the Free Software Foundation; either
 * version 3 of the License, or (at your option) any later version.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 * Lesser General Public License for more details.
 *
 * You should have received a copy of the GNU Lesser General Public License
 * along with this program; if not, write to the Free Software Foundation,
 * Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA.
 */
import $ from 'jquery';
import Backbone from 'backbone';
import Marionette from 'backbone.marionette';
import PluginChangelogView from './plugin-changelog-view';
import Template from './templates/update-center-plugin.hbs';
import SystemTemplate from './templates/update-center-system-update.hbs';

export default Marionette.ItemView.extend({
  tagName: 'li',
  className: 'panel panel-vertical',
  template: Template,
  systemTemplate: SystemTemplate,

  modelEvents: {
    'change:_hidden': 'toggleDisplay',
    'change': 'onModelChange',
    'request': 'onRequest'
  },

  events: {
    'click .js-changelog': 'onChangelogClick',
    'click .js-install': 'install',
    'click .js-update': 'update',
    'click .js-uninstall': 'uninstall',
    'change .js-terms': 'onTermsChange',
    'click .js-plugin-category': 'onCategoryClick'
  },

  getTemplate: function () {
    return this.model.get('_system') ? this.systemTemplate : this.template;
  },

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

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

  onModelChange: function () {
    if (!this.model.hasChanged('_hidden')) {
      this.render();
    }
  },

  onChangelogClick: function (e) {
    e.preventDefault();
    e.stopPropagation();
    $('body').click();
    var index = $(e.currentTarget).data('idx'),
    // if show changelog of update, show details of this update
    // otherwise show changelog of the available release
        update = this.model.has('release') ? this.model.toJSON() : this.model.get('updates')[index],
        popup = new PluginChangelogView({
          triggerEl: $(e.currentTarget),
          model: new Backbone.Model(update)
        });
    popup.render();
  },

  onRequest: function () {
    this.$('.js-actions').addClass('hidden');
    this.$('.js-spinner').removeClass('hidden');
  },

  toggleDisplay: function () {
    this.$el.toggleClass('hidden', this.model.get('_hidden'));
  },

  install: function () {
    this.model.install();
  },

  update: function () {
    this.model.update();
  },

  uninstall: function () {
    this.model.uninstall();
  },

  onTermsChange: function () {
    var isAccepted = this.$('.js-terms').is(':checked');
    this.$('.js-install').prop('disabled', !isAccepted);
  },

  onCategoryClick: function (e) {
    e.preventDefault();
    this.model.trigger('filter', this.model);
  }
});