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
129
|
/*
* 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.
*/
import $ from 'jquery';
import difference from 'lodash/difference';
import Backbone from 'backbone';
import Marionette from 'backbone.marionette';
import State from '../issues/models/state';
import Layout from '../issues/layout';
import Issues from '../issues/models/issues';
import Facets from '../../components/navigator/models/facets';
import Controller from '../issues/controller';
import Router from '../issues/router';
import WorkspaceListView from '../issues/workspace-list-view';
import WorkspaceHeaderView from '../issues/workspace-header-view';
import FacetsView from './../issues/facets-view';
import HeaderView from './../issues/HeaderView';
const App = new Marionette.Application();
const init = function({ el, component, currentUser }) {
this.config = {
resource: component.id,
resourceName: component.name,
resourceQualifier: component.qualifier
};
this.state = new State({
canBulkChange: currentUser.isLoggedIn,
isContext: true,
contextQuery: { componentUuids: this.config.resource },
contextComponentUuid: this.config.resource,
contextComponentName: this.config.resourceName,
contextComponentQualifier: this.config.resourceQualifier
});
this.updateContextFacets();
this.list = new Issues();
this.facets = new Facets();
this.layout = new Layout({ app: this, el });
this.layout.render();
$('#footer').addClass('search-navigator-footer');
this.controller = new Controller({ app: this });
this.issuesView = new WorkspaceListView({
app: this,
collection: this.list
});
this.layout.workspaceListRegion.show(this.issuesView);
this.issuesView.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.headerView = new HeaderView({
app: this
});
this.layout.filtersRegion.show(this.headerView);
key.setScope('list');
App.router = new Router({ app: App });
Backbone.history.start();
};
App.getContextQuery = function() {
return { componentUuids: this.config.resource };
};
App.getRestrictedFacets = function() {
return {
TRK: ['projectUuids'],
BRC: ['projectUuids'],
DIR: ['projectUuids', 'moduleUuids', 'directories'],
DEV: ['authors'],
DEV_PRJ: ['projectUuids', 'authors']
};
};
App.updateContextFacets = function() {
const facets = this.state.get('facets');
const allFacets = this.state.get('allFacets');
const facetsFromServer = this.state.get('facetsFromServer');
return this.state.set({
facets,
allFacets: difference(allFacets, this.getRestrictedFacets()[this.config.resourceQualifier]),
facetsFromServer: difference(
facetsFromServer,
this.getRestrictedFacets()[this.config.resourceQualifier]
)
});
};
App.on('start', options => {
init.call(App, options);
});
export default function(el, component, currentUser) {
App.start({ el, component, currentUser });
return () => {
Backbone.history.stop();
App.layout.destroy();
$('#footer').removeClass('search-navigator-footer');
};
}
|