mirror of
https://github.com/invoiceninja/invoiceninja.git
synced 2024-09-20 16:31:33 +02:00
3d31f810c0
* Working on importing company gateways * Fix for companyuser settings object * Migrate client_gateway_tokens * Working on Notificaitons * Working on notifications * Failsafe for user-company * unlink files * Set DB for jobs * Always have a fallback for company_id * Fixes for user model * Formatting for MultiDB * Working on Company Ledger Tests * Fixes for contact request * Set Invitations as a default include for invoices
111 lines
3.2 KiB
PHP
111 lines
3.2 KiB
PHP
<?php
|
|
/**
|
|
* Invoice Ninja (https://invoiceninja.com)
|
|
*
|
|
* @link https://github.com/invoiceninja/invoiceninja source repository
|
|
*
|
|
* @copyright Copyright (c) 2020. Invoice Ninja LLC (https://invoiceninja.com)
|
|
*
|
|
* @license https://opensource.org/licenses/AAL
|
|
*/
|
|
|
|
namespace App\Repositories;
|
|
|
|
use App\Factory\QuoteInvitationFactory;
|
|
use App\Helpers\Invoice\InvoiceSum;
|
|
use App\Jobs\Quote\ApplyQuoteNumber;
|
|
use App\Jobs\Quote\CreateQuoteInvitations;
|
|
use App\Models\Client;
|
|
use App\Models\ClientContact;
|
|
use App\Models\Quote;
|
|
use App\Models\QuoteInvitation;
|
|
use App\Utils\Traits\MakesHash;
|
|
use Illuminate\Http\Request;
|
|
|
|
/**
|
|
* QuoteRepository
|
|
*/
|
|
class QuoteRepository extends BaseRepository
|
|
{
|
|
|
|
use MakesHash;
|
|
|
|
public function getClassName()
|
|
{
|
|
return Quote::class;
|
|
}
|
|
|
|
public function save($data, Quote $quote) : ?Quote
|
|
{
|
|
|
|
/* Always carry forward the initial invoice amount this is important for tracking client balance changes later......*/
|
|
$starting_amount = $quote->amount;
|
|
|
|
$quote->fill($data);
|
|
|
|
$quote->save();
|
|
|
|
if (isset($data['client_contacts'])) {
|
|
foreach ($data['client_contacts'] as $contact) {
|
|
if ($contact['send_email'] == 1 && is_string($contact['id'])) {
|
|
$client_contact = ClientContact::find($this->decodePrimaryKey($contact['id']));
|
|
$client_contact->send_email = true;
|
|
$client_contact->save();
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
if (isset($data['invitations'])) {
|
|
$invitations = collect($data['invitations']);
|
|
|
|
/* Get array of Keys which have been removed from the invitations array and soft delete each invitation */
|
|
collect($quote->invitations->pluck('key'))->diff($invitations->pluck('key'))->each(function ($invitation) {
|
|
$this->getInvitationByKey($invitation)->delete();
|
|
});
|
|
|
|
foreach ($data['invitations'] as $invitation) {
|
|
$inv = false;
|
|
|
|
if (array_key_exists('key', $invitation)) {
|
|
$inv = $this->getInvitationByKey([$invitation['key']])->first();
|
|
}
|
|
|
|
if (!$inv) {
|
|
|
|
if (isset($invitation['id'])) {
|
|
unset($invitation['id']);
|
|
}
|
|
|
|
$new_invitation = QuoteInvitationFactory::create($quote->company_id, $quote->user_id);
|
|
$new_invitation->quote_id = $quote->id;
|
|
$new_invitation->client_contact_id = $this->decodePrimaryKey($invitation['client_contact_id']);
|
|
$new_invitation->save();
|
|
|
|
}
|
|
}
|
|
}
|
|
|
|
/* If no invitations have been created, this is our fail safe to maintain state*/
|
|
if ($quote->invitations->count() == 0) {
|
|
$quote->service()->createInvitations();
|
|
}
|
|
|
|
$quote = $quote->calc()->getQuote();
|
|
|
|
$quote->save();
|
|
|
|
$finished_amount = $quote->amount;
|
|
|
|
$quote = $quote->service()->applyNumber()->save();
|
|
|
|
return $quote->fresh();
|
|
}
|
|
|
|
public function getInvitationByKey($key) :?QuoteInvitation
|
|
{
|
|
return QuoteInvitation::whereRaw("BINARY `key`= ?", [$key])->first();
|
|
}
|
|
|
|
}
|