client; if(!$reminder_template) $reminder_template = $this->calculateTemplate(); //Need to determine which email template we are producing return $this->generateTemplateData($reminder_template, $contact); } private function generateTemplateData(string $reminder_template, $contact) :array { $data = []; $client = $this->client; $body_template = $client->getSetting('email_template_'.$reminder_template); /* Use default translations if a custom message has not been set*/ if(iconv_strlen($body_template) == 0){ $body_template = trans('texts.invoice_message', ['amount'=>$this->present()->amount(),'account'=>$this->company->present()->name()], null, $this->client->locale()); } $subject_template = $client->getSetting('email_subject_'.$reminder_template); if(iconv_strlen($subject_template) == 0){ if($reminder_template == 'invoice') $subject_template = trans('texts.invoice_subject', ['number'=>$this->present()->invoice_number(),'account'=>$this->company->present()->name()], null, $this->client->locale()); else $subject_template = trans('texts.reminder_subject', ['number'=>$this->present()->invoice_number(),'account'=>$this->company->present()->name()], null, $this->client->locale()); } $data['body'] = $this->parseTemplate($body_template, false, $contact); $data['subject'] = $this->parseTemplate($subject_template, true, $contact); if($client->getSetting('pdf_email_attachment') !== false) $data['files'][] = $this->pdf_file_path(); return $data; } private function parseTemplate(string $template_data, bool $is_markdown = true, $contact) :string { $invoice_variables = $this->makeValues($contact); //process variables $data = str_replace(array_keys($invoice_variables), array_values($invoice_variables), $template_data); //process markdown if($is_markdown) $data = Parsedown::instance()->line($data); return $data; } private function calculateTemplate() :string { //if invoice is currently a draft, or being marked as sent, this will be the initial email $client = $this->client; //if the invoice if($this->status_id == Invoice::STATUS_DRAFT || Carbon::parse($this->due_date) > now()) { return 'invoice'; } else if($client->getSetting('enable_reminder1') !== false && $this->inReminderWindow($client->getSetting('schedule_reminder1'), $client->getSetting('num_days_reminder1'))) { return 'template1'; } else if($client->getSetting('enable_reminder2') !== false && $this->inReminderWindow($client->getSetting('schedule_reminder2'), $client->getSetting('num_days_reminder2'))) { return 'template2'; } else if($client->getSetting('enable_reminder3') !== false && $this->inReminderWindow($client->getSetting('schedule_reminder3'), $client->getSetting('num_days_reminder3'))) { return 'template3'; } else return 'invoice'; //also implement endless reminders here } private function inReminderWindow($schedule_reminder, $num_days_reminder) { switch ($schedule_reminder) { case 'after_invoice_date': return Carbon::parse($this->date)->addDays($num_days_reminder)->startOfDay()->eq(Carbon::now()->startOfDay()); break; case 'before_due_date': return Carbon::parse($this->due_date)->subDays($num_days_reminder)->startOfDay()->eq(Carbon::now()->startOfDay()); break; case 'after_due_date': return Carbon::parse($this->due_date)->addDays($num_days_reminder)->startOfDay()->eq(Carbon::now()->startOfDay()); break; default: # code... break; } } }