Woocommerce - Afișarea prețului pentru variația activă a produsului

14 aug. 2016, 03:22:47
Vizualizări: 20.1K
Voturi: 1

Folosesc butoane radio pentru variantele produselor în WooCommerce. Fiecare variantă a produsului are propriul preț. Aș dori ca prețul variantei să se afișeze după ce un buton radio este selectat. Nu sunt sigur cum să transmit variation_id-ul variantei selectate active către funcția get_product_variation_price($variation_id).

Un exemplu de cod HTML pentru butonul radio arată astfel în output-ul HTML:

<input type="radio" class="radioselect" name="attribute_size" value="3,000+"      
id="size_v_3,000+">
<label for="size_v_3,000+">3,000+</label>

Totuși, variațiile mele sunt numere (cred că sunt numere de post) precum #12, #3041, etc.

Iată fișierul meu complet variable.php:

<?php
/**
 * Adăugare în coș pentru produse cu variații
 *
 * @author  WooThemes
 * @package WooCommerce/Templates
 * @version 2.5.0
 *
 * Modificat pentru a folosi butoane radio în loc de liste dropdown
 * @author 8manos
 */

if ( ! defined( 'ABSPATH' ) ) {
    exit;
}

function print_attribute_radio( $checked_value, $value, $label, $name ) {
    // Gestionează compatibilitatea cu versiunile < 2.4.0 unde atributele text nu erau sanitizate.
    $checked = sanitize_title( $checked_value ) === $checked_value ? checked( $checked_value, sanitize_title( $value ), false ) : checked( $checked_value, $value, false );

    $input_name = 'attribute_' . esc_attr( $name ) ;
    $esc_value = esc_attr( $value );
    $id = esc_attr( $name . '_v_' . $value );
    $filtered_label = apply_filters( 'woocommerce_variation_option_name', $label );
    $super_filtered = explode(' ', $filtered_label);
    printf( '<div><input type="radio" class="radioselect" name="%1$s" value="%2$s" id="%3$s" %4$s><label for="%3$s">%5$s</label></div>', $input_name, $esc_value, $id, $checked, $super_filtered[0] );
}

global $product;

$attribute_keys = array_keys( $attributes );

do_action( 'woocommerce_before_add_to_cart_form' ); ?>

<form class="variations_form cart" method="post" enctype='multipart/form-data' data-product_id="<?php echo absint( $product->id ); ?>" data-product_variations="<?php echo htmlspecialchars( json_encode( $available_variations ) ) ?>">
    <?php do_action( 'woocommerce_before_variations_form' ); ?>

    <?php if ( empty( $available_variations ) && false !== $available_variations ) : ?>
        <p class="stock out-of-stock"><?php _e( 'Acest produs este momentan epuizat și indisponibil.', 'woocommerce' ); ?></p>
    <?php else : ?>
        <table class="variations" cellspacing="0">
            <tbody>
                <?php foreach ( $attributes as $name => $options ) : ?>
                    <tr>
                        <td class="label" style="margin-top: -10px;"><label for="<?php echo sanitize_title( $name ); ?>"><?php echo wc_attribute_label( $name ); ?></label></td>
                        <?php
                        $sanitized_name = sanitize_title( $name );
                        if ( isset( $_REQUEST[ 'attribute_' . $sanitized_name ] ) ) {
                            $checked_value = $_REQUEST[ 'attribute_' . $sanitized_name ];
                        } elseif ( isset( $selected_attributes[ $sanitized_name ] ) ) {
                            $checked_value = $selected_attributes[ $sanitized_name ];
                        } else {
                            $checked_value = '';
                        }
                        ?>
                        <td class="value" style="margin-top: -30px;">

                            <?php
                            if ( ! empty( $options ) ) {
                                if ( taxonomy_exists( $name ) ) {
                                    // Obține termenii dacă este o taxonomie - ordonată. Avem nevoie și de nume.
                                    $terms = wc_get_product_terms( $product->id, $name, array( 'fields' => 'all' ) );

                                    foreach ( $terms as $term ) {
                                        if ( ! in_array( $term->slug, $options ) ) {
                                            continue;
                                        }
                                        print_attribute_radio( $checked_value, $term->slug, $term->name, $sanitized_name );

                                    }
                                } else {
                                    foreach ( $options as $option ) {
                                        print_attribute_radio( $checked_value, $option, $option, $sanitized_name );
                                    }
                                }
                            }

                            echo end( $attribute_keys ) === $name ? apply_filters( 'woocommerce_reset_variations_link', '<a class="reset_variations" href="#">' . __( 'Șterge', 'woocommerce' ) . '</a>' ) : '';
                            ?>
                        </td>
                    </tr>
                <?php endforeach; ?>
            </tbody>
        </table>

        <?php do_action( 'woocommerce_before_add_to_cart_button' ); ?>

        <div class="single_variation_wrap">
            <?php do_action( 'woocommerce_before_single_variation' ); ?>

            <?php
            if ( has_action( 'woocommerce_single_variation' ) ) {
                do_action( 'woocommerce_single_variation' );
            } else {
                // Compatibilitate cu versiuni anterioare WC < 2.4
            ?>
                <div class="woocommerce-variation single_variation"></div>

                <div class="woocommerce-variation-add-to-cart variations_button">
                    <?php if ( ! $product->is_sold_individually() ) : ?>
                        <?php woocommerce_quantity_input( array( 'input_value' => isset( $_POST['quantity'] ) ? wc_stock_amount( $_POST['quantity'] ) : 1 ) ); ?>
                    <?php endif; ?>
                    <button type="submit" class="single_add_to_cart_button button alt otto"><?php echo esc_html( $product->single_add_to_cart_text() ); ?></button>
                    <input type="hidden" name="add-to-cart" value="<?php echo absint( $product->id ); ?>" />
                    <input type="hidden" name="product_id" value="<?php echo absint( $product->id ); ?>" />
                    <input type="hidden" name="variation_id" class="variation_id" value="0" />
                </div>
            <?php } ?>

            <?php do_action( 'woocommerce_after_single_variation' ); ?>
        </div>

        <?php do_action( 'woocommerce_after_add_to_cart_button' ); ?>

    <?php endif; ?>

    <?php do_action( 'woocommerce_after_variations_form' ); ?>
