Rellene previamente los campos de pago de Woocommerce con variables de Url guardadas en la sesión

3 minutos de lectura

Rellene previamente los campos de pago de Woocommerce con variables
Ronny

Cuando las personas ingresan a my woocommerce shop siguiendo un enlace en un correo electrónico de ventas con el correo electrónico y el nombre como parámetros, me gustaría completar previamente el nombre y el correo electrónico en la página de pago.

Por lo tanto, creé una acción y un filtro. Esto funciona como se esperaba, pero solo si realizo una actualización completa en la página de ventas (ctrl + f5)

Excluí la página de ventas y la página de pago del caché y del caché de barniz, pero esto no solucionó el problema.

¿Me estoy perdiendo de algo? ¿Tienes alguna idea de por qué esto solo funciona con una actualización completa?

Cualquier ayuda es muy apreciada.

Código:

    function save()
    {
    if ( is_page( 'sales-page' ) )
    {
        if ( isset( $_GET['tu_em'] ) ) {
            global $woocommerce;
            $woocommerce->session->set( 'tu_em', $_GET['tu_em'] );
        }
        if ( isset( $_GET['tu_name'] ) ) {
            global $woocommerce;
            $woocommerce->session->set( 'tu_name', $_GET['tu_name'] );
        }
    }
}
add_action( 'wp_enqueue_scripts', 'save_email' , 1100);

function override_checkout_email_field( $fields ) {
    global $woocommerce;
    $email = $woocommerce->session->get('tu_em');
    if(!is_null($email)) {
      $fields['billing']['billing_email']['default'] = $email;
    }
    $name = $woocommerce->session->get('tu_name');
    if(!is_null($name)) {
      $fields['billing']['billing_first_name']['default'] = $name;
    }
    return $fields;
}
add_filter( 'woocommerce_checkout_fields' , 'override_checkout_email_field' );

Rellene previamente los campos de pago de Woocommerce con variables
LoicTheAztec

A continuación, encontrará el código de trabajo correcto para guardar los datos del usuario de una URL (GET) en las sesiones de WooCommerce y para autocompletar con esos datos los campos de pago relacionados.

La URL será como: http://example.com/sales-page/?tu_em=name@example.com&tu_name=theFirstName

Esto se puede hacer desde cualquier URL, ya que el código detectará la variable de URL, cuando se establezcan.

El código;

// Save user data from URL to Woocommerce session
add_action( 'template_redirect', 'set_custom_data_wc_session' );
function set_custom_data_wc_session () {
    if ( isset( $_GET['tu_em'] ) || isset( $_GET['tu_name'] ) ) {
        $em   = isset( $_GET['tu_em'] )   ? esc_attr( $_GET['tu_em'] )   : '';
        $name = isset( $_GET['tu_name'] ) ? esc_attr( $_GET['tu_name'] ) : '';

        // Set the session data
        WC()->session->set( 'custom_data', array( 'email' => $em, 'name' => $name ) );
    }
}

// Autofill checkout fields from user data saved in Woocommerce session
add_filter( 'woocommerce_billing_fields' , 'prefill_billing_fields' );
function prefill_billing_fields ( $address_fields ) {
    // Get the session data
    $data = WC()->session->get('custom_data');

    // Email
    if( isset($data['email']) && ! empty($data['email']) )
        $address_fields['billing_email']['default'] = $data['email'];

    // Name
    if( isset($data['name']) && ! empty($data['name']) )
        $address_fields['billing_first_name']['default'] = $data['name'];

    return $address_fields;
}

El código va en el archivo function.php de su tema secundario activo (o tema activo). Probado y funciona.

La información de envío (enviar a otra dirección) por defecto es automática, la usamos para autocompletar los campos de facturación

add_filter( 'woocommerce_checkout_fields' , 'ahmadyani_checkout_field_defaults', 20 );
function ahmadyani_checkout_field_defaults( $fields ) {
    $user = get_user_meta(get_current_user_id());
    $first_name = $user ? $user['shipping_first_name'][0] : '';
    $last_name = $user ? $user['shipping_last_name'][0] : '';
    $company = $user ? $user['shipping_company'][0] : '';
    $shipping_address_1 = $user ? $user['shipping_address_1'][0] : '';
    $shipping_address_2 = $user ? $user['shipping_address_2'][0] : '';
    $shipping_city = $user ? $user['shipping_city'][0] : '';
    $shipping_state = $user ? $user['shipping_state'][0] : '';
    $shipping_postcode = $user ? $user['shipping_postcode'][0] : '';
    $fields['billing']['billing_first_name']['default'] = $first_name;
    $fields['billing']['billing_last_name']['default'] = $last_name;
    $fields['billing']['billing_company']['default'] = $company;
    $fields['billing']['billing_address_1']['default'] = $shipping_address_1;
    $fields['billing']['billing_address_2']['default'] = $shipping_address_2;
    $fields['billing']['billing_city']['default'] = $shipping_city;
    $fields['billing']['billing_state']['default'] = $shipping_state;
    $fields['billing']['billing_postcode']['default'] = $shipping_postcode;
    return $fields;
}

¿Ha sido útil esta solución?

Esta web utiliza cookies propias y de terceros para su correcto funcionamiento y para fines analíticos y para mostrarte publicidad relacionada con sus preferencias en base a un perfil elaborado a partir de tus hábitos de navegación. Al hacer clic en el botón Aceptar, acepta el uso de estas tecnologías y el procesamiento de tus datos para estos propósitos. Configurar y más información
Privacidad