forked from snxraven/peardock
fix up status indicator on deploy
This commit is contained in:
parent
5e8c085446
commit
3457eb0e46
3
app.js
3
app.js
@ -314,10 +314,11 @@ function handlePeerData(data, topicId, peer) {
|
|||||||
console.log(response.message)
|
console.log(response.message)
|
||||||
if (response.success && response.message.includes && response.message.includes('deployed successfully')) {
|
if (response.success && response.message.includes && response.message.includes('deployed successfully')) {
|
||||||
console.log(`[INFO] Template deployed successfully: ${response.message}`);
|
console.log(`[INFO] Template deployed successfully: ${response.message}`);
|
||||||
|
closeAllModals(); // Close all modals after successful deployment
|
||||||
|
|
||||||
hideStatusIndicator();
|
hideStatusIndicator();
|
||||||
startStatsInterval(); // Restart stats polling
|
startStatsInterval(); // Restart stats polling
|
||||||
showAlert('success', response.message);
|
showAlert('success', response.message);
|
||||||
closeAllModals(); // Close all modals after successful deployment
|
|
||||||
hideStatusIndicator();
|
hideStatusIndicator();
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -4,16 +4,14 @@ const templateSearchInput = document.getElementById('template-search-input');
|
|||||||
const templateDeployModal = new bootstrap.Modal(document.getElementById('templateDeployModalUnique'));
|
const templateDeployModal = new bootstrap.Modal(document.getElementById('templateDeployModalUnique'));
|
||||||
const deployForm = document.getElementById('deploy-form');
|
const deployForm = document.getElementById('deploy-form');
|
||||||
let templates = [];
|
let templates = [];
|
||||||
|
|
||||||
// Function to close all modals
|
|
||||||
function closeAllModals() {
|
function closeAllModals() {
|
||||||
const modals = document.querySelectorAll('.modal.show');
|
// Find and hide all open modals
|
||||||
modals.forEach(modal => {
|
const modals = document.querySelectorAll('.modal.show'); // Adjust selector if necessary
|
||||||
const modalInstance = bootstrap.Modal.getInstance(modal);
|
modals.forEach(modal => {
|
||||||
if (modalInstance) modalInstance.hide();
|
const modalInstance = bootstrap.Modal.getInstance(modal); // Get Bootstrap modal instance
|
||||||
});
|
modalInstance.hide(); // Close the modal
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
// Show status indicator
|
// Show status indicator
|
||||||
function showStatusIndicator(message = 'Processing...') {
|
function showStatusIndicator(message = 'Processing...') {
|
||||||
const statusIndicator = document.createElement('div');
|
const statusIndicator = document.createElement('div');
|
||||||
@ -156,7 +154,6 @@ function openDeployModal(template) {
|
|||||||
templateDeployModal.show();
|
templateDeployModal.show();
|
||||||
}
|
}
|
||||||
|
|
||||||
// Deploy Docker container
|
|
||||||
// Deploy Docker container
|
// Deploy Docker container
|
||||||
async function deployDockerContainer(payload) {
|
async function deployDockerContainer(payload) {
|
||||||
const { containerName, imageName, ports = [], volumes = [], envVars = [] } = payload;
|
const { containerName, imageName, ports = [], volumes = [], envVars = [] } = payload;
|
||||||
@ -178,33 +175,40 @@ async function deployDockerContainer(payload) {
|
|||||||
});
|
});
|
||||||
|
|
||||||
console.log('[INFO] Sending deployment command to the server...');
|
console.log('[INFO] Sending deployment command to the server...');
|
||||||
sendCommand('deployContainer', {
|
|
||||||
containerName,
|
return new Promise((resolve, reject) => {
|
||||||
image: imageName,
|
window.handlePeerResponse = (response) => {
|
||||||
ports: validPorts,
|
if (response.success && response.message.includes('deployed successfully')) {
|
||||||
volumes: validVolumes,
|
console.log('[INFO] Deployment response received:', response.message);
|
||||||
env: envVars.map(({ name, value }) => ({ name, value })),
|
resolve(response); // Resolve with success
|
||||||
|
} else if (response.error) {
|
||||||
|
reject(new Error(response.error)); // Reject on error
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
// Send the deployment command
|
||||||
|
sendCommand('deployContainer', {
|
||||||
|
containerName,
|
||||||
|
image: imageName,
|
||||||
|
ports: validPorts,
|
||||||
|
volumes: validVolumes,
|
||||||
|
env: envVars.map(({ name, value }) => ({ name, value })),
|
||||||
|
});
|
||||||
|
|
||||||
|
// Fallback timeout to avoid hanging indefinitely
|
||||||
|
setTimeout(() => {
|
||||||
|
reject(new Error('Deployment timed out. No response from server.'));
|
||||||
|
}, 30000); // Adjust timeout duration as needed
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
// Example of how to dispatch the event when the server response is received
|
|
||||||
function handleServerResponse(serverResponse) {
|
|
||||||
console.log('[DEBUG] Dispatching server response:', serverResponse);
|
|
||||||
const responseEvent = new CustomEvent('responseReceived', { detail: serverResponse });
|
|
||||||
window.dispatchEvent(responseEvent);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Integration for server response handling
|
|
||||||
// Ensure this function is called whenever a server response is received
|
|
||||||
async function processServerMessage(response) {
|
|
||||||
if (response.type === 'deployResult') {
|
|
||||||
handleServerResponse(response);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Handle form submission for deployment
|
|
||||||
// Handle form submission for deployment
|
// Handle form submission for deployment
|
||||||
deployForm.addEventListener('submit', async (e) => {
|
deployForm.addEventListener('submit', async (e) => {
|
||||||
|
closeAllModals();
|
||||||
|
|
||||||
e.preventDefault();
|
e.preventDefault();
|
||||||
|
|
||||||
const containerName = document.getElementById('deploy-container-name').value.trim();
|
const containerName = document.getElementById('deploy-container-name').value.trim();
|
||||||
@ -223,22 +227,18 @@ deployForm.addEventListener('submit', async (e) => {
|
|||||||
|
|
||||||
try {
|
try {
|
||||||
showStatusIndicator('Deploying container...');
|
showStatusIndicator('Deploying container...');
|
||||||
closeAllModals();
|
// Wait for deployment to complete
|
||||||
// Send the deployment request
|
const successResponse = await deployDockerContainer(deployPayload);
|
||||||
await deployDockerContainer(deployPayload);
|
|
||||||
|
|
||||||
// Wait for a specific response
|
|
||||||
// Wait for the specific response
|
|
||||||
|
|
||||||
console.log('[INFO] Deployment success:', successResponse);
|
|
||||||
hideStatusIndicator();
|
hideStatusIndicator();
|
||||||
showAlert('success', successResponse.message);
|
showAlert('success', successResponse.message);
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
console.error('[ERROR] Failed to deploy container:', error.message);
|
console.error('[ERROR] Failed to deploy container:', error.message);
|
||||||
hideStatusIndicator();
|
hideStatusIndicator();
|
||||||
|
closeAllModals();
|
||||||
showAlert('danger', error.message);
|
showAlert('danger', error.message);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
// Initialize templates on load
|
// Initialize templates on load
|
||||||
document.addEventListener('DOMContentLoaded', fetchTemplates);
|
document.addEventListener('DOMContentLoaded', fetchTemplates);
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user