mirror of
				https://github.com/invoiceninja/invoiceninja.git
				synced 2025-10-26 04:02:53 -04:00 
			
		
		
		
	
						commit
						656d7941cb
					
				
							
								
								
									
										1
									
								
								.github/workflows/release.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								.github/workflows/release.yml
									
									
									
									
										vendored
									
									
								
							| @ -36,7 +36,6 @@ jobs: | ||||
|           php artisan optimize | ||||
|           php artisan storage:link | ||||
|           sudo php artisan cache:clear | ||||
|           sudo find ./ -type f -exec chmod 644 {} \; | ||||
|           sudo find ./vendor/bin/ -type f -exec chmod +x {} \; | ||||
|           sudo find ./ -type d -exec chmod 755 {} \; | ||||
|            | ||||
|  | ||||
| @ -1 +1 @@ | ||||
| 5.0.49 | ||||
| 5.0.50 | ||||
| @ -25,7 +25,7 @@ class CloneCreditFactory | ||||
|         $clone_credit->due_date = null; | ||||
|         $clone_credit->partial_due_date = null; | ||||
|         $clone_credit->user_id = $user_id; | ||||
|         $clone_credit->balance = $credit->amount; | ||||
|         //$clone_credit->balance = $credit->amount;
 | ||||
|         $clone_credit->line_items = $credit->line_items; | ||||
| 
 | ||||
|         return $clone_credit; | ||||
|  | ||||
| @ -39,7 +39,7 @@ class CloneCreditToQuoteFactory | ||||
|         $quote->custom_value3 = $credit->custom_value3; | ||||
|         $quote->custom_value4 = $credit->custom_value4; | ||||
|         $quote->amount = $credit->amount; | ||||
|         $quote->balance = $credit->balance; | ||||
|         //$quote->balance = $credit->balance;
 | ||||
|         $quote->partial = $credit->partial; | ||||
|         $quote->partial_due_date = $credit->partial_due_date; | ||||
|         $quote->last_viewed = $credit->last_viewed; | ||||
| @ -49,7 +49,7 @@ class CloneCreditToQuoteFactory | ||||
|         $quote->date = null; | ||||
|         $quote->due_date = null; | ||||
|         $quote->partial_due_date = null; | ||||
|         $quote->balance = $credit->amount; | ||||
|         // $quote->balance = $credit->amount;
 | ||||
|         $quote->line_items = $credit->line_items; | ||||
| 
 | ||||
|         return $quote; | ||||
|  | ||||
| @ -24,7 +24,7 @@ class CloneInvoiceFactory | ||||
|         $clone_invoice->due_date = null; | ||||
|         $clone_invoice->partial_due_date = null; | ||||
|         $clone_invoice->user_id = $user_id; | ||||
|         $clone_invoice->balance = $invoice->amount; | ||||
|         //$clone_invoice->balance = $invoice->amount;
 | ||||
|         $clone_invoice->amount = $invoice->amount; | ||||
|         $clone_invoice->line_items = $invoice->line_items; | ||||
| 
 | ||||
|  | ||||
| @ -38,7 +38,7 @@ class CloneInvoiceToQuoteFactory | ||||
|         $quote->custom_value3 = $invoice->custom_value3; | ||||
|         $quote->custom_value4 = $invoice->custom_value4; | ||||
|         $quote->amount = $invoice->amount; | ||||
|         $quote->balance = $invoice->amount; | ||||
|         //$quote->balance = $invoice->amount;
 | ||||
|         $quote->partial = $invoice->partial; | ||||
|         $quote->partial_due_date = $invoice->partial_due_date; | ||||
|         $quote->last_viewed = $invoice->last_viewed; | ||||
|  | ||||
| @ -24,7 +24,7 @@ class CloneQuoteFactory | ||||
|         $clone_quote->due_date = null; | ||||
|         $clone_quote->partial_due_date = null; | ||||
|         $clone_quote->user_id = $user_id; | ||||
|         $clone_quote->balance = $quote->amount; | ||||
|         //$clone_quote->balance = $quote->amount;
 | ||||
|         $clone_quote->amount = $quote->amount; | ||||
|         $clone_quote->line_items = $quote->line_items; | ||||
| 
 | ||||
