#9029 Added starmap
This commit is contained in:
parent
225da0dac5
commit
a71c26b4a7
|
@ -4294,3 +4294,147 @@ function agents_get_offspring(int $id_agent)
|
||||||
|
|
||||||
return $return;
|
return $return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
function agents_get_starmap(int $id_agent, float $width=0, float $height=0)
|
||||||
|
{
|
||||||
|
ui_require_css_file('heatmap');
|
||||||
|
|
||||||
|
// $all_modules = agents_get_modules($id_agent);
|
||||||
|
// if (empty($all_modules)) {
|
||||||
|
// return null;
|
||||||
|
// }
|
||||||
|
// $total_modules = count($all_modules);
|
||||||
|
$all_modules = [];
|
||||||
|
$total_modules = 200;
|
||||||
|
$contador = 0;
|
||||||
|
while ($contador < $total_modules) {
|
||||||
|
$contador++;
|
||||||
|
$all_modules[$contador] = '';
|
||||||
|
}
|
||||||
|
|
||||||
|
// Best square.
|
||||||
|
$high = (float) max($width, $height);
|
||||||
|
$low = 0.0;
|
||||||
|
|
||||||
|
while (abs($high - $low) > 0.000001) {
|
||||||
|
$mid = (($high + $low) / 2.0);
|
||||||
|
$midval = (floor($width / $mid) * floor($height / $mid));
|
||||||
|
if ($midval >= $total_modules) {
|
||||||
|
$low = $mid;
|
||||||
|
} else {
|
||||||
|
$high = $mid;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
$square_length = min(($width / floor($width / $low)), ($height / floor($height / $low)));
|
||||||
|
|
||||||
|
// Print starmap.
|
||||||
|
$html = sprintf(
|
||||||
|
'<svg id="svg_%s" style="width: %spx; height: %spx;">',
|
||||||
|
$id_agent,
|
||||||
|
$width,
|
||||||
|
$height
|
||||||
|
);
|
||||||
|
|
||||||
|
$html .= '<g>';
|
||||||
|
$row = 0;
|
||||||
|
$column = 0;
|
||||||
|
$x = 0;
|
||||||
|
$y = 0;
|
||||||
|
$cont = 1;
|
||||||
|
foreach ($all_modules as $key => $value) {
|
||||||
|
// Colour by status.
|
||||||
|
// $status = modules_get_agentmodule_status($key);
|
||||||
|
$status = random_int(0, 5);
|
||||||
|
switch ($status) {
|
||||||
|
case 0:
|
||||||
|
case 4:
|
||||||
|
case 300:
|
||||||
|
$status = 'normal';
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 1:
|
||||||
|
case 100:
|
||||||
|
$status = 'critical';
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 2:
|
||||||
|
case 200:
|
||||||
|
$status = 'warning';
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 3:
|
||||||
|
$status = 'unknown';
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 5:
|
||||||
|
$status = 'notinit';
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
$html .= sprintf(
|
||||||
|
'<rect id="%s" x="%s" y="%s" row="%s" col="%s" width="%s" height="%s" class="%s_%s"></rect>',
|
||||||
|
'rect_'.$cont,
|
||||||
|
$x,
|
||||||
|
$y,
|
||||||
|
$row,
|
||||||
|
$column,
|
||||||
|
$square_length,
|
||||||
|
$square_length,
|
||||||
|
$status,
|
||||||
|
random_int(1, 10)
|
||||||
|
);
|
||||||
|
|
||||||
|
$y += $square_length;
|
||||||
|
$row++;
|
||||||
|
if ((int) ($y + $square_length) > (int) $height) {
|
||||||
|
$y = 0;
|
||||||
|
$x += $square_length;
|
||||||
|
$row = 0;
|
||||||
|
$column++;
|
||||||
|
}
|
||||||
|
|
||||||
|
if ((int) ($x + $square_length) > (int) $width) {
|
||||||
|
$x = 0;
|
||||||
|
$y += $square_length;
|
||||||
|
$column = 0;
|
||||||
|
$row++;
|
||||||
|
}
|
||||||
|
|
||||||
|
$cont++;
|
||||||
|
}
|
||||||
|
?>
|
||||||
|
<script type="text/javascript">
|
||||||
|
$(document).ready(function() {
|
||||||
|
const total_modules = '<?php echo $total_modules; ?>';
|
||||||
|
|
||||||
|
function getRandomInteger(min, max) {
|
||||||
|
return Math.floor(Math.random() * max) + min;
|
||||||
|
}
|
||||||
|
|
||||||
|
function oneSquare(solid, time) {
|
||||||
|
var randomPoint = getRandomInteger(1, total_modules);
|
||||||
|
let target = $(`#rect_${randomPoint}`);
|
||||||
|
let class_name = target.attr('class');
|
||||||
|
class_name = class_name.split('_')[0];
|
||||||
|
setTimeout(function() {
|
||||||
|
target.removeClass();
|
||||||
|
target.addClass(`${class_name}_${solid}`);
|
||||||
|
oneSquare(getRandomInteger(1, 10), getRandomInteger(100, 900));
|
||||||
|
}, time);
|
||||||
|
}
|
||||||
|
|
||||||
|
let cont = 0;
|
||||||
|
while (cont < Math.ceil(total_modules / 3)) {
|
||||||
|
oneSquare(getRandomInteger(1, 10), getRandomInteger(100, 900));
|
||||||
|
cont ++;
|
||||||
|
}
|
||||||
|
});
|
||||||
|
</script>
|
||||||
|
<?php
|
||||||
|
$html .= '</g>';
|
||||||
|
$html .= '</svg>';
|
||||||
|
|
||||||
|
return $html;
|
||||||
|
}
|
||||||
|
|
|
@ -2869,7 +2869,7 @@ function donutNarrowGraph(
|
||||||
arc = d3.svg
|
arc = d3.svg
|
||||||
.arc()
|
.arc()
|
||||||
.outerRadius(radius)
|
.outerRadius(radius)
|
||||||
.innerRadius(radius - radius / 6);
|
.innerRadius(radius - radius / 4);
|
||||||
|
|
||||||
svg = donutbody
|
svg = donutbody
|
||||||
.append("svg")
|
.append("svg")
|
||||||
|
|
|
@ -159,10 +159,26 @@
|
||||||
fill: #cccccc;
|
fill: #cccccc;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.notinit_10,
|
||||||
|
.notinit_9,
|
||||||
|
.notinit_8,
|
||||||
.notinit {
|
.notinit {
|
||||||
fill: #4a83f3;
|
fill: #4a83f3;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.notinit_7,
|
||||||
|
.notinit_6,
|
||||||
|
.notinit_5,
|
||||||
|
.notinit_4 {
|
||||||
|
fill: #6695f5;
|
||||||
|
}
|
||||||
|
|
||||||
|
.notinit_3,
|
||||||
|
.notinit_2,
|
||||||
|
.notinit_1 {
|
||||||
|
fill: #79a3f6;
|
||||||
|
}
|
||||||
|
|
||||||
.hover {
|
.hover {
|
||||||
cursor: pointer;
|
cursor: pointer;
|
||||||
}
|
}
|
||||||
|
|
|
@ -5614,12 +5614,12 @@ div#bullets_modules div {
|
||||||
}
|
}
|
||||||
|
|
||||||
.agent_details_col_left {
|
.agent_details_col_left {
|
||||||
width: 40%;
|
width: 49%;
|
||||||
min-width: 300px;
|
min-width: 450px;
|
||||||
}
|
}
|
||||||
.agent_details_col_right {
|
.agent_details_col_right {
|
||||||
width: 59%;
|
width: 49%;
|
||||||
min-width: 480px;
|
min-width: 450px;
|
||||||
}
|
}
|
||||||
|
|
||||||
.agent_access_rate_events {
|
.agent_access_rate_events {
|
||||||
|
@ -5630,14 +5630,15 @@ div#bullets_modules div {
|
||||||
}
|
}
|
||||||
|
|
||||||
.white_table_graph#table_access_rate {
|
.white_table_graph#table_access_rate {
|
||||||
flex: 1 1 auto;
|
margin-left: 1px;
|
||||||
min-width: 450px;
|
margin-right: 1px;
|
||||||
margin-right: 1%;
|
width: 49%;
|
||||||
}
|
}
|
||||||
|
|
||||||
.white_table_graph#table_events {
|
.white_table_graph#table_events {
|
||||||
flex: 1 1 auto;
|
margin-left: 1px;
|
||||||
min-width: 450px;
|
margin-right: 1px;
|
||||||
|
width: 49%;
|
||||||
}
|
}
|
||||||
|
|
||||||
@media screen and (max-width: 1150px) {
|
@media screen and (max-width: 1150px) {
|
||||||
|
@ -5676,7 +5677,7 @@ div#status_pie {
|
||||||
justify-content: flex-end;
|
justify-content: flex-end;
|
||||||
align-items: center;
|
align-items: center;
|
||||||
border-bottom: 1px solid #e2e2e2;
|
border-bottom: 1px solid #e2e2e2;
|
||||||
padding: 6px 20px;
|
padding: 8px 20px;
|
||||||
}
|
}
|
||||||
|
|
||||||
.agent_details_content {
|
.agent_details_content {
|
||||||
|
|
|
@ -74,9 +74,7 @@ if (! check_acl_one_of_groups($config['id_user'], $all_groups, 'AR')
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
$alive_animation = agents_get_status_animation(
|
$alive_animation = agents_get_starmap($id_agente, 200, 50);
|
||||||
agents_get_interval_status($agent, false)
|
|
||||||
);
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* START: TABLE AGENT BUILD.
|
* START: TABLE AGENT BUILD.
|
||||||
|
@ -170,10 +168,10 @@ $status_img = agents_detail_view_status_img(
|
||||||
$table_agent_header .= '<div class="icono_right">'.$status_img.'</div>';
|
$table_agent_header .= '<div class="icono_right">'.$status_img.'</div>';
|
||||||
|
|
||||||
// Fixed width non interactive charts.
|
// Fixed width non interactive charts.
|
||||||
$status_chart_width = 180;
|
$status_chart_width = 150;
|
||||||
$graph_width = 180;
|
$graph_width = 150;
|
||||||
|
|
||||||
$table_agent_graph = '<div id="status_pie" style="width: '.$status_chart_width.'px;">';
|
$table_agent_graph = '<div id="status_pie" style="width: '.$graph_width.'px;">';
|
||||||
$table_agent_graph .= graph_agent_status(
|
$table_agent_graph .= graph_agent_status(
|
||||||
$id_agente,
|
$id_agente,
|
||||||
$graph_width,
|
$graph_width,
|
||||||
|
|
Loading…
Reference in New Issue