mirror of
https://github.com/Ylianst/MeshCentral.git
synced 2025-01-15 08:44:59 -05:00
update to chart 4.3.3
Signed-off-by: Simon <simonsmith5521@gmail.com>
This commit is contained in:
parent
89cf7d8c1e
commit
ef2f111eb0
7
public/scripts/chartjs-adapter-moment-min.js
vendored
Normal file
7
public/scripts/chartjs-adapter-moment-min.js
vendored
Normal file
@ -0,0 +1,7 @@
|
|||||||
|
/*!
|
||||||
|
* chartjs-adapter-moment v1.0.1
|
||||||
|
* https://www.chartjs.org
|
||||||
|
* (c) 2022 chartjs-adapter-moment Contributors
|
||||||
|
* Released under the MIT license
|
||||||
|
*/
|
||||||
|
!function(e,t){"object"==typeof exports&&"undefined"!=typeof module?t(require("moment"),require("chart.js")):"function"==typeof define&&define.amd?define(["moment","chart.js"],t):t((e="undefined"!=typeof globalThis?globalThis:e||self).moment,e.Chart)}(this,(function(e,t){"use strict";function n(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}var f=n(e);const a={datetime:"MMM D, YYYY, h:mm:ss a",millisecond:"h:mm:ss.SSS a",second:"h:mm:ss a",minute:"h:mm a",hour:"hA",day:"MMM D",week:"ll",month:"MMM YYYY",quarter:"[Q]Q - YYYY",year:"YYYY"};t._adapters._date.override("function"==typeof f.default?{_id:"moment",formats:function(){return a},parse:function(e,t){return"string"==typeof e&&"string"==typeof t?e=f.default(e,t):e instanceof f.default||(e=f.default(e)),e.isValid()?e.valueOf():null},format:function(e,t){return f.default(e).format(t)},add:function(e,t,n){return f.default(e).add(t,n).valueOf()},diff:function(e,t,n){return f.default(e).diff(f.default(t),n)},startOf:function(e,t,n){return e=f.default(e),"isoWeek"===t?(n=Math.trunc(Math.min(Math.max(0,n),6)),e.isoWeekday(n).startOf("day").valueOf()):e.startOf(t).valueOf()},endOf:function(e,t){return f.default(e).endOf(t).valueOf()}}:{})}));
|
73
public/scripts/chartjs-adapter-moment.js
Normal file
73
public/scripts/chartjs-adapter-moment.js
Normal file
@ -0,0 +1,73 @@
|
|||||||
|
/*!
|
||||||
|
* chartjs-adapter-moment v1.0.1
|
||||||
|
* https://www.chartjs.org
|
||||||
|
* (c) 2022 chartjs-adapter-moment Contributors
|
||||||
|
* Released under the MIT license
|
||||||
|
*/
|
||||||
|
(function (global, factory) {
|
||||||
|
typeof exports === 'object' && typeof module !== 'undefined' ? factory(require('moment'), require('chart.js')) :
|
||||||
|
typeof define === 'function' && define.amd ? define(['moment', 'chart.js'], factory) :
|
||||||
|
(global = typeof globalThis !== 'undefined' ? globalThis : global || self, factory(global.moment, global.Chart));
|
||||||
|
}(this, (function (moment, chart_js) { 'use strict';
|
||||||
|
|
||||||
|
function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }
|
||||||
|
|
||||||
|
var moment__default = /*#__PURE__*/_interopDefaultLegacy(moment);
|
||||||
|
|
||||||
|
const FORMATS = {
|
||||||
|
datetime: 'MMM D, YYYY, h:mm:ss a',
|
||||||
|
millisecond: 'h:mm:ss.SSS a',
|
||||||
|
second: 'h:mm:ss a',
|
||||||
|
minute: 'h:mm a',
|
||||||
|
hour: 'hA',
|
||||||
|
day: 'MMM D',
|
||||||
|
week: 'll',
|
||||||
|
month: 'MMM YYYY',
|
||||||
|
quarter: '[Q]Q - YYYY',
|
||||||
|
year: 'YYYY'
|
||||||
|
};
|
||||||
|
|
||||||
|
chart_js._adapters._date.override(typeof moment__default['default'] === 'function' ? {
|
||||||
|
_id: 'moment', // DEBUG ONLY
|
||||||
|
|
||||||
|
formats: function() {
|
||||||
|
return FORMATS;
|
||||||
|
},
|
||||||
|
|
||||||
|
parse: function(value, format) {
|
||||||
|
if (typeof value === 'string' && typeof format === 'string') {
|
||||||
|
value = moment__default['default'](value, format);
|
||||||
|
} else if (!(value instanceof moment__default['default'])) {
|
||||||
|
value = moment__default['default'](value);
|
||||||
|
}
|
||||||
|
return value.isValid() ? value.valueOf() : null;
|
||||||
|
},
|
||||||
|
|
||||||
|
format: function(time, format) {
|
||||||
|
return moment__default['default'](time).format(format);
|
||||||
|
},
|
||||||
|
|
||||||
|
add: function(time, amount, unit) {
|
||||||
|
return moment__default['default'](time).add(amount, unit).valueOf();
|
||||||
|
},
|
||||||
|
|
||||||
|
diff: function(max, min, unit) {
|
||||||
|
return moment__default['default'](max).diff(moment__default['default'](min), unit);
|
||||||
|
},
|
||||||
|
|
||||||
|
startOf: function(time, unit, weekday) {
|
||||||
|
time = moment__default['default'](time);
|
||||||
|
if (unit === 'isoWeek') {
|
||||||
|
weekday = Math.trunc(Math.min(Math.max(0, weekday), 6));
|
||||||
|
return time.isoWeekday(weekday).startOf('day').valueOf();
|
||||||
|
}
|
||||||
|
return time.startOf(unit).valueOf();
|
||||||
|
},
|
||||||
|
|
||||||
|
endOf: function(time, unit) {
|
||||||
|
return moment__default['default'](time).endOf(unit).valueOf();
|
||||||
|
}
|
||||||
|
} : {});
|
||||||
|
|
||||||
|
})));
|
||||||
|
|
6
public/scripts/charts-min.js
vendored
6
public/scripts/charts-min.js
vendored
File diff suppressed because one or more lines are too long
19295
public/scripts/charts.js
19295
public/scripts/charts.js
File diff suppressed because one or more lines are too long
1
public/scripts/moment-min.js
vendored
Normal file
1
public/scripts/moment-min.js
vendored
Normal file
File diff suppressed because one or more lines are too long
18239
public/scripts/moment.js
Normal file
18239
public/scripts/moment.js
Normal file
File diff suppressed because it is too large
Load Diff
@ -41,6 +41,8 @@
|
|||||||
<script type="text/javascript" src="mstsc/canvas.js"></script>
|
<script type="text/javascript" src="mstsc/canvas.js"></script>
|
||||||
<script keeplink=1 type="text/javascript" src="scripts/u2f-api{{{min}}}.js"></script>
|
<script keeplink=1 type="text/javascript" src="scripts/u2f-api{{{min}}}.js"></script>
|
||||||
<script keeplink=1 type="text/javascript" src="scripts/charts{{{min}}}.js"></script>
|
<script keeplink=1 type="text/javascript" src="scripts/charts{{{min}}}.js"></script>
|
||||||
|
<script keeplink=1 type="text/javascript" src="scripts/moment{{min}}.js"></script>
|
||||||
|
<script keeplink=1 type="text/javascript" src="scripts/chartjs-adapter-moment{{{min}}}.js"></script>
|
||||||
<script keeplink=1 type="text/javascript" src="scripts/filesaver.min.js"></script>
|
<script keeplink=1 type="text/javascript" src="scripts/filesaver.min.js"></script>
|
||||||
<script keeplink=1 type="text/javascript" src="scripts/ol{{{min}}}.js"></script>
|
<script keeplink=1 type="text/javascript" src="scripts/ol{{{min}}}.js"></script>
|
||||||
<script keeplink=1 type="text/javascript" src="scripts/ol3-contextmenu{{{min}}}.js"></script>
|
<script keeplink=1 type="text/javascript" src="scripts/ol3-contextmenu{{{min}}}.js"></script>
|
||||||
@ -578,11 +580,11 @@
|
|||||||
<strong>Server Statistics</strong><br /><br />
|
<strong>Server Statistics</strong><br /><br />
|
||||||
<div id="serverStats">
|
<div id="serverStats">
|
||||||
<div id="serverCpuChartView" style="display:none">
|
<div id="serverCpuChartView" style="display:none">
|
||||||
<div class="chartViewCanvas"><canvas id="serverCpuChart"></canvas></div>
|
<div class="chartViewCanvas" style="height:40px; text-align:center"><canvas id="serverCpuChart" style="display:inline-block"></canvas></div>
|
||||||
<div class="chartViewText" id="serverCpuChartText"></div>
|
<div class="chartViewText" id="serverCpuChartText"></div>
|
||||||
</div>
|
</div>
|
||||||
<div id="serverMemoryChartView" style="display:none">
|
<div id="serverMemoryChartView" style="display:none">
|
||||||
<div class="chartViewCanvas"><canvas id="serverMemoryChart"></canvas></div>
|
<div class="chartViewCanvas" style="height:40px; text-align:center"><canvas id="serverMemoryChart" style="display:inline-block"></canvas></div>
|
||||||
<div class="chartViewText" id="serverMemoryChartText"></div>
|
<div class="chartViewText" id="serverMemoryChartText"></div>
|
||||||
</div><br /><br />
|
</div><br /><br />
|
||||||
<div id="serverStatsTable"></div>
|
<div id="serverStatsTable"></div>
|
||||||
@ -11364,8 +11366,8 @@
|
|||||||
tooltips: { enabled: false },
|
tooltips: { enabled: false },
|
||||||
elements: { line: { cubicInterpolationMode: 'monotone' } },
|
elements: { line: { cubicInterpolationMode: 'monotone' } },
|
||||||
scales: {
|
scales: {
|
||||||
xAxes: [{ type: 'linear', display: true, scaleLabel: { display: false, labelString: '' }, ticks: { min: 0, max: 100, reverse: true } }],
|
x: { type: 'linear', display: true, title: { display: false, text: '' }, min: 0, max: 100, reverse: true },
|
||||||
yAxes: [{ type: 'linear', display: true, scaleLabel: { display: false, labelString: '' }, ticks: { min: 0, max: 100 } }]
|
y: { type: 'linear', display: true, title: { display: false, text: '' }, min: 0, max: 100 }
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
@ -13773,43 +13775,25 @@
|
|||||||
//
|
//
|
||||||
|
|
||||||
function setupMeshSummaryStats() {
|
function setupMeshSummaryStats() {
|
||||||
var draw = Chart.controllers.doughnut.prototype.draw;
|
|
||||||
Chart.controllers.doughnut = Chart.controllers.doughnut.extend({
|
|
||||||
draw: function() {
|
|
||||||
draw.apply(this, arguments);
|
|
||||||
var ctx = this.chart.chart.ctx;
|
|
||||||
var _fill = ctx.fill;
|
|
||||||
ctx.fill = function() {
|
|
||||||
ctx.save();
|
|
||||||
ctx.shadowColor = 'blue';
|
|
||||||
ctx.shadowBlur = 10;
|
|
||||||
ctx.shadowOffsetX = 2;
|
|
||||||
ctx.shadowOffsetY = 2;
|
|
||||||
_fill.apply(this, arguments)
|
|
||||||
ctx.restore();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
window.meshPowerChart = new Chart(document.getElementById('meshPowerChart').getContext('2d'), {
|
window.meshPowerChart = new Chart(document.getElementById('meshPowerChart').getContext('2d'), {
|
||||||
type: 'doughnut',
|
type: 'doughnut',
|
||||||
data: { datasets: [{ data: [0, 0], backgroundColor: ['#20F', '#40D', '#60B', '#809', '#A07', '#C05'] }] },
|
data: { datasets: [{ data: [0, 0], backgroundColor: ['#20F', '#40D', '#60B', '#809', '#A07', '#C05'] }] },
|
||||||
options: { responsive: true, legend: { position: 'none' }, animation: { animateScale: true, animateRotate: true }, layout: { padding: { left: 10, right: 10, top: 10, bottom: 10 } } }
|
options: { shadowColor: 'blue', responsive: true, plugins: { legend: { display: false } }, animation: { animateScale: true, animateRotate: true }, layout: { padding: { left: 10, right: 10, top: 10, bottom: 10 } } }
|
||||||
});
|
});
|
||||||
window.meshOsChart = new Chart(document.getElementById('meshOsChart').getContext('2d'), {
|
window.meshOsChart = new Chart(document.getElementById('meshOsChart').getContext('2d'), {
|
||||||
type: 'doughnut',
|
type: 'doughnut',
|
||||||
data: { datasets: [{ data: [0, 0], backgroundColor: ['#20F', '#30E', '#40D', '#50C', '#60B', '#70A', '#809', '#908', '#A07', '#B06', '#C05'] }] },
|
data: { datasets: [{ data: [0, 0], backgroundColor: ['#20F', '#30E', '#40D', '#50C', '#60B', '#70A', '#809', '#908', '#A07', '#B06', '#C05'] }] },
|
||||||
options: { responsive: true, legend: { position: 'none' }, animation: { animateScale: true, animateRotate: true }, layout: { padding: { left: 10, right: 10, top: 10, bottom: 10 } } }
|
options: { responsive: true, plugins: { legend: { display: false } }, animation: { animateScale: true, animateRotate: true }, layout: { padding: { left: 10, right: 10, top: 10, bottom: 10 } } }
|
||||||
});
|
});
|
||||||
window.meshConnChart = new Chart(document.getElementById('meshConnChart').getContext('2d'), {
|
window.meshConnChart = new Chart(document.getElementById('meshConnChart').getContext('2d'), {
|
||||||
type: 'doughnut',
|
type: 'doughnut',
|
||||||
data: { datasets: [{ data: [0, 0], backgroundColor: ['#20F', '#40D', '#60B', '#809', '#A07', '#C05'] }], labels: ["Not Connected", "Agent", "Intel® AMT", "Agent + Intel® AMT"] },
|
data: { datasets: [{ data: [0, 0], backgroundColor: ['#20F', '#40D', '#60B', '#809', '#A07', '#C05'] }], labels: ["Not Connected", "Agent", "Intel® AMT", "Agent + Intel® AMT"] },
|
||||||
options: { responsive: true, legend: { position: 'none' }, animation: { animateScale: true, animateRotate: true }, layout: { padding: { left: 10, right: 10, top: 10, bottom: 10 } } }
|
options: { responsive: true, plugins: { legend: { display: false } }, animation: { animateScale: true, animateRotate: true }, layout: { padding: { left: 10, right: 10, top: 10, bottom: 10 } } }
|
||||||
});
|
});
|
||||||
window.meshSecurityChart = new Chart(document.getElementById('meshSecurityChart').getContext('2d'), {
|
window.meshSecurityChart = new Chart(document.getElementById('meshSecurityChart').getContext('2d'), {
|
||||||
type: 'doughnut',
|
type: 'doughnut',
|
||||||
data: { datasets: [{ data: [0, 0], backgroundColor: ['#20F', '#40D', '#60B', '#809', '#A07', '#C05'] }], labels: ["OK", "Anti-virus not active", "No automatic update", "Firewall not active", "Multiple Issues"] },
|
data: { datasets: [{ data: [0, 0], backgroundColor: ['#20F', '#40D', '#60B', '#809', '#A07', '#C05'] }], labels: ["OK", "Anti-virus not active", "No automatic update", "Firewall not active", "Multiple Issues"] },
|
||||||
options: { responsive: true, legend: { position: 'none' }, animation: { animateScale: true, animateRotate: true }, layout: { padding: { left: 10, right: 10, top: 10, bottom: 10 } } }
|
options: { responsive: true, plugins: { legend: { display: false } }, animation: { animateScale: true, animateRotate: true }, layout: { padding: { left: 10, right: 10, top: 10, bottom: 10 } } }
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -17168,12 +17152,12 @@
|
|||||||
window.serverStatCpu = new Chart(document.getElementById('serverCpuChart').getContext('2d'), {
|
window.serverStatCpu = new Chart(document.getElementById('serverCpuChart').getContext('2d'), {
|
||||||
type: 'doughnut',
|
type: 'doughnut',
|
||||||
data: { datasets: [{ data: [0, 0], backgroundColor: ['#AAAAAA', '#00AA00'] }], labels: ["Used", "Free"] },
|
data: { datasets: [{ data: [0, 0], backgroundColor: ['#AAAAAA', '#00AA00'] }], labels: ["Used", "Free"] },
|
||||||
options: { events: [], responsive: true, legend: { position: 'none', }, animation: { animateScale: true, animateRotate: true }, width: '40px' }
|
options: { events: [], responsive: true, plugins: { legend: { display: false, } }, animation: { animateScale: true, animateRotate: true }, width: '40px' }
|
||||||
});
|
});
|
||||||
window.serverStatMemory = new Chart(document.getElementById('serverMemoryChart').getContext('2d'), {
|
window.serverStatMemory = new Chart(document.getElementById('serverMemoryChart').getContext('2d'), {
|
||||||
type: 'doughnut',
|
type: 'doughnut',
|
||||||
data: { datasets: [{ data: [0, 0], backgroundColor: ['#AAAAAA', '#00AA00'] }], labels: ["Used", "Free"] },
|
data: { datasets: [{ data: [0, 0], backgroundColor: ['#AAAAAA', '#00AA00'] }], labels: ["Used", "Free"] },
|
||||||
options: { events: [], responsive: true, legend: { position: 'none', }, animation: { animateScale: true, animateRotate: true }, width: '40px' }
|
options: { events: [], responsive: true, plugins: { legend: { display: false, } }, animation: { animateScale: true, animateRotate: true }, width: '40px' }
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -17256,9 +17240,8 @@
|
|||||||
maintainAspectRatio: false,
|
maintainAspectRatio: false,
|
||||||
elements: { line: { cubicInterpolationMode: 'monotone' } },
|
elements: { line: { cubicInterpolationMode: 'monotone' } },
|
||||||
scales: {
|
scales: {
|
||||||
y: { stacked: true },
|
x: { type: 'time', time: { tooltipFormat: 'll HH:mm' }, display: true, title: { display: false, text: '' } },
|
||||||
xAxes: [{ type: 'time', time: { tooltipFormat: 'll HH:mm' }, display: true, scaleLabel: { display: false, labelString: '' } }],
|
y: { type: 'linear', display: true, title: { display: true, text: '' }, stacked: true }
|
||||||
yAxes: [{ type: 'linear', display: true, scaleLabel: { display: true, labelString: '' } }]
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
@ -17304,8 +17287,8 @@
|
|||||||
updateServerTimelineHours();
|
updateServerTimelineHours();
|
||||||
}
|
}
|
||||||
function updateServerTimelineHours() {
|
function updateServerTimelineHours() {
|
||||||
serverTimelineConfig.options.scales.yAxes[0].type = (Q('p40log').checked ? 'logarithmic' : 'linear');
|
serverTimelineConfig.options.scales.y.type = (Q('p40log').checked ? 'logarithmic' : 'linear');
|
||||||
serverTimelineConfig.options.scales.xAxes[0].time = { min: pastDate(Q('p40time').value) };
|
serverTimelineConfig.options.scales.x.min = pastDate(Q('p40time').value);
|
||||||
window.serverMainStats.update();
|
window.serverMainStats.update();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -17320,10 +17303,10 @@
|
|||||||
|
|
||||||
var data, chartType = Q('p40type').value, timeAfter = pastDate(Q('p40time').value), servers = [], selectedServer = null, serverEmptyExists = false, serverAutoSelect = true;
|
var data, chartType = Q('p40type').value, timeAfter = pastDate(Q('p40time').value), servers = [], selectedServer = null, serverEmptyExists = false, serverAutoSelect = true;
|
||||||
if (Q('p40server').value != null) { selectedServer = decodeURIComponent(Q('p40server').value); if (selectedServer == "") { selectedServer = null; } serverAutoSelect = false; }
|
if (Q('p40server').value != null) { selectedServer = decodeURIComponent(Q('p40server').value); if (selectedServer == "") { selectedServer = null; } serverAutoSelect = false; }
|
||||||
serverTimelineConfig.options.scales.xAxes[0].time = { min: timeAfter };
|
serverTimelineConfig.options.scales.x.min = timeAfter;
|
||||||
serverTimelineConfig.options.scales.yAxes[0].stacked = ((chartType == 3) || (chartType == 4));
|
serverTimelineConfig.options.scales.y.stacked = ((chartType == 3) || (chartType == 4));
|
||||||
if (chartType == 0) { // Connections
|
if (chartType == 0) { // Connections
|
||||||
serverTimelineConfig.options.scales.yAxes[0].scaleLabel.labelString = "Connection Count";
|
serverTimelineConfig.options.scales.y.title.text = "Connection Count";
|
||||||
data = {
|
data = {
|
||||||
labels: [pastDate(0), timeAfter],
|
labels: [pastDate(0), timeAfter],
|
||||||
datasets: [
|
datasets: [
|
||||||
@ -17358,7 +17341,7 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else if (chartType == 1) { // Memory
|
} else if (chartType == 1) { // Memory
|
||||||
serverTimelineConfig.options.scales.yAxes[0].scaleLabel.labelString = "Megabytes";
|
serverTimelineConfig.options.scales.y.title.text = "Megabytes";
|
||||||
data = {
|
data = {
|
||||||
labels: [pastDate(0), timeAfter],
|
labels: [pastDate(0), timeAfter],
|
||||||
datasets: [
|
datasets: [
|
||||||
@ -17387,7 +17370,7 @@
|
|||||||
data.datasets[3].data.push({ x: serverTimelineStats[i].time, y: serverTimelineStats[i].mem.rss / (1024 * 1024) });
|
data.datasets[3].data.push({ x: serverTimelineStats[i].time, y: serverTimelineStats[i].mem.rss / (1024 * 1024) });
|
||||||
}
|
}
|
||||||
} else if ((chartType == 3) || (chartType == 4)) { // Inbound/Outbound traffic
|
} else if ((chartType == 3) || (chartType == 4)) { // Inbound/Outbound traffic
|
||||||
serverTimelineConfig.options.scales.yAxes[0].scaleLabel.labelString = "Megabytes";
|
serverTimelineConfig.options.scales.y.title.text = "Megabytes";
|
||||||
data = { labels: [pastDate(0), timeAfter], datasets: [] };
|
data = { labels: [pastDate(0), timeAfter], datasets: [] };
|
||||||
var seriesWithData = 0;
|
var seriesWithData = 0;
|
||||||
|
|
||||||
@ -17463,7 +17446,7 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else if (chartType == 5) { // CPU
|
} else if (chartType == 5) { // CPU
|
||||||
serverTimelineConfig.options.scales.yAxes[0].scaleLabel.labelString = "Usage";
|
serverTimelineConfig.options.scales.y.title.text = "Usage";
|
||||||
data = {
|
data = {
|
||||||
labels: [pastDate(0), timeAfter],
|
labels: [pastDate(0), timeAfter],
|
||||||
datasets: [
|
datasets: [
|
||||||
@ -17486,7 +17469,7 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
/*else if (chartType == 2) { // Database
|
/*else if (chartType == 2) { // Database
|
||||||
serverTimelineConfig.options.scales.yAxes[0].scaleLabel.labelString = 'Records';
|
serverTimelineConfig.options.scales.y.title.text = 'Records';
|
||||||
data = {
|
data = {
|
||||||
labels: [pastDate(0), timeAfter],
|
labels: [pastDate(0), timeAfter],
|
||||||
datasets: [
|
datasets: [
|
||||||
|
Loading…
x
Reference in New Issue
Block a user