• Вопрос без рабочей ссылки на проблему считается риторическим. Без ссылки и скриншота - провокацией!
  • Темы озаглавленные с маленькой буквы или капсом удаляются без предупреждения!

Вывод счетчика количества товара для вариативных товаров в каталоге WooCommerce

pizzabox

Новичок
#1
Всем привет! Спецы спасайте! Задача вывести счетчик количества товара для вариативных товаров в каталог WooCommerce. На просторах интернета нашел кучу сниппетов и плагинов для того, чтобы вывести счетчик для обычных товаров, но вот для вариативных они не подходят и я нашел только один подходящий:
Код:
<?php
// Display variations dropdowns on shop page for variable products
 add_filter( 'woocommerce_loop_add_to_cart_link', 'woo_display_variation_dropdown_on_shop_page' );
 
 function woo_display_variation_dropdown_on_shop_page() {
    
     global $product;
    if( $product->is_type( 'variable' )) {
    
    $attribute_keys = array_keys( $product->get_attributes() );
    ?>
    
    <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( $product->get_available_variations() ) ) ?>">
        <?php do_action( 'woocommerce_before_variations_form' ); ?>
    
        <?php if ( empty( $product->get_available_variations() ) && false !== $product->get_available_variations() ) : ?>
            <p class="stock out-of-stock"><?php _e( 'This product is currently out of stock and unavailable.', 'woocommerce' ); ?></p>
        <?php else : ?>
            <table class="variations" cellspacing="0">
                <tbody>
                    <?php foreach ( $product->get_attributes() as $attribute_name => $options ) : ?>
                        <tr>
                            <td class="label"><label for="<?php echo sanitize_title( $attribute_name ); ?>"><?php echo wc_attribute_label( $attribute_name ); ?></label></td>
                            <td class="value">
                                <?php
                                    $selected = isset( $_REQUEST[ 'attribute_' . sanitize_title( $attribute_name ) ] ) ? wc_clean( urldecode( $_REQUEST[ 'attribute_' . sanitize_title( $attribute_name ) ] ) ) : $product->get_variation_default_attribute( $attribute_name );
                                    wc_dropdown_variation_attribute_options( array( 'options' => $options, 'attribute' => $attribute_name, 'product' => $product, 'selected' => $selected ) );
                                    echo end( $attribute_keys ) === $attribute_name ? apply_filters( 'woocommerce_reset_variations_link', '<a class="reset_variations" href="#">' . __( 'Clear', 'woocommerce' ) . '</a>' ) : '';
                                ?>
                            </td>
                        </tr>
                    <?php endforeach;?>
                </tbody>
            </table>
    
            <?php do_action( 'woocommerce_before_add_to_cart_button' ); ?>
    
            <div class="single_variation_wrap">
                <?php
                    /**
                     * woocommerce_before_single_variation Hook.
                     */
                    do_action( 'woocommerce_before_single_variation' );
    
                    /**
                     * woocommerce_single_variation hook. Used to output the cart button and placeholder for variation data.
                     * @since 2.4.0
                     * @hooked woocommerce_single_variation - 10 Empty div for variation data.
                     * @hooked woocommerce_single_variation_add_to_cart_button - 20 Qty and cart button.
                     */
                    do_action( 'woocommerce_single_variation' );
    
                    /**
                     * woocommerce_after_single_variation Hook.
                     */
                    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 } else {
        
    echo sprintf( '<a rel="nofollow" href="%s" data-quantity="%s" data-product_id="%s" data-product_sku="%s" class="%s">%s</a>',
            esc_url( $product->add_to_cart_url() ),
            esc_attr( isset( $quantity ) ? $quantity : 1 ),
            esc_attr( $product->id ),
            esc_attr( $product->get_sku() ),
            esc_attr( isset( $class ) ? $class : 'button' ),
            esc_html( $product->add_to_cart_text() )
        );
    
    }
    
}
Если точнее, то в этот сниппет позволяет вывести атрибуты товара и счетчик в каталог, но мне нужен фрагмент, который позволяет вывести только счетчик для вариативного товара в каталоге. Нужно правильно выдернуть эту часть кода. Я не могу грамотно прописать нужную часть кода в functions.php, чтобы все работало без ошибок. Прошу помочь друзья.
 

rikitiki

Специалист
Местный
#2
Какой же это вариативный товар, если атрибуты отображаться не будут.
Попробуйте плагин :
https://wordpress.org/plugins/woocommerce-ajax-add-to-cart-for-variable-products/
В категориях у вариативных товаров появится кнопка Добавить в корзину, счётчик и атрибуты. И ещё Ajiax работать будет.
Возможно, покопавшись в плагине, удалите атрибуты.
 
Последнее редактирование:

pizzabox

