Menu

Posts Customizados no Wordpress - Custom posts types

Pode ser que criar um post customizado seja algo necessário para seu novo tema. Por exemplo, eu precisei criar um site de casamento e para que o usuário pudesse cadastrar madrinhas e padrinhos, criei um Post Customizado ou em inglês Custom Posts Types.

Para que o wordpress saiba que você deseja criar um tipo de post customizado, precisamos informar nossa intenção no arquivo functions.php, criando uma função específica para isso e depois adicionando ela a alguma ação.

O código é parecido com esse:

function meu_tema_personalizado_registrando_post_customizado()
{
    register_post_type('padrinhos',
        array(
            'labels' => array('name' => 'Madrinhas e Padrinhos'),
            'public' => true,
            'menu_position' => 0,
            'supports' => array('title', 'editor', 'thumbnail'),
            'menu_icon' => 'dashicons-admin-site'
        )
    );
}
add_action('init','meu_tema_personalizado_registrando_post_customizado');

O register_post_type possuí dois argumentos. O primeiro é o post_type, que é um identificador único para seu post customizado no qual poderemos referenciá-los mais tarde quando necessário. O segundo é um array de argumentos que informa as configurações básicas e o que precisamos suportar no nosso post customizado.

Nesse array de argumentos, o labels informa o nome que aparecerá no menu do wordpress.

A segunda opção informa que estará disponível para todos os usuários do site.

Na sequência dizemos a posição que nosso novo post customizado ocupará no menu inical do wordpress.

A opção de supports temos que informar o que terá no nosso post customizado.

Todas as entradas no menu inicial possuem um ícone, também podemos definir esse ícone com a entrada menu_icon


WP_Query

Para exibir o post customizado que criamos na página desejada, vamos usar o Loop do Wordpress de forma customizada. Precisamos alterar o loop para informar onde precisamos buscar os dados para o Loop.

Para fazer isso usamos a classe WP_Query.

$args = array('post_type' => 'padrinhos' ); //precisa ser o nome informado no register_post_type
$query = new WP_Query($args);
if ($query->have_posts()):
    while($query->have_posts()): $query->the_post();
        the_post_thumbnail();
        the_title();
        the_content();
    endwhile;
endif;

Claro que sempre pode ser personalizado de acordo com as necessidades do seu post.

Hierarquia dos Templates no Wordpress

Supondo que no Wordpress temos duas páginas:

Uma com título de Home e outra com título de Contato.

Quando você solicita ao Wordpress carregar uma página, por exemplo, página de Contato, o que acontece?

Primeiro ele tenta encontrar se existe algum arquivo específico para a página Contato. Se existir ele renderiza esse arquivo e pronto. Nada mais acontece. Se não existir esse arquivo específico, o Wordpress vai renderizar o index.php, que é o arquivo mais genérico de todos e a razão dele ser obrigatório.

Se olharmos a imagem com resumo da Hierarquia, podemos observar que a imagem está orientada da esquerda pra direita, partindo dos arquivos mais específicos e terminando no mais genéricos de todos que é index.php.

Por si só a imagem já demostra que wordpress não é tão simples quanto parece, mas também não é tão difícil assim. O arquivo que estamos querendo renderizar é de uma página estática, criada como página normal no wordpress. Seguindo o fluxo da imagem, temos:

Singular Page -> Static Page -> Page Template -> Default Template -> page-$slug.php -> page-$id.php -> page.php -> singular.php -> index.php

O arquivo mais específico possível disponível está mais a esquerda e nesse caso é page-$slug.php. Se criarmos um arquivo chamado page-contato.php, o wordpress irá reconhecer e renderizar primeiro o que está nessa página toda vez que for requisitado este arquivo.

No caso de configurar uma página incial estática (ao invés de uma página de posts), podemos também criar um arquivo específico para isso.

Site Front Page -> front-page.php

O que nos diz que, se criarmos um arquivo chamado front-page.php e nas configurações do wordpress definir que a página inicial será estática, conseguimos definir o layout para ela nesse arquivo com nome de front-page.php

Este é apenas um exemplo simples para entender a hierarquia de templates do wordpress.

Para mais informações consulte a documentação oficial, e também na imagem de resumo.

Loop do Wordpress

Para exibir conteúdos dos posts padrões do wordpress, utilizamos o famoso Loop. O código é parecido com abaixo:

if(have_posts()):
    while(have_posts()): the_post();
        the_post_thumbnail();
        the_title();
        the_content();
    endwhile;
endif;

É importante salientar que, para criar posts personalizados, também usaremos uma estrutura parecida na hora de exibir.

Adicionando Folha de Estilos ao Wordpress - Tema Personalizado

Para adicionar estilos ao seu tema, não há muito mistério. No cabeçalho, no arquivo header.php, coloque este código dentro da tag head

< link rel="stylesheet" href="< ?= get_template_directory_uri() . '/css/normalize.css' ?>">
< link rel="stylesheet" href="< ?= get_template_directory_uri() . '/css/bootstrap.css' ?>">
< link rel="stylesheet" href="< ?= get_template_directory_uri() . '/css/header.css' ?>">

Adicionando Logo Personalizada

Simples e direto

function meu_tema_personalizado_adicionando_recursos_ao_tema(){
    add_theme_support('custom-logo');
}
add_action('after_setup_theme', 'meu_tema_personalizado_adicionando_recursos_ao_tema');

Especificado argumentos:

function meu_tema_personalizado_custom_logo_setup() {
	$defaults = array(
		'height'               => 100,
		'width'                => 400,
		'flex-height'          => true,
		'flex-width'           => true,
		'header-text'          => array( 'site-title', 'site-description' ),
		'unlink-homepage-logo' => true, 
	);

	add_theme_support( 'custom-logo', $defaults );
}

add_action( 'after_setup_theme', 'meu_tema_personalizado_custom_logo_setup' );

No header, onde for exibir:

if ( function_exists( 'the_custom_logo' ) ) {
	the_custom_logo();
}

Para adicionar logotipo com mais informações, como link por exemplo:

$custom_logo_id = get_theme_mod( 'custom_logo' );
$logo = wp_get_attachment_image_src( $custom_logo_id , 'full' );

if ( has_custom_logo() ) {
	echo '< img src="' . esc_url( $logo[0] ) . '" alt="' . get_bloginfo( 'name' ) . '">';
} else {
	echo '< h1 >' . get_bloginfo('name') . '< /h1>';
}
Outras informações consultar referência oficial.