|  | ||||
| @ -38,6 +38,7 @@ class CloneQuoteToInvoiceFactory | ||||
|         $invoice->partial_due_date = null; | ||||
|         $invoice->number = null; | ||||
|         $invoice->date = now()->format('Y-m-d'); | ||||
|         $invoice->balance = 0; | ||||
|         return $invoice; | ||||
|     } | ||||
| } | ||||
|  | ||||
| @ -42,7 +42,7 @@ class InvoiceToRecurringInvoiceFactory | ||||
|         $recurring_invoice->custom_value3 = $invoice->custom_value3; | ||||
|         $recurring_invoice->custom_value4 = $invoice->custom_value4; | ||||
|         $recurring_invoice->amount = $invoice->amount; | ||||
|         $recurring_invoice->balance = $invoice->balance; | ||||
|         // $recurring_invoice->balance = $invoice->balance;
 | ||||
|         $recurring_invoice->user_id = $invoice->user_id; | ||||
|         $recurring_invoice->client_id = $invoice->client_id; | ||||
|         $recurring_invoice->company_id = $invoice->company_id; | ||||
|  | ||||
| @ -75,7 +75,7 @@ class BaseController extends Controller | ||||
|           'company.credits.invitations.company', | ||||
|           'company.credits.documents', | ||||
|           'company.expenses.documents', | ||||
|           'company.groups', | ||||
|           'company.groups.documents', | ||||
|           'company.invoices.invitations.contact', | ||||
|           'company.invoices.invitations.company', | ||||
|           'company.invoices.documents', | ||||
|  | ||||
							
								
								
									
										99
									
								
								app/Jobs/Mail/EntityFailedSendMailer.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										99
									
								
								app/Jobs/Mail/EntityFailedSendMailer.php
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,99 @@ | ||||
| <?php | ||||
| /** | ||||
|  * Invoice Ninja (https://invoiceninja.com). | ||||
|  * | ||||
|  * @link https://github.com/invoiceninja/invoiceninja source repository | ||||
|  * | ||||
|  * @copyright Copyright (c) 2021. Invoice Ninja LLC (https://invoiceninja.com) | ||||
|  * | ||||
|  * @license https://opensource.org/licenses/AAL | ||||
|  */ | ||||
| 
 | ||||
| namespace App\Jobs\Mail; | ||||
| 
 | ||||
| use App\Libraries\MultiDB; | ||||
| use App\Mail\Admin\EntityNotificationMailer; | ||||
| use App\Mail\Admin\EntitySentObject; | ||||
| use Illuminate\Bus\Queueable; | ||||
| use Illuminate\Contracts\Queue\ShouldQueue; | ||||
| use Illuminate\Foundation\Bus\Dispatchable; | ||||
| use Illuminate\Queue\InteractsWithQueue; | ||||
| use Illuminate\Queue\SerializesModels; | ||||
| use Illuminate\Support\Facades\Mail; | ||||
| 
 | ||||
| /*Multi Mailer implemented*/ | ||||
| 
 | ||||
