2015-08-23 22:16:16 +00:00
|
|
|
define(function (require) {
|
|
|
|
|
|
|
|
"use strict";
|
|
|
|
|
|
|
|
var $ = require('jquery'),
|
|
|
|
_ = require('underscore'),
|
|
|
|
Backbone = require('backbone'),
|
|
|
|
Marionette = require('marionette'),
|
|
|
|
MissionRotations = require('app/collections/mission_rotations'),
|
|
|
|
AvailableListView = require('app/views/servers/missions/available/list'),
|
|
|
|
RotationListView = require('app/views/servers/missions/rotation/list'),
|
|
|
|
tpl = require('text!tpl/servers/missions/index.html');
|
|
|
|
|
2017-10-05 20:55:57 +00:00
|
|
|
return Marionette.LayoutView.extend({
|
2015-08-23 22:16:16 +00:00
|
|
|
template: _.template(tpl),
|
2019-06-23 18:32:04 +00:00
|
|
|
templateHelpers: function() {
|
|
|
|
return {
|
|
|
|
filterValue: this.filterValue
|
|
|
|
}
|
|
|
|
},
|
2015-08-23 22:16:16 +00:00
|
|
|
|
|
|
|
regions: {
|
|
|
|
availableView: "#available",
|
|
|
|
rotationView: "#rotation",
|
|
|
|
},
|
|
|
|
|
2019-06-23 18:32:04 +00:00
|
|
|
events: {
|
|
|
|
"keyup #filterMissions": "updateFilter",
|
|
|
|
},
|
|
|
|
|
2015-09-19 22:04:22 +00:00
|
|
|
modelEvents: {
|
|
|
|
"change": "serverUpdated",
|
|
|
|
},
|
|
|
|
|
2015-08-23 22:16:16 +00:00
|
|
|
initialize: function (options) {
|
|
|
|
this.missions = options.missions;
|
2019-06-23 18:32:04 +00:00
|
|
|
this.filterValue = ''
|
2015-08-23 22:16:16 +00:00
|
|
|
|
2015-09-19 22:04:22 +00:00
|
|
|
this.rotationCollection = new MissionRotations(this.model.get('missions'));
|
2015-08-23 22:16:16 +00:00
|
|
|
|
|
|
|
var self = this;
|
|
|
|
|
2019-06-23 18:32:04 +00:00
|
|
|
this.availableListView = new AvailableListView({collection: this.missions, filterValue: this.filterValue});
|
2015-09-19 22:04:22 +00:00
|
|
|
this.availableListView.on('add', function (model) {
|
2015-08-23 22:16:16 +00:00
|
|
|
self.rotationCollection.add([{
|
|
|
|
name: model.get('name').replace('.pbo', ''),
|
|
|
|
}]);
|
|
|
|
});
|
2015-09-19 22:04:22 +00:00
|
|
|
this.rotationListView = new RotationListView({collection: this.rotationCollection});
|
|
|
|
},
|
|
|
|
|
|
|
|
onRender: function() {
|
|
|
|
this.availableView.show(this.availableListView);
|
|
|
|
this.rotationView.show(this.rotationListView);
|
|
|
|
},
|
2015-08-23 22:16:16 +00:00
|
|
|
|
2019-06-23 18:32:04 +00:00
|
|
|
updateFilter: function (event) {
|
|
|
|
this.filterValue = event.target.value;
|
|
|
|
this.availableView.currentView.filterValue = this.filterValue;
|
|
|
|
this.availableView.currentView.render();
|
|
|
|
},
|
|
|
|
|
2015-09-19 22:04:22 +00:00
|
|
|
serverUpdated: function() {
|
|
|
|
this.rotationCollection.set(this.model.get('missions'));
|
2015-08-23 22:16:16 +00:00
|
|
|
},
|
|
|
|
|
|
|
|
serialize : function() {
|
|
|
|
return {
|
|
|
|
missions: this.rotationCollection.toJSON(),
|
|
|
|
};
|
|
|
|
},
|
|
|
|
});
|
|
|
|
});
|