Skip Navigation

[Resolved] Retrieve custom post fields added by theme or plugin

This support ticket is created 5 years, 9 months ago. There's a good chance that you are reading advice that it now obsolete.

This is the technical support forum for Toolset - a suite of plugins for developing WordPress sites without writing PHP.

Everyone can read this forum, but only Toolset clients can post in it. Toolset support works 6 days per week, 19 hours per day.

Sun Mon Tue Wed Thu Fri Sat
- 7:00 – 14:00 7:00 – 14:00 7:00 – 14:00 7:00 – 14:00 7:00 – 14:00 -
- 15:00 – 16:00 15:00 – 16:00 15:00 – 16:00 15:00 – 16:00 15:00 – 16:00 -

Supporter timezone: Europe/London (GMT+00:00)

This topic contains 3 replies, has 2 voices.

Last updated by Nigel 5 years, 9 months ago.

Assisted by: Nigel.

Author
Posts
#1218579
Bildschirmfoto 2019-03-21 um 08.47.38.png
Bildschirmfoto 2019-03-21 um 08.43.57.png
Bildschirmfoto 2019-03-21 um 08.43.01.png

Currently I use types_get_fields() to retrieve a list of custom post fields from Toolset. However, the list only contains those fields added by Toolset. When creating a View, Toolset is also able to show other fields like post id/slug/title but also fields added by third party themes and plugins.

If I use an event calendar plugin for example and on one of the post types added by the event calendar has some custom fields, in a View, Toolset allows me to use these fields. I now want to extend my Toolset for Divi plugin so it supports those fields as well.

How can I ask Toolset for a list of all possible fields and how can I then render those fields on the frontend?

Please find attached an image of the post type with the custom fields, added by the event calendar plugin, my Divi plugin showing the list of text fields retrieved by types_get_fields() and the Toolset View where the fields are available.

#1218971

Nigel
Supporter

Languages: English (English ) Spanish (Español )

Timezone: Europe/London (GMT+00:00)

For non-Types fields you can just use the standard WordPress function get_post_meta.

You pass a post ID as the first argument.

If you don't pass any more arguments it will retrieve *all* the post meta as an array. The values will be the raw values as stored in the database, and you may want to format them differently before outputting them, but that will depend entirely on the custom fields.

(Types custom fields are also standard post meta, saved with a wpcf- prefix, so a Types field of 'priority' would be saved with a key of 'wpcf-priority'.)

Note that post meta keys that begin with an underscore (e.g. "_VenueAddress") are 'hidden' fields, they would not normally show on post edit screens when you choose to display custom fields.

#1219552

Ah so when I click the button on the view to load non toolset post fields, toolset under the hood also only calls get_post_meta, right?

That would explain a lot. And thanks for the hint with the underscore. I was wondering why the fields didn't show in the list but the plugin adds a custom meta box in which it shows those fields. So thats the reason.

Thank you so far.

#1219613

Nigel
Supporter

Languages: English (English ) Spanish (Español )

Timezone: Europe/London (GMT+00:00)

I haven't dug into the Views code to know what actually happens when you click the load non-Toolset post fields button does, but it surely must use get_post_meta.

Types fields are just WordPress post meta at the end of the day, but Types has special handling to know that a Select field—although stored just as a string of the selected option—has options available and should be rendered as a select field in the back end and in Toolset Forms.

But it is still just post meta.