mirror of
				https://github.com/invoiceninja/invoiceninja.git
				synced 2025-10-26 15: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 optimize | ||||||
|           php artisan storage:link |           php artisan storage:link | ||||||
|           sudo php artisan cache:clear |           sudo php artisan cache:clear | ||||||
|           sudo find ./ -type f -exec chmod 644 {} \; |  | ||||||
|           sudo find ./vendor/bin/ -type f -exec chmod +x {} \; |           sudo find ./vendor/bin/ -type f -exec chmod +x {} \; | ||||||
|           sudo find ./ -type d -exec chmod 755 {} \; |           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->due_date = null; | ||||||
|         $clone_credit->partial_due_date = null; |         $clone_credit->partial_due_date = null; | ||||||
|         $clone_credit->user_id = $user_id; |         $clone_credit->user_id = $user_id; | ||||||
|         $clone_credit->balance = $credit->amount; |         //$clone_credit->balance = $credit->amount;
 | ||||||
|         $clone_credit->line_items = $credit->line_items; |         $clone_credit->line_items = $credit->line_items; | ||||||
| 
 | 
 | ||||||
|         return $clone_credit; |         return $clone_credit; | ||||||
|  | |||||||
| @ -39,7 +39,7 @@ class CloneCreditToQuoteFactory | |||||||
|         $quote->custom_value3 = $credit->custom_value3; |         $quote->custom_value3 = $credit->custom_value3; | ||||||
|         $quote->custom_value4 = $credit->custom_value4; |         $quote->custom_value4 = $credit->custom_value4; | ||||||
|         $quote->amount = $credit->amount; |         $quote->amount = $credit->amount; | ||||||
|         $quote->balance = $credit->balance; |         //$quote->balance = $credit->balance;
 | ||||||
|         $quote->partial = $credit->partial; |         $quote->partial = $credit->partial; | ||||||
|         $quote->partial_due_date = $credit->partial_due_date; |         $quote->partial_due_date = $credit->partial_due_date; | ||||||
|         $quote->last_viewed = $credit->last_viewed; |         $quote->last_viewed = $credit->last_viewed; | ||||||
| @ -49,7 +49,7 @@ class CloneCreditToQuoteFactory | |||||||
|         $quote->date = null; |         $quote->date = null; | ||||||
|         $quote->due_date = null; |         $quote->due_date = null; | ||||||
|         $quote->partial_due_date = null; |         $quote->partial_due_date = null; | ||||||
|         $quote->balance = $credit->amount; |         // $quote->balance = $credit->amount;
 | ||||||
|         $quote->line_items = $credit->line_items; |         $quote->line_items = $credit->line_items; | ||||||
| 
 | 
 | ||||||
|         return $quote; |         return $quote; | ||||||
|  | |||||||
| @ -24,7 +24,7 @@ class CloneInvoiceFactory | |||||||
|         $clone_invoice->due_date = null; |         $clone_invoice->due_date = null; | ||||||
|         $clone_invoice->partial_due_date = null; |         $clone_invoice->partial_due_date = null; | ||||||
|         $clone_invoice->user_id = $user_id; |         $clone_invoice->user_id = $user_id; | ||||||
|         $clone_invoice->balance = $invoice->amount; |         //$clone_invoice->balance = $invoice->amount;
 | ||||||
|         $clone_invoice->amount = $invoice->amount; |         $clone_invoice->amount = $invoice->amount; | ||||||
|         $clone_invoice->line_items = $invoice->line_items; |         $clone_invoice->line_items = $invoice->line_items; | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -38,7 +38,7 @@ class CloneInvoiceToQuoteFactory | |||||||
|         $quote->custom_value3 = $invoice->custom_value3; |         $quote->custom_value3 = $invoice->custom_value3; | ||||||
|         $quote->custom_value4 = $invoice->custom_value4; |         $quote->custom_value4 = $invoice->custom_value4; | ||||||
|         $quote->amount = $invoice->amount; |         $quote->amount = $invoice->amount; | ||||||
|         $quote->balance = $invoice->amount; |         //$quote->balance = $invoice->amount;
 | ||||||
|         $quote->partial = $invoice->partial; |         $quote->partial = $invoice->partial; | ||||||
|         $quote->partial_due_date = $invoice->partial_due_date; |         $quote->partial_due_date = $invoice->partial_due_date; | ||||||
|         $quote->last_viewed = $invoice->last_viewed; |         $quote->last_viewed = $invoice->last_viewed; | ||||||
|  | |||||||
| @ -24,7 +24,7 @@ class CloneQuoteFactory | |||||||
|         $clone_quote->due_date = null; |         $clone_quote->due_date = null; | ||||||
|         $clone_quote->partial_due_date = null; |         $clone_quote->partial_due_date = null; | ||||||
|         $clone_quote->user_id = $user_id; |         $clone_quote->user_id = $user_id; | ||||||
|         $clone_quote->balance = $quote->amount; |         //$clone_quote->balance = $quote->amount;
 | ||||||
