BootstrapAdmin/Bootstrap.Admin/Content/js/longbow.dataentity.js

44 lines
1.7 KiB
JavaScript
Raw Normal View History

2016-10-20 17:55:29 +08:00
(function ($) {
DataEntity = function (options) {
this.options = $.extend({ map: {} }, options);
};
DataEntity.VERSION = "1.0";
DataEntity.Author = "Argo Zhang";
DataEntity.Email = "argo@163.com";
DataEntity.prototype = {
load: function (value) {
for (name in this.options.map) {
2016-11-08 11:08:10 +08:00
var ctl = $("#" + this.options.map[name]);
if (ctl.hasClass('selectpicker')) ctl.selectpicker('val', value[name]);
else ctl.val(value[name]);
2016-10-20 17:55:29 +08:00
}
},
reset: function () {
for (name in this.options.map) {
2016-11-08 16:31:23 +08:00
var ctl = $("#" + this.options.map[name]);
var dv = ctl.attr("data-default-val");
if (dv === undefined) dv = "";
if (ctl.hasClass('selectpicker')) ctl.selectpicker('val', dv);
else ctl.val(dv);
2016-10-20 17:55:29 +08:00
}
},
get: function () {
var target = {};
for (name in this.options.map) {
2016-11-08 16:31:23 +08:00
var ctl = $("#" + this.options.map[name]);
if (ctl.hasClass('selectpicker')) {
target[name] = ctl.selectpicker('val');
target[name + 'Name'] = ctl.parentsUntil('bootstrap-select').children('button[data-id="' + this.options.map[name] + '"]').attr('title');
}
else {
var dv = ctl.attr('data-default-val');
if (dv !== undefined && ctl.val().trim() === "") target[name] = dv;
else target[name] = ctl.val();
}
2016-10-20 17:55:29 +08:00
}
return target;
}
}
}(jQuery));