Same filename and directory in other branches
  1. 8.x-3.x src/Plugin/TabType/QtabsContent.php 1 comment

Namespace

Drupal\quicktabs\Plugin\TabType

File

src/Plugin/TabType/QtabsContent.php

View source
<?php

namespace Drupal\quicktabs\Plugin\TabType;

use Drupal\Core\StringTranslation\StringTranslationTrait;
use Drupal\quicktabs\TabTypeBase;

/**
 * Provides a 'qtabs content' tab type.
 *
 * @TabType(
 *   id = "qtabs_content",
 *   name = @Translation("qtabs"),
 * )
 */
class QtabsContent extends TabTypeBase {
    use StringTranslationTrait;
    
    /**
     * {@inheritdoc}
     */
    public function optionsForm(array $tab) {
        $plugin_id = $this->getPluginDefinition()['id'];
        $form = [];
        $tab_options = [];
        foreach (\Drupal::entityTypeManager()->getStorage('quicktabs_instance')
            ->loadMultiple() as $machine_name => $entity) {
            // Do not offer the option to put a tab inside itself.
            if (!isset($tab['entity_id']) || $machine_name != $tab['entity_id']) {
                $tab_options[$machine_name] = $entity->label();
            }
        }
        $form['machine_name'] = [
            '#type' => 'select',
            '#title' => $this->t('QuickTabs instance'),
            '#description' => $this->t('The QuickTabs instance to put inside this tab.'),
            '#options' => $tab_options,
            '#default_value' => isset($tab['content'][$plugin_id]['options']['machine_name']) ? $tab['content'][$plugin_id]['options']['machine_name'] : '',
        ];
        return $form;
    }
    
    /**
     * {@inheritdoc}
     */
    public function render(array $tab) {
        $options = $tab['content'][$tab['type']]['options'];
        $qt = \Drupal::service('entity_type.manager')->getStorage('quicktabs_instance')
            ->load($options['machine_name']);
        return $qt->getRenderArray();
    }

}

Classes

Title Deprecated Summary
QtabsContent Provides a 'qtabs content' tab type.