mirror of
https://github.com/Ylianst/MeshCentral.git
synced 2025-01-12 07:23:21 -05:00
Can select what devices can be in the multi-desktop view
This commit is contained in:
parent
2526a0841c
commit
7eb6626daa
@ -1,6 +1,6 @@
|
|||||||
{
|
{
|
||||||
"name": "meshcentral",
|
"name": "meshcentral",
|
||||||
"version": "0.1.5-r",
|
"version": "0.1.5-s",
|
||||||
"keywords": [
|
"keywords": [
|
||||||
"Remote Management",
|
"Remote Management",
|
||||||
"Intel AMT",
|
"Intel AMT",
|
||||||
|
@ -116,10 +116,10 @@
|
|||||||
<input type=checkbox id=HostnameCheckBox onclick=onHostnameCheckBox() /><span title="Show device hostnames">Hostname</span>
|
<input type=checkbox id=HostnameCheckBox onclick=onHostnameCheckBox() /><span title="Show device hostnames">Hostname</span>
|
||||||
</div>
|
</div>
|
||||||
<div id=kvmListToolbar class=style14 style=height:100%;float:left>
|
<div id=kvmListToolbar class=style14 style=height:100%;float:left>
|
||||||
<input type="button" onclick="connectAllKvmFunction();" value="Connect All" />
|
<input type="button" onclick="connectAllKvmFunction()" value="Connect All" />
|
||||||
<input type="button" onclick="disconnectAllKvmFunction();" value="Disconnect All" />
|
<input type="button" onclick="disconnectAllKvmFunction()" value="Disconnect All" />
|
||||||
<input type="checkbox" id="autoConnectDesktopCheckbox" onclick="autoConnectDesktops(event)" />AutoConnect
|
<input type="checkbox" id="autoConnectDesktopCheckbox" onclick="autoConnectDesktops(event)" />AutoConnect
|
||||||
<input type="button" onclick="showMultiDesktopSettings();" value="Settings" />
|
<input type="button" onclick="showMultiDesktopSettings()" value="Settings" />
|
||||||
</div>
|
</div>
|
||||||
<div id=devMapToolbar class=style14 style=height:100%;float:left>
|
<div id=devMapToolbar class=style14 style=height:100%;float:left>
|
||||||
<input type=text id=mapSearchLocation placeholder="Search Location" onfocus=onMapSearchFocus(1) onblur=onMapSearchFocus(0) />
|
<input type=text id=mapSearchLocation placeholder="Search Location" onfocus=onMapSearchFocus(1) onblur=onMapSearchFocus(0) />
|
||||||
@ -367,6 +367,7 @@
|
|||||||
<div>
|
<div>
|
||||||
|
|
||||||
<input id="DeskCAD" type="button" value="Ctrl-Alt-Del" onkeypress="return false" onkeydown="return false" onclick="sendCAD()">
|
<input id="DeskCAD" type="button" value="Ctrl-Alt-Del" onkeypress="return false" onkeydown="return false" onclick="sendCAD()">
|
||||||
|
<span title="Toggle mouse and keyboard input"><input id="DeskControl" type="checkbox" onkeypress="return false" onkeydown="return false" onclick="toggleKvmControl()">Input</span>
|
||||||
</div>
|
</div>
|
||||||
</td>
|
</td>
|
||||||
</tr>
|
</tr>
|
||||||
@ -659,6 +660,7 @@
|
|||||||
var debugLevel = {{{debuglevel}}};
|
var debugLevel = {{{debuglevel}}};
|
||||||
var features = {{{features}}};
|
var features = {{{features}}};
|
||||||
var multiDesktop = {};
|
var multiDesktop = {};
|
||||||
|
var multiDesktopFilter = null;
|
||||||
var serverPublicNamePort = "{{{serverDnsName}}}:{{{serverPublicPort}}}";
|
var serverPublicNamePort = "{{{serverDnsName}}}:{{{serverPublicPort}}}";
|
||||||
var amtScanResults = null;
|
var amtScanResults = null;
|
||||||
var debugmode = false;
|
var debugmode = false;
|
||||||
@ -721,6 +723,7 @@
|
|||||||
showHostnames = (getstore("showHostnames", 0) == 1);
|
showHostnames = (getstore("showHostnames", 0) == 1);
|
||||||
Q('HostnameCheckBox').checked = showHostnames;
|
Q('HostnameCheckBox').checked = showHostnames;
|
||||||
Q('viewselect').value = getstore("deviceView", 1);
|
Q('viewselect').value = getstore("deviceView", 1);
|
||||||
|
Q('DeskControl').checked = (getstore('DeskControl', 1) == 1);
|
||||||
|
|
||||||
// Display the page devices
|
// Display the page devices
|
||||||
onSortSelectChange();
|
onSortSelectChange();
|
||||||
@ -1288,7 +1291,7 @@
|
|||||||
}
|
}
|
||||||
|
|
||||||
function ondockeypress(e) {
|
function ondockeypress(e) {
|
||||||
if (!xxdialogMode && xxcurrentView == 11 && desktop) return desktop.m.handleKeys(e);
|
if (!xxdialogMode && xxcurrentView == 11 && desktop && Q("DeskControl").checked) return desktop.m.handleKeys(e);
|
||||||
if (!xxdialogMode && xxcurrentView == 12 && terminal && terminal.State == 3) return terminal.m.TermHandleKeys(e);
|
if (!xxdialogMode && xxcurrentView == 12 && terminal && terminal.State == 3) return terminal.m.TermHandleKeys(e);
|
||||||
if (!xxdialogMode && xxcurrentView == 15) return agentConsoleHandleKeys(e);
|
if (!xxdialogMode && xxcurrentView == 15) return agentConsoleHandleKeys(e);
|
||||||
if (xxdialogMode || xxcurrentView != 1) return;
|
if (xxdialogMode || xxcurrentView != 1) return;
|
||||||
@ -1324,7 +1327,7 @@
|
|||||||
}
|
}
|
||||||
|
|
||||||
function ondockeydown(e) {
|
function ondockeydown(e) {
|
||||||
if (!xxdialogMode && xxcurrentView == 11 && desktop) { return desktop.m.handleKeyDown(e); }
|
if (!xxdialogMode && xxcurrentView == 11 && desktop && Q("DeskControl").checked) { return desktop.m.handleKeyDown(e); }
|
||||||
if (!xxdialogMode && xxcurrentView == 12 && terminal && terminal.State == 3) { return terminal.m.TermHandleKeyDown(e); }
|
if (!xxdialogMode && xxcurrentView == 12 && terminal && terminal.State == 3) { return terminal.m.TermHandleKeyDown(e); }
|
||||||
if (!xxdialogMode && xxcurrentView == 13 && e.keyCode == 116 && p13filetree != null) { haltEvent(e); return false; } // F5 Refresh on files
|
if (!xxdialogMode && xxcurrentView == 13 && e.keyCode == 116 && p13filetree != null) { haltEvent(e); return false; } // F5 Refresh on files
|
||||||
if (!xxdialogMode && xxcurrentView == 15) { return agentConsoleHandleKeys(e); }
|
if (!xxdialogMode && xxcurrentView == 15) { return agentConsoleHandleKeys(e); }
|
||||||
@ -1342,7 +1345,7 @@
|
|||||||
}
|
}
|
||||||
|
|
||||||
function ondockeyup(e) {
|
function ondockeyup(e) {
|
||||||
if (!xxdialogMode && xxcurrentView == 11 && desktop) return desktop.m.handleKeyUp(e);
|
if (!xxdialogMode && xxcurrentView == 11 && desktop && Q("DeskControl").checked) return desktop.m.handleKeyUp(e);
|
||||||
if (!xxdialogMode && xxcurrentView == 12 && terminal && terminal.State == 3) return terminal.m.TermHandleKeyUp(e);
|
if (!xxdialogMode && xxcurrentView == 12 && terminal && terminal.State == 3) return terminal.m.TermHandleKeyUp(e);
|
||||||
if (!xxdialogMode && xxcurrentView == 13 && e.keyCode == 116 && p13filetree != null) { p13folderup(9999); haltEvent(e); return false; } // F5 Refresh on files
|
if (!xxdialogMode && xxcurrentView == 13 && e.keyCode == 116 && p13filetree != null) { p13folderup(9999); haltEvent(e); return false; } // F5 Refresh on files
|
||||||
if (xxdialogMode && e.keyCode == 27) { dialogclose(0); }
|
if (xxdialogMode && e.keyCode == 27) { dialogclose(0); }
|
||||||
@ -1354,6 +1357,7 @@
|
|||||||
var deviceHeaderId = 0;
|
var deviceHeaderId = 0;
|
||||||
var deviceHeaderCount;
|
var deviceHeaderCount;
|
||||||
var deviceHeaders = {};
|
var deviceHeaders = {};
|
||||||
|
var oldviewmode = 0;
|
||||||
function updateDevices() {
|
function updateDevices() {
|
||||||
var r = '', c = 0, current = null, count = 0, displayedMeshes = {}, view = Q('viewselect').value;
|
var r = '', c = 0, current = null, count = 0, displayedMeshes = {}, view = Q('viewselect').value;
|
||||||
QV('xdevices', view < 4);
|
QV('xdevices', view < 4);
|
||||||
@ -1382,6 +1386,8 @@
|
|||||||
// Save the list of currently checked nodeid's
|
// Save the list of currently checked nodeid's
|
||||||
var checkedNodeids = [], elements = document.getElementsByClassName("DeviceCheckbox"), checkcount = 0;
|
var checkedNodeids = [], elements = document.getElementsByClassName("DeviceCheckbox"), checkcount = 0;
|
||||||
for (var i in elements) { if (elements[i].checked) { checkedNodeids.push(elements[i].value); } }
|
for (var i in elements) { if (elements[i].checked) { checkedNodeids.push(elements[i].value); } }
|
||||||
|
if ((oldviewmode < 3) && (view == 3)) { multiDesktopFilter = checkedNodeids; }
|
||||||
|
else if ((oldviewmode == 3) && (view < 3)) { checkedNodeids = multiDesktopFilter; }
|
||||||
|
|
||||||
// Go thru the list of nodes and display them
|
// Go thru the list of nodes and display them
|
||||||
for (var i in nodes) {
|
for (var i in nodes) {
|
||||||
@ -1439,6 +1445,7 @@
|
|||||||
r += '<div class=g1 style=height:18px;float:left></div><div class=g2 style=height:18px;float:right></div>';
|
r += '<div class=g1 style=height:18px;float:left></div><div class=g2 style=height:18px;float:right></div>';
|
||||||
r += '<div style=cursor:pointer;font-size:14px title="' + title + '" onclick=gotoDevice(\'' + nodes[i]._id + '\')><span style=float:right>' + nodestate + '</span><span style=width:300px>' + name + '</span></div></div></td></tr>';
|
r += '<div style=cursor:pointer;font-size:14px title="' + title + '" onclick=gotoDevice(\'' + nodes[i]._id + '\')><span style=float:right>' + nodestate + '</span><span style=width:300px>' + name + '</span></div></div></td></tr>';
|
||||||
} else if ((view == 3) && (nodes[i].conn & 1) && ((meshrights & 8) != 0)) {
|
} else if ((view == 3) && (nodes[i].conn & 1) && ((meshrights & 8) != 0)) {
|
||||||
|
if ((multiDesktopFilter.length == 0) || (multiDesktopFilter.indexOf('devid_' + nodes[i]._id) >= 0)) {
|
||||||
r += '<div id=devs style=display:inline-block;margin:1px;background-color:lightgray;border-radius:5px;position:relative><div style=padding:3px;cursor:pointer onclick=gotoDevice(\'' + nodes[i]._id + '\',11)>';
|
r += '<div id=devs style=display:inline-block;margin:1px;background-color:lightgray;border-radius:5px;position:relative><div style=padding:3px;cursor:pointer onclick=gotoDevice(\'' + nodes[i]._id + '\',11)>';
|
||||||
//r += '<input class="' + nodes[i].meshid + ' DeviceCheckbox" onclick=p1updateInfo() value=devid_' + nodes[i]._id + ' type=checkbox style=float:left>';
|
//r += '<input class="' + nodes[i].meshid + ' DeviceCheckbox" onclick=p1updateInfo() value=devid_' + nodes[i]._id + ' type=checkbox style=float:left>';
|
||||||
r += '<div class="j' + icon + '" style=width:16px;float:left></div> ' + name + '</div>';
|
r += '<div class="j' + icon + '" style=width:16px;float:left></div> ' + name + '</div>';
|
||||||
@ -1446,6 +1453,7 @@
|
|||||||
r += '</div>';
|
r += '</div>';
|
||||||
kvmDivs.push(nodes[i]._id);
|
kvmDivs.push(nodes[i]._id);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
deviceHeaderTotal++;
|
deviceHeaderTotal++;
|
||||||
if (typeof deviceHeaderCount[nodes[i].state] == 'undefined') { deviceHeaderCount[nodes[i].state] = 1; } else { deviceHeaderCount[nodes[i].state]++; }
|
if (typeof deviceHeaderCount[nodes[i].state] == 'undefined') { deviceHeaderCount[nodes[i].state] = 1; } else { deviceHeaderCount[nodes[i].state]++; }
|
||||||
@ -1553,8 +1561,8 @@
|
|||||||
disconnectAllKvmFunction();
|
disconnectAllKvmFunction();
|
||||||
Q('autoConnectDesktopCheckbox').checked = false;
|
Q('autoConnectDesktopCheckbox').checked = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
oldviewmode = view;
|
||||||
}
|
}
|
||||||
|
|
||||||
function toggleKvmDevice(nodeid) {
|
function toggleKvmDevice(nodeid) {
|
||||||
@ -1588,14 +1596,15 @@
|
|||||||
}
|
}
|
||||||
|
|
||||||
function connectMultiDesktop(node, contype) {
|
function connectMultiDesktop(node, contype) {
|
||||||
var nodeid = node._id;
|
var nodeid = node._id, shortid = nodeid.split('/')[2];
|
||||||
var desk = multiDesktop[nodeid];
|
var desk = multiDesktop[nodeid];
|
||||||
if (desk == null) {
|
if (desk == null) {
|
||||||
|
if (Q('kvmid_' + shortid) == null) return; // Check if this device is being displayed, if not, exit now.
|
||||||
if (contype == 2) {
|
if (contype == 2) {
|
||||||
// Setup the Intel AMT remote desktop
|
// Setup the Intel AMT remote desktop
|
||||||
if ((node.intelamt.user == null) || (node.intelamt.user == '')) { return; }
|
if ((node.intelamt.user == null) || (node.intelamt.user == '')) { return; }
|
||||||
desk = CreateAmtRedirect(CreateAmtRemoteDesktop('kvmid_' + nodeid.split('/')[2]));
|
desk = CreateAmtRedirect(CreateAmtRemoteDesktop('kvmid_' + shortid));
|
||||||
desk.shortid = nodeid.split('/')[2];
|
desk.shortid = shortid;
|
||||||
//desk.debugmode = debugmode;
|
//desk.debugmode = debugmode;
|
||||||
desk.onStateChanged = onMultiDesktopStateChange;
|
desk.onStateChanged = onMultiDesktopStateChange;
|
||||||
desk.m.bpp = 1;
|
desk.m.bpp = 1;
|
||||||
@ -1607,8 +1616,8 @@
|
|||||||
multiDesktop[nodeid] = desk;
|
multiDesktop[nodeid] = desk;
|
||||||
} else if (contype == 1) {
|
} else if (contype == 1) {
|
||||||
// Setup the Mesh Agent remote desktop
|
// Setup the Mesh Agent remote desktop
|
||||||
desk = CreateAgentRedirect(meshserver, CreateAgentRemoteDesktop('kvmid_' + nodeid.split('/')[2]), serverPublicNamePort);
|
desk = CreateAgentRedirect(meshserver, CreateAgentRemoteDesktop('kvmid_' + shortid), serverPublicNamePort);
|
||||||
desk.shortid = nodeid.split('/')[2];
|
desk.shortid = shortid;
|
||||||
desk.attemptWebRTC = attemptWebRTC;
|
desk.attemptWebRTC = attemptWebRTC;
|
||||||
desk.onStateChanged = onMultiDesktopStateChange;
|
desk.onStateChanged = onMultiDesktopStateChange;
|
||||||
desk.m.CompressionLevel = multidesktopsettings.quality;
|
desk.m.CompressionLevel = multidesktopsettings.quality;
|
||||||
@ -3333,6 +3342,9 @@
|
|||||||
desktop.m.sendcad();
|
desktop.m.sendcad();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Toggle mouse and keyboard input
|
||||||
|
function toggleKvmControl() { putstore('DeskControl', (Q("DeskControl").checked?1:0)); }
|
||||||
|
|
||||||
// Save the desktop image to file
|
// Save the desktop image to file
|
||||||
function deskSaveImage() {
|
function deskSaveImage() {
|
||||||
if (xxdialogMode || desktop == null || desktop.State != 3) return;
|
if (xxdialogMode || desktop == null || desktop.State != 3) return;
|
||||||
@ -3354,10 +3366,10 @@
|
|||||||
desktop.m.SetDisplay(display);
|
desktop.m.SetDisplay(display);
|
||||||
}
|
}
|
||||||
|
|
||||||
function dmousedown(e) { if (!xxdialogMode && desktop != null) desktop.m.mousedown(e) }
|
function dmousedown(e) { if (!xxdialogMode && desktop != null && Q('DeskControl').checked) desktop.m.mousedown(e) }
|
||||||
function dmouseup(e) { if (!xxdialogMode && desktop != null) desktop.m.mouseup(e) }
|
function dmouseup(e) { if (!xxdialogMode && desktop != null && Q('DeskControl').checked) desktop.m.mouseup(e) }
|
||||||
function dmousemove(e) { if (!xxdialogMode && desktop != null) desktop.m.mousemove(e) }
|
function dmousemove(e) { if (!xxdialogMode && desktop != null && Q('DeskControl').checked) desktop.m.mousemove(e) }
|
||||||
function dmousewheel(e) { if (!xxdialogMode && desktop != null) { desktop.m.mousewheel(e); haltEvent(e); return true; } return false; }
|
function dmousewheel(e) { if (!xxdialogMode && desktop != null && Q('DeskControl').checked) { desktop.m.mousewheel(e); haltEvent(e); return true; } return false; }
|
||||||
function drotate(x) { if (!xxdialogMode && desktop != null) { desktop.m.setRotation(desktop.m.rotation + x); deskAdjust(); deskAdjust(); } }
|
function drotate(x) { if (!xxdialogMode && desktop != null) { desktop.m.setRotation(desktop.m.rotation + x); deskAdjust(); deskAdjust(); } }
|
||||||
|
|
||||||
//
|
//
|
||||||
|
Loading…
Reference in New Issue
Block a user