2019-09-02 07:08:26 +02:00
|
|
|
<?php
|
|
|
|
/**
|
|
|
|
* Invoice Ninja (https://invoiceninja.com)
|
|
|
|
*
|
|
|
|
* @link https://github.com/invoiceninja/invoiceninja source repository
|
|
|
|
*
|
|
|
|
* @copyright Copyright (c) 2019. Invoice Ninja LLC (https://invoiceninja.com)
|
|
|
|
*
|
|
|
|
* @license https://opensource.org/licenses/AAL
|
|
|
|
*/
|
|
|
|
|
|
|
|
namespace App\Utils\Traits;
|
|
|
|
|
2019-12-16 12:34:38 +01:00
|
|
|
use App\Models\Country;
|
2019-09-02 07:08:26 +02:00
|
|
|
use App\Utils\Number;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Class MakesInvoiceValues
|
|
|
|
* @package App\Utils\Traits
|
|
|
|
*/
|
|
|
|
trait MakesInvoiceValues
|
|
|
|
{
|
2019-12-30 22:59:12 +01:00
|
|
|
/**
|
|
|
|
* Master list of columns used
|
|
|
|
* for invoice tables
|
|
|
|
* @var array
|
|
|
|
*/
|
2019-09-04 01:16:23 +02:00
|
|
|
private static $master_columns = [
|
|
|
|
'date',
|
|
|
|
'discount',
|
|
|
|
'product_key',
|
|
|
|
'notes',
|
|
|
|
'cost',
|
|
|
|
'quantity',
|
|
|
|
'tax_name1',
|
|
|
|
'tax_name2',
|
2019-10-05 04:28:23 +02:00
|
|
|
'tax_name3',
|
2019-09-04 01:16:23 +02:00
|
|
|
'line_total',
|
|
|
|
'custom_label1',
|
|
|
|
'custom_label2',
|
|
|
|
'custom_label3',
|
|
|
|
'custom_label4',
|
|
|
|
];
|
|
|
|
|
2019-09-04 23:50:16 +02:00
|
|
|
/**
|
|
|
|
* Master list of invoice labels
|
|
|
|
* @var array
|
|
|
|
*/
|
2019-12-30 22:59:12 +01:00
|
|
|
private static $labels = [
|
2019-11-27 11:27:24 +01:00
|
|
|
'date',
|
2019-09-04 03:45:53 +02:00
|
|
|
'due_date',
|
2019-12-18 11:49:28 +01:00
|
|
|
'invoice_number',
|
2019-09-04 03:45:53 +02:00
|
|
|
'po_number',
|
|
|
|
'discount',
|
|
|
|
'taxes',
|
|
|
|
'tax',
|
|
|
|
'item',
|
|
|
|
'description',
|
|
|
|
'unit_cost',
|
|
|
|
'quantity',
|
|
|
|
'line_total',
|
|
|
|
'subtotal',
|
|
|
|
'paid_to_date',
|
|
|
|
'balance_due',
|
|
|
|
'partial_due',
|
|
|
|
'terms',
|
|
|
|
'your_invoice',
|
|
|
|
'quote',
|
|
|
|
'your_quote',
|
|
|
|
'quote_date',
|
|
|
|
'quote_number',
|
|
|
|
'total',
|
|
|
|
'invoice_issued_to',
|
|
|
|
'quote_issued_to',
|
|
|
|
'rate',
|
|
|
|
'hours',
|
|
|
|
'balance',
|
|
|
|
'from',
|
|
|
|
'to',
|
|
|
|
'invoice_to',
|
|
|
|
'quote_to',
|
|
|
|
'details',
|
|
|
|
'invoice_no',
|
|
|
|
'quote_no',
|
|
|
|
'valid_until',
|
|
|
|
'client_name',
|
|
|
|
'address1',
|
|
|
|
'address2',
|
|
|
|
'id_number',
|
|
|
|
'vat_number',
|
|
|
|
'city_state_postal',
|
|
|
|
'postal_city_state',
|
|
|
|
'country',
|
|
|
|
'email',
|
|
|
|
'contact_name',
|
|
|
|
'company_name',
|
|
|
|
'website',
|
|
|
|
'phone',
|
|
|
|
'blank',
|
|
|
|
'surcharge',
|
|
|
|
'tax_invoice',
|
|
|
|
'tax_quote',
|
|
|
|
'statement',
|
|
|
|
'statement_date',
|
|
|
|
'your_statement',
|
|
|
|
'statement_issued_to',
|
|
|
|
'statement_to',
|
|
|
|
'credit_note',
|
|
|
|
'credit_date',
|
|
|
|
'credit_number',
|
|
|
|
'credit_issued_to',
|
|
|
|
'credit_to',
|
|
|
|
'your_credit',
|
2019-10-04 13:01:52 +02:00
|
|
|
'phone',
|
2019-09-04 03:45:53 +02:00
|
|
|
'invoice_total',
|
|
|
|
'outstanding',
|
|
|
|
'invoice_due_date',
|
|
|
|
'quote_due_date',
|
|
|
|
'service',
|
|
|
|
'product_key',
|
|
|
|
'unit_cost',
|
|
|
|
'custom_value1',
|
|
|
|
'custom_value2',
|
|
|
|
'delivery_note',
|
|
|
|
'date',
|
|
|
|
'method',
|
|
|
|
'payment_date',
|
|
|
|
'reference',
|
|
|
|
'amount',
|
|
|
|
'amount_paid',
|
|
|
|
];
|
|
|
|
|
2019-12-30 22:59:12 +01:00
|
|
|
/**
|
2019-09-03 01:00:52 +02:00
|
|
|
* Iterates and translates all labels
|
|
|
|
*
|
2019-12-30 22:59:12 +01:00
|
|
|
* @return array returns an array of
|
2019-09-04 23:50:16 +02:00
|
|
|
* keyed labels (appended with _label)
|
2019-09-03 01:00:52 +02:00
|
|
|
*/
|
|
|
|
public function makeLabels() :array
|
|
|
|
{
|
2019-12-18 11:49:28 +01:00
|
|
|
//todo we might want to translate like this
|
|
|
|
//trans('texts.labe', [], null, $this->client->locale());
|
2019-12-30 22:59:12 +01:00
|
|
|
$data = [];
|
2019-09-03 01:00:52 +02:00
|
|
|
|
2019-12-30 22:59:12 +01:00
|
|
|
foreach (self::$labels as $label) {
|
|
|
|
$data['$'.$label . '_label'] = ctrans('texts.'.$label);
|
|
|
|
}
|
2019-09-03 01:00:52 +02:00
|
|
|
|
2019-12-30 22:59:12 +01:00
|
|
|
return $data;
|
|
|
|
}
|
2019-09-03 01:00:52 +02:00
|
|
|
|
2019-12-30 22:59:12 +01:00
|
|
|
/**
|
|
|
|
* Transforms all placeholders
|
2019-09-04 23:50:16 +02:00
|
|
|
* to invoice values
|
2019-12-30 22:59:12 +01:00
|
|
|
*
|
|
|
|
* @return array returns an array
|
2019-09-04 23:50:16 +02:00
|
|
|
* of keyed labels (appended with _label)
|
2019-09-03 01:00:52 +02:00
|
|
|
*/
|
2019-12-24 22:55:29 +01:00
|
|
|
public function makeValues($contact = null) :array
|
2019-09-02 07:08:26 +02:00
|
|
|
{
|
2019-12-30 22:59:12 +01:00
|
|
|
if (!$this->client->currency() || !$this->client) {
|
2019-10-07 11:39:22 +02:00
|
|
|
throw new Exception(debug_backtrace()[1]['function'], 1);
|
|
|
|
exit;
|
|
|
|
}
|
2019-12-16 12:34:38 +01:00
|
|
|
|
|
|
|
$settings = $this->client->getMergedSettings();
|
|
|
|
|
2019-09-02 07:08:26 +02:00
|
|
|
$data = [];
|
|
|
|
|
2019-12-30 22:59:12 +01:00
|
|
|
$data['$date'] = $this->date;
|
|
|
|
$data['$invoice.date'] = &$data['$date'];
|
|
|
|
$data['$due_date'] = $this->due_date;
|
|
|
|
$data['$invoice.due_date'] = &$data['$due_date'];
|
|
|
|
$data['$number'] = $this->number;
|
|
|
|
$data['$invoice.number'] = &$data['$number'];
|
|
|
|
$data['$po_number'] = $this->po_number;
|
|
|
|
$data['$invoice.po_number'] = &$data['$po_number'];
|
|
|
|
$data['$line_taxes'] = $this->makeLineTaxes();
|
|
|
|
$data['$invoice.line_taxes'] = &$data['$line_taxes'];
|
|
|
|
$data['$total_taxes'] = $this->makeTotalTaxes();
|
|
|
|
$data['$invoice.total_taxes'] = &$data['$total_taxes'];
|
|
|
|
// $data['$tax'] = ;
|
|
|
|
// $data['$item'] = ;
|
|
|
|
// $data['$description'] = ;
|
|
|
|
// $data['$unit_cost'] = ;
|
|
|
|
// $data['$quantity'] = ;
|
|
|
|
// $data['$line_total'] = ;
|
|
|
|
// $data['$paid_to_date'] = ;
|
|
|
|
$data['$discount'] = Number::formatMoney($this->calc()->getTotalDiscount(), $this->client);
|
|
|
|
$data['$invoice.discount'] = &$data['$discount'];
|
|
|
|
$data['$subtotal'] = Number::formatMoney($this->calc()->getSubTotal(), $this->client);
|
|
|
|
$data['$invoice.subtotal'] = &$data['$subtotal'];
|
|
|
|
$data['$balance_due'] = Number::formatMoney($this->balance, $this->client);
|
|
|
|
$data['$invoice.balance_due'] = &$data['$balance_due'];
|
|
|
|
$data['$partial_due'] = Number::formatMoney($this->partial, $this->client);
|
|
|
|
$data['$invoice.partial_due'] = &$data['$partial_due'];
|
|
|
|
$data['$total'] = Number::formatMoney($this->calc()->getTotal(), $this->client);
|
|
|
|
$data['$invoice.total'] = &$data['$total'];
|
|
|
|
$data['$amount'] = &$data['$total'];
|
|
|
|
$data['$invoice.amount'] = &$data['$total'];
|
|
|
|
|
|
|
|
$data['$balance'] = Number::formatMoney($this->calc()->getBalance(), $this->client);
|
|
|
|
$data['$invoice.balance'] = &$data['$balance'];
|
|
|
|
$data['$taxes'] = Number::formatMoney($this->calc()->getItemTotalTaxes(), $this->client);
|
|
|
|
$data['$invoice.taxes'] = &$data['$taxes'];
|
|
|
|
$data['$terms'] = $this->terms;
|
|
|
|
$data['$invoice.terms'] = &$data['$terms'];
|
|
|
|
// $data['$your_invoice'] = ;
|
|
|
|
// $data['$quote'] = ;
|
|
|
|
// $data['$your_quote'] = ;
|
|
|
|
// $data['$quote_date'] = ;
|
|
|
|
// $data['$quote_number'] = ;
|
|
|
|
// $data['$invoice_issued_to'] = ;
|
|
|
|
// $data['$quote_issued_to'] = ;
|
|
|
|
// $data['$rate'] = ;
|
|
|
|
// $data['$hours'] = ;
|
|
|
|
// $data['$from'] = ;
|
|
|
|
// $data['$to'] = ;
|
|
|
|
// $data['$invoice_to'] = ;
|
|
|
|
// $data['$quote_to'] = ;
|
|
|
|
// $data['$details'] = ;
|
|
|
|
$data['$invoice_no'] = $this->number;
|
|
|
|
$data['$invoice.invoice_no'] = &$data['$invoice_no'];
|
|
|
|
// $data['$quote_no'] = ;
|
|
|
|
// $data['$valid_until'] = ;
|
|
|
|
$data['$client_name'] = $this->present()->clientName();
|
|
|
|
$data['$client.name'] = &$data['$client_name'];
|
|
|
|
$data['$client_address'] = $this->present()->address();
|
|
|
|
$data['$client.address'] = &$data['$client_address'];
|
|
|
|
$data['$address1'] = $this->client->address1;
|
|
|
|
$data['$client.address1'] = &$data['$address1'];
|
|
|
|
$data['$address2'] = $this->client->address2;
|
|
|
|
$data['$client.address2'] = &$data['$address2'];
|
|
|
|
$data['$id_number'] = $this->client->id_number;
|
|
|
|
$data['$client.id_number'] = &$data['$id_number'];
|
|
|
|
$data['$vat_number'] = $this->client->vat_number;
|
|
|
|
$data['$client.vat_number'] = &$data['$vat_number'];
|
|
|
|
$data['$website'] = $this->client->present()->website();
|
|
|
|
$data['$client.website'] = &$data['$website'];
|
|
|
|
$data['$phone'] = $this->client->present()->phone();
|
|
|
|
$data['$client.phone'] = &$data['$phone'];
|
|
|
|
$data['$city_state_postal'] = $this->present()->cityStateZip($this->client->city, $this->client->state, $this->client->postal_code, false);
|
|
|
|
$data['$client.city_state_postal'] = &$data['$city_state_postal'];
|
|
|
|
$data['$postal_city_state'] = $this->present()->cityStateZip($this->client->city, $this->client->state, $this->client->postal_code, true);
|
|
|
|
$data['$client.postal_city_state'] = &$data['$postal_city_state'];
|
|
|
|
$data['$country'] = isset($this->client->country->name) ?: 'No Country Set';
|
|
|
|
$data['$client.country'] = &$data['$country'];
|
|
|
|
$data['$email'] = isset($this->client->primary_contact()->first()->email) ?: 'no contact email on record';
|
|
|
|
$data['$client.email'] = &$data['$email'];
|
|
|
|
|
|
|
|
if ($contact) {
|
2019-12-24 22:55:29 +01:00
|
|
|
$data['$contact_name'] = $contact->present()->name();
|
|
|
|
$data['$contact.name'] = &$data['$contact_name'];
|
2019-12-30 22:59:12 +01:00
|
|
|
} else {
|
2019-09-04 03:45:53 +02:00
|
|
|
$data['$contact_name'] = $this->client->present()->primary_contact_name();
|
2019-12-16 12:34:38 +01:00
|
|
|
$data['$contact.name'] = &$data['$contact_name'];
|
2019-12-30 22:59:12 +01:00
|
|
|
}
|
2019-12-24 22:55:29 +01:00
|
|
|
|
2019-12-30 22:59:12 +01:00
|
|
|
$data['$company.name'] = $this->company->present()->name();
|
|
|
|
$data['$company.address1'] = $settings->address1;
|
|
|
|
$data['$company.address2'] = $settings->address2;
|
|
|
|
$data['$company.city'] = $settings->city;
|
|
|
|
$data['$company.state'] = $settings->state;
|
|
|
|
$data['$company.postal_code'] = $settings->postal_code;
|
|
|
|
$data['$company.country'] = Country::find($settings->country_id)->first()->name;
|
|
|
|
$data['$company.phone'] = $settings->phone;
|
|
|
|
$data['$company.email'] = $settings->email;
|
|
|
|
$data['$company.vat_number'] = $settings->vat_number;
|
|
|
|
$data['$company.id_number'] = $settings->id_number;
|
|
|
|
$data['$company.address'] = $this->company->present()->address($settings);
|
|
|
|
$data['$company.logo'] = $this->company->present()->logo($settings);
|
|
|
|
//$data['$blank'] = ;
|
|
|
|
//$data['$surcharge'] = ;
|
|
|
|
/*
|
|
|
|
$data['$tax_invoice'] =
|
|
|
|
$data['$tax_quote'] =
|
|
|
|
$data['$statement'] = ;
|
|
|
|
$data['$statement_date'] = ;
|
|
|
|
$data['$your_statement'] = ;
|
|
|
|
$data['$statement_issued_to'] = ;
|
|
|
|
$data['$statement_to'] = ;
|
|
|
|
$data['$credit_note'] = ;
|
|
|
|
$data['$credit_date'] = ;
|
|
|
|
$data['$credit_number'] = ;
|
|
|
|
$data['$credit_issued_to'] = ;
|
|
|
|
$data['$credit_to'] = ;
|
|
|
|
$data['$your_credit'] = ;
|
|
|
|
$data['$phone'] = ;
|
|
|
|
$data['$invoice_total'] = ;
|
|
|
|
$data['$outstanding'] = ;
|
|
|
|
$data['$invoice_due_date'] = ;
|
|
|
|
$data['$quote_due_date'] = ;
|
|
|
|
$data['$service'] = ;
|
|
|
|
$data['$product_key'] = ;
|
|
|
|
$data['$unit_cost'] = ;
|
|
|
|
$data['$custom_value1'] = ;
|
|
|
|
$data['$custom_value2'] = ;
|
|
|
|
$data['$delivery_note'] = ;
|
|
|
|
$data['$date'] = ;
|
|
|
|
$data['$method'] = ;
|
|
|
|
$data['$payment_date'] = ;
|
|
|
|
$data['$reference'] = ;
|
|
|
|
$data['$amount'] = ;
|
|
|
|
$data['$amount_paid'] =;
|
2019-09-02 07:08:26 +02:00
|
|
|
*/
|
|
|
|
return $data;
|
|
|
|
}
|
|
|
|
|
2019-09-03 01:00:52 +02:00
|
|
|
/**
|
|
|
|
* Returns a formatted HTML table of invoice line items
|
|
|
|
*
|
|
|
|
* @param array $columns The columns to be displayed
|
2019-12-30 22:59:12 +01:00
|
|
|
*
|
2019-09-03 01:00:52 +02:00
|
|
|
* @return string[HTML string
|
|
|
|
*/
|
2019-09-04 01:16:23 +02:00
|
|
|
public function table(array $columns) :?string
|
2019-09-03 01:00:52 +02:00
|
|
|
{
|
2019-12-30 22:59:12 +01:00
|
|
|
$data = '<table class="table table-striped items">';
|
|
|
|
$data .= '<thead><tr class="heading">';
|
2019-09-03 01:00:52 +02:00
|
|
|
|
2019-09-04 01:16:23 +02:00
|
|
|
$column_headers = $this->transformColumnsForHeader($columns);
|
|
|
|
|
2019-12-30 22:59:12 +01:00
|
|
|
foreach ($column_headers as $column) {
|
|
|
|
$data .= '<td>' . ctrans('texts.'.$column.'') . '</td>';
|
|
|
|
}
|
2019-09-03 05:39:35 +02:00
|
|
|
|
2019-12-30 22:59:12 +01:00
|
|
|
$data .= '</tr></thead>';
|
2019-09-03 01:00:52 +02:00
|
|
|
|
2019-12-30 22:59:12 +01:00
|
|
|
$columns = $this->transformColumnsForLineItems($columns);
|
2019-09-03 08:01:40 +02:00
|
|
|
|
2019-12-30 22:59:12 +01:00
|
|
|
$items = $this->transformLineItems($this->line_items);
|
2019-09-03 01:00:52 +02:00
|
|
|
|
2019-12-30 22:59:12 +01:00
|
|
|
foreach ($items as $item) {
|
|
|
|
$data .= '<tr class="item">';
|
2019-09-04 01:16:23 +02:00
|
|
|
|
2019-12-30 22:59:12 +01:00
|
|
|
foreach ($columns as $column) {
|
|
|
|
$data .= '<td>'. $item->{$column} . '</td>';
|
|
|
|
}
|
|
|
|
$data .= '</tr>';
|
|
|
|
}
|
2019-09-03 05:39:35 +02:00
|
|
|
|
2019-12-30 22:59:12 +01:00
|
|
|
$data .= '</table>';
|
2019-09-04 01:16:23 +02:00
|
|
|
|
|
|
|
return $data;
|
2019-09-03 01:00:52 +02:00
|
|
|
}
|
|
|
|
|
2019-09-04 01:16:23 +02:00
|
|
|
|
2019-09-03 08:01:40 +02:00
|
|
|
/**
|
2019-09-04 01:16:23 +02:00
|
|
|
* Transform the column headers into translated header values
|
2019-12-30 22:59:12 +01:00
|
|
|
*
|
2019-09-04 01:16:23 +02:00
|
|
|
* @param array $columns The column header values
|
|
|
|
* @return array The new column header variables
|
|
|
|
*/
|
|
|
|
private function transformColumnsForHeader(array $columns) :array
|
|
|
|
{
|
2019-09-04 07:10:10 +02:00
|
|
|
$pre_columns = $columns;
|
|
|
|
$columns = array_intersect($columns, self::$master_columns);
|
2019-09-04 01:16:23 +02:00
|
|
|
|
2019-12-30 22:59:12 +01:00
|
|
|
return str_replace(
|
|
|
|
[
|
2019-09-04 01:16:23 +02:00
|
|
|
'tax_name1',
|
|
|
|
'tax_name2'
|
2019-12-30 22:59:12 +01:00
|
|
|
],
|
2019-09-04 01:16:23 +02:00
|
|
|
[
|
|
|
|
'tax',
|
|
|
|
'tax',
|
2019-12-30 22:59:12 +01:00
|
|
|
],
|
|
|
|
$columns
|
|
|
|
);
|
2019-09-04 01:16:23 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2019-12-30 22:59:12 +01:00
|
|
|
*
|
2019-09-03 08:01:40 +02:00
|
|
|
* Transform the column headers into invoice variables
|
2019-12-30 22:59:12 +01:00
|
|
|
*
|
2019-09-03 08:01:40 +02:00
|
|
|
* @param array $columns The column header values
|
|
|
|
* @return array The invoice variables
|
|
|
|
*/
|
2019-09-04 01:16:23 +02:00
|
|
|
private function transformColumnsForLineItems(array $columns) :array
|
2019-09-03 08:01:40 +02:00
|
|
|
{
|
2019-09-04 01:16:23 +02:00
|
|
|
/* Removes any invalid columns the user has entered. */
|
2019-09-04 07:10:10 +02:00
|
|
|
$columns = array_intersect($columns, self::$master_columns);
|
2019-09-04 01:16:23 +02:00
|
|
|
|
2019-12-30 22:59:12 +01:00
|
|
|
return str_replace(
|
|
|
|
[
|
|
|
|
'custom_invoice_label1',
|
|
|
|
'custom_invoice_label2',
|
|
|
|
'custom_invoice_label3',
|
|
|
|
'custom_invoice_label4',
|
|
|
|
'tax_name1',
|
|
|
|
'tax_name2'
|
|
|
|
],
|
|
|
|
[
|
2019-09-04 00:16:53 +02:00
|
|
|
'custom_invoice_value1',
|
|
|
|
'custom_invoice_value2',
|
|
|
|
'custom_invoice_value3',
|
|
|
|
'custom_invoice_value4',
|
|
|
|
'tax_rate1',
|
|
|
|
'tax_rate2'
|
2019-12-30 22:59:12 +01:00
|
|
|
],
|
|
|
|
$columns
|
|
|
|
);
|
2019-09-03 08:01:40 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Formats the line items for display
|
|
|
|
* @param array $items The array of invoice items
|
|
|
|
* @return array The formatted array of invoice items
|
|
|
|
*/
|
|
|
|
private function transformLineItems(array $items) :array
|
|
|
|
{
|
2019-12-30 22:59:12 +01:00
|
|
|
foreach ($items as $item) {
|
2019-09-11 05:46:23 +02:00
|
|
|
$item->cost = Number::formatMoney($item->cost, $this->client);
|
|
|
|
$item->line_total = Number::formatMoney($item->line_total, $this->client);
|
2019-09-04 00:16:53 +02:00
|
|
|
|
2019-12-30 22:59:12 +01:00
|
|
|
if (isset($item->discount) && $item->discount > 0) {
|
|
|
|
if ($item->is_amount_discount) {
|
2019-09-11 05:46:23 +02:00
|
|
|
$item->discount = Number::formatMoney($item->discount, $this->client);
|
2019-12-30 22:59:12 +01:00
|
|
|
} else {
|
2019-09-04 00:16:53 +02:00
|
|
|
$item->discount = $item->discount . '%';
|
2019-12-30 22:59:12 +01:00
|
|
|
}
|
2019-09-04 00:16:53 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-12-30 22:59:12 +01:00
|
|
|
return $items;
|
2019-09-03 08:01:40 +02:00
|
|
|
}
|
2019-09-04 14:01:19 +02:00
|
|
|
|
|
|
|
/**
|
2019-12-30 22:59:12 +01:00
|
|
|
* Due to the way we are compiling the blade template we
|
2019-09-04 14:01:19 +02:00
|
|
|
* have no ability to iterate, so in the case
|
2019-12-30 22:59:12 +01:00
|
|
|
* of line taxes where there are multiple rows,
|
2019-09-04 14:01:19 +02:00
|
|
|
* we use this function to format a section of rows
|
2019-12-30 22:59:12 +01:00
|
|
|
*
|
|
|
|
* @return string a collection of <tr> rows with line item
|
2019-09-04 14:01:19 +02:00
|
|
|
* aggregate data
|
|
|
|
*/
|
|
|
|
private function makeLineTaxes() :string
|
|
|
|
{
|
|
|
|
$tax_map = $this->calc()->getTaxMap();
|
|
|
|
|
|
|
|
$data = '';
|
|
|
|
|
2019-12-30 22:59:12 +01:00
|
|
|
foreach ($tax_map as $tax) {
|
2019-09-04 14:01:19 +02:00
|
|
|
$data .= '<tr class="line_taxes">';
|
|
|
|
$data .= '<td>'. $tax['name'] .'</td>';
|
2019-09-11 05:46:23 +02:00
|
|
|
$data .= '<td>'. Number::formatMoney($tax['total'], $this->client) .'</td></tr>';
|
2019-09-04 14:01:19 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
return $data;
|
|
|
|
}
|
2019-10-13 12:59:55 +02:00
|
|
|
|
|
|
|
/**
|
2019-12-30 22:59:12 +01:00
|
|
|
* @return string a collectino of <tr> with
|
2019-10-13 12:59:55 +02:00
|
|
|
* itemised total tax data
|
|
|
|
*/
|
|
|
|
|
|
|
|
private function makeTotalTaxes() :string
|
|
|
|
{
|
|
|
|
$data = '';
|
|
|
|
|
2019-12-30 22:59:12 +01:00
|
|
|
if (!$this->calc()->getTotalTaxMap()) {
|
2019-10-16 11:28:52 +02:00
|
|
|
return $data;
|
2019-12-30 22:59:12 +01:00
|
|
|
}
|
2019-10-16 11:28:52 +02:00
|
|
|
|
2019-12-30 22:59:12 +01:00
|
|
|
foreach ($this->calc()->getTotalTaxMap() as $tax) {
|
2019-10-13 12:59:55 +02:00
|
|
|
$data .= '<tr class="total_taxes">';
|
|
|
|
$data .= '<td>'. $tax['name'] .'</td>';
|
|
|
|
$data .= '<td>'. Number::formatMoney($tax['total'], $this->client) .'</td></tr>';
|
|
|
|
}
|
|
|
|
|
|
|
|
return $data;
|
|
|
|
}
|
2019-12-30 22:59:12 +01:00
|
|
|
}
|