|         $clone_quote->amount = $quote->amount; |         $clone_quote->amount = $quote->amount; | ||||||
|         $clone_quote->line_items = $quote->line_items; |         $clone_quote->line_items = $quote->line_items; | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -38,6 +38,7 @@ class CloneQuoteToInvoiceFactory | |||||||
|         $invoice->partial_due_date = null; |         $invoice->partial_due_date = null; | ||||||
|         $invoice->number = null; |         $invoice->number = null; | ||||||
|         $invoice->date = now()->format('Y-m-d'); |         $invoice->date = now()->format('Y-m-d'); | ||||||
|  |         $invoice->balance = 0; | ||||||
|         return $invoice; |         return $invoice; | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  | |||||||
| @ -42,7 +42,7 @@ class InvoiceToRecurringInvoiceFactory | |||||||
|         $recurring_invoice->custom_value3 = $invoice->custom_value3; |         $recurring_invoice->custom_value3 = $invoice->custom_value3; | ||||||
|         $recurring_invoice->custom_value4 = $invoice->custom_value4; |         $recurring_invoice->custom_value4 = $invoice->custom_value4; | ||||||
|         $recurring_invoice->amount = $invoice->amount; |         $recurring_invoice->amount = $invoice->amount; | ||||||
|         $recurring_invoice->balance = $invoice->balance; |         // $recurring_invoice->balance = $invoice->balance;
 | ||||||
|         $recurring_invoice->user_id = $invoice->user_id; |         $recurring_invoice->user_id = $invoice->user_id; | ||||||
|         $recurring_invoice->client_id = $invoice->client_id; |         $recurring_invoice->client_id = $invoice->client_id; | ||||||
|         $recurring_invoice->company_id = $invoice->company_id; |         $recurring_invoice->company_id = $invoice->company_id; | ||||||
|  | |||||||
| @ -75,7 +75,7 @@ class BaseController extends Controller | |||||||
|           'company.credits.invitations.company', |           'company.credits.invitations.company', | ||||||
|           'company.credits.documents', |           'company.credits.documents', | ||||||
|           'company.expenses.documents', |           'company.expenses.documents', | ||||||
|           'company.groups', |           'company.groups.documents', | ||||||
|           'company.invoices.invitations.contact', |           'company.invoices.invitations.contact', | ||||||
|           'company.invoices.invitations.company', |           'company.invoices.invitations.company', | ||||||
|           'company.invoices.documents', |           '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; | namespace App\Jobs\Util; | ||||||
| 
 | 
 | ||||||
| use Illuminate\Http\UploadedFile; |  | ||||||
| use App\DataMapper\Analytics\MigrationFailure; | use App\DataMapper\Analytics\MigrationFailure; | ||||||
| use App\DataMapper\CompanySettings; | use App\DataMapper\CompanySettings; | ||||||
| use App\Exceptions\MigrationValidatorFailed; | use App\Exceptions\MigrationValidatorFailed; | ||||||
| @ -37,6 +36,7 @@ use App\Libraries\MultiDB; | |||||||
| use App\Mail\MigrationCompleted; | use App\Mail\MigrationCompleted; | ||||||
| use App\Models\Activity; | use App\Models\Activity; | ||||||
| use App\Models\Client; | use App\Models\Client; | ||||||
|  | use App\Models\ClientContact; | ||||||
| use App\Models\ClientGatewayToken; | use App\Models\ClientGatewayToken; | ||||||
| use App\Models\Company; | use App\Models\Company; | ||||||
| use App\Models\CompanyGateway; | use App\Models\CompanyGateway; | ||||||
| @ -76,6 +76,7 @@ use Exception; | |||||||
| use Illuminate\Bus\Queueable; | use Illuminate\Bus\Queueable; | ||||||
| use Illuminate\Contracts\Queue\ShouldQueue; | use Illuminate\Contracts\Queue\ShouldQueue; | ||||||
| use Illuminate\Foundation\Bus\Dispatchable; | use Illuminate\Foundation\Bus\Dispatchable; | ||||||
|  | use Illuminate\Http\UploadedFile; | ||||||
| use Illuminate\Queue\InteractsWithQueue; | use Illuminate\Queue\InteractsWithQueue; | ||||||
| use Illuminate\Queue\SerializesModels; | use Illuminate\Queue\SerializesModels; | ||||||
| use Illuminate\Support\Facades\Mail; | use Illuminate\Support\Facades\Mail; | ||||||
| @ -470,17 +471,22 @@ class Import implements ShouldQueue | |||||||
|                 $contact_repository->save($saveable_contacts, $client); |                 $contact_repository->save($saveable_contacts, $client); | ||||||
| 
 | 
 | ||||||
