BootstrapAdmin/Bootstrap.Admin/wwwroot/js/Settings.js

170 lines
7.7 KiB
JavaScript
Raw Normal View History

2018-06-07 00:45:47 +08:00
$(function () {
$('a[data-admin="False"]').hide();
var bsa = new BootstrapAdmin({
url: Settings.url,
bootstrapTable: null,
validateForm: null,
modal: null,
dataEntity: new DataEntity({
map: {
Title: "sysName",
Footer: "sysFoot"
}
})
});
$('button[data-method]').on('click', function (e) {
var $this = $(this);
switch ($this.attr('data-method')) {
case 'footer':
var data = bsa.dataEntity.get();
$.bc({
url: Settings.url, data: { name: '网站页脚', code: data.Footer, category: Settings.title }, title: Settings.title,
callback: function (result) {
if (result) $('#websiteFooter').text(data.Footer);
2018-06-07 00:45:47 +08:00
}
});
break;
case 'title':
var data = bsa.dataEntity.get();
$.bc({
url: Settings.url, data: { name: '网站标题', code: data.Title, category: Settings.title }, title: Settings.title,
callback: function (result) {
if (result) $('#websiteTitle').text(data.Title);
2018-06-07 00:45:47 +08:00
}
});
break;
case 'css':
2018-08-02 19:19:03 +08:00
var cssDefine = $('#dictCssDefine').attr("data-val");
$.bc({
url: Settings.url, data: { name: '使用样式', code: cssDefine, category: '当前样式' }, title: '网站样式',
callback: function (result) {
if (result) {
window.setTimeout(function () { window.location.reload(true); }, 1000);
2018-06-07 00:45:47 +08:00
}
}
});
break;
2018-06-07 00:45:47 +08:00
}
});
var $sortable = $('#sortable');
var listCacheUrl = function (options) {
options = $.extend({ clear: false }, options);
2018-06-07 00:45:47 +08:00
$sortable.html('');
$.bc({
url: Settings.url,
method: 'GET',
swal: false,
callback: function (result) {
if (result && $.isArray(result)) {
$.each(result, function (index, item) {
if (options.clear) options.url = item.Url + "?clear=clear";
else options.url = item.Url;
$.bc({
url: options.url,
xhrFields: {
withCredentials: true
},
swal: false,
callback: function (result) {
if ($.isArray(result)) {
var html = '<li class="{4}"><i class="fa fa-ellipsis-v"></i><div class="task-title"><span class="task-title-sp" data-toggle="tooltip" title="{1}">{2}</span><span class="badge badge-success">{0}</span><span class="task-value" title="{3}">{3}</span><div class="pull-right hidden-phone"><span>{7}</span><button class="btn btn-danger btn-xs fa fa-trash-o" title="{1}" data-url="{5}?cacheKey={1}" data-toggle="tooltip" data-self="{6}" data-placement="left"></button></div></div></li>';
var content = result.sort(function (x, y) {
return x.Key > y.Key ? 1 : -1;
}).map(function (ele) {
var key = ele.Key.split('-')[0];
var css = 'list-default';
switch (key) {
case "MenuHelper":
css = 'list-primary';
break;
case "UserHelper":
css = 'list-success';
break;
case "RoleHelper":
css = 'list-danger';
break;
case "GroupHelper":
css = 'list-warning';
break;
case "LogHelper":
css = 'list-info';
break;
case "DictHelper":
css = 'list-inverse';
break;
case "ExceptionHelper":
css = 'list-Exception';
break;
case "MessageHelper":
css = 'list-Message';
break;
case "TaskHelper":
css = 'list-Task';
break;
case "NotificationHelper":
css = 'list-Notification';
break;
default:
break;
}
return $.format(html, ele.Interval, ele.Key, ele.Desc, ele.Value, css, $.format(item.Url, ele.Key), item.Self, Math.max(0, ele.Interval - Math.round((new Date() - new Date(ele.CreateTime.replace(/-/g, '/'))) / 1000)));
}).join('');
$sortable.append($.format('<li class="title">{0}</li>', item.Desc));
$sortable.append(content);
$sortable.find('[data-toggle="tooltip"]').tooltip();
}
}
});
2018-06-07 00:45:47 +08:00
});
}
}
});
}
var listCache = function (options) {
$.bc({
url: options.url,
xhrFields: {
withCredentials: true
},
swal: false
2018-06-07 00:45:47 +08:00
});
}
$('a[data-method]').on('click', function (e) {
e.preventDefault();
e.stopPropagation();
var $this = $(this);
var options = {};
switch ($this.attr('data-method')) {
case 'clear':
options.clear = true;
break;
case 'refresh':
break;
}
listCacheUrl(options);
}).last().trigger('click');
2018-06-07 00:45:47 +08:00
$sortable.on('click', '.btn', function () {
2018-08-03 18:12:35 +08:00
$(this).tooltip('dispose');
listCache({ url: $(this).attr('data-url') });
2018-06-07 00:45:47 +08:00
listCacheUrl();
});
$.bc({
2018-06-07 12:25:03 +08:00
url: Dicts.css, swal: false,
2018-06-07 00:45:47 +08:00
callback: function (result) {
var html = result.map(function (ele, index) { return $.format('<li><a href="#" data-val="{1}">{0}</a></li>', ele.Name, ele.Code); }).join('');
$('#cssContainer').append(html);
$.bc({
2018-06-07 12:25:03 +08:00
url: Dicts.css, swal: false, method: 'get',
2018-06-07 00:45:47 +08:00
callback: function (result) {
if (result.length > 0)
$('.lgbDropdown').lgbDropdown('val', result);
}
});
}
});
})