<p>


<?php

function get_product_variation_price($variation_id) {

    global $woocommerce; 
    $product = new WC_Product_Variation($variation_id);
    return $product->get_price_html(); // Funcționează. Folosește aceasta dacă vrei prețul formatat

}

///Afișează prețul pentru variantele selectate activ cu butoane radio
echo get_product_variation_price(11);
?>

</p>
</form>

<?php do_action( 'woocommerce_after_add_to_cart_form' ); ?>
1
Comentarii

Întrebările legate de funcționarea internă a plugin-urilor terțe sunt mai bine adresate autorilor acestora.

cjbj cjbj
14 aug. 2016 13:16:57
Toate răspunsurile la întrebare 1
0

Am reușit să găsesc o soluție. Aceasta afișează prețul variantei sub/lângă butoanele radio.

Afișare preț variantă (când este dat un ID):

function get_product_variation_price($variation_id) {

global $woocommerce; 
$product = new WC_Product_Variation($variation_id);
return $product->get_price_html(); // Funcționează. Folosește această funcție dacă vrei prețul formatat
}

Găsire ID variantă, trimitere la funcția get_product_variation_price, apoi afișare preț:

///Afișare preț pentru butoanele radio selectate activ
$product_variations = $product->get_available_variations();
$arr_variations_id = array();
foreach ($product_variations as $variation) {
    $product_variation_id = $variation['variation_id'];
    $product_price = get_product_variation_price($product_variation_id);
    echo $product_price;
}

Afișarea butoanelor radio foreach:

foreach ( $options as $option ) {
    print_attribute_radio( $checked_value, $option, $option, $sanitized_name );
                                }

Foreach pentru butoane radio modificat cu cheie de array

foreach ( $options as $key=>$option ) {...}

Foreach combinat:

foreach ( $options as $key=>$option ) {
    print_attribute_radio( $checked_value, $option, $option, $sanitized_name );
    $product_variations = $product->get_available_variations();
    $variation_product_id = $product_variations [$key]['variation_id'];
    $product_price = get_product_variation_price($variation_product_id);
    printf ('%1$s</div> ', $product_price);
                                    }

Cod complet:

<?php
/**
 * Formular de adăugare în coș pentru produs variabil
 *
 * @author  WooThemes
 * @package WooCommerce/Templates
 * @version 2.5.0
 *
 * Modificat pentru a folosi butoane radio în loc de meniuri dropdown
 * @author 8manos
 * Modificări suplimentare pentru afișarea prețului sub butoanele radio
 * @author GoodGuyTaj
 */

if ( ! defined( 'ABSPATH' ) ) {
    exit;
}
// START obținere preț produs 
function get_product_variation_price($variation_id) {

    global $woocommerce; 
    $product = new WC_Product_Variation($variation_id);
    return $product->get_price_html(); // Funcționează. Folosește această funcție dacă vrei prețul formatat

}
// END obținere preț produs 


// START Afișare Butoane Radio
function print_attribute_radio( $checked_value, $value, $label, $name ) {
    // Aceasta gestionează compatibilitatea < 2.4.0 unde atributele text nu erau sanitizate.
    $checked = sanitize_title( $checked_value ) === $checked_value ? checked( $checked_value, sanitize_title( $value ), false ) : checked( $checked_value, $value, false );

    $input_name = 'attribute_' . esc_attr( $name ) ;
    $esc_value = esc_attr( $value );
    $id = esc_attr( $name . '_v_' . $value );
    $filtered_label = apply_filters( 'woocommerce_variation_option_name', $label );
    $super_filtered = explode(' ', $filtered_label);
    printf( '<div><input type="radio" class="radioselect" name="%1$s" value="%2$s" id="%3$s" %4$s><label for="%3$s">%5$s</label>', $input_name, $esc_value, $id, $checked, $super_filtered[0] );
}

