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'); return Marionette.LayoutView.extend({ template: _.template(tpl), templateHelpers: function() { return { filterValue: this.filterValue } }, regions: { availableView: "#available", rotationView: "#rotation", }, events: { "keyup #filterMissions": "updateFilter", }, modelEvents: { "change": "serverUpdated", }, initialize: function (options) { this.missions = options.missions; this.filterValue = '' this.rotationCollection = new MissionRotations(this.model.get('missions')); var self = this; this.availableListView = new AvailableListView({collection: this.missions, filterValue: this.filterValue}); this.availableListView.on('add', function (model) { self.rotationCollection.add([{ name: model.get('name').replace('.pbo', ''), }]); }); this.rotationListView = new RotationListView({collection: this.rotationCollection}); }, onRender: function() { this.availableView.show(this.availableListView); this.rotationView.show(this.rotationListView); }, updateFilter: function (event) { this.filterValue = event.target.value; this.availableView.currentView.filterValue = this.filterValue; this.availableView.currentView.render(); }, serverUpdated: function() { this.rotationCollection.set(this.model.get('missions')); }, serialize : function() { return { missions: this.rotationCollection.toJSON(), }; }, }); });