Drupal 7.を使用しています。現在、メインメニューのナビゲーションと言語スイッチャーがWebサイトのヘッダーにあります。CMS> Structure> Blocksに移動してそこに配置しました。ブロックをヘッダー領域にドラッグします。
これらのブロックをヘッダーにプログラムで配置するにはどうすればよいですか?
他のモジュールで定義されたブロックが配置される領域を変更するには、次の引数を受け取る hook_block_info_alter() を実装できます。
$blocks
_(参照渡し):モジュールによってキー設定されたブロック定義とデルタを含む配列$theme
_:ブロックが定義されているテーマ$code_blocks
_:hook_block_info()
実装から定義されたブロック、それらの値がデータベースから取得された値によってオーバーライドされる前Hook_page_build()で任意のページ領域にレンダリング可能な配列を追加することは正当です。 Drupal 7フッター領域にミニパネルを追加する例。
<?php
/**
* Implements hook_page_build().
*/
function MODULE_page_build(&$page) {
$block = module_invoke('panels_mini', 'block_view', 'blah');
$blocks['blah'] = array('#markup' => $block['content']);
$region = 'footer';
if (isset($page[$region])) {
$page[$region] = array_merge($page[$region], $blocks);
}
else {
$page[$region] = $blocks;
}
}
これは、コンテキストモジュールを使用する手法とまったく同じです。
注:これを機能させるためにblock.moduleを有効にする必要はありません。
カスタムブロックを追加する場合は、hook_block_infoを使用して、statusオプションを1に、regionオプションをブロックを配置する領域に設定します。
例:
MODULE_block_info() {
$blocks = array();
$blocks['my_block'] = array(
'info' => t('My Block Name'),
'status' => 1,
'region' => 'THE_REGION_I_WANT',
);
return $blocks;
}
既存のブロックを変更したい場合は、代わりにhook_block_info_alter()を使用します。以下に示す同じオプションを更新します。
例:
MODULE_hook_block_info_alter(&$blocks, $theme, $code_blocks) {
$blocks['my_block']['status'] = 1;
$blocks['my_block']['region'] = 'THE_REGION_I_WANT';
}
詳細については、 https://api.drupal.org/api/drupal/modules%21block%21block.api.php/function/hook_block_info/7 を参照してください
D6では本質的に
$block = module_invoke("the_module_name", "block", "view", the_block_delta);
drupal_set_content("the_region_name", theme("block", $block));
D7ではそうだと思います
$block = module_invoke("the_module_name", "block_view", the_block_delta);
drupal_add_region_content("the_region_name", theme("block", $block));
しかし、私はまだD7でスピードを上げています。
このコードは@jonhattanに基づいていますが、彼はブロックコンテナーHTMLまたはコンテキストリンクをレンダリングしません。また、すべてのブロックとリージョンを1か所で指定する簡単な方法も提供しました。
<?php
/**
* Implements hook_page_build().
*/
function MODULE_page_build(&$page) {
global $theme;
// A list of blocks you wish to display, keyed by region.
// These are in the format of: 'module_name' => 'delta'.
$blocks_to_render = array(
'header' => array(
'block' => 1,
),
);
// Add the blocks to each region.
foreach ($blocks_to_render as $region => $block_list) {
$block_objects = array();
foreach ($block_list as $module_name => $delta) {
$block = block_load($module_name, $delta);
// Alter some of the defaults to match the current context.
$block->theme = $theme;
$block->region = $region;
$block->weight = 0;
$block_objects[] = $block;
}
$blocks_build = _block_get_renderable_array(_block_render_blocks($block_objects));
if (isset($page[$region])) {
$page[$region] = array_merge($page[$region], $blocks_build);
}
else {
$page[$region] = $blocks_build;
}
}
}
注:彼のコードとは異なり、block.moduleをインストールする必要があります。