J'ai créé un type de message personnalisé. J'ai également ajouté une méta-boîte à mon type de message personnalisé. Ce que je veux faire maintenant, c’est d’ajouter ma boîte méta en tant que colonnes à ma table de messages personnalisée.
Mon message personnalisé
add_action( 'init', 'create_post_type' );
// Create my custom post
function create_post_type() {
register_post_type( 'spark_stars',
array('labels' =>
array(
'name' => __( 'Stars' ),
'singular_name' => __( 'Star' )),
'public' => true,
'has_archive' => true,
'supports' => array( 'title', 'editor', 'thumbnail'),
)
);
}
add_action('add_meta_boxes','stars_meta_box');
// Create my meta box
function stars_meta_box(){
global $post;
add_meta_box('first_name_meta_box','First Name',
'first_name_meta_box_html','spark_stars','normal','default');
}
// Create meta box html
function first_name_meta_box_html(){
wp_nonce_field('first_name','first_name_meta_box_nonce');
$value = get_post_meta(get_the_ID(), 'first_name_meta_box_key', true ); ?>
<label>First Name: </label>
<input type="text" name="fname"
value="<?php echo esc_attr($value); ?>"/>
<?php {
add_action('manage_spark_stars_posts_columns',.....) // is this the function?
add_filter('manage_spark_stars_posts_columns',.....) // is this the function?
Comment puis-je obtenir cette méta-boîte en tant que colonne dans ma table de publication personnalisée et comment puis-je obtenir la vignette de chaque publication en tant que colonne dans ma table de publication personnalisée?
Je pense que le filtre manage_{$post_type}_posts_columns
est ce que vous recherchez. Vous pouvez ensuite utiliser l'action manage_posts_custom_column
pour gérer le contenu de chaque colonne de la vue Liste des publications.
MODIFIER::
Pour ajouter des colonnes personnalisées à votre type d'article personnalisé, vous devez filtrer les colonnes en sortie à l'aide de manage_{$post_type}_posts_columns
où $post_type
est le nom que vous avez utilisé pour enregistrer le type d'article personnalisé. Dans votre cas, ce serait spark_stars
.
La variable $columns
est un tableau des colonnes actuelles. Vous pouvez soit y ajouter complètement le remplacer si nécessaire.
add_filter('manage_spark_stars_posts_columns','filter_cpt_columns');
function filter_cpt_columns( $columns ) {
// this will add the column to the end of the array
$columns['first_name'] = 'First Name';
//add more columns as needed
// as with all filters, we need to return the passed content/variable
return $columns;
}
L'étape suivante consiste à indiquer à WordPress quel contenu doit être affiché dans la colonne. Cela peut être fait avec l'action manage_posts_custom_column
. La méthode ci-dessous renvoie le First Name
si la méta de publication existe ou une chaîne par défaut dans le cas contraire.
add_action( 'manage_posts_custom_column','action_custom_columns_content', 10, 2 );
function action_custom_columns_content ( $column_id, $post_id ) {
//run a switch statement for all of the custom columns created
switch( $column_id ) {
case 'first_name':
echo ($value = get_post_meta($post_id, 'first_name_meta_box_key', true ) ) ? $value : 'No First Name Given';
break;
//add more items here as needed, just make sure to use the column_id in the filter for each new item.
}
}
J'espère que c'est plus clair!