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
|
define([
'backbone',
'backbone.marionette',
'./layout',
'./header-view',
'./search-view',
'./list-view',
'./footer-view',
'./controller',
'./router',
'./plugins'
], function (Backbone, Marionette, Layout, HeaderView, SearchView, ListView, FooterView, Controller, Router, Plugins) {
var App = new Marionette.Application(),
init = function (options) {
// State
this.state = new Backbone.Model({
updateCenterActive: window.SS.updateCenterActive
});
// Layout
this.layout = new Layout({ el: options.el });
this.layout.render();
// Plugins
this.plugins = new Plugins();
// Controller
this.controller = new Controller({ collection: this.plugins, state: this.state });
// Router
this.router = new Router({ controller: this.controller });
// Header
this.headerView = new HeaderView({ collection: this.plugins });
this.layout.headerRegion.show(this.headerView);
// Search
this.searchView = new SearchView({ collection: this.plugins, router: this.router, state: this.state });
this.layout.searchRegion.show(this.searchView);
this.searchView.focusSearch();
// List
this.listView = new ListView({ collection: this.plugins });
this.layout.listRegion.show(this.listView);
// Footer
this.footerView = new FooterView({ collection: this.plugins });
this.layout.footerRegion.show(this.footerView);
// Go
Backbone.history.start({
pushState: true,
root: options.urlRoot
});
};
App.on('start', function (options) {
init.call(App, options);
});
return App;
});
|