- Created import_labels.py with CSV and Excel file processing - Implemented validation for order rows and date format handling - Added import-labels route with preview and save functionality - Created import_labels.html template with new app UI styling - Added import card to labels module index - Added openpyxl to requirements.txt for Excel support
122 lines
4.7 KiB
HTML
122 lines
4.7 KiB
HTML
{% extends "base.html" %}
|
|
|
|
{% block title %}Labels Module - Quality App v2{% endblock %}
|
|
|
|
{% block content %}
|
|
<div class="container-fluid py-5">
|
|
<div class="row mb-4">
|
|
<div class="col-12">
|
|
<h1 class="mb-2">
|
|
<i class="fas fa-print"></i> Labels Module
|
|
</h1>
|
|
<p class="text-muted">Manage and print labels for thermal printers</p>
|
|
</div>
|
|
</div>
|
|
|
|
<div class="row">
|
|
<!-- Print Module Card -->
|
|
<div class="col-md-6 col-lg-4 mb-4">
|
|
<div class="card shadow-sm h-100 module-launcher">
|
|
<div class="card-body text-center">
|
|
<div class="launcher-icon mb-3">
|
|
<i class="fas fa-print text-primary"></i>
|
|
</div>
|
|
<h5 class="card-title">Print Labels</h5>
|
|
<p class="card-text text-muted">Print labels directly to thermal printers with live preview.</p>
|
|
<a href="{{ url_for('labels.print_module') }}" class="btn btn-primary btn-sm">
|
|
<i class="fas fa-arrow-right"></i> Open Printing
|
|
</a>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<!-- Import Labels Card -->
|
|
<div class="col-md-6 col-lg-4 mb-4">
|
|
<div class="card shadow-sm h-100 module-launcher">
|
|
<div class="card-body text-center">
|
|
<div class="launcher-icon mb-3">
|
|
<i class="fas fa-file-import text-info"></i>
|
|
</div>
|
|
<h5 class="card-title">Import Labels Data</h5>
|
|
<p class="card-text text-muted">Upload CSV or Excel files with order data for label printing.</p>
|
|
<a href="{{ url_for('labels.import_labels') }}" class="btn btn-info btn-sm">
|
|
<i class="fas fa-arrow-right"></i> Import Data
|
|
</a>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<!-- Print Lost Labels Card -->
|
|
<div class="col-md-6 col-lg-4 mb-4">
|
|
<div class="card shadow-sm h-100 module-launcher">
|
|
<div class="card-body text-center">
|
|
<div class="launcher-icon mb-3">
|
|
<i class="fas fa-file-pdf text-danger"></i>
|
|
</div>
|
|
<h5 class="card-title">Print Lost Labels</h5>
|
|
<p class="card-text text-muted">Search and reprint labels for orders that need reprinting.</p>
|
|
<a href="{{ url_for('labels.print_lost_labels') }}" class="btn btn-danger btn-sm">
|
|
<i class="fas fa-arrow-right"></i> Reprint Labels
|
|
</a>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<!-- Module Overview Section -->
|
|
<div class="row mt-5">
|
|
<div class="col-12">
|
|
<div class="card shadow-sm">
|
|
<div class="card-header bg-light">
|
|
<h5 class="mb-0"><i class="fas fa-info-circle"></i> Module Overview</h5>
|
|
</div>
|
|
<div class="card-body">
|
|
<div class="row">
|
|
<div class="col-md-6">
|
|
<h6><i class="fas fa-check-circle text-success"></i> Key Features:</h6>
|
|
<ul class="text-muted">
|
|
<li>Real-time label preview</li>
|
|
<li>Direct thermal printer integration</li>
|
|
<li>PDF export fallback</li>
|
|
<li>Batch label printing</li>
|
|
<li>QZ Tray support for Windows/Mac/Linux</li>
|
|
</ul>
|
|
</div>
|
|
<div class="col-md-6">
|
|
<h6><i class="fas fa-chart-pie text-primary"></i> Supported Printers:</h6>
|
|
<ul class="text-muted">
|
|
<li>Zebra thermal printers</li>
|
|
<li>Epson TM series</li>
|
|
<li>Brother thermal printers</li>
|
|
<li>Generic thermal printers via QZ Tray</li>
|
|
<li>PDF export for any printer</li>
|
|
</ul>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<style>
|
|
.module-launcher {
|
|
transition: transform 0.2s, box-shadow 0.2s;
|
|
}
|
|
|
|
.module-launcher:hover {
|
|
transform: translateY(-5px);
|
|
box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15) !important;
|
|
}
|
|
|
|
.launcher-icon {
|
|
font-size: 48px;
|
|
line-height: 1;
|
|
}
|
|
|
|
.launcher-icon i {
|
|
display: inline-block;
|
|
}
|
|
</style>
|
|
{% endblock %}
|