2016-10-22 20:55:07 +08:00
|
|
|
|
(function ($) {
|
|
|
|
|
BootstrapAdmin = function (options) {
|
|
|
|
|
var that = this;
|
2016-11-05 15:26:42 +08:00
|
|
|
|
options = options || {};
|
|
|
|
|
options.click = $.extend({}, BootstrapAdmin.settings.click, options.click);
|
2016-10-22 20:55:07 +08:00
|
|
|
|
this.options = $.extend({}, BootstrapAdmin.settings, options);
|
|
|
|
|
|
|
|
|
|
this.dataEntity = options.dataEntity;
|
|
|
|
|
if (!(this.dataEntity instanceof DataEntity) && window.console) {
|
|
|
|
|
window.console.log('初始化参数中没有DataEntity实例');
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// handler click event
|
|
|
|
|
for (name in this.options.click) {
|
2016-10-25 18:47:33 +08:00
|
|
|
|
var ele = this.options.click[name];
|
|
|
|
|
var cId = ele;
|
|
|
|
|
var event = null;
|
|
|
|
|
if ($.isArray(ele)) {
|
|
|
|
|
for (index in ele) {
|
|
|
|
|
if (ele[index].id === undefined) {
|
2016-10-28 21:26:13 +08:00
|
|
|
|
window.console.log('options.click.assign[{0}].{1}.id 未设置控件id', ele[index].id, name);
|
2016-10-25 18:47:33 +08:00
|
|
|
|
continue;
|
|
|
|
|
}
|
|
|
|
|
cId = ele[index]['id'];
|
|
|
|
|
event = ele[index]['click'];
|
|
|
|
|
handler(cId, event);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
else handler(cId, event);
|
2016-10-22 20:55:07 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// handler modal window show event
|
2016-11-10 00:47:23 +08:00
|
|
|
|
if (this.options.modal && this.options.modal.constructor === String) {
|
2016-10-22 20:55:07 +08:00
|
|
|
|
$('#' + this.options.modal).on('show.bs.modal', function (e) {
|
2016-11-17 21:36:02 +08:00
|
|
|
|
if (that.options.validateForm && that.options.validateForm.constructor === String) {
|
2016-11-15 11:39:59 +08:00
|
|
|
|
var v = $('#' + that.options.validateForm);
|
|
|
|
|
var vf = v.validate();
|
|
|
|
|
vf.currentElements.each(function () { $(this).popover('destroy'); })
|
|
|
|
|
vf.resetForm();
|
|
|
|
|
v.find('div.form-group').removeClass("has-error has-success");
|
2016-10-22 20:55:07 +08:00
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
}
|
2016-10-25 18:47:33 +08:00
|
|
|
|
|
|
|
|
|
function handler(cid, event) {
|
|
|
|
|
var source = $("#" + cId);
|
|
|
|
|
source.data('click', name);
|
|
|
|
|
if (event !== null) source.data('event', event);
|
|
|
|
|
source.click(function () {
|
2016-11-15 14:31:53 +08:00
|
|
|
|
var method = source.data('click');
|
|
|
|
|
BootstrapAdmin.prototype[method].call(that, this, source.data('event'));
|
2016-10-25 18:47:33 +08:00
|
|
|
|
});
|
|
|
|
|
}
|
2016-10-22 20:55:07 +08:00
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
BootstrapAdmin.VERSION = "1.0";
|
|
|
|
|
BootstrapAdmin.Author = "Argo Zhang";
|
|
|
|
|
BootstrapAdmin.Email = "argo@163.com";
|
|
|
|
|
|
|
|
|
|
BootstrapAdmin.settings = {
|
|
|
|
|
url: undefined,
|
|
|
|
|
bootstrapTable: 'table',
|
|
|
|
|
validateForm: 'dataForm',
|
|
|
|
|
modal: 'dialogNew',
|
2016-10-24 20:53:05 +08:00
|
|
|
|
click: {
|
|
|
|
|
query: 'btn_query',
|
|
|
|
|
create: 'btn_add',
|
|
|
|
|
edit: 'btn_edit',
|
|
|
|
|
del: 'btn_delete',
|
2016-10-25 18:47:33 +08:00
|
|
|
|
save: 'btnSubmit',
|
|
|
|
|
assign: []
|
2016-10-24 20:53:05 +08:00
|
|
|
|
}
|
|
|
|
|
};
|
2016-10-22 20:55:07 +08:00
|
|
|
|
|
|
|
|
|
BootstrapAdmin.idFormatter = function (value, row, index) {
|
|
|
|
|
return "<a class='edit' href='javascript:void(0)'>" + value + "</a>";
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
BootstrapAdmin.prototype = {
|
|
|
|
|
constructor: BootstrapAdmin,
|
2016-10-24 19:12:22 +08:00
|
|
|
|
idEvents: function () {
|
|
|
|
|
var op = {
|
2016-10-25 18:47:33 +08:00
|
|
|
|
dataEntity: $.extend({}, this.options.dataEntity),
|
2016-10-24 19:12:22 +08:00
|
|
|
|
table: this.options.bootstrapTable,
|
|
|
|
|
modal: this.options.modal
|
|
|
|
|
};
|
|
|
|
|
return {
|
|
|
|
|
'click .edit': function (e, value, row, index) {
|
|
|
|
|
op.dataEntity.load(row);
|
2016-10-25 18:47:33 +08:00
|
|
|
|
$(op.table).bootstrapTable('uncheckAll');
|
|
|
|
|
$(op.table).bootstrapTable('check', index);
|
2016-10-24 19:12:22 +08:00
|
|
|
|
$('#' + op.modal).modal("show");
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
},
|
2016-10-22 20:55:07 +08:00
|
|
|
|
|
2016-11-15 14:31:53 +08:00
|
|
|
|
query: function (e, callback) {
|
2016-10-22 20:55:07 +08:00
|
|
|
|
if (this.options.bootstrapTable.constructor === String) $(this.options.bootstrapTable).bootstrapTable('refresh');
|
2016-11-15 14:31:53 +08:00
|
|
|
|
handlerCallback.call(this, callback, e, { oper: 'query' });
|
2016-10-22 20:55:07 +08:00
|
|
|
|
},
|
|
|
|
|
|
2016-11-15 14:31:53 +08:00
|
|
|
|
create: function (e, callback) {
|
2016-10-25 18:47:33 +08:00
|
|
|
|
if (this.dataEntity instanceof DataEntity) this.dataEntity.reset();
|
2016-10-22 20:55:07 +08:00
|
|
|
|
if (this.options.modal.constructor === String) $('#' + this.options.modal).modal("show");
|
|
|
|
|
if (this.options.bootstrapTable.constructor === String) $(this.options.bootstrapTable).bootstrapTable('uncheckAll');
|
2016-11-15 14:31:53 +08:00
|
|
|
|
handlerCallback.call(this, callback, e, { oper: 'create' });
|
2016-10-22 20:55:07 +08:00
|
|
|
|
},
|
|
|
|
|
|
2016-11-15 14:31:53 +08:00
|
|
|
|
edit: function (e, callback) {
|
2016-10-25 18:47:33 +08:00
|
|
|
|
var options = this.options;
|
2016-11-15 14:31:53 +08:00
|
|
|
|
var data = {};
|
|
|
|
|
if (options.bootstrapTable.constructor === String) {
|
|
|
|
|
var arrselections = $(options.bootstrapTable).bootstrapTable('getSelections');
|
|
|
|
|
if (arrselections.length == 0) {
|
|
|
|
|
swal('请选择要编辑的数据', "编辑操作", "warning");
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
else if (arrselections.length > 1) {
|
|
|
|
|
swal('请选择一个要编辑的数据', "编辑操作", "warning");
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
else {
|
|
|
|
|
data = arrselections[0];
|
|
|
|
|
if (this.dataEntity instanceof DataEntity) this.dataEntity.load(data);
|
|
|
|
|
if (options.modal.constructor === String) $('#' + options.modal).modal("show");
|
|
|
|
|
}
|
2016-10-22 20:55:07 +08:00
|
|
|
|
}
|
2016-11-15 14:31:53 +08:00
|
|
|
|
handlerCallback.call(this, callback, e, { oper: 'edit', data: data });
|
2016-10-22 20:55:07 +08:00
|
|
|
|
},
|
|
|
|
|
|
2016-11-15 14:31:53 +08:00
|
|
|
|
del: function (e, callback) {
|
|
|
|
|
var that = this;
|
2016-10-22 20:55:07 +08:00
|
|
|
|
var options = this.options;
|
2016-11-15 14:31:53 +08:00
|
|
|
|
if (options.bootstrapTable.constructor === String) {
|
|
|
|
|
var arrselections = $(options.bootstrapTable).bootstrapTable('getSelections');
|
|
|
|
|
if (arrselections.length == 0) {
|
|
|
|
|
swal('请选择要删除的数据', "删除操作", "warning");
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
else {
|
|
|
|
|
swal({
|
|
|
|
|
title: "您确定要删除吗?",
|
|
|
|
|
text: "删除操作",
|
|
|
|
|
type: "warning",
|
|
|
|
|
showCancelButton: true,
|
|
|
|
|
closeOnConfirm: true,
|
|
|
|
|
confirmButtonText: "是的,我要删除",
|
|
|
|
|
confirmButtonColor: "#d9534f",
|
|
|
|
|
cancelButtonText: "取消"
|
|
|
|
|
}, function () {
|
2016-11-19 10:40:28 +08:00
|
|
|
|
setTimeout(function () {
|
|
|
|
|
var iDs = arrselections.map(function (element, index) { return element.ID }).join(",");
|
|
|
|
|
options.IDs = iDs;
|
|
|
|
|
$.bc({
|
|
|
|
|
url: options.url, data: { "": iDs }, method: 'DELETE', title: '删除数据',
|
|
|
|
|
callback: function (result) {
|
|
|
|
|
if ($.isPlainObject(result)) {
|
|
|
|
|
var info = result.result ? "success" : "error";
|
|
|
|
|
var msg = result.msg
|
|
|
|
|
swal(msg, "删除数据", info);
|
|
|
|
|
result = result.result;
|
|
|
|
|
this.swal = false;
|
|
|
|
|
}
|
|
|
|
|
if (result) $(options.bootstrapTable).bootstrapTable('refresh');
|
|
|
|
|
handlerCallback.call(that, callback, e, { oper: 'del', success: result });
|
2016-11-17 20:01:28 +08:00
|
|
|
|
}
|
2016-11-19 10:40:28 +08:00
|
|
|
|
});
|
|
|
|
|
}, 100);
|
2016-10-22 20:55:07 +08:00
|
|
|
|
});
|
2016-11-15 14:31:53 +08:00
|
|
|
|
}
|
2016-10-22 20:55:07 +08:00
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
|
2016-11-15 14:31:53 +08:00
|
|
|
|
save: function (e, callback) {
|
|
|
|
|
var that = this;
|
2016-10-25 18:47:33 +08:00
|
|
|
|
var options = $.extend({ data: {} }, this.options);
|
|
|
|
|
if (this.dataEntity instanceof DataEntity) options = $.extend(options, { data: this.dataEntity.get() });
|
2016-10-22 20:55:07 +08:00
|
|
|
|
if (options.validateForm.constructor === String && !$("#" + options.validateForm).valid()) return;
|
2016-11-18 22:53:56 +08:00
|
|
|
|
$.bc({
|
|
|
|
|
url: options.url, data: options.data, title: "保存数据", modal: options.modal,
|
|
|
|
|
callback: function (result) {
|
2016-11-15 14:31:53 +08:00
|
|
|
|
var finalData = null;
|
|
|
|
|
var index = 0;
|
2016-10-22 20:55:07 +08:00
|
|
|
|
if (result) {
|
|
|
|
|
if (options.bootstrapTable.constructor === String && options.data.ID.constructor === String) {
|
|
|
|
|
// 更新表格
|
|
|
|
|
if (options.data.ID > 0) {
|
|
|
|
|
var allTableData = $(options.bootstrapTable).bootstrapTable('getData');
|
|
|
|
|
for (index = 0; index < allTableData.length; index++) {
|
2016-11-15 14:31:53 +08:00
|
|
|
|
finalData = allTableData[index];
|
|
|
|
|
if (finalData.ID == options.data.ID) {
|
|
|
|
|
$(options.bootstrapTable).bootstrapTable('updateRow', { index: index, row: $.extend(finalData, options.data) });
|
2016-10-22 20:55:07 +08:00
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
else {
|
|
|
|
|
$(options.bootstrapTable).bootstrapTable('refresh');
|
2016-11-15 14:31:53 +08:00
|
|
|
|
finalData = options.data;
|
2016-10-22 20:55:07 +08:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
2016-11-18 22:53:56 +08:00
|
|
|
|
handlerCallback.call(that, callback, e, { oper: 'save', success: result, index: index, data: finalData });
|
2016-10-22 20:55:07 +08:00
|
|
|
|
}
|
|
|
|
|
});
|
2016-10-25 18:47:33 +08:00
|
|
|
|
},
|
|
|
|
|
|
2016-11-15 14:31:53 +08:00
|
|
|
|
assign: function (e, callback) {
|
2016-10-25 18:47:33 +08:00
|
|
|
|
var options = this.options;
|
2016-11-10 00:47:23 +08:00
|
|
|
|
var row = {};
|
|
|
|
|
if (options.bootstrapTable && options.bootstrapTable.constructor === String) {
|
|
|
|
|
var arrselections = $(options.bootstrapTable).bootstrapTable('getSelections');
|
|
|
|
|
if (arrselections.length == 0) {
|
|
|
|
|
swal('请选择要编辑的数据', "编辑操作", "warning");
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
else if (arrselections.length > 1) {
|
|
|
|
|
swal('请选择一个要编辑的数据', "编辑操作", "warning");
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
else {
|
|
|
|
|
row = arrselections[0];
|
2016-10-25 18:47:33 +08:00
|
|
|
|
}
|
|
|
|
|
}
|
2016-11-15 14:31:53 +08:00
|
|
|
|
var data = options.dataEntity;
|
|
|
|
|
if (data instanceof DataEntity) data = data.get();
|
|
|
|
|
if ($.isFunction(callback)) callback.call(e, row, $.extend({}, data));
|
|
|
|
|
if ($.isFunction(this.options.callback)) this.options.callback.call(e, { oper: 'assign', row: row, data: data });
|
|
|
|
|
}
|
2016-10-25 18:47:33 +08:00
|
|
|
|
};
|
|
|
|
|
|
2016-11-18 20:49:44 +08:00
|
|
|
|
var handlerCallback = function (callback, e, data) {
|
|
|
|
|
if ($.isFunction(callback)) callback.call(e, data);
|
|
|
|
|
if ($.isFunction(this.options.callback)) this.options.callback.call(e, data);
|
|
|
|
|
}
|
2016-11-02 15:11:09 +08:00
|
|
|
|
|
2016-11-09 00:34:47 +08:00
|
|
|
|
|
2016-11-18 20:49:44 +08:00
|
|
|
|
$.extend({
|
|
|
|
|
bc: function (options, callback) {
|
|
|
|
|
var data = $.extend({
|
|
|
|
|
remote: true,
|
|
|
|
|
Id: "",
|
|
|
|
|
url: this.url,
|
|
|
|
|
data: {},
|
|
|
|
|
method: "POST",
|
|
|
|
|
htmlTemplate: '<div class="form-group checkbox col-lg-3 col-xs-4"><label class="tooltips" data-placement="top" data-original-title="{3}" title="{3}"><input type="checkbox" value="{0}" {2}/>{1}</label></div>',
|
|
|
|
|
title: this.title,
|
|
|
|
|
swal: true,
|
|
|
|
|
modal: null,
|
|
|
|
|
callback: null
|
|
|
|
|
}, options);
|
2016-11-09 00:34:47 +08:00
|
|
|
|
|
2016-11-18 20:49:44 +08:00
|
|
|
|
if (!data.url || data.url == "") {
|
|
|
|
|
swal('参数错误', '未设置请求地址Url', 'error');
|
|
|
|
|
return;
|
2016-11-09 00:34:47 +08:00
|
|
|
|
}
|
2016-11-18 20:49:44 +08:00
|
|
|
|
|
|
|
|
|
if (data.remote && data.url) {
|
|
|
|
|
$.ajax({
|
|
|
|
|
url: data.url + data.Id,
|
|
|
|
|
data: data.data,
|
|
|
|
|
type: data.method,
|
|
|
|
|
success: function (result) {
|
|
|
|
|
success(result);
|
|
|
|
|
},
|
|
|
|
|
error: function (XMLHttpRequest, textStatus, errorThrown) {
|
|
|
|
|
if ($.isFunction(data.callback)) data.callback(false);
|
|
|
|
|
}
|
|
|
|
|
});
|
2016-11-09 00:34:47 +08:00
|
|
|
|
}
|
2016-11-18 20:49:44 +08:00
|
|
|
|
function success(result) {
|
|
|
|
|
if ($.isFunction(data.callback)) {
|
|
|
|
|
data.callback(result);
|
|
|
|
|
}
|
|
|
|
|
if (data.modal !== null) {
|
|
|
|
|
$("#" + data.modal).modal('hide');
|
|
|
|
|
}
|
|
|
|
|
if (data.swal) {
|
2016-11-19 10:40:28 +08:00
|
|
|
|
if (result) { swal("成功", data.title, "success"); }
|
|
|
|
|
else { swal("失败", data.title, "error"); }
|
2016-11-18 20:49:44 +08:00
|
|
|
|
}
|
2016-10-25 18:47:33 +08:00
|
|
|
|
}
|
2016-11-09 00:34:47 +08:00
|
|
|
|
}
|
2016-11-18 20:49:44 +08:00
|
|
|
|
});
|
2016-11-18 11:58:54 +08:00
|
|
|
|
|
2016-11-15 18:44:54 +08:00
|
|
|
|
// Roles
|
2016-11-02 15:11:09 +08:00
|
|
|
|
Role = {
|
2016-11-09 00:34:47 +08:00
|
|
|
|
url: '../api/Roles/',
|
2016-11-18 20:49:44 +08:00
|
|
|
|
title: "授权角色"
|
2016-10-28 11:12:25 +08:00
|
|
|
|
};
|
2016-11-18 20:49:44 +08:00
|
|
|
|
|
2016-11-02 15:11:09 +08:00
|
|
|
|
// Users
|
|
|
|
|
User = {
|
2016-11-09 00:34:47 +08:00
|
|
|
|
url: '../api/Users/',
|
2016-11-18 20:49:44 +08:00
|
|
|
|
title: "授权用户"
|
2016-11-18 10:18:41 +08:00
|
|
|
|
};
|
2016-11-18 20:49:44 +08:00
|
|
|
|
|
2016-11-02 15:11:09 +08:00
|
|
|
|
// Groups
|
|
|
|
|
Group = {
|
2016-11-09 00:34:47 +08:00
|
|
|
|
url: '../api/Groups/',
|
2016-11-18 20:49:44 +08:00
|
|
|
|
title: "授权部门"
|
2016-10-29 09:24:55 +08:00
|
|
|
|
};
|
2016-11-15 18:44:54 +08:00
|
|
|
|
|
|
|
|
|
// Menus
|
2016-11-07 21:41:17 +08:00
|
|
|
|
Menu = {
|
2016-11-09 00:34:47 +08:00
|
|
|
|
url: '../api/Menus/',
|
2016-11-18 20:49:44 +08:00
|
|
|
|
title: "授权菜单"
|
2016-11-07 21:41:17 +08:00
|
|
|
|
};
|
2016-11-15 18:44:54 +08:00
|
|
|
|
|
|
|
|
|
// Exceptions
|
|
|
|
|
Exceptions = {
|
|
|
|
|
url: '../api/Exceptions/',
|
2016-11-18 20:49:44 +08:00
|
|
|
|
title: "程序异常日志"
|
2016-11-18 10:18:41 +08:00
|
|
|
|
};
|
2016-11-17 20:01:28 +08:00
|
|
|
|
|
|
|
|
|
// Dicts
|
|
|
|
|
Dicts = {
|
|
|
|
|
url: '../api/Dicts/'
|
2016-11-18 10:18:41 +08:00
|
|
|
|
};
|
2016-11-18 20:49:44 +08:00
|
|
|
|
|
|
|
|
|
// Infos
|
|
|
|
|
Infos = {
|
|
|
|
|
url: '../api/Infos/'
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Profiles
|
|
|
|
|
Profiles = {
|
|
|
|
|
url: '../api/Profiles/',
|
|
|
|
|
title: '网站设置'
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Messages
|
|
|
|
|
Messages = {
|
|
|
|
|
url: '../api/Messages/'
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Tasks
|
|
|
|
|
Tasks = {
|
|
|
|
|
url: '../api/Tasks/'
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Notifications
|
|
|
|
|
Notifications = {
|
|
|
|
|
url: '../api/Notifications/'
|
|
|
|
|
}
|
2016-10-20 17:55:29 +08:00
|
|
|
|
})(jQuery);
|