228 lines
8.9 KiB
PHP
228 lines
8.9 KiB
PHP
<?php
|
|
/**
|
|
* @var string $ressourcePathPrefix
|
|
* @var Invoice $invoice
|
|
* @var array $vat
|
|
*/
|
|
$net_total = $invoice->total + $invoice->total_setup;
|
|
$gross_total = $invoice->total_gross + $invoice->total_setup_gross;
|
|
$is_credit = $net_total < 0;
|
|
|
|
$this->setReturnValue(['filename' => $invoice->invoice_number . ".pdf"]);
|
|
|
|
//die(json_encode($invoice->positions));
|
|
|
|
?>
|
|
|
|
<!DOCTYPE html>
|
|
<html>
|
|
<head>
|
|
<title>Rechnung</title>
|
|
<meta charset="utf-8" />
|
|
<!-- <link href="-->
|
|
<?php //= self::getResourcePath() ?><!--assets/css/bootstrap.min.css" rel="stylesheet" type="text/css" />-->
|
|
|
|
<style>
|
|
body {
|
|
margin-top: 0;
|
|
/*padding-top: 20pt;*/
|
|
font-family: "Open Sans", sans-serif, Verdana;
|
|
font-size: 12px;
|
|
}
|
|
|
|
tr {
|
|
page-break-inside: avoid;
|
|
}
|
|
|
|
.uneven {
|
|
background-color: #ebebeb;
|
|
}
|
|
|
|
|
|
table tr td:last-child {
|
|
text-align: right;
|
|
}
|
|
|
|
.additionalRow td:first-child {
|
|
text-align: left;
|
|
padding-left: 20pt;
|
|
}
|
|
|
|
th {
|
|
height: 28px;
|
|
}
|
|
|
|
#invoiceTable tr *:nth-child(5),
|
|
#invoiceTable tr *:nth-child(4),
|
|
#invoiceTable tr *:nth-child(3) {
|
|
text-align: right;
|
|
}
|
|
|
|
#invoiceTable tr *:not(:first-child) {
|
|
padding: 4px 0;
|
|
}
|
|
|
|
#invoiceTable tr td {
|
|
font-size: 11px;
|
|
}
|
|
|
|
tr.position td {
|
|
vertical-align: top;
|
|
}
|
|
|
|
tr.position td:first-child {
|
|
vertical-align: middle !important;
|
|
padding-left: 4pt;
|
|
}
|
|
|
|
#invoiceTable tr td:first-child {
|
|
max-width: 200pt;
|
|
}
|
|
|
|
</style>
|
|
|
|
|
|
</head>
|
|
<body>
|
|
<div>
|
|
|
|
<h2 style="text-align: center;color: #005384">Ihre Xinon <?=($is_credit) ? "Gutschrift" : "Rechnung"?> vom <?=date("d.m.Y",$invoice->invoice_date)?></h2>
|
|
|
|
<table style="border-collapse: collapse; width: 100%;" id="invoiceTable">
|
|
<tr style="font-weight: bold; border-bottom: 1px solid black;" class="uneven">
|
|
<th style="text-align: center">Leistung / Produkt</th>
|
|
<th style="text-align: center">Zeitraum</th>
|
|
<th style="text-align: right">Preis</th>
|
|
<th style="text-align: center">Menge</th>
|
|
<th style="text-align: right">Netto €</th>
|
|
<th style="text-align: right">Ust. %</th>
|
|
<th style="text-align: right; padding-right: 4pt">Brutto €</th>
|
|
</tr>
|
|
<?php
|
|
$i = 0;
|
|
foreach($invoice->positions as $p):
|
|
$timerange_month_only = $p->getOption('timerange_month_only');
|
|
$start_date = new DateTime($p->start_date);
|
|
$end_date = new DateTime($p->end_date);
|
|
$amount = (float) number_format($p->amount, 3, ",", ".");
|
|
$price = number_format($p->price, 2, ",",".");
|
|
$price_total = number_format($p->price_total, 2, ",",".");
|
|
$price_gross = number_format($p->price_gross, 2, ",",".");
|
|
$vatrate = number_format($p->vatrate, 0, ",",".");
|
|
|
|
?>
|
|
|
|
<tr class="position <?=($i%2 == 0) ? "even" : "uneven" ?>">
|
|
<td>
|
|
<?=$p->product_name?>
|
|
<?php if($p->matchcode): ?>
|
|
<div style="padding-left: 12pt"><?=$p->matchcode?></div>
|
|
<?php endif; ?>
|
|
</td>
|
|
<td style="text-align: center;">
|
|
<?php if($timerange_month_only): ?>
|
|
<?=$start_date->format("m.Y")?>
|
|
<?php elseif($p->billing_period > 1): ?>
|
|
<?=$start_date->format("m.Y")?> - <?=$end_date->format("m.Y") ?>
|
|
<?php else: ?>
|
|
<?php if($start_date->format("d.m.Y") == $end_date->format("d.m.Y")): ?>
|
|
<?=$start_date->format("d.m.Y")?>
|
|
<?php else: ?>
|
|
<?=$start_date->format("d.m.Y")?> - <?=$end_date->format("d.m.Y") ?>
|
|
<?php endif; ?>
|
|
<?php endif; ?>
|
|
|
|
</td>
|
|
<td><?=$price?> €</td>
|
|
<td style="text-align: center"><?=$amount?></td>
|
|
<td><?=$price_total?> €</td>
|
|
<td style="text-align: right;"><?=$vatrate?>%</td>
|
|
<td style="padding-right: 4pt;"><?=$price_gross?> €</td>
|
|
</tr>
|
|
<?php if($p->matchcode): ?>
|
|
<!--tr class="additionalRow <?=($i%2 == 0) ? "even" : "uneven" ?>">
|
|
<td colspan="7"><?=$p->matchcode?></td>
|
|
</tr-->
|
|
<?php endif;
|
|
$i++;
|
|
endforeach;
|
|
?>
|
|
<tr style="font-weight: bold; background-color: #ebebeb; border-bottom: 1px solid black;border-top: 1px solid black">
|
|
<td colspan="5">Gesamt Netto:</td>
|
|
<td colspan="2" style="text-align: right; padding-right: 4pt;"><?=number_format($net_total, 2, ",","."). " €"?></td>
|
|
</tr>
|
|
|
|
<?php foreach ($vat as $rate => $vat_total): ?>
|
|
|
|
<?php if($rate > 0): ?>
|
|
<tr style="font-size: 11px;border-bottom: 1px solid black;">
|
|
<td colspan="5">USt. <?=number_format($rate, 0, ",", ".")?>%:</td>
|
|
<td colspan="2" style="text-align: right; padding-right: 4pt;"><?=number_format($vat_total, 2, ",","."). " €"?></td>
|
|
</tr>
|
|
<?php endif; ?>
|
|
|
|
<?php endforeach; ?>
|
|
|
|
<!-- double underline border on bottom -->
|
|
<tr style="font-weight: bold; border-bottom: 3px double black; background-color: #ebebeb;">
|
|
<td colspan="5">Gesamt Brutto:</td>
|
|
<td colspan="2" style="text-align: right; padding-right: 4pt;"><?=number_format($gross_total, 2, ",","."). " €"?></td>
|
|
</tr>
|
|
</table>
|
|
|
|
|
|
<div style="margin-top: 20pt;">
|
|
<?php if($invoice->tax_text): ?>
|
|
<p style="font-weight: bold;"><?=$invoice->tax_text?></p>
|
|
<?php endif; ?>
|
|
<?php if($is_credit): ?>
|
|
<p style="color: #FF0000; font-weight: bold">Gutschrift! Bitte nicht überweisen.</p>
|
|
<?php elseif($invoice->billing_type == "sepa"): ?>
|
|
<p style="color: #FF0000; font-weight: bold">BITTE NICHT EINZAHLEN, DER BETRAG WIRD AUTOMATISCH VON IHREM KONTO ABGEBUCHT !</p>
|
|
<?php else: ?>
|
|
Bitte <b>überweisen</b> Sie den Rechnungsbetrag bis zum <b><?=(new DateTime("@".$invoice->invoice_date))->modify("+14 days")->format("d.m.Y")?></b> auf folgendes Konto:<br />
|
|
<b style="padding-left: 4pt;">IBAN: <?=$bank_iban?></b><br />
|
|
<b style="padding-left: 4pt;">BIC: <?=$bank_bic?></b><br /><br />
|
|
Bitte geben Sie als Verwendungszweck unbedingt die Rechnungsnummer an, nur so können wir Ihre Zahlung eindeutig zuordnen
|
|
<?php endif; ?>
|
|
</div>
|
|
|
|
|
|
<?php if(count($invoice->voicenumbers)): ?>
|
|
<?php foreach($invoice->voicenumbers as $voicenumber): ?>
|
|
<?php $start_date = new DateTime($voicenumber->start_date); ?>
|
|
<div style="margin-top: 20pt;">
|
|
<h3 style="color: #005384;margin-bottom: 0">Gesprächsgebühren für <?=preg_replace('/^43/','0', $voicenumber->voicenumber)?></h3>
|
|
<div style="margin-bottom: 16px">(<?=$start_date->format("m.Y")?>)</div>
|
|
|
|
<table style="border-collapse: collapse; width: 100%;">
|
|
<tr style="text-align: left;" class="uneven">
|
|
<th style="padding-left: 4px;">Ziel</th>
|
|
<th style="text-align: right">Preis pro Minute</th>
|
|
<th style="text-align: right; padding-right: 8pt;">Anzahl</th>
|
|
<th style="text-align: right;">Dauer</th>
|
|
<th style="text-align: right">Netto €</th>
|
|
<th style="text-align: right; padding-right: 4pt;">Brutto €</th>
|
|
</tr>
|
|
<?php $v = 0; ?>
|
|
<?php foreach($voicenumber->zones as $zone): ?>
|
|
<?php if($zone->price_total < 0.000000001) continue; ?>
|
|
<tr class="<?=($v%2 == 0) ? "even" : "uneven" ?>">
|
|
<td style="padding-left: 4px;"><?=$zone->zone?></td>
|
|
<td style="text-align: right"><?=number_format($zone->price * 60, 4, ",",".")?> €</td>
|
|
<td style="text-align: right; padding-right: 8pt;"><?=number_format($zone->call_count, 0, ",",".")?></td>
|
|
<td style="text-align: right"><?=self::getHumanReadableInterval($zone->duration)?></td>
|
|
<td style="text-align: right"><?=number_format($zone->price_total, 4, ",",".")?> €</td>
|
|
<td style="text-align: right; padding-right: 4pt;"><?=number_format($zone->price_total_gross, 4, ",",".")?> €</td>
|
|
</tr>
|
|
<?php $v++; ?>
|
|
<?php endforeach; ?>
|
|
</table>
|
|
</div>
|
|
<?php endforeach; ?>
|
|
<?php endif; ?>
|
|
|
|
|
|
|
|
</body>
|
|
</html>
|