Tableless

Busca Menu

Usando Meta Box em seu tema WordPress

Seja o primeiro a comentar por

O que são Meta Boxes?

Os Meta Boxes (Caixas de informações) foi implementado a partir da versão 2.5 do CMS, os Meta Boxes são aquelas caixas arrastáveis que estão presente na Dashboard, edição de um post, páginas, além de outros locais na área administrativa do WordPress.

Os Meta Boxes é uma maneira atraente para a tela do editor de post e evita forçar os usuários a confiar em campos personalizados. Se você já criou algum tipo de campo personalizado no WordPress, você provavelmente gostaria de adicionar algum campo.

Com os Meta Box e mais fácil. Imagine que você esteja criando um tema para um cliente que precise catalogar sua coleção de vinil. Você começa imediatamente olhar para o WordPress para ver como isso pode ser feito. Cada Post representa um Vinil, que é perfeito para adicionar imagem, titulo e descrição. Podemos usar também as categorias e marcar dentro do WordPress para que os organize. Mas vamos supor que o cara queira acrescentar mais um dado para catalogação? O WordPress não te dar essa opção por padrão a não ser que usemos o grande Meta Box.

Usando o Meta boxes

Neste tutorial não iremos trabalhar em um arquivo functions.php. Que não é o lugar correto para ele. Se você está adicionando dados a uma mensagem, é provável que você quer que ele exista independentemente do seu projeto de front end. Como tal, você deve colocar esse código em algum lugar que não é dependente do seu design. Ex: Um arquivo de plugin.

Convenientemente o WordPress oferece uma função para adicionar os Meta Boxes a uma tela de administração, usando o seguinte “add_meta_box”. Abaixo um exemplo.


<?php add_meta_box( $id, $title, $callback, $page, $context, $priority, $callback_args ); ?>

Parâmetros

  • $id – (String) Identificador único (Obrigatório)
  • $title – (String) Titulo a ser exibido (Obrigatório)
  • $callback – (Callback) Função para exibir o conteúdo do Meta Boxes (Obrigatório) Exemplo
  • $page – (String) Onde será exibido o Meta Boxes. Exemplos ('post', 'page', 'link', or'custom_post_type' )
  • $context (String) Tela onde o box vai ser inserido.
  • $priority (String) Prioridade de inserção da caixa em relação as demais.
  • $callback_args (array) Determina a passagem de parâmetros a função callback.

Então, nosso add_meta_box será parecido com esse.


<?php add_meta_box ( 'my-meta-box-id', 'Meu primeiro Meta Box', 'vinil_meta_box_vinil', 'post', 'normal', 'high' ); ?>

Não podemos simplesmente colocar em nosso arquivo plugin sozinho, se não vamos acabar na tela branca da morte ou o erro fatal PHP. Chamada para a função indefinida, por quê? Porque chamamos a função add_meta_box antes do WordPress ser carregado. Com isso precisamos fazer um gancho no WordPress, que faz parte da api de um plugin. Basicamente, as funções começam enganchando em uma ação do WordPress. Então vamos fazer nosso gancho add_meta_box em uma função, então conectar essa função ao add_meta_boxes, evitando o erro fatal. Nosso código para o Meta Boxes para tela de postagem ficará assim:


<?php add_action( 'add_meta_boxes', 'vinil_meta_box_add' );

function vinil_meta_box_add() {

add_meta_box( 'my-meta-box-id', 'Meu primeiro Meta Box', 'vinil_meta_box_vinil', 'post', 'normal', 'high' ); }

?>

Renderizando o Meta Box

O código acima é o suficiente para adicionar o Meta Box, mas agora temos que tornar a coisa mais legal. Vamos adicionar campos, apenas um formulário HTML misturado com um pouco de PHP para exibir os dados salvos. Não precisamos incluir as tags de formulário pois o WordPress já faz isso para a gente. 🙂 Lembre que a string passada como o $callback em add_meta_box? Agora vamos criar um função com o mesmo nome.


<?php function vinil_meta_box_vinil() {

echo 'Conteúdo do meu primeiro Meta Box.'; }

?>

Agora vamos fazer o formulário, vamos adicionar vários campos para este Meta Box, 1 input, 1 select, 1 checkbox. Vamos começar com o input.

Na função


function vinil_meta_box_vinil() {

echo 'Conteúdo do meu primeiro Meta Box.'; }

?>

Vamos retirar o


echo 'Conteúdo do meu primeiro Meta Box';

Para começar a fazer o formulario do Meta Box, ficando da seguinte forma:


function vinil_meta_box_vinil()
{
?>
<p>
<label for="texto_meta_box">Text Label</label>
<input type="text" name="texto_meta_box" id="texto_meta_box" />
</p>
<?php
}

?>

