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
|
/*
* 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 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 FiltersView from './filters-view';
const App = new Marionette.Application();
App.on('start', function(options: {
el: HTMLElement,
organization: ?string,
isDefaultOrganization: boolean
}) {
const data = options.organization ? { organization: options.organization } : {};
$.get(window.baseUrl + '/api/rules/app', data)
.done(r => {
App.customRules = options.organization == null || options.isDefaultOrganization;
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('search-navigator-footer');
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);
this.filtersView = new FiltersView({
app: this
});
this.layout.filtersRegion.show(this.filtersView);
window.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('search-navigator-footer');
};
}
|