- The post relations types
- How to create a post relation
- Displaying the related posts of different type with JetEngine
- Grandparents Relations
JetEngine is the first-class addon for Elementor editor which allows adding the dynamic listing and grid layouts and provides a way to display the custom posts and taxonomies within any page templates.
Today we’ll show you how to choose the needed posts relations and how to set them with the JetEngine plugin.
JetEngine provides you with 3 types of such relations, so let’s take a quick overview of them.
The post relations types
One-to-one posts relation
This relations type implies that one parent post type can be connected only to one child post type. E.g., one country has only one capital, and there are no capitals that are actually related to many countries at once. So the relation between the “Country” and “Capital” post types should be “one-to-one”.
One-to-many posts relation
This means that one parent post type can be related to many other child post types. E.g., one book has only one author, however, one author could have written multiple books. So the parent “author” post type should have “one-to-many” relations type with the “book” child post type.
Many-to-many posts relation
Allows linking a lot of parent post types to many child post types at once. E.g., the is a “product” child post type, which is related to the “shop” parent post type. However, there are many products in each of the shops, and there are different shops where each of the products can be sold. So, the relations are “many-to-many”.
How to create a post relation
Open the JetEngine > Post Relation directory in the WordPress Dashboard. Click the “Add New” button and start filling the fields.
Provide the title for post relation in the Name field. After that, select the post type both for parent and child posts in the Parent post type and Child post type drop-downs. Afterward, set the needed posts relation in the Relation type dropdown.
In the Advanced Settings section you can also see two toggles:
- Register controls for parent post type. Enable this option in order to add the Related children meta box to the parent post’s editing page;
- Register controls for child post type. If you want to add a Related parent meta box to the child post’s editing page – turn this option on.
Finally, click the “Add Relation” in order to save it.
Displaying the related posts of different type with JetEngine
1 Step— Create a Single Page template
First, let’s clear up where we should add the related posts. Usually, the related posts are displayed on the Single Pages, so in order to add them, one should create the template.
Open the WordPress Dashboard and proceed to the Crocoblock > Theme Builder directory and click the “Add New” button. To learn more about creating the Single Page template feel free to check this tutorial.
2 Step— Create listings for Parent, Child, or both post types
Proceed to JetEngine > Listings block and here create a new listing for the post type you would like to display on the page. For more information, check out our Listing template creation tutorial.
3 Step— Open page in Elementor and customize it
Now open the Single Page template to which you’ve decided to add the related posts, in the Elementor editor. Find the Listing Grid widget and drop it to the page’s canvas. Choose the listing template in the listing drop-down menu and proceed to the Post Query section.
Add a new item and choose the “Posts&Author Parameters” option in the Type drop-down list.
Afterward, paste the
%related_parents_from|post-type-slug% macros into the Include posts by IDs field. The macro code depends on the relations between the posts, as well as the type of post template you are working with.
Don’t forget to replace the “
post-type-slug” with an actual slug of the post type and click the “Update” green button on the bottom of the menu.
This relation type allows you to make a hierarchical path between two separate relations.
Let’s puzzle it out on the example. As an example, we took such post types as Continents, Countries, and Tours. It is possible to create two relations Continents > Countries and Countries > Tours and connect these two relations in one path.
So, to create a grandparent relation, you need to have two relations. Create them and open the relation that has the lower hierarchy. In our case, it will be the Continents > Country relation.
In the Parent Relation block type “grandparent_name to parent_name”. In our case, it will be “continents to country”.
To display this type of relation you will also need a macro code. Add the Listing Grid to the page and choose the listing related to the certain Single post. Open the Post Query section and paste on of these macro codes:
%get_grandparent|from-post-type%— get the parent post for the current post type;
%get_grandchild|from-post-type%— the search will go from the current post to the child’s one.
Instead of “
from-post-type” you need to enter the slug of the post type.
It is a little overview for you to have an idea about this type of relation. To get to know more, kindly take a look at the full tutorial.
Great! Now you’ve created the post relations and learned to display them on the Single Page!