Timber и WooCommerce показывают пользовательскую категорию в цикле - PullRequest
0 голосов
/ 19 июня 2019

Я использую Timber и WooCommerce.У меня есть специальная таксономия под названием «Бренды», где каждому продукту присваивается категория бренда.Этот бренд должен быть указан над названием продукта внутри цикла продукта (tease-product.twig).Он должен отображаться на всех шаблонах, будь то первая страница, архив или отдельный файл.

То, что у меня есть на данный момент, работает для страниц архива, однако мне нужно, чтобы категория бренда отображалась на домашней странице и страницах с отдельным продуктом.

woocommerce.php

$context            = Timber::get_context();
$context['sidebar'] = Timber::get_widgets( 'shop-sidebar' );

if ( is_singular( 'product' ) ) {
    $context['post']    = Timber::get_post();
    $product            = wc_get_product( $context['post']->ID );
    $context['product'] = $product;

    // Get related products
    $related_limit               = wc_get_loop_prop( 'columns' );
    $related_ids                 = wc_get_related_products( $context['post']->id, $related_limit );
    $context['related_products'] =  Timber::get_posts( $related_ids );

    // Restore the context and loop back to the main query loop.
    wp_reset_postdata();

    Timber::render( 'views/woocommerce/single-product.twig', $context );
} else {
    $posts = $products = Timber::get_posts();
    $context['products'] = $posts;

    foreach($products as $product) {
        $product->brands = get_the_terms($product->ID, 'brands');

        if (empty($product->brands)) {
            $product->brands = new stdClass();
      }
    }

    if ( is_product_category() ) {
        $queried_object = get_queried_object();
        $term_id = $queried_object->term_id;
        $context['category'] = get_term( $term_id, 'product_cat' );
        $context['title'] = single_term_title( '', false );
    }

    Timber::render( 'views/woocommerce/archive.twig', $context );
}

tease-product.twig

<div class="column is-6 is-4-desktop is-3-widescreen has-text-centered">

    {{ fn('timber_set_product', post) }}

    <a href="{{ post.link }}">
        <img src="{{ post.thumbnail.src | resize(450) }}" alt="{{ post.title }}" />
    </a>

    {% if post.brands | length > 0 %}
        {% for brand in post.brands %}
            <div>{{ brand.name }}</div>
        {% endfor %}
    {% endif %}

    <a href="{{ post.link }}">
        <div>{{ post.title }}</div>
    </a>

    {% do action( 'woocommerce_after_shop_loop_item_title' ) %}
</div>

page.php (это чтобы показать товары на первой странице)

$context = Timber::get_context();
$page = new TimberPost();
$context['post'] = $page;

if ( is_front_page() ) {
    $top_selling = [
        'post_type' => 'product',
        'posts_per_page' => 4,
        'post_status' => 'publish'
    ];
    $context['top_selling'] =  new Timber\PostQuery($top_selling);
}

Timber::render(array('page-' . $page->post_name . '.twig', 'page.twig'), $context);

Спасибо за вашу помощь.

...