2020-12-02 14:26:20 +01:00
|
|
|
/* globals $, GridStack, load_modal, TreeController, forced_title_callback, createVisualConsole, tinyMCE*/
|
2020-03-26 12:29:38 +01:00
|
|
|
// eslint-disable-next-line no-unused-vars
|
|
|
|
function show_option_dialog(settings) {
|
|
|
|
load_modal({
|
|
|
|
target: $("#modal-update-dashboard"),
|
|
|
|
form: "form-update-dashboard",
|
|
|
|
url: settings.url_ajax,
|
|
|
|
modal: {
|
|
|
|
title: settings.title,
|
|
|
|
cancel: settings.btn_cancel,
|
|
|
|
ok: settings.btn_text
|
|
|
|
},
|
|
|
|
onshow: {
|
|
|
|
page: settings.url,
|
|
|
|
method: "drawFormDashboard",
|
|
|
|
extradata: {
|
|
|
|
dashboardId: settings.dashboardId
|
|
|
|
}
|
|
|
|
},
|
|
|
|
onsubmit: {
|
|
|
|
page: settings.url,
|
|
|
|
method: "updateDashboard",
|
|
|
|
dataType: "json"
|
|
|
|
},
|
|
|
|
ajax_callback: update_dashboard
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
function update_dashboard(data) {
|
|
|
|
if (data.error === 1) {
|
|
|
|
console.error(data.error_mesage);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
$(".ui-dialog-content").dialog("close");
|
|
|
|
var url = data.url + "&dashboardId=" + data.dashboardId;
|
|
|
|
location.replace(url);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Onchange input switch private.
|
|
|
|
* @return {void}
|
|
|
|
*/
|
|
|
|
// eslint-disable-next-line no-unused-vars
|
|
|
|
function showGroup() {
|
|
|
|
$("#li-group").removeClass("hidden");
|
|
|
|
var private = $("#private").prop("checked");
|
|
|
|
if (private) {
|
2021-04-21 08:57:12 +02:00
|
|
|
$("#id_group").removeAttr("required");
|
2020-03-26 12:29:38 +01:00
|
|
|
$("#li-group").hide();
|
|
|
|
} else {
|
2021-04-21 08:57:12 +02:00
|
|
|
$("#id_group").attr("required", true);
|
2020-03-26 12:29:38 +01:00
|
|
|
$("#li-group").show();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// eslint-disable-next-line no-unused-vars
|
|
|
|
function initialiceLayout(data) {
|
2020-12-02 14:26:20 +01:00
|
|
|
var grid = GridStack.init({
|
2020-03-26 12:29:38 +01:00
|
|
|
float: true,
|
|
|
|
column: 12,
|
|
|
|
alwaysShowResizeHandle: /Android|webOS|iPhone|iPad|iPod|BlackBerry|IEMobile|Opera Mini/i.test(
|
|
|
|
navigator.userAgent
|
|
|
|
),
|
|
|
|
resizable: {
|
|
|
|
handles: "e, se, s, sw, w"
|
|
|
|
},
|
|
|
|
disableDrag: true,
|
|
|
|
disableResize: true,
|
|
|
|
draggable: false
|
|
|
|
});
|
|
|
|
|
2021-03-03 13:42:02 +01:00
|
|
|
var positionGrid = grid.el.getBoundingClientRect();
|
2020-03-26 12:29:38 +01:00
|
|
|
var gridWidth = positionGrid.width;
|
2022-12-05 17:20:08 +01:00
|
|
|
var title = data.title;
|
2020-03-26 12:29:38 +01:00
|
|
|
getCellsLayout();
|
|
|
|
|
|
|
|
function getCellsLayout() {
|
|
|
|
$.ajax({
|
|
|
|
method: "post",
|
|
|
|
url: data.url,
|
|
|
|
data: {
|
|
|
|
page: data.page,
|
|
|
|
method: "getCellsLayout",
|
2020-07-22 10:56:16 +02:00
|
|
|
dashboardId: data.dashboardId,
|
|
|
|
auth_class: data.auth.class,
|
|
|
|
auth_hash: data.auth.hash,
|
|
|
|
id_user: data.auth.user
|
2020-03-26 12:29:38 +01:00
|
|
|
},
|
|
|
|
dataType: "json",
|
2020-07-22 10:56:16 +02:00
|
|
|
success: function(d) {
|
|
|
|
loadLayout(d);
|
2020-03-26 12:29:38 +01:00
|
|
|
},
|
|
|
|
error: function(error) {
|
|
|
|
console.error(error);
|
|
|
|
return [];
|
|
|
|
}
|
|
|
|
});
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
function loadLayout(items) {
|
|
|
|
// Remove layout.
|
|
|
|
grid.removeAll();
|
|
|
|
// Update.
|
|
|
|
grid.batchUpdate();
|
|
|
|
// Add widgets.
|
|
|
|
items.forEach(function(item) {
|
|
|
|
var id = parseInt(item.id);
|
|
|
|
var position = item.position;
|
|
|
|
var widgetId = item.widgetId;
|
|
|
|
// Retrocompatibility old dashboard.
|
|
|
|
position = {
|
|
|
|
x: 0,
|
|
|
|
y: 0,
|
|
|
|
width: 4,
|
|
|
|
height: 4,
|
|
|
|
autoPosition: true,
|
|
|
|
minWidth: 0,
|
|
|
|
maxWidth: 2000,
|
|
|
|
minHeight: 0,
|
|
|
|
maxHeight: 2000
|
|
|
|
};
|
|
|
|
if (item.position !== "") {
|
|
|
|
position = JSON.parse(item.position);
|
|
|
|
}
|
|
|
|
addCell(
|
|
|
|
id,
|
|
|
|
position.x,
|
|
|
|
position.y,
|
|
|
|
position.width,
|
|
|
|
position.height,
|
|
|
|
position.autoPosition,
|
|
|
|
position.minWidth,
|
|
|
|
position.maxWidth,
|
|
|
|
position.minHeight,
|
|
|
|
position.maxHeight,
|
2020-07-22 10:56:16 +02:00
|
|
|
widgetId,
|
|
|
|
false
|
2020-03-26 12:29:38 +01:00
|
|
|
);
|
|
|
|
});
|
|
|
|
// Commit.
|
|
|
|
grid.commit();
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
function addCell(
|
|
|
|
id,
|
|
|
|
x,
|
|
|
|
y,
|
|
|
|
width,
|
|
|
|
height,
|
|
|
|
autoPosition,
|
|
|
|
minWidth,
|
|
|
|
maxWidth,
|
|
|
|
minHeight,
|
|
|
|
maxHeight,
|
|
|
|
widgetId,
|
|
|
|
needSaveLayout = false
|
|
|
|
) {
|
|
|
|
$.ajax({
|
|
|
|
method: "post",
|
|
|
|
url: data.url,
|
|
|
|
data: {
|
|
|
|
page: data.page,
|
|
|
|
method: "drawCell",
|
|
|
|
dashboardId: data.dashboardId,
|
|
|
|
cellId: id,
|
|
|
|
widgetId: widgetId,
|
2020-07-22 10:56:16 +02:00
|
|
|
gridWidth: gridWidth,
|
|
|
|
auth_class: data.auth.class,
|
|
|
|
auth_hash: data.auth.hash,
|
|
|
|
id_user: data.auth.user
|
2020-03-26 12:29:38 +01:00
|
|
|
},
|
|
|
|
dataType: "html",
|
|
|
|
success: function(cellData) {
|
|
|
|
var elem = grid.addWidget(
|
|
|
|
cellData,
|
|
|
|
x,
|
|
|
|
y,
|
|
|
|
width,
|
|
|
|
height,
|
|
|
|
autoPosition,
|
|
|
|
minWidth,
|
|
|
|
maxWidth,
|
|
|
|
minHeight,
|
|
|
|
maxHeight,
|
|
|
|
id
|
|
|
|
);
|
|
|
|
|
|
|
|
// Add spinner.
|
|
|
|
var element = $("#widget-" + id);
|
|
|
|
element = element[0].querySelector(".content-widget");
|
|
|
|
addSpinner(element);
|
|
|
|
|
|
|
|
// Width and height.
|
2020-12-02 14:26:20 +01:00
|
|
|
var newWidth = $(elem).attr("data-gs-width");
|
|
|
|
var newHeight = $(elem).attr("data-gs-height");
|
2020-03-26 12:29:38 +01:00
|
|
|
|
|
|
|
$.ajax({
|
|
|
|
method: "post",
|
|
|
|
url: data.url,
|
|
|
|
data: {
|
|
|
|
page: data.page,
|
|
|
|
method: "drawWidget",
|
|
|
|
dashboardId: data.dashboardId,
|
|
|
|
cellId: id,
|
|
|
|
widgetId: widgetId,
|
|
|
|
newWidth: newWidth,
|
|
|
|
newHeight: newHeight,
|
2020-07-22 10:56:16 +02:00
|
|
|
gridWidth: gridWidth,
|
|
|
|
auth_class: data.auth.class,
|
|
|
|
auth_hash: data.auth.hash,
|
|
|
|
id_user: data.auth.user
|
2020-03-26 12:29:38 +01:00
|
|
|
},
|
|
|
|
dataType: "html",
|
|
|
|
success: function(widgetData) {
|
|
|
|
// Remove spinner.
|
|
|
|
removeSpinner(element);
|
|
|
|
$("#widget-" + id + " .content-widget").append(widgetData);
|
|
|
|
|
|
|
|
$("#button-add-widget-" + id).click(function() {
|
|
|
|
addWidgetDialog(id);
|
|
|
|
});
|
|
|
|
|
|
|
|
if (!$("#checkbox-edit-mode").is(":checked")) {
|
|
|
|
$(".add-widget").hide();
|
|
|
|
} else {
|
|
|
|
$(".new-widget-message").hide();
|
|
|
|
}
|
|
|
|
|
|
|
|
if (needSaveLayout === true) {
|
|
|
|
var parentElement = $("#widget-" + id).parent();
|
|
|
|
grid.enableMove(parentElement, true);
|
|
|
|
grid.enableResize(parentElement, true);
|
2020-12-02 14:26:20 +01:00
|
|
|
grid.float(false);
|
2020-03-26 12:29:38 +01:00
|
|
|
}
|
|
|
|
},
|
|
|
|
error: function(error) {
|
|
|
|
console.error(error);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
if (needSaveLayout === true) {
|
|
|
|
saveLayout();
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!$("#checkbox-edit-mode").is(":checked")) {
|
|
|
|
$(".header-options").hide();
|
|
|
|
}
|
|
|
|
|
|
|
|
$("#delete-widget-" + id).click(function(event) {
|
2020-04-27 16:40:50 +02:00
|
|
|
// eslint-disable-next-line no-undef
|
|
|
|
confirmDialog({
|
|
|
|
title: "Are you sure?",
|
2020-04-28 10:12:20 +02:00
|
|
|
message:
|
2022-06-27 18:07:01 +02:00
|
|
|
"<h3 style='text-align: center;padding-top: 20px;'>All changes made to this widget will be lost</h3>",
|
2020-04-27 16:40:50 +02:00
|
|
|
cancel: "Cancel",
|
|
|
|
ok: "Ok",
|
2023-02-23 10:11:35 +01:00
|
|
|
size: 400,
|
2020-04-27 16:40:50 +02:00
|
|
|
onAccept: function() {
|
|
|
|
// Continue execution.
|
|
|
|
var nodo = event.target.offsetParent;
|
|
|
|
deleteCell(id, nodo.parentNode);
|
|
|
|
}
|
|
|
|
});
|
2020-03-26 12:29:38 +01:00
|
|
|
});
|
|
|
|
|
|
|
|
$("#configure-widget-" + id).click(function() {
|
2022-05-18 12:55:10 +02:00
|
|
|
getSizeModalConfiguration(id, widgetId);
|
2020-03-26 12:29:38 +01:00
|
|
|
});
|
|
|
|
},
|
|
|
|
error: function(error) {
|
|
|
|
console.error(error);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2022-05-18 12:55:10 +02:00
|
|
|
function getSizeModalConfiguration(cellId, widgetId) {
|
|
|
|
$.ajax({
|
|
|
|
method: "post",
|
|
|
|
url: data.url,
|
|
|
|
data: {
|
|
|
|
page: data.page,
|
|
|
|
method: "getSizeModalConfiguration",
|
|
|
|
dashboardId: data.dashboardId,
|
|
|
|
cellId: cellId,
|
|
|
|
widgetId: widgetId
|
|
|
|
},
|
|
|
|
dataType: "json",
|
|
|
|
success: function(size) {
|
|
|
|
configurationWidget(cellId, widgetId, size);
|
|
|
|
},
|
|
|
|
error: function(error) {
|
|
|
|
console.log(error);
|
|
|
|
return [];
|
|
|
|
}
|
|
|
|
});
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2020-03-26 12:29:38 +01:00
|
|
|
function saveLayout() {
|
|
|
|
var items = $(".grid-stack > .grid-stack-item:visible")
|
|
|
|
.map(function(i, el) {
|
|
|
|
el = $(el);
|
|
|
|
var node = el.data("_gridstack_node");
|
|
|
|
return {
|
|
|
|
id: node.id,
|
|
|
|
x: node.x,
|
|
|
|
y: node.y,
|
|
|
|
width: node.width,
|
|
|
|
height: node.height
|
|
|
|
};
|
|
|
|
})
|
|
|
|
.toArray();
|
|
|
|
|
|
|
|
$.ajax({
|
|
|
|
method: "post",
|
|
|
|
url: data.url,
|
|
|
|
data: {
|
|
|
|
page: data.page,
|
|
|
|
method: "saveLayout",
|
|
|
|
dashboardId: data.dashboardId,
|
2020-07-22 10:56:16 +02:00
|
|
|
items: items,
|
|
|
|
auth_class: data.auth.class,
|
|
|
|
auth_hash: data.auth.hash,
|
|
|
|
id_user: data.auth.user
|
2020-03-26 12:29:38 +01:00
|
|
|
},
|
|
|
|
dataType: "html",
|
|
|
|
success: function(data) {
|
2021-04-06 14:20:07 +02:00
|
|
|
return data;
|
2020-03-26 12:29:38 +01:00
|
|
|
},
|
|
|
|
error: function(error) {
|
|
|
|
console.error(error);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
function deleteCell(cellId, node) {
|
|
|
|
$.ajax({
|
|
|
|
method: "post",
|
|
|
|
url: data.url,
|
|
|
|
data: {
|
|
|
|
page: data.page,
|
|
|
|
dashboardId: data.dashboardId,
|
|
|
|
method: "deleteCell",
|
2020-07-22 10:56:16 +02:00
|
|
|
cellId: cellId,
|
|
|
|
auth_class: data.auth.class,
|
|
|
|
auth_hash: data.auth.hash,
|
|
|
|
id_user: data.auth.user
|
2020-03-26 12:29:38 +01:00
|
|
|
},
|
|
|
|
dataType: "json",
|
|
|
|
success: function(data) {
|
2020-07-22 10:56:16 +02:00
|
|
|
// By default x and y = 0
|
2020-03-26 12:29:38 +01:00
|
|
|
// width and height = 4
|
|
|
|
// position auto = true.
|
|
|
|
if (data.result !== 0) {
|
|
|
|
grid.removeWidget(node);
|
|
|
|
saveLayout();
|
|
|
|
}
|
|
|
|
},
|
|
|
|
error: function(error) {
|
|
|
|
console.error(error);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
function insertCellLayout() {
|
|
|
|
$.ajax({
|
|
|
|
method: "post",
|
|
|
|
url: data.url,
|
|
|
|
data: {
|
|
|
|
page: data.page,
|
|
|
|
method: "insertCellLayout",
|
2020-07-22 10:56:16 +02:00
|
|
|
dashboardId: data.dashboardId,
|
|
|
|
auth_class: data.auth.class,
|
|
|
|
auth_hash: data.auth.hash,
|
|
|
|
id_user: data.auth.user
|
2020-03-26 12:29:38 +01:00
|
|
|
},
|
|
|
|
dataType: "json",
|
|
|
|
success: function(data) {
|
2020-07-22 10:56:16 +02:00
|
|
|
// By default x and y = 0
|
2020-03-26 12:29:38 +01:00
|
|
|
// width and height = 4
|
|
|
|
// position auto = true.
|
|
|
|
if (data.cellId !== 0) {
|
|
|
|
addCell(data.cellId, 0, 0, 4, 4, true, 0, 2000, 0, 2000, 0, true);
|
|
|
|
}
|
|
|
|
},
|
|
|
|
error: function(error) {
|
|
|
|
console.error(error);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2022-05-18 12:55:10 +02:00
|
|
|
function configurationWidget(cellId, widgetId, size) {
|
2020-03-26 12:29:38 +01:00
|
|
|
load_modal({
|
|
|
|
target: $("#modal-config-widget"),
|
|
|
|
form: "form-config-widget",
|
|
|
|
url: data.url,
|
|
|
|
modal: {
|
|
|
|
title: "Configure widget",
|
|
|
|
cancel: "Cancel",
|
|
|
|
ok: "Ok"
|
|
|
|
},
|
|
|
|
onshow: {
|
|
|
|
page: data.page,
|
|
|
|
method: "drawConfiguration",
|
|
|
|
extradata: {
|
|
|
|
cellId: cellId,
|
|
|
|
dashboardId: data.dashboardId,
|
|
|
|
widgetId: widgetId
|
|
|
|
},
|
2022-05-18 12:55:10 +02:00
|
|
|
width: size.width,
|
|
|
|
minHeight: size.height
|
2020-03-26 12:29:38 +01:00
|
|
|
},
|
|
|
|
onsubmit: {
|
|
|
|
page: data.page,
|
|
|
|
method: "saveWidgetIntoCell",
|
|
|
|
dataType: "json",
|
|
|
|
preaction: function() {
|
|
|
|
if (tinyMCE != undefined && tinyMCE.editors.length > 0 && widgetId) {
|
|
|
|
// Content tiny.
|
|
|
|
var label = tinyMCE.activeEditor.getContent();
|
|
|
|
$("#textarea_text").val(label);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
},
|
|
|
|
ajax_callback: update_widget_to_cell,
|
|
|
|
onsubmitClose: 1,
|
|
|
|
beforeClose: function() {
|
|
|
|
tinyMCE.remove("#textarea_text");
|
|
|
|
tinyMCE.execCommand("mceRemoveControl", true, "textarea_text");
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
function update_widget_to_cell(data) {
|
|
|
|
if (data.error === 1) {
|
|
|
|
console.error(data.text);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Add spinner.
|
|
|
|
var element = $("#widget-" + data.cellId);
|
|
|
|
element = element[0].querySelector(".content-widget");
|
|
|
|
addSpinner(element);
|
|
|
|
|
|
|
|
// Width and height.
|
|
|
|
var newWidth = $("#widget-" + data.cellId)
|
|
|
|
.parent()
|
|
|
|
.attr("data-gs-width");
|
|
|
|
|
|
|
|
var newHeight = $("#widget-" + data.cellId)
|
|
|
|
.parent()
|
|
|
|
.attr("data-gs-height");
|
|
|
|
|
|
|
|
redraw(data.cellId, newWidth, newHeight, gridWidth, data.widgetId);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Operations.
|
|
|
|
// Add Widgets.
|
|
|
|
$("#add-widget").click(function() {
|
|
|
|
insertCellLayout();
|
|
|
|
});
|
|
|
|
|
|
|
|
// Enable Layout.
|
|
|
|
$("#checkbox-edit-mode").click(function() {
|
|
|
|
if ($("#checkbox-edit-mode").is(":checked")) {
|
|
|
|
grid.movable(".grid-stack-item", true);
|
|
|
|
grid.resizable(".grid-stack-item", true);
|
2020-12-02 14:26:20 +01:00
|
|
|
grid.float(false);
|
2020-03-26 12:29:38 +01:00
|
|
|
$(".header-options").show();
|
|
|
|
$(".add-widget").show();
|
|
|
|
$(".new-widget-message").hide();
|
|
|
|
$("#container-layout").addClass("container-layout");
|
2021-03-15 15:42:22 +01:00
|
|
|
$("#add-widget").removeClass("invisible");
|
2020-03-26 12:29:38 +01:00
|
|
|
} else {
|
|
|
|
grid.movable(".grid-stack-item", false);
|
|
|
|
grid.resizable(".grid-stack-item", false);
|
2020-12-02 14:26:20 +01:00
|
|
|
grid.float(true);
|
2020-03-26 12:29:38 +01:00
|
|
|
$(".header-options").hide();
|
|
|
|
$(".add-widget").hide();
|
|
|
|
$(".new-widget-message").show();
|
|
|
|
$("#container-layout").removeClass("container-layout");
|
2021-03-15 15:42:22 +01:00
|
|
|
$("#add-widget").addClass("invisible");
|
2020-03-26 12:29:38 +01:00
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
// End drag.
|
|
|
|
$(".grid-stack").on("dragstop", function() {
|
|
|
|
setTimeout(function() {
|
|
|
|
saveLayout();
|
|
|
|
}, 200);
|
|
|
|
});
|
|
|
|
|
|
|
|
// Start Resize.
|
|
|
|
$(".grid-stack").on("resizestart", function(event) {
|
|
|
|
var element = event.target.querySelector(".content-widget");
|
|
|
|
addSpinner(element);
|
|
|
|
});
|
|
|
|
|
|
|
|
// End Resize.
|
|
|
|
$(".grid-stack").on("gsresizestop", function(event, elem) {
|
|
|
|
var grid = this;
|
|
|
|
|
|
|
|
// Grid Height and Width.
|
|
|
|
var positionGrid = grid.getBoundingClientRect();
|
|
|
|
// var gridHeight = positionGrid.height;
|
|
|
|
var gridWidth = positionGrid.width;
|
|
|
|
|
|
|
|
// Width and height.
|
|
|
|
var newWidth = $(elem).attr("data-gs-width");
|
|
|
|
var newHeight = $(elem).attr("data-gs-height");
|
|
|
|
|
|
|
|
var cellId = elem.getAttribute("data-gs-id");
|
|
|
|
|
|
|
|
redraw(cellId, newWidth, newHeight, gridWidth);
|
|
|
|
});
|
|
|
|
|
|
|
|
// Add Spinner
|
|
|
|
function addSpinner(element) {
|
|
|
|
var divParent = document.createElement("div");
|
|
|
|
divParent.className = "div-dashboard-spinner";
|
|
|
|
|
|
|
|
var divSpinner = document.createElement("div");
|
|
|
|
divSpinner.className = "dashboard-spinner";
|
|
|
|
divParent.appendChild(divSpinner);
|
|
|
|
|
|
|
|
element.innerHTML = "";
|
|
|
|
|
|
|
|
element.appendChild(divParent);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Remove Spinner
|
|
|
|
function removeSpinner(element) {
|
|
|
|
// Div resize.
|
|
|
|
var div = element.querySelector(".div-dashboard-spinner");
|
|
|
|
if (div !== null) {
|
|
|
|
var parent = div.parentElement;
|
|
|
|
if (parent !== null) {
|
|
|
|
parent.removeChild(div);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
function addWidgetDialog(id) {
|
|
|
|
$("#modal-add-widget")
|
|
|
|
.dialog({
|
2022-12-05 17:20:08 +01:00
|
|
|
title: data.title,
|
2020-03-26 12:29:38 +01:00
|
|
|
resizable: false,
|
|
|
|
modal: true,
|
|
|
|
overlay: {
|
|
|
|
opacity: 0.5,
|
|
|
|
background: "black"
|
|
|
|
},
|
|
|
|
width: 600,
|
|
|
|
height: 600,
|
|
|
|
open: function() {
|
|
|
|
loadWidgetsDialog(id, 0);
|
|
|
|
}
|
|
|
|
})
|
|
|
|
.show();
|
|
|
|
}
|
|
|
|
|
|
|
|
function loadWidgetsDialog(cellId, offset, search) {
|
|
|
|
$.ajax({
|
|
|
|
method: "post",
|
|
|
|
url: data.url,
|
|
|
|
data: {
|
|
|
|
dashboardId: data.dashboardId,
|
|
|
|
page: data.page,
|
|
|
|
method: "drawAddWidget",
|
|
|
|
cellId: cellId,
|
|
|
|
offset: offset,
|
2020-07-22 10:56:16 +02:00
|
|
|
search: search,
|
|
|
|
auth_class: data.auth.class,
|
|
|
|
auth_hash: data.auth.hash,
|
|
|
|
id_user: data.auth.user
|
2020-03-26 12:29:38 +01:00
|
|
|
},
|
|
|
|
dataType: "html",
|
|
|
|
success: function(data) {
|
|
|
|
$("#modal-add-widget").empty();
|
|
|
|
$("#modal-add-widget").append(data);
|
2023-03-02 14:25:52 +01:00
|
|
|
$("a.pandora_pagination").click(function() {
|
2020-03-26 12:29:38 +01:00
|
|
|
var offset = $(this)
|
|
|
|
.attr("href")
|
|
|
|
.split("=")
|
|
|
|
.pop();
|
|
|
|
|
|
|
|
loadWidgetsDialog(cellId, offset, search);
|
|
|
|
});
|
|
|
|
|
|
|
|
document.getElementById("text-search-widget").focus();
|
|
|
|
if (typeof search !== "undefined") {
|
|
|
|
document.getElementById("text-search-widget").value = "";
|
|
|
|
document.getElementById("text-search-widget").value = search;
|
|
|
|
}
|
|
|
|
|
|
|
|
$("input[name=search-widget]").on(
|
|
|
|
"keyup",
|
|
|
|
debounce(function() {
|
|
|
|
loadWidgetsDialog(cellId, 0, this.value);
|
|
|
|
}, 300)
|
|
|
|
);
|
|
|
|
|
|
|
|
$(".img-add-widget").click(function() {
|
|
|
|
// Empty and close modal.
|
|
|
|
$("#modal-add-widget").empty();
|
|
|
|
$("#modal-add-widget").dialog("close");
|
|
|
|
|
|
|
|
// Extract Id widget
|
|
|
|
var widgetId = this.id.replace("img-add-widget-", "");
|
|
|
|
|
|
|
|
// Add spinner.
|
|
|
|
var element = $("#widget-" + cellId);
|
|
|
|
element = element[0].querySelector(".content-widget");
|
|
|
|
addSpinner(element);
|
|
|
|
|
|
|
|
// Width and height.
|
|
|
|
var newWidth = $("#widget-" + data.cellId)
|
|
|
|
.parent()
|
|
|
|
.attr("data-gs-width");
|
|
|
|
|
|
|
|
var newHeight = $("#widget-" + data.cellId)
|
|
|
|
.parent()
|
|
|
|
.attr("data-gs-height");
|
|
|
|
|
|
|
|
redraw(cellId, newWidth, newHeight, gridWidth, widgetId);
|
|
|
|
});
|
|
|
|
},
|
|
|
|
error: function(error) {
|
|
|
|
console.error(error);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
function redraw(cellId, newWidth, newHeight, gridWidth, widgetId = 0) {
|
|
|
|
$.ajax({
|
|
|
|
method: "post",
|
|
|
|
url: data.url,
|
|
|
|
data: {
|
|
|
|
page: data.page,
|
|
|
|
method: "drawCell",
|
|
|
|
dashboardId: data.dashboardId,
|
|
|
|
cellId: cellId,
|
|
|
|
widgetId: widgetId,
|
|
|
|
gridWidth: gridWidth,
|
2020-07-22 10:56:16 +02:00
|
|
|
redraw: true,
|
|
|
|
auth_class: data.auth.class,
|
|
|
|
auth_hash: data.auth.hash,
|
|
|
|
id_user: data.auth.user
|
2020-03-26 12:29:38 +01:00
|
|
|
},
|
|
|
|
dataType: "html",
|
|
|
|
success: function(cellData) {
|
|
|
|
var element = $("#widget-" + cellId);
|
|
|
|
|
|
|
|
// Widget empty.
|
|
|
|
element.empty();
|
|
|
|
|
|
|
|
// Add Resize element.
|
|
|
|
element.append(cellData);
|
|
|
|
|
|
|
|
// Add spinner.
|
|
|
|
var elementSpinner = element[0].querySelector(".content-widget");
|
|
|
|
addSpinner(elementSpinner);
|
|
|
|
|
|
|
|
$.ajax({
|
|
|
|
method: "post",
|
|
|
|
url: data.url,
|
|
|
|
data: {
|
|
|
|
page: data.page,
|
|
|
|
method: "drawWidget",
|
|
|
|
dashboardId: data.dashboardId,
|
|
|
|
cellId: cellId,
|
|
|
|
newWidth: newWidth,
|
|
|
|
newHeight: newHeight,
|
|
|
|
gridWidth: gridWidth,
|
2020-07-22 10:56:16 +02:00
|
|
|
widgetId: widgetId,
|
|
|
|
auth_class: data.auth.class,
|
|
|
|
auth_hash: data.auth.hash,
|
|
|
|
id_user: data.auth.user
|
2020-03-26 12:29:38 +01:00
|
|
|
},
|
|
|
|
dataType: "html",
|
|
|
|
success: function(dataWidget) {
|
|
|
|
var element = $("#widget-" + cellId);
|
|
|
|
element = element[0].querySelector(".content-widget");
|
|
|
|
removeSpinner(element);
|
|
|
|
|
|
|
|
// Widget empty.
|
|
|
|
$("#widget-" + cellId + " .content-widget").empty();
|
|
|
|
|
|
|
|
// Add Resize element.
|
|
|
|
$("#widget-" + cellId + " .content-widget").append(dataWidget);
|
|
|
|
|
|
|
|
$("#button-add-widget-" + cellId).click(function() {
|
|
|
|
addWidgetDialog(cellId);
|
|
|
|
});
|
|
|
|
|
|
|
|
if (!$("#checkbox-edit-mode").is(":checked")) {
|
|
|
|
$(".add-widget").hide();
|
|
|
|
} else {
|
|
|
|
$(".new-widget-message").hide();
|
|
|
|
}
|
|
|
|
},
|
|
|
|
error: function(error) {
|
|
|
|
console.error(error);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
if (!$("#checkbox-edit-mode").is(":checked")) {
|
|
|
|
$(".header-options").hide();
|
|
|
|
}
|
|
|
|
|
|
|
|
$("#delete-widget-" + cellId).click(function(event) {
|
2020-05-11 14:50:13 +02:00
|
|
|
// eslint-disable-next-line no-undef
|
|
|
|
confirmDialog({
|
|
|
|
title: "Are you sure?",
|
|
|
|
message:
|
2022-06-27 18:07:01 +02:00
|
|
|
"<h3 style='text-align: center;padding-top: 20px;'>All changes made to this widget will be lost</h3>",
|
2020-05-11 14:50:13 +02:00
|
|
|
cancel: "Cancel",
|
|
|
|
ok: "Ok",
|
|
|
|
onAccept: function() {
|
|
|
|
// Continue execution.
|
|
|
|
var nodo = event.target.offsetParent;
|
|
|
|
deleteCell(cellId, nodo.parentNode);
|
|
|
|
}
|
|
|
|
});
|
2020-03-26 12:29:38 +01:00
|
|
|
});
|
|
|
|
|
|
|
|
$("#configure-widget-" + cellId).click(function() {
|
2022-05-18 12:55:10 +02:00
|
|
|
getSizeModalConfiguration(cellId, widgetId);
|
2020-03-26 12:29:38 +01:00
|
|
|
});
|
|
|
|
|
|
|
|
saveLayout();
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Onchange input image.
|
|
|
|
* @return {void}
|
|
|
|
*/
|
|
|
|
// eslint-disable-next-line no-unused-vars
|
|
|
|
function imageIconChange(data) {
|
|
|
|
data = JSON.parse(atob(data));
|
|
|
|
|
|
|
|
var nameImg = document.getElementById("imageSrc").value;
|
|
|
|
|
|
|
|
if (nameImg == 0) {
|
|
|
|
$("#li-image-item label").empty();
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
$.ajax({
|
|
|
|
method: "post",
|
|
|
|
url: data.url,
|
|
|
|
data: {
|
|
|
|
page: data.page,
|
|
|
|
method: "imageIconDashboardAjax",
|
|
|
|
nameImg: nameImg,
|
|
|
|
dashboardId: data.dashboardId
|
|
|
|
},
|
|
|
|
dataType: "html",
|
|
|
|
success: function(data) {
|
|
|
|
$("#li-image-item label").empty();
|
|
|
|
$("#li-image-item label").append(data);
|
|
|
|
},
|
|
|
|
error: function(error) {
|
|
|
|
console.error(error);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Load network map.
|
|
|
|
* @return {void}
|
|
|
|
*/
|
|
|
|
// eslint-disable-next-line no-unused-vars
|
|
|
|
function dashboardLoadNetworkMap(settings) {
|
|
|
|
// Add spinner.
|
|
|
|
var element = document.getElementById("body_cell-" + settings.cellId);
|
|
|
|
|
|
|
|
var divParent = document.createElement("div");
|
|
|
|
divParent.id = "div-dashboard-spinner-" + settings.cellId;
|
|
|
|
divParent.className = "div-dashboard-spinner";
|
|
|
|
var divSpinner = document.createElement("div");
|
|
|
|
divSpinner.className = "dashboard-spinner";
|
|
|
|
divParent.appendChild(divSpinner);
|
|
|
|
|
|
|
|
element.appendChild(divParent);
|
|
|
|
|
|
|
|
$.ajax({
|
|
|
|
method: "post",
|
|
|
|
url: settings.url,
|
|
|
|
data: {
|
|
|
|
page: settings.page,
|
|
|
|
networkmap: 1,
|
|
|
|
networkmap_id: settings.networkmap_id,
|
|
|
|
x_offset: settings.x_offset,
|
|
|
|
y_offset: settings.y_offset,
|
|
|
|
zoom_dash: settings.zoom_dash,
|
2020-07-22 10:56:16 +02:00
|
|
|
auth_class: settings.auth_class,
|
|
|
|
auth_hash: settings.auth_hash,
|
2021-01-15 13:52:31 +01:00
|
|
|
id_user: settings.id_user,
|
2021-04-06 16:47:32 +02:00
|
|
|
ignore_acl: 1,
|
2023-03-13 19:30:51 +01:00
|
|
|
node: settings.node,
|
|
|
|
dashboard: 1,
|
|
|
|
size: settings.size
|
2020-03-26 12:29:38 +01:00
|
|
|
},
|
|
|
|
dataType: "html",
|
|
|
|
success: function(data) {
|
|
|
|
$("#div-dashboard-spinner-" + settings.cellId).remove();
|
|
|
|
$("#body_cell-" + settings.cellId).append(data);
|
|
|
|
},
|
|
|
|
error: function(error) {
|
|
|
|
console.error(error);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Load Wux Stats map.
|
|
|
|
* @return {void}
|
|
|
|
*/
|
|
|
|
// eslint-disable-next-line no-unused-vars
|
|
|
|
function dashboardLoadWuxStats(settings) {
|
|
|
|
$.ajax({
|
|
|
|
method: "post",
|
|
|
|
url: settings.url,
|
|
|
|
data: {
|
|
|
|
page: settings.page,
|
|
|
|
wux_transaction_stats: 1,
|
|
|
|
id_agent: settings.id_agent,
|
2021-07-13 17:26:03 +02:00
|
|
|
server_id: settings.server_id,
|
2020-03-26 12:29:38 +01:00
|
|
|
transaction: settings.transaction,
|
|
|
|
view_all_stats: settings.view_all_stats,
|
2020-07-22 10:56:16 +02:00
|
|
|
auth_class: settings.auth_class,
|
|
|
|
auth_hash: settings.auth_hash,
|
2020-03-26 12:29:38 +01:00
|
|
|
id_user: settings.id_user
|
|
|
|
},
|
|
|
|
dataType: "html",
|
|
|
|
success: function(data) {
|
|
|
|
$("#body-cell-" + settings.cellId).append(data);
|
|
|
|
},
|
|
|
|
error: function(error) {
|
|
|
|
console.error(error);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
// eslint-disable-next-line no-unused-vars
|
|
|
|
function processTreeSearch(settings) {
|
|
|
|
var treeController = TreeController.getController();
|
|
|
|
|
|
|
|
// Clear the tree
|
|
|
|
if (
|
|
|
|
typeof treeController.recipient != "undefined" &&
|
|
|
|
treeController.recipient.length > 0
|
|
|
|
) {
|
|
|
|
treeController.recipient.empty();
|
|
|
|
}
|
|
|
|
|
|
|
|
var filters = {};
|
|
|
|
filters.searchAgent = settings.searchAgent;
|
|
|
|
filters.statusAgent = settings.statusAgent;
|
|
|
|
filters.searchModule = settings.searchModule;
|
|
|
|
filters.statusModule = settings.statusModule;
|
|
|
|
filters.groupID = settings.searchGroup;
|
2021-05-13 10:11:58 +02:00
|
|
|
filters.searchHirearchy = 1;
|
2021-07-07 17:17:36 +02:00
|
|
|
filters.show_not_init_agents = 1;
|
|
|
|
filters.show_not_init_modules = 1;
|
2020-03-26 12:29:38 +01:00
|
|
|
|
|
|
|
$.ajax({
|
|
|
|
type: "POST",
|
|
|
|
url: settings.ajaxUrl,
|
|
|
|
data: {
|
|
|
|
getChildren: 1,
|
|
|
|
page: settings.page,
|
|
|
|
type: settings.type,
|
2020-07-22 10:56:16 +02:00
|
|
|
auth_class: settings.auth_class,
|
|
|
|
auth_hash: settings.auth_hash,
|
|
|
|
id_user: settings.id_user,
|
2020-03-26 12:29:38 +01:00
|
|
|
filter: filters
|
|
|
|
},
|
|
|
|
success: function(data) {
|
|
|
|
if (data.success) {
|
|
|
|
treeController.init({
|
|
|
|
recipient: $("div#tree-controller-recipient_" + settings.cellId),
|
|
|
|
detailRecipient: {
|
|
|
|
render: function(element, data) {
|
|
|
|
return {
|
|
|
|
open: function() {
|
|
|
|
$("#module_details_window")
|
|
|
|
.hide()
|
|
|
|
.empty()
|
|
|
|
.append(data)
|
|
|
|
.dialog({
|
|
|
|
resizable: true,
|
|
|
|
draggable: true,
|
|
|
|
modal: true,
|
|
|
|
title: "Info module",
|
|
|
|
overlay: {
|
|
|
|
opacity: 0.5,
|
|
|
|
background: "black"
|
|
|
|
},
|
|
|
|
width: 450,
|
|
|
|
height: 500
|
|
|
|
});
|
|
|
|
}
|
|
|
|
};
|
|
|
|
}
|
|
|
|
},
|
|
|
|
page: settings.page,
|
|
|
|
emptyMessage: settings.translate.emptyMessage,
|
|
|
|
foundMessage: settings.translate.foundMessage,
|
|
|
|
tree: data.tree,
|
2020-07-22 10:56:16 +02:00
|
|
|
auth_hash: settings.auth_hash,
|
|
|
|
auth_class: settings.auth_class,
|
|
|
|
id_user: settings.id_user,
|
2020-03-26 12:29:38 +01:00
|
|
|
ajaxURL: settings.ajaxUrl,
|
2020-07-22 10:56:16 +02:00
|
|
|
baseURL: settings.baseUrl,
|
2020-03-26 12:29:38 +01:00
|
|
|
filter: filters,
|
|
|
|
counterTitles: {
|
|
|
|
total: {
|
|
|
|
agents: settings.translate.total.agents,
|
|
|
|
modules: settings.translate.total.modules,
|
|
|
|
none: settings.translate.total.none
|
|
|
|
},
|
|
|
|
alerts: {
|
|
|
|
agents: settings.translate.alerts.agents,
|
|
|
|
modules: settings.translate.alerts.modules,
|
|
|
|
none: settings.translate.alerts.none
|
|
|
|
},
|
|
|
|
critical: {
|
|
|
|
agents: settings.translate.critical.agents,
|
|
|
|
modules: settings.translate.critical.modules,
|
|
|
|
none: settings.translate.critical.none
|
|
|
|
},
|
|
|
|
warning: {
|
|
|
|
agents: settings.translate.warning.agents,
|
|
|
|
modules: settings.translate.warning.modules,
|
|
|
|
none: settings.translate.warning.none
|
|
|
|
},
|
|
|
|
unknown: {
|
|
|
|
agents: settings.translate.unknown.agents,
|
|
|
|
modules: settings.translate.unknown.modules,
|
|
|
|
none: settings.translate.unknown.none
|
|
|
|
},
|
|
|
|
not_init: {
|
|
|
|
agents: settings.translate.not_init.agents,
|
|
|
|
modules: settings.translate.not_init.modules,
|
|
|
|
none: settings.translate.not_init.none
|
|
|
|
},
|
|
|
|
ok: {
|
|
|
|
agents: settings.translate.ok.agents,
|
|
|
|
modules: settings.translate.ok.modules,
|
|
|
|
none: settings.translate.ok.none
|
2023-02-13 15:03:23 +01:00
|
|
|
},
|
|
|
|
not_normal: {
|
|
|
|
agents: settings.translate.not_normal.agents,
|
|
|
|
modules: settings.translate.not_normal.modules,
|
|
|
|
none: settings.translate.not_normal.none
|
2020-03-26 12:29:38 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
if (settings.openAllNodes) {
|
|
|
|
$("#widget-" + settings.cellId)
|
|
|
|
.find(".leaf-icon")
|
|
|
|
.click();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
},
|
|
|
|
dataType: "json"
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2021-08-13 14:12:21 +02:00
|
|
|
function processServiceTree(settings) {
|
|
|
|
var treeController = TreeController.getController();
|
|
|
|
|
|
|
|
if (
|
|
|
|
typeof treeController.recipient != "undefined" &&
|
|
|
|
treeController.recipient.length > 0
|
|
|
|
)
|
|
|
|
treeController.recipient.empty();
|
|
|
|
|
|
|
|
$(".loading_tree").show();
|
|
|
|
|
|
|
|
var parameters = {};
|
|
|
|
parameters["page"] = "include/ajax/tree.ajax";
|
|
|
|
parameters["getChildren"] = 1;
|
|
|
|
parameters["type"] = "services";
|
|
|
|
parameters["filter"] = {};
|
|
|
|
parameters["filter"]["searchGroup"] = "";
|
|
|
|
parameters["filter"]["searchAgent"] = "";
|
|
|
|
parameters["filter"]["statusAgent"] = "";
|
|
|
|
parameters["filter"]["searchModule"] = "";
|
|
|
|
parameters["filter"]["statusModule"] = "";
|
|
|
|
parameters["filter"]["groupID"] = "";
|
|
|
|
parameters["filter"]["tagID"] = "";
|
|
|
|
parameters["filter"]["searchHirearchy"] = 1;
|
|
|
|
parameters["filter"]["show_not_init_agents"] = 1;
|
|
|
|
parameters["filter"]["show_not_init_modules"] = 1;
|
|
|
|
parameters["filter"]["is_favourite"] = 0;
|
|
|
|
parameters["filter"]["width"] = 100;
|
|
|
|
|
|
|
|
$.ajax({
|
|
|
|
type: "POST",
|
|
|
|
url: settings.ajaxURL,
|
|
|
|
data: parameters,
|
|
|
|
success: function(data) {
|
|
|
|
if (data.success) {
|
|
|
|
$(".loading_tree").hide();
|
|
|
|
// Get the main values of the tree.
|
|
|
|
var rawTree = Object.values(data.tree);
|
|
|
|
// Sorting tree by description (TreeController.js).
|
|
|
|
rawTree.sort(function(a, b) {
|
|
|
|
var x = a.description.toLowerCase();
|
|
|
|
var y = b.description.toLowerCase();
|
|
|
|
if (x < y) {
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
if (x > y) {
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
return 0;
|
|
|
|
});
|
|
|
|
treeController.init({
|
|
|
|
recipient: $("div#container_servicemap_" + settings.cellId),
|
2021-09-21 13:22:37 +02:00
|
|
|
detailRecipient: {
|
|
|
|
render: function(element, data) {
|
|
|
|
return {
|
|
|
|
open: function() {
|
|
|
|
$("#module_details_window")
|
|
|
|
.hide()
|
|
|
|
.empty()
|
|
|
|
.append(data)
|
|
|
|
.dialog({
|
|
|
|
resizable: true,
|
|
|
|
draggable: true,
|
|
|
|
modal: true,
|
|
|
|
title: "Info",
|
|
|
|
overlay: {
|
|
|
|
opacity: 0.5,
|
|
|
|
background: "black"
|
|
|
|
},
|
|
|
|
width: 450,
|
|
|
|
height: 500
|
|
|
|
});
|
|
|
|
}
|
|
|
|
};
|
|
|
|
}
|
|
|
|
},
|
2021-08-13 14:12:21 +02:00
|
|
|
page: parameters["page"],
|
|
|
|
emptyMessage: "No data found",
|
|
|
|
foundMessage: "Found groups",
|
|
|
|
tree: rawTree,
|
|
|
|
baseURL: settings.baseURL,
|
|
|
|
ajaxURL: settings.ajaxURL,
|
|
|
|
filter: parameters["filter"],
|
|
|
|
counterTitles: {
|
|
|
|
total: {
|
|
|
|
agents: "Total agents",
|
|
|
|
modules: "Total modules",
|
|
|
|
none: "Total"
|
|
|
|
},
|
|
|
|
alerts: {
|
|
|
|
agents: "Fired alerts",
|
|
|
|
modules: "Fired alerts",
|
|
|
|
none: "Fired alerts"
|
|
|
|
},
|
|
|
|
critical: {
|
|
|
|
agents: "Critical agents",
|
|
|
|
modules: "Critical modules')",
|
|
|
|
none: "Critical"
|
|
|
|
},
|
|
|
|
warning: {
|
|
|
|
agents: "Warning agents",
|
|
|
|
modules: "Warning modules",
|
|
|
|
none: "Warning"
|
|
|
|
},
|
|
|
|
unknown: {
|
|
|
|
agents: "Unknown agents",
|
|
|
|
modules: "Unknown modules",
|
|
|
|
none: "Unknown"
|
|
|
|
},
|
|
|
|
not_init: {
|
|
|
|
agents: "Not init agents",
|
|
|
|
modules: "Not init modules",
|
|
|
|
none: "Not init"
|
|
|
|
},
|
|
|
|
ok: {
|
|
|
|
agents: " Normal agents ",
|
|
|
|
modules: " Normal modules ",
|
|
|
|
none: " Normal "
|
|
|
|
}
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
},
|
|
|
|
dataType: "json"
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2020-03-26 12:29:38 +01:00
|
|
|
function show_module_detail_dialog(
|
|
|
|
module_id,
|
|
|
|
id_agent,
|
|
|
|
server_name,
|
|
|
|
offset,
|
|
|
|
period,
|
|
|
|
module_name
|
|
|
|
) {
|
|
|
|
var params = {};
|
|
|
|
var f = new Date();
|
|
|
|
period = $("#period").val();
|
|
|
|
|
|
|
|
params.selection_mode = $("input[name=selection_mode]:checked").val();
|
|
|
|
if (!params.selection_mode) {
|
|
|
|
params.selection_mode = "fromnow";
|
|
|
|
}
|
|
|
|
|
|
|
|
params.date_from = $("#text-date_from").val();
|
|
|
|
if (!params.date_from) {
|
|
|
|
params.date_from =
|
|
|
|
f.getFullYear() + "/" + (f.getMonth() + 1) + "/" + f.getDate();
|
|
|
|
}
|
|
|
|
|
|
|
|
params.time_from = $("#text-time_from").val();
|
|
|
|
if (!params.time_from) {
|
|
|
|
params.time_from = f.getHours() + ":" + f.getMinutes();
|
|
|
|
}
|
|
|
|
|
|
|
|
params.date_to = $("#text-date_to").val();
|
|
|
|
if (!params.date_to) {
|
|
|
|
params.date_to =
|
|
|
|
f.getFullYear() + "/" + (f.getMonth() + 1) + "/" + f.getDate();
|
|
|
|
}
|
|
|
|
|
|
|
|
params.time_to = $("#text-time_to").val();
|
|
|
|
if (!params.time_to) {
|
|
|
|
params.time_to = f.getHours() + ":" + f.getMinutes();
|
|
|
|
}
|
|
|
|
|
|
|
|
params.page = "include/ajax/module";
|
|
|
|
params.get_module_detail = 1;
|
|
|
|
params.server_name = server_name;
|
|
|
|
params.id_agent = id_agent;
|
|
|
|
params.id_module = module_id;
|
|
|
|
params.offset = offset;
|
|
|
|
params.period = period;
|
|
|
|
|
|
|
|
$.ajax({
|
|
|
|
type: "POST",
|
|
|
|
url: "ajax.php",
|
|
|
|
data: params,
|
|
|
|
dataType: "html",
|
|
|
|
success: function(data) {
|
|
|
|
$("#module_details_window")
|
|
|
|
.hide()
|
|
|
|
.empty()
|
|
|
|
.append(data)
|
|
|
|
.dialog({
|
|
|
|
resizable: true,
|
|
|
|
draggable: true,
|
|
|
|
modal: true,
|
|
|
|
title: "Module: " + module_name,
|
|
|
|
overlay: {
|
|
|
|
opacity: 0.5,
|
|
|
|
background: "black"
|
|
|
|
},
|
|
|
|
width: 650,
|
|
|
|
height: 500
|
|
|
|
})
|
|
|
|
.show();
|
|
|
|
refresh_pagination_callback(
|
|
|
|
module_id,
|
|
|
|
id_agent,
|
|
|
|
server_name,
|
|
|
|
module_name
|
|
|
|
);
|
|
|
|
//datetime_picker_callback();
|
|
|
|
forced_title_callback();
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
/*
|
|
|
|
function datetime_picker_callback() {
|
|
|
|
$("#text-time_from, #text-time_to").timepicker({
|
|
|
|
showSecond: true,
|
|
|
|
timeFormat: settings.timeFormat,
|
|
|
|
timeOnlyTitle: settings.translate.timeOnlyTitle,
|
|
|
|
timeText: settings.translate.timeText,
|
|
|
|
hourText: settings.translate.hourText,
|
|
|
|
minuteText: settings.translate.minuteText,
|
|
|
|
secondText: settings.translate.secondText,
|
|
|
|
currentText: settings.translate.currentText,
|
|
|
|
closeText: settings.translate.closeText
|
|
|
|
});
|
|
|
|
|
|
|
|
$.datepicker.setDefaults($.datepicker.regional[settings.userLanguage]);
|
|
|
|
$("#text-date_from, #text-date_to").datepicker({
|
|
|
|
dateFormat: settings.dateFormat
|
|
|
|
});
|
|
|
|
}*/
|
|
|
|
|
|
|
|
function refresh_pagination_callback(
|
|
|
|
module_id,
|
|
|
|
id_agent,
|
|
|
|
server_name,
|
|
|
|
module_name
|
|
|
|
) {
|
|
|
|
$(".binary_dialog").click(function() {
|
|
|
|
var classes = $(this).attr("class");
|
|
|
|
classes = classes.split(" ");
|
|
|
|
var offset_class = classes[2];
|
|
|
|
offset_class = offset_class.split("_");
|
|
|
|
var offset = offset_class[1];
|
|
|
|
|
|
|
|
var period = $("#period").val();
|
|
|
|
|
|
|
|
show_module_detail_dialog(
|
|
|
|
module_id,
|
|
|
|
id_agent,
|
|
|
|
server_name,
|
|
|
|
offset,
|
|
|
|
period,
|
|
|
|
module_name
|
|
|
|
);
|
|
|
|
return false;
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
// eslint-disable-next-line no-unused-vars
|
|
|
|
function dashboardLoadVC(settings) {
|
2022-03-18 13:07:29 +01:00
|
|
|
var headerMobileFix = 40;
|
|
|
|
|
2020-03-26 12:29:38 +01:00
|
|
|
var container = document.getElementById(
|
|
|
|
"visual-console-container-" + settings.cellId
|
|
|
|
);
|
|
|
|
|
2022-03-18 13:07:29 +01:00
|
|
|
var interval = 300 * 1000;
|
|
|
|
|
2020-03-26 12:29:38 +01:00
|
|
|
// Add the datetime when the item was received.
|
|
|
|
var receivedAt = new Date();
|
|
|
|
|
2022-03-18 13:07:29 +01:00
|
|
|
var beforeUpdate = function(items, visualConsole, props, size) {
|
2022-03-15 18:12:01 +01:00
|
|
|
var ratio_visualconsole = props.height / props.width;
|
2022-03-18 13:07:29 +01:00
|
|
|
var ratio_w = size.width / props.width;
|
|
|
|
var ratio_h = size.height / props.height;
|
2022-06-16 14:09:30 +02:00
|
|
|
var acum_height = props.height;
|
|
|
|
var acum_width = props.width;
|
2022-03-15 18:12:01 +01:00
|
|
|
|
2022-03-18 13:07:29 +01:00
|
|
|
props.width = size.width;
|
|
|
|
props.height = size.width * ratio_visualconsole;
|
2022-03-15 18:12:01 +01:00
|
|
|
|
|
|
|
var ratio = ratio_w;
|
|
|
|
if (settings.mobile != undefined && settings.mobile === true) {
|
|
|
|
if (props.height < props.width) {
|
2022-03-18 13:07:29 +01:00
|
|
|
if (props.height > size.height) {
|
2022-03-15 18:12:01 +01:00
|
|
|
ratio = ratio_h;
|
2022-03-18 13:07:29 +01:00
|
|
|
props.height = size.height;
|
|
|
|
props.width = size.height / ratio_visualconsole;
|
2022-03-15 18:12:01 +01:00
|
|
|
}
|
2022-06-16 14:09:30 +02:00
|
|
|
} else {
|
|
|
|
ratio = ratio_w;
|
|
|
|
var height = (acum_height * size.width) / acum_width;
|
|
|
|
props.height = height;
|
|
|
|
props.width = height / ratio_visualconsole;
|
2022-03-15 11:39:57 +01:00
|
|
|
}
|
2022-03-15 18:12:01 +01:00
|
|
|
} else {
|
2022-03-18 13:07:29 +01:00
|
|
|
if (props.height > size.height) {
|
2022-03-15 18:12:01 +01:00
|
|
|
ratio = ratio_h;
|
2022-03-18 13:07:29 +01:00
|
|
|
props.height = size.height;
|
|
|
|
props.width = size.height / ratio_visualconsole;
|
2022-03-15 11:39:57 +01:00
|
|
|
}
|
2022-03-15 18:12:01 +01:00
|
|
|
}
|
2020-03-26 12:29:38 +01:00
|
|
|
|
2022-03-15 18:12:01 +01:00
|
|
|
$.ajax({
|
|
|
|
method: "post",
|
|
|
|
url: settings.baseUrl + "ajax.php",
|
|
|
|
data: {
|
|
|
|
page: settings.page,
|
|
|
|
load_css_cv: 1,
|
|
|
|
uniq: settings.uniq,
|
|
|
|
ratio: ratio
|
|
|
|
},
|
|
|
|
dataType: "html",
|
|
|
|
success: function(css) {
|
|
|
|
$("#css_cv_" + settings.uniq)
|
|
|
|
.empty()
|
|
|
|
.append(css);
|
|
|
|
|
|
|
|
// Add the datetime when the item was received.
|
|
|
|
items.map(function(item) {
|
|
|
|
item["receivedAt"] = receivedAt;
|
|
|
|
return item;
|
|
|
|
});
|
2020-03-26 12:29:38 +01:00
|
|
|
|
2022-03-15 18:12:01 +01:00
|
|
|
// Update the data structure.
|
|
|
|
visualConsole.props = props;
|
2022-03-15 11:39:57 +01:00
|
|
|
|
2022-03-15 18:12:01 +01:00
|
|
|
// Update the items.
|
|
|
|
visualConsole.updateElements(items);
|
2022-03-15 11:39:57 +01:00
|
|
|
|
2022-03-22 12:31:30 +01:00
|
|
|
//Remove spinner change VC.
|
|
|
|
container.classList.remove("is-updating");
|
|
|
|
var div = container.querySelector(".div-visual-console-spinner");
|
|
|
|
|
|
|
|
if (div !== null) {
|
|
|
|
var parent = div.parentElement;
|
|
|
|
if (parent !== null) {
|
|
|
|
parent.removeChild(div);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-03-15 18:12:01 +01:00
|
|
|
if (settings.mobile != undefined && settings.mobile === true) {
|
2022-03-15 11:39:57 +01:00
|
|
|
// Update Url.
|
|
|
|
var regex = /(id=|id_visual_console=|id_layout=|id_visualmap=)\d+(&?)/gi;
|
|
|
|
var replacement = "$1" + props.id + "$2";
|
|
|
|
|
|
|
|
var regex_hash = /(hash=)[^&]+(&?)/gi;
|
|
|
|
var replacement_hash = "$1" + props.hash + "$2";
|
2020-03-26 12:29:38 +01:00
|
|
|
|
2022-06-16 14:09:30 +02:00
|
|
|
/*
|
2022-03-18 13:07:29 +01:00
|
|
|
var regex_width = /(width=)[^&]+(&?)/gi;
|
|
|
|
var replacement_width = "$1" + size.width + "$2";
|
|
|
|
|
|
|
|
var regex_height = /(height=)[^&]+(&?)/gi;
|
|
|
|
var replacement_height =
|
|
|
|
"$1" + (size.height + headerMobileFix) + "$2";
|
2022-06-16 14:09:30 +02:00
|
|
|
*/
|
2022-03-18 13:07:29 +01:00
|
|
|
|
2022-03-15 11:39:57 +01:00
|
|
|
// Change the URL (if the browser has support).
|
|
|
|
if ("history" in window) {
|
|
|
|
var href = window.location.href.replace(regex, replacement);
|
|
|
|
href = href.replace(regex_hash, replacement_hash);
|
2022-06-16 14:09:30 +02:00
|
|
|
//href = href.replace(regex_width, replacement_width);
|
|
|
|
//href = href.replace(regex_height, replacement_height);
|
2022-03-15 11:39:57 +01:00
|
|
|
window.history.replaceState({}, document.title, href);
|
2022-03-18 13:07:29 +01:00
|
|
|
}
|
2020-03-26 12:29:38 +01:00
|
|
|
|
2022-06-16 14:09:30 +02:00
|
|
|
if (props.height > props.width) {
|
|
|
|
$(".container-center").css("overflow", "auto");
|
|
|
|
} else {
|
|
|
|
$(".container-center").css("overflow", "inherit");
|
|
|
|
}
|
|
|
|
|
2022-03-22 12:31:30 +01:00
|
|
|
container.classList.remove("cv-overflow");
|
2022-03-21 10:04:11 +01:00
|
|
|
|
|
|
|
// View title.
|
|
|
|
var title = document.querySelector(".ui-title");
|
|
|
|
if (title !== null) {
|
|
|
|
title.textContent = visualConsole.props.name;
|
|
|
|
}
|
2022-03-15 11:39:57 +01:00
|
|
|
}
|
2022-03-15 18:12:01 +01:00
|
|
|
},
|
|
|
|
error: function(error) {
|
|
|
|
console.error(error);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
};
|
2022-03-15 11:39:57 +01:00
|
|
|
|
|
|
|
var handleUpdate = function() {
|
2022-03-18 13:07:29 +01:00
|
|
|
return;
|
2020-03-26 12:29:38 +01:00
|
|
|
};
|
|
|
|
|
|
|
|
settings.items.map(function(item) {
|
|
|
|
item["receivedAt"] = receivedAt;
|
|
|
|
return item;
|
|
|
|
});
|
|
|
|
|
2021-08-05 11:57:31 +02:00
|
|
|
settings.items.map(function(item) {
|
|
|
|
item["cellId"] = settings.cellId;
|
|
|
|
return item;
|
|
|
|
});
|
|
|
|
|
2022-03-18 13:07:29 +01:00
|
|
|
var visualConsoleManager = createVisualConsole(
|
2020-03-26 12:29:38 +01:00
|
|
|
container,
|
|
|
|
settings.props,
|
|
|
|
settings.items,
|
|
|
|
settings.baseUrl,
|
2022-03-18 13:07:29 +01:00
|
|
|
interval,
|
2020-03-26 12:29:38 +01:00
|
|
|
handleUpdate,
|
|
|
|
beforeUpdate,
|
2021-05-19 11:57:17 +02:00
|
|
|
settings.size,
|
|
|
|
settings.id_user,
|
2022-03-15 18:12:01 +01:00
|
|
|
settings.hash,
|
|
|
|
settings.mobile != undefined && settings.mobile === true
|
|
|
|
? "mobile"
|
|
|
|
: "dashboard"
|
2020-03-26 12:29:38 +01:00
|
|
|
);
|
2022-03-18 13:07:29 +01:00
|
|
|
|
2022-10-13 17:45:44 +02:00
|
|
|
if (settings.props.maintenanceMode != null) {
|
2023-01-30 09:51:12 +01:00
|
|
|
visualConsoleManager.visualConsole.enableMaintenanceMode();
|
2022-10-13 17:45:44 +02:00
|
|
|
}
|
|
|
|
|
2022-05-13 12:54:58 +02:00
|
|
|
if (settings.mobile_view_orientation_vc === true) {
|
|
|
|
$(window).on("orientationchange", function() {
|
|
|
|
$(container).width($(window).height());
|
|
|
|
$(container).height($(window).width() - headerMobileFix);
|
|
|
|
//Remove spinner change VC.
|
|
|
|
container.classList.remove("is-updating");
|
|
|
|
container.classList.remove("cv-overflow");
|
2022-03-18 13:07:29 +01:00
|
|
|
|
2022-05-13 12:54:58 +02:00
|
|
|
var div = container.querySelector(".div-visual-console-spinner");
|
2022-03-18 13:07:29 +01:00
|
|
|
|
2022-05-13 12:54:58 +02:00
|
|
|
if (div !== null) {
|
|
|
|
var parent = div.parentElement;
|
|
|
|
if (parent !== null) {
|
|
|
|
parent.removeChild(div);
|
|
|
|
}
|
2022-03-18 13:07:29 +01:00
|
|
|
}
|
|
|
|
|
2022-05-13 12:54:58 +02:00
|
|
|
container.classList.add("is-updating");
|
|
|
|
container.classList.add("cv-overflow");
|
|
|
|
const divParent = document.createElement("div");
|
|
|
|
divParent.className = "div-visual-console-spinner";
|
2022-03-18 13:07:29 +01:00
|
|
|
|
2022-05-13 12:54:58 +02:00
|
|
|
const divSpinner = document.createElement("div");
|
|
|
|
divSpinner.className = "visual-console-spinner";
|
2022-03-18 13:07:29 +01:00
|
|
|
|
2022-05-13 12:54:58 +02:00
|
|
|
divParent.appendChild(divSpinner);
|
|
|
|
container.appendChild(divParent);
|
2022-03-18 13:07:29 +01:00
|
|
|
|
2022-05-13 12:54:58 +02:00
|
|
|
var dimensions = {
|
|
|
|
width: $(window).height(),
|
|
|
|
height: $(window).width() - 40
|
|
|
|
};
|
2020-03-26 12:29:38 +01:00
|
|
|
|
2022-05-13 12:54:58 +02:00
|
|
|
visualConsoleManager.changeDimensionsVc(dimensions, interval);
|
|
|
|
});
|
2021-08-27 09:20:30 +02:00
|
|
|
}
|
2020-03-26 12:29:38 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
// eslint-disable-next-line no-unused-vars
|
|
|
|
function dashboardInitTinyMce(url) {
|
|
|
|
// Initialice.
|
|
|
|
tinyMCE.init({
|
|
|
|
selector: "#textarea_text",
|
|
|
|
theme: "advanced",
|
2021-11-04 16:28:15 +01:00
|
|
|
content_css: url + "include/styles/pandora.css",
|
2020-03-26 12:29:38 +01:00
|
|
|
theme_advanced_font_sizes:
|
|
|
|
"4pt=.visual_font_size_4pt, " +
|
|
|
|
"6pt=.visual_font_size_6pt, " +
|
|
|
|
"8pt=.visual_font_size_8pt, " +
|
|
|
|
"10pt=.visual_font_size_10pt, " +
|
|
|
|
"12pt=.visual_font_size_12pt, " +
|
|
|
|
"14pt=.visual_font_size_14pt, " +
|
|
|
|
"18pt=.visual_font_size_18pt, " +
|
|
|
|
"24pt=.visual_font_size_24pt, " +
|
|
|
|
"28pt=.visual_font_size_28pt, " +
|
|
|
|
"36pt=.visual_font_size_36pt, " +
|
|
|
|
"48pt=.visual_font_size_48pt, " +
|
|
|
|
"60pt=.visual_font_size_60pt, " +
|
|
|
|
"72pt=.visual_font_size_72pt, " +
|
|
|
|
"84pt=.visual_font_size_84pt, " +
|
|
|
|
"96pt=.visual_font_size_96pt, " +
|
|
|
|
"116pt=.visual_font_size_116pt, " +
|
|
|
|
"128pt=.visual_font_size_128pt, " +
|
|
|
|
"140pt=.visual_font_size_140pt, " +
|
|
|
|
"154pt=.visual_font_size_154pt, " +
|
|
|
|
"196pt=.visual_font_size_196pt",
|
|
|
|
theme_advanced_toolbar_location: "top",
|
|
|
|
theme_advanced_toolbar_align: "left",
|
|
|
|
theme_advanced_buttons1:
|
|
|
|
"bold,italic, |,justifyleft, justifycenter, justifyright, |, undo, redo, |, image, link",
|
|
|
|
theme_advanced_buttons2: "fontselect, forecolor, fontsizeselect, |,code",
|
|
|
|
theme_advanced_buttons3: "",
|
|
|
|
theme_advanced_statusbar_location: "none",
|
|
|
|
body_class: "",
|
|
|
|
forced_root_block: false,
|
|
|
|
force_p_newlines: false,
|
|
|
|
force_br_newlines: true,
|
|
|
|
convert_newlines_to_brs: false,
|
|
|
|
remove_linebreaks: true
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
function debounce(func, wait, immediate) {
|
|
|
|
var timeout;
|
|
|
|
return function() {
|
|
|
|
var context = this,
|
|
|
|
args = arguments;
|
|
|
|
var later = function() {
|
|
|
|
timeout = null;
|
|
|
|
if (!immediate) func.apply(context, args);
|
|
|
|
};
|
|
|
|
var callNow = immediate && !timeout;
|
|
|
|
clearTimeout(timeout);
|
|
|
|
timeout = setTimeout(later, wait);
|
|
|
|
if (callNow) func.apply(context, args);
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
// eslint-disable-next-line no-unused-vars
|
|
|
|
function formSlides(settings) {
|
|
|
|
load_modal({
|
|
|
|
target: $("#modal-update-dashboard"),
|
|
|
|
form: "slides-form",
|
|
|
|
url: settings.url_ajax,
|
|
|
|
modal: {
|
|
|
|
title: settings.title,
|
|
|
|
cancel: settings.btn_cancel,
|
|
|
|
ok: settings.btn_text
|
|
|
|
},
|
|
|
|
onshow: {
|
|
|
|
page: settings.url,
|
|
|
|
method: "formSlides",
|
|
|
|
extradata: {
|
|
|
|
dashboardId: settings.dashboardId
|
|
|
|
},
|
|
|
|
width: 250
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
// eslint-disable-next-line no-unused-vars
|
|
|
|
function loadSliceWidget(settings) {
|
|
|
|
settings = JSON.parse(settings);
|
|
|
|
var width = $(window).width();
|
|
|
|
$.ajax({
|
|
|
|
method: "post",
|
|
|
|
url: settings.url,
|
|
|
|
data: {
|
|
|
|
page: settings.page,
|
|
|
|
method: "drawWidget",
|
|
|
|
dashboardId: settings.dashboardId,
|
|
|
|
cellId: settings.cellId,
|
|
|
|
newWidth: 12,
|
|
|
|
newHeight: 12,
|
|
|
|
gridWidth: width,
|
|
|
|
widgetId: settings.widgetId
|
|
|
|
},
|
|
|
|
dataType: "html",
|
|
|
|
success: function(dataWidget) {
|
|
|
|
// Widget empty.
|
|
|
|
$("#view-slides-cell-mode").empty();
|
|
|
|
|
|
|
|
// Add Resize element.
|
|
|
|
$("#view-slides-cell-mode").append(dataWidget);
|
|
|
|
},
|
|
|
|
error: function(error) {
|
|
|
|
console.error(error);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
2022-10-10 11:20:03 +02:00
|
|
|
|
|
|
|
// eslint-disable-next-line no-unused-vars
|
|
|
|
function showManualThresholds(element) {
|
|
|
|
$("#min_warning").val(null);
|
|
|
|
$("#max_warning").val(null);
|
|
|
|
$("#min_critical").val(null);
|
|
|
|
$("#max_critical").val(null);
|
|
|
|
if ($(element).is(":checked") === true) {
|
|
|
|
$(".dashboard-input-threshold-warning").removeClass("invisible_important");
|
|
|
|
$(".dashboard-input-threshold-critical").removeClass("invisible_important");
|
|
|
|
} else {
|
|
|
|
$(".dashboard-input-threshold-warning").addClass("invisible_important");
|
|
|
|
$(".dashboard-input-threshold-critical").addClass("invisible_important");
|
|
|
|
}
|
|
|
|
}
|