465 lines
18 KiB
JavaScript
465 lines
18 KiB
JavaScript
(function ($) {
|
||
// 增加Array扩展
|
||
if (!$.isFunction(Array.prototype.filter)) {
|
||
Array.prototype.filter = function (callback, thisObject) {
|
||
if ($.isFunction(callback)) {
|
||
var res = new Array();
|
||
for (var i = 0; i < this.length; i++) {
|
||
callback.call(thisObject, this[i], i, this) && res.push(this[i]);
|
||
}
|
||
return res;
|
||
}
|
||
};
|
||
}
|
||
|
||
// 增加String扩展
|
||
if (!$.isFunction(String.prototype.trim)) {
|
||
String.prototype.trim = function () {
|
||
if (this === null) return "";
|
||
var trimLeft = /^\s+/, trimRight = /\s+$/;
|
||
return this.replace(trimLeft, "").replace(trimRight, "");
|
||
};
|
||
}
|
||
|
||
// 扩展Date
|
||
if (!$.isFunction(Date.prototype.format)) {
|
||
Date.prototype.format = function (format) {
|
||
var o = {
|
||
"M+": this.getMonth() + 1,
|
||
"d+": this.getDate(),
|
||
"h+": this.getHours() % 12 === 0 ? 12 : this.getHours() % 12,
|
||
"H+": this.getHours(),
|
||
"m+": this.getMinutes(),
|
||
"s+": this.getSeconds(),
|
||
"q+": Math.floor((this.getMonth() + 3) / 3),
|
||
"S": this.getMilliseconds()
|
||
};
|
||
var week = {
|
||
0: "日",
|
||
1: "一",
|
||
2: "二",
|
||
3: "三",
|
||
4: "四",
|
||
5: "五",
|
||
6: "六"
|
||
};
|
||
|
||
if (/(y+)/.test(format))
|
||
format = format.replace(RegExp.$1, (this.getFullYear() + "").substr(4 - RegExp.$1.length));
|
||
|
||
if (/(E+)/.test(format))
|
||
format = format.replace(RegExp.$1, (RegExp.$1.length > 1 ? RegExp.$1.length > 2 ? "星期" : "周" : "") + week[this.getDay()]);
|
||
|
||
for (var k in o)
|
||
if (new RegExp("(" + k + ")").test(format))
|
||
format = format.replace(RegExp.$1, RegExp.$1.length === 1 ? o[k] : ("00" + o[k]).substr(("" + o[k]).length));
|
||
return format;
|
||
};
|
||
}
|
||
|
||
// 扩展format
|
||
$.extend({
|
||
"format": function (source, params) {
|
||
if (params === undefined) {
|
||
return source;
|
||
}
|
||
if (arguments.length > 2 && params.constructor !== Array) {
|
||
params = $.makeArray(arguments).slice(1);
|
||
}
|
||
if (params.constructor !== Array) {
|
||
params = [params];
|
||
}
|
||
$.each(params, function (i, n) {
|
||
source = source.replace(new RegExp("\\{" + i + "\\}", "g"), function () {
|
||
return n;
|
||
});
|
||
});
|
||
return source;
|
||
}
|
||
});
|
||
|
||
// enhance window.console.log
|
||
if (!window.console) {
|
||
window.console = {
|
||
log: function () {
|
||
|
||
}
|
||
};
|
||
}
|
||
window.console = window.console || {};
|
||
console.log || (console.log = opera.postError);
|
||
|
||
// client
|
||
jQuery.browser = {
|
||
versions: function () {
|
||
var u = navigator.userAgent;
|
||
return { //移动终端浏览器版本信息
|
||
trident: u.indexOf('Trident') > -1, //IE内核
|
||
presto: u.indexOf('Presto') > -1, //opera内核
|
||
webKit: u.indexOf('AppleWebKit') > -1, //苹果、谷歌内核
|
||
gecko: u.indexOf('Gecko') > -1 && u.indexOf('KHTML') === -1, //火狐内核
|
||
mobile: !!u.match(/AppleWebKit.*Mobile.*/), //是否为移动终端
|
||
ios: !!u.match(/\(i[^;]+;( U;)? CPU.+Mac OS X/), //ios终端
|
||
android: u.indexOf('Android') > -1 || u.indexOf('Linux') > -1, //android终端或uc浏览器
|
||
iPhone: u.indexOf('iPhone') > -1, //是否为iPhone或者QQHD浏览器
|
||
iPod: u.indexOf('iPod') > -1, //是否为iPod或者QQHD浏览器
|
||
iPad: u.indexOf('iPad') > -1, //是否iPad
|
||
webApp: u.indexOf('Safari') === -1 //是否web应该程序,没有头部与底部
|
||
};
|
||
}(),
|
||
language: (navigator.browserLanguage || navigator.language).toLowerCase()
|
||
};
|
||
|
||
$.extend({
|
||
bc: function (options, callback) {
|
||
options = $.extend({
|
||
remote: true,
|
||
id: "",
|
||
url: "",
|
||
data: {},
|
||
contentType: 'application/json',
|
||
dataType: 'json',
|
||
method: "post",
|
||
htmlTemplate: '<div class="form-group checkbox col-md-3 col-sm-4 col-xs-6"><label role="tooltip" title="{3}"><input type="checkbox" value="{0}" {2}/>{1}</label></div>',
|
||
title: "",
|
||
swal: true,
|
||
modal: null,
|
||
loading: false,
|
||
loadingTimeout: 10000,
|
||
callback: null,
|
||
$element: null,
|
||
async: true,
|
||
toastr: false
|
||
}, options);
|
||
|
||
if (!options.url || options.url === "") {
|
||
lgbSwal({ title: '参数错误', text: '未设置请求地址Url', type: 'error' });
|
||
return;
|
||
}
|
||
|
||
if (options.loading && options.modal) {
|
||
$(options.modal).find('.close').addClass('hidden')
|
||
$(options.modal).modal('show');
|
||
setTimeout(function () {
|
||
$(options.modal).find('.close').removeClass('hidden');
|
||
}, options.loadingTimeout);
|
||
}
|
||
|
||
if (options.remote && options.url) {
|
||
$.ajax({
|
||
url: $.formatUrl(options.url) + options.id,
|
||
data: (options.contentType === 'application/json' &&
|
||
(options.method.toLowerCase() === 'post' || options.method.toLowerCase() === 'put' || options.method.toLowerCase() === 'delete'))
|
||
? JSON.stringify(options.data) : options.data,
|
||
type: options.method,
|
||
contentType: options.contentType,
|
||
dataType: options.dataType,
|
||
async: options.async,
|
||
xhrFields: options.xhrFields,
|
||
success: function (result) {
|
||
success(result);
|
||
},
|
||
error: function (XMLHttpRequest, textStatus, errorThrown) {
|
||
if (options.toastr && toastr) {
|
||
options.toastr = $.extend({ msg: "未设置", title: "系统错误" }, options.toastr);
|
||
toastr.error(options.toastr.msg, options.toastr.title);
|
||
}
|
||
success(false);
|
||
}
|
||
});
|
||
}
|
||
function success(result) {
|
||
var interval = 10;
|
||
if ($.isFunction(options.callback)) {
|
||
options.callback.call(options.$element == null ? options : options.$element, result);
|
||
}
|
||
if (options.modal !== null && (result || options.loading)) {
|
||
$(options.modal).modal('hide');
|
||
interval = 400;
|
||
}
|
||
window.setTimeout(function () {
|
||
if (options.swal) {
|
||
lgbSwal({ title: options.title + (result ? "成功" : "失败"), type: result ? 'success' : 'error' });
|
||
}
|
||
if ($.isFunction(callback)) {
|
||
callback.call(options.$element == null ? this : options.$element);
|
||
}
|
||
}, interval);
|
||
}
|
||
},
|
||
lgbSwal: function (options) {
|
||
if ($.isFunction(swal)) {
|
||
swal($.extend({ showConfirmButton: false, showCancelButton: false, timer: 1000, title: '未设置', type: "success" }, options));
|
||
}
|
||
},
|
||
getUID: function (prefix) {
|
||
if (!prefix) prefix = 'lgb';
|
||
do prefix += ~~(Math.random() * 1000000)
|
||
while (document.getElementById(prefix))
|
||
return prefix;
|
||
},
|
||
fullScreenStatus: function fullScreenStatus(value) {
|
||
if (value != undefined) window.fullscreen = value;
|
||
return document.fullscreen ||
|
||
document.mozFullScreen ||
|
||
document.webkitIsFullScreen || window.fullscreen ||
|
||
false;
|
||
},
|
||
formatter: function (key) {
|
||
if (!this[key]) {
|
||
this[key] = {};
|
||
var that = this;
|
||
$.each($('#' + key).children(), function (index, element) {
|
||
that[key][$(element).attr('value')] = $(element).text();
|
||
});
|
||
}
|
||
return this;
|
||
},
|
||
formatUrl: function (url) {
|
||
if (url.substr(0, 4) == "http") return url;
|
||
var base = $('#pathBase').attr('href');
|
||
return base + url;
|
||
}
|
||
});
|
||
|
||
window.lgbSwal = $.lgbSwal;
|
||
|
||
// Roles
|
||
Role = {
|
||
url: 'api/Roles/',
|
||
title: "授权角色"
|
||
};
|
||
|
||
// Users
|
||
User = {
|
||
url: 'api/Users/',
|
||
title: "授权用户"
|
||
};
|
||
|
||
// Groups
|
||
Group = {
|
||
url: 'api/Groups/',
|
||
title: "授权部门"
|
||
};
|
||
|
||
// Menus
|
||
Menu = {
|
||
url: 'api/Menus/',
|
||
iconView: 'Admin/IconView',
|
||
title: "授权菜单"
|
||
};
|
||
|
||
// Exceptions
|
||
Exceptions = {
|
||
url: 'api/Exceptions/',
|
||
title: "程序异常日志"
|
||
};
|
||
|
||
// Dicts
|
||
Dicts = {
|
||
url: 'api/Dicts/',
|
||
css: 'api/Css/',
|
||
};
|
||
|
||
// Profiles
|
||
Profiles = {
|
||
url: 'api/Profiles/'
|
||
};
|
||
|
||
// Settings
|
||
Settings = {
|
||
url: 'api/Settings/',
|
||
title: '网站设置'
|
||
};
|
||
|
||
// Messages
|
||
Messages = {
|
||
url: 'api/Messages/'
|
||
};
|
||
|
||
// Tasks
|
||
Tasks = {
|
||
url: 'api/Tasks/'
|
||
};
|
||
|
||
// Notifications
|
||
Notifications = {
|
||
url: 'api/Notifications/'
|
||
};
|
||
|
||
$.fn.extend({
|
||
fixCollapse: function () {
|
||
var $root = this;
|
||
var $collapse = $root.find('a[data-toggle="collapse"]:visible');
|
||
$collapse.each(function () {
|
||
var $this = $(this);
|
||
if ($this.attr('href') != '#') return;
|
||
var $target = $this.parent().next();
|
||
var tId = $.getUID('collapse');
|
||
$target.attr('id', tId);
|
||
$this.attr('href', '#' + tId);
|
||
});
|
||
return this;
|
||
},
|
||
adjustDialog: function () {
|
||
var $modal_dialog = this;
|
||
var m_top = Math.max(0, ($(window).height() - $modal_dialog.height()) / 2);
|
||
$modal_dialog.css({ 'margin': m_top + 'px auto' });
|
||
return this;
|
||
},
|
||
autoCenter: function (options) {
|
||
options = $.extend({ top: 0 }, options);
|
||
var that = this;
|
||
var defaultVal = parseFloat(that.css('marginTop').replace('px', ''));
|
||
var getHeight = function () {
|
||
return Math.max(defaultVal, ($(window).height() - options.top - that.outerHeight()) / 2 + $(document).scrollTop());
|
||
};
|
||
$(window).resize(function () {
|
||
that.css({ marginTop: getHeight() });
|
||
});
|
||
that.css({ marginTop: getHeight(), transition: "all .5s linear" });
|
||
return this;
|
||
},
|
||
footer: function (options) {
|
||
if ($(window).width() >= 768) { this.addClass('fixed'); return this; }
|
||
var op = $.extend({ header: "header", content: ".main-content" }, options);
|
||
return ($(op.header).outerHeight() + $(op.content).outerHeight() + this.outerHeight() > $(window).height()) ? this.removeClass('fixed') : this.addClass('fixed');
|
||
},
|
||
lgbTooltip: function (options) {
|
||
if (/show|hide|destroy/.test(options)) {
|
||
this.tooltip(options);
|
||
if (options === 'destroy') this.removeAttr('data-original-title');
|
||
}
|
||
else {
|
||
this.tooltip($.extend({ delay: { "show": 100, "hide": 100 } }, options));
|
||
}
|
||
return this;
|
||
},
|
||
lgbPopover: function (options) {
|
||
if (/show|hide|destroy/.test(options)) {
|
||
this.popover(options);
|
||
if (options === 'destroy') this.removeAttr('data-original-title');
|
||
}
|
||
else {
|
||
this.popover($.extend({ placement: 'auto' }, options));
|
||
this.on('click', function (e) { e.preventDefault(); });
|
||
}
|
||
return this;
|
||
},
|
||
autoValidate: function (rules, messages, handler) {
|
||
var parent = 'body';
|
||
var $wrapper = $('#dialogNew');
|
||
if ($wrapper.length === 1) parent = '#dialogNew';
|
||
// validate
|
||
var $this = $(this);
|
||
if (messages && $.isArray(messages.button)) {
|
||
handler = messages;
|
||
messages = {};
|
||
}
|
||
else {
|
||
messages = $.extend({}, messages);
|
||
}
|
||
$this.validate({
|
||
validClass: "has-success",
|
||
errorClass: "has-error",
|
||
ignore: ".ignore",
|
||
rules: $.extend({}, rules),
|
||
messages: $.extend({}, messages),
|
||
highlight: function (element, errorClass, validClass) {
|
||
$(element).parents('.form-group').addClass(errorClass).removeClass(validClass);
|
||
},
|
||
unhighlight: function (element, errorClass, validClass) {
|
||
$(element).lgbTooltip('destroy').parents('.form-group').removeClass(errorClass).addClass(validClass);
|
||
},
|
||
errorPlacement: function (label, element) {
|
||
var $ele = $(element);
|
||
if (!$ele.attr('data-original-title')) $ele.lgbTooltip({ container: parent });
|
||
$ele.attr('data-original-title', $(label).text());
|
||
$ele.lgbTooltip('show');
|
||
$('#' + $ele.attr('aria-describedby')).addClass(this.settings.errorClass);
|
||
}
|
||
});
|
||
if (handler && $.isArray(handler.button)) {
|
||
$.each(handler.button, function (index, btn) {
|
||
$('#' + btn).on('click', function () {
|
||
$(this).attr('data-valid', $this.valid());
|
||
});
|
||
});
|
||
}
|
||
},
|
||
smartTable: function (options) {
|
||
var settings = $.extend({
|
||
method: 'get', //请求方式(*)
|
||
toolbar: '#toolbar', //工具按钮用哪个容器
|
||
striped: true, //是否显示行间隔色
|
||
cache: false, //是否使用缓存,默认为true,所以一般情况下需要设置一下这个属性(*)
|
||
pagination: true, //是否显示分页(*)
|
||
sortOrder: "asc", //排序方式
|
||
sidePagination: "server", //分页方式:client客户端分页,server服务端分页(*)
|
||
pageNumber: 1, //初始化加载第一页,默认第一页
|
||
pageSize: 20, //每页的记录行数(*)
|
||
pageList: [20, 40, 80, 120], //可供选择的每页的行数(*)
|
||
showColumns: true, //是否显示所有的列
|
||
showRefresh: true, //是否显示刷新按钮
|
||
showToggle: true, //是否显示详细视图和列表视图的切换按钮
|
||
cardView: $(window).width() < 768, //是否显示详细视图
|
||
footer: '.site-footer',
|
||
onLoadSuccess: function () {
|
||
$(settings.footer).footer();
|
||
}
|
||
}, options);
|
||
settings.url = $.formatUrl(settings.url);
|
||
this.bootstrapTable(settings);
|
||
$(settings.toolbar).removeClass('hidden').find('.toolbar').on('click', 'a', function (e) {
|
||
e.preventDefault();
|
||
$('#' + $(this).attr('id').replace('tb_', 'btn_')).trigger("click");
|
||
}).insertBefore(this.parents('.bootstrap-table').find('.fixed-table-toolbar > .bs-bars'));
|
||
return this;
|
||
},
|
||
lgbDropdown: function (options) {
|
||
var $this = $(this);
|
||
var op = typeof options === 'object' && options;
|
||
if (/val/.test(options)) {
|
||
if (arguments.length === 1)
|
||
return $this.first().children('a').val();
|
||
else {
|
||
$this.first().children(':first').children(':first').text($this.find('[data-val="' + arguments[1] + '"]').text());
|
||
}
|
||
}
|
||
else {
|
||
$this.each(function () {
|
||
$(this).on('click', '.dropdown-menu a', { $parent: $(this) }, function (event) {
|
||
event.preventDefault();
|
||
var $op = $(this);
|
||
event.data.$parent.children('a').val($op.attr('data-val')).children(':first').text($op.text());
|
||
});
|
||
});
|
||
}
|
||
}
|
||
});
|
||
|
||
//fix bug
|
||
$.fn.modal.Constructor.prototype.adjustDialog = function () {
|
||
var modalIsOverflowing = this.$element[0].scrollHeight > document.documentElement.clientHeight;
|
||
|
||
this.$element.css({
|
||
paddingLeft: !this.bodyIsOverflowing && modalIsOverflowing ? this.scrollbarWidth : '',
|
||
paddingRight: this.bodyIsOverflowing && !modalIsOverflowing ? this.scrollbarWidth : ''
|
||
});
|
||
|
||
// added by Argo
|
||
var $modal_dialog = $(this.$element[0]).find('.modal-dialog');
|
||
$modal_dialog.adjustDialog();
|
||
};
|
||
})(jQuery);
|
||
|
||
$(function () {
|
||
// loading customer css
|
||
$.bc({
|
||
url: Dicts.css, swal: false, method: 'get',
|
||
callback: function (result) {
|
||
if (result.length > 0)
|
||
$('head').append($.format('<link href="{0}css/{1}" rel="stylesheet" type="text/css" />', $('#pathBase').attr('href'), result));
|
||
}
|
||
});
|
||
}); |