Show ACF Gallery Images in a Divi Gallery Module

Written by Dan Mossop

The Divi Gallery module is great for adding images to your posts and projects. But what if you'd like the convenience of creating a template for these posts / projects and dynamically populate the gallery module with images from an Advanced Custom Fields Pro gallery? Here's how you can configure a Divi Gallery module to load images from ACF Pro. 

Load an ACF Gallery into a Divi Gallery Module using PHP Code

With a bit of PHP code, we can filter the Divi Gallery module attributes and replace the gallery ids with those loaded from ACF. But first, let's walk through an example setup to demonstrate this.

Step 1: Set up the Advanced Custom Fields Gallery Field

If you haven't already, install Advanced Custom Fields Pro (the free version of Advanced Custom Fields, while great, doesn't support galleries). Then create a new Field Group and set it up as shown: 

Make sure your Field Type is set to "Gallery" and the return format is set to "Image Array". You can choose whatever Field Label and Field Name you like, but make a note of your Field Name as we'll need to reference it in our PHP code.

Now, below that, assign your field group to the location you want it to show up, e.g. posts, pages or projects. In this example, I'm going to set the field group to show on projects so that I can add an ACF gallery to any project custom post type I create:

Step 2: Add Images to your Gallery

If you now open one of your posts, pages or projects (depending on what you assigned your field group to) in the backend WordPress editor and below the post content you should see that ACF has added an area to upload your gallery images. Upload some images to it and it should look something like this:

Step 3: Set up your Theme Builder Template

If you haven't already done so, go to the Divi Theme Builder at "WP Dashboard > Divi > Theme Builder" and create a new template for your posts:

Assign the template to the posts or post types you want to display the template / gallery on. This should match the location you assigned your ACF field group to, above:

Now add a select to add a Custom Header, Body or Footer layout to your template depending on which part of the page you want to design in the template and open it for editing.

Step 4: Add your Gallery Module

Now, at the appropriate place in your template, add a Divi gallery module. We'll leave the gallery's Images field empty as our PHP code will automatically override this:

If you're not comfortable adding PHP code to your site, then at this point you might like to grab a copy of the Divi Dynamic Helper plugin from PeeAye Creative instead. Divi Dynamic Helper adds dynamic content support to the Images field of the Divi Gallery module, letting you select your ACF gallery from the dynamic content menu, instead of injecting it with the PHP code given below.

We'll give the gallery module a custom class "acf-gallery" that we'll use in our code to identify this gallery as one that should load ACF gallery images:

Note that the visual builder preview may display some images from your media library as placeholder content – but these will be replaced with ACF gallery images on the front end by the PHP code that we'll add next.

The only change you may need to make is to change "project_gallery" to the Field Name you assigned to your ACF gallery (if you set something different than that shown in my example).

Step 5: Add the PHP Code

Now that we've set up the ACF gallery and template with gallery module, let's add the PHP code that will connect the two. Add this PHP code to your site:

function divibooster_acf_gallery_ids($attrs) {
    if (isset($attrs['module_class']) && strpos($attrs['module_class'], 'acf-gallery') !== false && function_exists('get_field')) {
        $acf_gallery_images = get_field('project_gallery', get_the_ID());
        if ($acf_gallery_images) {
            $image_ids = [];
            foreach ($acf_gallery_images as $image) {
                $image_ids[] = $image['ID'];
            }
            $attrs['gallery_ids'] = implode(',', $image_ids);
        }
    }
    return $attrs;
}
add_filter('et_pb_module_shortcode_attributes', 'divibooster_acf_gallery_ids');

Note that if your custom field is empty, this code will fall back to the Divi default behavior of showing the oldest images from your media library as placeholders. If you expect to have empty custom fields in some cases, you may wish to hide the module entirely when the custom field is empty.

Step 6: View the Result

Now, go to the post (or page, project or other custom post type) whose ACF gallery you added images to in Step 2. View the page on the front-end and you should hopefully now see the gallery module displaying the images sourced from the ACF gallery, alongside the rest of your template and post content, e.g.:

We may earn a commission when you visit links on our website.

Enhance Your Divi Site with Dynamic Content

Unlock the full potential of your Divi site by seamlessly integrating Advanced Custom Fields with the Divi Gallery module. Use the Divi Dynamic Content Extended plugin to effortlessly connect dynamic ACF data like galleries to Divi modules, making your designs more responsive and interactive.

