You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
147 lines
5.3 KiB
147 lines
5.3 KiB
/**
|
|
* @author zhixin wen <wenzhixin2010@gmail.com>
|
|
* 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 ['<a href="javascript:void(0)"',
|
|
' data-name="' + column.field + '"',
|
|
' data-pk="' + row[that.options.idField] + '"',
|
|
' data-value="' + result + '"',
|
|
editableDataMarkup.join(''),
|
|
'>' + '</a>'
|
|
].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);
|