AlkantarClanX12
Current Path : /home/thanudqk/www/wp-content/plugins/thegem-elements/inc/ |
Current File : /home/thanudqk/www/wp-content/plugins/thegem-elements/inc/product-grid.php |
<?php // Print Products Grid Extended function thegem_products_grid_extended($params) { global $post; $portfolio_posttemp = $post; wp_enqueue_script('thegem-woocommerce'); wp_enqueue_style('thegem-portfolio-products-extended'); if (!wp_script_is('thegem-portfolio-grid-extended')) { wp_enqueue_script('thegem-portfolio-grid-extended'); wp_add_inline_script( 'thegem-portfolio-grid-extended', "jQuery('.extended-products-grid .yith-icon').each(function () { var addIcon = jQuery(this).children('.add-wishlist-icon').clone(); var addedIcon = jQuery(this).children('.added-wishlist-icon').clone(); jQuery(this).find('a i').remove(); jQuery(this).find('a svg').remove(); jQuery(this).find('.yith-wcwl-add-button a:not(.delete_item)').prepend(addIcon); jQuery(this).find('.yith-wcwl-add-button a.delete_item').prepend(addedIcon); jQuery(this).find('.yith-wcwl-wishlistexistsbrowse a').prepend(addedIcon); jQuery(this).find('a').addClass('icon'); jQuery(this).find('a.gem-button').removeAttr('class').removeAttr('style').removeAttr('onmouseleave').removeAttr('onmouseenter').addClass('icon'); jQuery(this).find('.yith-wcwl-wishlistaddedbrowse a').prepend(addedIcon); });" ); } $widget_uid = $params['portfolio_uid']; $style_uid = substr(md5(rand()), 0, 7); $params['style_uid'] = $style_uid; if ($params['layout_type'] == 'list') { $params['extended_grid_skin'] = 'below-default-cart-button'; $params['layout'] = 'justified'; $params['columns_desktop'] = $params['columns_desktop_list']; $params['columns_tablet'] = $params['columns_tablet_list']; $params['columns_mobile'] = '1x'; $params['image_aspect_ratio'] = $params['image_aspect_ratio_list']; $params['caption_position'] = 'page'; $params['ignore_highlights'] = '1'; $params['add_to_cart_type'] = 'button'; $params['caption_container_alignment'] = !empty($params['caption_container_alignment']) ? $params['caption_container_alignment'] : 'default'; } $is_archive_template = false; if ( $params['source_type'] == 'archive' && (is_tax( 'product_cat' ) || is_tax( 'product_tag' ) || is_post_type_archive( 'product' )) ) { $is_archive_template = true; } if ($params['filters_type'] == 'filter_woo') { $params['filters_scroll_top'] = $params['woo_filters_scroll_top']; $params['sidebar_position'] = $params['woo_sidebar_position']; } $queried = get_queried_object(); if ( is_tax( 'product_cat' ) && $params['source_type'] == 'archive' ) { $params['select_products_categories'] = '1'; $params['content_products_cat'] = $queried->slug; } $grid_uid = $is_archive_template ? '' : $widget_uid; $grid_uid_url = $is_archive_template ? '' : $widget_uid.'-'; $params['portfolio_uid'] = $widget_uid; if ($params['source_type'] == 'archive') { if ( is_tax( 'product_tag' )) { $params['select_products_tags'] = '1'; $params['content_products_tags'] = array($queried->slug); } else if (isset($queried->taxonomy)) { $params['select_products_tax'] = $queried->taxonomy; $params['content_products_tax'] = array($queried->slug); } } $post__in = null; $is_related_upsell = false; if ($params['source_type'] == 'related_upsell') { $product = thegem_templates_init_product(); if (empty($product)) { $post = $portfolio_posttemp; return; } $is_related_upsell = true; if ($params['related_upsell_source'] == 'related') { $related_products = wc_get_related_products($product->get_id(), -1); $post__in = $related_products; } else { global $thegem_product_data; $upsells = $product->get_upsell_ids(); if(intval($thegem_product_data['product_page_elements_upsell_items']) > -1) { $upsells = array_slice($upsells, 0, intval($thegem_product_data['product_page_elements_upsell_items'])); } $post__in = $upsells; } $params['select_products'] = '1'; $params['content_products'] = implode(",", $post__in); if (empty($post__in) && !is_admin()) { $post = $portfolio_posttemp; return; } } else if ($params['source_type'] == 'cross_sell') { $cross_sells_ids_in_cart = array(); if (WC()->cart) { foreach ( WC()->cart->get_cart() as $cart_item ) { if ( $cart_item['quantity'] > 0 ) { $cross_sells_ids_in_cart = array_merge( $cart_item['data']->get_cross_sell_ids(), $cross_sells_ids_in_cart ); } } } $cross_sells = wp_parse_id_list( $cross_sells_ids_in_cart ); $post__in = $cross_sells; $params['select_products'] = '1'; $params['content_products'] = implode(",", $post__in); if (empty($post__in) && !is_admin()) { $post = $portfolio_posttemp; return; } } if (isset($params['attribute_swatches']) && $params['attribute_swatches'] == '1' && ($params['attribute_swatches_desktop'] == '1' || $params['attribute_swatches_tablet'] == '1' || $params['attribute_swatches_mobile'] == '1')) { $params['attribute_swatches'] = $params['attribute_swatches_desktop']; $params['repeater_swatches'] = vc_param_group_parse_atts($params['repeater_swatches']); wp_enqueue_script('wc-add-to-cart-variation'); } else { $params['attribute_swatches'] = ''; $params['attribute_swatches_tablet'] = ''; $params['attribute_swatches_mobile'] = ''; } $localize = array( 'data' => $params, 'action' => 'extended_products_grid_load_more', 'url' => admin_url('admin-ajax.php'), 'nonce' => wp_create_nonce('extended_products_grid_ajax-nonce') ); wp_localize_script('thegem-portfolio-grid-extended', 'thegem_portfolio_ajax_' . $style_uid, $localize); $normal_filter = true; $native_ajax = false; if ($params['filters_type'] == 'filter_woo') { $normal_filter = false; $params['filters_style'] = $params['woo_filters_style']; if ($params['woo_ajax_filtering']) { $native_ajax = true; } } if ($params['select_products_categories'] == '1') { $categories = explode(",", $params['content_products_cat']); } else { $categories = ['0']; } $cat_args = array( 'hide_empty' => true, 'orderby' => $params['filter_by_categories_order_by'] ); if ($params['filter_by_categories_order_by'] == 'term_order') { $cat_args['orderby'] = 'meta_value_num'; $cat_args['meta_key'] = 'order'; } if (in_array('0', $categories)) { if ($params['filter_by_categories_hierarchy'] == '1') { $cat_args['parent'] = 0; } } else { $cat_args['slug'] = $categories; } $terms = get_terms('product_cat', $cat_args); $categories_filter = null; if (!empty($_GET[$grid_uid_url . 'category'])) { $active_cat = $_GET[$grid_uid_url . 'category']; $categories_current = [$active_cat]; $categories_filter = $active_cat; } else if (is_tax('product_cat') && $params['source_type'] == 'archive') { $active_cat = $queried->slug; $categories_current = [$active_cat]; $cat_args['slug'] = []; $cat_args['parent'] = $queried->term_id; $terms = get_terms('product_cat', $cat_args); } else { $active_cat = 'all'; $categories_current = $categories; } $attributes = []; if ($params['select_products_attributes'] == '1') { if (!empty($params['content_products_attr'])) { $attrs = explode(",", $params['content_products_attr']); if ($attrs) { foreach ($attrs as $attr) { $values = explode(",", $params['content_products_attr_val_' . $attr]); if (in_array('0', $values) || empty($values)) { $values = get_terms('pa_' . $attr, array('fields' => 'slugs')); } $attributes[$attr] = $values; } } } else if (!empty($params['content_products_attr_val'])) { $attrs = explode(", ", $params['content_products_attr_val']); if ($attrs) { foreach ($attrs as $attr) { $attr_arr = explode("|", $attr); if ($attr_arr[1] == 'all') { $values = get_terms('pa_' . $attr_arr[0], array('fields' => 'slugs')); } else { if (isset($attributes[$attr_arr[0]])) { if (!in_array($attr_arr[1], $attributes[$attr_arr[0]])) { $values = array_push($attributes[$attr_arr[0]], $attr_arr[1]); } else { $values = false; } } else { $values = [$attr_arr[1]]; } } if ($values) { $attributes[$attr_arr[0]] = $values; } } } } } $attributes_url = []; $has_attr_url = false; $attributes_list = get_woo_attribute_productGrid(); foreach ($attributes_list as $name => $attr) { if (!empty($_GET[$grid_uid_url . 'filter_' . $attr])) { $attributes_url[$attr] = explode(",", $_GET[$grid_uid_url . 'filter_' . $attr]); $has_attr_url = true; } } $attributes_filter = null; if ($has_attr_url) { $attributes_current = $attributes_url; $attributes_filter = $attributes_url; } else { $attributes_current = $attributes; } $active_tag = $products_tax = $products_tax_value = null; if ($params['select_products_tags'] == '1') { $active_tag = explode(",", $params['content_products_tags']); } if (!empty($params['select_products_tax'])) { $products_tax = $params['select_products_tax']; $products_tax_value = $params['content_products_tax']; } if ($params['select_products'] == '1') { $post__in = explode(",", $params['content_products']); } if ($params['caption_position'] == 'image') { $hover_effect = $params['image_hover_effect_image']; } else if ($params['caption_position'] == 'page') { $hover_effect = $params['image_hover_effect_page']; } else { $hover_effect = $params['image_hover_effect_hover']; } if ( $params['layout_type'] == 'list') { $hover_effect = 'list-' . $hover_effect; } wp_enqueue_style('thegem-hovers-' . $hover_effect); if ($params['pagination_type'] == 'more') { wp_enqueue_style('thegem-button'); } else if ($params['pagination_type'] == 'scroll') { wp_enqueue_script('thegem-scroll-monitor'); } if ($params['quick_view'] == '1') { wp_enqueue_script('wc-single-product'); wp_enqueue_script('wc-add-to-cart-variation'); wp_enqueue_script('thegem-product-quick-view'); wp_enqueue_script('thegem-quick-view'); wp_enqueue_style('thegem-quick-view'); if(thegem_get_option('product_page_layout') == 'default') { if(thegem_get_option('product_page_button_add_to_cart_icon') && thegem_get_option('product_page_button_add_to_cart_icon_pack')) { wp_enqueue_style('icons-'.thegem_get_option('product_page_button_add_to_cart_icon_pack')); } if(thegem_get_option('product_page_button_add_to_wishlist_icon') && thegem_get_option('product_page_button_add_to_wishlist_icon_pack')) { wp_enqueue_style('icons-'.thegem_get_option('product_page_button_add_to_wishlist_icon_pack')); } if(thegem_get_option('product_page_button_added_to_wishlist_icon') && thegem_get_option('product_page_button_added_to_wishlist_icon_pack')) { wp_enqueue_style('icons-'.thegem_get_option('product_page_button_added_to_wishlist_icon_pack')); } } if (thegem_get_option('product_gallery') != 'legacy') { wp_enqueue_style('thegem-product-gallery'); } else { wp_enqueue_style('thegem-hovers'); } } if ($params['product_show_filter'] === '1') { wp_enqueue_script('jquery-dlmenu'); if ($params['filter_by_price'] === '1') { wp_enqueue_script('wc-jquery-ui-touchpunch'); } } if ($params['loading_animation'] === '1') { wp_enqueue_style('thegem-animations'); wp_enqueue_script('thegem-items-animations'); wp_enqueue_script('thegem-scroll-monitor'); } if ($params['layout'] !== 'justified' || $params['ignore_highlights'] !== '1') { if ($params['layout'] == 'metro') { wp_enqueue_script('thegem-isotope-metro'); } else { wp_enqueue_script('thegem-isotope-masonry-custom'); } } if ( $params['sidebar_sticky'] || $params['woo_sidebar_sticky'] ) { wp_enqueue_script( 'thegem-sticky' ); } $items_per_page = intval($params['items_per_page']); if ($items_per_page == 0) { $items_per_page = 8; } $page = 1; $next_page = 0; if (!empty($_GET[$grid_uid_url . 'page'])) { $page = $_GET[$grid_uid_url . 'page']; } if (!empty($_GET[$grid_uid_url . 'orderby'])) { $orderby = $_GET[$grid_uid_url . 'orderby']; $order = 'desc'; $sortby = $orderby; if ($sortby == 'price' || $sortby == 'title') { $order = 'asc'; } } else { $orderby = $params['orderby']; $order = $params['order']; $sortby = 'default'; } $featured_only = $params['featured_only'] == '1'; $sale_only = $params['sale_only'] == '1'; $stock_only = $params['stock_only'] == '1'; $status_current = null; if (!empty($_GET[$grid_uid_url . 'status'])) { $status_current = explode(",", $_GET[$grid_uid_url . 'status']); if (in_array('sale', $status_current)) { $sale_only = true; } if (in_array('stock', $status_current)) { $stock_only = true; } } $price_current = null; if (!empty($_GET[$grid_uid_url . 'min_price']) || !empty($_GET[$grid_uid_url . 'max_price'])) { $price_range = thegem_extended_products_get_product_price_range($featured_only, $sale_only, $categories, $attributes); $current_min_price = !empty($_GET[$grid_uid_url . 'min_price']) ? floatval($_GET[$grid_uid_url . 'min_price']) : $price_range['min']; $current_max_price = !empty($_GET[$grid_uid_url . 'max_price']) ? floatval($_GET[$grid_uid_url . 'max_price']) : $price_range['max']; $price_current = [$current_min_price, $current_max_price]; } $search_current = null; if (!empty($_GET[$grid_uid_url . 's'])) { $search_current = $_GET[$grid_uid_url . 's']; } $active_tab = 0; if ($params['product_show_filter'] == '1' && $params['filters_style'] == 'tabs') { if (!empty($_GET[$grid_uid_url . 'tab'])) { $active_tab = intval($_GET[$grid_uid_url . 'tab']); } else { $active_tab = 1; } $filter_tabs = vc_param_group_parse_atts($params['filters_tabs_tabs']); $filter_tabs_current = $filter_tabs[$active_tab - 1]; if ($filter_tabs_current['filters_tabs_tab_filter_by'] == 'featured') { $featured_only = true; } else if ($filter_tabs_current['filters_tabs_tab_filter_by'] == 'sale') { $sale_only = true; } else if ($filter_tabs_current['filters_tabs_tab_filter_by'] == 'recent') { $orderby = 'date'; $order = 'desc'; } else if ($filter_tabs_current['filters_tabs_tab_filter_by'] == 'categories') { $categories_current = [$filter_tabs_current['filters_tabs_tab_products_cat']]; } } $product_loop = thegem_extended_products_get_posts($page, $items_per_page, $orderby, $order, $featured_only, $sale_only, $stock_only, $categories_current, $attributes_current, $price_current, $search_current, null, $active_tag, $products_tax, $products_tax_value, $post__in, $params['offset'], explode(",", $params['exclude_products'])); if ($product_loop && $product_loop->have_posts() || $search_current != null || $price_current != null) : echo thegem_extended_products_render_styles($params); $max_page = ceil(($product_loop->found_posts - intval($params['offset'])) / $items_per_page); if ($max_page > $page) $next_page = $page + 1; else $next_page = 0; $item_classes = get_thegem_extended_products_render_item_classes($params); $thegem_sizes = get_thegem_extended_products_render_item_image_sizes($params); $search_only = true; if ($params['product_show_filter'] == '1' && (!$normal_filter || ( ($params['filter_by_categories'] == '1' && count($terms) > 0) || $params['filter_by_attribute'] == '1' || $params['filter_by_price'] == '1' || $params['filter_by_status'] == '1' ))) { $search_only = false; } if ($params['columns_desktop'] == '100%' || (($params['ignore_highlights'] !== '1' || $params['layout'] !== 'justified') && $params['skeleton_loader'] !== '1')) { echo apply_filters('thegem_portfolio_preloader_html', '<div class="preloader save-space"><div class="preloader-spin"></div></div>'); } else if ($params['skeleton_loader'] == '1') { ?> <div class="preloader save-space" data-style-uid="<?php echo esc_attr($style_uid); ?>"> <div class="skeleton panel-sidebar-position-<?php echo $params['sidebar_position']; ?>"> <?php if ($params['product_show_filter'] == '1' && $params['filters_style'] == 'sidebar' && !$search_only) { ?> <div class="with-filter-sidebar"> <div class="filter-sidebar"> <div class="widget"></div> <div class="widget"></div> <div class="widget"></div> </div> <div class="content"> <?php } if ($params['product_show_sorting'] == '1') { ?> <div class="portfolio-top-panel"> <div class="skeleton-sorting"></div> </div> <?php } ?> <div class="skeleton-posts row portfolio-row"> <?php for ($x = 0; $x < $product_loop->post_count; $x++) { echo thegem_extended_products_render_item($params, $item_classes); } ?> </div> <?php if ($params['product_show_filter'] == '1' && $params['filters_style'] == 'sidebar' && !$search_only) { ?> </div> </div> <?php } ?> </div> </div> <?php } ?> <div class="portfolio-preloader-wrapper panel-sidebar-position-<?php echo $params['sidebar_position']; ?> "> <?php if ($params['caption_position'] == 'hover') { $title_on = 'hover'; } else { $title_on = 'page'; } $portfolio_classes = array( 'portfolio portfolio-grid extended-products-grid', 'woocommerce', 'products', 'no-padding', 'portfolio-preset-' . $params['extended_grid_skin'], 'portfolio-pagination-' . $params['pagination_type'], 'portfolio-style-' . $params['layout'], 'background-style-' . $params['caption_container_preset'], (($params['caption_position'] == 'hover' && ($params['image_hover_effect_hover'] == 'slide' || $params['image_hover_effect_hover'] == 'fade')) || $params['caption_position'] == 'image') ? 'caption-container-preset-' . $params['caption_container_preset_hover'] : '', (($params['caption_position'] == 'hover' && ($params['image_hover_effect_hover'] == 'slide' || $params['image_hover_effect_hover'] == 'fade')) || $params['caption_position'] == 'image') ? 'caption-alignment-' . $params['caption_container_alignment_hover'] : '', 'caption-position-' . $params['caption_position'], 'aspect-ratio-' . $params['image_aspect_ratio'], 'hover-' . $hover_effect, 'title-on-' . $title_on, ($params['layout_type'] == 'list' ? 'list-style disabled-hover caption-position-list-' . $params['caption_position_list'] : ''), ($params['layout_type'] == 'list' ? 'caption-alignment-list-' . $params['caption_container_alignment'] : ''), ($params['layout_type'] == 'list' ? 'caption-layout-list-' . $params['caption_layout_list'] : ''), ($is_archive_template ? 'main-loop-grid' : ''), ($params['loading_animation'] == '1' ? 'loading-animation' : ''), ($params['loading_animation'] == '1' && $params['animation_effect'] ? 'item-animation-' . $params['animation_effect'] : ''), ($params['loading_animation'] == '1' && $params['loading_animation_mobile'] ? 'enable-animation-mobile' : ''), ($params['image_gaps'] == 0 ? 'no-gaps' : ''), ($params['shadowed_container'] == '1' ? 'shadowed-container' : ''), ($params['columns_desktop'] == '100%' || $params['fullwidth_section_sorting'] == '1' ? 'fullwidth-columns' : ''), ($params['columns_desktop'] == '100%' ? 'fullwidth-columns-desktop-' . $params['columns_100'] : ''), ($params['caption_position'] == 'image' && $params['image_hover_effect_image'] == 'gradient' ? 'hover-gradient-title' : ''), ($params['caption_position'] == 'image' && $params['image_hover_effect_image'] == 'circular' ? 'hover-circular-title' : ''), ($params['caption_position'] == 'hover' || $params['caption_position'] == 'image' ? 'hover-title' : ''), ($params['social_sharing'] != '1' ? 'portfolio-disable-socials' : ''), ($params['layout'] == 'masonry' ? 'portfolio-items-masonry' : ''), ($params['columns_desktop'] != '100%' ? 'columns-desktop-' . $params['columns_desktop'] : 'columns-desktop-' . $params['columns_100']), ('columns-tablet-' . $params['columns_tablet']), ('columns-mobile-' . $params['columns_mobile']), ($params['product_separator'] == '1' ? 'item-separator' : ''), ($params['layout'] == 'justified' && $params['ignore_highlights'] == '1' ? 'disable-isotope' : ''), ($params['next_page_preloading'] == '1' && $params['show_pagination'] === '1' ? 'next-page-preloading' : ''), ($params['tabs_preloading'] == '1' ? 'tabs-preloading' : ''), ($params['product_show_divider'] == '1' ? 'with-divider' : ''), ); ?> <div class="<?php echo esc_attr(implode(' ', $portfolio_classes)) ?>" data-per-page="<?php echo esc_attr($items_per_page) ?>" data-current-page="<?php echo esc_attr($page) ?>" data-next-page="<?php echo esc_attr($next_page) ?>" data-next-tab="<?php echo esc_attr($active_tab) ?>" data-pages-count="<?php echo esc_attr($max_page) ?>" data-style-uid="<?php echo esc_attr($style_uid); ?>" data-portfolio-uid="<?php echo esc_attr($grid_uid) ?>" data-hover="<?php echo esc_attr($hover_effect) ?>" data-portfolio-filter='<?php echo esc_attr($categories_filter) ?>' data-portfolio-filter-attributes='<?php echo esc_attr(json_encode($attributes_filter)) ?>' data-portfolio-filter-status='<?php echo esc_attr(json_encode($status_current)) ?>' data-portfolio-filter-price='<?php echo esc_attr(json_encode($price_current)) ?>' data-portfolio-filter-search='<?php echo esc_attr($search_current) ?>'> <?php $show_widgets = false; $has_right_panel = $params['product_show_sorting'] == '1' || ( $params['filter_by_search'] == '1' && ( $params['filters_style'] == 'standard' || $search_only)); ?> <?php if ($params['source_type'] == 'cross_sell' && $params['show_cross_sell_title']) { $text_styled_class = implode(' ', array($params['cross_sell_title_style'], $params['cross_sell_title_weight'])); ?> <<?php echo $params['cross_sell_title_tag']; ?> class="cross-sell-title <?php echo $text_styled_class; ?>"> <?php echo $params['cross_sell_title_text']; ?> </<?php echo $params['cross_sell_title_tag']; ?>> <?php } ?> <div class="portfolio-row-outer <?php if ($params['columns_desktop'] == '100%' || $params['fullwidth_section_sorting'] == '1'): ?>fullwidth-block no-paddings<?php endif; ?>"> <?php if ($is_archive_template) { $shop_url = get_post_type_archive_link('product'); if (!$normal_filter && is_tax('product_cat')) { $shop_url = get_term_link($queried->slug, 'product_cat'); } else if (!$normal_filter && is_tax('product_tag')) { $shop_url = get_term_link($queried->slug, 'product_tag'); } ?> <input id="shop-page-url" type="hidden" value="<?php echo esc_url($shop_url); ?>"> <?php } ?> <?php if ($params['product_show_filter'] == '1' && $params['filters_style'] == 'sidebar' && !$search_only) { ?> <div class="with-filter-sidebar <?php echo $params['sidebar_sticky'] || $params['woo_sidebar_sticky'] ? 'sticky-sidebar' : ''; ?>"> <div class="filter-sidebar <?php echo $params['product_show_sorting'] == '1' ? 'left' : ''; ?>"> <?php if ( $normal_filter ) { include( locate_template( array( 'gem-templates/products-extended/filters.php' ) ) ); } else { ?> <div class="portfolio-filters-list sidebar <?php echo $normal_filter ? 'normal hide-mobile hide-tablet' : 'native'; ?> style-sidebar <?php echo $params['filters_scroll_top'] == '1' ? 'scroll-top' : ''; ?> <?php echo $has_right_panel ? 'has-right-panel' : ''; ?> <?php echo $params['woo_remove_counts'] == '1' ? 'hide-filter-counts' : ''; ?> <?php echo $native_ajax ? 'native-ajax-filters' : ''; ?>"> <div class="portfolio-show-filters-button <?php echo $params['filter_buttons_hidden_show_icon'] == '1' ? 'with-icon' : ''; ?>"> <?php echo esc_html( $params['filter_buttons_hidden_show_text'] ); ?> <?php if ( $params['filter_buttons_hidden_show_icon'] == '1' ) { ?> <span class="portfolio-show-filters-button-icon"></span> <?php } ?> </div> <div class="portfolio-filters-outer"> <div class="portfolio-filters-area"> <div class="portfolio-filters-area-scrollable"> <div class="widget-area-wrap"> <?php get_sidebar('shop'); ?> </div> </div> </div> <div class="portfolio-close-filters"></div> </div> </div> <?php } ?> </div> <div class="content"> <?php } ?> <?php if (($params['product_show_filter'] == '1' || $params['product_show_sorting'] == '1') && $params['filters_style'] != 'tabs'): ?> <div class="portfolio-top-panel <?php echo $params['filters_style'] == 'sidebar' ? 'sidebar-filter' : ''; ?> <?php echo ($params['product_show_sorting'] != '1' && ($params['filter_by_search'] != '1' || $params['filters_style'] != 'standard')) ? 'selected-only' : ''; ?>"> <div class="portfolio-top-panel-row"> <div class="portfolio-top-panel-left <?php echo esc_attr($params['filter_buttons_standard_alignment']); ?>"> <?php if ($normal_filter) { if ($params['product_show_filter'] == '1' && $params['filters_style'] != 'sidebar' && !$search_only) { include(locate_template(array('gem-templates/products-extended/filters.php'))); } if (($params['product_show_filter'] == '1' && $params['filters_style'] == 'sidebar') || $params['product_show_filter'] != '1') { include(locate_template(array('gem-templates/products-extended/selected-filters.php'))); } } else { if ($params['filters_style'] == 'hidden' && is_active_sidebar('shop-sidebar')) { ?> <div class="portfolio-filters-list sidebar native style-<?php echo esc_attr($params['filters_style']); ?> <?php echo $params['filters_scroll_top'] == '1' ? 'scroll-top' : ''; ?> <?php echo $has_right_panel ? 'has-right-panel' : ''; ?> <?php echo $params['woo_remove_counts'] == '1' ? 'hide-filter-counts' : ''; ?> <?php echo $native_ajax ? 'native-ajax-filters' : ''; ?>"> <div class="portfolio-show-filters-button <?php echo $params['filter_buttons_hidden_show_icon'] == '1' ? 'with-icon' : ''; ?>"> <?php echo esc_html($params['filter_buttons_hidden_show_text']); ?> <?php if ($params['filter_buttons_hidden_show_icon'] == '1') { ?> <span class="portfolio-show-filters-button-icon"></span> <?php } ?> </div> <div class="portfolio-filters-outer"> <div class="portfolio-filters-area"> <div class="portfolio-filters-area-scrollable"> <div class="widget-area-wrap"> <?php get_sidebar('shop'); ?> </div> </div> </div> <div class="portfolio-close-filters"></div> </div> </div> <?php } if ($params['filters_style'] == 'sidebar' && $native_ajax) { include(locate_template(array('gem-templates/products-extended/selected-filters.php'))); } } ?> </div> <?php if ($has_right_panel): ?> <div class="portfolio-top-panel-right"> <?php if ($params['product_show_sorting'] == '1'): ?> <div class="portfolio-sorting-select"> <div class="portfolio-sorting-select-current"> <div class="portfolio-sorting-select-name"> <?php switch ($sortby) { case "date": echo esc_html($params["sorting_dropdown_latest_text"]); break; case "popularity": echo esc_html($params["sorting_dropdown_popularity_text"]); break; case "rating": echo esc_html($params["sorting_dropdown_rating_text"]); break; case "price": echo esc_html($params["sorting_dropdown_price_low_high_text"]); break; case "price-desc": echo esc_html($params["sorting_dropdown_price_high_low_text"]); break; default: echo esc_html($params['sorting_text']); } ?> </div> <span class="portfolio-sorting-select-current-arrow"></span> </div> <ul> <li class="default <?php echo $sortby == 'default' ? 'portfolio-sorting-select-current' : ''; ?>" data-orderby="<?php echo esc_attr($params['orderby']); ?>" data-order="<?php echo esc_attr($params['order']); ?>"><?php echo esc_html($params['sorting_text']); ?></li> <li class="<?php echo $sortby == 'date' ? 'portfolio-sorting-select-current' : ''; ?>" data-orderby="date" data-order="desc"><?php echo esc_html($params['sorting_dropdown_latest_text']); ?> </li> <li class="<?php echo $sortby == 'popularity' ? 'portfolio-sorting-select-current' : ''; ?>" data-orderby="popularity" data-order="desc"><?php echo esc_html($params['sorting_dropdown_popularity_text']); ?> </li> <li class="<?php echo $sortby == 'rating' ? 'portfolio-sorting-select-current' : ''; ?>" data-orderby="rating" data-order="desc"><?php echo esc_html($params['sorting_dropdown_rating_text']); ?> </li> <li class="<?php echo $sortby == 'price' ? 'portfolio-sorting-select-current' : ''; ?>" data-orderby="price" data-order="asc"><?php echo esc_html($params['sorting_dropdown_price_low_high_text']); ?> </li> <li class="<?php echo $sortby == 'price-desc' ? 'portfolio-sorting-select-current' : ''; ?>" data-orderby="price" data-order="desc"><?php echo esc_html($params['sorting_dropdown_price_high_low_text']); ?> </li> </ul> </div> <?php endif; ?> <?php if ($params['filter_by_search'] == '1' && ($params['filters_style'] == 'standard' || $search_only)) { ?> <span> </span> <form class="portfolio-search-filter <?php echo $search_only ? 'mobile-visible' : ''; ?>" role="search" action=""> <div class="portfolio-search-filter-form"> <input type="search" placeholder="<?php echo esc_attr($params['filters_text_labels_search_text']); ?>" value="<?php echo esc_attr($search_current); ?>"> </div> <div class="portfolio-search-filter-button"></div> </form> <?php } ?> </div> <?php endif; ?> </div> <?php if ($params['product_show_filter'] == '1') { include(locate_template(array('gem-templates/products-extended/selected-filters.php'))); } ?> </div> <?php endif; ?> <?php if ($params['product_show_filter'] == '1' && $params['filters_style'] == 'tabs'): ?> <div class="portfolio-top-panel"> <div class="portfolio-filter-tabs style-<?php echo $params['filters_tabs_style']; ?> alignment-<?php echo $params['product_tabs_alignment']; ?> <?php echo $params['filters_tabs_title_separator'] == '1' ? 'separator' : ''; ?>"> <?php if ($params['filters_tabs_title_text'] != '') { ?> <div class="title-h4 portfolio-filter-tabs-title <?php echo $params['filters_tabs_title_style_preset'] == 'thin' ? 'light' : ''; ?>"><?php echo $params['filters_tabs_title_text']; ?></div> <?php } $filter_tabs = vc_param_group_parse_atts($params['filters_tabs_tabs']); if (!empty($filter_tabs)) { ?> <ul class="portfolio-filter-tabs-list"> <?php foreach ($filter_tabs as $index => $item) { if (!empty($item['filters_tabs_tab_title'])) { ?> <li class="portfolio-filter-tabs-list-tab <?php echo $index == $active_tab - 1 ? 'active' : ''; ?>" data-num="<?php echo $index + 1; ?>" data-filter="<?php echo $item['filters_tabs_tab_filter_by'] ?>" data-filter-cat="<?php echo isset($item['filters_tabs_tab_products_cat']) ? $item['filters_tabs_tab_products_cat'] : ''; ?>"> <?php echo $item['filters_tabs_tab_title'] ?> </li> <?php } } ?> </ul> <?php } ?> <?php if ($params['pagination_type'] == 'arrows' && $params['filters_tabs_style'] == 'alternative'): ?> <div class="portfolio-navigator gem-pagination gem-pagination-arrows"> <a href="" class="prev"> <?php if (isset($params['pagination_arrows_left_pack']) && $params['pagination_arrows_left_icon_' . $params['pagination_arrows_left_pack']] != '') { echo thegem_build_icon($params['pagination_arrows_left_pack'], $params['pagination_arrows_left_icon_' . $params['pagination_arrows_left_pack']]); } else { ?> <i class="default"></i> <?php } ?> </a> <a href="" class="next"><?php if (isset($params['pagination_arrows_right_pack']) && $params['pagination_arrows_right_icon_' . $params['pagination_arrows_right_pack']] != '') { echo thegem_build_icon($params['pagination_arrows_right_pack'], $params['pagination_arrows_right_icon_' . $params['pagination_arrows_right_pack']]); } else { ?> <i class="default"></i> <?php } ?></a> </div> <?php endif; ?> </div> </div> <?php endif; ?> <div class="row portfolio-row clearfix"> <div class="portfolio-set" data-max-row-height="<?php echo $params['metro_max_row_height'] ? esc_attr($params['metro_max_row_height']) : ''; ?>"> <?php if ($product_loop->have_posts()) { remove_action('woocommerce_before_shop_loop_item_title', 'woocommerce_show_product_loop_sale_flash', 10); remove_action('woocommerce_before_shop_loop_item_title', 'woocommerce_template_loop_product_thumbnail', 10); remove_action('woocommerce_before_shop_loop_item_title', 'woocommerce_template_loop_rating', 5); remove_action('woocommerce_shop_loop_item_title', 'woocommerce_template_loop_product_title', 10); remove_action('woocommerce_after_shop_loop_item_title', 'woocommerce_template_loop_rating', 5); remove_action('woocommerce_after_shop_loop_item_title', 'woocommerce_template_loop_price', 10); remove_action('woocommerce_after_shop_loop_item', 'woocommerce_template_loop_add_to_cart', 10); remove_action('woocommerce_after_shop_loop_item', 'thegem_woocommerce_after_shop_loop_item_link', 15); remove_action('woocommerce_after_shop_loop_item', 'thegem_woocommerce_after_shop_loop_item_wishlist', 20); while ($product_loop->have_posts()) : $product_loop->the_post(); ?> <?php echo thegem_extended_products_render_item($params, $item_classes, $thegem_sizes, get_the_ID()); ?> <?php endwhile; wp_reset_postdata(); } else { ?> <div class="portfolio-item not-found"> <div class="wrap clearfix"> <div class="image-inner"></div> <?php echo esc_html($params['not_found_text']); ?> </div> </div> <?php } ?> </div><!-- .portflio-set --> <div class="portfolio-item-size-container"> <?php echo thegem_extended_products_render_item($params, $item_classes); ?> </div> </div><!-- .row--> <?php /** Pagination */ if ('1' === ($params['show_pagination'])) : ?> <?php if ($params['pagination_type'] == 'normal'): ?> <div class="portfolio-navigator gem-pagination"> <a href="" class="prev"><i class="default"></i></a> <div class="pages"></div> <a href="" class="next"><i class="default"></i></a> </div> <?php endif; ?> <?php if ($params['pagination_type'] == 'more' && $next_page > 0): $separator_enabled = ($params['more_show_separator'] === '1' && $params['more_stretch_full_width'] !== '1') ? true : false; // Container $classes_container = 'gem-button-container gem-widget-button '; if ($separator_enabled) { $classes_container .= 'gem-button-position-center gem-button-with-separator '; } else { if ('1' === $params['more_stretch_full_width']) { $classes_container .= 'gem-button-position-fullwidth '; } } // Separator $classes_separator = 'gem-button-separator '; if (!empty($params['pagination_more_button_separator_style'])) { $classes_separator .= $params['pagination_more_button_separator_style']; } // Link $classes_button = "load-more-button gem-button gem-button-text-weight-" . $params['pagination_more_button_text_weight'] . " gem-button-size-" . $params['pagination_more_button_size'] . " gem-button-style-" . $params['pagination_more_button_type']; ?> <div class="portfolio-load-more gem-pagination"> <div class="inner"> <?php include(locate_template(array('gem-templates/products-extended/more-button.php'))); ?> </div> </div> <?php endif; ?> <?php if ($params['pagination_type'] == 'scroll' && $next_page > 0): ?> <div class="portfolio-scroll-pagination gem-pagination"></div> <?php endif; ?> <?php endif; ?> <?php if ($params['pagination_type'] == 'arrows' && ($params['filters_style'] !== 'tabs' || $params['filters_tabs_style'] == 'default')): ?> <div class="portfolio-navigator gem-pagination gem-pagination-arrows alignment-<?php echo $params['product_tabs_alignment']; ?>"> <a href="" class="prev"><i class="default"></i></a> <a href="" class="next"><i class="default"></i></a> </div> <?php endif; ?> <?php if ($params['product_show_filter'] == '1' && $params['filters_style'] == 'sidebar' && !$search_only) { ?> </div> </div> <?php } thegem_woocommerce_product_page_ajax_notification($params); ?> </div><!-- .full-width --> </div><!-- .portfolio--> <script> (function ($) { $(document).ready(function () { $('.portfolio-filters-list .widget_layered_nav, .portfolio-filters-list .widget_product_categories').find('.count').each(function () { $(this).html($(this).html().replace('(', '').replace(')', '')).css('opacity', 1); }); }); })(jQuery); </script> </div><!-- .portfolio-preloader-wrapper--> <?php else: ?> <?php if (!$is_related_upsell) { ?> <div class="bordered-box centered-box styled-subtitle"> <?php echo esc_html__('Please select products in "Products" section', 'thegem') ?> </div> <?php } ?> <?php endif; $post = $portfolio_posttemp; } // Print Products Compact Grid function thegem_products_compact_grid($params) { global $post; $portfolio_posttemp = $post; wp_enqueue_style('thegem-products-compact-grid'); $unique_id = uniqid('thegem-custom-menu-') . rand(1, 9999); $custom_css = ''; if ($params['select_products_categories'] == '1') { $categories = explode(",", $params['content_products_cat']); } else { $categories = ['0']; } $attributes = []; if ($params['select_products_attributes'] == '1') { if (!empty($params['content_products_attr'])) { $attrs = explode(",", $params['content_products_attr']); if ($attrs) { foreach ($attrs as $attr) { $values = explode(",", $params['content_products_attr_val_' . $attr]); if (in_array('0', $values) || empty($values)) { $values = get_terms('pa_' . $attr, array('fields' => 'slugs')); } $attributes[$attr] = $values; } } } else if (!empty($params['content_products_attr_val'])) { $attrs = explode(", ", $params['content_products_attr_val']); if ($attrs) { foreach ($attrs as $attr) { $attr_arr = explode("|", $attr); if ($attr_arr[1] == 'all') { $values = get_terms('pa_' . $attr_arr[0], array('fields' => 'slugs')); } else { if (isset($attributes[$attr_arr[0]])) { if (!in_array($attr_arr[1], $attributes[$attr_arr[0]])) { $values = array_push($attributes[$attr_arr[0]], $attr_arr[1]); } else { $values = false; } } else { $values = [$attr_arr[1]]; } } if ($values) { $attributes[$attr_arr[0]] = $values; } } } } } $items_per_page = intval($params['items_per_page']); if ($items_per_page == 0) { $items_per_page = 8; } $page = 1; $orderby = $params['orderby']; $order = $params['order']; $featured_only = $params['featured_only'] == '1' ? true : false; $sale_only = $params['sale_only'] == '1' ? true : false; $product_loop = thegem_extended_products_get_posts($page, $items_per_page, $orderby, $order, $featured_only, $sale_only, $stock_only = false, $categories, $attributes); if ($product_loop && $product_loop->have_posts()) : if (!empty($params['gaps_mobile'])) { $custom_css .= '.products-compact-grid#' . esc_attr($unique_id) . '.layout-grid { grid-row-gap:' . $params['gaps_mobile'] . 'px; grid-column-gap:' . $params['gaps_mobile'] . 'px; } .products-compact-grid#' . esc_attr($unique_id) . '.layout-list:not(.with-separator) .compact-product-item { padding-bottom:' . $params['gaps_mobile'] . 'px; } .products-compact-grid#' . esc_attr($unique_id) . '.layout-list.with-separator .compact-product-item { padding-bottom: calc(' . $params['gaps_mobile'] . 'px / 2); margin-bottom: calc(' . $params['gaps_mobile'] . 'px / 2); }'; } if (!empty($params['gaps_tablet'])) { $custom_css .= '@media (min-width: 768px) { .products-compact-grid#' . esc_attr($unique_id) . '.layout-grid { grid-row-gap:' . $params['gaps_tablet'] . 'px; grid-column-gap:' . $params['gaps_tablet'] . 'px; } .products-compact-grid#' . esc_attr($unique_id) . '.layout-list:not(.with-separator) .compact-product-item { padding-bottom:' . $params['gaps_tablet'] . 'px; } .products-compact-grid#' . esc_attr($unique_id) . '.layout-list.with-separator .compact-product-item { padding-bottom: calc(' . $params['gaps_tablet'] . 'px / 2); margin-bottom: calc(' . $params['gaps_tablet'] . 'px / 2); } }'; } if (!empty($params['gaps'])) { $custom_css .= '@media (min-width: 992px) { .products-compact-grid#' . esc_attr($unique_id) . '.layout-grid { grid-row-gap:' . $params['gaps'] . 'px; grid-column-gap:' . $params['gaps'] . 'px; } .products-compact-grid#' . esc_attr($unique_id) . '.layout-list:not(.with-separator) .compact-product-item { padding-bottom:' . $params['gaps'] . 'px; } .products-compact-grid#' . esc_attr($unique_id) . '.layout-list.with-separator .compact-product-item { padding-bottom: calc(' . $params['gaps'] . 'px / 2); margin-bottom: calc(' . $params['gaps'] . 'px / 2); } }'; } if (!empty($params['image_border_radius'])) { $custom_css .= '.products-compact-grid#' . esc_attr($unique_id) . '.layout-list .image a { border-radius:' . $params['image_border_radius'] . 'px; }'; } if ($params['product_separator'] == '1') { if (!empty($params['product_separator_width'])) { $custom_css .= '.products-compact-grid#' . esc_attr($unique_id) . '.layout-list.with-separator .compact-product-item { border-width:' . $params['product_separator_width'] . 'px; }'; } if (!empty($params['product_separator_color'])) { $custom_css .= '.products-compact-grid#' . esc_attr($unique_id) . '.layout-list.with-separator .compact-product-item { border-color:' . $params['product_separator_color'] . '; }'; } } if (!empty($params['categories_color_normal'])) { $custom_css .= '.products-compact-grid#' . esc_attr($unique_id) . ' .caption .categories { color:' . $params['categories_color_normal'] . '; }'; } if (!empty($params['categories_color_hover'])) { $custom_css .= '.products-compact-grid#' . esc_attr($unique_id) . ' .caption .categories a:hover { color:' . $params['categories_color_hover'] . '; }'; } if (!empty($params['title_color_normal'])) { $custom_css .= '.products-compact-grid#' . esc_attr($unique_id) . ' .caption .title { color:' . $params['title_color_normal'] . '; }'; } if (!empty($params['title_color_hover'])) { $custom_css .= '.products-compact-grid#' . esc_attr($unique_id) . ' .caption .title a:hover { color:' . $params['title_color_hover'] . '; }'; } if (!empty($params['price_color_normal'])) { $custom_css .= '.products-compact-grid#' . esc_attr($unique_id) . ' .product-price .price { color:' . $params['price_color_normal'] . '; }'; } if (!empty($params['rating_rated_color'])) { $custom_css .= '.products-compact-grid#' . esc_attr($unique_id) . ' .star-rating > span:before { color:' . $params['rating_rated_color'] . '; }'; } if (!empty($params['rating_base_color'])) { $custom_css .= '.products-compact-grid#' . esc_attr($unique_id) . ' .star-rating:before { color:' . $params['rating_base_color'] . '; }'; } if (!empty($params['caption_background'])) { $custom_css .= '.products-compact-grid#' . esc_attr($unique_id) . ' .wrap { background-color:' . $params['caption_background'] . '; }'; } $portfolio_classes = array( 'products-compact-grid woocommerce', 'layout-' . $params['layout'], 'columns-' . $params['columns'], 'alignment-' . $params['caption_alignment'], 'aspect-ratio-' . $params['image_aspect_ratio'], $params['product_separator'] == 1 ? 'with-separator' : '', ); ?> <div id="<?php echo(esc_attr($unique_id)); ?>" class="<?php echo esc_attr(implode(' ', $portfolio_classes)) ?>"> <?php if ($product_loop->have_posts()) { while ($product_loop->have_posts()) : $product_loop->the_post(); include(locate_template(array('gem-templates/products-extended/content-product-grid-item-compact.php'))); ?> <?php endwhile; wp_reset_postdata(); } else { ?> <div class="portfolio-item not-found"> <div class="wrap clearfix"> <div class="image-inner"></div> <?php echo esc_html($params['not_found_text']); ?> </div> </div> <?php } ?> </div> <?php // Print custom css if (!empty($custom_css)) { ?> <style><?php echo $custom_css; ?></style> <?php } ?> <?php else: ?> <div class="bordered-box centered-box styled-subtitle"> <?php echo esc_html__('Please select products in "Products" section', 'thegem') ?> </div> <?php endif; $post = $portfolio_posttemp; } // Print Products Grid Carousel Extended function thegem_products_grid_carousel_extended($params) { global $post; $portfolio_posttemp = $post; $grid_uid = $params['portfolio_uid']; $style_uid = substr(md5(rand()), 0, 7); $params['style_uid'] = $style_uid; wp_enqueue_style('thegem-portfolio-products-carousel'); wp_enqueue_script('thegem-portfolio-products-carousel'); if ($params['select_products_categories'] == '1') { $categories = explode(",", $params['content_products_cat']); } else { $categories = ['0']; } $attributes = []; if ($params['select_products_attributes'] == '1') { if (!empty($params['content_products_attr'])) { $attrs = explode(",", $params['content_products_attr']); if ($attrs) { foreach ($attrs as $attr) { $values = explode(",", $params['content_products_attr_val_' . $attr]); if (in_array('0', $values) || empty($values)) { $values = get_terms('pa_' . $attr, array('fields' => 'slugs')); } $attributes[$attr] = $values; } } } else if (!empty($params['content_products_attr_val'])) { $attrs = explode(", ", $params['content_products_attr_val']); if ($attrs) { foreach ($attrs as $attr) { $attr_arr = explode("|", $attr); if ($attr_arr[1] == 'all') { $values = get_terms('pa_' . $attr_arr[0], array('fields' => 'slugs')); } else { if (isset($attributes[$attr_arr[0]])) { if (!in_array($attr_arr[1], $attributes[$attr_arr[0]])) { $values = array_push($attributes[$attr_arr[0]], $attr_arr[1]); } else { $values = false; } } else { $values = [$attr_arr[1]]; } } if ($values) { $attributes[$attr_arr[0]] = $values; } } } } } $active_tag = null; if ($params['select_products_tags'] == '1') { $active_tag = explode(",", $params['content_products_tags']); } $post__in = null; if ($params['select_products'] == '1') { $post__in = explode(",", $params['content_products']); } if ($params['caption_position'] == 'image') { $hover_effect = $params['image_hover_effect_image']; } else if ($params['caption_position'] == 'page') { $hover_effect = $params['image_hover_effect_page']; } else { $hover_effect = $params['image_hover_effect_hover']; } wp_enqueue_style('thegem-hovers-' . $hover_effect); if ($params['quick_view'] == '1') { wp_enqueue_script('wc-single-product'); wp_enqueue_script('wc-add-to-cart-variation'); wp_enqueue_script('thegem-product-quick-view'); wp_enqueue_script('thegem-quick-view'); wp_enqueue_style('thegem-quick-view'); if(thegem_get_option('product_page_layout') == 'default') { if(thegem_get_option('product_page_button_add_to_cart_icon') && thegem_get_option('product_page_button_add_to_cart_icon_pack')) { wp_enqueue_style('icons-'.thegem_get_option('product_page_button_add_to_cart_icon_pack')); } if(thegem_get_option('product_page_button_add_to_wishlist_icon') && thegem_get_option('product_page_button_add_to_wishlist_icon_pack')) { wp_enqueue_style('icons-'.thegem_get_option('product_page_button_add_to_wishlist_icon_pack')); } if(thegem_get_option('product_page_button_added_to_wishlist_icon') && thegem_get_option('product_page_button_added_to_wishlist_icon_pack')) { wp_enqueue_style('icons-'.thegem_get_option('product_page_button_added_to_wishlist_icon_pack')); } } if (thegem_get_option('product_gallery') != 'legacy') { wp_enqueue_style('thegem-product-gallery'); } else { wp_enqueue_style('thegem-hovers'); } } if ($params['loading_animation'] === '1') { wp_enqueue_style('thegem-animations'); wp_enqueue_script('thegem-items-animations'); wp_enqueue_script('thegem-scroll-monitor'); } if ($params['slider_scroll_init'] === '1') { wp_enqueue_script('thegem-scroll-monitor'); } $items_per_page = intval($params['items_per_page']); $page = 1; $orderby = $params['orderby']; $order = $params['order']; $featured_only = $params['featured_only'] == '1'; $sale_only = $params['sale_only'] == '1'; $stock_only = $params['stock_only'] == '1'; $product_loops = []; $active_tab = 1; if ($params['product_show_tabs'] == '1') { if (isset($_GET[$grid_uid . '-tab'])) { $active_tab = intval($_GET[$grid_uid . '-tab']); } $filter_tabs = vc_param_group_parse_atts($params['filters_tabs_tabs']); $product_loops = []; if (!empty($filter_tabs)) { foreach ($filter_tabs as $index => $item) { if ($item['filters_tabs_tab_filter_by'] == 'featured') { $product_loops[] = thegem_extended_products_get_posts($page, $items_per_page, $orderby, $order, true, $sale_only, $stock_only, $categories, $attributes, null, null, null, $active_tag, null, null, $post__in, $params['offset'], explode(",", $params['exclude_products'])); } else if ($item['filters_tabs_tab_filter_by'] == 'sale') { $product_loops[] = thegem_extended_products_get_posts($page, $items_per_page, $orderby, $order, $featured_only, true, $stock_only, $categories, $attributes, null, null, null, $active_tag, null, null, $post__in, $params['offset'], explode(",", $params['exclude_products'])); } else if ($item['filters_tabs_tab_filter_by'] == 'recent') { $product_loops[] = thegem_extended_products_get_posts($page, $items_per_page, 'date', 'desc', $featured_only, $sale_only, $stock_only, $categories, $attributes, null, null, null, $active_tag, null, null, $post__in, $params['offset'], explode(",", $params['exclude_products'])); } else if ($item['filters_tabs_tab_filter_by'] == 'categories') { $product_loops[] = thegem_extended_products_get_posts($page, $items_per_page, $orderby, $order, $featured_only, $sale_only, $stock_only, [$item['filters_tabs_tab_products_cat']], $attributes, null, null, null, $active_tag, null, null, $post__in, $params['offset'], explode(",", $params['exclude_products'])); } } } } else { $is_related_upsell = false; if ($params['source_type'] == 'related_upsell') { $product = thegem_templates_init_product(); if (empty($product)) { $post = $portfolio_posttemp; return; } $is_related_upsell = true; if ($params['related_upsell_source'] == 'related') { $related_products = wc_get_related_products($product->get_id(), -1); $post__in = $related_products; } else { global $thegem_product_data; $upsells = $product->get_upsell_ids(); if(intval($thegem_product_data['product_page_elements_upsell_items']) > -1) { $upsells = array_slice($upsells, 0, intval($thegem_product_data['product_page_elements_upsell_items'])); } $post__in = $upsells; } if (empty($post__in) && !is_admin()) { $post = $portfolio_posttemp; return; } } else if ($params['source_type'] == 'cross_sell') { $cross_sells_ids_in_cart = array(); if (WC()->cart) { foreach ( WC()->cart->get_cart() as $cart_item ) { if ( $cart_item['quantity'] > 0 ) { $cross_sells_ids_in_cart = array_merge( $cart_item['data']->get_cross_sell_ids(), $cross_sells_ids_in_cart ); } } } $cross_sells = wp_parse_id_list( $cross_sells_ids_in_cart ); $post__in = $cross_sells; if (empty($post__in) && !is_admin()) { $post = $portfolio_posttemp; return; } } $product_loops[] = thegem_extended_products_get_posts($page, $items_per_page, $orderby, $order, $featured_only, $sale_only, $stock_only, $categories, $attributes, null, null, null, $active_tag, null, null, $post__in, $params['offset'], $params['exclude_products']); } if ($params['product_show_tabs'] == '1' || (!empty($product_loops[0]) && $product_loops[0]->have_posts())) : $params['layout'] = 'justified'; $params['ignore_highlights'] = '1'; echo thegem_extended_products_render_styles($params, true); $item_classes = get_thegem_extended_products_render_item_classes($params); $thegem_sizes = get_thegem_extended_products_render_item_image_sizes($params); if ($params['columns_desktop'] == '100%') { echo apply_filters('thegem_portfolio_preloader_html', '<div class="preloader"><div class="preloader-spin"></div></div>'); } else { ?> <div class="preloader skeleton-carousel" data-style-uid="<?php echo esc_attr($style_uid); ?>"> <div class="skeleton"> <div class="skeleton-posts row portfolio-row"> <?php for ($x = 0; $x < $product_loops[0]->post_count; $x++) { echo thegem_extended_products_render_item($params, $item_classes); } ?> </div> </div> </div> <?php } ?> <div class="portfolio-preloader-wrapper"> <?php if ($params['caption_position'] == 'hover') { $title_on = 'hover'; } else { $title_on = 'page'; } $portfolio_classes = array( 'portfolio portfolio-grid extended-products-grid extended-products-grid-carousel extended-carousel-grid', 'woocommerce', 'products', 'no-padding', 'disable-isotope', 'portfolio-preset-' . $params['extended_grid_skin'], 'portfolio-style-justified', 'background-style-' . $params['caption_container_preset'], (($params['caption_position'] == 'hover' && ($params['image_hover_effect_hover'] == 'slide' || $params['image_hover_effect_hover'] == 'fade')) || $params['caption_position'] == 'image') ? 'caption-container-preset-' . $params['caption_container_preset_hover'] : '', (($params['caption_position'] == 'hover' && ($params['image_hover_effect_hover'] == 'slide' || $params['image_hover_effect_hover'] == 'fade')) || $params['caption_position'] == 'image') ? 'caption-alignment-' . $params['caption_container_alignment_hover'] : '', 'caption-position-' . $params['caption_position'], 'aspect-ratio-' . $params['image_aspect_ratio'], 'hover-' . $hover_effect, 'title-on-' . $title_on, 'arrows-position-' . $params['arrows_navigation_position'], ($params['loading_animation'] == '1' ? 'loading-animation' : ''), ($params['loading_animation'] == '1' && $params['animation_effect'] ? 'item-animation-' . $params['animation_effect'] : ''), ($params['image_gaps'] == 0 ? 'no-gaps' : ''), ($params['columns_desktop'] == '100%' ? 'fullwidth-columns fullwidth-columns-desktop-' . $params['columns_100'] : ''), ($params['columns_desktop'] == '100%' && ($params['image_gaps'] < 24 || $params['product_separator'] == '1') ? 'prevent-arrows-outside' : ''), ($params['caption_position'] == 'image' && $params['image_hover_effect_image'] == 'gradient' ? 'hover-gradient-title' : ''), ($params['caption_position'] == 'image' && $params['image_hover_effect_image'] == 'circular' ? 'hover-circular-title' : ''), ($params['caption_position'] == 'hover' || $params['caption_position'] == 'image' ? 'hover-title' : ''), ($params['social_sharing'] != '1' ? 'portfolio-disable-socials' : ''), ($params['columns_desktop'] != '100%' ? 'columns-desktop-' . $params['columns_desktop'] : 'columns-desktop-' . $params['columns_100']), ('columns-tablet-' . $params['columns_tablet']), ('columns-mobile-' . $params['columns_mobile']), ($params['product_separator'] == '1' ? 'item-separator' : ''), ($params['arrows_navigation_visibility'] == 'hover' ? 'arrows-hover' : ''), ($params['slider_scroll_init'] === '1' || $params['slider_loop'] == '1' ? 'carousel-scroll-init' : ''), ); ?> <div class="<?php echo esc_attr(implode(' ', $portfolio_classes)) ?>" data-style-uid="<?php echo esc_attr($style_uid); ?>" data-portfolio-uid="<?php echo esc_attr($grid_uid) ?>" data-columns-mobile="<?php echo esc_attr(str_replace("x", "", $params['columns_mobile'])) ?>" data-columns-tablet="<?php echo esc_attr(str_replace("x", "", $params['columns_tablet'])) ?>" data-columns-desktop="<?php echo $params['columns_desktop'] != '100%' ? esc_attr(str_replace("x", "", $params['columns_desktop'])) : esc_attr($params['columns_100']) ?>" data-margin-mobile="<?php echo esc_attr($params['image_gaps_mobile']) ?>" data-margin-tablet="<?php echo esc_attr($params['image_gaps_tablet']) ?>" data-margin-desktop="<?php echo esc_attr($params['image_gaps']) ?>" data-hover="<?php echo esc_attr($hover_effect) ?>" data-dots='<?php echo $params['show_dots_navigation'] == '1' ? '1' : '0' ?>' data-arrows='<?php echo $params['show_arrows_navigation'] == '1' ? '1' : '0' ?>' data-loop='<?php echo $params['slider_loop'] == '1' ? '1' : '0' ?>' data-sliding-animation='<?php echo esc_attr($params['sliding_animation']) ?>' data-autoscroll-speed='<?php echo $params['autoscroll'] == '1' ? esc_attr($params['autoscroll_speed']) : '0' ?>'> <?php if ($params['source_type'] == 'cross_sell' && $params['show_cross_sell_title']) { $text_styled_class = implode(' ', array($params['cross_sell_title_style'], $params['cross_sell_title_weight'])); ?> <<?php echo $params['cross_sell_title_tag']; ?> class="cross-sell-title <?php echo $text_styled_class; ?>"> <?php echo $params['cross_sell_title_text']; ?> </<?php echo $params['cross_sell_title_tag']; ?>> <?php } ?> <div class="portfolio-row-outer <?php if ($params['columns_desktop'] == '100%'): ?>fullwidth-block no-paddings<?php endif; ?>"> <?php if ($params['product_show_tabs'] == '1') : ?> <div class="portfolio-top-panel"> <div class="portfolio-filter-tabs style-<?php echo $params['filters_tabs_style']; ?> alignment-<?php echo $params['product_tabs_alignment']; ?> <?php echo $params['filters_tabs_title_separator'] == '1' ? 'separator' : ''; ?>"> <?php if ($params['filters_tabs_title_text'] != '') { ?> <div class="title-h4 portfolio-filter-tabs-title <?php echo $params['filters_tabs_title_style_preset'] == 'thin' ? 'light' : ''; ?>"><?php echo $params['filters_tabs_title_text']; ?></div> <?php } $filter_tabs = vc_param_group_parse_atts($params['filters_tabs_tabs']); if (!empty($filter_tabs)) { ?> <ul class="portfolio-filter-tabs-list"> <?php foreach ($filter_tabs as $index => $item) { if (!empty($item['filters_tabs_tab_title'])) { ?> <li class="portfolio-filter-tabs-list-tab <?php echo $index == $active_tab - 1 ? 'active' : ''; ?>" data-num="<?php echo $index + 1; ?>"> <?php echo $item['filters_tabs_tab_title'] ?> </li> <?php } } ?> </ul> <?php } ?> </div> </div> <?php endif; ?> <div class="portfolio-filter-tabs-content"> <?php foreach ($product_loops as $index => $product_loop) { ?> <div class="extended-products-grid-carousel-item <?php echo $index == $active_tab - 1 ? 'active' : ''; ?>" data-num="<?php echo $index + 1; ?>"> <div class="portfolio-row clearfix"> <div class="portfolio-set"> <?php if ($product_loop->have_posts()) { remove_action('woocommerce_before_shop_loop_item_title', 'woocommerce_show_product_loop_sale_flash', 10); remove_action('woocommerce_before_shop_loop_item_title', 'woocommerce_template_loop_product_thumbnail', 10); remove_action('woocommerce_before_shop_loop_item_title', 'woocommerce_template_loop_rating', 5); remove_action('woocommerce_shop_loop_item_title', 'woocommerce_template_loop_product_title', 10); remove_action('woocommerce_after_shop_loop_item_title', 'woocommerce_template_loop_rating', 5); remove_action('woocommerce_after_shop_loop_item_title', 'woocommerce_template_loop_price', 10); remove_action('woocommerce_after_shop_loop_item', 'woocommerce_template_loop_add_to_cart', 10); remove_action('woocommerce_after_shop_loop_item', 'thegem_woocommerce_after_shop_loop_item_link', 15); remove_action('woocommerce_after_shop_loop_item', 'thegem_woocommerce_after_shop_loop_item_wishlist', 20); while ($product_loop->have_posts()) : $product_loop->the_post(); ?> <?php echo thegem_extended_products_render_item($params, $item_classes, $thegem_sizes, get_the_ID()); ?> <?php endwhile; wp_reset_postdata(); } else { ?> <div class="portfolio-item not-found"> <div class="wrap clearfix"> <div class="image-inner"></div> <?php echo esc_html($params['not_found_text']); ?> </div> </div> <?php } ?> </div><!-- .portflio-set --> </div><!-- .row--> <?php if ($params['show_arrows_navigation'] == '1'): ?> <div class="slider-prev-icon position-<?php echo $params['arrows_navigation_position']; ?>"> <i class="default"></i> </div> <div class="slider-next-icon position-<?php echo $params['arrows_navigation_position']; ?>"> <i class="default"></i> </div> <?php endif; ?> </div> <?php } ?> </div> <?php thegem_woocommerce_product_page_ajax_notification($params); ?> </div><!-- .full-width --> </div><!-- .portfolio--> </div><!-- .portfolio-preloader-wrapper--> <?php else: ?> <?php if (!$is_related_upsell) { ?> <div class="bordered-box centered-box styled-subtitle"> <?php echo esc_html__('Please select products in "Products" section', 'thegem') ?> </div> <?php } ?> <?php endif; $post = $portfolio_posttemp; if (thegem_is_plugin_active('js_composer/js_composer.php')) { global $vc_manager; if ($vc_manager->mode() == 'admin_frontend_editor' || $vc_manager->mode() == 'admin_page' || $vc_manager->mode() == 'page_editable') { ?> <script type="text/javascript"> (function ($) { setTimeout(function () { $('#<?php echo esc_attr($grid_uid) ?>.extended-products-grid-carousel').initProductGalleries(); }, 1000); })(jQuery); </script> <?php } } } // Print Products Grid Categories function thegem_products_grid_categories($params) { global $post; $portfolio_posttemp = $post; $grid_uid = $params['portfolio_uid']; $style_uid = substr(md5(rand()), 0, 7); $params['style_uid'] = $style_uid; wp_enqueue_style('thegem-products-categories-styles'); wp_enqueue_script('thegem-products-categories-scripts'); $categories = ['0']; if ($params['source'] == 'subcategories') { if (is_tax( 'product_cat' )) { $categories = get_terms('product_cat', array('fields' => 'slugs', 'parent' => get_queried_object()->term_id )); } } else { if (!empty($params['content_products_cat'])) { $categories = explode(", ", $params['content_products_cat']); } } $cat_args = [ 'taxonomy' => 'product_cat', 'hide_empty' => $params['hide_empty'] == '1' ? true : false, 'orderby' => $params['orderby'], 'order' => $params['order'], ]; if ( 'order' === $params['orderby'] ) { $cat_args['orderby'] = 'meta_value_num'; $cat_args['meta_key'] = 'order'; } $sorted_categories = get_terms($cat_args); if (in_array('0', $categories)) { $categories = get_terms('product_cat', array('fields' => 'slugs')); } if ($params['layout_type'] === 'creative' && ($params['columns_desktop'] == '1x' || $params['columns_desktop'] == '2x')) { $params['layout_type'] = 'grid'; } if ($params['layout_type'] === 'carousel') { wp_enqueue_style('owl'); wp_enqueue_script('owl'); } if ($params['loading_animation'] === '1') { wp_enqueue_style('thegem-animations'); wp_enqueue_script('thegem-items-animations'); wp_enqueue_script('thegem-scroll-monitor'); } if ($params['slider_scroll_init'] === '1') { wp_enqueue_script('thegem-scroll-monitor'); } if (!empty($categories)) : echo thegem_products_grid_categories_render_styles($params, $params['layout_type'] == 'carousel'); $thegem_sizes = get_thegem_extended_products_render_item_image_sizes($params); $item_classes = get_thegem_extended_products_render_item_classes($params); if ($params['columns_desktop'] == '100%') { echo apply_filters('thegem_portfolio_preloader_html', '<div class="preloader save-space"><div class="preloader-spin"></div></div>'); } else if ($params['layout_type'] == 'carousel' || $params['skeleton_loader'] == '1') { ?> <div class="preloader <?php echo $params['layout_type'] == 'carousel' ? 'skeleton-carousel' : 'save-space'; ?>" data-style-uid="<?php echo esc_attr($style_uid); ?>"> <div class="skeleton"> <div class="skeleton-posts row categories-row caption-position-<?php echo $params['caption_position']; ?> aspect-ratio-<?php echo $params['image_aspect_ratio']; ?>"> <?php for ($x = 0; $x < sizeof($categories); $x++) { ?> <div class="products-category-item <?php echo implode(" ", $item_classes); ?>"></div> <?php if (!empty($params['items_count']) && $x == $params['items_count']) { break; } } ?> </div> </div> </div> <?php } ?> <div class="portfolio-preloader-wrapper"> <?php $categories_classes = array( 'products-categories-widget', 'layout-type-' . $params['layout_type'], 'portfolio-preset-' . $params['product_grid_categories_skin'], 'caption-position-' . $params['caption_position'], 'aspect-ratio-' . $params['image_aspect_ratio'], 'counts-visible-' . $params['product_counts'], ($params['caption_position'] == 'image' ? 'caption-container-preset-' . $params['caption_container_preset'] : 'caption-container-preset-' . $params['caption_container_preset_below']), ($params['caption_position'] == 'image' ? 'caption-container-preset-color-' . $params['caption_container_preset_color'] : ''), ($params['caption_position'] == 'image' ? 'caption-container-vertical-position-' . $params['caption_container_vertical_position'] : ''), ($params['layout_type'] == 'carousel' ? 'extended-carousel-grid arrows-position-' . $params['arrows_navigation_position'] : ''), ($params['loading_animation'] == '1' ? 'loading-animation' : ''), ($params['loading_animation'] == '1' && $params['animation_effect'] ? 'item-animation-' . $params['animation_effect'] : ''), ($params['image_gaps'] == 0 ? 'no-gaps' : ''), ($params['columns_desktop'] == '100%' ? 'fullwidth-columns fullwidth-columns-desktop-' . $params['columns_100'] : ''), ($params['columns_desktop'] != '100%' ? 'columns-desktop-' . str_replace("x", "", $params['columns_desktop']) : 'columns-desktop-' . $params['columns_100']), ($params['columns_desktop'] == '100%' && ($params['image_gaps'] < 24 || $params['product_separator'] == '1') ? 'prevent-arrows-outside' : ''), ('columns-tablet-' . str_replace("x", "", $params['columns_tablet'])), ('columns-mobile-' . str_replace("x", "", $params['columns_mobile'])), ($params['product_separator'] == '1' ? 'item-separator' : ''), ($params['arrows_navigation_visibility'] == 'hover' ? 'arrows-hover' : ''), ($params['slider_scroll_init'] === '1' || $params['slider_loop'] == '1' ? 'carousel-scroll-init' : ''), ($params['layout_type'] === 'creative' && $params['scheme_apply_mobiles'] !== '1' ? 'creative-disable-mobile' : ''), ($params['layout_type'] === 'creative' && $params['scheme_apply_tablets'] !== '1' ? 'creative-disable-tablet' : ''), ); ?> <div class="<?php echo esc_attr(implode(' ', $categories_classes)) ?>" data-style-uid="<?php echo esc_attr($style_uid); ?>" data-portfolio-uid="<?php echo esc_attr($grid_uid) ?>" data-columns-mobile="<?php echo esc_attr(str_replace("x", "", $params['columns_mobile'])) ?>" data-columns-tablet="<?php echo esc_attr(str_replace("x", "", $params['columns_tablet'])) ?>" data-columns-desktop="<?php echo $params['columns_desktop'] != '100%' ? esc_attr(str_replace("x", "", $params['columns_desktop'])) : esc_attr($params['columns_100']) ?>" data-margin-mobile="<?php echo esc_attr($params['image_gaps_mobile']) ?>" data-margin-tablet="<?php echo esc_attr($params['image_gaps_tablet']) ?>" data-margin-desktop="<?php echo esc_attr($params['image_gaps']) ?>" data-dots='<?php echo $params['show_dots_navigation'] == '1' ? '1' : '0' ?>' data-arrows='<?php echo $params['show_arrows_navigation'] == '1' ? '1' : '0' ?>' data-loop='<?php echo $params['slider_loop'] == '1' ? '1' : '0' ?>' data-sliding-animation='<?php echo esc_attr($params['sliding_animation']) ?>' data-autoscroll-speed='<?php echo $params['autoscroll'] == '1' ? esc_attr($params['autoscroll_speed']) : '0' ?>'> <div class="categories-row-outer <?php if ($params['columns_desktop'] == '100%'): ?>fullwidth-block no-paddings<?php endif; ?>"> <div class="categories-row clearfix"> <div class="categories-set"> <?php if ($params['layout_type'] == 'creative') { $creative_categories_schemes_list = [ '6' => [ '6a' => [ 'count' => 9, 0 => 'squared', ], '6b' => [ 'count' => 7, 0 => 'squared', 1 => 'horizontal', 6 => 'horizontal', ], '6c' => [ 'count' => 9, 0 => 'horizontal', 3 => 'horizontal', 6 => 'horizontal', ], '6d' => [ 'count' => 9, 0 => 'horizontal', 1 => 'horizontal', 2 => 'horizontal', ], '6e' => [ 'count' => 6, 0 => 'squared', 1 => 'squared', ] ], '5' => [ '5a' => [ 'count' => 7, 0 => 'squared', ], '5b' => [ 'count' => 8, 0 => 'horizontal', 4 => 'horizontal', ], '5c' => [ 'count' => 6, 0 => 'horizontal', 1 => 'horizontal', 4 => 'horizontal', 5 => 'horizontal', ], '5d' => [ 'count' => 4, 0 => 'squared', 1 => 'vertical', 2 => 'horizontal', 3 => 'horizontal', ] ], '4' => [ '4a' => [ 'count' => 5, 0 => 'squared', ], '4b' => [ 'count' => 4, 0 => 'squared', 1 => 'horizontal', ], '4c' => [ 'count' => 4, 0 => 'squared', 1 => 'vertical', ], '4d' => [ 'count' => 7, 0 => 'vertical', ], '4e' => [ 'count' => 4, 0 => 'vertical', 1 => 'vertical', 2 => 'horizontal', 3 => 'horizontal', ], '4f' => [ 'count' => 6, 0 => 'horizontal', 5 => 'horizontal', ] ], '3' => [ '3a' => [ 'count' => 4, 0 => 'vertical', 1 => 'vertical', ], '3b' => [ 'count' => 4, 1 => 'horizontal', 2 => 'horizontal', ], '3c' => [ 'count' => 5, 0 => 'vertical', ], '3d' => [ 'count' => 5, 0 => 'horizontal', ], '3e' => [ 'count' => 3, 0 => 'squared', ], '3f' => [ 'count' => 4, 0 => 'horizontal', 1 => 'vertical', ], '3g' => [ 'count' => 4, 0 => 'vertical', 3 => 'horizontal', ], '3h' => [ 'count' => 5, 2 => 'vertical', ] ], ]; $columns = $params['columns_desktop'] != '100%' ? str_replace("x", "", $params['columns_desktop']) : $params['columns_100']; $items_sizes = $creative_categories_schemes_list[$columns][$params['layout_scheme_' . $columns . 'x']]; $items_count = $items_sizes['count']; } $i = 0; foreach ($sorted_categories as $category) { if (in_array($category->slug, $categories)) { $thegem_highlight_type = 'disabled'; if ($params['layout_type'] == 'creative') { $item_num = $i % $items_count; if (isset($items_sizes[$item_num])) { $thegem_highlight_type = $items_sizes[$item_num]; } } thegem_category_render_item($params, $thegem_sizes, $category, $thegem_highlight_type); $i++; if (!empty($params['items_count']) && $i == $params['items_count']) { break; } } } if ($params['layout_type'] == 'creative') { thegem_category_render_item($params, $thegem_sizes); } ?> </div><!-- .portflio-set --> </div><!-- .row--> <?php if ($params['show_arrows_navigation'] == '1'): ?> <div class="slider-prev-icon position-<?php echo $params['arrows_navigation_position']; ?>"> <i class="default"></i> </div> <div class="slider-next-icon position-<?php echo $params['arrows_navigation_position']; ?>"> <i class="default"></i> </div> <?php endif; ?> </div><!-- .full-width --> </div><!-- .portfolio--> </div><!-- .portfolio-preloader-wrapper--> <?php else: ?> <div class="bordered-box centered-box styled-subtitle"> <?php echo esc_html__('Please select product categories in "Categories" section', 'thegem') ?> </div> <?php endif; $post = $portfolio_posttemp; if (thegem_is_plugin_active('js_composer/js_composer.php')) { global $vc_manager; if ($vc_manager->mode() == 'admin_frontend_editor' || $vc_manager->mode() == 'admin_page' || $vc_manager->mode() == 'page_editable') { ?> <script type="text/javascript"> (function ($) { setTimeout(function () { $('#<?php echo esc_attr($grid_uid) ?>.products-categories-widget').initCategoriesGalleries(); $('#<?php echo esc_attr($grid_uid) ?>.products-categories-widget.layout-type-carousel').updateCategoriesGalleries(); }, 1000); })(jQuery); </script> <?php } } } function thegem_category_render_item($params, $thegem_sizes, $category = null, $thegem_highlight_type = 'disabled') { $thegem_classes = array('products-category-item'); if (!$category) { $thegem_classes[] = 'size-item'; $category = (object)array( 'term_id' => ' ', 'name' => 'Size', 'count' => '0', ); } if ($thegem_highlight_type != 'disabled') { $thegem_classes[] = 'double-item-' . $thegem_highlight_type; $thegem_sizes = get_thegem_extended_products_render_item_image_sizes($params, $thegem_highlight_type); } if ($params['loading_animation'] === '1') { $thegem_classes[] = 'item-animations-not-inited'; } include(locate_template(array('gem-templates/products-categories/content-product-category-item.php'))); } function thegem_products_grid_categories_render_styles($params, $carousel = false) { $wrapper = '.products-categories-widget[data-style-uid="' . $params['style_uid'] . '"]'; $wrapper_skeleton = '.preloader[data-style-uid="' . $params['style_uid'] . '"]'; $image_gaps = $params['image_gaps']; $image_gaps_tablet = $params['image_gaps_tablet']; $image_gaps_mobile = $params['image_gaps_mobile']; $style = "<style>"; if ($carousel) { $style .= $wrapper . ".item-separator .products-category-item { padding: calc(" . $image_gaps_mobile . "px/2) !important; }". $wrapper . ":not(.item-separator) .fullwidth-block { padding: 0 calc(" . $image_gaps_mobile . "px) !important; }". $wrapper_skeleton . " .products-category-item { padding: calc(" . $image_gaps_mobile . "px/2); }" . $wrapper_skeleton . " .skeleton-posts.portfolio-row { margin: calc(-" . $image_gaps_mobile . "px/2); }" ; $style .= "@media (min-width: 768px) { " . $wrapper . ".item-separator .products-category-item { padding: calc(" . $image_gaps_tablet . "px/2) !important; }". $wrapper . ":not(.item-separator) .fullwidth-block { padding: 0 calc(" . $image_gaps_tablet . "px) !important; }". $wrapper_skeleton . " .products-category-item { padding: calc(" . $image_gaps_tablet . "px/2); }" . $wrapper_skeleton . " .skeleton-posts.portfolio-row { margin: calc(-" . $image_gaps_tablet . "px/2); } }"; $style .= "@media (min-width: 992px) { " . $wrapper . ".item-separator .products-category-item { padding: calc(" . $image_gaps . "px/2) !important; }". $wrapper . ":not(.item-separator) .fullwidth-block { padding: 0 calc(" . $image_gaps . "px) !important; }". $wrapper_skeleton . " .products-category-item { padding: calc(" . $image_gaps . "px/2); }" . $wrapper_skeleton . " .skeleton-posts.portfolio-row { margin: calc(-" . $image_gaps . "px/2); } }"; } else { $style .= $wrapper . " .products-category-item," . $wrapper_skeleton . " .skeleton-posts .products-category-item { padding: calc(" . $image_gaps_mobile . "px/2); }" . $wrapper . ":not(.item-separator) .categories-row," . $wrapper_skeleton . " .skeleton-posts.categories-row { margin: calc(-" . $image_gaps_mobile . "px/2); }" . $wrapper . ".item-separator .categories-row { margin: 0 calc(-" . $image_gaps_mobile . "px/2); }" . $wrapper . ".extended-carousel-grid .categories-row { margin: 0 calc(-" . $image_gaps_mobile . "px/2); }" . $wrapper . ".extended-carousel-grid:not(.item-separator) .owl-stage-outer { margin: calc(-" . $image_gaps_mobile . "px/2) 0; }" . $wrapper . ".fullwidth-columns:not(.item-separator) .categories-row { margin: calc(-" . $image_gaps_mobile . "px/2) 0; }" . $wrapper . ".fullwidth-columns.item-separator .categories-row { margin: 0; }" . $wrapper . " .fullwidth-block .categories-row { padding-left: calc(" . $image_gaps_mobile . "px/2); padding-right: calc(" . $image_gaps_mobile . "px/2); }"; $style .= "@media (min-width: 768px) { " . $wrapper . " .products-category-item," . $wrapper_skeleton . " .skeleton-posts .products-category-item { padding: calc(" . $image_gaps_tablet . "px/2); }" . $wrapper . ":not(.item-separator) .categories-row," . $wrapper_skeleton . " .skeleton-posts.categories-row { margin: calc(-" . $image_gaps_tablet . "px/2); }" . $wrapper . ".item-separator .categories-row { margin: 0 calc(-" . $image_gaps_tablet . "px/2); }" . $wrapper . ".extended-carousel-grid .categories-row { margin: 0 calc(-" . $image_gaps_tablet . "px/2); }" . $wrapper . ".extended-carousel-grid:not(.item-separator) .owl-stage-outer { margin: calc(-" . $image_gaps_tablet . "px/2) 0; }" . $wrapper . ".fullwidth-columns:not(.item-separator) .categories-row { margin: calc(-" . $image_gaps_tablet . "px/2) 0; }" . $wrapper . ".fullwidth-columns.item-separator .categories-row { margin: 0; }" . $wrapper . " .fullwidth-block .categories-row { padding-left: calc(" . $image_gaps_tablet . "px/2); padding-right: calc(" . $image_gaps_tablet . "px/2); } }"; $style .= "@media (min-width: 992px) { " . $wrapper . " .products-category-item," . $wrapper_skeleton . " .skeleton-posts .products-category-item { padding: calc(" . $image_gaps . "px/2); }" . $wrapper . ":not(.item-separator) .categories-row," . $wrapper_skeleton . " .skeleton-posts.categories-row { margin: calc(-" . $image_gaps . "px/2); }" . $wrapper . ".item-separator .categories-row { margin: 0 calc(-" . $image_gaps . "px/2); }" . $wrapper . ".extended-carousel-grid .categories-row { margin: 0 calc(-" . $image_gaps . "px/2); }" . $wrapper . ".extended-carousel-grid:not(.item-separator) .owl-stage-outer { margin: calc(-" . $image_gaps . "px/2) 0; }" . $wrapper . ".fullwidth-columns:not(.item-separator) .categories-row { margin: calc(-" . $image_gaps . "px/2) 0; }" . $wrapper . ".fullwidth-columns.item-separator .categories-row { margin: 0; }" . $wrapper . " .fullwidth-block .categories-row { padding-left: calc(" . $image_gaps . "px/2); padding-right: calc(" . $image_gaps . "px/2); } } "; } if (isset($params['product_separator']) && $params['product_separator'] === '1') { $style .= $wrapper . ".item-separator .products-category-item:before," . $wrapper . ".item-separator .products-category-item:after," . $wrapper . ".item-separator .products-category-item .item-separator-box:before," . $wrapper . ".item-separator .products-category-item .item-separator-box:after { border-width: " . $params['product_separator_width'] . "px; border-color: " . $params['product_separator_color'] . "; }"; $style .= $wrapper . ".item-separator .products-category-item .item-separator-box:before," . $wrapper . ".item-separator .products-category-item .item-separator-box:after { width: calc(100% + " . $params['product_separator_width'] . "px); left: calc(-" . $params['product_separator_width'] . "px/2);};"; $style .= $wrapper . ".item-separator .products-category-item:before," . $wrapper . ".item-separator .products-category-item:after { height: calc(100% + " . $params['product_separator_width'] . "px); top: calc(-" . $params['product_separator_width'] . "px/2);}"; if ($carousel) { $style .= $wrapper . ".item-separator .owl-carousel .owl-stage-outer { padding: calc(" . $params['product_separator_width'] . "px/2); width: calc(100% + " . $params['product_separator_width'] . "px); margin-left: calc(-" . $params['product_separator_width'] . "px/2);}"; } if ($params['product_separator_width'] % 2 !== 0) { $floor = floor($params['product_separator_width'] / 2); $ceil = ceil($params['product_separator_width'] / 2); $style .= $wrapper . ".item-separator .products-category-item:before { transform: translateX(-" . $floor . "px) !important; top: -" . $floor . "px !important;}"; $style .= $wrapper . ".item-separator .products-category-item:after { transform: translateX(" . $ceil . "px) !important; top: -" . $floor . "px !important;}"; $style .= $wrapper . ".item-separator .products-category-item .item-separator-box:before { transform: translateY(-" . $floor . "px) !important; left: -" . $floor . "px !important;}"; $style .= $wrapper . " .products-category-item .item-separator-box:after { transform: translateY(" . $ceil . "px) !important; left: -" . $floor . "px !important;}"; if ($carousel) { $style .= $wrapper . ".item-separator .owl-carousel .owl-stage-outer { padding: " . $ceil . "px !important; width: calc(100% + " . $ceil . "px * 2) !important; margin-left: calc(-" . $ceil . "px) !important; }"; } } } if (isset($params['image_border_width']) && $params['image_border_width'] != '') { if (isset($params['border_caption_container']) && $params['border_caption_container'] === '1') { $style .= $wrapper . " .products-category-item .wrap .category-thumbnail { border-width: " . $params['image_border_width'] . "px; border-style: solid; border-bottom: 0; }"; $style .= $wrapper . " .products-category-item .wrap .category-overlay { border-width: " . $params['image_border_width'] . "px; border-style: solid; border-top: 0; }"; } else { $style .= $wrapper . " .products-category-item .wrap .category-thumbnail { border-width: " . $params['image_border_width'] . "px; border-style: solid; }"; } if (isset($params['image_border_color']) && $params['image_border_color'] != '') { $style .= $wrapper . " .products-category-item .wrap .category-thumbnail, " . $wrapper . " .products-category-item .wrap .category-overlay { border-color: " . $params['image_border_color'] . "; }"; } if (isset($params['image_border_color_hover']) && $params['image_border_color_hover'] != '') { $style .= $wrapper . ":hover .products-category-item .wrap .category-thumbnail, " . $wrapper . ":hover .products-category-item .wrap .category-overlay { border-color: " . $params['image_border_color_hover'] . "; }"; } } if (isset($params['image_border_radius']) && $params['image_border_radius'] != '') { if (isset($params['border_caption_container']) && $params['border_caption_container'] === '1') { $style .= $wrapper . " .products-category-item .wrap { border-radius: " . $params['image_border_radius'] . "px; }"; $style .= $wrapper . " .products-category-item .wrap .category-thumbnail { border-top-left-radius: " . $params['image_border_radius'] . "px; border-top-right-radius: " . $params['image_border_radius'] . "px; }"; $style .= $wrapper . " .products-category-item .wrap .category-overlay { border-bottom-left-radius: " . $params['image_border_radius'] . "px; border-bottom-right-radius: " . $params['image_border_radius'] . "px; }"; } else { $style .= $wrapper . " .products-category-item .wrap .category-thumbnail { border-radius: " . $params['image_border_radius'] . "px }"; $style .= $wrapper . " .products-category-item .wrap { border-radius: " . $params['image_border_radius'] . "px " . $params['image_border_radius'] . "px 0 0 }"; } } if (isset($params['image_overlay_normal']) && $params['image_overlay_normal'] != '') { $style .= $wrapper . " .products-category-item .category-thumbnail:after { background: " . $params['image_overlay_normal'] . " }"; } if (isset($params['image_overlay_hover']) && $params['image_overlay_hover'] != '') { $style .= $wrapper . ":hover .products-category-item .category-thumbnail:after { background: " . $params['image_overlay_hover'] . " }"; } if (isset($params['caption_container_vertical_position']) && $params['caption_container_vertical_position'] != '') { if ($params['caption_container_vertical_position'] == 'top') { $align = 'flex-start'; } else if ($params['caption_container_vertical_position'] == 'bottom') { $align = 'flex-end'; } else { $align = 'center'; } $style .= $wrapper . ".caption-position-image .products-category-item .wrap .category-overlay { align-items: " . $align . " }"; } if (isset($params['caption_container_alignment']) && $params['caption_container_alignment'] != '' && $params['caption_position'] == 'image') { if ($params['caption_container_alignment'] == 'left') { $align = 'flex-start'; } else if ($params['caption_container_alignment'] == 'right') { $align = 'flex-end'; } else { $align = 'center'; } $style .= $wrapper . " .products-category-item .wrap .category-overlay .category-overlay-inner-inside { align-items: " . $align . "; text-align: " . $params['caption_container_alignment'] . " }"; } if (isset($params['caption_container_background_color_normal']) && $params['caption_container_background_color_normal'] != '' && $params['caption_position'] == 'image') { $style .= $wrapper . ".caption-position-image.caption-container-preset-solid .products-category-item .wrap .category-overlay .category-overlay-inner { background-color: " . $params['caption_container_background_color_normal'] . " }"; } if (isset($params['caption_container_background_color_hover']) && $params['caption_container_background_color_hover'] != '' && $params['caption_position'] == 'image') { $style .= $wrapper . ".caption-position-image.caption-container-preset-solid .products-category-item:hover .wrap .category-overlay .category-overlay-inner { background-color: " . $params['caption_container_background_color_hover'] . " }"; } if (isset($params['categories_title_color_normal']) && $params['categories_title_color_normal'] != '') { $style .= $wrapper . " .products-category-item .wrap .category-overlay .category-title { color: " . $params['categories_title_color_normal'] . " }"; } if (isset($params['categories_title_color_hover']) && $params['categories_title_color_hover'] != '') { $style .= $wrapper . " .products-category-item:hover .wrap .category-overlay .category-title { color: " . $params['categories_title_color_hover'] . " }"; } if (isset($params['categories_counts_color_normal']) && $params['categories_counts_color_normal'] != '') { $style .= $wrapper . " .products-category-item .wrap .category-overlay .category-count { color: " . $params['categories_counts_color_normal'] . " }"; } if (isset($params['categories_counts_color_hover']) && $params['categories_counts_color_hover'] != '') { $style .= $wrapper . " .products-category-item:hover .wrap .category-overlay .category-count { color: " . $params['categories_counts_color_hover'] . " }"; } if (isset($params['caption_separator_color_normal']) && $params['caption_separator_color_normal'] != '') { $style .= $wrapper . " .products-category-item .wrap .category-overlay .category-overlay-separator { background-color: " . $params['caption_separator_color_normal'] . " }"; } if (isset($params['caption_separator_color_hover']) && $params['caption_separator_color_hover'] != '') { $style .= $wrapper . " .products-category-item:hover .wrap .category-overlay .category-overlay-separator { background-color: " . $params['caption_separator_color_hover'] . " }"; } if (isset($params['caption_container_alignment_below']) && $params['caption_container_alignment_below'] != '' && $params['caption_position'] == 'below') { if ($params['caption_container_alignment_below'] == 'left') { $align = 'flex-start'; } else if ($params['caption_container_alignment_below'] == 'right') { $align = 'flex-end'; } else { $align = 'center'; } $style .= $wrapper . " .products-category-item .wrap .category-overlay .category-overlay-inner-inside { align-items: " . $align . "; text-align: " . $params['caption_container_alignment_below'] . " }"; } if (isset($params['caption_container_background_below_normal']) && $params['caption_container_background_below_normal'] != '' && $params['caption_position'] == 'below') { $style .= $wrapper . " .products-category-item .wrap .category-overlay .category-overlay-inner { background-color: " . $params['caption_container_background_below_normal'] . " }"; } if (isset($params['caption_container_background_below_hover']) && $params['caption_container_background_below_hover'] != '' && $params['caption_position'] == 'below') { $style .= $wrapper . " .products-category-item:hover .wrap .category-overlay .category-overlay-inner { background-color: " . $params['caption_container_background_below_hover'] . " }"; } if (isset($params['navigation_arrows_icon_color_normal']) && $params['navigation_arrows_icon_color_normal'] != '') { $style .= $wrapper . " .product-gallery-slider .owl-nav .owl-prev div, " . $wrapper . " .product-gallery-slider .owl-nav .owl-next div { color: " . $params['navigation_arrows_icon_color_normal'] . " }"; } if (isset($params['navigation_arrows_icon_color_hover']) && $params['navigation_arrows_icon_color_hover'] != '') { $style .= $wrapper . " .product-gallery-slider .owl-nav .owl-prev:hover div, " . $wrapper . " .product-gallery-slider .owl-nav .owl-next:hover div { color: " . $params['navigation_arrows_icon_color_hover'] . " }"; } if (isset($params['navigation_arrows_border_width']) && $params['navigation_arrows_border_width'] != '') { $style .= $wrapper . " .product-gallery-slider .owl-nav .owl-prev, " . $wrapper . " .product-gallery-slider .owl-nav .owl-next { border-width: " . $params['navigation_arrows_border_width'] . "px }"; } if (isset($params['navigation_arrows_border_radius']) && $params['navigation_arrows_border_radius'] != '') { $style .= $wrapper . " .product-gallery-slider .owl-nav .owl-prev, " . $wrapper . " .product-gallery-slider .owl-nav .owl-next { border-radius: " . $params['navigation_arrows_border_radius'] . "px }"; } if (isset($params['navigation_arrows_border_color_normal']) && $params['navigation_arrows_border_color_normal'] != '') { $style .= $wrapper . " .product-gallery-slider .owl-nav .owl-prev, " . $wrapper . " .product-gallery-slider .owl-nav .owl-next { border-color: " . $params['navigation_arrows_border_color_normal'] . " }"; } if (isset($params['navigation_arrows_border_color_hover']) && $params['navigation_arrows_border_color_hover'] != '') { $style .= $wrapper . " .product-gallery-slider .owl-nav .owl-prev:hover, " . $wrapper . " .product-gallery-slider .owl-nav .owl-next:hover { border-color: " . $params['navigation_arrows_border_color_hover'] . " }"; } if (isset($params['navigation_arrows_background_color_normal']) && $params['navigation_arrows_background_color_normal'] != '') { $style .= $wrapper . " .product-gallery-slider .owl-nav .owl-prev div.position-on, " . $wrapper . " .product-gallery-slider .owl-nav .owl-next div.position-on { background-color: " . $params['navigation_arrows_background_color_normal'] . " }"; } if (isset($params['navigation_arrows_background_color_hover']) && $params['navigation_arrows_background_color_hover'] != '') { $style .= $wrapper . " .product-gallery-slider .owl-nav .owl-prev:hover div.position-on, " . $wrapper . " .product-gallery-slider .owl-nav .owl-next:hover div.position-on { background-color: " . $params['navigation_arrows_background_color_hover'] . " }"; } if (isset($params['navigation_dots_spacing']) && $params['navigation_dots_spacing'] != '') { $style .= $wrapper . " .owl-dots { margin-top: " . $params['navigation_dots_spacing'] . "px }"; } if (isset($params['navigation_dots_border_width']) && $params['navigation_dots_border_width'] != '') { $style .= $wrapper . " .owl-dots .owl-dot span { border-width: " . $params['navigation_dots_border_width'] . "px }"; } if (isset($params['navigation_dots_border_color_normal']) && $params['navigation_dots_border_color_normal'] != '') { $style .= $wrapper . " .owl-dots .owl-dot span { border-color: " . $params['navigation_dots_border_color_normal'] . " }"; } if (isset($params['navigation_dots_border_color_active']) && $params['navigation_dots_border_color_active'] != '') { $style .= $wrapper . " .owl-dots .owl-dot.active span { border-color: " . $params['navigation_dots_border_color_active'] . " }"; } if (isset($params['navigation_dots_background_color_normal']) && $params['navigation_dots_background_color_normal'] != '') { $style .= $wrapper . " .owl-dots .owl-dot span { background-color: " . $params['navigation_dots_background_color_normal'] . " }"; } if (isset($params['navigation_dots_background_color_active']) && $params['navigation_dots_background_color_active'] != '') { $style .= $wrapper . " .owl-dots .owl-dot.active span { background-color: " . $params['navigation_dots_background_color_active'] . " }"; } $style .= "</style>"; return $style; }