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

Woocommerce основы

HIT

19.02.2017

2648

Наиболее часто встречающиеся и необходимые вызовы при использовании плагина 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

is_woocommerce() Возвращает true, если на странице используются шаблоны WooCommerce (корзина и касса являются стандартными страницами с короткими кодами и поэтому не включены).

Главная страница магазина

is_shop() Возвращает истину, когда находится на странице архива продукта (магазин).

Страница категории товаров

  • is_product_category()Возвращает true при просмотре архива категории продуктов.
  • is_product_category( 'shirts' )Когда отображается страница категории продукта для категории «рубашки».
  • is_product_category( array( 'shirts', 'games' ) )Когда отображается страница категории продукта для категории «рубашки» или «игры».

Страница с тегом продукта

  • is_product_tag() Возвращает true при просмотре архива тегов продукта
  • is_product_tag( 'shirts' ) Когда отображается страница тега продукта для тега «рубашки».
  • is_product_tag( array( 'shirts', 'games' ) ) Когда отображается страница тега продукта для тегов «рубашки» или «игры».

Страница одного продукта

is_product() Возвращает истину на одной странице продукта. Обертка для is_singular.

Страница корзины

is_cart() Возвращает true на странице корзины.

Страница оформления заказа

is_checkout() Возвращает true на странице оформления заказа.

Страницы учетной записи клиента

is_account_page()Возвращает true на страницах учетной записи клиента.

Конечная точка

  • is_wc_endpoint_url() Возвращает true при просмотре конечной точки WooCommerce.
  • is_wc_endpoint_url( 'order-pay' ) Когда отображается страница конечной точки для оплаты заказа.
  • is_wc_endpoint_url( 'order-received' ) Когда отображается страница конечной точки для полученного заказа.
  • is_wc_endpoint_url( 'view-order' ) Когда отображается страница конечной точки для порядка просмотра.
  • is_wc_endpoint_url( 'edit-account' ) Когда отображается страница конечной точки для редактирования учетной записи.
  • is_wc_endpoint_url( 'edit-address' ) Когда отображается страница конечной точки для редактирования адреса.
  • is_wc_endpoint_url( 'lost-password' ) Когда отображается страница конечной точки для потерянного пароля.
  • is_wc_endpoint_url( 'customer-logout' ) Когда отображается страница конечной точки для выхода клиента из системы.
  • is_wc_endpoint_url( 'add-payment-method' ) Когда отображается страница конечной точки для добавления метода оплаты.

Запрос Ajax

is_ajax()Возвращает true, когда страница загружается через ajax.

Поделиться в соц. сетях:

  • Похожие записи
  • Комментарии
  • Вложения
Связывание товаров

Связывание товаров

Если товары продаются несколькими частями, но части нужно связать чтобы одну без другой нельзя было приобрести, можно связать такие товары. Как вариант такие товары можно заводить как один товар (в Читать далее »

WooCommerce AJAX Products Filter

WooCommerce AJAX Products Filter

Раннее данный фильтр участвовал в общем обзоре, в котором я приводил основные особенности. Рассмотрим подробнее работу с фильтром WooCommerce AJAX Products Filter (также он называется Advanced AJAX Product Filters). Работа Читать далее »

/
Отзывы к товарам

Отзывы к товарам

Рассмотрим различные аспекты такого функционала WC как отзывы к товарам. Изображения в отзывах Плагин YITH WooCommerce Advanced Reviews (6000) добавляет в комментарии поле изображение (можно добавлять несколько) и заголовок. Также Читать далее »

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

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

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