mirror of
https://github.com/crater-invoice/crater.git
synced 2025-10-27 11:41:09 -04:00
Send Invoices/Estimates/Payments as email attachments
This commit is contained in:
@ -13,15 +13,17 @@ class SendEstimateMail extends Mailable
|
||||
use Queueable, SerializesModels;
|
||||
|
||||
public $data = [];
|
||||
public $pdfData;
|
||||
|
||||
/**
|
||||
* Create a new message instance.
|
||||
*
|
||||
* @return void
|
||||
*/
|
||||
public function __construct($data)
|
||||
public function __construct($data, $pdfData)
|
||||
{
|
||||
$this->data = $data;
|
||||
$this->pdfData = $pdfData;
|
||||
}
|
||||
|
||||
/**
|
||||
@ -40,9 +42,17 @@ class SendEstimateMail extends Mailable
|
||||
'mailable_id' => $this->data['estimate']['id']
|
||||
]);
|
||||
|
||||
return $this->from($this->data['from'])
|
||||
->subject($this->data['subject'])
|
||||
->markdown('emails.send.estimate', ['data', $this->data]);
|
||||
$mailContent = $this->from($this->data['from'])
|
||||
->subject($this->data['subject'])
|
||||
->markdown('emails.send.estimate', ['data', $this->data]);
|
||||
|
||||
if ($this->pdfData) {
|
||||
$mailContent->attachData(
|
||||
$this->pdfData->output(),
|
||||
$this->data['estimate']['estimate_number'] . '.pdf'
|
||||
);
|
||||
}
|
||||
|
||||
return $mailContent;
|
||||
}
|
||||
}
|
||||
|
||||
@ -13,15 +13,17 @@ class SendInvoiceMail extends Mailable
|
||||
use Queueable, SerializesModels;
|
||||
|
||||
public $data = [];
|
||||
public $pdfData;
|
||||
|
||||
/**
|
||||
* Create a new message instance.
|
||||
*
|
||||
* @return void
|
||||
*/
|
||||
public function __construct($data)
|
||||
public function __construct($data, $pdfData)
|
||||
{
|
||||
$this->data = $data;
|
||||
$this->pdfData = $pdfData;
|
||||
}
|
||||
|
||||
/**
|
||||
@ -39,9 +41,18 @@ class SendInvoiceMail extends Mailable
|
||||
'mailable_type' => Invoice::class,
|
||||
'mailable_id' => $this->data['invoice']['id']
|
||||
]);
|
||||
|
||||
$mailContent = $this->from($this->data['from'])
|
||||
->subject($this->data['subject'])
|
||||
->markdown('emails.send.invoice', ['data', $this->data]);
|
||||
|
||||
return $this->from($this->data['from'])
|
||||
->subject($this->data['subject'])
|
||||
->markdown('emails.send.invoice', ['data', $this->data]);
|
||||
if ($this->pdfData) {
|
||||
$mailContent->attachData(
|
||||
$this->pdfData->output(),
|
||||
$this->data['invoice']['invoice_number'] . '.pdf'
|
||||
);
|
||||
}
|
||||
|
||||
return $mailContent;
|
||||
}
|
||||
}
|
||||
|
||||
@ -14,15 +14,17 @@ class SendPaymentMail extends Mailable
|
||||
use Queueable, SerializesModels;
|
||||
|
||||
public $data = [];
|
||||
public $pdfData;
|
||||
|
||||
/**
|
||||
* Create a new message instance.
|
||||
*
|
||||
* @return void
|
||||
*/
|
||||
public function __construct($data)
|
||||
public function __construct($data, $pdfData)
|
||||
{
|
||||
$this->data = $data;
|
||||
$this->pdfData = $pdfData;
|
||||
}
|
||||
|
||||
/**
|
||||
@ -41,9 +43,17 @@ class SendPaymentMail extends Mailable
|
||||
'mailable_id' => $this->data['payment']['id']
|
||||
]);
|
||||
|
||||
return $this->from($this->data['from'])
|
||||
->subject($this->data['subject'])
|
||||
->markdown('emails.send.payment', ['data', $this->data]);
|
||||
|
||||
$mailContent = $this->from($this->data['from'])
|
||||
->subject($this->data['subject'])
|
||||
->markdown('emails.send.payment', ['data', $this->data]);
|
||||
|
||||
if ($this->pdfData) {
|
||||
$mailContent->attachData(
|
||||
$this->pdfData->output(),
|
||||
$this->data['payment']['payment_number'] . '.pdf'
|
||||
);
|
||||
}
|
||||
|
||||
return $mailContent;
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user