global $product;

$attribute_keys = array_keys( $attributes );

do_action( 'woocommerce_before_add_to_cart_form' ); ?>

<form class="variations_form cart" method="post" enctype='multipart/form-data' data-product_id="<?php echo absint( $product->id ); ?>" data-product_variations="<?php echo htmlspecialchars( json_encode( $available_variations ) ) ?>">
    <?php do_action( 'woocommerce_before_variations_form' ); ?>

    <?php if ( empty( $available_variations ) && false !== $available_variations ) : ?>
        <p class="stock out-of-stock"><?php _e( 'Acest produs este momentan indisponibil și nu se află în stoc.', 'woocommerce' ); ?></p>
    <?php else : ?>
        <table class="variations" cellspacing="0">
            <tbody>
                <?php foreach ( $attributes as $name => $options ) : ?>
                    <tr>
                        <td class="label" style="margin-top: -10px;"><label for="<?php echo sanitize_title( $name ); ?>"><?php echo wc_attribute_label( $name ); ?></label></td>
                        <?php
                        $sanitized_name = sanitize_title( $name );
                        if ( isset( $_REQUEST[ 'attribute_' . $sanitized_name ] ) ) {
                            $checked_value = $_REQUEST[ 'attribute_' . $sanitized_name ];
                        } elseif ( isset( $selected_attributes[ $sanitized_name ] ) ) {
                            $checked_value = $selected_attributes[ $sanitized_name ];
                        } else {
                            $checked_value = '';
                        }
                        ?>
                        <td class="value" style="margin-top: -30px;">

                            <?php
                            if ( ! empty( $options ) ) {
                                if ( taxonomy_exists( $name ) ) {
                                    // Obține termenii dacă aceasta este o taxonomie - ordonată. Avem nevoie și de nume.
                                    $terms = wc_get_product_terms( $product->id, $name, array( 'fields' => 'all' ) );

                                    foreach ( $terms as $term ) {
                                        if ( ! in_array( $term->slug, $options ) ) {
                                            continue;
                                        }
                                        print_attribute_radio( $checked_value, $term->slug, $term->name, $sanitized_name );

                                    }
                                } else {

                                    foreach ( $options as $key=>$option ) {
                                        print_attribute_radio( $checked_value, $option, $option, $sanitized_name );
                                        $product_variations = $product->get_available_variations();
                                        $variation_product_id = $product_variations [$key]['variation_id'];
                                        $product_price = get_product_variation_price($variation_product_id);
                                        printf ('%1$s</div> ', $product_price);
                                    }


                                }
                            }

                            echo end( $attribute_keys ) === $name ? apply_filters( 'woocommerce_reset_variations_link', '<a class="reset_variations" href="#">' . __( 'Șterge', 'woocommerce' ) . '</a>' ) : '';
                            ?>
                        </td>
                    </tr>
                <?php endforeach; ?>
            </tbody>
        </table>

        <?php do_action( 'woocommerce_before_add_to_cart_button' ); ?>

        <div class="single_variation_wrap">
            <?php do_action( 'woocommerce_before_single_variation' ); ?>

            <?php
            if ( has_action( 'woocommerce_single_variation' ) ) {
                do_action( 'woocommerce_single_variation' );
            } else {
                // Compatibilitate cu versiuni WC < 2.4
            ?>
                <div class="woocommerce-variation single_variation"></div>

                <div class="woocommerce-variation-add-to-cart variations_button">
                    <?php if ( ! $product->is_sold_individually() ) : ?>
                        <?php woocommerce_quantity_input( array( 'input_value' => isset( $_POST['quantity'] ) ? wc_stock_amount( $_POST['quantity'] ) : 1 ) ); ?>
                    <?php endif; ?>
                    <button type="submit" class="single_add_to_cart_button button alt otto"><?php echo esc_html( $product->single_add_to_cart_text() ); ?></button>
                    <input type="hidden" name="add-to-cart" value="<?php echo absint( $product->id ); ?>" />
                    <input type="hidden" name="product_id" value="<?php echo absint( $product->id ); ?>" />
                    <input type="hidden" name="variation_id" class="variation_id" value="0" />
                </div>
            <?php } ?>

            <?php do_action( 'woocommerce_after_single_variation' ); ?>
        </div>

        <?php do_action( 'woocommerce_after_add_to_cart_button' ); ?>

    <?php endif; ?>

    <?php do_action( 'woocommerce_after_variations_form' ); ?>

</form>

<?php do_action( 'woocommerce_after_add_to_cart_form' ); ?>
14 aug. 2016 22:19:02