石家庄wordpress建站教程之WooCommerce:显示订单交货日期在结帐页面

以下是如何在 WooCommerce 结帐页面上添加“日历”字段,让人们决定交货日期,并将此值保存在订单中。

我花了很长时间才为客户实现这个(它要复杂得多,有可用的日期,基于不同运输区域的不同日历,每天的最大重量等)所以我想和你分享基本的片段!

 

/**
 * @snippet       Display Order Delivery Date @ WooCommerce Checkout
 * @how-to        Get CustomizeWoo.com FREE
 * @author        Rodolfo Melogli
 * @compatible    WooCommerce 5
 * @donate $9     https://businessbloomer.com/bloomer-armada/
 */
// ——————————-
// 1. Display Checkout Calendar if Shipping Selected
add_action( ‘woocommerce_review_order_before_payment’, ‘bbloomer_echo_acf_date_picker’ );
function bbloomer_echo_acf_date_picker( $checkout ) {
   echo ‘<div id=”show-if-shipping” style=”display:none”><h3>Delivery Date</h3>’;
   woocommerce_form_field( ‘delivery_date’, array(
        ‘type’ => ‘text’,
        ‘class’ => array( ‘form-row-wide’ ),
        ‘id’ => ‘datepicker’,
        ‘required’ => true,
        ‘label’ => ‘Select Delivery Date’,
        ‘placeholder’ => ‘Click to open calendar’,
   ));
   echo ‘</div>’;
}
add_action( ‘woocommerce_after_checkout_form’, ‘bbloomer_show_hide_calendar’ );
function bbloomer_show_hide_calendar( $available_gateways ) {
   wc_enqueue_js( “
      function show_calendar( val ) {
         if ( val.match(‘^flat_rate’) || val.match(‘^free_shipping’) ) {
            jQuery(‘#show-if-shipping’).fadeIn();
         } else {
            jQuery(‘#show-if-shipping’).fadeOut();
         }
      }
      jQuery(document).ajaxComplete(function() {
         var val = jQuery(‘input[name^=\’shipping_method\’]:checked’).val();
         show_calendar( val );
      });
   ” );
}
add_action( ‘woocommerce_checkout_process’, ‘bbloomer_validate_new_checkout_fields’ );
function bbloomer_validate_new_checkout_fields() {
   if ( isset( $_POST[ ‘delivery_date’ ] ) && empty( $_POST[ ‘delivery_date’ ] ) ) wc_add_notice( __( ‘Please select the Delivery Date’ ), ‘error’ );
}
// ——————————-
// 2. Load JQuery Datepicker
add_action( ‘woocommerce_after_checkout_form’, ‘bbloomer_enable_datepicker’, 10 );
function bbloomer_enable_datepicker() {
   echo ‘<link rel=”stylesheet” href=”//code.jquery.com/ui/1.13.0/themes/base/jquery-ui.css”>’;
   echo ‘<script src=”//code.jquery.com/ui/1.13.0/jquery-ui.js”></script>’;
}
// ——————————-
// 3. Load Calendar Dates
add_action( ‘woocommerce_after_checkout_form’, ‘bbloomer_load_calendar_dates’, 20 );
function bbloomer_load_calendar_dates( $available_gateways ) {
   wc_enqueue_js( “
      $(‘#datepicker’).click(function() {
            $(‘#datepicker’).datepicker({
               dateFormat: ‘dd-mm-yy’,
               maxDate: “+2m”,
               minDate: 1,
            }).datepicker( “show” );
      });
   ” );
}
// ——————————-
// 4. Save & show date as order meta
add_action( ‘woocommerce_checkout_update_order_meta’, ‘bbloomer_save_date_weight_order’ );
function bbloomer_save_date_weight_order( $order_id ) {
    if ( $_POST[‘delivery_date’] ) update_post_meta( $order_id, ‘_delivery_date’, esc_attr( $_POST[‘delivery_date’] ) );
}
add_action( ‘woocommerce_admin_order_data_after_billing_address’, ‘bbloomer_delivery_weight_display_admin_order_meta’ );
function bbloomer_delivery_weight_display_admin_order_meta( $order ) {
   echo ‘<p><strong>Delivery Date:</strong> ‘ . get_post_meta( $order->get_id(), ‘_delivery_date’, true ) . ‘</p>’;
}
0

评论0

请先
显示验证码
没有账号?注册  忘记密码?