Woocommerce 结帐页面中的运输承运人自定义字段验证

Dan*_*eer 1 php wordpress jquery woocommerce shipping-method

我通过更改模板在运输方式部分添加了两个自定义输入字段,/genesis-sample/woocommerce/checkout/review-order.php 我还设法使它们有条件地需要。只有当特定的单选按钮被选中时,输入字段才会出现并成为必需的。我正在使用 jQuery 代码使字段出现和消失。所有这些都运行良好。代码在这里:

if ( isset($_POST['shipping_method_0_legacy_local_pickup']) && $_POST['shipping_method_0_legacy_local_pickup'] == 1 ) {
    $cheq = 'true';
}
else {
    $cheq = 'false';
}
woocommerce_form_field( 'fieldtester1' , array(
    'type'          => 'text',
    'class'         => array('wccs-field-class wccs-form-row-wide blahblah1'), 
    'label'         => 'Enter Your Carrier Name',
    'required'  => $cheq,
    'placeholder'       => 'Carrier Name',
    ), $checkout->get_value( 'fieldtester1' )); 
woocommerce_form_field( 'fieldtester2' , array(
    'type'          => 'text',
    'class'         => array('wccs-field-class wccs-form-row-wide blahblah2'), 
    'label'         => 'Enter Your Carrier Account #',
    'required'  => $cheq,
    'placeholder'       => 'Carrier Number',
    ), $checkout->get_value( 'fieldtester2' )); 
Run Code Online (Sandbox Code Playgroud)

但问题是,即使为两个字段required设置了属性true,如果Place Order按下按钮时字段为空,验证也不会发生。理想情况下,订单不应通过,并应生成错误消息。我已经添加了以下代码functions.php来强制验证输入字段,但它没有做任何事情。代码在这里:

add_action('woocommerce_checkout_process', 'carrier_checkout_process');
function carrier_checkout_process() {
    if ( isset($_POST['shipping_method_0_legacy_local_pickup']) && $_POST['shipping_method_0_legacy_local_pickup'] == 1 ) {
        if( empty( $_POST['fieldtester1'] ) ) {
            wc_add_notice( ( "Please don't forget to enter your shipping carrier details." ), "error" );
        }
    }
}
Run Code Online (Sandbox Code Playgroud)

所以,这就是我要找的:

  1. 谁能帮我强制验证我添加的两个输入字段?
  2. 验证后,我还想在新订单电子邮件中添加这两个字段,并在 Wordpress 仪表板中添加订单详细信息。

如果您想知道为什么我不首先使用 woocommerce 结帐字段挂钩来添加输入字段……我没有将字段添加到结帐表单中,因此挂钩没有任何帮助。这些字段添加在运输方式部分。另一个原因是,我想在required每次用户切换运输方式时更新属性。required无论出于何种原因,使用 Jquery 更改属性都不起作用,相信我,我尝试了两天。无论如何,那部分已经在工作了。唯一的问题是让字段进行验证并将它们添加到订单电子邮件和订单详细信息中。我四处看了看,我得到的最接近的帮助是这篇文章,其中 LoicTheAztec 给出了详细的解决方案

Loi*_*tec 10

这可以在没有 jQuery 的情况下使用一个特殊的钩子来完成,当它被选中时,它将在运输方式下方显示您的两个“承运人”自定义字段legacy_local_pickup。如果客户更改为不同的运输方式,这些字段将被删除。

因此,您应该需要先删除您的自定义模板和所有相关代码。

现在验证工作完美,当“运营商”自定义字段被填充时,它们会按订单元数据保存。

// Add custom fields to a specific selected shipping method
add_action( 'woocommerce_after_shipping_rate', 'carrier_custom_fields', 20, 2 );
function carrier_custom_fields( $method, $index ) {
    if( ! is_checkout()) return; // Only on checkout page

    $customer_carrier_method = 'legacy_local_pickup';

    if( $method->id != $customer_carrier_method ) return; // Only display for "local_pickup"

    $chosen_method_id = WC()->session->chosen_shipping_methods[ $index ];

    // If the chosen shipping method is 'legacy_local_pickup' we display
    if($chosen_method_id == $customer_carrier_method ):

    echo '<div class="custom-carrier">';

    woocommerce_form_field( 'carrier_name' , array(
        'type'          => 'text',
        'class'         => array('form-row-wide carrier-name'),
        'label'         => 'Carrier Information:',
        'required'      => true,
        'placeholder'   => 'Carrier Name',
    ), WC()->checkout->get_value( 'carrier_name' ));

    woocommerce_form_field( 'carrier_number' , array(
        'type'          => 'text',
        'class'         => array('form-row-wide carrier-number'),
        'required'      => true,
        'placeholder'   => 'Carrier Number',
    ), WC()->checkout->get_value( 'carrier_number' ));

    echo '</div>';
    endif;
}

// Check custom fields validation
add_action('woocommerce_checkout_process', 'carrier_checkout_process');
function carrier_checkout_process() {
    if( isset( $_POST['carrier_name'] ) && empty( $_POST['carrier_name'] ) )
        wc_add_notice( ( "Please don't forget to enter the shipping carrier name." ), "error" );

    if( isset( $_POST['carrier_number'] ) && empty( $_POST['carrier_number'] ) )
        wc_add_notice( ( "Please don't forget to enter the shipping carrier account number." ), "error" );
}

// Save custom fields to order meta data
add_action( 'woocommerce_checkout_update_order_meta', 'carrier_update_order_meta', 30, 1 );
function carrier_update_order_meta( $order_id ) {
    if( isset( $_POST['carrier_name'] ))
        update_post_meta( $order_id, '_carrier_name', sanitize_text_field( $_POST['carrier_name'] ) );

    if( isset( $_POST['carrier_number'] ))
        update_post_meta( $order_id, '_carrier_number', sanitize_text_field( $_POST['carrier_number'] ) );
}
Run Code Online (Sandbox Code Playgroud)

此代码位于活动子主题(或主题)的 functions.php 文件中。测试和工作。

不显示:

在此处输入图片说明

选择“本地取件”时显示:

在此处输入图片说明