Initial commit - LEGO Instructions Manager v1.5.0
This commit is contained in:
209
app/templates/dashboard.html
Normal file
209
app/templates/dashboard.html
Normal file
@@ -0,0 +1,209 @@
|
||||
{% extends "base.html" %}
|
||||
|
||||
{% block title %}Dashboard - {{ app_name }}{% endblock %}
|
||||
|
||||
{% block content %}
|
||||
<div class="row mb-4">
|
||||
<div class="col">
|
||||
<h1>
|
||||
<i class="bi bi-speedometer2"></i> Dashboard
|
||||
</h1>
|
||||
<p class="text-muted">Welcome back, {{ current_user.username }}!</p>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<!-- Statistics Cards -->
|
||||
<div class="row mb-4">
|
||||
<div class="col-md-6 col-lg-3 mb-3">
|
||||
<div class="card stat-card h-100">
|
||||
<div class="card-body">
|
||||
<div class="d-flex justify-content-between align-items-center">
|
||||
<div>
|
||||
<h6 class="text-muted mb-2">Total Sets</h6>
|
||||
<h2 class="mb-0">{{ total_sets }}</h2>
|
||||
</div>
|
||||
<div class="text-primary">
|
||||
<i class="bi bi-box-seam display-4"></i>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="col-md-6 col-lg-3 mb-3">
|
||||
<div class="card stat-card h-100">
|
||||
<div class="card-body">
|
||||
<div class="d-flex justify-content-between align-items-center">
|
||||
<div>
|
||||
<h6 class="text-muted mb-2">Instructions</h6>
|
||||
<h2 class="mb-0">{{ total_instructions }}</h2>
|
||||
</div>
|
||||
<div class="text-success">
|
||||
<i class="bi bi-file-pdf display-4"></i>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="col-md-6 col-lg-3 mb-3">
|
||||
<div class="card stat-card h-100">
|
||||
<div class="card-body">
|
||||
<div class="d-flex justify-content-between align-items-center">
|
||||
<div>
|
||||
<h6 class="text-muted mb-2">Themes</h6>
|
||||
<h2 class="mb-0">{{ theme_stats|length }}</h2>
|
||||
</div>
|
||||
<div class="text-danger">
|
||||
<i class="bi bi-grid-3x3 display-4"></i>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="col-md-6 col-lg-3 mb-3">
|
||||
<div class="card stat-card h-100">
|
||||
<div class="card-body">
|
||||
<div class="d-flex justify-content-between align-items-center">
|
||||
<div>
|
||||
<h6 class="text-muted mb-2">Years Collected</h6>
|
||||
<h2 class="mb-0">{{ year_stats|length }}</h2>
|
||||
</div>
|
||||
<div class="text-warning">
|
||||
<i class="bi bi-calendar-range display-4"></i>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="row">
|
||||
<!-- Top Themes -->
|
||||
<div class="col-lg-6 mb-4">
|
||||
<div class="card h-100">
|
||||
<div class="card-header">
|
||||
<h5 class="mb-0">
|
||||
<i class="bi bi-bar-chart"></i> Top Themes
|
||||
</h5>
|
||||
</div>
|
||||
<div class="card-body">
|
||||
{% if theme_stats %}
|
||||
<ul class="list-group list-group-flush">
|
||||
{% for theme, count in theme_stats %}
|
||||
<li class="list-group-item d-flex justify-content-between align-items-center">
|
||||
{{ theme }}
|
||||
<span class="badge bg-primary rounded-pill">{{ count }}</span>
|
||||
</li>
|
||||
{% endfor %}
|
||||
</ul>
|
||||
{% else %}
|
||||
<p class="text-muted">No themes yet. <a href="{{ url_for('sets.add_set') }}">Add your first set!</a></p>
|
||||
{% endif %}
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<!-- Recent Years -->
|
||||
<div class="col-lg-6 mb-4">
|
||||
<div class="card h-100">
|
||||
<div class="card-header">
|
||||
<h5 class="mb-0">
|
||||
<i class="bi bi-calendar3"></i> Sets by Year
|
||||
</h5>
|
||||
</div>
|
||||
<div class="card-body">
|
||||
{% if year_stats %}
|
||||
<ul class="list-group list-group-flush">
|
||||
{% for year, count in year_stats %}
|
||||
<li class="list-group-item d-flex justify-content-between align-items-center">
|
||||
{{ year }}
|
||||
<span class="badge bg-success rounded-pill">{{ count }}</span>
|
||||
</li>
|
||||
{% endfor %}
|
||||
</ul>
|
||||
{% else %}
|
||||
<p class="text-muted">No sets yet.</p>
|
||||
{% endif %}
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<!-- Recent Sets -->
|
||||
<div class="row">
|
||||
<div class="col-12">
|
||||
<div class="card">
|
||||
<div class="card-header d-flex justify-content-between align-items-center">
|
||||
<h5 class="mb-0">
|
||||
<i class="bi bi-clock-history"></i> Recently Added Sets
|
||||
</h5>
|
||||
<a href="{{ url_for('sets.list_sets') }}" class="btn btn-sm btn-outline-primary">
|
||||
View All <i class="bi bi-arrow-right"></i>
|
||||
</a>
|
||||
</div>
|
||||
<div class="card-body dashboard">
|
||||
{% if recent_sets %}
|
||||
<div class="row">
|
||||
{% for set in recent_sets %}
|
||||
<div class="col-md-6 col-lg-4 mb-3">
|
||||
<div class="card h-100">
|
||||
<a href="{{ url_for('sets.view_set', set_id=set.id) }}" class="text-decoration-none">
|
||||
{% if set.cover_image %}
|
||||
<img src="{{ url_for('static', filename='uploads/' + set.cover_image.replace('\\', '/')) }}"
|
||||
class="card-img-top set-image" alt="{{ set.set_name }}"
|
||||
style="cursor: pointer;">
|
||||
{% elif set.image_url %}
|
||||
<img src="{{ set.image_url }}" class="card-img-top set-image" alt="{{ set.set_name }}"
|
||||
style="cursor: pointer;">
|
||||
{% else %}
|
||||
<div class="card-img-top set-image d-flex align-items-center justify-content-center bg-light"
|
||||
style="cursor: pointer;">
|
||||
<i class="bi bi-image display-1 text-muted"></i>
|
||||
</div>
|
||||
{% endif %}
|
||||
</a>
|
||||
<div class="card-body">
|
||||
<h6 class="card-title">
|
||||
{{ set.set_number }}
|
||||
{% if set.is_moc %}
|
||||
<span class="badge bg-warning text-dark" title="My Own Creation">
|
||||
<i class="bi bi-star-fill"></i>
|
||||
</span>
|
||||
{% endif %}
|
||||
</h6>
|
||||
<p class="card-text small">{{ set.set_name }}</p>
|
||||
<div class="d-flex justify-content-between align-items-center">
|
||||
<span class="badge badge-theme">{{ set.theme }}</span>
|
||||
<span class="badge badge-year">{{ set.year_released }}</span>
|
||||
</div>
|
||||
</div>
|
||||
<div class="card-footer bg-transparent">
|
||||
<a href="{{ url_for('sets.view_set', set_id=set.id) }}" class="btn btn-sm btn-primary w-100">
|
||||
View Details
|
||||
</a>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
{% endfor %}
|
||||
</div>
|
||||
{% else %}
|
||||
<div class="text-center py-5">
|
||||
<i class="bi bi-inbox display-1 text-muted"></i>
|
||||
<p class="mt-3 text-muted">No sets in your collection yet.</p>
|
||||
<div class="d-flex justify-content-center gap-2">
|
||||
<a href="{{ url_for('sets.add_set') }}" class="btn btn-danger">
|
||||
<i class="bi bi-box-seam"></i> Add Official Set
|
||||
</a>
|
||||
<a href="{{ url_for('sets.add_set') }}?type=moc" class="btn btn-warning">
|
||||
<i class="bi bi-star-fill"></i> Add MOC
|
||||
</a>
|
||||
</div>
|
||||
</div>
|
||||
{% endif %}
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
{% endblock %}
|
||||
Reference in New Issue
Block a user