app/js/component/ui/columns_modal.js
/*
* Copyright 2014 Thoughtworks Inc.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
define([
'flight/lib/component',
'component/templates/column_input_template'
],
function (defineComponent, columnInputTemplate) {
'use strict';
return defineComponent(columnsModal, columnInputTemplate);
function columnsModal() {
this.defaultAttrs({
columnsContainerSeletor: '.columns-container'
})
this.showModal = function () {
this.$node.modal({
backdrop: 'static',
keyboard: false
});
};
this.displayColumns = function (event, data) {
var columns = _.sortBy(data.columns, function (column) {
return Number(column['order']);
});
var that = this;
this.$node.find(this.attr.columnsContainerSeletor).html('');
_.each(columns, function (column) {
var columnInput = that.renderColumnInput(column.column, column.order);
this.append(columnInput);
}, this.$node.find(this.attr.columnsContainerSeletor));
};
this.addNewColumn = function () {
var columnsContainer = this.$node.find(this.attr.columnsContainerSeletor);
var order = columnsContainer.children().length;
columnsContainer.append(this.renderColumnInput('', order));
};
this.saveColumns = function () {
var columnsContainer = this.$node.find(this.attr.columnsContainerSeletor);
var columns = _.chain(columnsContainer.find('input')).
filter(function (input) {
return !_.isEmpty(input.value);
}).
sortBy(function (input) {
return $(input).data('order');
}).
map(function (input, index) {
return {
column: input.value,
order: index
};
}).
value();
$(document).trigger('data:store:columns', [columns]);
$(document).trigger('data:retrieve:columns');
this.$node.modal('hide');
};
this.removeColumn = function (event, column) {
$(column).remove();
};
this.changeColumnsEvents = function () {
$('#changeColumns').click(function () {
$(document).trigger('ui:show:columnsModal');
});
};
this.addColumnEvent = function () {
$('#addColumn').click(function () {
$(document).trigger('ui:show:addColumn');
});
};
this.saveColumnsChanges = function () {
$('#saveColumnsChanges').click(function () {
$(document).trigger('ui:show:saveColumns');
});
};
this.bindRemoveColumnEvents = function () {
$('a.remove-column').click(function () {
$(document).trigger('ui:show:removeColumn', $(this).parent());
});
};
this.setUp = function () {
this.changeColumnsEvents();
this.addColumnEvent();
this.saveColumnsChanges();
};
this.after('initialize', function () {
this.setUp();
this.on(document, 'ui:show:columnsModal', this.showModal.bind(this));
this.on(document, 'ui:show:columnsModal', this.bindRemoveColumnEvents)
this.on(document, 'data:got:columns', this.displayColumns.bind(this));
this.on(document, 'ui:show:addColumn', this.addNewColumn.bind(this));
this.on(document, 'ui:show:saveColumns', this.saveColumns.bind(this));
this.on(document, 'ui:show:removeColumn', this.removeColumn.bind(this));
});
}
});