Отправить пользовательское письмо с динамической темой и получателем в Woocommerce - PullRequest
0 голосов
/ 27 октября 2018

В Woocommerce мне удалось создать пользовательский мета-блок с кнопкой, которая отправляет электронное письмо, используя Отправка пользовательского электронного письма, когда кнопка извлечения WooCommerce нажата существующий код ответа. Он отображает следующий метабокс:

MetaBox

Поэтому, когда я нажимаю кнопку, она отправляет электронное письмо, которое работает просто отлично.

Мой вопрос:
Как я могу настроить этот код для отправки настраиваемого электронного письма, так как мне нужно только отправить «Тема» (с идентификатором заказа и общей суммой платежа) на адрес электронной почты, который должен иметь формат: mobilenumber@domain.com (таким образом, он будет отправлен на шлюз SMS и доставляется в виде смс на мобильное устройство)?

Например:
Адрес электронной почты: 123456789@smsgateway.com
subject: ваш заказ {order_id} выполнен. Итого: {order_total}. Спасибо

1 Ответ

0 голосов
/ 27 октября 2018

Обновлено

Первая функция является необязательной и отображает обязательное поле оформления заказа для мобильного телефона.

Второй код функции отображает метабокс на страницах редактирования заказа администратора woocommerce с пользовательской кнопкой, которая запускает действие. При нажатии он отправит пользовательское электронное письмо на шлюз SMS с:

  • конкретный динамический предмет, содержащий номер заказа и общую сумму
  • конкретный адрес электронной почты, сделанный из мобильного телефона клиента и определенного доменного имени шлюза SMS, например 'smsgateway.com'.

Примечание: При использовании функции wp_mail() сообщение является обязательным (если сообщение отсутствует или пустое, электронное письмо не отправляется).

код:

// 1. Add mandatory billing phone field (and save the field value in the order)
add_filter( 'woocommerce_billing_fields', 'add_billing_mobile_phone_field', 20, 1 );
function add_billing_mobile_phone_field( $billing_fields ) {
    $billing_fields['billing_mobile_phone'] = array(
        'type'        => 'text',
        'label'       => __("Mobile phone", "woocommerce") ,
        'class'       => array('form-row-wide'),
        'required'    => true,
        'clear'       => true,
    );
    return $billing_fields;
}

// 2. Send a specific custom email to a SMS gateway from a meta box

// Add a metabox
add_action( 'add_meta_boxes', 'order_metabox_email_to_sms' );
function order_metabox_email_to_sms() {
    add_meta_box( 'sms_notification',
    __( 'SMS notification', "woocommerce" ),
    'order_metabox_content_email_to_sms',
    'shop_order', 'side', 'high' );
}

// Metabox content: Button and SMS processing script
function order_metabox_content_email_to_sms(){
    global $pagenow;

    if( $pagenow != 'post.php' || get_post_type($_GET['post']) != 'shop_order' )
        return; // Exit

    if ( ! ( isset($_GET['post']) && $_GET['post'] > 0 ) )
        return; // Exit

    $order_id = $_GET['post'];

    $is_sent = get_post_meta( $order_id, '_sms_email_sent', true );

    // Sending SMS
    if ( isset($_GET['send_sms']) && $_GET['send_sms'] && ! $is_sent ) {
        // Get an instance of the WC_Order object
        $order = wc_get_order( $order_id );

        // Using the billing mobile phone if it exist, or the billing phone if not.
        if( $mobile_phone = $order->get_meta( '_billing_mobile_phone' ) ) {
            $phone = $mobile_phone;
        } else {
            $phone = $order->get_billing_phone();
        }

        // Email address: Customer mobile phone + @ + sms domain
        $send_to = $phone . '@' . 'smsgateway.com';

        // Subject with the order ID and the order total amount
        $subject = sprintf(
            __("Your order number %d with a total of %s is being processed. Thank you.", "woocommerce"),
            $order_id, html_entity_decode( strip_tags( wc_price( $order->get_total() ) ) )
        );

        // Message: It is required (we just add the order number to it).
        $message = $order_id;

        // Sending this custom email
        $trigger_send = wp_mail( $send_to, $subject, $message );

        // Displaying the result
        if( $trigger_send ) {
            $result  = '<span style="color:green;">' ;
            $result .= __( "The SMS is being processed by the gateway." );

            // On email sent with success, Mark this email as sent in the Order meta data (To avoid repetitions)
            update_post_meta( $order_id, '_sms_email_sent', $trigger_send );
        } else {
            $result  = '<span style="color:red;">' ;
            $result .= __( "Sorry, but the SMS is not processed." );
        }
        $result .= '</span>';
    }

    // Displaying the button
    $href = '?post=' . $order_id . '&action=edit&send_sms=1';
    $send_text = isset($is_sent) && $is_sent ? '<em><small style="float:right;"> ('. __("Already sent") . ')</small></em>' : '';
    echo '<p><a href="' . $href . '" class="button">' . __( "Send SMS" ) . '</a>'.$send_text.'</p>';

    // Displaying a feed back on send
    echo isset($result) ? '<p><small>' . $result . '</small></p>' : false;
}

Код помещается в файл function.php активной дочерней темы (или активной темы). Проверено и работает.


Четыре возможности в этом метабоксе:

enter image description here

Как только SMS отправлено один раз, функция становится неактивной, чтобы избежать повторений.

...