|                 //link contact ids
 |                 //link contact ids
 | ||||||
|                 $client->fresh(); |  | ||||||
|                 $new_contacts = $client->contacts; |  | ||||||
| 
 | 
 | ||||||
|                 foreach ($resource['contacts'] as $key => $old_contact) { |                 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) { |                     if ($contact_match) { | ||||||
|  |                          | ||||||
|                         $this->ids['client_contacts']['client_contacts_'.$old_contact['id']] = [ |                         $this->ids['client_contacts']['client_contacts_'.$old_contact['id']] = [ | ||||||
|                             'old' => $old_contact['id'], |                             'old' => $old_contact['id'], | ||||||
|                             'new' => $contact_match->id, |                             'new' => $contact_match->id, | ||||||
|                         ]; |                         ]; | ||||||
|  |                          | ||||||
|                     } |                     } | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
| @ -875,7 +881,7 @@ class Import implements ShouldQueue | |||||||
|                 PaymentFactory::create($this->company->id, $modified['user_id']) |                 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->company_gateway_id = $this->transformId('company_gateways', $resource['company_gateway_id']); | ||||||
|                 $payment->save(); |                 $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 App\Utils\Number; | ||||||
| use stdClass; | use stdClass; | ||||||
| 
 | 
 | ||||||
| class EntitySentObject | class EntityFailedSendObject | ||||||
| { | { | ||||||
|     public $invitation; |     public $invitation; | ||||||
| 
 | 
 | ||||||
| @ -91,7 +91,6 @@ class EntitySentObject | |||||||
|                 $this->template_subject = "texts.notification_credit_sent_subject"; |                 $this->template_subject = "texts.notification_credit_sent_subject"; | ||||||
|                 $this->template_body = "texts.notification_credit_sent"; |                 $this->template_body = "texts.notification_credit_sent"; | ||||||
|                 break; |                 break; | ||||||
| 
 |  | ||||||
|             default: |             default: | ||||||
|                 $this->template_subject = "texts.notification_invoice_sent_subject"; |                 $this->template_subject = "texts.notification_invoice_sent_subject"; | ||||||
|                 $this->template_body = "texts.notification_invoice_sent"; |                 $this->template_body = "texts.notification_invoice_sent"; | ||||||
|  | |||||||
| @ -73,6 +73,7 @@ class Client extends BaseModel implements HasLocalePreference | |||||||
|         'id_number', |         'id_number', | ||||||
|         'group_settings_id', |         'group_settings_id', | ||||||
|         'public_notes', |         'public_notes', | ||||||
|  |         'phone' | ||||||
|     ]; |     ]; | ||||||
| 
 | 
 | ||||||
|     protected $with = [ |     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)); |         $entity_design_id = $entity->design_id ? $entity->design_id : $this->decodePrimaryKey($entity->client->getSetting($entity_design_id)); | ||||||
| 
 | 
 | ||||||
|         $design = Design::find($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()); |         $html = new HtmlEngine($entity->invitations->first()); | ||||||
| 
 | 
 | ||||||
