forked from snxraven/peardock
Feat: auto collapse when connection is made
This commit is contained in:
parent
956b7ee056
commit
37aa448011
67
app.js
67
app.js
@ -33,6 +33,33 @@ collapseSidebarBtn.addEventListener('click', () => {
|
|||||||
btn.innerHTML = sidebar.classList.contains('collapsed') ? '>' : '<';
|
btn.innerHTML = sidebar.classList.contains('collapsed') ? '>' : '<';
|
||||||
});
|
});
|
||||||
|
|
||||||
|
function handlePeerData(data, topicId, peer) {
|
||||||
|
try {
|
||||||
|
const response = JSON.parse(data.toString());
|
||||||
|
console.log(`[DEBUG] Received data from peer (topic: ${topicId}): ${JSON.stringify(response)}`);
|
||||||
|
|
||||||
|
if (response.type === 'containers') {
|
||||||
|
if (window.activePeer === peer) {
|
||||||
|
renderContainers(response.data);
|
||||||
|
}
|
||||||
|
} else if (response.type === 'terminalOutput') {
|
||||||
|
appendTerminalOutput(response.data, response.containerId, response.encoding);
|
||||||
|
} else if (response.type === 'containerConfig') {
|
||||||
|
if (window.inspectContainerCallback) {
|
||||||
|
window.inspectContainerCallback(response.data);
|
||||||
|
window.inspectContainerCallback = null; // Reset the callback
|
||||||
|
}
|
||||||
|
} else if (response.type === 'stats') {
|
||||||
|
updateContainerStats(response.data);
|
||||||
|
} else if (response.error) {
|
||||||
|
console.error(`[ERROR] Server error: ${response.error}`);
|
||||||
|
}
|
||||||
|
} catch (err) {
|
||||||
|
console.error(`[ERROR] Failed to parse data from peer (topic: ${topicId}): ${err.message}`);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
// Add a new connection
|
// Add a new connection
|
||||||
addConnectionForm.addEventListener('submit', (e) => {
|
addConnectionForm.addEventListener('submit', (e) => {
|
||||||
e.preventDefault();
|
e.preventDefault();
|
||||||
@ -60,7 +87,7 @@ function addConnection(topicHex) {
|
|||||||
</span>
|
</span>
|
||||||
<button class="btn btn-sm btn-danger disconnect-btn">
|
<button class="btn btn-sm btn-danger disconnect-btn">
|
||||||
<i class="fas fa-plug"></i>
|
<i class="fas fa-plug"></i>
|
||||||
</button>
|
</button>
|
||||||
`;
|
`;
|
||||||
|
|
||||||
// Add click event to switch connection
|
// Add click event to switch connection
|
||||||
@ -96,35 +123,7 @@ function addConnection(topicHex) {
|
|||||||
connections[topicId].peer = peer;
|
connections[topicId].peer = peer;
|
||||||
updateConnectionStatus(topicId, true);
|
updateConnectionStatus(topicId, true);
|
||||||
|
|
||||||
|
|
||||||
function handlePeerData(data, topicId, peer) {
|
|
||||||
try {
|
|
||||||
const response = JSON.parse(data.toString());
|
|
||||||
console.log(`[DEBUG] Received data from peer (topic: ${topicId}): ${JSON.stringify(response)}`);
|
|
||||||
|
|
||||||
if (response.type === 'containers') {
|
|
||||||
if (window.activePeer === peer) {
|
|
||||||
renderContainers(response.data);
|
|
||||||
}
|
|
||||||
} else if (response.type === 'terminalOutput') {
|
|
||||||
appendTerminalOutput(response.data, response.containerId, response.encoding);
|
|
||||||
} else if (response.type === 'containerConfig') {
|
|
||||||
if (window.inspectContainerCallback) {
|
|
||||||
window.inspectContainerCallback(response.data);
|
|
||||||
window.inspectContainerCallback = null; // Reset the callback
|
|
||||||
}
|
|
||||||
} else if (response.type === 'stats') {
|
|
||||||
updateContainerStats(response.data);
|
|
||||||
} else if (response.error) {
|
|
||||||
console.error(`[ERROR] Server error: ${response.error}`);
|
|
||||||
}
|
|
||||||
} catch (err) {
|
|
||||||
console.error(`[ERROR] Failed to parse data from peer (topic: ${topicId}): ${err.message}`);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
peer.on('data', (data) => {
|
peer.on('data', (data) => {
|
||||||
// Handle incoming data
|
|
||||||
handlePeerData(data, topicId, peer);
|
handlePeerData(data, topicId, peer);
|
||||||
});
|
});
|
||||||
|
|
||||||
@ -145,8 +144,18 @@ function addConnection(topicHex) {
|
|||||||
switchConnection(topicId);
|
switchConnection(topicId);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
// Collapse the sidebar after adding a new connection
|
||||||
|
const sidebar = document.getElementById('sidebar');
|
||||||
|
const collapseSidebarBtn = document.getElementById('collapse-sidebar-btn');
|
||||||
|
if (!sidebar.classList.contains('collapsed')) {
|
||||||
|
sidebar.classList.add('collapsed');
|
||||||
|
collapseSidebarBtn.innerHTML = '>';
|
||||||
|
console.log('[INFO] Sidebar collapsed after adding new connection.');
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
function disconnectConnection(topicId, connectionItem) {
|
function disconnectConnection(topicId, connectionItem) {
|
||||||
const connection = connections[topicId];
|
const connection = connections[topicId];
|
||||||
if (!connection) {
|
if (!connection) {
|
||||||
|
Loading…
Reference in New Issue
Block a user