perf: eliminate connection timeouts in offline mode
Fixed application freezing in offline mode by preventing unnecessary reconnection attempts: **Changes:** 1. **DSN timeouts** (localdb.go) - Added timeout=3s, readTimeout=3s, writeTimeout=3s to MySQL DSN - Reduces connection timeout from 75s to 3s when MariaDB unreachable 2. **Fast /api/db-status** (main.go) - Check connection status before attempting GetDB() - Avoid reconnection attempts on every status request - Returns cached offline status instantly 3. **Optimized sync service** (sync/service.go) - GetStatus() checks connection status before GetDB() - NeedSync() skips server check if already offline - Prevents repeated 3s timeouts on every sync info request 4. **Local pricelist fallback** (pricelist.go) - GetLatest() returns local pricelists when server offline - UI can now display pricelist version in offline mode 5. **Better UI error messages** (configs.html) - 404 shows "Не загружен" instead of "Ошибка загрузки" - Network errors show "Не доступен" in gray - Distinguishes between missing data and real errors **Performance:** - Before: 75s timeout on every offline request - After: <5ms response time in offline mode - Cached error state prevents repeated connection attempts **User Impact:** - UI no longer freezes when loading pages offline - Instant page loads and API responses - Pricelist version displays correctly in offline mode - Clear visual feedback for offline state Fixes Phase 2.5 offline mode performance issues. Co-Authored-By: Claude Sonnet 4.5 <noreply@anthropic.com>
This commit is contained in:
@@ -421,18 +421,23 @@ async function loadLatestPricelistVersion() {
|
||||
const pricelist = await resp.json();
|
||||
document.getElementById('pricelist-version').textContent = pricelist.version;
|
||||
document.getElementById('pricelist-badge').classList.remove('hidden');
|
||||
} else if (resp.status === 404) {
|
||||
// No active pricelist (normal in offline mode or when not synced)
|
||||
document.getElementById('pricelist-version').textContent = 'Не загружен';
|
||||
document.getElementById('pricelist-badge').classList.remove('hidden');
|
||||
document.getElementById('pricelist-badge').classList.add('bg-gray-100', 'text-gray-600');
|
||||
} else {
|
||||
// Show error in badge
|
||||
// Real error
|
||||
document.getElementById('pricelist-version').textContent = 'Ошибка загрузки';
|
||||
document.getElementById('pricelist-badge').classList.remove('hidden');
|
||||
document.getElementById('pricelist-badge').classList.add('bg-red-100', 'text-red-800');
|
||||
}
|
||||
} catch(e) {
|
||||
// Show error in badge
|
||||
// Network error or other exception
|
||||
console.error('Failed to load pricelist version:', e);
|
||||
document.getElementById('pricelist-version').textContent = 'Ошибка загрузки';
|
||||
document.getElementById('pricelist-version').textContent = 'Не доступен';
|
||||
document.getElementById('pricelist-badge').classList.remove('hidden');
|
||||
document.getElementById('pricelist-badge').classList.add('bg-red-100', 'text-red-800');
|
||||
document.getElementById('pricelist-badge').classList.add('bg-gray-100', 'text-gray-600');
|
||||
}
|
||||
}
|
||||
</script>
|
||||
|
||||
Reference in New Issue
Block a user