quantum-observer-network / monitoring.html
elasko-aim's picture
Веб-приложение представляет собой визуально-ориентированную интерфейсную систему для отображения многослойных “квантовых наблюдений”, состояния сенсоров и аномалий в реальном времени, построенную вокруг метафоры Quantum Observer Network и использующую UI-парадигмы мониторинга/визоринга.
9a5585c verified
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Live Monitoring | Quantum Observer Network</title>
<link rel="stylesheet" href="style.css">
<script src="https://cdn.tailwindcss.com"></script>
<script src="https://cdn.jsdelivr.net/npm/feather-icons/dist/feather.min.js"></script>
<script src="https://unpkg.com/feather-icons"></script>
<script src="https://cdn.jsdelivr.net/npm/chart.js"></script>
<script>
tailwind.config = {
theme: {
extend: {
colors: {
primary: '#ec4899',
secondary: '#84cc16'
}
}
}
}
</script>
</head>
<body class="bg-gray-50 text-gray-800">
<anomaly-visualizer></anomaly-visualizer>
<custom-navbar></custom-navbar>
<main class="min-h-screen">
<!-- Monitoring Header -->
<section class="bg-white shadow-sm">
<div class="container mx-auto px-4 py-6">
<div class="flex flex-col md:flex-row justify-between items-start md:items-center">
<h1 class="text-3xl font-bold">
<span class="text-secondary">Live</span> Monitoring
</h1>
<div class="flex items-center space-x-4 mt-4 md:mt-0">
<div class="bg-green-100 text-green-800 px-3 py-1 rounded-full text-sm font-medium">
<i data-feather="activity" class="inline w-4 h-4 mr-1"></i>
Streaming Data
</div>
<div class="text-sm text-gray-500">
Refresh: <span class="font-medium">5s</span>
</div>
</div>
</div>
</div>
</section>
<!-- Main Monitoring Grid -->
<section class="container mx-auto px-4 py-8">
<div class="grid grid-cols-1 lg:grid-cols-2 gap-8">
<!-- Quantum Fluctuations Chart -->
<div class="bg-white rounded-xl shadow-md p-6">
<div class="flex justify-between items-center mb-6">
<h3 class="text-lg font-semibold">Quantum Fluctuations</h3>
<div class="flex space-x-2">
<button class="px-3 py-1 bg-gray-100 rounded-lg text-sm">1h</button>
<button class="px-3 py-1 bg-primary text-white rounded-lg text-sm">24h</button>
<button class="px-3 py-1 bg-gray-100 rounded-lg text-sm">7d</button>
</div>
</div>
<canvas id="quantumChart" height="250"></canvas>
</div>
<!-- Observer Status -->
<div class="bg-white rounded-xl shadow-md p-6">
<h3 class="text-lg font-semibold mb-6">Observer Status</h3>
<div class="space-y-4">
<div class="flex items-center justify-between">
<div class="flex items-center">
<div class="w-3 h-3 bg-green-500 rounded-full mr-3"></div>
<span>Observer #1</span>
</div>
<span class="text-sm text-gray-500">Active (12.7ms)</span>
</div>
<div class="flex items-center justify-between">
<div class="flex items-center">
<div class="w-3 h-3 bg-green-500 rounded-full mr-3"></div>
<span>Observer #2</span>
</div>
<span class="text-sm text-gray-500">Active (8.2ms)</span>
</div>
<div class="flex items-center justify-between">
<div class="flex items-center">
<div class="w-3 h-3 bg-yellow-500 rounded-full mr-3"></div>
<span>Observer #3</span>
</div>
<span class="text-sm text-gray-500">Standby</span>
</div>
<div class="flex items-center justify-between">
<div class="flex items-center">
<div class="w-3 h-3 bg-green-500 rounded-full mr-3"></div>
<span>Observer #4</span>
</div>
<span class="text-sm text-gray-500">Active (15.1ms)</span>
</div>
<div class="flex items-center justify-between">
<div class="flex items-center">
<div class="w-3 h-3 bg-red-500 rounded-full mr-3"></div>
<span>Observer #5</span>
</div>
<span class="text-sm text-gray-500">Offline</span>
</div>
</div>
</div>
<!-- Anomaly Detection -->
<div class="bg-white rounded-xl shadow-md p-6">
<h3 class="text-lg font-semibold mb-6">Anomaly Detection</h3>
<div class="flex items-center justify-between mb-4">
<div>
<p class="text-2xl font-bold text-primary">3</p>
<p class="text-sm text-gray-500">Active anomalies</p>
</div>
<div class="bg-pink-100 p-3 rounded-lg">
<i data-feather="alert-triangle" class="text-primary w-6 h-6"></i>
</div>
</div>
<div class="space-y-3">
<div class="p-3 bg-red-50 rounded-lg border-l-4 border-red-500">
<div class="flex justify-between">
<span class="font-medium">Quantum decoherence</span>
<span class="text-xs text-red-500">Critical</span>
</div>
<p class="text-sm text-gray-600 mt-1">Observer #7, Sector 4</p>
</div>
<div class="p-3 bg-yellow-50 rounded-lg border-l-4 border-yellow-500">
<div class="flex justify-between">
<span class="font-medium">Latency spike</span>
<span class="text-xs text-yellow-500">Warning</span>
</div>
<p class="text-sm text-gray-600 mt-1">Observer #2, Sector 1</p>
</div>
<div class="p-3 bg-yellow-50 rounded-lg border-l-4 border-yellow-500">
<div class="flex justify-between">
<span class="font-medium">Signal interference</span>
<span class="text-xs text-yellow-500">Warning</span>
</div>
<p class="text-sm text-gray-600 mt-1">Observer #4, Sector 3</p>
</div>
</div>
</div>
<!-- Reality Coherence Map -->
<div class="bg-white rounded-xl shadow-md p-6">
<h3 class="text-lg font-semibold mb-6">Reality Coherence Map</h3>
<div class="bg-gray-100 rounded-lg p-4 flex items-center justify-center">
<div class="relative">
<img src="http://static.photos/technology/640x360/42" alt="Reality Map" class="rounded-lg">
<div class="absolute -top-2 -right-2 bg-red-500 text-white text-xs px-2 py-1 rounded-full">Live</div>
</div>
</div>
<div class="mt-4 grid grid-cols-3 gap-2">
<div class="text-center">
<p class="text-sm text-gray-500">Sector 1</p>
<p class="font-medium">98.2%</p>
</div>
<div class="text-center">
<p class="text-sm text-gray-500">Sector 2</p>
<p class="font-medium">96.7%</p>
</div>
<div class="text-center">
<p class="text-sm text-gray-500">Sector 3</p>
<p class="font-medium">91.4%</p>
</div>
</div>
</div>
</div>
</section>
</main>
<custom-footer></custom-footer>
<script src="components/navbar.js"></script>
<script src="components/footer.js"></script>
<script src="components/anomaly-visualizer.js"></script>
<script src="script.js"></script>
<script>
feather.replace();
// Initialize charts
document.addEventListener('DOMContentLoaded', function() {
// Quantum Fluctuations Chart
const quantumCtx = document.getElementById('quantumChart').getContext('2d');
const quantumChart = new Chart(quantumCtx, {
type: 'line',
data: {
labels: Array.from({length: 24}, (_, i) => `${i}:00`),
datasets: [{
label: 'Quantum Variance',
data: [85, 86, 87, 88, 89, 90, 91, 92, 91, 90, 89, 88, 87, 86, 85, 84, 83, 82, 83, 84, 85, 86, 87, 88],
borderColor: '#ec4899',
backgroundColor: 'rgba(236, 72, 153, 0.1)',
borderWidth: 2,
tension: 0.4,
fill: true
}]
},
options: {
responsive: true,
plugins: {
legend: {
display: false
}
},
scales: {
y: {
beginAtZero: false,
min: 80,
max: 100
}
}
}
});
// Simulate live data updates
setInterval(() => {
const newData = quantumChart.data.datasets[0].data.map(value => {
const change = (Math.random() - 0.5) * 2;
return Math.max(80, Math.min(100, value + change));
});
quantumChart.data.datasets[0].data = newData;
quantumChart.update();
}, 5000);
});
</script>
</body>
</html>