2017-01-30 20:40:43 +01:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace App\Ninja\Import\CSV;
|
2015-11-24 20:45:38 +01:00
|
|
|
|
2015-12-08 11:10:20 +01:00
|
|
|
use App\Ninja\Import\BaseTransformer;
|
2015-11-24 20:45:38 +01:00
|
|
|
use League\Fractal\Resource\Item;
|
|
|
|
|
2016-07-03 18:11:58 +02:00
|
|
|
/**
|
2017-01-30 20:40:43 +01:00
|
|
|
* Class InvoiceTransformer.
|
2016-07-03 18:11:58 +02:00
|
|
|
*/
|
2015-12-08 11:10:20 +01:00
|
|
|
class InvoiceTransformer extends BaseTransformer
|
2015-11-24 20:45:38 +01:00
|
|
|
{
|
2016-07-03 18:11:58 +02:00
|
|
|
/**
|
|
|
|
* @param $data
|
2017-01-30 20:40:43 +01:00
|
|
|
*
|
2016-07-03 18:11:58 +02:00
|
|
|
* @return bool|Item
|
|
|
|
*/
|
2015-12-08 11:10:20 +01:00
|
|
|
public function transform($data)
|
2015-11-24 20:45:38 +01:00
|
|
|
{
|
2017-01-30 17:05:31 +01:00
|
|
|
if (! $this->getClientId($data->name)) {
|
2015-11-24 20:45:38 +01:00
|
|
|
return false;
|
|
|
|
}
|
2015-11-24 21:41:08 +01:00
|
|
|
|
2015-12-08 11:10:20 +01:00
|
|
|
if (isset($data->invoice_number) && $this->hasInvoice($data->invoice_number)) {
|
2015-11-24 20:45:38 +01:00
|
|
|
return false;
|
|
|
|
}
|
2015-12-08 11:10:20 +01:00
|
|
|
|
|
|
|
return new Item($data, function ($data) {
|
2015-11-24 20:45:38 +01:00
|
|
|
return [
|
2015-12-08 11:10:20 +01:00
|
|
|
'client_id' => $this->getClientId($data->name),
|
2015-12-10 14:35:40 +01:00
|
|
|
'invoice_number' => isset($data->invoice_number) ? $this->getInvoiceNumber($data->invoice_number) : null,
|
2016-12-22 18:17:45 +01:00
|
|
|
'paid' => $this->getFloat($data, 'paid'),
|
2015-12-31 16:09:45 +01:00
|
|
|
'po_number' => $this->getString($data, 'po_number'),
|
|
|
|
'terms' => $this->getString($data, 'terms'),
|
|
|
|
'public_notes' => $this->getString($data, 'public_notes'),
|
2017-01-15 20:48:31 +01:00
|
|
|
'invoice_date_sql' => $this->getDate($data, 'invoice_date'),
|
|
|
|
'due_date_sql' => $this->getDate($data, 'due_date'),
|
2015-11-24 20:45:38 +01:00
|
|
|
'invoice_items' => [
|
|
|
|
[
|
2017-08-23 14:26:03 +02:00
|
|
|
'product_key' => $this->getString($data, 'item_product'),
|
|
|
|
'notes' => $this->getString($data, 'item_notes') ?: $this->getProduct($data, 'item_product', 'notes', ''),
|
|
|
|
'cost' => $this->getFloat($data, 'item_notes') ?: $this->getProduct($data, 'item_product', 'cost', 0),
|
|
|
|
'qty' => $this->getFloat($data, 'item_quantity') ?: 1,
|
|
|
|
'tax_name1' => $this->getTaxName($this->getString($data, 'item_tax1')),
|
|
|
|
'tax_rate1' => $this->getTaxRate($this->getString($data, 'item_tax1')),
|
|
|
|
'tax_name2' => $this->getTaxName($this->getString($data, 'item_tax2')),
|
|
|
|
'tax_rate2' => $this->getTaxRate($this->getString($data, 'item_tax2')),
|
2017-01-30 20:40:43 +01:00
|
|
|
],
|
2015-11-24 20:45:38 +01:00
|
|
|
],
|
|
|
|
];
|
|
|
|
});
|
|
|
|
}
|
2016-12-22 18:17:45 +01:00
|
|
|
}
|