mirror of
https://github.com/invoiceninja/invoiceninja.git
synced 2024-09-20 16:31:33 +02:00
Freshbooks import
This commit is contained in:
parent
b4b49023de
commit
b1df10689c
55
app/Import/Transformer/Freshbooks/ClientTransformer.php
Normal file
55
app/Import/Transformer/Freshbooks/ClientTransformer.php
Normal file
@ -0,0 +1,55 @@
|
||||
<?php
|
||||
/**
|
||||
* Invoice Ninja (https://clientninja.com).
|
||||
*
|
||||
* @link https://github.com/clientninja/clientninja source repository
|
||||
*
|
||||
* @copyright Copyright (c) 2021. client Ninja LLC (https://clientninja.com)
|
||||
*
|
||||
* @license https://www.elastic.co/licensing/elastic-license
|
||||
*/
|
||||
|
||||
namespace App\Import\Transformer\Freshbooks;
|
||||
|
||||
use App\Import\ImportException;
|
||||
use App\Import\Transformer\BaseTransformer;
|
||||
use Illuminate\Support\Str;
|
||||
|
||||
/**
|
||||
* Class ClientTransformer.
|
||||
*/
|
||||
class ClientTransformer extends BaseTransformer {
|
||||
/**
|
||||
* @param $data
|
||||
*
|
||||
* @return array|bool
|
||||
*/
|
||||
public function transform( $data ) {
|
||||
if ( isset( $data['Organization'] ) && $this->hasClient( $data['Organization'] ) ) {
|
||||
throw new ImportException('Client already exists');
|
||||
}
|
||||
|
||||
return [
|
||||
'company_id' => $this->company->id,
|
||||
'name' => $this->getString( $data, 'Organization' ),
|
||||
'work_phone' => $this->getString( $data, 'Phone' ),
|
||||
'address1' => $this->getString( $data, 'Street' ),
|
||||
'city' => $this->getString( $data, 'City' ),
|
||||
'state' => $this->getString( $data, 'Province/State' ),
|
||||
'postal_code' => $this->getString( $data, 'Postal Code' ),
|
||||
'country_id' => isset( $data['Country'] ) ? $this->getCountryId( $data['Country'] ) : null,
|
||||
'private_notes' => $this->getString( $data, 'Notes' ),
|
||||
'credit_balance' => 0,
|
||||
'settings' => new \stdClass,
|
||||
'client_hash' => Str::random( 40 ),
|
||||
'contacts' => [
|
||||
[
|
||||
'first_name' => $this->getString( $data, 'First Name' ),
|
||||
'last_name' => $this->getString( $data, 'Last Name' ),
|
||||
'email' => $this->getString( $data, 'Email' ),
|
||||
'phone' => $this->getString( $data, 'Phone' ),
|
||||
],
|
||||
],
|
||||
];
|
||||
}
|
||||
}
|
86
app/Import/Transformer/Freshbooks/InvoiceTransformer.php
Normal file
86
app/Import/Transformer/Freshbooks/InvoiceTransformer.php
Normal file
@ -0,0 +1,86 @@
|
||||
<?php
|
||||
/**
|
||||
* client Ninja (https://clientninja.com).
|
||||
*
|
||||
* @link https://github.com/clientninja/clientninja source repository
|
||||
*
|
||||
* @copyright Copyright (c) 2021. client Ninja LLC (https://clientninja.com)
|
||||
*
|
||||
* @license https://www.elastic.co/licensing/elastic-license
|
||||
*/
|
||||
|
||||
namespace App\Import\Transformer\Freshbooks;
|
||||
|
||||
use App\Import\ImportException;
|
||||
use App\Import\Transformer\BaseTransformer;
|
||||
use App\Models\Invoice;
|
||||
use App\Utils\Number;
|
||||
|
||||
/**
|
||||
* Class InvoiceTransformer.
|
||||
*/
|
||||
class InvoiceTransformer extends BaseTransformer {
|
||||
/**
|
||||
* @param $line_items_data
|
||||
*
|
||||
* @return bool|array
|
||||
*/
|
||||
public function transform( $line_items_data ) {
|
||||
$invoice_data = reset( $line_items_data );
|
||||
|
||||
if ( $this->hasInvoice( $invoice_data['Invoice #'] ) ) {
|
||||
throw new ImportException( 'Invoice number already exists' );
|
||||
}
|
||||
|
||||
$invoiceStatusMap = [
|
||||
'sent' => Invoice::STATUS_SENT,
|
||||
'draft' => Invoice::STATUS_DRAFT,
|
||||
];
|
||||
|
||||
$transformed = [
|
||||
'company_id' => $this->company->id,
|
||||
'client_id' => $this->getClient( $this->getString( $invoice_data, 'Client Name' ), null ),
|
||||
'number' => $this->getString( $invoice_data, 'Invoice #' ),
|
||||
'date' => isset( $invoice_data['Date Issued'] ) ? date( 'Y-m-d', strtotime( $invoice_data['Date Issued'] ) ) : null,
|
||||
'currency_id' => $this->getCurrencyByCode( $invoice_data, 'Currency' ),
|
||||
'amount' => 0,
|
||||
'status_id' => $invoiceStatusMap[ $status =
|
||||
strtolower( $this->getString( $invoice_data, 'Invoice Status' ) ) ] ?? Invoice::STATUS_SENT,
|
||||
// 'viewed' => $status === 'viewed',
|
||||
];
|
||||
|
||||
$line_items = [];
|
||||
foreach ( $line_items_data as $record ) {
|
||||
$line_items[] = [
|
||||
'product_key' => $this->getString( $record, 'Item Name' ),
|
||||
'notes' => $this->getString( $record, 'Item Description' ),
|
||||
'cost' => $this->getFreshbookQuantityFloat( $record, 'Rate' ),
|
||||
'quantity' => $this->getFreshbookQuantityFloat( $record, 'Quantity' ),
|
||||
'discount' => $this->getFreshbookQuantityFloat( $record, 'Discount Percentage' ),
|
||||
'is_amount_discount' => false,
|
||||
'tax_name1' => $this->getString( $record, 'Tax 1 Type' ),
|
||||
'tax_rate1' => $this->getFreshbookQuantityFloat( $record, 'Tax 1 Amount' ),
|
||||
'tax_name2' => $this->getString( $record, 'Tax 2 Type' ),
|
||||
'tax_rate2' => $this->getFreshbookQuantityFloat( $record, 'Tax 2 Amount' ),
|
||||
];
|
||||
$transformed['amount'] += $this->getFreshbookQuantityFloat( $record, 'Line Total' );
|
||||
}
|
||||
$transformed['line_items'] = $line_items;
|
||||
|
||||
if ( ! empty( $invoice_data['Date Paid'] ) ) {
|
||||
$transformed['payments'] = [[
|
||||
'date' => date( 'Y-m-d', strtotime( $invoice_data['Date Paid'] ) ),
|
||||
'amount' => $transformed['amount'],
|
||||
]];
|
||||
}
|
||||
|
||||
return $transformed;
|
||||
}
|
||||
|
||||
/** @return float */
|
||||
public function getFreshbookQuantityFloat($data, $field)
|
||||
{
|
||||
return $data[$field];
|
||||
}
|
||||
|
||||
}
|
@ -36,8 +36,6 @@ class ClientTransformer extends BaseTransformer {
|
||||
$settings->payment_terms = $data['Payment Terms'];
|
||||
}
|
||||
|
||||
nlog($settings);
|
||||
|
||||
return [
|
||||
'company_id' => $this->company->id,
|
||||
'name' => $this->getString( $data, 'Company Name' ),
|
||||
|
Loading…
Reference in New Issue
Block a user