2018-06-07 00:45:47 +08:00
|
|
|
|
(function ($) {
|
|
|
|
|
var cascadeMenu = function (menus) {
|
|
|
|
|
var html = "";
|
|
|
|
|
$.each(menus, function (index, menu) {
|
2018-09-06 14:56:16 +08:00
|
|
|
|
if (menu.Menus.length === 0) {
|
2018-06-07 00:45:47 +08:00
|
|
|
|
html += $.format('<li class="dd-item dd3-item" data-id="{0}" data-order="{4}" data-category="{3}"><div class="dd-handle dd3-handle"></div><div class="dd3-content"><div class="checkbox"><label><input type="checkbox" value="{0}"><span><i class="{1}"></i>{2}</span></label></div><div class="radio"><label><input type="radio" name="menu" value="{0}"><span><i class="{1}"></i>{2}</span></label></div><span class="menuType">{5}</span><span class="menuOrder">{4}</span></div></li>', menu.Id, menu.Icon, menu.Name, menu.Category, menu.Order, menu.CategoryName);
|
|
|
|
|
}
|
|
|
|
|
else {
|
|
|
|
|
html += $.format('<li class="dd-item dd3-item" data-id="{0}" data-order="{5}" data-category="{3}"><div class="dd-handle dd3-handle"></div><div class="dd3-content"><div class="checkbox"><label><input type="checkbox" value="{0}"><span><i class="{1}"></i>{2}</span></label></div><div class="radio"><label><input type="radio" name="menu" value="{0}"><span><i class="{1}"></i>{2}</span></label></div><span class="menuType">{6}</span><span class="menuOrder">{5}</span></div><ol class="dd-list">{4}</ol></li>', menu.Id, menu.Icon, menu.Name, menu.Category, cascadeSubMenu(menu.Menus), menu.Order, menu.CategoryName);
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
return html;
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
var cascadeSubMenu = function (menus) {
|
2018-09-06 14:56:16 +08:00
|
|
|
|
var html = "";
|
2018-06-07 00:45:47 +08:00
|
|
|
|
$.each(menus, function (index, menu) {
|
|
|
|
|
html += $.format('<li class="dd-item dd3-item" data-id="{0}" data-order="{4}" data-category="{3}"><div class="dd-handle dd3-handle"></div><div class="dd3-content"><div class="checkbox"><label><input type="checkbox" value="{0}"><span><i class="{1}"></i>{2}</span></label></div><div class="radio"><label><input type="radio" name="menu" value="{0}"><span><i class="{1}"></i>{2}</span></label></div><span class="menuType">{5}</span><span class="menuOrder">{4}</span></div></li>', menu.Id, menu.Icon, menu.Name, menu.Category, menu.Order, menu.CategoryName);
|
|
|
|
|
});
|
|
|
|
|
return html;
|
|
|
|
|
};
|
|
|
|
|
|
2018-09-13 16:34:32 +08:00
|
|
|
|
var setBadge = function (source) {
|
|
|
|
|
var data = $.extend({
|
|
|
|
|
TasksCount: 0,
|
|
|
|
|
AppExceptionsCount: 0,
|
|
|
|
|
DbExceptionsCount: 0,
|
|
|
|
|
MessagesCount: 0,
|
|
|
|
|
NewUsersCount: 0
|
|
|
|
|
}, source);
|
|
|
|
|
$('#msgHeaderTaskBadge').text(data.TasksCount === 0 ? "" : data.TasksCount);
|
|
|
|
|
$('#msgHeaderUserBadge').text(data.NewUsersCount === 0 ? "" : data.NewUsersCount);
|
|
|
|
|
$('#msgHeaderAppBadge').text(data.AppExceptionsCount === 0 ? "" : data.AppExceptionsCount);
|
|
|
|
|
$('#msgHeaderDbBadge').text(data.DbExceptionsCount === 0 ? "" : data.DbExceptionsCount);
|
|
|
|
|
$('#msgHeaderMsgBadge').text(data.MessagesCount === 0 ? "" : data.MessagesCount);
|
|
|
|
|
$('#logoutNoti').text(data.NewUsersCount === 0 ? "" : data.NewUsersCount);
|
|
|
|
|
};
|
|
|
|
|
|
2018-06-07 00:45:47 +08:00
|
|
|
|
$.fn.extend({
|
|
|
|
|
nestMenu: function (callback) {
|
|
|
|
|
var $this = $(this);
|
|
|
|
|
$.bc({
|
2018-09-13 19:21:35 +08:00
|
|
|
|
id: 0, url: Menu.url, query: { type: "user" }, method: "post",
|
2018-06-07 00:45:47 +08:00
|
|
|
|
callback: function (result) {
|
|
|
|
|
var html = "";
|
|
|
|
|
if ($.isArray(result)) html = cascadeMenu(result);
|
|
|
|
|
$this.find('ol:first').html(html);
|
|
|
|
|
$this.nestable();
|
|
|
|
|
callback();
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
},
|
2018-09-06 15:47:07 +08:00
|
|
|
|
clearWidgetItems: function () {
|
2018-09-13 16:34:32 +08:00
|
|
|
|
setBadge(false);
|
2018-09-06 15:47:07 +08:00
|
|
|
|
this.children('.dropdown').each(function () {
|
|
|
|
|
$(this).children('.dropdown-menu').each(function () {
|
|
|
|
|
$(this).children('a').remove();
|
|
|
|
|
});
|
2018-06-07 00:45:47 +08:00
|
|
|
|
});
|
2018-09-06 15:47:07 +08:00
|
|
|
|
return this;
|
|
|
|
|
},
|
2018-06-07 00:45:47 +08:00
|
|
|
|
reloadWidget: function () {
|
2018-08-09 22:36:07 +08:00
|
|
|
|
if (this.length === 0) return this;
|
|
|
|
|
var that = this;
|
2018-06-07 00:45:47 +08:00
|
|
|
|
$.bc({
|
|
|
|
|
url: Notifications.url,
|
|
|
|
|
callback: function (result) {
|
2018-09-06 15:47:07 +08:00
|
|
|
|
that.clearWidgetItems();
|
2018-09-13 16:34:32 +08:00
|
|
|
|
if (!result) return;
|
|
|
|
|
|
|
|
|
|
setBadge(result);
|
|
|
|
|
|
2018-06-07 00:45:47 +08:00
|
|
|
|
// tasks
|
|
|
|
|
$('#msgHeaderTask').text(result.TasksCount);
|
2018-08-26 19:23:37 +08:00
|
|
|
|
var htmlUserTemplate = '<a class="dropdown-item" href="{4}?id={3}"><span class="desc">{0}-{2}</span><span class="percent">{1}%</span></span><div class="progress progress-striped"><div class="progress-bar" role="progressbar" aria-valuenow="{1}" aria-valuemin="0" aria-valuemax="100" style="width: {1}%"><span class="sr-only">{1}% 完成</span></div></div></a>';
|
2018-06-07 00:45:47 +08:00
|
|
|
|
var html = result.Tasks.map(function (u) {
|
2018-08-26 19:23:37 +08:00
|
|
|
|
return $.format(htmlUserTemplate, u.TaskName, u.TaskProgress, u.AssignDisplayName, u.Id, $.formatUrl('Admin/Tasks'));
|
2018-06-07 00:45:47 +08:00
|
|
|
|
}).join('');
|
|
|
|
|
$(html).insertAfter($('#msgHeaderTaskContent'));
|
|
|
|
|
|
|
|
|
|
// new users
|
|
|
|
|
$('#msgHeaderUser').text(result.NewUsersCount);
|
2018-08-26 19:23:37 +08:00
|
|
|
|
htmlUserTemplate = '<a class="dropdown-item" href="{4}"><span class="label label-success"><i class="fa fa-plus"></i></span><div title="{2}" class="content">{1}({0})</div><span class="small italic">{3}</span></a>';
|
2018-06-07 00:45:47 +08:00
|
|
|
|
html = result.Users.map(function (u) {
|
2018-08-26 19:23:37 +08:00
|
|
|
|
return $.format(htmlUserTemplate, u.UserName, u.DisplayName, u.Description, u.Period, $.formatUrl('Admin/Notifications'));
|
2018-06-07 00:45:47 +08:00
|
|
|
|
}).join('');
|
|
|
|
|
$(html).insertAfter($('#msgHeaderUserContent'));
|
|
|
|
|
|
|
|
|
|
// apps
|
|
|
|
|
$('#msgHeaderApp').text(result.AppExceptionsCount);
|
2018-08-26 19:23:37 +08:00
|
|
|
|
htmlUserTemplate = '<a class="dropdown-item" href="{3}"><span class="label label-warning"><i class="fa fa-bug"></i></span><div title="{1}" class="content">{0}</div><span class="small italic">{2}</span></a>';
|
2018-06-07 00:45:47 +08:00
|
|
|
|
html = result.Apps.map(function (u) {
|
2018-08-26 19:23:37 +08:00
|
|
|
|
return $.format(htmlUserTemplate, u.ExceptionType, u.Message, u.Period, $.formatUrl('Admin/Exceptions'));
|
2018-06-07 00:45:47 +08:00
|
|
|
|
}).join('');
|
|
|
|
|
$(html).insertAfter($('#msgHeaderAppContent'));
|
|
|
|
|
|
|
|
|
|
// dbs
|
|
|
|
|
$('#msgHeaderDb').text(result.DbExceptionsCount);
|
2018-08-26 19:23:37 +08:00
|
|
|
|
htmlUserTemplate = '<a class="dropdown-item" href="{3}"><span class="label label-danger"><i class="fa fa-bolt"></i></span><div title="{1}" class="content">{0}</div><span class="small italic">{2}</span></a>';
|
2018-06-07 00:45:47 +08:00
|
|
|
|
html = result.Dbs.map(function (u) {
|
2018-08-26 19:23:37 +08:00
|
|
|
|
return $.format(htmlUserTemplate, u.ErrorPage, u.Message, u.Period, $.formatUrl('Admin/Exceptions'));
|
2018-06-07 00:45:47 +08:00
|
|
|
|
}).join('');
|
|
|
|
|
$(html).insertAfter($('#msgHeaderDbContent'));
|
|
|
|
|
|
|
|
|
|
// messages
|
|
|
|
|
$('#msgHeaderMsg').text(result.MessagesCount);
|
2018-08-26 19:23:37 +08:00
|
|
|
|
htmlUserTemplate = '<a class="dropdown-item" href="{6}?id={0}"><span class="photo"><img alt="avatar" src="{1}"></span><span class="subject"><span class="from">{2}</span><span class="time">{4}</span></span><span class="message" title="{5}">{3}</span></a>';
|
2018-06-07 00:45:47 +08:00
|
|
|
|
html = result.Messages.map(function (u) {
|
2018-08-26 19:23:37 +08:00
|
|
|
|
return $.format(htmlUserTemplate, u.Id, u.FromIcon, u.FromDisplayName, u.Title, u.Period, u.Content, $.formatUrl('Admin/Messages'));
|
2018-06-07 00:45:47 +08:00
|
|
|
|
}).join('');
|
|
|
|
|
$(html).insertAfter($('#msgHeaderMsgContent'));
|
|
|
|
|
}
|
|
|
|
|
});
|
2018-08-09 22:36:07 +08:00
|
|
|
|
return this;
|
2018-06-07 00:45:47 +08:00
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
})(jQuery);
|
|
|
|
|
|
|
|
|
|
$(function () {
|
|
|
|
|
toastr.options = {
|
|
|
|
|
"closeButton": true,
|
|
|
|
|
"debug": false,
|
|
|
|
|
"progressBar": true,
|
|
|
|
|
"positionClass": "toast-bottom-right",
|
|
|
|
|
"onclick": null,
|
|
|
|
|
"showDuration": "600",
|
|
|
|
|
"hideDuration": "2000",
|
2018-09-07 15:53:16 +08:00
|
|
|
|
"timeOut": "4000",
|
2018-06-07 00:45:47 +08:00
|
|
|
|
"extendedTimeOut": "1000",
|
|
|
|
|
"showEasing": "swing",
|
|
|
|
|
"hideEasing": "linear",
|
|
|
|
|
"showMethod": "fadeIn",
|
|
|
|
|
"hideMethod": "fadeOut"
|
2018-09-06 14:56:16 +08:00
|
|
|
|
};
|
2018-06-07 00:45:47 +08:00
|
|
|
|
|
2018-09-19 00:19:43 +08:00
|
|
|
|
var $sideMenu = $(".sidebar");
|
2018-06-07 00:45:47 +08:00
|
|
|
|
|
2018-09-16 01:25:52 +08:00
|
|
|
|
$sideMenu.dcAccordion({
|
2018-06-07 00:45:47 +08:00
|
|
|
|
autoExpand: true
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
$("#gotoTop").on('click', function (e) {
|
|
|
|
|
e.preventDefault();
|
2018-10-05 15:41:47 +08:00
|
|
|
|
$('.main-content, html').animate({
|
2018-06-07 00:45:47 +08:00
|
|
|
|
scrollTop: 0
|
|
|
|
|
}, 200);
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
// breadcrumb
|
2018-09-19 00:19:43 +08:00
|
|
|
|
var $breadNav = $('#breadNav');
|
2018-09-16 01:25:52 +08:00
|
|
|
|
var arch = $sideMenu.find('a.active').last();
|
2018-09-29 20:16:21 +08:00
|
|
|
|
$breadNav.removeClass('d-none').text(arch.text() || $('title').text());
|
2018-09-16 19:40:32 +08:00
|
|
|
|
|
2018-09-19 00:19:43 +08:00
|
|
|
|
$.fn.extend({
|
|
|
|
|
autoScrollSidebar: function (options) {
|
|
|
|
|
var option = $.extend({ target: null, offsetTop: 0 }, options);
|
2018-09-23 12:59:49 +08:00
|
|
|
|
var $navItem = option.target;
|
2018-09-23 15:24:59 +08:00
|
|
|
|
if ($navItem === null) return this;
|
2018-09-19 00:19:43 +08:00
|
|
|
|
|
|
|
|
|
// sidebar scroll animate
|
2018-09-23 12:59:49 +08:00
|
|
|
|
var middle = this.outerHeight() / 2;
|
2018-09-23 15:24:59 +08:00
|
|
|
|
var top = 0;
|
|
|
|
|
if (this.hasClass('mCustomScrollbar')) {
|
|
|
|
|
top = $navItem.offset().top - $('header').outerHeight() + option.offsetTop;
|
|
|
|
|
if (top > middle) {
|
|
|
|
|
this.mCustomScrollbar('scrollTo', top - middle);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
else {
|
|
|
|
|
top = $navItem.offset().top + option.offsetTop;
|
|
|
|
|
if (top > middle)
|
|
|
|
|
this.animate({
|
|
|
|
|
scrollTop: top - middle
|
|
|
|
|
});
|
|
|
|
|
}
|
2018-09-19 00:19:43 +08:00
|
|
|
|
return this;
|
|
|
|
|
},
|
|
|
|
|
addNiceScroll: function () {
|
2018-09-23 14:48:46 +08:00
|
|
|
|
if ($.browser.versions.ios && $(window).width() > 768) {
|
|
|
|
|
this.css('overflow', 'auto');
|
|
|
|
|
}
|
|
|
|
|
else if (!$.browser.versions.ios && $(window).width() > 768) {
|
2018-09-23 12:59:49 +08:00
|
|
|
|
this.mCustomScrollbar({ theme: 'minimal' });
|
|
|
|
|
}
|
|
|
|
|
else {
|
|
|
|
|
this.mCustomScrollbar('destroy');
|
2018-09-19 00:19:43 +08:00
|
|
|
|
}
|
|
|
|
|
return this;
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
// custom scrollbar
|
2018-09-23 12:59:49 +08:00
|
|
|
|
var $sidebar = $('aside').addNiceScroll().autoScrollSidebar({ target: arch.parent(), offsetTop: arch.parent().innerHeight() / 2 });
|
2018-09-19 00:19:43 +08:00
|
|
|
|
|
|
|
|
|
$sideMenu.on('click', 'a.dcjq-parent', function () {
|
2018-09-23 15:24:59 +08:00
|
|
|
|
var $this = $(this);
|
2018-09-23 14:48:46 +08:00
|
|
|
|
if (!$.browser.versions.ios && $(window).width() > 768) {
|
|
|
|
|
setTimeout(function () {
|
|
|
|
|
var offsetScroll = parseInt($this.parents('.mCSB_container').css('top').replace('px', ''));
|
|
|
|
|
$sidebar.autoScrollSidebar({ target: $this.parent(), offsetTop: 25.5 - offsetScroll });
|
|
|
|
|
}, 600);
|
|
|
|
|
}
|
2018-09-23 15:24:59 +08:00
|
|
|
|
else if ($.browser.versions.ios && $(window).width() > 768) {
|
|
|
|
|
var offsetScroll = parseInt($this.parents('aside').scrollTop());
|
|
|
|
|
$sidebar.autoScrollSidebar({ target: $this.parent(), offsetTop: 25.5 + offsetScroll });
|
|
|
|
|
}
|
2018-06-07 00:45:47 +08:00
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
$('.sidebar-toggle-box').on('click', function () {
|
2018-09-19 00:19:43 +08:00
|
|
|
|
$('body').toggleClass('sidebar-open');
|
2018-06-07 00:45:47 +08:00
|
|
|
|
});
|
|
|
|
|
|
2018-08-05 15:31:21 +08:00
|
|
|
|
$('[data-toggle="dropdown"].dropdown-select').dropdown('select');
|
2018-06-07 00:45:47 +08:00
|
|
|
|
|
2018-09-16 19:40:32 +08:00
|
|
|
|
// tooltip
|
|
|
|
|
$('[data-toggle="tooltip"]').tooltip();
|
|
|
|
|
|
2018-06-07 00:45:47 +08:00
|
|
|
|
// load widget data
|
2018-09-07 15:53:16 +08:00
|
|
|
|
$('.header .nav').reloadWidget().socketHandler({
|
|
|
|
|
onmessage: function (e) {
|
|
|
|
|
var result = JSON.parse(e.data);
|
|
|
|
|
for (index in result) {
|
|
|
|
|
var cate = result[index].Category;
|
|
|
|
|
var msg = result[index].Message;
|
|
|
|
|
switch (cate) {
|
2018-09-08 17:20:12 +08:00
|
|
|
|
case "DB":
|
|
|
|
|
toastr.error(msg, "数据库操作发生异常");
|
2018-09-07 15:53:16 +08:00
|
|
|
|
break;
|
|
|
|
|
case "Users":
|
|
|
|
|
toastr.success(msg, "新用户注册");
|
|
|
|
|
break;
|
2018-09-08 17:20:12 +08:00
|
|
|
|
case "App":
|
|
|
|
|
toastr.warning(msg, "应用程序发生异常");
|
2018-09-07 15:53:16 +08:00
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
if (result.length > 0) this.reloadWidget();
|
|
|
|
|
}
|
|
|
|
|
});
|
2018-09-19 00:19:43 +08:00
|
|
|
|
|
|
|
|
|
$(window).on('resize', function () {
|
2018-09-23 12:59:49 +08:00
|
|
|
|
$sidebar.addNiceScroll();
|
2018-09-19 00:19:43 +08:00
|
|
|
|
});
|
2016-11-16 23:47:01 +08:00
|
|
|
|
});
|