262 lines
8.6 KiB
HTML
262 lines
8.6 KiB
HTML
{% extends "base.html" %}
|
|
|
|
{% block title %}Daily Mirror - Quality Recticel{% endblock %}
|
|
|
|
{% block content %}
|
|
<div class="container-fluid">
|
|
<!-- Page Header -->
|
|
<div class="row mb-4">
|
|
<div class="col-12">
|
|
<div class="d-flex justify-content-between align-items-center">
|
|
<div>
|
|
<h1 class="h3 mb-0">📊 Daily Mirror</h1>
|
|
<p class="text-muted">Business Intelligence and Production Reporting</p>
|
|
</div>
|
|
<div>
|
|
<!-- Buttons removed; now present in top header -->
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<!-- Daily Mirror Cards -->
|
|
<div class="row">
|
|
<!-- Card 1: Build Database -->
|
|
<div class="col-lg-6 col-md-6 mb-4">
|
|
<div class="card h-100 daily-mirror-card">
|
|
<div class="card-body d-flex flex-column">
|
|
<div class="text-center mb-3">
|
|
<div class="feature-icon bg-primary">
|
|
<i class="fas fa-database"></i>
|
|
</div>
|
|
</div>
|
|
<h5 class="card-title text-center">Build Database</h5>
|
|
<p class="card-text flex-grow-1 text-center">
|
|
Upload Excel files to create and populate tables.
|
|
</p>
|
|
<div class="mt-auto">
|
|
<a href="{{ url_for('daily_mirror.daily_mirror_build_database') }}" class="btn btn-primary btn-block w-100">
|
|
<i class="fas fa-hammer"></i> Build Database
|
|
</a>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<!-- Card 2: Tune Database -->
|
|
<div class="col-lg-6 col-md-6 mb-4">
|
|
<div class="card h-100 daily-mirror-card">
|
|
<div class="card-body d-flex flex-column">
|
|
<div class="text-center mb-3">
|
|
<div class="feature-icon bg-warning">
|
|
<i class="fas fa-edit"></i>
|
|
</div>
|
|
</div>
|
|
<h5 class="card-title text-center">Tune Database</h5>
|
|
<p class="card-text flex-grow-1 text-center">
|
|
Edit and update records after import.
|
|
</p>
|
|
<div class="mt-auto">
|
|
<a href="{{ url_for('daily_mirror.tune_production_data') }}" class="btn btn-warning btn-block w-100 btn-sm mb-2">
|
|
<i class="fas fa-industry"></i> Production Orders
|
|
</a>
|
|
<a href="{{ url_for('daily_mirror.tune_orders_data') }}" class="btn btn-warning btn-block w-100 btn-sm mb-2">
|
|
<i class="fas fa-shopping-cart"></i> Customer Orders
|
|
</a>
|
|
<a href="{{ url_for('daily_mirror.tune_delivery_data') }}" class="btn btn-warning btn-block w-100 btn-sm">
|
|
<i class="fas fa-truck"></i> Delivery Records
|
|
</a>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<!-- Card 3: Daily Mirror -->
|
|
<div class="col-lg-6 col-md-6 mb-4">
|
|
<div class="card h-100 daily-mirror-card">
|
|
<div class="card-body d-flex flex-column">
|
|
<div class="text-center mb-3">
|
|
<div class="feature-icon bg-success">
|
|
<i class="fas fa-chart-line"></i>
|
|
</div>
|
|
</div>
|
|
<h5 class="card-title text-center">Daily Mirror</h5>
|
|
<p class="card-text flex-grow-1 text-center">
|
|
Generate daily production reports.
|
|
</p>
|
|
<div class="mt-auto">
|
|
<a href="{{ url_for('daily_mirror.daily_mirror_route') }}" class="btn btn-success btn-block w-100">
|
|
<i class="fas fa-plus-circle"></i> Create Daily Report
|
|
</a>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<!-- Card 4: Daily Mirror History -->
|
|
<div class="col-lg-6 col-md-6 mb-4">
|
|
<div class="card h-100 daily-mirror-card">
|
|
<div class="card-body d-flex flex-column">
|
|
<div class="text-center mb-3">
|
|
<div class="feature-icon bg-info">
|
|
<i class="fas fa-history"></i>
|
|
</div>
|
|
</div>
|
|
<h5 class="card-title text-center">Daily Mirror History</h5>
|
|
<p class="card-text flex-grow-1 text-center">
|
|
View historical production reports.
|
|
</p>
|
|
<div class="mt-auto">
|
|
<a href="{{ url_for('daily_mirror.daily_mirror_history_route') }}" class="btn btn-info btn-block w-100">
|
|
<i class="fas fa-chart-bar"></i> View History
|
|
</a>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<style>
|
|
.daily-mirror-card {
|
|
transition: transform 0.2s ease, box-shadow 0.2s ease;
|
|
border: none;
|
|
box-shadow: 0 2px 4px rgba(0,0,0,0.1);
|
|
background-color: var(--card-bg);
|
|
color: var(--text-color);
|
|
}
|
|
|
|
.daily-mirror-card:hover {
|
|
transform: translateY(-5px);
|
|
box-shadow: 0 4px 15px rgba(0,0,0,0.15);
|
|
}
|
|
|
|
.feature-icon {
|
|
width: 80px;
|
|
height: 80px;
|
|
border-radius: 50%;
|
|
display: flex;
|
|
align-items: center;
|
|
justify-content: center;
|
|
margin: 0 auto;
|
|
color: white;
|
|
font-size: 2rem;
|
|
}
|
|
|
|
/* Light mode styles */
|
|
body:not(.dark-mode) .daily-mirror-card {
|
|
background-color: #ffffff;
|
|
color: #333333;
|
|
border: 1px solid #e0e0e0;
|
|
}
|
|
|
|
body:not(.dark-mode) .card-text {
|
|
color: #666666;
|
|
}
|
|
|
|
body:not(.dark-mode) .text-muted {
|
|
color: #6c757d !important;
|
|
}
|
|
|
|
/* Dark mode styles */
|
|
body.dark-mode .daily-mirror-card {
|
|
background-color: #2d3748;
|
|
color: #e2e8f0;
|
|
border: 1px solid #4a5568;
|
|
box-shadow: 0 2px 4px rgba(255,255,255,0.1);
|
|
}
|
|
|
|
body.dark-mode .daily-mirror-card:hover {
|
|
box-shadow: 0 4px 15px rgba(255,255,255,0.15);
|
|
}
|
|
|
|
body.dark-mode .card-text {
|
|
color: #cbd5e0;
|
|
}
|
|
|
|
body.dark-mode .text-muted {
|
|
color: #a0aec0 !important;
|
|
}
|
|
|
|
body.dark-mode .h3 {
|
|
color: #e2e8f0;
|
|
}
|
|
|
|
body.dark-mode .container-fluid {
|
|
color: #e2e8f0;
|
|
}
|
|
|
|
/* Ensure buttons maintain their intended colors in both themes */
|
|
.btn-primary {
|
|
background: linear-gradient(135deg, #007bff 0%, #0056b3 100%);
|
|
border: none;
|
|
color: white;
|
|
}
|
|
|
|
.btn-warning {
|
|
background: linear-gradient(135deg, #ffc107 0%, #e0a800 100%);
|
|
border: none;
|
|
color: #212529;
|
|
}
|
|
|
|
.btn-success {
|
|
background: linear-gradient(135deg, #28a745 0%, #1e7e34 100%);
|
|
border: none;
|
|
color: white;
|
|
}
|
|
|
|
.btn-info {
|
|
background: linear-gradient(135deg, #17a2b8 0%, #138496 100%);
|
|
border: none;
|
|
color: white;
|
|
}
|
|
|
|
.btn-secondary {
|
|
background: linear-gradient(135deg, #6c757d 0%, #545b62 100%);
|
|
border: none;
|
|
color: white;
|
|
}
|
|
|
|
@media (max-width: 768px) {
|
|
.feature-icon {
|
|
width: 60px;
|
|
height: 60px;
|
|
font-size: 1.5rem;
|
|
}
|
|
}</style>
|
|
|
|
<script>
|
|
// Initialize theme on page load
|
|
document.addEventListener('DOMContentLoaded', function() {
|
|
// Apply saved theme from localStorage
|
|
const savedTheme = localStorage.getItem('theme');
|
|
const body = document.body;
|
|
|
|
if (savedTheme === 'dark') {
|
|
body.classList.add('dark-mode');
|
|
} else {
|
|
body.classList.remove('dark-mode');
|
|
}
|
|
|
|
// Update theme toggle button text if it exists
|
|
const themeToggleButton = document.getElementById('theme-toggle');
|
|
if (themeToggleButton) {
|
|
if (body.classList.contains('dark-mode')) {
|
|
themeToggleButton.textContent = 'Change to Light Mode';
|
|
} else {
|
|
themeToggleButton.textContent = 'Change to Dark Mode';
|
|
}
|
|
}
|
|
});
|
|
|
|
function showComingSoon(feature) {
|
|
alert(`${feature} functionality will be available in a future update!\n\nThis feature is currently under development and will include advanced capabilities for enhanced Daily Mirror operations.`);
|
|
}
|
|
|
|
// Auto-refresh quick stats every 5 minutes
|
|
setInterval(function() {
|
|
// This could be implemented to refresh the quick stats
|
|
console.log('Auto-refresh daily stats (not implemented yet)');
|
|
}, 300000); // 5 minutes
|
|
</script>
|
|
{% endblock %} |