0
votes

So I have created an add on plugin for WooCommerce. I have a custom class to extend the 'cheque' payment gateway to allow a user to perform a wholesale checkout without payment. So far this functionality works perfect. The issue is I cannot get the custom email to work with this custom payment. I'm not sure if i'm connecting the two custom classes together. Am I missing something in my trigger or using the wrong hook for the trigger?

Right here I include the email class..

 function add_dealer_invoice_woocommerce_email( $email_classes ) {
// include our custom email class
require_once( 'includes/class-wc-dealer-invoice-email.php' );

// add the email class to the list of email classes that WooCommerce loads
$email_classes['WC_Dealer_Invoice_Email'] = new WC_Dealer_Invoice_Email();

return $email_classes;
}

add_filter( 'woocommerce_email_classes', 'add_dealer_invoice_woocommerce_email' );
// Register new status for woocomerce 2.2+
function register_dealer_invoice_order_status() {
register_post_status( 'wc-dealer-invoice', array(
    'label'                     => 'Dealer Invoice',
    'public'                    => true,
    'exclude_from_search'       => false,
    'show_in_admin_all_list'    => true,
    'show_in_admin_status_list' => true,
    'label_count'               => _n_noop( 'Awaiting payment <span class="count">(%s)</span>', 'Awaiting payment <span class="count">(%s)</span>' )
) );
}
 add_action( 'init', 'register_dealer_invoice_order_status' );

And here is the custom email class that extends WC_Email

if ( ! defined( 'ABSPATH' ) ) exit; // Exit if accessed directly

class WC_Dealer_Invoice_Email extends WC_Email {

public function __construct() {

    // set ID, this simply needs to be a unique name
    $this->id = 'wc_dealer_invoice';

    // this is the title in WooCommerce Email settings
    $this->title = 'Dealer Invoice';

    // this is the description in WooCommerce email settings
    $this->description = 'Dealer Invoice Notification emails are sent when a customer places a wholesale order on consignment';

    // these are the default heading and subject lines that can be overridden using the settings
    $this->heading = 'Dealer Invoice Order';
    $this->subject = 'Dealer Invoice Order';

    // these define the locations of the templates that this email should use, we'll just use the new order template since this email is similar
    $this->template_html  = 'emails/admin-new-order.php';
    $this->template_plain = 'emails/plain/admin-new-order.php';

    // Trigger on new paid orders
    add_action( 'woocommerce_order_status_pending_to_processing_notification', array( $this, 'trigger' ) );
    add_action( 'woocommerce_order_status_failed_to_processing_notification',  array( $this, 'trigger' ) );
    add_action( 'woocommerce_checkout_order_processed',  array( $this, 'trigger' ) );

    // Call parent constructor to load any other defaults not explicity defined here
    parent::__construct();

    // this sets the recipient to the settings defined below in init_form_fields()
    $this->recipient = $this->get_option( 'recipient' );

    // if none was entered, just use the WP admin email as a fallback
    if ( ! $this->recipient )
        $this->recipient = get_option( 'admin_email' );
}


/**
 * Determine if the email should actually be sent and setup email merge variables
 *
 * @since 0.1
 * @param int $order_id
 */
public function trigger( $order_id ) {

    // bail if no order ID is present
    if ( ! $order_id )
        return;

    // setup order object
    $this->object = new WC_Order( $order_id );

    // bail if shipping method is not expedited
    if (  'cheque' !=  get_post_meta( $order_id, '_payment_method', true ))
        return;

    // replace variables in the subject/headings
    $this->find[] = '{order_date}';
    $this->replace[] = date_i18n( woocommerce_date_format(), strtotime( $this->object->order_date ) );

    $this->find[] = '{order_number}';
    $this->replace[] = $this->object->get_order_number();

    if ( ! $this->is_enabled() || ! $this->get_recipient() )
        return;

    // woohoo, send the email!
    $this->send( $this->get_recipient(), $this->get_subject(), $this->get_content(), $this->get_headers(), $this->get_attachments() );
}


/**
 * get_content_html function.
 *
 * @since 0.1
 * @return string
 */
public function get_content_html() {
    ob_start();
    woocommerce_get_template( $this->template_html, array(
        'order'         => $this->object,
        'email_heading' => $this->get_heading()
    ) );
    return ob_get_clean();
}


/**
 * get_content_plain function.
 *
 * @since 0.1
 * @return string
 */
public function get_content_plain() {
    ob_start();
    woocommerce_get_template( $this->template_plain, array(
        'order'         => $this->object,
        'email_heading' => $this->get_heading()
    ) );
    return ob_get_clean();
}


/**
 * Initialize Settings Form Fields
 *
 * @since 2.0
 */
public function init_form_fields() {

    $this->form_fields = array(
        'enabled'    => array(
            'title'   => 'Enable/Disable',
            'type'    => 'checkbox',
            'label'   => 'Enable this email notification',
            'default' => 'yes'
        ),
        'recipient'  => array(
            'title'       => 'Recipient(s)',
            'type'        => 'text',
            'description' => sprintf( 'Enter recipients (comma separated) for this email. Defaults to <code>%s</code>.', esc_attr( get_option( 'admin_email' ) ) ),
            'placeholder' => '',
            'default'     => ''
        ),
        'subject'    => array(
            'title'       => 'Subject',
            'type'        => 'text',
            'description' => sprintf( 'This controls the email subject line. Leave blank to use the default subject: <code>%s</code>.', $this->subject ),
            'placeholder' => '',
            'default'     => ''
        ),
        'heading'    => array(
            'title'       => 'Email Heading',
            'type'        => 'text',
            'description' => sprintf( __( 'This controls the main heading contained within the email notification. Leave blank to use the default heading: <code>%s</code>.' ), $this->heading ),
            'placeholder' => '',
            'default'     => ''
        ),
        'email_type' => array(
            'title'       => 'Email type',
            'type'        => 'select',
            'description' => 'Choose which format of email to send.',
            'default'     => 'html',
            'class'       => 'email_type',
            'options'     => array(
                'plain'     => __( 'Plain text', 'woocommerce' ),
                'html'      => __( 'HTML', 'woocommerce' ),
                'multipart' => __( 'Multipart', 'woocommerce' ),
            )
        )
    );
}
} // end \WC_Dealer_Invoice_Email class
1
If you aren't accepting payment I'm not sure that any of your trigger actions are firing.... woocommerce_order_status_pending_to_processing_notification, woocommerce_order_status_failed_to_processing_notification, or woocommerce_checkout_order_processed. If you want it to fire on your new custom status you need to filter woocommerce_email_actions. When do you want it to send? What is the status of the order after a user checks out?helgatheviking
I would like the email to be sent at the last step in the checkout. Preferably with a link so they can go and pay later. The status of the order shows up as Dealer Invoice which is an extension to the cheque class.Cavan Page

1 Answers

0
votes

I think you just need to add a code to your function.php

add_filter('woocommerce_cart_needs_payment', '__return_false');

to allow users to send their orders without proceeding with payment. The email notification you can setup from woocommerce settings.