Include pre-order products in the ‘Crosssell’ section of the pop-up add to cart

This topic has 4 replies, 2 voices, and was last updated 7 months, 2 weeks ago ago by Luca Rossi

  • Avatar: MediaPixel.eu
    Alex
    Participant
    April 8, 2024 at 19:42

    How can we include pre-order products in the ‘Crosssell’ section of the pop-up add to cart content? These Crosssell products appear in the Cart Page, but not in the Pop-up Add to Cart

    3 Answers
    Avatar: Justin
    Luca Rossi
    Support staff
    April 9, 2024 at 09:09

    Hi @Alex,

    Please navigate to Theme Options > WooCommerce(Shop) > Shop > Shop Page Layout > scroll down at the bottom you will see POPUP NOTIFICATION section > Linked Products Type select Cross-sells:

    https://prnt.sc/RZnxNq05jBGt

    Also make sure that you’ve already setup the Cross-sells for each product:

    https://prnt.sc/dPlkjAx2-_sO

    Hope it helps!

    Avatar: MediaPixel.eu
    Alex
    Participant
    April 10, 2024 at 14:40

    Hi,
    The products are checked in cross-sell, but I believe there is a condition that the stock > 1.
    The products with stock are displayed correctly in the “pop-up add to cart”

    The products are marked as “backorder” with zero stock, but they can still be ordered.
    These are the products that I want to appear in “pop-up add to cart”

    Thanks.

    Avatar: Justin
    Luca Rossi
    Support staff
    April 10, 2024 at 16:11

    Hi @Alex,

    Please create a new PHP file in your child theme: xstore-child/woocommerce/product-added-to-cart.php with the following code:

    
    <?php
    /**
     * Description
     *
     * @package    product-added-to-cart.php
     * @since      1.0.0
     * @author     Stas
     * @link       http://xstore.8theme.com
     * @license    Themeforest Split Licence
     */
    
    $cart = WC()->cart->get_cart();
    
    if ( ! $cart ) return;
    
    remove_filter( 'wp_get_attachment_image_attributes', 'etheme_lazy_attachment_attrs', 10, 3 );
    
    $cart_item = $cart[$cart_current_item_key];
    
    $_product   = apply_filters( 'woocommerce_cart_item_product', $cart_item['data'], $cart_item, $cart_current_item_key );
    
    $product_id = apply_filters( 'woocommerce_cart_item_product_id', $cart_item['product_id'], $cart_item, $cart_current_item_key );
    
    $product_permalink = apply_filters( 'woocommerce_cart_item_permalink', $_product->is_visible() ? $_product->get_permalink( $cart_item ) : '', $cart_item, $cart_current_item_key );
    
    $product_name = apply_filters( 'woocommerce_cart_item_name', $_product->get_name(), $cart_item, $cart_current_item_key );
    
    $element_options = array();
    
    ob_start();
    
    wc_print_notice( wp_kses_post( apply_filters( 'woocommerce_cart_item_name', $product_name, $cart_item, $cart_current_item_key ) . ' ' . esc_html__('has been added to your cart.', 'xstore' ) ) );
    
    ?>
    
    <table class="shop_table shop_table_responsive" cellspacing="0">
        <tbody>
            <tr class="woocommerce-cart-form__cart-item woocommerce-mini-cart-item <?php echo esc_attr( apply_filters( 'woocommerce_cart_item_class', 'cart_item', $cart_item, $cart_current_item_key ) ); ?>" data-key="<?php echo esc_attr($cart_current_item_key); ?>">
                <td class="product-name col-md-3" data-title="<?php esc_attr_e( 'Product', 'xstore' ); ?>">
                    <div class="product-thumbnail">
    			        <?php
    			        $thumbnail = apply_filters( 'woocommerce_cart_item_thumbnail', $_product->get_image(), $cart_item, $cart_current_item_key );
    			
    			        if ( ! $_product->is_visible() || ! $product_permalink){
    				        echo wp_kses_post( $thumbnail );
    			        } else {
    				        printf( '<a href="%s">%s</a>', esc_url( $product_permalink ), $thumbnail );
    			        }
    			        ?>
                    </div>
                </td>
                <td class="product-details col-md-9">
                    <div class="cart-item-details align-start">
                        
                        <h4 class="product-title">
                            <?php
                                if ( ! $_product->is_visible() || ! $product_permalink  ){
                                    echo wp_kses_post( apply_filters( 'woocommerce_cart_item_name', $product_name, $cart_item, $cart_current_item_key ) );
                                } else {
                                    echo wp_kses_post( apply_filters( 'woocommerce_cart_item_name', sprintf( '<a href="%s" class="product-title">%s</a>', esc_url( $product_permalink ) , $product_name ), $cart_item, $cart_current_item_key ) );
                                }
                            ?>
                        </h4>
                        
                        <?php
    			
    			        do_action( 'woocommerce_after_cart_item_name', $cart_item, $cart_current_item_key );
    			
    			        // Meta data
    			        echo wc_get_formatted_cart_item_data( $cart_item );
    			
    			        // Backorder notification
    			        if ( $_product->backorders_require_notification() && $_product->is_on_backorder( $cart_item['quantity'] ) )
    				        echo wp_kses_post( apply_filters( 'woocommerce_cart_item_backorder_notification', '<p class="backorder_notification">' . esc_html__( 'Available on backorder', 'xstore' ) . '</p>', $product_id ) );
    			        ?>
    			        <?php
    			        echo apply_filters( 'woocommerce_cart_item_remove_link', sprintf(
    				        '<a href="%s" class="remove remove_from_cart_button text-underline block popup-remove-from-cart" aria-label="%s" data-product_id="%s" data-cart_item_key="%s" data-product_sku="%s">%s</a>',
    				        esc_url( wc_get_cart_remove_url( $cart_current_item_key ) ),
                            /* translators: %s is the product name */
                            esc_attr( sprintf( __( 'Remove %s from cart', 'xstore' ), $product_name ) ),
    				        esc_attr( $product_id ),
    				        esc_attr( $cart_current_item_key ),
    				        esc_attr( $_product->get_sku() ),
    				        esc_html__('Remove', 'xstore')
    			        ), $cart_current_item_key );
    			        ?>
                    </div>
    
                    <div class="product-quantity align-start">
    		            <?php
    		            if ( ! $_product->is_sold_individually() && $_product->is_purchasable() ) {
    			            remove_action( 'woocommerce_before_quantity_input_field', 'et_quantity_minus_icon' );
    			            remove_action( 'woocommerce_after_quantity_input_field', 'et_quantity_plus_icon' );
    			            add_action( 'woocommerce_before_quantity_input_field', 'et_quantity_minus_icon' );
    			            add_action( 'woocommerce_after_quantity_input_field', 'et_quantity_plus_icon' );
    			            echo '<div class="quantity-wrapper clearfix">';
                                woocommerce_quantity_input(
                                    array(
                                        'input_value' => $cart_item['quantity'],
                                        'min_value'   => apply_filters( 'woocommerce_quantity_input_min', $_product->get_min_purchase_quantity(), $_product ),
                                        'max_value'   => apply_filters( 'woocommerce_quantity_input_max', $_product->get_max_purchase_quantity(), $_product ),
                                    ),
                                    $_product
                                );
                                remove_action( 'woocommerce_before_quantity_input_field', 'et_quantity_minus_icon' );
                                remove_action( 'woocommerce_after_quantity_input_field', 'et_quantity_plus_icon' );
                                echo '<span class="quantity">' . ' &times; ' .
                                         apply_filters( 'woocommerce_cart_item_price', WC()->cart->get_product_price( $_product ), $cart_item, $cart_current_item_key ) .
                                     '</span>';
    			            echo '</div>';
    		            }
    		            ?>
    		
                    </div>
    	
    	            <?php
                        if ( in_array('popup_added_to_cart', (array)get_theme_mod('product_sku_locations', array('cart', 'popup_added_to_cart', 'mini-cart'))) && wc_product_sku_enabled() ) {
                            add_filter('product_meta_elements', function () {
                                return array('sku');
                            });
                            global $product;
                            $product = $_product;
                            woocommerce_template_single_meta();
                        }
    	            ?>
                    
                </td>
            </tr>
            <tr class="order-total">
                <th><?php esc_html_e('Subtotal', 'xstore'); ?></th>
                <?php echo
                    '<td data-title="'.esc_attr('Subtotal', 'xstore') . '">' .
                           apply_filters( 'woocommerce_cart_item_subtotal',
                               WC()->cart->get_product_subtotal( $_product, $cart_item['quantity'] ),
                               $cart_item, $cart_current_item_key ) .
                    '</td>'; ?>
            </tr>
        </tbody>
    </table>
    
    <?php do_action('etheme_product_added_to_cart_section_01'); ?>
        
    <?php $element_options['product_section_01'] = ob_get_clean();
    
    ob_start(); ?>
    
        <a class="flex-inline btn light big et-close-mfp mob-hide"><i class="et-icon et_b-icon et-left-arrow-2"></i><span><?php esc_html_e('Back to shop','xstore'); ?></span></a>
    <a class="flex-inline btn light big" href="<?php echo wc_get_cart_url(); ?>"><?php esc_html_e('View Cart','xstore'); ?></a>
    <a class="flex-inline btn black big" href="<?php echo wc_get_checkout_url(); ?>"><?php esc_html_e('Checkout','xstore'); ?></a>
    
    <?php do_action('etheme_product_added_to_cart_section_02');
    
    if ( get_theme_mod('ajax_added_product_notify_popup_progress_bar', false) ) {
        echo do_shortcode('[etheme_sales_booster_cart_checkout_progress_bar]');
    }
    
    $element_options['product_section_02'] = ob_get_clean();
    
    $element_options['linked_products_ids'] = array();
    $element_options['linked_products_ids']['upsell_ids'] = array();
    $element_options['linked_products_ids']['upsell_ids_not_in'] = array();
    
    $element_options['linked_products_ids']['cross-sell_ids'] = array();
    $element_options['linked_products_ids']['cross-sell_ids_not_in'] = array();
    
    $cart_content_linked_products_type = get_theme_mod('ajax_added_product_notify_popup_products_type', 'upsell');
    
    if ( $cart_content_linked_products_type != 'none' ) {
    	$_product_linked     = $_product;
    	$_product_4_linked_ids = array( $product_id );
    	if ( $_product->get_type() == 'variation' ) {
    		$parent_id               = $_product->get_parent_id();
    		$_product_4_linked_ids[] = $parent_id;
    		$_product_linked       = wc_get_product( $parent_id );
    	}
    	
    	if ( $cart_content_linked_products_type == 'upsell' ) {
    		
    		$element_options['linked_products_ids']['upsell_ids']        =
    			array_merge( $element_options['linked_products_ids']['upsell_ids'], array_map( 'absint', $_product_linked->get_upsell_ids() ) );
    		$element_options['linked_products_ids']['upsell_ids_not_in'] =
    			array_merge( $element_options['linked_products_ids']['upsell_ids_not_in'], $_product_4_linked_ids );
    		
    	}
    	else {
    		$element_options['linked_products_ids']['cross-sell_ids']        =
    			array_merge( $element_options['linked_products_ids']['cross-sell_ids'], array_map( 'absint', $_product_linked->get_cross_sell_ids() ) );
    		$element_options['linked_products_ids']['cross-sell_ids_not_in'] =
    			array_merge( $element_options['linked_products_ids']['cross-sell_ids_not_in'], $_product_4_linked_ids );
    	}
    }
    
     ob_start();
    global $woocommerce_loop;
    add_filter('etheme_product_content_settings', function ($args){
        return
            array(
                'product_page_productname',
                'product_page_price',
                'product_page_addtocart'
            );
    });
    
    do_action('etheme_product_added_popup');
    $woocommerce_loop['popup-added-to-cart'] = true;
    $woocommerce_loop['product_view'] = 'disable';
        et_mini_cart_linked_products(
                $cart_content_linked_products_type,
                $element_options['linked_products_ids'],
                array(
                    'as_widget' => false,
                    'slides_per_view' => get_theme_mod('ajax_added_product_notify_popup_products_per_view_et-desktop', 4),
                    'slides_per_view_mobile' => 2,
                    'hide_out_stock' => false
                )
        );
    unset($woocommerce_loop['product_view']);
    unset($woocommerce_loop['popup-added-to-cart']);
    
    do_action( 'etheme_product_added_to_cart_section_03' );
    
    $element_options['product_section_03'] = str_replace('carousel-area', '', ob_get_clean());
    
        echo json_encode(
            array(
                'product_section_01'       => $element_options['product_section_01'],
                'product_section_02'       => $element_options['product_section_02'],
                'product_section_03'       => $element_options['product_section_03'],
            )
        );
    
    

    Hope it helps!

  • Viewing 4 results - 1 through 4 (of 4 total)

You must be logged in to reply to this topic.Log in/Sign up

8theme customization service
We're using our own and third-party cookies to improve your experience and our website. Keep on browsing to accept our cookie policy.