PIT Designs Logo

ACF Repeater Table in Oxygen Builder

About the author: Ninos
I'm the owner and founder of PIT Designs. I love creating digital presence and creative digital solutions for our clients.


Posted 11 months ago on August 14th, 2019. Last modified on June 7th, 2020


Tags: | | |

How to create and style an HTML Table in Oxygen builder using dynamic data from ACF Repeater table.

With the recent updates of Oxygen bringing the Repeater fields to the builder. It's a great addition, which opens up to a lot of possibilities. One particular use that I needed for the Oxygen Repeater module (using ACF Repeater) is to output the results as a table.

The builtin Repeater in Oxygen builder doesn't allow for such manipulation at the moment. However, there's a workaround solution to get Oxygen builder output ACF Repeater table. Which you can style further with the magic of CSS.

Step 1: Starting ACF Repeater table

Create your custom repeater fields, in this example I'll create a simple [subject] [result] table. The method can be replicated to any number of columns.

Create a field group:

Label: Subject & Results

Field name: r_subject_&_results

Field type: Repeater

ACF Repeater table

Expand the Repeater field and add the nested fields. In this case will be:

Label: Subject with field name: r_subject.

Label: Result with field name: r_result

ACF Repeater to Table

Step 2: Using Oxygen Builder

Create the template, page, any other CPT you want to add the table to.

Insert the Code Module, and add below PHP code:

<!--
r_subject_&_results = ACF Repeater
r_subject = Field 1
r_result = Field 2
--><!-- repeater fields table output-->
<?php
$i = 0;
if( have_rows('r_subject_&_results') ): ?><table class="r-table"><tr><th>Subject</th><th>Result</th></tr><?php while( have_rows('r_subject_&_results') ): the_row(); $i++;$post = get_sub_field('r_subject');if( empty($post) )
{
continue;
}setup_postdata( $post );?><?php if( $i == 1 ): ?>

<tr>
<?php endif; ?>

<td><?php the_sub_field('r_subject'); ?></td>
<td><?php the_sub_field('r_result'); ?></td>

</tr>

<?php if( $i == 2 ): $i = 0; ?>

<?php endif; ?>

<?php endwhile; ?>

<?php wp_reset_postdata(); // IMPORTANT - reset the $post object so the rest of the page works correctly ?>

<?php endif; ?>
</table>

The above code will basically create a table based on the ACF repeater fields r_subject and r_result

Step 3. Applying CSS Styles to the Table

As you can see in the above code, the table is created and given a class of r-table


<table ID="r-table">

And just like an HTML Table it has < th > and < tr > that you can style further.

This is easily done with CSS. Here's a reference to CSS Tables styling on W3School.

if you have any question, feel free to write in the comments below.

Happy Oxygen-ing!






5/5


(2 Reviews)

Do we all agree that Coffee is the fuel that feeds the free content creating?
Is 2020 a Good Time to Start a Career in Tech?

In terms of demand, the tech field has become what in the past used to be the stock market. Back […]

Interview & Business Lessons From Paul's Hair Port

It is a remarkable milestone when a business celebrates its 20th year anniversary in business. Paul’s Hair Port, located in […]

Should You Trust Kuraz Insurance Company in Erbil?

Kuraz insurance company based in Erbil. Claims to be professionals in the business of ensuring your health, assets, travel, and […]

How to Create Before & After Slider in Oxygen

Before & After slider is a cool effect, used to provide a real-time sense of comparison of two images. If […]

Title With Lines On Sides in Oxygen (CSS Only)

Working on a website, I needed to create a title with lines on sides. A sort of text-decoration-cool-design-thing. That looks […]

How to Create Animated Number Counters in Oxygen

Animated number counters are seen on many landing pages. They bring a cool effect (movement) to the page and convey […]

All the Shape Dividers in Oxygen Builder

Shape Dividers in Oxygen builder is the new cool feature added. Shape dividers have become more and more used in […]

Leave a Reply

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

For security, use of Google's reCAPTCHA service is required which is subject to the Google Privacy Policy and Terms of Use.

I agree to these terms.

chevron-downmenu-circlecross-circle