Using Pods Framework to add Data to WordPress Widgets

Why use structured data on your website?

Google and other search engines use formatted structured data to power rich snippets in search results. For instance, when searching for ‘ticketmaster omaha’ in Google, the following listing appears:
rich snippet
These rich snippets make a search listing stand out, and therefore make it more likely someone might click on your listing. Check out what Google has to say about

Creating event data with Pods Framework

Photo Credit: issyeyre via Compfight cc
Photo Credit: issyeyre via Compfight cc

If you use WordPress, you can easily create a re-usable rich snippet widget with the Pods Framework. Here’s how!

Install Pods Framework plugin

Either search for ‘Pods Framework’ in your WordPress admin plugins area, or download Pods here.

Create pod and fields

If you’re new to the Pods Framework, you can learn how to get started at the Pods website. I won’t be showing how to use the Pods Framework, so you’ll need to know how to create a custom Pod and add fields to complete this tutorial. Speaking of fields, create a new pod and then add the following fields:

Find the item type code for events

If you’d like to learn more about event item types, visit the event item type page on Here’s what I use for my event item type.

<div style="background-color:#000000;padding:20px;" itemscope="" itemtype="">
  <h1><span itemprop="name">[Event Name]</span></h1>
  <span itemprop="startDate">[Start Date]</span> - <span itemprop="endDate">[End Date]</span>
    <a href="[Website Address]" target="_blank">Event Website</a>
      [Venue Name]
      <div itemprop="location" itemscope="" itemtype="">
          <div itemprop="address" itemscope="" itemtype="">
            <span itemprop="streetAddress"> [Street Address] </span>
            <span itemprop="addressLocality">[City]</span>, <span itemprop="addressRegion">[State]</span> <span itemprop="postalCode">[ZIP]</span>

Create and place a text widget with Pods code

Here’s my code with the Pods Framework integrated.

<div style="background-color:#000000;padding:20px;" itemscope="" itemtype="">

  <h1><span itemprop="name">[pods]{@event_name}[/pods]</span></h1>
  <span itemprop="startDate">[pods]{@start_date}[/pods]</span> - <span itemprop="endDate">[pods]{@end_date}[/pods]</span>
  <a href="[pods]{@httpsite}[/pods]" target="_blank">Event Website</a>

  <div itemprop="location" itemscope="" itemtype="">

    <div itemprop="address" itemscope="" itemtype="">

      <span itemprop="streetAddress">[pods]{@street_address}[/pods]</span>
      <span itemprop="addressLocality">[pods]{@city}[/pods]</span>, <span itemprop="addressRegion">[pods]{@state}[/pods]</span> <span itemprop="postalCode">[pods]{@zip}[/pods]</span>




Either paste my code into a widget, or add your own code.

Create a sample post and add Pods Framework field data

Now that you’ve set everything up, it’s time to test it out! Create a new page called ‘Hello World Event’ and scroll to the bottom of the page to see the Pods fields you created. Add some test information to try out the new widget (remember the widget must be visible on this page).
adding info to event fields for Pods Framework integration with schema

What next?

Nothing! You’re done! Preview your page to see your handy-work! Replicate this strategy for other item types such as places. To see the event item type in action, check out my WordCamp Omaha event page and view source. This page uses the same concept except with Divi 2.0 visual layout editor instead of widgets.

Have a question, need clarification, or have your own implementation ideas? Give me a shout in the comments or @ifyouwillit on Twitter!

3 Responses

  1. This looks really useful — I’m just now learning about Google Search Console and the still missing meta fields that the Events Calendar doesn’t add.

    Unfortunately the snippets above are not appearing. Any chance they are just broken links & easy to update?

    Thank you very much!

Leave a Reply

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