Mas e quanto a exibir os dados? Bem você verá a seguinte, vamos armazenar esses dados na tabela usando a função wp_postmeta update_post_meta. Essas funções tem duas irmãs chamada get_post_meta e get_post_custom, que pega os dados de wp_postmeta. O get_post_meta só peega dados de uma chave, enquanto get_post_custom pega tudo. Como estamos usando realmente apenas um campo, neste ponto, vamos usar o get_post_meta.


function vinil_meta_box_vinil()
{
$values = get_post_custom( $post->ID );
$text = isset( $values['texto_meta_box'] ) ? esc_attr( $values['texto_meta_box'][0] ) : '';
$selected = isset( $values['meta_box_select'] ) ? esc_attr( $values['meta_box_select'][0] ) : '';
$check = isset( $values['meta_box_check'] ) ? esc_attr( $values['meta_box_check'][0] ) : '';
wp_nonce_field( 'my_meta_box_nonce', 'meta_box_nonce' );
?>
<p>
<label for="texto_meta_box">Text Label</label>
<input type="text" name="texto_meta_box" id="texto_meta_box" />
</p>

<?php
}

?>

Agora vamos adicionar o DropDow em nosso Meta Box.

No drop-dow iremos usar uma das funções mais úteis no WordPress, o selected(). Ele compara o primeiro valor, os dados que salva, com o segundo atributo de valor, <option>. Se eles são os mesmos a função selected=”selected” que faz com o que o valor do drop down seja gravado. Mas você também pode usar o selected com botões de radio.

Ficando da seguinte forma:


function vinil_meta_box_vinil()
{
$values = get_post_custom( $post->ID );
$text = isset( $values['texto_meta_box'] ) ? esc_attr( $values['texto_meta_box'][0] ) : '';
$selected = isset( $values['meta_box_select'] ) ? esc_attr( $values['meta_box_select'][0] ) : '';
$check = isset( $values['meta_box_check'] ) ? esc_attr( $values['meta_box_check'][0] ) : '';
wp_nonce_field( 'my_meta_box_nonce', 'meta_box_nonce' );
?>
<p>
<label for="texto_meta_box">Text Label</label>
<input type="text" name="texto_meta_box" id="texto_meta_box" />
</p>
<p>
<label for="meta_box_select">Color</label>
<select name="meta_box_select" id="meta_box_select">
<option value="red" <?php selected( $selected, 'red' ); ?>>Vermelho</option>
<option value="blue" <?php selected( $selected, 'blue' ); ?>>Azul</option>
</select>
</p>
<?php
}

?>

Adicionando o Check box


function vinil_meta_box_vinil()
{
$values = get_post_custom( $post->ID );
$text = isset( $values['texto_meta_box'] ) ? esc_attr( $values['texto_meta_box'][0] ) : '';
$selected = isset( $values['meta_box_select'] ) ? esc_attr( $values['meta_box_select'][0] ) : '';
$check = isset( $values['meta_box_check'] ) ? esc_attr( $values['meta_box_check'][0] ) : '';
wp_nonce_field( 'my_meta_box_nonce', 'meta_box_nonce' );
?>
<p>
<label for="texto_meta_box">Text Label</label>
<input type="text" name="texto_meta_box" id="texto_meta_box" />
</p>
<p>
<label for="meta_box_select">Color</label>
<select name="meta_box_select" id="meta_box_select">
<option value="red" <?php selected( $selected, 'red' ); ?>>Vermelho</option>
<option value="blue" <?php selected( $selected, 'blue' ); ?>>Azul</option>
</select>
</p>
<p>
<input type="checkbox" name="meta_box_check" id="meta_box_check" <?php checked( $check, 'on' ); ?> />
<label for="meta_box_check">Don't Check This.</label>
</p>
<?php
}

?>

Novamente o WordPress fornece a função checked(). Ela funciona exatamente como selected() comparando o primeiro valor com o segundo valor e repetindo para checked=”checked” se eles são o mesmo.

Para finalizar vamos salvar nosso Meta Box

Para salvar nossos dados, vamos confiar em outro gancho: save_post. Isso funciona como o nosso gancho na ação acima:


<?php add_action( 'save_post', 'vinil_meta_box_save' ); ?>

A função vinil_meta_box receberá um argumento, a ID do Post, e vai cuidar da limpeza e salvar todos os nossos dados.

Antes de podermos fazer qualquer coisa, no entanto, que temos que fazer 3 coisas: verificar se o Post esta auto salvando, verificar o valor único que criamos anteriormente, e verificar se o usuário atual pode realmente editar o post.


add_action( 'save_post', 'vinil_meta_box_save' );
function vinil_meta_box_save( $post_id )
{
if( defined( 'DOING_AUTOSAVE' ) && DOING_AUTOSAVE ) return;

if( !isset( $_POST['meta_box_nonce'] ) || !wp_verify_nonce( $_POST['meta_box_nonce'], 'my_meta_box_nonce' ) ) return;

if( !current_user_can( 'edit_post' ) ) return;

}

