luci/applications/luci-app-dawn/htdocs/luci-static/resources/view/dawn/hearing_map.js
Daniel Vijge 69eeebe23d
luci-app-dawn: error message when service not running
Display a nicer error message when the DAWN service is not running

Signed-off-by: Daniel Vijge <danielvijge@gmail.com>
2023-11-07 20:12:15 +01:00

103 lines
3.3 KiB
JavaScript

'use strict';
'require uci';
'require view';
'require dawn.dawn-common as dawn';
return view.extend({
handleSaveApply: null,
handleSave: null,
handleReset: null,
load: function() {
return Promise.all([
dawn.isDawnRPCAvailable().then(function(isAvailable) {
return ( isAvailable ? dawn.callDawnGetHearingMap() : null )
}),
dawn.isDawnRPCAvailable().then(function(isAvailable) {
return ( isAvailable ? dawn.callDawnGetNetwork() : null )
}),
dawn.callHostHints()
]);
},
render: function(data) {
const dawnHearingMapData = data[0];
const dawnNetworkData = data[1];
const hostHintsData = data[2];
let accessPointsHintsData = {};
let connectedClients = {};
for (let network in dawnNetworkData) {
connectedClients[network] = [];
let aps = Object.entries(dawnNetworkData[network]).map(function(ap) {
accessPointsHintsData[ap[0]] = {name: ap[1].hostname};
let clientData = Object.entries(ap[1]);
for (let i = 0; i < clientData.length; i++) {
if (typeof clientData[i][1] === 'object') {
connectedClients[network].push(clientData[i][0]);
}
}
});
}
if (!dawnHearingMapData || !dawnNetworkData) {
return dawn.getDawnServiceNotRunningErrorMessage();
}
const body = E([
E('h2', _('Hearing Map'))
]);
for (let network in dawnHearingMapData) {
body.appendChild(
E('h3', 'SSID: ' + network)
);
let hearing_map_table = E('table', { 'class': 'table cbi-section-table' }, [
E('tr', { 'class': 'tr table-titles' }, [
E('th', { 'class': 'th' }, _('Client')),
E('th', { 'class': 'th' }, _('Access Point')),
E('th', { 'class': 'th' }, _('Frequency')),
E('th', { 'class': 'th' }, E('span', { 'data-tooltip': _('High Throughput') }, [ _('HT') ])),
E('th', { 'class': 'th' }, E('span', { 'data-tooltip': _('Very High Throughput') }, [ _('VHT') ])),
E('th', { 'class': 'th' }, _('Signal')),
E('th', { 'class': 'th' }, E('span', { 'data-tooltip': _('Received Channel Power Indication') }, [ _('RCPI') ])),
E('th', { 'class': 'th' }, E('span', { 'data-tooltip': _('Received Signal to Noise Indicator') }, [ _('RSNI') ])),
E('th', { 'class': 'th' }, _('Channel Utilization')),
E('th', { 'class': 'th' }, _('Connected to Network')),
E('th', { 'class': 'th' }, _('Score'))
])
]);
let clients = Object.entries(dawnHearingMapData[network]).map(function(client) {
return Object.entries(client[1]).map(function(ap) {
if (ap[1].freq != 0) {
return [
dawn.getHostnameFromMAC(hostHintsData, client[0]),
dawn.getHostnameFromMAC(accessPointsHintsData, ap[0]),
dawn.getFormattedNumber(ap[1].freq, 3, 1000) + ' GHz (' + _('Channel') + ': ' + dawn.getChannelFromFrequency(ap[1].freq) + ')',
dawn.getAvailableText(ap[1].ht_capabilities && ap[1].ht_support),
dawn.getAvailableText(ap[1].vht_capabilities && ap[1].vht_support),
ap[1].signal,
ap[1].rcpi,
ap[1].rsni,
dawn.getFormattedNumber(ap[1].channel_utilization, 2, 2.55) + '%',
dawn.getYesText(connectedClients[network].includes(client[0])),
ap[1].score
]
}
})
}).flat();
cbi_update_table(hearing_map_table, clients, E('em', _('No clients connected.')));
body.appendChild(hearing_map_table);
}
return body;
}
});