Files
medicalalert-web-reloaded/wp/wp-content/plugins/woocommerce-smart-coupons/includes/emails/class-wc-sc-acknowledgement-email.php
2024-06-17 16:29:48 -04:00

351 lines
11 KiB
PHP

<?php
/**
* Main class for Smart Coupons Acknowledgement Email
*
* @author StoreApps
* @since 4.7.8
* @version 1.2.0
*
* @package woocommerce-smart-coupons/includes/emails/
*/
if ( ! defined( 'ABSPATH' ) ) {
exit; // Exit if accessed directly.
}
if ( ! class_exists( 'WC_SC_Acknowledgement_Email' ) ) {
/**
* The Smart Coupons Email class
*
* @extends \WC_SC_Email
*/
class WC_SC_Acknowledgement_Email extends WC_SC_Email {
/**
* Whether email is a scheduled email or not.
*
* @var bool
*/
public $is_email_scheduled = false;
/**
* Set email defaults
*/
public function __construct() {
$this->id = 'wc_sc_acknowledgement_email';
$this->customer_email = true;
// Set email title and description.
$this->title = __( 'Smart Coupons - Acknowledgement email', 'woocommerce-smart-coupons' );
$this->description = __( 'Send an acknowledgement email to the purchaser. One email per customer.', 'woocommerce-smart-coupons' );
// Use our plugin templates directory as the template base.
$this->template_base = dirname( WC_SC_PLUGIN_FILE ) . '/templates/';
// Email template location.
$this->template_html = 'acknowledgement-email.php';
$this->template_plain = 'plain/acknowledgement-email.php';
$this->placeholders = array(
'{coupon_type}' => '',
);
// Trigger for this email.
add_action( 'wc_sc_acknowledgement_email_notification', array( $this, 'trigger' ) );
// Call parent constructor to load any other defaults not explicity defined here.
parent::__construct();
}
/**
* Get default email subject.
*
* @return string Default email subject
*/
public function get_default_subject() {
return __( '{site_title}: {coupon_type} sent successfully', 'woocommerce-smart-coupons' );
}
/**
* Get default email heading.
*
* @return string Default email heading
*/
public function get_default_heading() {
return __( '{coupon_type} sent successfully', 'woocommerce-smart-coupons' );
}
/**
* Get default scheduled email subject.
*
* @return string Default email subject
*/
public function get_default_scheduled_subject() {
return __( '{site_title}: {coupon_type} has been successfully scheduled', 'woocommerce-smart-coupons' );
}
/**
* Get default scheduled email heading.
*
* @return string Default email heading
*/
public function get_default_scheduled_heading() {
return __( '{coupon_type} has been successfully scheduled', 'woocommerce-smart-coupons' );
}
/**
* Initialize Settings Form Fields
*/
public function init_form_fields() {
/* translators: %s: list of placeholders */
$placeholder_text = sprintf( __( 'This will be used when the setting "WooCommerce > Settings > Smart Coupons > Allow schedule sending of coupons?" is enabled. Available placeholders: %s.', 'woocommerce-smart-coupons' ), '<code>' . implode( '</code>, <code>', array_keys( $this->placeholders ) ) . '</code>' );
$form_fields = array(
'scheduled_subject' => array(
'title' => __( 'Scheduled email subject', 'woocommerce-smart-coupons' ),
'type' => 'text',
'desc_tip' => true,
'description' => $placeholder_text,
'placeholder' => $this->get_default_scheduled_subject(),
'default' => '',
),
'scheduled_heading' => array(
'title' => __( 'Scheduled email heading', 'woocommerce-smart-coupons' ),
'type' => 'text',
'desc_tip' => true,
'description' => $placeholder_text,
'placeholder' => $this->get_default_scheduled_heading(),
'default' => '',
),
);
parent::init_form_fields();
$this->form_fields = array_merge( $this->form_fields, $form_fields );
}
/**
* Determine if the email should actually be sent and setup email merge variables
*
* @param array $args Email arguments.
*/
public function trigger( $args = array() ) {
$this->email_args = wp_parse_args( $args, $this->email_args );
if ( ! isset( $this->email_args['email'] ) || empty( $this->email_args['email'] ) ) {
return;
}
$email_scheduled_details = ! empty( $this->email_args['scheduled_email'] ) ? $this->email_args['scheduled_email'] : array();
$this->is_email_scheduled = ! empty( $email_scheduled_details );
$this->setup_locale();
$this->recipient = $this->email_args['email'];
$order_id = isset( $this->email_args['order_id'] ) ? $this->email_args['order_id'] : 0;
// Get order object.
if ( ! empty( $order_id ) && 0 !== $order_id ) {
$order = wc_get_order( $order_id );
if ( is_a( $order, 'WC_Order' ) ) {
$this->object = $order;
}
}
$this->set_placeholders();
$email_content = $this->get_content();
// Replace placeholders with values in the email content.
$email_content = ( is_callable( array( $this, 'format_string' ) ) ) ? $this->format_string( $email_content ) : $email_content;
// Send email.
if ( $this->is_enabled() && $this->get_recipient() ) {
$this->send( $this->get_recipient(), $this->get_subject(), $email_content, $this->get_headers(), $this->get_attachments() );
}
$this->restore_locale();
}
/**
* Function to get email subject.
*
* @return string Email subject.
*/
public function get_subject() {
if ( true === $this->is_email_scheduled ) {
return $this->get_scheduled_subject();
}
return parent::get_subject();
}
/**
* Function to get email subject.
*
* @return string Email subject.
*/
public function get_heading() {
if ( true === $this->is_email_scheduled ) {
return $this->get_scheduled_heading();
}
return parent::get_heading();
}
/**
* Get scheduled email subject.
*
* @return string
*/
public function get_scheduled_subject() {
return apply_filters(
$this->id . '_scheduled_subject',
$this->format_string( $this->get_option( 'scheduled_subject', $this->get_default_scheduled_subject() ) ),
array(
'email_object' => $this->object,
'source' => $this,
)
);
}
/**
* Get scheduled email heading.
*
* @return string
*/
public function get_scheduled_heading() {
return apply_filters(
$this->id . '_scheduled_heading',
$this->format_string( $this->get_option( 'scheduled_heading', $this->get_default_scheduled_heading() ) ),
array(
'email_object' => $this->object,
'source' => $this,
)
);
}
/**
* Function to set placeholder variables used in email subject/heading
*/
public function set_placeholders() {
$this->placeholders['{coupon_type}'] = $this->get_coupon_type();
}
/**
* Function to load email html content
*
* @return string Email content html
*/
public function get_content_html() {
global $woocommerce_smart_coupon;
$order = $this->object;
$email_heading = $this->get_heading();
$email = isset( $this->email_args['email'] ) ? $this->email_args['email'] : '';
$receivers_detail = isset( $this->email_args['receivers_detail'] ) ? $this->email_args['receivers_detail'] : array();
$receiver_name = isset( $this->email_args['receiver_name'] ) ? $this->email_args['receiver_name'] : '';
$receiver_count = isset( $this->email_args['receiver_count'] ) ? $this->email_args['receiver_count'] : 0;
$email_scheduled_details = isset( $this->email_args['scheduled_email'] ) ? $this->email_args['scheduled_email'] : array();
$contains_core_coupons = ( isset( $this->email_args['contains_core_coupons'] ) && 'yes' === $this->email_args['contains_core_coupons'] ) ? $this->email_args['contains_core_coupons'] : 'no';
$default_path = $this->template_base;
$template_path = $woocommerce_smart_coupon->get_template_base_dir( $this->template_html );
ob_start();
wc_get_template(
$this->template_html,
array(
'email' => $email,
'email_obj' => $this,
'email_heading' => $email_heading,
'order' => $order,
'receivers_detail' => $receivers_detail,
'gift_certificate_receiver_name' => $receiver_name,
'receiver_count' => $receiver_count,
'email_scheduled_details' => $email_scheduled_details,
'contains_core_coupons' => $contains_core_coupons,
),
$template_path,
$default_path
);
return ob_get_clean();
}
/**
* Function to load email plain content
*
* @return string Email plain content
*/
public function get_content_plain() {
global $woocommerce_smart_coupon;
$order = $this->object;
$email_heading = $this->get_heading();
$email = isset( $this->email_args['email'] ) ? $this->email_args['email'] : '';
$receivers_detail = isset( $this->email_args['receivers_detail'] ) ? $this->email_args['receivers_detail'] : array();
$receiver_name = isset( $this->email_args['receiver_name'] ) ? $this->email_args['receiver_name'] : '';
$receiver_count = isset( $this->email_args['receiver_count'] ) ? $this->email_args['receiver_count'] : 0;
$email_scheduled_details = isset( $this->email_args['scheduled_email'] ) ? $this->email_args['scheduled_email'] : array();
$contains_core_coupons = ( isset( $this->email_args['contains_core_coupons'] ) && 'yes' === $this->email_args['contains_core_coupons'] ) ? $this->email_args['contains_core_coupons'] : 'no';
$default_path = $this->template_base;
$template_path = $woocommerce_smart_coupon->get_template_base_dir( $this->template_html );
ob_start();
wc_get_template(
$this->template_plain,
array(
'email' => $email,
'email_obj' => $this,
'email_heading' => $email_heading,
'order' => $order,
'receivers_detail' => $receivers_detail,
'gift_certificate_receiver_name' => $receiver_name,
'receiver_count' => $receiver_count,
'email_scheduled_details' => $email_scheduled_details,
'contains_core_coupons' => $contains_core_coupons,
),
$template_path,
$default_path
);
return ob_get_clean();
}
/**
* Function to get coupon type for current coupon being sent.
*
* @return string $coupon_type Coupon type.
*/
public function get_coupon_type() {
global $store_credit_label;
$receiver_count = isset( $this->email_args['receiver_count'] ) ? $this->email_args['receiver_count'] : 0;
$singular = ( ! empty( $store_credit_label['singular'] ) ) ? ucwords( $store_credit_label['singular'] ) : __( 'Gift card', 'woocommerce-smart-coupons' );
$plural = ( ! empty( $store_credit_label['plural'] ) ) ? ucwords( $store_credit_label['plural'] ) : __( 'Gift cards', 'woocommerce-smart-coupons' );
$coupon_type = ( $receiver_count > 1 ) ? $plural : $singular;
$contains_core_coupons = ( isset( $this->email_args['contains_core_coupons'] ) && 'yes' === $this->email_args['contains_core_coupons'] ) ? $this->email_args['contains_core_coupons'] : 'no';
if ( 'yes' === $contains_core_coupons ) {
$coupon_type = _n( 'Coupon', 'Coupons', $receiver_count, 'woocommerce-smart-coupons' );
}
return $coupon_type;
}
}
}