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]);
|
2016-11-09 14:48:21 +08:00
|
|
|
|
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]);
|
2016-11-08 17:13:05 +08:00
|
|
|
|
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');
|
|
|
|
|
}
|
2016-11-09 14:48:21 +08:00
|
|
|
|
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));
|