123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368 |
- <?php
- /**
- * @file
- * Hooks provided by the Block module.
- */
- /**
- * @addtogroup hooks
- * @{
- */
- /**
- * Define all blocks provided by the module.
- *
- * This hook declares to Drupal what blocks are provided by your module and can
- * optionally specify initial block configuration settings.
- *
- * In hook_block_info(), each block your module provides is given a unique
- * identifier referred to as "delta" (the array key in the return value). Delta
- * values only need to be unique within your module, and they are used in the
- * following ways:
- * - Passed into the other block hooks in your module as an argument to identify
- * the block being configured or viewed.
- * - Used to construct the default HTML ID of "block-MODULE-DELTA" applied to
- * each block when it is rendered. This ID may then be used for CSS styling or
- * JavaScript programming.
- * - Used to define a theming template suggestion of block__MODULE__DELTA, for
- * advanced theming possibilities.
- * - Used by other modules to identify your block in hook_block_info_alter() and
- * other alter hooks.
- * The values of delta can be strings or numbers, but because of the uses above
- * it is preferable to use descriptive strings whenever possible, and only use a
- * numeric identifier if you have to (for instance if your module allows users
- * to create several similar blocks that you identify within your module code
- * with numeric IDs). The maximum length for delta values is 32 bytes.
- *
- * @return
- * An associative array whose keys define the delta for each block and whose
- * values contain the block descriptions. Each block description is itself an
- * associative array, with the following key-value pairs:
- * - info: (required) The human-readable administrative name of the block.
- * This is used to identify the block on administration screens, and is not
- * displayed to non-administrative users.
- * - cache: (optional) A bitmask describing what kind of caching is
- * appropriate for the block. Drupal provides the following bitmask
- * constants for defining cache granularity:
- * - DRUPAL_CACHE_PER_ROLE (default): The block can change depending on the
- * roles the user viewing the page belongs to.
- * - DRUPAL_CACHE_PER_USER: The block can change depending on the user
- * viewing the page. This setting can be resource-consuming for sites with
- * large number of users, and should only be used when
- * DRUPAL_CACHE_PER_ROLE is not sufficient.
- * - DRUPAL_CACHE_PER_PAGE: The block can change depending on the page being
- * viewed.
- * - DRUPAL_CACHE_GLOBAL: The block is the same for every user on every page
- * where it is visible.
- * - DRUPAL_CACHE_CUSTOM: The module implements its own caching system.
- * - DRUPAL_NO_CACHE: The block should not get cached.
- * - properties: (optional) Array of additional metadata to add to the block.
- * Common properties include:
- * - administrative: Boolean that categorizes this block as usable in an
- * administrative context. This might include blocks that help an
- * administrator approve/deny comments, or view recently created user
- * accounts.
- * - weight: (optional) Initial value for the ordering weight of this block.
- * Most modules do not provide an initial value, and any value provided can
- * be modified by a user on the block configuration screen.
- * - status: (optional) Initial value for block enabled status. (1 = enabled,
- * 0 = disabled). Most modules do not provide an initial value, and any
- * value provided can be modified by a user on the block configuration
- * screen.
- * - region: (optional) Initial value for theme region within which this
- * block is set. Most modules do not provide an initial value, and any value
- * provided can be modified by a user on the block configuration screen.
- * Note: If you set a region that isn't available in the currently enabled
- * theme, the block will be disabled.
- * - visibility: (optional) Initial value for the visibility flag, which tells
- * how to interpret the 'pages' value. Possible values are:
- * - BLOCK_VISIBILITY_NOTLISTED: Show on all pages except listed pages.
- * 'pages' lists the paths where the block should not be shown.
- * - BLOCK_VISIBILITY_LISTED: Show only on listed pages. 'pages' lists the
- * paths where the block should be shown.
- * - BLOCK_VISIBILITY_PHP: Use custom PHP code to determine visibility.
- * 'pages' gives the PHP code to use.
- * Most modules do not provide an initial value for 'visibility' or 'pages',
- * and any value provided can be modified by a user on the block
- * configuration screen.
- * - pages: (optional) See 'visibility' above. A string that contains one or
- * more page paths separated by "\n", "\r", or "\r\n" when 'visibility' is
- * set to BLOCK_VISIBILITY_NOTLISTED or BLOCK_VISIBILITY_LISTED (example:
- * "<front>\nnode/1"), or custom PHP code when 'visibility' is set to
- * BLOCK_VISIBILITY_PHP. Paths may use '*' as a wildcard (matching any
- * number of characters); '<front>' designates the site's front page. For
- * BLOCK_VISIBILITY_PHP, the PHP code's return value should be TRUE if the
- * block is to be made visible or FALSE if the block should not be visible.
- *
- * For a detailed usage example, see block_example.module.
- *
- * @see hook_block_configure()
- * @see hook_block_save()
- * @see hook_block_view()
- * @see hook_block_info_alter()
- */
- function hook_block_info() {
- // This example comes from node.module.
- $blocks['syndicate'] = array(
- 'info' => t('Syndicate'),
- 'cache' => DRUPAL_NO_CACHE
- );
- $blocks['recent'] = array(
- 'info' => t('Recent content'),
- // DRUPAL_CACHE_PER_ROLE will be assumed.
- );
- return $blocks;
- }
- /**
- * Change block definition before saving to the database.
- *
- * @param $blocks
- * A multidimensional array of blocks keyed by the defining module and delta;
- * the values are blocks returned by hook_block_info(). This hook is fired
- * after the blocks are collected from hook_block_info() and the database,
- * right before saving back to the database.
- * @param $theme
- * The theme these blocks belong to.
- * @param $code_blocks
- * The blocks as defined in hook_block_info() before being overwritten by the
- * database data.
- *
- * @see hook_block_info()
- */
- function hook_block_info_alter(&$blocks, $theme, $code_blocks) {
- // Disable the login block.
- $blocks['user']['login']['status'] = 0;
- }
- /**
- * Define a configuration form for a block.
- *
- * @param $delta
- * Which block is being configured. This is a unique identifier for the block
- * within the module, defined in hook_block_info().
- *
- * @return
- * A configuration form, if one is needed for your block beyond the standard
- * elements that the block module provides (block title, visibility, etc.).
- *
- * For a detailed usage example, see block_example.module.
- *
- * @see hook_block_info()
- * @see hook_block_save()
- */
- function hook_block_configure($delta = '') {
- // This example comes from node.module.
- $form = array();
- if ($delta == 'recent') {
- $form['node_recent_block_count'] = array(
- '#type' => 'select',
- '#title' => t('Number of recent content items to display'),
- '#default_value' => variable_get('node_recent_block_count', 10),
- '#options' => drupal_map_assoc(array(2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 25, 30)),
- );
- }
- return $form;
- }
- /**
- * Save the configuration options from hook_block_configure().
- *
- * This hook allows you to save the block-specific configuration settings
- * defined within your hook_block_configure().
- *
- * @param $delta
- * Which block is being configured. This is a unique identifier for the block
- * within the module, defined in hook_block_info().
- * @param $edit
- * The submitted form data from the configuration form.
- *
- * For a detailed usage example, see block_example.module.
- *
- * @see hook_block_configure()
- * @see hook_block_info()
- */
- function hook_block_save($delta = '', $edit = array()) {
- // This example comes from node.module.
- if ($delta == 'recent') {
- variable_set('node_recent_block_count', $edit['node_recent_block_count']);
- }
- }
- /**
- * Return a rendered or renderable view of a block.
- *
- * @param $delta
- * Which block to render. This is a unique identifier for the block
- * within the module, defined in hook_block_info().
- *
- * @return
- * Either an empty array so the block will not be shown or an array containing
- * the following elements:
- * - subject: The default localized title of the block. If the block does not
- * have a default title, this should be set to NULL.
- * - content: The content of the block's body. This may be a renderable array
- * (preferable) or a string containing rendered HTML content. If the content
- * is empty the block will not be shown.
- *
- * For a detailed usage example, see block_example.module.
- *
- * @see hook_block_info()
- * @see hook_block_view_alter()
- * @see hook_block_view_MODULE_DELTA_alter()
- */
- function hook_block_view($delta = '') {
- // This example is adapted from node.module.
- $block = array();
- switch ($delta) {
- case 'syndicate':
- $block['subject'] = t('Syndicate');
- $block['content'] = array(
- '#theme' => 'feed_icon',
- '#url' => 'rss.xml',
- '#title' => t('Syndicate'),
- );
- break;
- case 'recent':
- if (user_access('access content')) {
- $block['subject'] = t('Recent content');
- if ($nodes = node_get_recent(variable_get('node_recent_block_count', 10))) {
- $block['content'] = array(
- '#theme' => 'node_recent_block',
- '#nodes' => $nodes,
- );
- } else {
- $block['content'] = t('No content available.');
- }
- }
- break;
- }
- return $block;
- }
- /**
- * Perform alterations to the content of a block.
- *
- * This hook allows you to modify any data returned by hook_block_view().
- *
- * Note that instead of hook_block_view_alter(), which is called for all
- * blocks, you can also use hook_block_view_MODULE_DELTA_alter() to alter a
- * specific block.
- *
- * @param $data
- * The data as returned from the hook_block_view() implementation of the
- * module that defined the block. This could be an empty array or NULL value
- * (if the block is empty) or an array containing:
- * - subject: The default localized title of the block.
- * - content: Either a string or a renderable array representing the content
- * of the block. You should check that the content is an array before trying
- * to modify parts of the renderable structure.
- * @param $block
- * The block object, as loaded from the database, having the main properties:
- * - module: The name of the module that defined the block.
- * - delta: The unique identifier for the block within that module, as defined
- * in hook_block_info().
- *
- * @see hook_block_view_MODULE_DELTA_alter()
- * @see hook_block_view()
- */
- function hook_block_view_alter(&$data, $block) {
- // Remove the contextual links on all blocks that provide them.
- if (is_array($data['content']) && isset($data['content']['#contextual_links'])) {
- unset($data['content']['#contextual_links']);
- }
- // Add a theme wrapper function defined by the current module to all blocks
- // provided by the "somemodule" module.
- if (is_array($data['content']) && $block->module == 'somemodule') {
- $data['content']['#theme_wrappers'][] = 'mymodule_special_block';
- }
- }
- /**
- * Perform alterations to a specific block.
- *
- * Modules can implement hook_block_view_MODULE_DELTA_alter() to modify a
- * specific block, rather than implementing hook_block_view_alter().
- *
- * @param $data
- * The data as returned from the hook_block_view() implementation of the
- * module that defined the block. This could be an empty array or NULL value
- * (if the block is empty) or an array containing:
- * - subject: The localized title of the block.
- * - content: Either a string or a renderable array representing the content
- * of the block. You should check that the content is an array before trying
- * to modify parts of the renderable structure.
- * @param $block
- * The block object, as loaded from the database, having the main properties:
- * - module: The name of the module that defined the block.
- * - delta: The unique identifier for the block within that module, as defined
- * in hook_block_info().
- *
- * @see hook_block_view_alter()
- * @see hook_block_view()
- */
- function hook_block_view_MODULE_DELTA_alter(&$data, $block) {
- // This code will only run for a specific block. For example, if MODULE_DELTA
- // in the function definition above is set to "mymodule_somedelta", the code
- // will only run on the "somedelta" block provided by the "mymodule" module.
- // Change the title of the "somedelta" block provided by the "mymodule"
- // module.
- $data['subject'] = t('New title of the block');
- }
- /**
- * Act on blocks prior to rendering.
- *
- * This hook allows you to add, remove or modify blocks in the block list. The
- * block list contains the block definitions, not the rendered blocks. The
- * blocks are rendered after the modules have had a chance to manipulate the
- * block list.
- *
- * You can also set $block->content here, which will override the content of the
- * block and prevent hook_block_view() from running.
- *
- * @param $blocks
- * An array of $blocks, keyed by the block ID.
- */
- function hook_block_list_alter(&$blocks) {
- global $language, $theme_key;
- // This example shows how to achieve language specific visibility setting for
- // blocks.
- $result = db_query('SELECT module, delta, language FROM {my_table}');
- $block_languages = array();
- foreach ($result as $record) {
- $block_languages[$record->module][$record->delta][$record->language] = TRUE;
- }
- foreach ($blocks as $key => $block) {
- // Any module using this alter should inspect the data before changing it,
- // to ensure it is what they expect.
- if (!isset($block->theme) || !isset($block->status) || $block->theme != $theme_key || $block->status != 1) {
- // This block was added by a contrib module, leave it in the list.
- continue;
- }
- if (!isset($block_languages[$block->module][$block->delta])) {
- // No language setting for this block, leave it in the list.
- continue;
- }
- if (!isset($block_languages[$block->module][$block->delta][$language->language])) {
- // This block should not be displayed with the active language, remove
- // from the list.
- unset($blocks[$key]);
- }
- }
- }
- /**
- * @} End of "addtogroup hooks".
- */
|