Вам необходимо использовать атрибут «#theme», например, в следующем коде.
$build['dblog_table'] = array(
'#theme' => 'table',
'#header' => $header,
'#rows' => $rows,
'#attributes' => array('id' => 'admin-dblog'),
'#empty' => t('No log messages available.'),
);
#theme
рассказывает Drupal, которая нуждается в тему вызываемой функции; другие свойства, если они уже используются для другой цели, используются как имена переменных для перехода к функции темы или файла шаблона, если они используются. В этом случае theme_table() получит следующий массив.
array(
'header' => $header,
'rows' => $rows,
'attributes' => array('id' => 'admin-dblog'),
'empty' => t('No log messages available.'),
);
Это можно сделать даже с теми функциями темы, которые действительно используют файл шаблона.
Вы определяете функцию темы в своем hook_theme(), используя необходимые ключи, используемые для функции темы, которая использует файл шаблона, например, в следующем коде.
function mymodule_theme($existing, $type, $theme, $path) {
return array(
'mymodule_sidebar' => array(
'variables' => array('topics' => NULL, 'parents' => NULL, 'tid' => NULL, 'sortby' => NULL),
'template' => 'mymodule-display',
),
);
}
Функция темы затем будет использоваться с чем-то похожим на следующий код.
$page['sidebar_first'] = array(
'#theme' => 'mymodule_sidebar',
'#topics' => array('first topic', 'second topic', 'third topic'),
'#parents' => array('my topics', 'my friend's topics'),
);
Переменные, которые не получают явное значение получит по умолчанию один сообщается в hook_theme()
; в этом случае значение по умолчанию для используемых переменных равно NULL
.