Новичок
#3
Какой же это вариативный товар, если атрибуты отображаться не будут.
Попробуйте плагин :
https://wordpress.org/plugins/woocommerce-ajax-add-to-cart-for-variable-products/
В категориях у вариативных товаров появится кнопка Добавить в корзину, счётчик и атрибуты. И ещё Ajiax работать будет.
Возможно, покопавшись в плагине, удалите атрибуты.
Спасибо за ответ, но к сожалению не помогло( Возможно особенность темы
 

falkor81

Новичок
#4
Можно сделать на Woocommerce выбор вариации товаров в самом каталоге как тут только это пример с опен карта http://prntscr.com/mb4k7k . Что бы при выборе по весу и количеству товара сразу менялась в каталоге цена и была сразу кнопка добавить в корзину.
 

falkor81

Новичок
#5
Частично вопрос решил вывел выбор вариативного товара в каталоге с помощью этого хука в functions.php

add_filter('woocommerce_loop_add_to_cart_link', 'variation_on_category');

function variation_on_category(){

global $product;

if ($product->is_type('variable')) {

// Enqueue variation scripts.
wp_enqueue_script('wc-add-to-cart-variation');

// Get Available variations?
$get_variations = count($product->get_children()) <= apply_filters('woocommerce_ajax_variation_threshold', 30, $product);
$available_variations = $get_variations ? $product->get_available_variations() : false;
$attributes = $product->get_variation_attributes();
$selected_attributes = $product->get_default_attributes();
$attribute_keys = array_keys($attributes);
?>

<form class="variations_form cart"
action="<?php echo esc_url(apply_filters('woocommerce_add_to_cart_form_action', $product->get_permalink())); ?>"
method="post" enctype='multipart/form-data' data-product_id="<?php echo absint($product->get_id()); ?>"
data-product_variations="<?php echo htmlspecialchars(wp_json_encode($available_variations)); // WPCS: XSS ok. ?>">
<?php do_action('woocommerce_before_variations_form'); ?>

<?php if (empty($available_variations) && false !== $available_variations) : ?>
<p class="stock out-of-stock"><?php esc_html_e('This product is currently out of stock and unavailable.', 'woocommerce'); ?></p>
<?php else : ?>
<table class="variations" cellspacing="0">
<tbody>
<?php foreach ($attributes as $attribute_name => $options) : ?>
<tr>
<td class="label"><label
for="<?php echo esc_attr(sanitize_title($attribute_name)); ?>"><?php echo wc_attribute_label($attribute_name); // WPCS: XSS ok. ?></label>
</td>
<td class="value">
<?php
wc_dropdown_variation_attribute_options(array(
'options' => $options,
'attribute' => $attribute_name,
'product' => $product,
));
echo end($attribute_keys) === $attribute_name ? wp_kses_post(apply_filters('woocommerce_reset_variations_link', '<a class="reset_variations" href="#">' . esc_html__('Clear', 'woocommerce') . '</a>')) : '';
?>
</td>
</tr>
<?php endforeach; ?>
</tbody>
</table>

<div class="single_variation_wrap">
<?php
/**
* Hook: woocommerce_before_single_variation.
*/
do_action('woocommerce_before_single_variation');

/**
* Hook: woocommerce_single_variation. Used to output the cart button and placeholder for variation data.
*
* @since 2.4.0
* @hooked woocommerce_single_variation - 10 Empty div for variation data.
* @hooked woocommerce_single_variation_add_to_cart_button - 20 Qty and cart button.
*/
do_action('woocommerce_single_variation');

/**
* Hook: woocommerce_after_single_variation.
*/
do_action('woocommerce_after_single_variation');
?>
</div>
<?php endif; ?>

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

<?php } else {

$args = array();
$defaults = array(
'quantity' => 1,
'class' => implode(' ', array_filter(array(
'button',
'product_type_' . $product->get_type(),
$product->is_purchasable() && $product->is_in_stock() ? 'add_to_cart_button' : '',
$product->supports('ajax_add_to_cart') ? 'ajax_add_to_cart' : '',
))),
'attributes' => array(
'data-product_id' => $product->get_id(),
'data-product_sku' => $product->get_sku(),
'aria-label' => $product->add_to_cart_description(),
'rel' => 'nofollow',
),
);

$args = wp_parse_args($args, $defaults);

if (isset($args['attributes']['aria-label'])) {
$args['attributes']['aria-label'] = strip_tags($args['attributes']['aria-label']);
}

echo sprintf('<a href="%s" data-quantity="%s" class="%s" %s>%s</a>',
esc_url($product->add_to_cart_url()),
esc_attr(isset($args['quantity']) ? $args['quantity'] : 1),
esc_attr(isset($args['class']) ? $args['class'] : 'button'),
isset($args['attributes']) ? wc_implode_html_attributes($args['attributes']) : '',
esc_html($product->add_to_cart_text())
);

}
}
 

falkor81

Новичок
#6
Остался такой вопрос при выборе вариативного товара в каталоге как сделать чтобы товар сразу добавлялся в корзину?
 

falkor81

Новичок
#7
Нашел ответ кому нужно пользуйтесь. Это хук для добавления вариативного товара с категории
add_filter( 'woocommerce_add_to_cart_redirect', 'antondrob_redirect_checkout_add_cart' );
function antondrob_redirect_checkout_add_cart( $url ) {
if( !is_product() ){
$url = wp_get_referer();
return $url;
}
}


проследите чтобы эти чекбоксы были отключены
http://prntscr.com/mj3bos
 
Сверху Снизу