/ Плагины / Woocommerce основы

Woocommerce основы

HIT

19.02.2017

1061

Наиболее часто встречающиеся и необходимые вызовы при использовании плагина woocommerce, а так же прочие хитрости при работе с woocommerce.

<?php echo $_product->get_sku( $cart_item ); ?> // Вывести артикул в корзине

echo get_the_title( $product->id ); // вывести название товара

global $product; 
echo $product->get_sale_price(); // вывести акционную цену

echo the_excerpt(); // вывести краткое описание

echo $product->get_stock_quantity(); // вывести количество товара в наличии

echo $product->get_price();  // вывести цену

//Вывести даты начала / окончания акционной цены
global $post;
echo get_post_meta($post->ID, '_sale_price_dates_to', true);
echo get_post_meta($post->ID, '_sale_price_dates_from', true);

Интерпритация даты в нормальный вид
global $post;
$sales_price_to = get_post_meta($post->ID, '_sale_price_dates_to', true);
$sales_price_date_to = date("j M y", $sales_price_to);
echo $sales_price_date_to

Параметры заказа

Получить метод оплаты:

get_post_meta( $order->id, '_payment_method', true );

или с версии 3.0

$order->get_payment_method();

Получить заказ (object со всеми данными) по id заказа:

$order = wc_get_order( $order_id );

Проверки

Проверка на распродажный товар

global $product;
if ( $product->is_on_sale() ) {
    do_something();
}

Проверка на товар, которого нет в наличии

global $product;
if (!$product->is_in_stock()) {
    do_something();
}

Альтернативная проверка наличия

if ($product->get_stock_quantity() == 0) {}

Глобально запретить предзаказы на сайте

Рекомендованные товары

Featured является термином таксономии product_visibility, т.е. если товар «рекомендуемый», то он привязан (в таблице БД wp_term_relationships) к термину featured.

Товар всегда в наличии и наоборот

Если по каким бы то ни было причинам (например обмен с 1С) нам нужно сделать принудительно товары какой-то категории всегда в наличии или наоборот, можно это сделать так:

Для категории с подкатегориями (чтобы применить правило и в них):

// Отключаем возможность заказа Товары для дома и сада
function wc_сonditions_domsad() {
	$args = array(
		'child_of'           => 954, //категория Товары для дома и сада
		'hide_empty'         => 1,
		'depth'              => -1,
		'taxonomy'           => 'product_cat',
	);

	$list_product_categoryes = get_categories( $args );

	$category_ids = array();

	foreach($list_product_categoryes as $product_category) $category_ids[] = $product_category->term_id;

	global $product;
	$cur_term = get_the_terms($product->id, 'product_cat');

	if (in_array($cur_term[0]->term_id, $category_ids)) {
		update_post_meta($product->id, '_stock_status', 'outstock');
	}
}
add_filter( 'woocommerce_single_product_summary', 'wc_сonditions_domsad', 6 );
add_filter( 'woocommerce_after_shop_loop_item_title', 'wc_сonditions_domsad', 6 );

Для категории без подкатегорий:

// Отключаем возможность заказа Изоляционные материалы
function wc_сonditions_izolation() {

	global $product;
	$cur_term = get_the_terms($product->id, 'product_cat');

	if ($cur_term[0]->term_id == 719) {
		update_post_meta($product->id, '_stock_status', 'outstock');
	}
}
add_filter( 'woocommerce_single_product_summary', 'wc_сonditions_izolation', 6 );
add_filter( 'woocommerce_after_shop_loop_item_title', 'wc_сonditions_izolation', 6 );

Но таким образом придется прописывать для каждой верхней категории подобную функцию. Более универсально это можно сделать с помощью тегов или произвольного поля прописывая их либо всей категории, либо конкретным товарам.

Тяжелые запросы

На одном из сайтов на Главной странице выводились последние 10 товаров. Но страница загружалось довольно долго, около 8 секунд. При этом товаров в базе было около 1000 и небольшая часть из них вариативные. Я изменил вывод, добавив выборку по типу товаров (type=simple) и вывел только простые (не вариативные товары), время загрузки страницы стало быстрее.

Чтобы это реализовать нужно выводить товары с помощью функции wc_get_products и последующей версткой товаров.

