feat: add new invoice template with structured layout and styling
This commit is contained in:
parent
748bfe9490
commit
03aa28eaf8
287
templates/invoice/invoiceTemplate.html
Normal file
287
templates/invoice/invoiceTemplate.html
Normal file
@ -0,0 +1,287 @@
|
||||
<!doctype html>
|
||||
<html lang="{{lang}}">
|
||||
<head>
|
||||
<meta charset="utf-8">
|
||||
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
||||
<title>{{documentTitle}} {{invoiceNumber}}</title>
|
||||
<style>
|
||||
* { margin: 0; padding: 0; box-sizing: border-box; }
|
||||
body {
|
||||
font-family: 'Segoe UI', Arial, Helvetica, sans-serif;
|
||||
color: #1f2937;
|
||||
background: #ffffff;
|
||||
font-size: 13px;
|
||||
line-height: 1.5;
|
||||
}
|
||||
|
||||
.page {
|
||||
max-width: 800px;
|
||||
margin: 0 auto;
|
||||
padding: 40px 48px;
|
||||
}
|
||||
|
||||
/* ── Header ────────────────────────────────── */
|
||||
.header {
|
||||
display: flex;
|
||||
justify-content: space-between;
|
||||
align-items: flex-start;
|
||||
margin-bottom: 40px;
|
||||
padding-bottom: 20px;
|
||||
border-bottom: 3px solid #1C2B4A;
|
||||
}
|
||||
.header-left { flex: 1; }
|
||||
.company-name {
|
||||
font-size: 26px;
|
||||
font-weight: 800;
|
||||
color: #1C2B4A;
|
||||
letter-spacing: -0.5px;
|
||||
}
|
||||
.company-sub {
|
||||
font-size: 11px;
|
||||
color: #6b7280;
|
||||
margin-top: 2px;
|
||||
}
|
||||
.header-right {
|
||||
text-align: right;
|
||||
}
|
||||
.invoice-badge {
|
||||
display: inline-block;
|
||||
background: #1C2B4A;
|
||||
color: #ffffff;
|
||||
font-size: 18px;
|
||||
font-weight: 700;
|
||||
padding: 8px 20px;
|
||||
border-radius: 6px;
|
||||
letter-spacing: 0.5px;
|
||||
}
|
||||
.invoice-number-label {
|
||||
margin-top: 8px;
|
||||
font-size: 12px;
|
||||
color: #6b7280;
|
||||
}
|
||||
.invoice-number-value {
|
||||
font-size: 15px;
|
||||
font-weight: 700;
|
||||
color: #1C2B4A;
|
||||
}
|
||||
|
||||
/* ── Meta Grid ─────────────────────────────── */
|
||||
.meta-grid {
|
||||
display: flex;
|
||||
justify-content: space-between;
|
||||
margin-bottom: 36px;
|
||||
gap: 24px;
|
||||
}
|
||||
.meta-block {
|
||||
flex: 1;
|
||||
}
|
||||
.meta-block h3 {
|
||||
font-size: 10px;
|
||||
font-weight: 700;
|
||||
text-transform: uppercase;
|
||||
letter-spacing: 1px;
|
||||
color: #9ca3af;
|
||||
margin-bottom: 6px;
|
||||
}
|
||||
.meta-block p {
|
||||
font-size: 13px;
|
||||
color: #1f2937;
|
||||
line-height: 1.6;
|
||||
}
|
||||
.meta-block .highlight {
|
||||
font-weight: 700;
|
||||
color: #1C2B4A;
|
||||
}
|
||||
|
||||
/* ── Items Table ───────────────────────────── */
|
||||
.items-table {
|
||||
width: 100%;
|
||||
border-collapse: collapse;
|
||||
margin-bottom: 24px;
|
||||
}
|
||||
.items-table thead th {
|
||||
background: #1C2B4A;
|
||||
color: #ffffff;
|
||||
font-size: 11px;
|
||||
font-weight: 600;
|
||||
text-transform: uppercase;
|
||||
letter-spacing: 0.8px;
|
||||
padding: 10px 14px;
|
||||
text-align: left;
|
||||
}
|
||||
.items-table thead th:last-child,
|
||||
.items-table thead th:nth-child(3),
|
||||
.items-table thead th:nth-child(4),
|
||||
.items-table thead th:nth-child(5) {
|
||||
text-align: right;
|
||||
}
|
||||
.items-table tbody td {
|
||||
padding: 10px 14px;
|
||||
border-bottom: 1px solid #e5e7eb;
|
||||
font-size: 13px;
|
||||
}
|
||||
.items-table tbody td:last-child,
|
||||
.items-table tbody td:nth-child(3),
|
||||
.items-table tbody td:nth-child(4),
|
||||
.items-table tbody td:nth-child(5) {
|
||||
text-align: right;
|
||||
}
|
||||
.items-table tbody tr:nth-child(even) {
|
||||
background: #f9fafb;
|
||||
}
|
||||
.items-table tbody tr:last-child td {
|
||||
border-bottom: 2px solid #1C2B4A;
|
||||
}
|
||||
|
||||
/* ── Totals ────────────────────────────────── */
|
||||
.totals {
|
||||
display: flex;
|
||||
justify-content: flex-end;
|
||||
margin-bottom: 36px;
|
||||
}
|
||||
.totals-box {
|
||||
width: 280px;
|
||||
}
|
||||
.totals-row {
|
||||
display: flex;
|
||||
justify-content: space-between;
|
||||
padding: 6px 0;
|
||||
font-size: 13px;
|
||||
color: #4b5563;
|
||||
}
|
||||
.totals-row.total-gross {
|
||||
border-top: 2px solid #1C2B4A;
|
||||
margin-top: 6px;
|
||||
padding-top: 10px;
|
||||
font-size: 16px;
|
||||
font-weight: 800;
|
||||
color: #1C2B4A;
|
||||
}
|
||||
|
||||
/* ── Payment Info ──────────────────────────── */
|
||||
.payment-info {
|
||||
background: #f0f4fa;
|
||||
border-radius: 8px;
|
||||
padding: 18px 20px;
|
||||
margin-bottom: 36px;
|
||||
}
|
||||
.payment-info h3 {
|
||||
font-size: 11px;
|
||||
font-weight: 700;
|
||||
text-transform: uppercase;
|
||||
letter-spacing: 1px;
|
||||
color: #1C2B4A;
|
||||
margin-bottom: 8px;
|
||||
}
|
||||
.payment-info p {
|
||||
font-size: 12px;
|
||||
color: #374151;
|
||||
line-height: 1.6;
|
||||
}
|
||||
|
||||
/* ── Footer ────────────────────────────────── */
|
||||
.footer {
|
||||
border-top: 1px solid #e5e7eb;
|
||||
padding-top: 16px;
|
||||
text-align: center;
|
||||
font-size: 11px;
|
||||
color: #9ca3af;
|
||||
line-height: 1.6;
|
||||
}
|
||||
</style>
|
||||
</head>
|
||||
<body>
|
||||
<div class="page">
|
||||
<!-- Header -->
|
||||
<div class="header">
|
||||
<div class="header-left">
|
||||
<div class="company-name">{{companyName}}</div>
|
||||
<div class="company-sub">Coffee Subscription Service</div>
|
||||
</div>
|
||||
<div class="header-right">
|
||||
<div class="invoice-badge">{{documentTitle}}</div>
|
||||
<div class="invoice-number-label">{{invoiceNumberLabel}}</div>
|
||||
<div class="invoice-number-value">{{invoiceNumber}}</div>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<!-- Meta Grid: From / To / Details -->
|
||||
<div class="meta-grid">
|
||||
<div class="meta-block">
|
||||
<h3>{{fromLabel}}</h3>
|
||||
<p>
|
||||
<span class="highlight">{{companyName}}</span><br>
|
||||
{{companyStreet}}<br>
|
||||
{{companyPostalCity}}<br>
|
||||
{{companyCountry}}
|
||||
</p>
|
||||
</div>
|
||||
<div class="meta-block">
|
||||
<h3>{{toLabel}}</h3>
|
||||
<p>
|
||||
<span class="highlight">{{customerName}}</span><br>
|
||||
{{customerEmail}}<br>
|
||||
{{customerStreet}}<br>
|
||||
{{customerPostalCity}}<br>
|
||||
{{customerCountry}}
|
||||
</p>
|
||||
</div>
|
||||
{{orderedByBlock}}
|
||||
<div class="meta-block">
|
||||
<h3>{{detailsLabel}}</h3>
|
||||
<p>
|
||||
{{dateLabel}}: <span class="highlight">{{issuedAt}}</span><br>
|
||||
{{dueDateLabel}}: <span class="highlight">{{dueAt}}</span><br>
|
||||
{{statusLabel}}: <span class="highlight">{{invoiceStatus}}</span>
|
||||
</p>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<!-- Items Table -->
|
||||
<table class="items-table">
|
||||
<thead>
|
||||
<tr>
|
||||
<th>#</th>
|
||||
<th>{{descriptionHeader}}</th>
|
||||
<th>{{qtyHeader}}</th>
|
||||
<th>{{unitPriceHeader}}</th>
|
||||
<th>{{totalHeader}}</th>
|
||||
</tr>
|
||||
</thead>
|
||||
<tbody>
|
||||
{{itemsRows}}
|
||||
</tbody>
|
||||
</table>
|
||||
|
||||
<!-- Totals -->
|
||||
<div class="totals">
|
||||
<div class="totals-box">
|
||||
<div class="totals-row">
|
||||
<span>{{subtotalLabel}}</span>
|
||||
<span>{{totalNet}}</span>
|
||||
</div>
|
||||
<div class="totals-row">
|
||||
<span>{{taxLabel}} ({{vatRateDisplay}})</span>
|
||||
<span>{{totalTax}}</span>
|
||||
</div>
|
||||
<div class="totals-row total-gross">
|
||||
<span>{{totalLabel}}</span>
|
||||
<span>{{totalGross}}</span>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<!-- Payment Info -->
|
||||
<div class="payment-info">
|
||||
<h3>{{paymentInfoTitle}}</h3>
|
||||
<p>{{paymentInfoText}}</p>
|
||||
</div>
|
||||
|
||||
<!-- Footer -->
|
||||
<div class="footer">
|
||||
{{companyName}} · {{companyStreet}} · {{companyPostalCity}} · {{companyCountry}}<br>
|
||||
{{footerText}}
|
||||
</div>
|
||||
</div>
|
||||
</body>
|
||||
</html>
|
||||
Loading…
Reference in New Issue
Block a user