2017-04-21 01:41:43 +03:00
|
|
|
<?php
|
2019-06-07 02:16:13 +03:00
|
|
|
declare(strict_types=1);
|
|
|
|
|
2017-04-24 19:22:24 +03:00
|
|
|
namespace common\emails;
|
2017-04-21 01:41:43 +03:00
|
|
|
|
2019-06-07 02:16:13 +03:00
|
|
|
use Exception;
|
2019-06-16 23:59:19 +03:00
|
|
|
use yii\mail\MailerInterface;
|
2017-04-21 01:41:43 +03:00
|
|
|
use yii\mail\MessageInterface;
|
|
|
|
|
|
|
|
abstract class TemplateWithRenderer extends Template {
|
|
|
|
|
|
|
|
/**
|
2019-06-07 02:16:13 +03:00
|
|
|
* @var RendererInterface
|
2017-04-21 01:41:43 +03:00
|
|
|
*/
|
2019-06-07 02:16:13 +03:00
|
|
|
private $renderer;
|
2017-04-21 01:41:43 +03:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @var string
|
|
|
|
*/
|
2019-06-16 23:59:19 +03:00
|
|
|
private $locale = 'en';
|
2017-04-21 01:41:43 +03:00
|
|
|
|
2019-06-16 23:59:19 +03:00
|
|
|
public function __construct(MailerInterface $mailer, RendererInterface $renderer) {
|
|
|
|
parent::__construct($mailer);
|
2019-06-07 02:16:13 +03:00
|
|
|
$this->renderer = $renderer;
|
2017-04-21 01:41:43 +03:00
|
|
|
}
|
|
|
|
|
2019-06-16 23:59:19 +03:00
|
|
|
public function setLocale(string $locale): void {
|
|
|
|
$this->locale = $locale;
|
2017-04-21 01:41:43 +03:00
|
|
|
}
|
|
|
|
|
2019-06-16 23:59:19 +03:00
|
|
|
public function getLocale(): string {
|
|
|
|
return $this->locale;
|
2017-04-21 01:41:43 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2019-06-16 23:59:19 +03:00
|
|
|
* This method should return the template's name, which will be rendered.
|
|
|
|
* List of available templates names can be found at https://github.com/elyby/emails-renderer
|
2017-04-21 01:41:43 +03:00
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
*/
|
2017-04-25 02:09:59 +03:00
|
|
|
abstract public function getTemplateName(): string;
|
2017-04-21 01:41:43 +03:00
|
|
|
|
2019-06-16 23:59:19 +03:00
|
|
|
final protected function getRenderer(): RendererInterface {
|
|
|
|
return $this->renderer;
|
|
|
|
}
|
|
|
|
|
2018-04-17 23:47:25 +03:00
|
|
|
final protected function getView() {
|
2017-04-21 01:41:43 +03:00
|
|
|
return $this->getTemplateName();
|
|
|
|
}
|
|
|
|
|
2019-06-07 02:16:13 +03:00
|
|
|
/**
|
2019-06-16 23:59:19 +03:00
|
|
|
* @param string|array $for
|
|
|
|
*
|
2019-06-07 02:16:13 +03:00
|
|
|
* @return MessageInterface
|
2019-06-16 23:59:19 +03:00
|
|
|
* @throws \common\emails\exceptions\CannotRenderEmailException
|
2019-06-07 02:16:13 +03:00
|
|
|
*/
|
2019-06-16 23:59:19 +03:00
|
|
|
protected function createMessage($for): MessageInterface {
|
2017-04-21 01:41:43 +03:00
|
|
|
return $this->getMailer()
|
|
|
|
->compose()
|
|
|
|
->setHtmlBody($this->render())
|
2019-06-16 23:59:19 +03:00
|
|
|
->setTo($for)
|
2017-04-21 01:41:43 +03:00
|
|
|
->setFrom($this->getFrom())
|
|
|
|
->setSubject($this->getSubject());
|
|
|
|
}
|
|
|
|
|
2019-06-07 02:16:13 +03:00
|
|
|
/**
|
|
|
|
* @return string
|
2019-06-16 23:59:19 +03:00
|
|
|
* @throws \common\emails\exceptions\CannotRenderEmailException
|
2019-06-07 02:16:13 +03:00
|
|
|
*/
|
2017-04-21 01:41:43 +03:00
|
|
|
private function render(): string {
|
2019-06-07 02:16:13 +03:00
|
|
|
try {
|
|
|
|
return $this->getRenderer()->render($this->getTemplateName(), $this->getLocale(), $this->getParams());
|
|
|
|
} catch (Exception $e) {
|
2019-06-16 23:59:19 +03:00
|
|
|
throw new exceptions\CannotRenderEmailException($e);
|
2019-06-07 02:16:13 +03:00
|
|
|
}
|
2017-04-21 01:41:43 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
}
|