WordPress Tips

Using FacetWP with post to post relations

On a client site some posts have a relationship with other posts, set in meta fields. The client wanted to have a category filter for products on a brand page. In this blog I will explain what I did to achieve this.

The Relationship

Let me first explain what the post to post relationship is.

There are two Custom Post Types: Brand and Product. Products can have exactly one brand, and these are stored in a custom field made with ACF.

The Requirement

The client was showing all products of a brand on the brand page. This was the initial requirement, but as we all know, requirements can change. And so did this one. The client wants visitors to be able to filter the products by category. This allows them to better find a product they want, for example a desk, a chair or a separator wall.

The solution in words

When a client tells me about a requirement, or a change, I immediately start to browse through my known plugins library in my head, and fire up my code engine. Also in my head.

I made up the following:

  • Use FacetWP
  • Create a taxonomy product-category for product
  • Create a facet based on the product-category
  • Create a FacetWP template to show the products
  • Done

Well, that looks easy, and in the end it was, but I had some struggles to get it right. The brand page only shows products of that brand. So I thought it would be handy to create a FacetWP template file in which I try to limit the WP query to only get products of the shown brand. And that’s where the s^%# hit the fan. But hey, making mistakes equals learning.

The solution in code

The FacetWP template for this case is pretty simple. Just a default loop, with some code on how to show posts (products in this case). This file is stored in the root directory of the theme as facetwp-products.php so FacetWP can find it.

echo '<div class="products">';
while ( have_posts() ) {
echo '<div class="product">';
echo '<div class="product-image"><a title="' . get_the_title() . '" href="' . get_the_permalink() . '">' . get_the_post_thumbnail( get_the_ID(), 'rectangle-landscape' ) . '<h2 class="product-title">' . get_the_title() . '</h2></a></div>';
echo '</div>';
echo '</div>';


The template and facets are loaded in the page template for brands. And that’s done with this code:


// Add brand collection to single-brand with facets and facet template
add_action( 'genesis_entry_content', 'nstrm_add_brand_products', 15 );
function nstrm_add_brand_products() {
  if ( is_singular( 'brand' ) ) {
  // load facets
  echo facetwp_display( 'facet', 'productcategory' );

// load default template
  echo facetwp_display( 'template', 'products' );


The above code is used in a Genesis theme, but can be used in other themes as well.

When we stop after these steps, products will be shown and the facets will be active (if product-categories have been assigned to products). But, all products will be shown, and not just the products that belong on this brand page.

Adding brand awareness

We need to make sure FacetWP is aware that it should only show products that have the product-category set to the brand of the currently active brand page. This is where the facetwp_query_args filter comes in handy. We need to add some arguments to the query, being the brand. To do that we need the brand id.

On a ‘normal’ page or post, it;s easy to get the post ID. But, when using FacetWP, which uses AJAX calls, the post ID can sometimes not be present. So, we need to help FacetWP by adding the post ID to the page in a little snippet of JavaScript, and use that in the facetwp_query_args filter function.

// facetwp - pass current post_id to FacetWP
add_action( 'wp_head', function () {
  if ( is_singular( 'brand' ) ) {
global $post;
(function ($) {
$(document).on('facetwp-refresh', function () {
FWP_HTTP.post_id = '<?php echo $post->ID; ?>';
}, 100 );


And let’s create the filter function so we can use the brand id in the query that FacetWP uses.


//facetwp - add facetwp_query_args filter for limiting products by brand
add_filter( 'facetwp_query_args', function ( $query_args, $class ) {

  // get post_id from Ajax request
$post_id = (int) $class->http_params[ 'post_id' ];
if ( empty( $post_id ) ) {
$post_id = get_queried_object_id();

$query_args[ 'meta_key' ] = 'merk';
$query_args[ 'meta_value' ] = $post_id;
$query_args[ 'posts_per_page' ] = '-1';

return $query_args;
}, 10, 2 );


That’s it. Happy coding and thanks for reading. If you have any remarks or questions, please let me know in the comments.

Photo by rawpixel on Unsplash


WordCamps and sustainability


WordCamps generate waste. Since I have been organizing several WordCamps (the latest was WordCamp Rotterdam 2018), I have realized it is possible to reduce that stream of waste and make a WordCamp more sustainable and less damaging for the environment. 

Assist sponsors with their choice of swag, make clear agreements to only use products that are re-usable or recyclable. Make banners re-usable, print only what’s needed, use organic clothing. Find many more tips below.

Where to start?

Every event starts with planning. A date, a location, number of tracks, food, drinks, sponsor area, are some topics event organizers need to think about. 

Let’s compare the planning of an event to a coding project. All kinds of decisions have to be made, what framework to use, what privacy restrictions should be considered and what’s the impact of certain accessibility rules we should comply to? A project will be easier to manage if all (or most, depending on project management-style) of these requirements and rules are set in the beginning.

Same goes for planning a sustainable event. Think sustainable for every decision made.

Tips for organizers

The following tips are categorized, and give organizers information about the different focus areas where sustainability improvements can make a difference.

  • Meet online
  • Register all decisions and motivations for those decisions. This helps everybody to understand these decisions, and what their environmental impact (or lack of that) are.
  • Share lessons learned with other organizing teams.
  • Choose a venue that’s close to public transportation stop/stations to allow people to use public transportation and leave their cars at home. 
  • Discuss catering details with venue and make sure waste is recycled, or even better, reused on site. 
  • When supplying branded clothing, choose clotting from sustainable sources.
  • Print badges on sustainable, organic or recycled paper. Or use paper with a secondary function, like embedded seeds to grow some flower with the badge.

Tips for sponsors

  • Sponsor locally.
  • Send local employees if available.
  • Invest in sustainable swag.
  • Use reusable exhibition material (exhibition stand, banners, flyers, etc)

Tips for attendees

  • Travel by train if possible
  • Bring your own lanyard.
  • Bring your own reusable water bottle

If you read this, and have more tips, please drop ’em in the comments. Thanks.


Hungry dog


Dragonfly and tomatoes


Hairy little fellow


Ready for take-off


Foggy sunrise


Sun & flowers


Blue with two tiny clouds


Good morning spring!