nordabiz/templates/admin/membership_print.html
Maciej Pienczyn cb1409bf09
Some checks are pending
NordaBiz Tests / Unit & Integration Tests (push) Waiting to run
NordaBiz Tests / E2E Tests (Playwright) (push) Blocked by required conditions
NordaBiz Tests / Smoke Tests (Production) (push) Blocked by required conditions
NordaBiz Tests / Send Failure Notification (push) Blocked by required conditions
fix(membership): legal form from business_type_label + blue print button
2026-03-30 12:26:26 +02:00

362 lines
9.7 KiB
HTML

<!DOCTYPE html>
<html lang="pl">
<head>
<meta charset="utf-8">
<style>
@page {
size: A4;
margin: 18mm 15mm 15mm 15mm;
@top-center { content: ""; }
@bottom-center { content: ""; }
}
body {
font-family: -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
font-size: 9pt;
color: #1a1a1a;
line-height: 1.4;
margin: 0;
padding: 0;
}
/* Header */
.header {
text-align: center;
margin-bottom: 14pt;
padding-bottom: 10pt;
border-bottom: 2.5pt solid #2E4872;
}
.header h1 {
font-size: 16pt;
color: #2E4872;
margin: 0 0 4pt 0;
letter-spacing: 0.5pt;
}
.header .subtitle {
font-size: 11pt;
color: #333;
margin: 0 0 6pt 0;
font-weight: 500;
}
.header .meta {
font-size: 8.5pt;
color: #555;
margin: 0;
}
.header .company-name {
font-size: 12pt;
font-weight: 600;
color: #1a1a1a;
margin: 4pt 0;
}
/* Section */
.section {
margin: 14pt 0 10pt 0;
page-break-inside: avoid;
}
.section-title {
font-size: 11pt;
font-weight: 600;
color: #2E4872;
border-bottom: 1.5pt solid #d0d7e3;
padding-bottom: 3pt;
margin: 0 0 8pt 0;
}
/* Data grid — airy layout */
.grid {
display: grid;
grid-template-columns: 1fr 1fr;
gap: 8pt 24pt;
}
.grid-3 {
grid-template-columns: 1fr 1fr 1fr;
}
.field {
padding: 4pt 0;
border-bottom: 0.5pt solid #eee;
}
.field-label {
font-size: 7pt;
color: #999;
text-transform: uppercase;
letter-spacing: 0.4pt;
margin: 0 0 1pt 0;
}
.field-value {
font-size: 9.5pt;
font-weight: 500;
color: #1a1a1a;
margin: 0;
}
.field-value.large {
font-size: 11pt;
font-weight: 600;
}
/* Tags */
.tag {
display: inline-block;
background: #e8f0fe;
color: #1a56db;
padding: 2pt 10pt;
border-radius: 4pt;
font-size: 8.5pt;
margin: 2pt 3pt;
}
/* Description */
.description {
font-size: 8.5pt;
line-height: 1.6;
color: #333;
text-align: justify;
max-height: 140pt;
overflow: hidden;
}
/* Consent */
.consent-grid {
display: grid;
grid-template-columns: 1fr 1fr;
gap: 4pt 20pt;
}
.consent-item {
display: flex;
align-items: center;
gap: 6pt;
font-size: 9pt;
padding: 3pt 0;
}
.check-icon {
width: 14pt;
height: 14pt;
border-radius: 3pt;
display: flex;
align-items: center;
justify-content: center;
font-size: 9pt;
font-weight: bold;
}
.check-yes { background: #dcfce7; color: #16a34a; }
.check-no { background: #fee2e2; color: #dc2626; }
/* Declaration box */
.declaration-box {
border: 1pt solid #2E4872;
border-radius: 4pt;
padding: 8pt 12pt;
margin-top: 8pt;
background: #f0f4fa;
font-size: 9pt;
display: flex;
justify-content: space-between;
}
.declaration-box .label { font-weight: 600; color: #2E4872; }
.declaration-box .date { color: #555; }
/* Workflow history */
.workflow-item {
display: flex;
align-items: center;
gap: 8pt;
padding: 3pt 0;
font-size: 8.5pt;
border-bottom: 0.5pt solid #eee;
}
.workflow-date {
color: #888;
min-width: 80pt;
font-size: 7.5pt;
}
.workflow-action {
font-weight: 500;
color: #2E4872;
}
/* Signature */
.signature-area {
margin-top: 36pt;
display: grid;
grid-template-columns: 1fr 1fr;
gap: 60pt;
}
.signature-block { text-align: center; }
.signature-line {
border-top: 0.5pt solid #666;
padding-top: 4pt;
font-size: 7.5pt;
color: #666;
}
.signature-dots {
height: 30pt;
}
/* Footer */
.footer {
margin-top: 16pt;
padding-top: 6pt;
border-top: 0.5pt solid #ddd;
font-size: 7pt;
color: #aaa;
text-align: center;
}
</style>
</head>
<body>
<div class="header">
<h1>Izba Gospodarcza Norda Biznes</h1>
<p class="subtitle">Deklaracja Przystąpienia do Izby nr {{ app.id }}</p>
<p class="company-name">{{ app.company_name }}</p>
<p class="meta">
Data złożenia: {{ app.submitted_at.strftime('%d.%m.%Y, godz. %H:%M') if app.submitted_at else 'brak' }}
&nbsp;&bull;&nbsp; Status: {{ app.status_label }}
</p>
</div>
<!-- Dane firmy -->
<div class="section">
<h2 class="section-title">Dane firmy</h2>
<div class="grid">
<div class="field">
<p class="field-label">NIP</p>
<p class="field-value large">{{ app.nip or '---' }}</p>
</div>
<div class="field">
<p class="field-label">KRS</p>
<p class="field-value">{{ app.krs_number or '---' }}</p>
</div>
<div class="field">
<p class="field-label">REGON</p>
<p class="field-value">{{ app.regon or '---' }}</p>
</div>
<div class="field">
<p class="field-label">Forma prawna</p>
<p class="field-value">{{ app.business_type_label or '---' }}</p>
</div>
</div>
</div>
<!-- Adres + Kontakt w jednej sekcji -->
<div class="section">
<h2 class="section-title">Adres i dane kontaktowe</h2>
<div class="grid">
<div class="field">
<p class="field-label">Adres siedziby</p>
<p class="field-value">{{ (app.address_street or '') }}{% if app.address_number %} {{ app.address_number }}{% endif %}, {{ app.address_postal_code or '' }} {{ app.address_city or '' }}</p>
</div>
<div class="field">
<p class="field-label">Telefon</p>
<p class="field-value">{{ app.phone or '---' }}</p>
</div>
<div class="field">
<p class="field-label">Email</p>
<p class="field-value">{{ app.email or '---' }}</p>
</div>
<div class="field">
<p class="field-label">Strona WWW</p>
<p class="field-value">{{ app.website or '---' }}</p>
</div>
</div>
</div>
<!-- Delegaci -->
<div class="section">
<h2 class="section-title">Delegaci do Walnego Zgromadzenia</h2>
<div class="grid grid-3">
<div class="field">
<p class="field-label">Delegat 1 (główny)</p>
<p class="field-value">{{ app.delegate_1 or '---' }}</p>
</div>
<div class="field">
<p class="field-label">Delegat 2</p>
<p class="field-value">{{ app.delegate_2 or '---' }}</p>
</div>
<div class="field">
<p class="field-label">Delegat 3</p>
<p class="field-value">{{ app.delegate_3 or '---' }}</p>
</div>
</div>
</div>
<!-- Sekcje tematyczne -->
{% if app.sections_labels %}
<div class="section">
<h2 class="section-title">Sekcje tematyczne</h2>
{% for label in app.sections_labels %}
<span class="tag">{{ label }}</span>
{% endfor %}
</div>
{% endif %}
<!-- Opis działalności -->
{% if app.description %}
<div class="section">
<h2 class="section-title">Opis działalności</h2>
<p class="description">{{ app.description[:800] }}{% if app.description|length > 800 %}...{% endif %}</p>
</div>
{% endif %}
<!-- Zgody i oświadczenia -->
<div class="section">
<h2 class="section-title">Zgody i oświadczenia</h2>
<div class="consent-grid">
<div class="consent-item">
<span class="check-icon {{ 'check-yes' if app.consent_email else 'check-no' }}">{{ '✓' if app.consent_email else '✗' }}</span>
Zgoda na komunikację e-mail
</div>
<div class="consent-item">
<span class="check-icon {{ 'check-yes' if app.consent_sms else 'check-no' }}">{{ '✓' if app.consent_sms else '✗' }}</span>
Zgoda na komunikację SMS
</div>
</div>
{% if app.declaration_accepted %}
<div class="declaration-box">
<div>
<span class="label">Deklaracja przystąpienia:</span> Zaakceptowana
</div>
<div class="date">
{% if app.declaration_accepted_at %}
{{ app.declaration_accepted_at.strftime('%d.%m.%Y, %H:%M') }}
{% endif %}
</div>
</div>
{% endif %}
</div>
<!-- Historia workflow -->
{% if app.workflow_history %}
<div class="section">
<h2 class="section-title">Historia rozpatrywania</h2>
{% for event in app.workflow_history %}
<div class="workflow-item">
<span class="workflow-date">{{ event.timestamp if event.timestamp is string else event.get('timestamp', '') }}</span>
<span class="workflow-action">{{ event.get('action_label', event.get('action', '')) }}</span>
{% if event.get('comment') %}<span style="color: #666;"> — {{ event.get('comment') }}</span>{% endif %}
</div>
{% endfor %}
</div>
{% endif %}
<!-- Podpisy -->
<div class="signature-area">
<div class="signature-block">
<div class="signature-dots"></div>
<div class="signature-line">Podpis wnioskodawcy</div>
</div>
<div class="signature-block">
<div class="signature-dots"></div>
<div class="signature-line">Podpis osoby przyjmującej</div>
</div>
</div>
<div class="footer">
Wygenerowano z portalu nordabiznes.pl &bull; Izba Gospodarcza Norda Biznes, Wejherowo
</div>
</body>
</html>