BootstrapAdmin/Bootstrap.Admin/wwwroot/lib/longbow/longbow.dataentity.js

246 lines
11 KiB
JavaScript
Raw Normal View History

(function ($) {
2018-06-07 00:45:47 +08:00
DataEntity = function (options) {
this.options = options;
2018-06-07 00:45:47 +08:00
};
DataEntity.prototype = {
load: function (value) {
for (name in this.options) {
var ctl = $(this.options[name]);
if (ctl.attr('data-toggle') === "dropdown") {
ctl.val(value[name]).dropdown('val');
2018-06-07 00:45:47 +08:00
}
else if (ctl.attr('data-toggle') === 'toggle') {
2018-06-07 00:45:47 +08:00
ctl.bootstrapToggle(value[name] ? 'on' : 'off');
}
2018-08-05 01:19:34 +08:00
else ctl.val(value[name]);
2018-06-07 00:45:47 +08:00
}
},
reset: function () {
for (name in this.options) {
var ctl = $(this.options[name]);
2018-06-07 00:45:47 +08:00
var dv = ctl.attr("data-default-val");
if (dv === undefined) dv = "";
if (ctl.attr('data-toggle') === "dropdown") {
ctl.val(dv).dropdown('val');
2018-06-07 00:45:47 +08:00
}
else if (ctl.attr('data-toggle') === 'toggle') {
ctl.bootstrapToggle(dv === "true" ? 'on' : 'off');
2018-06-07 00:45:47 +08:00
}
2018-08-05 01:19:34 +08:00
else ctl.val(dv);
2018-06-07 00:45:47 +08:00
}
},
get: function () {
var target = {};
for (name in this.options) {
var ctl = $(this.options[name]);
2018-06-07 00:45:47 +08:00
var dv = ctl.attr('data-default-val');
if (ctl.attr('data-toggle') === 'toggle') {
2018-06-07 00:45:47 +08:00
target[name] = ctl.prop('checked');
continue;
}
else if (dv !== undefined && ctl.val() === "") target[name] = dv;
2018-06-07 00:45:47 +08:00
else target[name] = ctl.val();
if (target[name] === "true" || target[name] === "True") target[name] = true;
if (target[name] === "false" || target[name] === "False") target[name] = false;
2018-06-07 00:45:47 +08:00
}
return target;
}
};
DataTable = function (options) {
var that = this;
this.options = $.extend(true, {}, DataTable.settings, options);
this.dataEntity = new DataEntity(options.map);
// handler click event
for (var name in this.options.click) {
$(name).on('click', { handler: this.options.click[name] }, function (e) {
e.preventDefault();
e.data.handler.call(that, this);
});
}
// handler extra click event
for (var cId in this.options.events) {
$(cId).on('click', { handler: this.options.events[cId] }, function (e) {
var options = that.options;
var row = {};
if (options.bootstrapTable && options.bootstrapTable.constructor === String) {
var arrselections = $(options.bootstrapTable).bootstrapTable('getSelections');
if (arrselections.length === 0) {
lgbSwal({ title: '请选择要编辑的数据', type: "warning" });
return;
}
else if (arrselections.length > 1) {
lgbSwal({ title: '请选择一个要编辑的数据', type: "warning" });
return;
}
else {
row = arrselections[0];
}
}
e.data.handler.call(this, row);
});
}
};
DataTable.settings = {
url: undefined,
bootstrapTable: 'table',
modal: '#dialogNew',
click: {
'#btn_query': function (element) {
if (this.options.bootstrapTable.constructor === String) $(this.options.bootstrapTable).bootstrapTable('refresh');
handlerCallback.call(this, null, element, { oper: 'query' });
},
'#btn_add': function (element) {
this.dataEntity.reset();
if (this.options.modal.constructor === String) $(this.options.modal).modal("show");
if (this.options.bootstrapTable.constructor === String) $(this.options.bootstrapTable).bootstrapTable('uncheckAll');
handlerCallback.call(this, null, element, { oper: 'create' });
},
'#btn_edit': function (element) {
var options = this.options;
var data = {};
if (options.bootstrapTable.constructor === String) {
var arrselections = $(options.bootstrapTable).bootstrapTable('getSelections');
if (arrselections.length === 0) {
lgbSwal({ title: '请选择要编辑的数据', type: "warning" });
return;
}
else if (arrselections.length > 1) {
lgbSwal({ title: '请选择一个要编辑的数据', type: "warning" });
return;
}
else {
data = arrselections[0];
this.dataEntity.load(data);
if (options.modal.constructor === String) $(options.modal).modal("show");
}
}
handlerCallback.call(this, null, element, { oper: 'edit', data: data });
},
'#btn_delete': function (element) {
var that = this;
var options = this.options;
if (options.bootstrapTable.constructor === String) {
var arrselections = $(options.bootstrapTable).bootstrapTable('getSelections');
if (arrselections.length === 0) {
lgbSwal({ title: '请选择要删除的数据', type: "warning" });
return;
}
else {
swal({
title: "删除数据",
text: "您确定要删除选中的所有数据吗",
type: "warning",
showCancelButton: true,
cancelButtonClass: 'btn-secondary',
confirmButtonText: "我要删除",
confirmButtonClass: "btn-danger ml-2",
cancelButtonText: "取消"
}, function () {
$.logData.push({ url: options.url, data: arrselections });
setTimeout(function () {
var iDs = arrselections.map(function (element, index) { return element.Id; });
$.bc({
url: options.url, data: iDs, method: 'delete', title: '删除数据',
callback: function (result) {
if (result) $(options.bootstrapTable).bootstrapTable('refresh');
handlerCallback.call(that, null, element, { oper: 'del', success: result });
}
});
}, 100);
});
}
}
},
'#btnSubmit': function (element) {
var that = this;
var options = $.extend(true, {}, this.options, { data: this.dataEntity.get() });
$.bc({
url: options.url, data: options.data, title: "保存数据", modal: options.modal, method: "post",
callback: function (result) {
if (result) {
$(options.bootstrapTable).bootstrapTable('refresh');
handlerCallback.call(that, null, element, { oper: 'save', success: result, data: options.data });
}
}
});
}
}
};
DataTable.prototype = {
constructor: DataTable,
idEvents: function () {
var op = {
dataEntity: this.dataEntity,
table: this.options.bootstrapTable,
modal: this.options.modal,
src: this,
url: this.options.url
};
var formatData = function (data) {
delete data._nodes;
delete data._parent;
delete data._level;
delete data._last;
};
return {
'click .edit': function (e, value, row, index) {
op.dataEntity.load(row);
$(op.table).bootstrapTable('uncheckAll');
$(op.table).bootstrapTable('check', index);
handlerCallback.call(op.src, null, e, { oper: 'edit', data: row });
$(op.modal).modal("show");
},
'click .del': function (e, value, row, index) {
var text = "您确定要删除 <span class='text-danger font-weight-bold'>" + row.Name + "</span> 吗?";
var data = $.extend({}, row);
formatData(data);
data = [data];
if ($.isArray(row._nodes) && row._nodes.length > 0) {
$.each(row._nodes, function (index, element) {
var ele = $.extend({}, element);
formatData(ele);
data.push(ele);
});
text = "本删除项含有级联子项目</br>您确定要删除 <span class='text-danger font-weight-bold'>" + row.Name + "</span> 以及子项目吗?";
}
swal({
html: true,
title: "删除数据",
text: text,
type: "warning",
showCancelButton: true,
cancelButtonClass: 'btn-secondary',
confirmButtonText: "我要删除",
confirmButtonClass: "btn-danger ml-2",
cancelButtonText: "取消"
}, function () {
$.logData.push({ url: op.url, data: data });
setTimeout(function () {
var iDs = data.map(function (element, index) {
return element.Id;
});
$.bc({
url: op.url, data: iDs, method: 'delete', title: '删除数据',
callback: function (result) {
if (result) $(op.table).bootstrapTable('refresh');
handlerCallback.call(op.src, null, e, { oper: 'del', success: result });
}
});
}, 100);
});
}
};
}
};
function handlerCallback(callback, element, data) {
if ($.isFunction(callback)) callback.call(e, data);
if ($.isFunction(this.options.callback)) this.options.callback.call(element, data);
2018-06-07 00:45:47 +08:00
}
2016-10-20 17:55:29 +08:00
}(jQuery));