Agora as coisas divertidas: na verdade, salvar nossos dados. A regra número um, ao colocar qualquer coisa em seu banco de dados ou em seu site é não confiar no usuário. Mesmo se esse usuário é você. Para o efeito, antes de salvar os dados, queremos ter certeza de que não há nada malicioso lá. Felizmente WordPress fornece um monte de funções para validação de dados. Para isso vamos utilizar o esc_attr(). E também vamos usar a função update_post_meta para salvar os nossos dados. Leva três argumentos: a ID post, a chave de meta, e o valor.


add_action( 'save_post', 'vinil_meta_box_save' );
function vinil_meta_box_save( $post_id )
{
if( defined( 'DOING_AUTOSAVE' ) && DOING_AUTOSAVE ) return;

if( !isset( $_POST['meta_box_nonce'] ) || !wp_verify_nonce( $_POST['meta_box_nonce'], 'my_meta_box_nonce' ) ) return;

if( !current_user_can( 'edit_post' ) ) return;

$allowed = array(
'a' => array(
'href' => array()
)
);

if( isset( $_POST['texto_meta_box'] ) )
update_post_meta( $post_id, 'texto_meta_box', wp_kses( $_POST['texto_meta_box'], $allowed ) );

if( isset( $_POST['meta_box_select'] ) )
update_post_meta( $post_id, 'meta_box_select', esc_attr( $_POST['meta_box_select'] ) );

$chk = ( isset( $_POST['meta_box_check'] ) && $_POST['meta_box_check'] ) ? 'on' : 'off';
update_post_meta( $post_id, 'meta_box_check', $chk );
}

?>

É isso, agora você deve ter um Meta Boxes funcionando em seu WordPress.

Nosso arquivo fica assim:


<?php
/*
Plugin Name: Meta Box
Plugin URI: http://bygiovanni.com.br
Description:
Version: 1.0
Author: Giovanni - Tableless
Author URI: http://bygiovanni.com.br
*/

//ADICIONANDO O META BOX
add_action( 'add_meta_boxes', 'vinil_meta_box_add' );
function vinil_meta_box_add()
{
add_meta_box( 'my-meta-box-id', 'Meu primeiro Meta Box', 'vinil_meta_box_vinil', 'post', 'normal', 'high' );
}

//FORMULARIO PARA SALVAS OS DADOS
function vinil_meta_box_vinil()
{
$values = get_post_custom( $post->ID );
$text = isset( $values['texto_meta_box'] ) ? esc_attr( $values['texto_meta_box'][0] ) : '';
$selected = isset( $values['meta_box_select'] ) ? esc_attr( $values['meta_box_select'][0] ) : '';
$check = isset( $values['meta_box_check'] ) ? esc_attr( $values['meta_box_check'][0] ) : '';
wp_nonce_field( 'my_meta_box_nonce', 'meta_box_nonce' );
?>
<p>
<label for="texto_meta_box">Text Label</label>
<input type="text" name="texto_meta_box" id="texto_meta_box" />
</p>
<p>
<label for="meta_box_select">Color</label>
<select name="meta_box_select" id="meta_box_select">
<option value="red" <?php selected( $selected, 'red' ); ?>>Vermelho</option>
<option value="blue" <?php selected( $selected, 'blue' ); ?>>Azul</option>
</select>
</p>
<p>
<input type="checkbox" name="meta_box_check" id="meta_box_check" <?php checked( $check, 'on' ); ?> />
<label for="meta_box_check">Don't Check This.</label>
</p>
<?php
}

add_action( 'save_post', 'vinil_meta_box_save' );
function vinil_meta_box_save( $post_id )
{
if( defined( 'DOING_AUTOSAVE' ) && DOING_AUTOSAVE ) return;

if( !isset( $_POST['meta_box_nonce'] ) || !wp_verify_nonce( $_POST['meta_box_nonce'], 'my_meta_box_nonce' ) ) return;

if( !current_user_can( 'edit_post' ) ) return;

$allowed = array(
'a' => array(
'href' => array()
)
);

if( isset( $_POST['texto_meta_box'] ) )
update_post_meta( $post_id, 'texto_meta_box', wp_kses( $_POST['texto_meta_box'], $allowed ) );

if( isset( $_POST['meta_box_select'] ) )
update_post_meta( $post_id, 'meta_box_select', esc_attr( $_POST['meta_box_select'] ) );

$chk = ( isset( $_POST['meta_box_check'] ) && $_POST['meta_box_check'] ) ? 'on' : 'off';
update_post_meta( $post_id, 'meta_box_check', $chk );
}

?>

Para saber mais sobre os Meta Box podem ver no Codex que também é uma ótima fonte de estudo para o WP. http://codex.wordpress.org/Function_Reference/add_meta_box

Publicado no dia