Latest Posts

Adjust Lightbox Arrow Size in Divi Gallery

Customize the size of the navigation arrows that appear in your gallery lightbox so they’re easier to see and aligned with your site’s design. Whether you want larger, more accessible controls or a subtler look, setting a precise arrow size creates a more polished...

Change Lightbox Arrow Color in the Divi Gallery Module

Make the lightbox navigation arrows in your Divi Gallery match your brand and stand out against your images by assigning a custom color. This improves visual consistency, enhances accessibility with better contrast, and elevates the overall browsing experience for...

Change the Divi Gallery Module Grid Image Scaling

Divi’s Gallery module offers a great way to showcase images, but it can sometimes stretch or crop them in unwanted ways. This article explains how to manage the module’s image scaling behavior to ensure your images are displayed at the correct size and aspect...

Set Custom CSS IDs for Individual Divi Accordion Items

Assigning unique CSS IDs to specific Divi Accordion items allows for precise control over styling, targeting, and linking within your page content. This ability is particularly useful when you want to apply custom designs or create anchor links to particular accordion...

Enable Swipe Navigation in the Divi Gallery Lightbox

Enabling swipe navigation in the Divi Gallery module's lightbox allows users to seamlessly browse through gallery images by swiping left or right, creating a more interactive and mobile-friendly experience. This functionality can significantly improve user engagement...

About Dan Mossop

Dan is a Scottish-born web developer, now living in Brisbane with his wife and son. He has been sharing tips and helping users with Divi since 2014. He created Divi Booster, the first Divi plugin, and continues to develop it along with 20+ other Divi plugins. Dan has a PhD in Computer Science, a background in web security and likes a lot of stuff, 

9 Comments

  1. This works great, thank you a lot :)

    Reply
    • Hey woo, happy to hear it helped :) If there's ever anything else you need help with, just let me know. Thanks!

      Reply
    • Hey Chris, I'm glad were able to figure it out and thanks for pointing out the tutorial. It looks like the link in your comment is just a link back to the current post… I'm guessing this is the tutorial you are referring to:

      Hide Divi Module when a Custom Field is Empty

      I've updated the post to link to it. Many thanks!

      Reply
  2. This works great, however I am having one issue. I've setup a post type and made a template for that post type with Divi builder. On a post where I actually add gallery images into the ACF fields, it works very well. But when I don't add gallery images on a post, the Divi gallery will just display the three oldest images from the media library as placeholders.

    How do you stop these placeholder images from being added, or better yet, just hiding the gallery altogether if there are no ACF gallery images added to the post?

    Reply
  3. Works perfectly!

    Had to tweak one thing, the $image['ID'] in the foreach should be just $image.

    Reply
    • Great! I'm glad it's working for you, Maurice – thanks for letting me know.

      For the tweak, is your "Return Format" on the ACF field definition set to "Image ID" by any chance? My code assumes the "Image Array" format is used, for which the return value for each image is an array of data with the ID stored in an "ID" field. If you change the format to "Image ID" then the return value for each image is just the image ID, so your version would work for that. The Image ID option actually leads to need to neater code – you don't even need the foreach – but since "Image Array" is the default I went with that. But maybe I'm wrong and you're not using the "Image ID" format…?

      Reply
      • Hey Dan!

        Afterwards I had to revert to $image['ID'].

        The only thing I'm now experiencing:
        I have the ACF on product_cat. If the product_cat has no products it works perfectly, but as soon as products are involved it stops working. Probably because the loop through the products messes things up. I haven't been able to workaround yet.

        Would you know a solution?

        Reply
        • Hey Maurice! I haven't had a chance to test it myself yet, but it might be that get_the_ID() is picking up the ID of one of the posts, rather than the category. Try replacing get_the_ID() with get_queried_object() – that should, I think, get the code to retrieve the field from the category itself, regardless of whether or not the loop is running. If it doesn't fix it let me know and I'll try to set up a proper test to figure out what's going on. Thanks!

          Reply

Submit a Comment

Comments are manually moderated and approved at the time they are answered. A preview is shown while pending but may disappear if your are cookies cleared - don't worry though, the comment is still in the queue.

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