Contains Drupal\quicktabs\Plugin\QuickContent\QuickBlockContent.php.

Namespace

Drupal\quicktabs\Plugin\QuickContent

File

src/Plugin/QuickContent/QuickBlockContent.php

View source
<?php


/**
 * @file
 * Contains Drupal\quicktabs\Plugin\QuickContent\QuickBlockContent.php.
 */
namespace Drupal\quicktabs\Plugin\QuickContent;

use Drupal\quicktabs\QuickContent;
use Drupal\quicktabs\QuicktabContentInterface;

/**
 * Class for tab content of type "block" - this is for rendering a block as tab
 * content.
 * @QuicktabFormat{
 *   id = "quickblockcontent
 */
class QuickBlockContent extends QuickContent implements QuicktabContentInterface {
    
    /**
     * {@inheritdoc}
     */
    public static function getType() {
        return 'block';
    }
    
    /**
     * {@inheritdoc}
     */
    public function optionsForm($delta, $qt, $form_state) {
        $tab = $this->settings;
        $form = array();
        $form['block']['bid'] = array(
            '#type' => 'select',
            '#options' => quicktabs_get_blocks(),
            '#default_value' => isset($tab['bid']) ? $tab['bid'] : '',
            '#title' => t('Select a block'),
        );
        $form['block']['hide_title'] = array(
            '#type' => 'checkbox',
            '#title' => t('Hide the title of this block'),
            '#default_value' => isset($tab['hide_title']) ? $tab['hide_title'] : 1,
        );
        return $form;
    }
    
    /**
     * {@inheritdoc}
     */
    public function render($hide_empty = FALSE, $args = array()) {
        if ($this->rendered_content) {
            return $this->rendered_content;
        }
        $output = array();
        $item = $this->settings;
        if (!empty($args)) {
            // The args have been passed in from an ajax request.
            $qt_name = array_shift($args);
            list($item['bid'], $item['hide_title']) = $args;
            // Ensure the block is assigned to the requested quicktabs block. This test prevents
            // AJAX access to blocks that have not been added to an AJAX-enabled quicktabs block.
            $break = TRUE;
            $quicktabs = quicktabs_load($qt_name);
            // Ensure AJAX is enabled for the quicktabs block.
            if (!empty($quicktabs) && $quicktabs->ajax == 1) {
                // Ensure the requested tab has been added to the quicktabs block.
                foreach ($quicktabs->tabs as $quicktab) {
                    if (isset($quicktab['bid']) && $quicktab['bid'] == $item['bid']) {
                        $break = FALSE;
                        break;
                    }
                }
            }
            if ($break == TRUE) {
                if (!$hide_empty) {
                    $output['#markup'] = theme('quicktabs_tab_access_denied', $item);
                }
                return $output;
            }
        }
        if (isset($item['bid'])) {
            if (\Drupal::moduleHandler()->moduleExists('block')) {
                $pos = strpos($item['bid'], '_delta_');
                $module = drupal_substr($item['bid'], 0, $pos);
                $delta = drupal_substr($item['bid'], $pos + 7);
                // Make sure the user can access the block.
                if ($this->accessBlock($module, $delta)) {
                    $block = block_load($module, $delta);
                    $block->region = 'quicktabs_tabpage';
                    if ($block_arr = _block_render_blocks(array(
                        $block,
                    ))) {
                        if ($item['hide_title']) {
                            $block_arr["{$block->module}_{$block->delta}"]->subject = FALSE;
                        }
                        if (!empty($block_arr["{$block->module}_{$block->delta}"]->content)) {
                            $build = _block_get_renderable_array($block_arr);
                            $output = $build;
                        }
                    }
                }
                elseif (!$hide_empty) {
                    $output['#markup'] = theme('quicktabs_tab_access_denied', $item);
                }
            }
            elseif (!$hide_empty) {
                $output['#markup'] = t('Block module is not enabled, cannot display content.');
            }
        }
        $this->rendered_content = $output;
        return $output;
    }
    
    /**
     * {@inheritdoc}
     */
    public function getAjaxKeys() {
        return array(
            'bid',
            'hide_title',
        );
    }
    
    /**
     * {@inheritdoc}
     */
    public function getUniqueKeys() {
        return array(
            'bid',
        );
    }
    
    /**
     * Checks if the current user can access a block.
     */
    private function accessBlock($module, $delta) {
        // Get current user's rids.
        global $user;
        $rids = array_keys($user->roles);
        // Get authorized rids.
        $authorized_rids = db_select('block_role', 'br')->fields('br', array(
            'rid',
        ))
            ->condition('module', $module, '=')
            ->condition('delta', $delta, '=')
            ->execute()
            ->fetchCol('rid');
        // Return whether the user can access the block:
        // - Either all roles have access - no record in {block_role}
        // - Or only specific roles have access - in which case rids should match.
        return count($authorized_rids) == 0 || count(array_intersect($authorized_rids, $rids)) != 0;
    }

}

Classes

Title Deprecated Summary
QuickBlockContent Class for tab content of type "block" - this is for rendering a block as tab content. @QuicktabFormat{ id = "quickblockcontent