Meta Box Lite
Meta Box

How to Display the Latest Products - P7 - Using Meta Box + Kadence

There are many different ways to show the latest products in a section on a page using Meta Box and page builders. In this tutorial, we will use Meta Box and Kadence.

We take the restaurants as an example for the posts as well as for the products:

Show the latest products in a section on a page using Meta Box and Kadence.

Video Version

Before Getting Started

As I said before, my products are restaurants. Each restaurant will be a post in a custom post type. In this section, only the 6 latest restaurants will be displayed.

The name of the restaurant and its image are the title and featured image of the post. Further, you may want to add some extra information about your products. I also have something such as logo, voucher, and address. This extra information will be saved in the custom fields created with Meta Box.

For this practice, we need these tools:

  • Meta Box core plugin: to have the framework for creating custom post types and custom fields;
  • MB Custom Post Types: to create a custom post type for the products;
  • Meta Box Builder: to have an intuitive UI to create custom fields in the backend;
  • Kadence: to build the page and create a section to display the latest posts. In this practice, I also use the pro version of Kadence.

Create a New Custom Post Type

Go to Meta Box > Post Types > New Post Type to create a new post type for the products.

Create a new custom post type

Create Custom Fields

Go to Meta Box > Custom Fields to create fields to save some extra information. These are the fields that I’ll create:

The created custom fields

After creating all the fields, move to the Settings tab > Location > choose Post Type as the Restaurants post type to apply these fields to this post type.

Set location for the created fields as post type

Go to the post editor, you will see all of the created custom fields.

All the created fields appear in the post editor

Just fill in the information.

Add the Section to the Homepage

Let’s edit the homepage to create a section for the latest restaurants.

First, add a Heading block.

Add a Heading block to name the section.

To display the wanted posts, we need the Query Loop block.

The Query Loop block to display the wanted posts.

After choosing a template for the Query Loop, you will see some default blog posts displayed.

Default blog posts

Their order is by date and descending. It means that the latest post will be shown first, followed by the older ones. That’s exactly what we want.

Now, our work is just changing the posts from blog posts to restaurants. Before that, you can remove some information from the post if you don’t want to display.

To change the posts to the restaurants, move to the Post Type section on the right sidebar and choose your post type from the list. In this case, it’s Restaurant.

Change the posts to the restaurants.

Look at the picture below! You can see that the titles are replaced by the restaurants’ names.

The restaurants’ names appear.

It’s time to get some information for the restaurants.

First, add the Advanced Image block to display the restaurant’s image.

Add the Advanced Image block to display the restaurant’s image.

There is an icon in the picture below to enable dynamic data for this block. Click on the icon, then choose the Featured Image from the list.

Enable dynamic data for the Advanced Image block.

Next, add a Paragraph block for the voucher information.

Add a Paragraph block for the voucher information.

Click on the Dynamic Data button, and choose Post Custom Field option since the voucher information is saved in a custom field.

After that, in the Custom Field section, we should choose the Custom Input option instead of choosing a field as usual. This is because the Voucher field is the Checkbox List type, and I want to get the label of the selected option from the field.

In the Custom Field section, choose the Custom Input option.

In the Custom Meta Key section, fill in the ID of the Voucher field.

In the Custom Meta Key section, fill in the ID of the Voucher field.

Now, the voucher information will not display, just a text like this will display instead.

The voucher information will not display.

Don’t worry! You will see the right information on the frontend. So, keep moving.

To get the restaurant's address, add another Paragraph block and add dynamic data for it.

To get the restaurant's address, add another Paragraph block and add dynamic data for it.

The logo will be the same as the feature image. So, choose an Advanced Image block and add dynamic data for it. Also choose Post Custom Field, then select the name of the field that saves the logo.

Get the logo information.

If you have more kinds of information for your products, just follow this way to display them.

Finally, I set the number of posts to display in this section as well as change the layout to the Grid style.

Set the number of posts as well as change the layout to the Grid style.

Go to the homepage, you can see all of the information about the restaurants displayed correctly.

All of the information about the restaurants displayed correctly.

Style the Section

Go back to edit the homepage. You can add some classes for the blocks if you want to use some CSS to style them.

Add some classes for the blocks.

You can also change some settings for each block.

For advanced style, you may want to use some CSS. Go to the Customizer section > Additional CSS and add some code.

Go to the Customizer section > Additional CSS and add some code.

I uploaded all of the code on Github, you can refer to it.

After adding some CSS, you can see the new look of the section immediately.

Show the latest products in a section on a page using Meta Box and Kadence.

Last Words

We’ve gone through all the necessary steps to create the latest products section using Meta Box and Kadence. Now, it's time to give it a go and let us know how it turns out! We would love to hear about your experience. Thank you for reading!

 

Leave a Reply

Your email address will not be published. Required fields are marked *