A proposta é criar meta boxes com um número ilimitado de entradas que serão adicionadas de acordo com a necessidade. No exemplo foram criados 2 boxes: nome e idade, que serão aplicadas para o post do tipo ‘integrantes‘.
Primeiro vamos criar o container dos meta boxes:
$meta_box_people = array(
'id' => 'my-meta-box-people',
'title' => 'Integrantes',
'page' => 'integrantes',
'context' => 'normal',
'priority' => 'high',
);
add_action('admin_menu', 'mytheme_add_box_people');
e agora a configuração para visualização dos boxes:
// Add meta box
function mytheme_add_box_people() {
global $meta_box_people;
add_meta_box($meta_box_people['id'], $meta_box_people['title'], 'mytheme_show_box_people', $meta_box_people['page'], $meta_box_people['context'], $meta_box_people['priority']);
}
// Callback function to show fields in meta box
function mytheme_show_box_people() {
global $post;
// Use nonce for verification
echo '<input type="hidden" name="mytheme_meta_box_people_nonce" value="', wp_create_nonce(basename(__FILE__)), '" />';
?>
<a class="add_new_media">Adicionar [+]</a>
<table class="form-table imag">
<?php
$mcs = get_post_meta($post->ID,'mcs',true); //array multidimensional
if($mcs):
//print_r($mcs);
$counter = 0;
foreach ($mcs as $mc) : //Para cada linha do array multidimensional ?>
<tr>
<td>Nome <input type="text" name="mc[<?php echo $counter;?>][name]" value="<?php echo $mc['name'] ?>" /> Idade <input type="text" name="mc[<?php echo $counter;?>][idade]" value="<?php echo $mc['idade'] ?>" /><?php if($counter > 0){echo ' <a class="remove">Remover</a>'; }?></td>
</tr>
<?php $counter++; endforeach; else : //Caso vazio ?>
<tr>
<td>Nome <input type="text" name="mc[0][name]" value="" /> Idade <input type="text" name="mc[0][idade]" value="" /></td>
</tr>
<?php endif; ?>
</table>
<?php
}
e por fim a ação de salvar:
add_action('save_post', 'mytheme_save_data_people');
function mytheme_save_data_people($post_id) {
// verify nonce
if (!wp_verify_nonce($_POST['mytheme_meta_box_people_nonce'], basename(__FILE__))) {
return $post_id;
}
// check autosave
if (defined('DOING_AUTOSAVE') && DOING_AUTOSAVE) {
return $post_id;
}
// check permissions
if ('page' == $_POST['post_type']) {
if (!current_user_can('edit_page', $post_id)) {
return $post_id;
}
} elseif (!current_user_can('edit_post', $post_id)) {
return $post_id;
}
$old = get_post_meta($post_id, 'mcs', true);
$new = $_POST['mc'];
foreach ($new as $mc) :
if($mc['name']!='' || $mc['idade']!=''){
$temp[] = array('name'=>$mc['name'],'idade'=>$mc['idade']);
}
update_post_meta($post_id, 'mcs', $temp);
endforeach;
}
Para o funcionamento dos botões de adicionar e remover é necessário incluir o arquivo javascript:
function my_admin_scripts() {
wp_register_script('my-script', get_bloginfo('template_url') . '/functions/my-script.js', array('jquery'));
wp_enqueue_script('my-script');
}
add_action('admin_print_scripts', 'my_admin_scripts');
Crie a pasta functions dentro do diretório do tema e crie o arquivo my-script.js que deverá conter o código abaixo:
jQuery(document).ready(function() {
jQuery('.add_new_media').click(function(e) {
var num = jQuery('table.imag tr').length;
jQuery('table.imag').append('<tr><td>Nome <input type="text" name="mc['+num+'][name]" value="" /> Idade <input type="text" name="mc['+num+'][idade]" value="" /> <a class="remove">Remove</a></td></tr>');
jQuery('.remove').click(function(){
jQuery(this).parent().parent().remove()
})
})
jQuery('.remove').click(function(){
jQuery(this).parent().parent().remove()
})
});
Et voilá! Agora você pode adicionar ou remover entradas como quiser.

