Integrate your Laravel application with InvoiceXpress' API
This package can be used on 2 different layers:
- via the provided Models.
- interacting directly with the API endpoint.
Using the former allows you to transparently create, update and delete entities both in your application's database and in InvoiceXpress.
You can install the package via composer:
composer require square-bit/invoicexpress-for-laravel
Optionally, you can publish and run the migrations:
php artisan vendor:publish --tag="invoicexpress-for-laravel-migrations"
php artisan migrate
You can publish the config file with:
php artisan vendor:publish --tag="invoicexpress-for-laravel-config"
This is the contents of the published config file:
return [
'account' => [
'name' => env('IX_ACCOUNT_NAME'),
'api_key' => env('IX_API_KEY'),
],
'service_endpoint' => 'app.invoicexpress.com',
'eloquent' => [
'persist' => false,
],
];
IX_ACCOUNT_NAME
is your InvoiceXpress account name (the XXX in https://XXX.app.invoicexpress.com).
IX_API_KEY
is the API key you can get from your InvoiceXpress account settings page.
persist
defines whether to store the entities in your database, when using the "Model" layer. Default is false
.
If you set it to true
, make sure you ran the migrations.
With this approach, the package handles both local and remote changes to the entities.
This however is not enabled by default. To enable it:
- publish and run the migrations (see Installation)
- set
persist => true
in the config file (see Installation)
You can get a specific Item and update it:
use Squarebit\InvoiceXpress\API\Data\ItemData;
use Squarebit\InvoiceXpress\Model\IxItem;
$item = IxItem::find(1234);
$item->description = "a serious description";
$item->save();
Or you can create one:
$data = ItemData::from([...]);
$item = (new IxItem())->fromData($data)
->save();
Or even delete it:
$item->delete();
use Squarebit\InvoiceXpress\API\Data\PdfData;
$invoice = (new IxInvoice())
->setClient(IxClient::findOrFail(1234)) // set the invoice's client
->addItem(IxItem::find(2345)) // add an IxItem model
->addItem(ItemData::from([....])) // you can also add from an ItemData
->addItems([ // or from an array
ItemData::from([...]),
IxItem::find(3579),
...
])
->save(); // creates the new invoice (locally and in InvoiceXpress)
->finalizeDocument() // formally registers the invoice
->email(); // email the invoice to the client
// Store the pdf locally
$pdf = $invoice->getPdf()->pdfUrl;
Storage::put('file.jpg', $pdf);
// Pay the invoice and email the receipt
$receipt = $invoice
->pay()
->email();
With this approach, only remote changes are handled. If you want, you'll have to manage local changes (in your database) manually.
You can get a specific Item and update it:
use Squarebit\InvoiceXpress\Facades\InvoiceXpress;
$itemsEndpoint = InvoiceXpress::items();
$itemData = $itemsEndpoint->get(1234);
$itemData->description = "a serious description";
$itemsEndpoint->update($itemData);
Or you can create one:
$data = ItemData::from([...]);
$itemData = InvoiceXpress::items()->create($itemData);
Or even delete it:
InvoiceXpress::items()->delete(1234);
use Squarebit\InvoiceXpress\API\Data\ClientData;
use Squarebit\InvoiceXpress\API\Data\EmailClientData;
use Squarebit\InvoiceXpress\API\Data\EmailData;
use Squarebit\InvoiceXpress\API\Data\InvoiceData;
use Squarebit\InvoiceXpress\API\Data\ItemData;
use Squarebit\InvoiceXpress\API\Data\PartialPaymentData;
use Squarebit\InvoiceXpress\API\Data\StateData;
use Squarebit\InvoiceXpress\Enums\DocumentEventEnum;
use Squarebit\InvoiceXpress\Enums\EntityTypeEnum;
use Squarebit\InvoiceXpress\Facades\InvoiceXpress;
$invoiceEndpoint = InvoiceXpress::invoices();
// Create an Invoice
$invoiceData = $invoiceEndpoint->create(
EntityTypeEnum::SimplifiedInvoice,
InvoiceData::from([
...
'client' => ClientData::from([
...
]),
'items' => [
ItemData::from([])
]
])
);
// Formally register it
$invoiceEndpoint->changeState(
EntityTypeEnum::SimplifiedInvoice,
$invoiceData->id,
StateData::from([
'state' => DocumentEventEnum::Finalized
])
);
// Email the Invoice
$invoiceEndpoint->sendByEmail(
EntityTypeEnum::SimplifiedInvoice,
$invoiceData->id,
EmailData::from([
'client_data' => EmailClientData::from([
'email' => 'someone@somewhere.com'
]),
'subject' => '...',
'body' => '...',
'cc' => '...',
'bcc' => '...',
])
);
// Get the pdf
$pdfData = $invoiceEndpoint->generatePDF($invoiceData->id)
// Pay the invoice (in total)
$receiptData = $invoiceEndpoint->generatePayment([
EntityTypeEnum::SimplifiedInvoice,
$invoiceData->id,
PartialPaymentData::from([
'amount' => $invoiceData->total,
])
])
$itemsEndpoint = InvoiceXpress::items();
// get an Item by querying the endpoint directly
$itemData = $itemsEndpoint->get(1234);
// create an IxItem model with that data and update it
$item = (new IxItem())->fromData($itemData);
$item->description = 'a more serious description';
// send the modifed data to InvoiceXpress
$itemsEndpoint->update($item->getData());
InvoiceXpress entity | Model class | Endpoint class |
---|---|---|
Items | IxItem | ItemsEndpoint |
Taxes | IxTax | TaxesEndpoint |
Clients | IxIClient | ClientsEndpoint |
Invoices (Invoice) | IxInvoice | InvoicesEndpoint |
Invoices (SimplifiedInvoice) | IxSimplifiedInvoice | InvoicesEndpoint |
Invoices (InvoiceReceipt) | IxInvoiceReceipt | InvoicesEndpoint |
Invoices (Receipt) | IxReceipt | InvoicesEndpoint |
Invoices (CreditNote) | IxCreditNote | InvoicesEndpoint |
Invoices (DebitNote) | IxDebitNote | InvoicesEndpoint |
Invoices (CashInvoice) | IxCashInvoice | InvoicesEndpoint |
Invoices (VatMossInvoice) | IxVatMossInvoice | InvoicesEndpoint |
Invoices (VatMossReceipt) | IxVatMossReceipt | InvoicesEndpoint |
Invoices (VatMossCreditNote) | IxVatMossCreditNote | InvoicesEndpoint |
Estimates (Quote) | IxQuote | EstimatesEndpoint |
Estimates (Proforma) | IxProforma | EstimatesEndpoint |
Estimates (FeesNote) | IxFeesNote | EstimatesEndpoint |
Guides (Shipping) | IxShipping | GuidesEndpoint |
Guides (Transport) | IxTransport | GuidesEndpoint |
Guides (Devolution) | IxDevolution | GuidesEndpoint |
Sequences | IxSequence | SequencesEndpoint |
SAF-T | - | SaftEndpoint |
composer test
Please see CHANGELOG for more information on what has changed recently.
Please see CONTRIBUTING for details.
Please review our security policy on how to report security vulnerabilities.
The MIT License (MIT). Please see License File for more information.