Skip to content
Snippets Groups Projects

Devel

Merged Piotr Potrebka requested to merge devel into main
Compare and Show latest version
4 files
+ 165
9
Compare changes
  • Side-by-side
  • Inline

Files

+ 154
4
@@ -2,20 +2,30 @@
namespace WPDesk\Library\WPEmail\Abstracts;
use Exception;
abstract class EmailAbstract implements EmailInterface {
/**
* @var bool
*/
private $is_enable;
/**
* @var array
*/
protected $recipients = [];
/**
* @var array
*/
protected $placeholders = [];
/**
* @var string
*/
protected $subject = '';
/**
* @var string
*/
@@ -34,7 +44,7 @@ abstract class EmailAbstract implements EmailInterface {
/**
* @var string
*/
protected $type = 'text/html';
protected $type = 'html';
/**
* @var array
@@ -48,6 +58,37 @@ abstract class EmailAbstract implements EmailInterface {
*/
abstract public function get_id(): string;
/**
* @return bool
*/
public function get_is_enable(): bool {
return $this->is_enable;
}
/**
* @param $enable
*
* @return EmailAbstract
*/
public function set_is_enable( $enable ): self {
$this->is_enable = $enable;
return $this;
}
/**
* Set placeholders.
*
* @param array $placeholders
*
* @return self
*/
public function set_placeholders( array $placeholders = [] ): self {
$this->placeholders = array_merge( $this->placeholders, $placeholders );
return $this;
}
/**
* Get defined placeholders.
*
@@ -57,20 +98,46 @@ abstract class EmailAbstract implements EmailInterface {
return $this->placeholders;
}
/**
* Get email subject.
*
* @param string $subject
*
* @return self
*/
public function set_subject( string $subject ): self {
$this->subject = $subject;
return $this;
}
/**
* Get email subject.
*
* @return string
* @throws \Exception
* @throws Exception
*/
public function get_subject(): string {
if ( ! $this->subject ) {
throw new \Exception( 'Empty email subject' );
throw new Exception( 'Empty email subject' );
}
return $this->subject;
}
/**
* Set email heading.
*
* @param string $heading
*
* @return self
*/
public function set_heading( string $heading ): self {
$this->heading = $heading;
return $this;
}
/**
* Get email heading.
*
@@ -80,6 +147,19 @@ abstract class EmailAbstract implements EmailInterface {
return $this->heading;
}
/**
* Get valid recipients.
*
* @param array $recipients
*
* @return self
*/
public function set_recipients( array $recipients = [] ): self {
$this->recipients = $recipients;
return $this;
}
/**
* Get valid recipients.
*
@@ -89,6 +169,19 @@ abstract class EmailAbstract implements EmailInterface {
return $this->recipients;
}
/**
* Get email headers.
*
* @param array $headers
*
* @return self
*/
public function set_headers( array $headers = [] ): self {
$this->headers = $headers;
return $this;
}
/**
* Get email headers.
*
@@ -98,6 +191,19 @@ abstract class EmailAbstract implements EmailInterface {
return $this->headers;
}
/**
* Set attachments.
*
* @param array $attachments
*
* @return self
*/
public function set_attachments( array $attachments ): self {
$this->attachments = $attachments;
return $this;
}
/**
* Get email attachments.
*
@@ -107,6 +213,19 @@ abstract class EmailAbstract implements EmailInterface {
return $this->attachments;
}
/**
* Set email type.
*
* @param string $type
*
* @return self
*/
public function set_type( string $type = 'html' ): self {
$this->type = $type;
return $this;
}
/**
* Get email type.
*
@@ -116,14 +235,44 @@ abstract class EmailAbstract implements EmailInterface {
return $this->type;
}
/**
* Get content type.
*
* @return string
*/
public function get_content_type(): string {
switch ( $this->get_type() ) {
case 'html':
return 'text/html';
case 'multipart':
return 'multipart/alternative';
default:
return 'text/plain';
}
}
/**
* Get email content.
*
* @param string $content
*
* @return self
*/
public function set_content( string $content ): self {
$this->content = $content;
return $this;
}
/**
* Get email content.
*
* @return string
* @throws Exception
*/
public function get_content(): string {
if ( ! $this->content ) {
throw new \Exception( 'Empty email subject' );
throw new Exception( 'Empty email content' );
}
return '';
@@ -136,4 +285,5 @@ abstract class EmailAbstract implements EmailInterface {
return '';
}
}
Loading