added analytics page
This commit is contained in:
@@ -9,9 +9,68 @@
|
||||
</style>
|
||||
</head>
|
||||
<body>
|
||||
<nav class="navbar">
|
||||
<div class="nav-content">
|
||||
<span class="nav-logo">Slimes 🧪</span>
|
||||
<div class="nav-links">
|
||||
<a href="/" class="{% if current_page == 'leaderboard' %}active{% endif %}">Leaderboard</a>
|
||||
<a href="/analytics" class="{% if current_page == 'analytics' %}active{% endif %}">Analytics</a>
|
||||
</div>
|
||||
</div>
|
||||
</nav>
|
||||
|
||||
<main>
|
||||
{% block content %}{% endblock %}
|
||||
</main>
|
||||
<footer>{{ now() | date(format="%Y") }} - Slimes</footer>
|
||||
</body>
|
||||
|
||||
<style>
|
||||
.navbar {
|
||||
background: var(--bg-card);
|
||||
border-bottom: 1px solid var(--border-color);
|
||||
padding: 0.75rem 1rem;
|
||||
position: sticky;
|
||||
top: 0;
|
||||
z-index: 100;
|
||||
}
|
||||
|
||||
.nav-content {
|
||||
max-width: 1400px;
|
||||
margin: 0 auto;
|
||||
display: flex;
|
||||
justify-content: space-between;
|
||||
align-items: center;
|
||||
}
|
||||
|
||||
.nav-logo {
|
||||
font-weight: 800;
|
||||
color: var(--primary-color);
|
||||
font-size: 1.2rem;
|
||||
}
|
||||
|
||||
.nav-links {
|
||||
display: flex;
|
||||
gap: 1.5rem;
|
||||
}
|
||||
|
||||
.nav-links a {
|
||||
text-decoration: none;
|
||||
color: var(--text-muted);
|
||||
font-weight: 600;
|
||||
font-size: 0.9rem;
|
||||
transition: color 0.2s;
|
||||
padding: 0.5rem 0;
|
||||
border-bottom: 2px solid transparent;
|
||||
}
|
||||
|
||||
.nav-links a:hover {
|
||||
color: var(--primary-color);
|
||||
}
|
||||
|
||||
.nav-links a.active {
|
||||
color: var(--primary-color);
|
||||
border-bottom-color: var(--primary-color);
|
||||
}
|
||||
</style>
|
||||
</html>
|
||||
|
||||
200
templates/analytics.html
Normal file
200
templates/analytics.html
Normal file
@@ -0,0 +1,200 @@
|
||||
{% extends "_layout.html" %}
|
||||
|
||||
{% block content %}
|
||||
<div class="header-section">
|
||||
<h2>Benchmark Analytics</h2>
|
||||
<p style="text-align: center; color: var(--text-muted);">Insights from {{ data.total_reports }} benchmarks</p>
|
||||
</div>
|
||||
|
||||
<div class="analytics-grid">
|
||||
<div class="fact-card">
|
||||
<span class="fact-title">RAM Efficiency</span>
|
||||
<span class="fact-value">{{ data.avg_score_per_gb | round(precision=1) }}</span>
|
||||
<span class="fact-label">Avg Score per GB RAM</span>
|
||||
</div>
|
||||
<div class="fact-card">
|
||||
<span class="fact-title">CPU Thread Efficiency</span>
|
||||
<span class="fact-value">{{ data.avg_score_per_thread | round(precision=1) }}</span>
|
||||
<span class="fact-label">Avg Score per Thread</span>
|
||||
</div>
|
||||
|
||||
<div class="chart-card">
|
||||
<h3>Score Distribution</h3>
|
||||
<canvas id="distChart"></canvas>
|
||||
</div>
|
||||
|
||||
<div class="chart-card">
|
||||
<h3>Avg Score by Operating System</h3>
|
||||
<canvas id="osChart"></canvas>
|
||||
</div>
|
||||
|
||||
<div class="chart-card">
|
||||
<h3>Highest Score by Operating System</h3>
|
||||
<canvas id="osMaxChart"></canvas>
|
||||
</div>
|
||||
|
||||
<div class="chart-card">
|
||||
<h3>Lowest Score by Operating System</h3>
|
||||
<canvas id="osMinChart"></canvas>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<script src="https://cdn.jsdelivr.net/npm/chart.js"></script>
|
||||
<script>
|
||||
const analyticsData = {{ json_data | safe }};
|
||||
|
||||
const primaryColor = '#d946ef';
|
||||
const secondaryColor = '#a21caf';
|
||||
|
||||
const chartOptions = {
|
||||
responsive: true,
|
||||
maintainAspectRatio: true,
|
||||
aspectRatio: 1.5,
|
||||
plugins: {
|
||||
legend: { display: false }
|
||||
}
|
||||
};
|
||||
|
||||
// Average per OS
|
||||
new Chart(document.getElementById('osChart'), {
|
||||
type: 'bar',
|
||||
data: {
|
||||
labels: analyticsData.os_labels,
|
||||
datasets: [{
|
||||
label: 'Average Score',
|
||||
data: analyticsData.os_scores,
|
||||
backgroundColor: primaryColor,
|
||||
borderRadius: 6
|
||||
}]
|
||||
},
|
||||
options: {
|
||||
...chartOptions,
|
||||
indexAxis: 'y',
|
||||
}
|
||||
});
|
||||
|
||||
// Highest per OS
|
||||
new Chart(document.getElementById('osMaxChart'), {
|
||||
type: 'bar',
|
||||
data: {
|
||||
labels: analyticsData.os_max_labels,
|
||||
datasets: [{
|
||||
label: 'Highest Score',
|
||||
data: analyticsData.os_max_scores,
|
||||
backgroundColor: secondaryColor,
|
||||
borderRadius: 6
|
||||
}]
|
||||
},
|
||||
options: {
|
||||
...chartOptions,
|
||||
indexAxis: 'y',
|
||||
}
|
||||
});
|
||||
|
||||
// Lowest per OS
|
||||
new Chart(document.getElementById('osMinChart'), {
|
||||
type: 'bar',
|
||||
data: {
|
||||
labels: analyticsData.os_min_labels,
|
||||
datasets: [{
|
||||
label: 'Lowest Score',
|
||||
data: analyticsData.os_min_scores,
|
||||
backgroundColor: secondaryColor,
|
||||
borderRadius: 6
|
||||
}]
|
||||
},
|
||||
options: {
|
||||
...chartOptions,
|
||||
indexAxis: 'y',
|
||||
}
|
||||
});
|
||||
|
||||
// Score distribution
|
||||
new Chart(document.getElementById('distChart'), {
|
||||
type: 'bar',
|
||||
data: {
|
||||
labels: analyticsData.dist_labels,
|
||||
datasets: [{
|
||||
label: 'Reports',
|
||||
data: analyticsData.dist_counts,
|
||||
backgroundColor: 'rgba(217, 70, 239, 0.6)',
|
||||
borderColor: primaryColor,
|
||||
borderWidth: 2,
|
||||
borderRadius: 4,
|
||||
barPercentage: 1.0,
|
||||
categoryPercentage: 0.9
|
||||
}]
|
||||
},
|
||||
options: {
|
||||
...chartOptions,
|
||||
scales: {
|
||||
x: { grid: { display: false } },
|
||||
y: { beginAtZero: true, ticks: { stepSize: 1 } }
|
||||
}
|
||||
}
|
||||
});
|
||||
</script>
|
||||
|
||||
<style>
|
||||
.header-section h2 { margin-bottom: 0.5rem; }
|
||||
|
||||
.chart-card h3 {
|
||||
font-size: 0.9rem;
|
||||
text-transform: uppercase;
|
||||
color: var(--text-muted);
|
||||
margin-bottom: 1.5rem;
|
||||
}
|
||||
|
||||
.analytics-grid {
|
||||
display: grid;
|
||||
grid-template-columns: repeat(auto-fit, minmax(min(100%, 500px), 1fr));
|
||||
gap: 1.5rem;
|
||||
margin-top: 2rem;
|
||||
}
|
||||
|
||||
.chart-card {
|
||||
background: var(--bg-card);
|
||||
padding: 1.5rem;
|
||||
border-radius: 12px;
|
||||
border: 1px solid var(--border-color);
|
||||
box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.05);
|
||||
min-width: 0;
|
||||
overflow: hidden;
|
||||
}
|
||||
|
||||
.fact-card {
|
||||
background: var(--bg-card);
|
||||
color: var(--primary-color);
|
||||
padding: 2rem;
|
||||
border-radius: 12px;
|
||||
text-align: center;
|
||||
}
|
||||
|
||||
.fact-value {
|
||||
font-size: 2.5rem;
|
||||
font-weight: 800;
|
||||
display: block;
|
||||
}
|
||||
|
||||
.fact-title {
|
||||
font-size: 0.9rem;
|
||||
opacity: 0.9;
|
||||
font-weight: 600;
|
||||
text-transform: uppercase;
|
||||
letter-spacing: 1px;
|
||||
}
|
||||
|
||||
.fact-label {
|
||||
font-size: 0.9rem;
|
||||
opacity: 0.9;
|
||||
/* text-transform: uppercase; */
|
||||
/* letter-spacing: 1px; */
|
||||
}
|
||||
|
||||
@media (max-width: 900px) {
|
||||
.analytics-grid {
|
||||
grid-template-columns: 1fr;
|
||||
}
|
||||
}
|
||||
</style>
|
||||
{% endblock %}
|
||||
Reference in New Issue
Block a user