| class EntityFailedSendMailer extends BaseMailerJob implements ShouldQueue | ||||
| { | ||||
|     use Dispatchable, InteractsWithQueue, Queueable, SerializesModels; | ||||
| 
 | ||||
|     public $company; | ||||
| 
 | ||||
|     public $user; | ||||
| 
 | ||||
|     public $invitation; | ||||
| 
 | ||||
|     public $entity_type; | ||||
| 
 | ||||
|     public $entity; | ||||
| 
 | ||||
|     public $settings; | ||||
| 
 | ||||
|     public $template; | ||||
|     /** | ||||
|      * Create a new job instance. | ||||
|      * | ||||
|      * @param $invitation | ||||
|      * @param $entity_type | ||||
|      * @param $user | ||||
|      * @param $company | ||||
|      */ | ||||
|     public function __construct($invitation, $entity_type, $user, $company, $template) | ||||
|     { | ||||
|         $this->company = $company; | ||||
| 
 | ||||
|         $this->user = $user; | ||||
| 
 | ||||
|         $this->invitation = $invitation; | ||||
| 
 | ||||
|         $this->entity = $invitation->{$entity_type}; | ||||
| 
 | ||||
|         $this->entity_type = $entity_type; | ||||
| 
 | ||||
|         $this->settings = $invitation->contact->client->getMergedSettings(); | ||||
|      | ||||
|         $this->template = $template; | ||||
|     } | ||||
| 
 | ||||
|     /** | ||||
|      * Execute the job. | ||||
|      * | ||||
|      * @return void | ||||
|      */ | ||||
|     public function handle() | ||||
|     { | ||||
|         nlog("entity sent mailer"); | ||||
|          | ||||
|         /*If we are migrating data we don't want to fire these notification*/ | ||||
|         if ($this->company->is_disabled) { | ||||
|             return true; | ||||
|         } | ||||
|          | ||||
|         //Set DB
 | ||||
|         MultiDB::setDb($this->company->db); | ||||
| 
 | ||||
|         //if we need to set an email driver do it now
 | ||||
|         $this->setMailDriver(); | ||||
| 
 | ||||
|         $mail_obj = (new EntitySentObject($this->invitation, $this->entity_type, $this->template))->build(); | ||||
|         $mail_obj->from = [config('mail.from.address'), config('mail.from.name')]; | ||||
| 
 | ||||
|         try { | ||||
|             Mail::to($this->user->email) | ||||
|                 ->send(new EntityNotificationMailer($mail_obj)); | ||||
|         } catch (\Exception $e) { | ||||
|             $this->failed($e); | ||||
|             $this->logMailError($e->getMessage(), $this->entity->client); | ||||
|         } | ||||
|     } | ||||
| } | ||||
| @ -11,7 +11,6 @@ | ||||
| 
 | ||||
| namespace App\Jobs\Util; | ||||
| 
 | ||||
| use Illuminate\Http\UploadedFile; | ||||
| use App\DataMapper\Analytics\MigrationFailure; | ||||
| use App\DataMapper\CompanySettings; | ||||
| use App\Exceptions\MigrationValidatorFailed; | ||||
| @ -37,6 +36,7 @@ use App\Libraries\MultiDB; | ||||
| use App\Mail\MigrationCompleted; | ||||
| use App\Models\Activity; | ||||
| use App\Models\Client; | ||||
| use App\Models\ClientContact; | ||||
| use App\Models\ClientGatewayToken; | ||||
| use App\Models\Company; | ||||
| use App\Models\CompanyGateway; | ||||
| @ -76,6 +76,7 @@ use Exception; | ||||
| use Illuminate\Bus\Queueable; | ||||
| use Illuminate\Contracts\Queue\ShouldQueue; | ||||
| use Illuminate\Foundation\Bus\Dispatchable; | ||||
| use Illuminate\Http\UploadedFile; | ||||
| use Illuminate\Queue\InteractsWithQueue; | ||||
| use Illuminate\Queue\SerializesModels; | ||||
| use Illuminate\Support\Facades\Mail; | ||||
| @ -470,17 +471,22 @@ class Import implements ShouldQueue | ||||
|                 $contact_repository->save($saveable_contacts, $client); | ||||
| 
 | ||||
|                 //link contact ids
 | ||||
|                 $client->fresh(); | ||||
|                 $new_contacts = $client->contacts; | ||||
| 
 | ||||
|                 foreach ($resource['contacts'] as $key => $old_contact) { | ||||
|                     $contact_match = $new_contacts->where('contact_key', $old_contact['contact_key'])->first(); | ||||
|                      | ||||
|                     $contact_match = ClientContact::where('contact_key', $old_contact['contact_key']) | ||||
|                                                  ->where('company_id', $this->company->id) | ||||
|                                                  ->where('client_id', $client->id) | ||||
|                                                  ->withTrashed() | ||||
|                                                  ->first(); | ||||
| 
 | ||||
|                     if ($contact_match) { | ||||
|                          | ||||
|                         $this->ids['client_contacts']['client_contacts_'.$old_contact['id']] = [ | ||||
|                             'old' => $old_contact['id'], | ||||
|                             'new' => $contact_match->id, | ||||
|                         ]; | ||||
|                          | ||||
|                     } | ||||
|                 } | ||||
|             } | ||||
| @ -875,7 +881,7 @@ class Import implements ShouldQueue | ||||
|                 PaymentFactory::create($this->company->id, $modified['user_id']) | ||||
|             ); | ||||
| 
 | ||||
