/** * @author zhixin wen * extensions: https://github.com/vitalets/x-editable */ (function($) { 'use strict'; $.extend($.fn.bootstrapTable.defaults, { editable: true, onEditableInit: function() { return false; }, onEditableSave: function(field, row, oldValue, $el) { return false; }, onEditableShown: function(field, row, $el, editable) { return false; }, onEditableHidden: function(field, row, $el, reason) { return false; } }); $.extend($.fn.bootstrapTable.Constructor.EVENTS, { 'editable-init.bs.table': 'onEditableInit', 'editable-save.bs.table': 'onEditableSave', 'editable-shown.bs.table': 'onEditableShown', 'editable-hidden.bs.table': 'onEditableHidden' }); var BootstrapTable = $.fn.bootstrapTable.Constructor, _initTable = BootstrapTable.prototype.initTable, _initBody = BootstrapTable.prototype.initBody; BootstrapTable.prototype.initTable = function() { var that = this; _initTable.apply(this, Array.prototype.slice.apply(arguments)); if (!this.options.editable) { return; } $.each(this.columns, function(i, column) { if (!column.editable) { return; } var editableOptions = {}, editableDataMarkup = [], editableDataPrefix = 'editable-'; var processDataOptions = function(key, value) { // Replace camel case with dashes. var dashKey = key.replace(/([A-Z])/g, function($1) { return "-" + $1.toLowerCase(); }); if (dashKey.slice(0, editableDataPrefix.length) == editableDataPrefix) { var dataKey = dashKey.replace(editableDataPrefix, 'data-'); editableOptions[dataKey] = value; } }; $.each(that.options, processDataOptions); column.formatter = column.formatter || function(value, row, index) { return value; }; column._formatter = column._formatter ? column._formatter : column.formatter; column.formatter = function(value, row, index) { var result = column._formatter ? column._formatter(value, row, index) : value; $.each(column, processDataOptions); $.each(editableOptions, function(key, value) { editableDataMarkup.push(' ' + key + '="' + value + '"'); }); var _dont_edit_formatter = false; if (column.editable.hasOwnProperty('noeditFormatter')) { _dont_edit_formatter = column.editable.noeditFormatter(value, row, index); } if (_dont_edit_formatter === false) { return ['' + '' ].join(''); } else { return _dont_edit_formatter; } }; }); }; BootstrapTable.prototype.initBody = function() { var that = this; _initBody.apply(this, Array.prototype.slice.apply(arguments)); if (!this.options.editable) { return; } $.each(this.columns, function(i, column) { if (!column.editable) { return; } that.$body.find('a[data-name="' + column.field + '"]').editable(column.editable) .off('save').on('save', function(e, params) { var data = that.getData(), index = $(this).parents('tr[data-index]').data('index'), row = data[index], oldValue = row[column.field]; $(this).data('value', params.submitValue); row[column.field] = params.submitValue; that.trigger('editable-save', column.field, row, oldValue, $(this)); that.resetFooter(); }); that.$body.find('a[data-name="' + column.field + '"]').editable(column.editable) .off('shown').on('shown', function(e, editable) { var data = that.getData(), index = $(this).parents('tr[data-index]').data('index'), row = data[index]; that.trigger('editable-shown', column.field, row, $(this), editable); }); that.$body.find('a[data-name="' + column.field + '"]').editable(column.editable) .off('hidden').on('hidden', function(e, reason) { var data = that.getData(), index = $(this).parents('tr[data-index]').data('index'), row = data[index]; that.trigger('editable-hidden', column.field, row, $(this), reason); }); }); this.trigger('editable-init'); }; })(jQuery);