|         if ($design->is_custom) { |         if ($design->is_custom) { | ||||||
|  | |||||||
| @ -40,8 +40,8 @@ class ConvertQuote | |||||||
|         $invoice->fresh(); |         $invoice->fresh(); | ||||||
| 
 | 
 | ||||||
|         $invoice->service() |         $invoice->service() | ||||||
|                 ->markSent() |                 // ->markSent()
 | ||||||
|                 ->createInvitations() |                 // ->createInvitations()
 | ||||||
|                 ->save(); |                 ->save(); | ||||||
| 
 | 
 | ||||||
|         $quote->invoice_id = $invoice->id; |         $quote->invoice_id = $invoice->id; | ||||||
|  | |||||||
| @ -38,17 +38,20 @@ class QuoteService | |||||||
|         return $this; |         return $this; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     public function markApproved() |     // public function markApproved()
 | ||||||
|     { |     // {
 | ||||||
|         $mark_approved = new MarkApproved($this->quote->client); |     //     $mark_approved = new MarkApproved($this->quote->client);
 | ||||||
|         $this->quote = $mark_approved->run($this->quote); |     //     $this->quote = $mark_approved->run($this->quote);
 | ||||||
| 
 | 
 | ||||||
|         if ($this->quote->client->getSetting('auto_convert_quote') === true) { |     //     if ($this->quote->client->getSetting('auto_convert_quote') == true) {
 | ||||||
|             $this->convert(); |     //         $this->convert();
 | ||||||
|         } |     //     }
 | ||||||
| 
 | 
 | ||||||
|         return $this; |     //     $this->markSent()
 | ||||||
|     } |     //          ->createInvitations();
 | ||||||
|  | 
 | ||||||
|  |     //     return $this;
 | ||||||
|  |     // }
 | ||||||
| 
 | 
 | ||||||
|     public function convert() :self |     public function convert() :self | ||||||
|     { |     { | ||||||
| @ -116,12 +119,18 @@ class QuoteService | |||||||
| 
 | 
 | ||||||
|         event(new QuoteWasApproved($contact, $this->quote, $this->quote->company, Ninja::eventVars())); |         event(new QuoteWasApproved($contact, $this->quote, $this->quote->company, Ninja::eventVars())); | ||||||
| 
 | 
 | ||||||
|         $invoice = null; |  | ||||||
| 
 |  | ||||||
|         if ($this->quote->client->getSetting('auto_convert_quote')) { |         if ($this->quote->client->getSetting('auto_convert_quote')) { | ||||||
|             $this->convert(); |             $this->convert(); | ||||||
|  | 
 | ||||||
|  |             $this->invoice | ||||||
|  |                  ->service() | ||||||
|  |                  ->markSent() | ||||||
|  |                  ->createInvitations() | ||||||
|  |                  ->save(); | ||||||
|  | 
 | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|  | 
 | ||||||
|         if ($this->quote->client->getSetting('auto_archive_quote')) { |         if ($this->quote->client->getSetting('auto_archive_quote')) { | ||||||
|             $quote_repo = new QuoteRepository(); |             $quote_repo = new QuoteRepository(); | ||||||
|             $quote_repo->archive($this->quote); |             $quote_repo->archive($this->quote); | ||||||
| @ -134,11 +143,13 @@ class QuoteService | |||||||
|     { |     { | ||||||
| 
 | 
 | ||||||
|         //to prevent circular references we need to explicit call this here.
 |         //to prevent circular references we need to explicit call this here.
 | ||||||
|         $mark_approved = new MarkApproved($this->quote->client); |         // $mark_approved = new MarkApproved($this->quote->client);
 | ||||||
|         $this->quote = $mark_approved->run($this->quote); |         // $this->quote = $mark_approved->run($this->quote);
 | ||||||
| 
 | 
 | ||||||
|         $this->convert(); |         $this->convert(); | ||||||
| 
 | 
 | ||||||
|  |         $this->invoice->service()->createInvitations(); | ||||||
|  | 
 | ||||||
|         return $this->invoice; |         return $this->invoice; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -11,7 +11,9 @@ | |||||||
| 
 | 
 | ||||||
| namespace App\Transformers; | namespace App\Transformers; | ||||||
| 
 | 
 | ||||||
|  | use App\Models\Document; | ||||||
| use App\Models\GroupSetting; | use App\Models\GroupSetting; | ||||||
|  | use App\Transformers\DocumentTransformer; | ||||||
| use App\Utils\Traits\MakesHash; | use App\Utils\Traits\MakesHash; | ||||||
| use stdClass; | use stdClass; | ||||||
| 
 | 
 | ||||||
| @ -23,6 +25,7 @@ class GroupSettingTransformer extends EntityTransformer | |||||||
|     use MakesHash; |     use MakesHash; | ||||||
| 
 | 
 | ||||||
|     protected $defaultIncludes = [ |     protected $defaultIncludes = [ | ||||||
|  |         'documents' | ||||||
|     ]; |     ]; | ||||||
| 
 | 
 | ||||||
|     /** |     /** | ||||||
| @ -47,4 +50,12 @@ class GroupSettingTransformer extends EntityTransformer | |||||||
|             'is_deleted' => (bool) $group_setting->is_deleted, |             '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), |     'require_https' => env('REQUIRE_HTTPS', true), | ||||||
|     'app_url' => rtrim(env('APP_URL', ''), '/'), |     'app_url' => rtrim(env('APP_URL', ''), '/'), | ||||||
|     'app_domain' => env('APP_DOMAIN', ''), |     'app_domain' => env('APP_DOMAIN', ''), | ||||||
|     'app_version' => '5.0.49', |     'app_version' => '5.0.50', | ||||||
|     'minimum_client_version' => '5.0.16', |     'minimum_client_version' => '5.0.16', | ||||||
|     'terms_version' => '1.0.1', |     'terms_version' => '1.0.1', | ||||||
|     'api_secret' => env('API_SECRET', false), |     '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_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.', |     '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