diff --git a/app/static/js/app.js b/app/static/js/app.js index 795bca6..8af400d 100644 --- a/app/static/js/app.js +++ b/app/static/js/app.js @@ -574,7 +574,7 @@ function updateStatus(status) { function updateLastRefresh() { const now = new Date(); const timeStr = now.toLocaleTimeString(); - document.getElementById('lastRefresh').textContent = `Last refresh: ${timeStr}`; + document.getElementById('lastRefresh').textContent = `Updated: ${timeStr}`; } /** diff --git a/app/static/js/dm.js b/app/static/js/dm.js index 7497b65..5b055a2 100644 --- a/app/static/js/dm.js +++ b/app/static/js/dm.js @@ -36,6 +36,9 @@ document.addEventListener('DOMContentLoaded', async function() { // Load conversations into dropdown await loadConversations(); + // Load connection status + await loadStatus(); + // Check for initial conversation from URL parameter if (window.MC_CONFIG && window.MC_CONFIG.initialConversation) { const convId = window.MC_CONFIG.initialConversation; @@ -45,8 +48,6 @@ document.addEventListener('DOMContentLoaded', async function() { // Setup auto-refresh setupAutoRefresh(); - - updateStatus('connected', 'Ready'); }); // Handle page restoration from cache (PWA back/forward navigation) @@ -484,6 +485,9 @@ function setupAutoRefresh() { // Reload conversations to update unread indicators await loadConversations(); + // Update connection status + await loadStatus(); + // If viewing a conversation, check for new messages if (currentConversationId) { await checkForNewMessages(); @@ -659,21 +663,37 @@ async function markAsRead(conversationId, timestamp) { populateConversationSelector(); } +/** + * Load connection status + */ +async function loadStatus() { + try { + const response = await fetch('/api/status'); + const data = await response.json(); + + if (data.success) { + updateStatus(data.connected ? 'connected' : 'disconnected'); + } + } catch (error) { + console.error('Error loading status:', error); + updateStatus('disconnected'); + } +} + /** * Update status indicator */ -function updateStatus(status, message) { +function updateStatus(status) { const statusEl = document.getElementById('dmStatusText'); if (!statusEl) return; - const statusColors = { - 'connected': 'success', - 'disconnected': 'danger', - 'connecting': 'warning' + const icons = { + connected: ' Connected', + disconnected: ' Disconnected', + connecting: ' Connecting...' }; - const color = statusColors[status] || 'secondary'; - statusEl.innerHTML = ` ${message}`; + statusEl.innerHTML = icons[status] || icons.connecting; } /** diff --git a/app/templates/dm.html b/app/templates/dm.html index ef158ad..fee0afe 100644 --- a/app/templates/dm.html +++ b/app/templates/dm.html @@ -109,15 +109,17 @@