aboutsummaryrefslogtreecommitdiffstats
path: root/server/sonar-web/src/main/js/apps/coding-rules/init.js
blob: 36d7f608fdaebcb626d7e275e2785e388c591084 (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
118
119
120
121
122
123
124
125
126
127
128
/*
 * SonarQube
 * Copyright (C) 2009-2017 SonarSource SA
 * mailto:info 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.
 */
// @flow
import $ from 'jquery';
import { sortBy } from 'lodash';
import Backbone from 'backbone';
import Marionette from 'backbone.marionette';
import key from 'keymaster';
import State from './models/state';
import Layout from './layout';
import Rules from './models/rules';
import Facets from '../../components/navigator/models/facets';
import Controller from './controller';
import Router from '../../components/navigator/router';
import WorkspaceListView from './workspace-list-view';
import WorkspaceHeaderView from './workspace-header-view';
import FacetsView from './facets-view';
import { areThereCustomOrganizations } from '../../store/organizations/utils';

const App = new Marionette.Application();

App.on('start', function(
  options /*: {
  el: HTMLElement,
  organization: ?string,
  isDefaultOrganization: boolean
} */
) {
  App.organization = options.organization;
  const data = options.organization ? { organization: options.organization } : {};
  $.get(window.baseUrl + '/api/rules/app', data)
    .done(r => {
      App.customRules = !areThereCustomOrganizations();
      App.canWrite = r.canWrite;
      App.organization = options.organization;
      App.qualityProfiles = sortBy(r.qualityprofiles, ['name', 'lang']);
      App.languages = { ...r.languages, none: 'None' };
      App.qualityProfiles.forEach(profile => {
        profile.language = App.languages[profile.lang];
      });
      App.repositories = r.repositories;
      App.statuses = r.statuses;
    })
    .done(() => {
      this.layout = new Layout({ el: options.el });
      this.layout.render();
      $('#footer').addClass('page-footer-with-sidebar');

      const allFacets = [
        'q',
        'rule_key',
        'languages',
        'types',
        'tags',
        'repositories',
        'severities',
        'statuses',
        'available_since',
        App.customRules ? 'is_template' : null,
        'qprofile',
        'inheritance',
        'active_severities'
      ].filter(f => f != null);

      this.state = new State({ allFacets });
      this.list = new Rules();
      this.facets = new Facets();

      this.controller = new Controller({ app: this });

      this.workspaceListView = new WorkspaceListView({
        app: this,
        collection: this.list
      });
      this.layout.workspaceListRegion.show(this.workspaceListView);
      this.workspaceListView.bindScrollEvents();

      this.workspaceHeaderView = new WorkspaceHeaderView({
        app: this,
        collection: this.list
      });
      this.layout.workspaceHeaderRegion.show(this.workspaceHeaderView);

      this.facetsView = new FacetsView({
        app: this,
        collection: this.facets
      });
      this.layout.facetsRegion.show(this.facetsView);

      key.setScope('list');
      this.router = new Router({
        app: this
      });
      Backbone.history.start();
    });
});

export default function(
  el /*: HTMLElement */,
  organization /*: ?string */,
  isDefaultOrganization /*: boolean */
) {
  App.start({ el, organization, isDefaultOrganization });

  return () => {
    // $FlowFixMe
    Backbone.history.stop();
    App.layout.destroy();
    $('#footer').removeClass('page-footer-with-sidebar');
  };
}