Pure Metafields is very light weight plugin tused to create custom metabox for any post type like page, post and your custom post type support it.
The Pure Metafields Plugin is a powerful tool designed to enhance the functionality and flexibility of your WordPress website. With this plugin, you can easily create and manage custom meta boxes, adding extra fields and data to your posts, pages, and custom post types.
✅ Custom Meta Boxes: Create unlimited custom meta boxes with ease. Define the title, placement, and priority of each meta box to suit your needs.
✅ Flexible Field Types: The plugin offers a wide range of field types to choose from, including text, textarea, select, checkbox, radio buttons, date picker, and more. Customize the field options and validation rules effortlessly.
✅ Repeatable Fields: Enable the ability to repeat fields, allowing users to add multiple instances of the same field dynamically. Perfect for scenarios where you need to capture multiple sets of data.
✅ Conditional Logic: Set up conditional logic to show or hide fields based on the value of other fields. This feature adds versatility and improves the user experience of your forms.
✅ Built-in Validation: Ensure data accuracy by implementing validation rules for your fields. You can define required fields, validate input formats, and customize error messages effortlessly.
✅ Save and Retrieve Meta Data: The plugin provides simple functions to save and retrieve meta data, allowing you to access and utilize the stored information in your themes or plugins.
✅ Integration with WordPress API: Seamlessly integrate with the WordPress API and extend its functionalities. Hook into actions and filters to manipulate meta data and create dynamic interactions.
If your server is not connected to the Internet, then you can use this method-
If you are unable to use any of the methods due to internet connectivity and file permission issues, then you can use this method-
wp-content/plugins/
Paste the code to your theme’s functions.php with the add_filter hook.
<?php add_filter( 'tp_meta_boxes', 'themepure_metabox' ); function themepure_metabox( $meta_boxes ) { $meta_boxes[] = array( 'metabox_id' => '_your_id', 'title' => esc_html__( 'Your Metabox Title', 'textdomain' ), 'post_type'=> 'post', // page, custom post type name 'context' => 'normal', 'priority' => 'core', 'fields' => array(), ); return $meta_boxes; } ?>
<?php // text field for normal text array( 'label' => 'Text Field', 'id' => "_your_id", 'type' => 'text', // specify the type field 'placeholder' => '', 'default' => '', // do not remove default key ) // textarea field for large text array( 'label' => 'Textarea Field', 'id' => "_your_id", 'type' => 'textarea', // specify the type field 'placeholder' => 'Type...', 'default' => '', 'conditional' => array() ) ?>
<?php array( 'label' => esc_html__( 'Your Title', 'textdomain' ), 'id' => "_your_id", 'type' => 'image', // specify the type field 'default' => '', 'conditional' => array() ) // Gallery field for multiple images upload array( 'label' => esc_html__( 'Your Title', '' ), 'id' => "_your_id", 'type' => 'gallery', // specify the type field 'default' => '', 'conditional' => array() ) ?>
<?php array( 'label' => esc_html__( 'Your Title', 'textdomain' ), 'id' => "_your_id", 'type' => 'switch', 'default' => 'off', 'conditional' => array() ) ?>
<?php array( 'label' => esc_html__( 'Files Included', 'pure' ), 'id' => "{$prefix}_files_options", 'type' => 'checkbox', 'default' => array( 'wordpress', 'react', 'html', 'psd', 'vue' ), 'options' => array( 'wordpress' => 'Wordpress File Included?', 'react' => 'React File Included?', 'html' => 'HTML File Included?', 'psd' => 'PSD Included?', 'vue' => 'Vue JS File Included?' ) ) ?>
<?php // multiple buttons group field like multiple radio buttons tabs array( 'label' => esc_html__( 'Group Buttons Tab', '' ), 'id' => "_your_id", 'desc' => '', 'type' => 'tabs', 'choices' => array( 'button_1' => 'Button 1', 'button_2' => 'Button 2', 'button_3' => 'Button 3', ), 'default' => 'button_1', 'conditional' => array() ) ?>
<?php // select field dropdown array( 'label' => esc_html__('TP Select Field', 'textdomain'), 'id' => "_your_id", 'type' => 'select', 'options' => array( '1' => 'one', '2' => 'two ', '3' => 'three ', '4' => 'four ', '5' => 'five ', ), 'placeholder' => 'Select an item', 'conditional' => array(), 'default' => '' ) ?>
<?php // Datepicker for date field array( 'label' => 'Datepicker', 'id' => "_your_id", 'type' => 'datepicker', 'placeholder' => '', 'default' => '', 'conditional' => array() ) ?>
<?php // Colorpicker for color field array( 'label' => 'Colorpicker', 'id' => "_your_id", 'type' => 'colorpicker', 'placeholder' => '', 'default' => '', 'conditional' => array() ) ?>
<?php // posts select dropdown field ( Lists any post types posts) array( 'label' => esc_html__('TP Posts Select', 'textdomain'), 'id' => "_your_id", 'type' => 'select_posts', 'post_type' => 'post', // specify the post type you want to fetch 'placeholder' => 'Select a post', 'conditional' => array(), 'default' => '' ) ?>
In the above code example where fields array paste the repeater array inside fields array
<?php array( 'label' => esc_html__('Field Title', 'textdomain'), 'id' => "_your_id", 'type' => 'repeater', // specify the type "repeater" (case sensitive) 'conditional' => array(), 'default' => array(), 'fields' => array( array( 'label' => esc_html__('Your Title', 'textdomain'), 'id' => "_your_id", 'type' => 'select', 'options' => array( 'footer_1' => 'Footer 1', 'footer_2' => 'Footer 2', 'footer_3' => 'Footer 3' ), 'placeholder' => 'Select a footer', 'conditional' => array(), 'default' => 'footer_1', ), array( 'label' => esc_html__('Select Footer Style', 'textdomain'), 'id' => "_footer_style_2", 'type' => 'select', 'options' => array( 'footer_1' => 'Footer 1', 'footer_2' => 'Footer 2', 'footer_3' => 'Footer 3' ), 'placeholder' => 'Select a footer', 'conditional' => array(), 'default' => 'footer_1', 'bind' => "_footer_template_2" // bind the key to be control with conditions ), array( 'label' => esc_html__('Select Footer Template', 'textdomain'), 'id' => "_footer_template_2", 'type' => 'select_posts', 'placeholder' => 'Select a template', 'post_type' => 'tp-footer', 'conditional' => array( "_footer_style_2", "==", "footer_2" // First parameter will be the id of control field and so on ), 'default' => '', ) ) ) ?>
<?php array( 'label' => 'Text Field', 'id' => "_your_id", 'type' => 'text', 'placeholder' => '', 'default' => '', 'conditional' => array( "_id_of_any_field", "any operator", "value_of_that_field" ) ) array( 'label' => 'Text Field', 'id' => "_your_id", 'type' => 'text', 'placeholder' => '', 'default' => '', 'conditional' => array( "_field_id", "==", "_field_value" ) ) ?>
<?php add_filter( 'tp_meta_boxes', 'themepure_metabox' ); function themepure_metabox( $meta_boxes ) { $meta_boxes[] = array( 'metabox_id' => $prefix . '_post_meta_gallery_box', 'title' => esc_html__( 'Post Meta Gallery', 'donafund' ), 'post_type'=> 'post', 'context' => 'normal', 'priority' => 'core', 'fields' => array( array( 'label' => esc_html__( 'Gallery Format', 'textdomain' ), 'id' => "{$prefix}_gallery_5", 'type' => 'gallery', 'default' => '', 'conditional' => array(), ), ), 'post_format' => 'gallery' // if u want to bind with post formats ); $meta_boxes[] = array( 'metabox_id' => $prefix . '_post_meta_audio_box', 'title' => esc_html__( 'Post Meta Audio', 'donafund' ), 'post_type'=> 'post', 'context' => 'normal', 'priority' => 'core', 'fields' => array( array( 'label' => esc_html__( 'Audio Format', 'donafund' ), 'id' => "{$prefix}_audio_format", 'type' => 'text', 'placeholder' => esc_html__( 'Audio url here', 'donafund' ), 'default' => '', 'conditional' => array() ), ), 'post_format' => 'audio' // if u want to bind with post formats ); $meta_boxes[] = array( 'metabox_id' => $prefix . '_post_meta_video_box', 'title' => esc_html__( 'Post Meta Video', 'donafund' ), 'post_type'=> 'post', 'context' => 'normal', 'priority' => 'core', 'fields' => array( array( 'label' => esc_html__( 'Video Format', 'donafund' ), 'id' => "{$prefix}_video_format", 'type' => 'text', 'placeholder' => esc_html__( 'Video url here', 'donafund' ), 'default' => '', 'conditional' => array() ), ), 'post_format' => 'video' // if u want to bind with post formats ); return $meta_boxes; } ?>
<?php $value = function_exists('tpmeta_field')? tpmeta_field('meta_key_id_here') : ''; ?>
<?php $value = function_exists('tpmeta_field')? tpmeta_field('meta_key_id_here', $post_id) : ''; ?>
<?php $tp_gallery_images = function_exists('tpmeta_gallery_field') ? tpmeta_gallery_field('gallery_meta_key') : ''; //tpmeta_gallery_field($string_ids, $size) foreach($tp_gallery_images as $single_image_src){ echo $single_image_src['url'] ."<br>"; echo $single_image_src['alt'] ."<br>"; } ?>
<?php $tp_image = function_exists('tpmeta_image_field') ? tpmeta_image_field('image_meta_key') : ''; // tpmeta_image_field($id, $size) echo $tp_image['url']; echo $tp_image['alt']; ?>
<?php $tp_repeater = function_exists('tpmeta_field') ? tpmeta_field('repeater_meta_key') : ''; // tpmeta_field($meta_key, $post_id) foreach($tp_repeater as $row){ // Iterate the data with loop echo $row['repeater_sub_field_key'] // get the subfield value by repeater inner array field key } ?>
<?php $tp_repeater = function_exists('tpmeta_field') ? tpmeta_field('repeater_meta_key') : ''; // tpmeta_field($meta_key, $post_id) foreach($tp_repeater as $row){ // Iterate the data with loop $gallery = tpmeta_gallery_images($row['repeater_sub_field_key'], 'image_size'); $image = tpmeta_image($row['repeater_sub_field_key'], 'image_size'); } ?>
A meta box is a user interface element in the WordPress backend that allows you to add extra fields and data to your posts, pages, or custom post types. It provides a way to extend the default functionality of WordPress and capture additional information relevant to your content.
A meta box plugin, such as the WordPress Meta Box Plugin, offers a user-friendly and efficient way to create and manage custom meta boxes. It eliminates the need for manual coding and provides a flexible interface for adding fields, defining field types, and implementing validation and conditional logic. Using a plugin saves you time and effort while enhancing the functionality and customization options of your WordPress website.
Yes, the WordPress Meta Box Plugin allows you to create unlimited custom meta boxes. You can define the title, placement, and priority of each meta box to organize and display the additional fields according to your specific requirements.
The plugin offers a wide range of field types to choose from, including text, textarea, select, checkbox, radio buttons, date picker, and more. You can select the most suitable field type for each meta box, depending on the type of data you want to capture.
Yes, the plugin supports repeatable fields. This means you can enable the option to add multiple instances of the same field dynamically. It is especially useful when you need to capture multiple sets of data, such as multiple addresses or multiple related items.
The WordPress Meta Box Plugin provides a straightforward way to set up conditional logic for your fields. You can define rules to show or hide fields based on the value of other fields. This feature allows you to create dynamic interactions and display only the relevant fields to the user.
Yes, the plugin includes built-in validation features. You can define validation rules for your fields, such as required fields, input format restrictions, and customized error messages. This ensures that the data entered by users meets your specific requirements and improves the data accuracy.
The WordPress Meta Box Plugin provides simple functions to save and retrieve meta data. You can easily access the stored information in your themes or plugins using the provided functions, allowing you to utilize the meta data for various purposes, such as displaying custom information or performing calculations.
Yes, the plugin seamlessly integrates with the WordPress API. You can leverage its functionalities by hooking into actions and filters to manipulate meta data and create dynamic interactions. This integration provides extensive possibilities for extending and customizing your WordPress website.
For support or to report any issues, please visit the plugin’s GitHub repository and open a new issue. We are committed to providing assistance and resolving any problems you may encounter while using the plugin.
Yes, contributions are welcome! If you have any ideas or improvements for the plugin, feel free to submit a pull request on the plugin’s GitHub repository. We appreciate community involvement and value your suggestions in making the plugin even better.