<h2>Новинки</h2>
<div class="carousel woocommerce">
	<ul class="multiple-items products">
		<?php $args = array(
			'type' => 'simple',
			'limit' => 10,
			'post_status' => 'publish',
		);
		$products = wc_get_products( $args );
		foreach( $products as $product_object ):

		$product_id = $product_object->get_id();
		$product = wc_get_product($product_id); ?>

		<li <?php wc_product_class(); ?>><span>
			<a href="<?php echo get_permalink( $product->get_id() ); ?>" class="woocommerce-LoopProduct-link woocommerce-loop-product__link"> 

				<div class="percentage">
					<div class="inside"><div class="inside-text">
						<?php $percentage = round( ( ( $product->get_regular_price() - $product->get_sale_price() ) / $product->get_regular_price() ) * 100 );
						echo $price . sprintf( __('-%s', 'woocommerce' ), $percentage . '%' ); ?>
					</div></div>
				</div>	

				<div class="label">
					<?php if ( $product->is_on_sale() ) : ?>
					<?php echo apply_filters( 'woocommerce_sale_flash', '<span class="onsale">' . __( 'Sale!', 'woocommerce' ) . '</span>', $post, $product ); ?>
					<?php endif; ?>
				</div>	

				<?php $image = wp_get_attachment_image_src( get_post_thumbnail_id( $product->get_id() ), 'shop_catalog' );?>
				<div class="imagewrapper"><img src="<?php  echo $image[0]; ?>" data-id="<?php echo $product->get_id(); ?>"></div>
				<h2 class="woocommerce-loop-product__title"><?php echo $product->get_title(); ?></h2>
				<span class="price"><?php echo $product->get_price_html(); ?></span>
			</a>

			<?php if ( ! $product->is_sold_individually() && 'variable' != $product->get_type() && $product->is_purchasable() && $product->is_in_stock() ) {
woocommerce_quantity_input( array( 'min_value' => 1, 'max_value' => $product->backorders_allowed() ? '' : $product->get_stock_quantity() ) );
} ?>

			<a href="/?add-to-cart=<?php echo $product->get_id(); ?>" data-quantity="1" class="button product_type_simple add_to_cart_button ajax_add_to_cart" data-product_id="<?php echo $product->get_id(); ?>" rel="nofollow">В корзину</a>

			</span></li>

		<?php endforeach; ?>			
	</ul>			
</div>

Формирование мета-данных товара

Эти данные выводятся хуком woocommerce_template_single_meta, но возможно пригодится как их сформировать:


function enter_product_info() {
	global $product;
	echo '<div class="product-info">';
	echo '<p>Артикул: '.$product->get_sku().'</p>';
	echo '<p>Категория: '.wc_get_product_category_list( $product->get_ID(), ', ').'</p>';
	echo '<p>Бренд: '.wc_get_product_tag_list( $product->get_ID(), ', ').'</p>';
	echo '</div>';
}
add_action( 'woocommerce_single_product_summary', 'enter_product_info', 55 );

Тэги:

Поделится информацией с друзьями

  • Похожие записи
  • Комментарии
  • Вложения
Адаптация woocommerce под свой шаблон

Адаптация woocommerce под свой шаблон

Первое что мы должны сделать при разработке темы включающей в себя функционал интернет-магазина — адаптировать woocommerce под свой шаблон. Локализация woocommerce Для адаптации woocommerce в нашем шаблоне необходимо: Создать в Читать далее »

Скидки Woocommerce

Скидки Woocommerce

Добавляем и настраиваем в woocommerce различные системы скидок. Стандартная скидка Woocommerce Можно включить «акционную» цену на товар, к ней можно добавить дату окончания скидки. У товара появляется лэйбл «Распродажа», можно Читать далее »

Варианты сортировки woocommerce

Варианты сортировки woocommerce

Добавляем свои варианты сортировки в woocommerce, кроме стандартных: по цене, по новизне, по популярности, по рейтингам. Вариант сортировки: Случайно Вариант сортировки: По названию Вариант сортировки: По меткам Вариант сортировки: По Читать далее »

/

Добавить комментарий

Пока нет комментариев. Будь первым!

Woocommerce основы
Создание metabox’а
Рекомендации для васСоздание metabox’аOpttour.ru
Спасибо! Наш менеджер свяжется с Вами в течении 5 минут.