Back-End

22 fev, 2013

Criando blocos programaticamente

Publicidade

Tudo bem, galera? Em um projeto web, seja ele site, portal, intranet, rede social ou qualquer outro, é comum ter seções que precisam de destaque, tanto na home quanto em landing pages. Por exemplo, em um portal de notícias temos as seguintes seções: Esportes, Tempo e Empregos.

O diretor do portal quer dar destaque a essas informações na home. Então, como faremos para apresentar essas informações? Não podemos simplesmente jogá-la na tela. Para resolver essa situação, podemos separar essas seções em blocos de informação. Desta forma, facilitamos o acesso à informação dentro do portal.

Com isso em mente, a missão de hoje é criar um bloco programaticamente. Iremos implementar um bloco de links, coisa bem simples. Segue o passo a passo:

Agora, mãos ao código!

Vamos criar um módulo chamado custom_block_link. Não sabe como criar um? Dá uma lida nesse artigo sobre como criar um módulo.

Com o módulo já criado e habilitado, vamos para o arquivo custom_block_link.module.

Passo 1

Implementação do hook_block_info():

/**
* Implements hook_block_info().
*/
function custom_block_link_block_info() {
$blocks['custom_block_link'] = array(
'info' => t('Block of links'),
'cache' => DRUPAL_NO_CACHE,
);

return $blocks;
}

Vamos entender?

Implementamos o hook_block_info() para informar ao Drupal que existe blocos associados ao nosso módulo. Caso não tenha esse hook no módulo, o Drupal enderá que não exitem blocos para serem associados.

Na linha 5 criamos uma chave para identificar o bloco. Na chave info é atribuído um texto que será exibido na área administrativa dos blocos. A chave cache é informada para não armazenar as informações em cache.

Passo 2

Implementação do hook_block_view():

/**
* Implements hook_block_view().
*/
function custom_block_link_block_view($delta = '') {
$block = array();

if ($delta == 'custom_block_link') {

$items = array(
'api' =>  l(t('Api Drupal'), 'http://api.drupal.org/'),
'modules' => l(t('Modules Drupal'), 'http://drupal.org/search/site?f[0]=ss_meta_type%3Amodule'),
'themes' => l(t('Themes Drupal'), 'http://drupal.org/search/site/?f[0]=ss_meta_type%3Atheme'),
);

$block['subject'] = t('Useful links');

$type = 'ul';
$attributes = array('id' => 'links');

$block['subject'] = t('Useful links');
$block['content'] = theme('item_list', (array('items' => $items, 'title' => '', 'type' => $type, 'attributes' => $attributes)));

}

return $block;
}

O hook_block_view() é responsável por construir o conteúdo do bloco. Nele verificamos a chave criada no hook_block_info. o Drupal irá procurar por essa chave para criar o nosso bloco.

Na linha 9, criamos uma variável com o conteúdo do nosso bloco. Na chave subject adicionamos um título para o bloco. A chave content recebe o HTML de uma lista com os valores passados na variável $items.

A tela abaixo mostra o nosso bloco na área de administração de blocos:

admin_block_1_0

Agora vamos adicionar o nosso bloco no Sidebar second:

admin_block_2

Bloco adicionado com sucesso!

result_block

Bom galera, é isso! Qualquer dúvida, crítica ou sugestão é só deixar um comentário.

Até a próxima!

***

Artigo original disponível em: http://drupaldeelite.com.br/blog/criando-blocos-programaticamente