|             if ($resource['company_gateway_id'] != 'NULL' && $resource['company_gateway_id'] != null) { | ||||
|             if (array_key_exists('company_gateway_id', $resource) && isset($resource['company_gateway_id']) && $resource['company_gateway_id'] != 'NULL') { | ||||
|                 $payment->company_gateway_id = $this->transformId('company_gateways', $resource['company_gateway_id']); | ||||
|                 $payment->save(); | ||||
|             } | ||||
|  | ||||
							
								
								
									
										63
									
								
								app/Listeners/Invoice/InvoiceFailedEmailNotification.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										63
									
								
								app/Listeners/Invoice/InvoiceFailedEmailNotification.php
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,63 @@ | ||||
| <?php | ||||
| /** | ||||
|  * Invoice Ninja (https://invoiceninja.com). | ||||
|  * | ||||
|  * @link https://github.com/invoiceninja/invoiceninja source repository | ||||
|  * | ||||
|  * @copyright Copyright (c) 2021. Invoice Ninja LLC (https://invoiceninja.com) | ||||
|  * | ||||
|  * @license https://opensource.org/licenses/AAL | ||||
|  */ | ||||
| 
 | ||||
| namespace App\Listeners\Invoice; | ||||
| 
 | ||||
| use App\Jobs\Mail\EntitySentMailer; | ||||
| use App\Libraries\MultiDB; | ||||
| use App\Notifications\Admin\EntitySentNotification; | ||||
| use App\Utils\Traits\Notifications\UserNotifies; | ||||
| use Illuminate\Contracts\Queue\ShouldQueue; | ||||
| 
 | ||||
| class InvoiceFailedEmailNotification implements ShouldQueue | ||||
| { | ||||
|     use UserNotifies; | ||||
| 
 | ||||
|     public function __construct() | ||||
|     { | ||||
|     } | ||||
| 
 | ||||
|     /** | ||||
|      * Handle the event. | ||||
|      * | ||||
|      * @param  object  $event | ||||
|      * @return void | ||||
|      */ | ||||
|     public function handle($event) | ||||
|     { | ||||
|         MultiDB::setDb($event->company->db); | ||||
| 
 | ||||
|         $first_notification_sent = true; | ||||
| 
 | ||||
|         $invoice = $event->invitation->invoice; | ||||
|         $invoice->last_sent_date = now(); | ||||
|         $invoice->save(); | ||||
| 
 | ||||
|         foreach ($event->invitation->company->company_users as $company_user) { | ||||
|             $user = $company_user->user; | ||||
| 
 | ||||
|             $notification = new EntitySentNotification($event->invitation, 'invoice'); | ||||
| 
 | ||||
|             $methods = $this->findUserNotificationTypes($event->invitation, $company_user, 'invoice', ['all_notifications', 'invoice_sent']); | ||||
| 
 | ||||
|             if (($key = array_search('mail', $methods)) !== false && $first_notification_sent === true) { | ||||
|                 unset($methods[$key]); | ||||
| 
 | ||||
|                 EntitySentMailer::dispatch($event->invitation, 'invoice', $user, $event->invitation->company, $event->template); | ||||
|                 $first_notification_sent = false; | ||||
|             } | ||||
| 
 | ||||
|             $notification->method = $methods; | ||||
| 
 | ||||
|             $user->notify($notification); | ||||
|         } | ||||
|     } | ||||
| } | ||||
							
								
								
									
										140
									
								
								app/Mail/Admin/EntityFailedSendObject.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										140
									
								
								app/Mail/Admin/EntityFailedSendObject.php
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,140 @@ | ||||
| <?php | ||||
| /** | ||||
|  * Invoice Ninja (https://invoiceninja.com). | ||||
|  * | ||||
|  * @link https://github.com/invoiceninja/invoiceninja source repository | ||||
|  * | ||||
|  * @copyright Copyright (c) 2021. Invoice Ninja LLC (https://invoiceninja.com) | ||||
|  * | ||||
|  * @license https://opensource.org/licenses/AAL | ||||
|  */ | ||||
| 
 | ||||
| namespace App\Mail\Admin; | ||||
| 
 | ||||
| use App\Utils\Number; | ||||
| use stdClass; | ||||
| 
 | ||||
| class EntityFailedSendObject | ||||
| { | ||||
|     public $invitation; | ||||
| 
 | ||||
|     public $entity_type; | ||||
| 
 | ||||
|     public $entity; | ||||
| 
 | ||||
|     public $contact; | ||||
| 
 | ||||
|     public $company; | ||||
| 
 | ||||
|     public $settings; | ||||
| 
 | ||||
|     public $template; | ||||
| 
 | ||||
|     private $template_subject; | ||||
| 
 | ||||
|     private $template_body; | ||||
| 
 | ||||
|     public function __construct($invitation, $entity_type, $template) | ||||
|     { | ||||
|         $this->invitation = $invitation; | ||||
|         $this->entity_type = $entity_type; | ||||
|         $this->entity = $invitation->{$entity_type}; | ||||
|         $this->contact = $invitation->contact; | ||||
|         $this->company = $invitation->company; | ||||
|         $this->template = $template; | ||||
|     } | ||||
| 
 | ||||
|     public function build() | ||||
|     { | ||||
|         $this->setTemplate(); | ||||
| 
 | ||||
|         $mail_obj = new stdClass; | ||||
|         $mail_obj->amount = $this->getAmount(); | ||||
|         $mail_obj->subject = $this->getSubject(); | ||||
|         $mail_obj->data = $this->getData(); | ||||
|         $mail_obj->markdown = 'email.admin.generic'; | ||||
|         $mail_obj->tag = $this->company->company_key; | ||||
| 
 | ||||
|         return $mail_obj; | ||||
|     } | ||||
| 
 | ||||
|     private function setTemplate() | ||||
|     { | ||||
|         // nlog($this->template);
 | ||||
| 
 | ||||
|         switch ($this->template) { | ||||
|             case 'invoice': | ||||
|                 $this->template_subject = "texts.notification_invoice_bounced_subject"; | ||||
|                 $this->template_body = "texts.notification_invoice_bounced"; | ||||
|                 break; | ||||
|             case 'reminder1': | ||||
|                 $this->template_subject = "texts.notification_invoice_reminder1_sent_subject"; | ||||
|                 $this->template_body = "texts.notification_invoice_sent"; | ||||
|                 break; | ||||
|             case 'reminder2': | ||||
|                 $this->template_subject = "texts.notification_invoice_reminder2_sent_subject"; | ||||
|                 $this->template_body = "texts.notification_invoice_sent"; | ||||
|                 break; | ||||
|             case 'reminder3': | ||||
|                 $this->template_subject = "texts.notification_invoice_reminder3_sent_subject"; | ||||
|                 $this->template_body = "texts.notification_invoice_sent"; | ||||
|                 break; | ||||
|             case 'reminder_endless': | ||||
|                 $this->template_subject = "texts.notification_invoice_reminder_endless_sent_subject"; | ||||
|                 $this->template_body = "texts.notification_invoice_sent"; | ||||
|                 break; | ||||
|             case 'quote': | ||||
|                 $this->template_subject = "texts.notification_quote_bounced_subject"; | ||||
|                 $this->template_body = "texts.notification_quote_sent"; | ||||
|                 break; | ||||
|             case 'credit': | ||||
|                 $this->template_subject = "texts.notification_credit_bounced_subject"; | ||||
|                 $this->template_body = "texts.notification_credit_bounced"; | ||||
|                 break; | ||||
|             default: | ||||
|                 $this->template_subject = "texts.notification_invoice_sent_subject"; | ||||
|                 $this->template_body = "texts.notification_invoice_sent"; | ||||
|                 break; | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
|     private function getAmount() | ||||
|     { | ||||
|         return Number::formatMoney($this->entity->amount, $this->entity->client); | ||||
|     } | ||||
| 
 | ||||
|     private function getSubject() | ||||
|     { | ||||
|         return | ||||
|             ctrans( | ||||
|                 $this->template_subject, | ||||
|                 [ | ||||
|                         'client' => $this->contact->present()->name(), | ||||
|                         'invoice' => $this->entity->number, | ||||
|                     ] | ||||
|             ); | ||||
|     } | ||||
| 
 | ||||
|     private function getData() | ||||
|     { | ||||
|         $settings = $this->entity->client->getMergedSettings(); | ||||
| 
 | ||||
|         return [ | ||||
|             'title' => $this->getSubject(), | ||||
|             'message' => ctrans( | ||||
|                 $this->template_body, | ||||
|                 [ | ||||
|                     'amount' => $this->getAmount(), | ||||
|                     'client' => $this->contact->present()->name(), | ||||
|                     'invoice' => $this->entity->number, | ||||
|                 ] | ||||
|             ), | ||||
|             'url' => $this->invitation->getAdminLink(), | ||||
|             'button' => ctrans("texts.view_{$this->entity_type}"), | ||||
|             'signature' => $settings->email_signature, | ||||
|             'logo' => $this->company->present()->logo(), | ||||
|             'settings' => $settings, | ||||
|             'whitelabel' => $this->company->account->isPaid() ? true : false, | ||||
|         ]; | ||||
|     } | ||||
| } | ||||
| @ -14,7 +14,7 @@ namespace App\Mail\Admin; | ||||
| use App\Utils\Number; | ||||
| use stdClass; | ||||
| 
 | ||||
| class EntitySentObject | ||||
| class EntityFailedSendObject | ||||
| { | ||||
|     public $invitation; | ||||
| 
 | ||||
| @ -91,7 +91,6 @@ class EntitySentObject | ||||
|                 $this->template_subject = "texts.notification_credit_sent_subject"; | ||||
|                 $this->template_body = "texts.notification_credit_sent"; | ||||
|                 break; | ||||
| 
 | ||||
|             default: | ||||
|                 $this->template_subject = "texts.notification_invoice_sent_subject"; | ||||
|                 $this->template_body = "texts.notification_invoice_sent"; | ||||
|  | ||||
| @ -73,6 +73,7 @@ class Client extends BaseModel implements HasLocalePreference | ||||
|         'id_number', | ||||
|         'group_settings_id', | ||||
|         'public_notes', | ||||
|         'phone' | ||||
|     ]; | ||||
| 
 | ||||
|     protected $with = [ | ||||
|  | ||||
| @ -120,6 +120,12 @@ class ActivityRepository extends BaseRepository | ||||
|         $entity_design_id = $entity->design_id ? $entity->design_id : $this->decodePrimaryKey($entity->client->getSetting($entity_design_id)); | ||||
| 
 | ||||
|         $design = Design::find($entity_design_id); | ||||
| 
 | ||||
|         if(!$entity->invitations()->exists()){ | ||||
|             nlog("No invitations for entity {$entity->id} - {$entity->number}"); | ||||
|             return; | ||||
|         } | ||||
| 
 | ||||
|         $html = new HtmlEngine($entity->invitations->first()); | ||||
| 
 | ||||
|         if ($design->is_custom) { | ||||
|  | ||||
| @ -40,8 +40,8 @@ class ConvertQuote | ||||
|         $invoice->fresh(); | ||||
| 
 | ||||
|         $invoice->service() | ||||
|                 ->markSent() | ||||
|                 ->createInvitations() | ||||
|                 // ->markSent()
 | ||||
|                 // ->createInvitations()
 | ||||
|                 ->save(); | ||||
| 
 | ||||
|         $quote->invoice_id = $invoice->id; | ||||
|  | ||||
| @ -38,17 +38,20 @@ class QuoteService | ||||
|         return $this; | ||||
|     } | ||||
| 
 | ||||
|     public function markApproved() | ||||
|     { | ||||
|         $mark_approved = new MarkApproved($this->quote->client); | ||||
|         $this->quote = $mark_approved->run($this->quote); | ||||
|     // public function markApproved()
 | ||||
|     // {
 | ||||
|     //     $mark_approved = new MarkApproved($this->quote->client);
 | ||||
|     //     $this->quote = $mark_approved->run($this->quote);
 | ||||
| 
 | ||||
|         if ($this->quote->client->getSetting('auto_convert_quote') === true) { | ||||
|             $this->convert(); | ||||
|         } | ||||
|     //     if ($this->quote->client->getSetting('auto_convert_quote') == true) {
 | ||||
|     //         $this->convert();
 | ||||
|     //     }
 | ||||
| 
 | ||||
|         return $this; | ||||
|     } | ||||
|     //     $this->markSent()
 | ||||
|     //          ->createInvitations();
 | ||||
| 
 | ||||
|     //     return $this;
 | ||||
|     // }
 | ||||
| 
 | ||||
|     public function convert() :self | ||||
|     { | ||||
| @ -116,12 +119,18 @@ class QuoteService | ||||
| 
 | ||||
|         event(new QuoteWasApproved($contact, $this->quote, $this->quote->company, Ninja::eventVars())); | ||||
| 
 | ||||
|         $invoice = null; | ||||
| 
 | ||||
|         if ($this->quote->client->getSetting('auto_convert_quote')) { | ||||
|             $this->convert(); | ||||
| 
 | ||||
|             $this->invoice | ||||
|                  ->service() | ||||
|                  ->markSent() | ||||
|                  ->createInvitations() | ||||
|                  ->save(); | ||||
| 
 | ||||
|         } | ||||
| 
 | ||||
| 
 | ||||
|         if ($this->quote->client->getSetting('auto_archive_quote')) { | ||||
|             $quote_repo = new QuoteRepository(); | ||||
|             $quote_repo->archive($this->quote); | ||||
| @ -134,11 +143,13 @@ class QuoteService | ||||
|     { | ||||
| 
 | ||||
|         //to prevent circular references we need to explicit call this here.
 | ||||
|         $mark_approved = new MarkApproved($this->quote->client); | ||||
|         $this->quote = $mark_approved->run($this->quote); | ||||
|         // $mark_approved = new MarkApproved($this->quote->client);
 | ||||
|         // $this->quote = $mark_approved->run($this->quote);
 | ||||
| 
 | ||||
|         $this->convert(); | ||||
| 
 | ||||
|         $this->invoice->service()->createInvitations(); | ||||
| 
 | ||||
|         return $this->invoice; | ||||
|     } | ||||
| 
 | ||||
|  | ||||
| @ -11,7 +11,9 @@ | ||||
| 
 | ||||
| namespace App\Transformers; | ||||
| 
 | ||||
| use App\Models\Document; | ||||
| use App\Models\GroupSetting; | ||||
| use App\Transformers\DocumentTransformer; | ||||
| use App\Utils\Traits\MakesHash; | ||||
| use stdClass; | ||||
| 
 | ||||
| @ -23,6 +25,7 @@ class GroupSettingTransformer extends EntityTransformer | ||||
|     use MakesHash; | ||||
| 
 | ||||
|     protected $defaultIncludes = [ | ||||
|         'documents' | ||||
|     ]; | ||||
| 
 | ||||
|     /** | ||||
| @ -47,4 +50,12 @@ class GroupSettingTransformer extends EntityTransformer | ||||
|             'is_deleted' => (bool) $group_setting->is_deleted, | ||||
|         ]; | ||||
|     } | ||||
| 
 | ||||
|     public function includeDocuments(GroupSetting $group_setting) | ||||
|     { | ||||
|         $transformer = new DocumentTransformer($this->serializer); | ||||
| 
 | ||||
|         return $this->includeCollection($group_setting->documents, $transformer, Document::class); | ||||
|     } | ||||
| 
 | ||||
| } | ||||
|  | ||||
| @ -13,7 +13,7 @@ return [ | ||||
|     'require_https' => env('REQUIRE_HTTPS', true), | ||||
|     'app_url' => rtrim(env('APP_URL', ''), '/'), | ||||
|     'app_domain' => env('APP_DOMAIN', ''), | ||||
|     'app_version' => '5.0.49', | ||||
|     'app_version' => '5.0.50', | ||||
|     'minimum_client_version' => '5.0.16', | ||||
|     'terms_version' => '1.0.1', | ||||
|     'api_secret' => env('API_SECRET', false), | ||||
|  | ||||
| @ -3372,4 +3372,6 @@ return [ | ||||
|     'required_payment_information_more' => 'To complete a payment we need more details about you.', | ||||
| 
 | ||||
|     'required_client_info_save_label' => 'We will save this, so you don\'t have to enter it next time.', | ||||
|     'notification_credit_bounced' => 'We were unable to deliver Credit :invoice to :contact.', | ||||
|     'notification_credit_bounced_subject' => 'Unable to deliver Credit :invoice', | ||||
| ]; | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user