I have created a custom post type with a metabox date from and date to.
Custom post type creation with the call back function of add_events_metaboxes
function event_list_init(){
$labels = array(
'name' => _x( 'Events', 'post type general name' ),
'singular_name' => _x( 'Event', 'post type singular name' ),
'menu_name' => _x( 'Events List', 'admin menu' ),
'name_admin_bar' => _x( 'Events List', 'add new on admin bar' ),
'add_new_item' => __( 'Add New Event' ),
'new_item' => __( 'New Event' ),
'edit_item' => __( 'Edit Event' ),
'view_item' => __( 'View Event' ),
'all_items' => __( 'All Events' ),
'search_items' => __( 'Search Events' ),
'not_found' => __( 'No Events found.' ),
'not_found_in_trash' => __( 'No Events found in Trash.' )
);
$args = array(
'labels' => $labels,
'description' => __( 'Create Events' ),
'public' => true,
'publicly_queryable' => true,
'show_ui' => true,
'show_in_menu' => true,
'query_var' => true,
'rewrite' => array( 'slug' => 'event' ),
'capability_type' => 'post',
'has_archive' => true,
'hierarchical' => true,
'menu_position' => 6,
'register_meta_box_cb' => 'add_events_metaboxes',
'menu_icon' => 'dashicons-calendar-alt',
'supports' => array( 'title', 'editor', 'author', 'thumbnail', 'excerpt', 'comments' )
);
register_post_type('events',$args);
}
add_action('init','event_list_init');
here is the call back function that instantiate a class to create the metabox and save post data via the action hook save_post
function add_events_metaboxes(){
new eventsListMetaBox();
}
class eventsListMetaBox{
/*
* Constructor that creates the meta box
*/
public function __construct(){
/**
* Render and Add form meta box
*/
add_meta_box('wpt_events_date', 'Events Date', array($this, 'fisa_events_date'), 'events', 'side', 'high');
/**
* Save Date from and to as meta key
*/
add_action('save_post',array($this, 'fisa_events_date_save'),1,2);
}
/**
* Render Form for Events date
*/
function fisa_events_date() {
global $post;
// Add an nonce field so we can check for it later.
wp_nonce_field( 'events_date_fromto', 'events_datefromto_nonce' );
// Echo out the field
echo '<label for="_fisa_date_from">Date From</label>';
echo '<input id="fisa-event-datefrom" type="text" name="_fisa_date_from" class="widefat" />';
echo '<br/><br/>';
echo '<label for="_fisa_date_to">Date To</label>';
echo '<input id="fisa-event-dateto" type="text" name="_fisa_date_to" class="widefat" />';
}
/**
* Meta key actual database insertion
*/
function fisa_events_date_save($post_id){
/**
* Check if nonce is not set
*/
// if (!isset($_POST['events_datefromto_nonce']))
// return $post_id;
//
// $nonce = $_POST['events_datefromto_nonce'];
// /**
// * Verify that the request came from our screen with the proper authorization
// */
// if(!wp_verify_nonce($nonce,'events_date_fromto'))
// return $post_id;
//
// //Check the user's permission
//
// if(!current_user_can('edit_post',$post_id) )
// return $post_id;
//Prepare and sanitize the data before saving it
$events_date = array(
sanitize_text_field( $_POST['_fisa_date_from']),
sanitize_text_field($_POST['_fisa_date_to'])
);
update_post_meta($post_id, '_fisa_events_date', $events_date);
}
}
My problem is I cant see _fisa_events_date
meta key in postmeta
table of wordpress.Can anyone please point what I have missed or what should I do to be able to save it?
You rely on
register_meta_box_cb
to display your meta box and to hook save logic intosave_post
. The problem is that WordPress runsregister_meta_box_cb
(which hooks intoadd_meta_boxes
) only when metaboxes need to be displayed – i.e. when the edit or add post pages are visited. But when WordPress is saving posts, it does not need to display the metaboxes, soregister_meta_box_cb
,add_events_metaboxes
, and yoursave_post
hook never get called.The simplest solution is to remove your
register_meta_box_cb
argument, and hook youradd_events_metaboxes
function to theadmin_init
event.You can do this just under your
add_action('init', 'event_list_init')
hook.Find a gist here.
According to the WordPress documentation,
register_meta_box_cb
:Which is too late to hook into the
save_post
.So I suggest you separately hook into the
save_post
somewhere in your functions.php file:Registering post type
Render the metabox
Saving the metabox
Please keep in mind that WordPress is not intended to operate fully Object-Oriented, thus there may be problems using its hooking system with OOP concepts.
As exposed in other answers, the issue is that
register_meta_box_cb
callback will only deal with the following:save_post
is not covered in the callback and has to be independent. This action hook happens:As you’re using a Class to wrap the meta box creation, I’d suggest wrapping everything inside it.
PS: check comments and add necessary checks inside
save_post
callback.Simplest & most flexible solution is to use Advanced Custom Fields.