You are here

LayoutBase.php in Layout Plugin (obsolete, use core's Layout Discovery) 8

File

src/Plugin/Layout/LayoutBase.php
View source
<?php

namespace Drupal\layout_plugin\Plugin\Layout;

use Drupal\Component\Plugin\ConfigurablePluginInterface;
use Drupal\Core\Form\FormStateInterface;
use Drupal\Core\Plugin\PluginBase;
use Drupal\Core\Plugin\PluginFormInterface;

/**
 * Provides a base class for Layout plugins.
 */
abstract class LayoutBase extends PluginBase implements LayoutInterface, ConfigurablePluginInterface, PluginFormInterface {

  /**
   * The layout configuration.
   *
   * @var array
   */
  protected $configuration = [];

  /**
   * Gets the human-readable name.
   *
   * @return \Drupal\Core\Annotation\Translation|NULL
   *   The human-readable name.
   */
  public function getLabel() {
    return $this->pluginDefinition['label'];
  }

  /**
   * Gets the optional description for advanced layouts.
   *
   * @return \Drupal\Core\Annotation\Translation|NULL
   *   The layout description.
   */
  public function getDescription() {
    return isset($this->pluginDefinition['description']) ? $this->pluginDefinition['description'] : NULL;
  }

  /**
   * Gets the human-readable category.
   *
   * @return \Drupal\Core\Annotation\Translation
   *   The human-readable category.
   */
  public function getCategory() {
    return $this->pluginDefinition['category'];
  }

  /**
   * Gets human-readable list of regions keyed by machine name.
   *
   * @return \Drupal\Core\Annotation\Translation[]
   *   An array of human-readable region names keyed by machine name.
   */
  public function getRegionNames() {
    return $this->pluginDefinition['region_names'];
  }

  /**
   * Gets information on regions keyed by machine name.
   *
   * @return array
   *   An array of information on regions keyed by machine name.
   */
  public function getRegionDefinitions() {
    return $this->pluginDefinition['regions'];
  }

  /**
   * Gets the path to resources like icon or template.
   *
   * @return string|NULL
   *   The path relative to the Drupal root.
   */
  public function getBasePath() {
    return isset($this->pluginDefinition['path']) ? $this->pluginDefinition['path'] : NULL;
  }

  /**
   * Gets the path to the preview image.
   *
   * This can optionally be used in the user interface to show the layout of
   * regions visually.
   *
   * @return string|NULL
   *   The path to preview image file.
   */
  public function getIconFilename() {
    return isset($this->pluginDefinition['icon']) ? $this->pluginDefinition['icon'] : NULL;
  }

  /**
   * Get the asset library.
   *
   * @return string|NULL
   *   The asset library.
   */
  public function getLibrary() {
    return isset($this->pluginDefinition['library']) ? $this->pluginDefinition['library'] : NULL;
  }

  /**
   * Gets the theme hook used to render this layout.
   *
   * @return string|NULL
   *   Theme hook.
   */
  public function getThemeHook() {
    return isset($this->pluginDefinition['theme']) ? $this->pluginDefinition['theme'] : NULL;
  }

  /**
   * {@inheritdoc}
   */
  public function build(array $regions) {
    $build = array_intersect_key($regions, $this
      ->getRegionDefinitions());
    $build['#layout'] = $this
      ->getPluginDefinition();
    $build['#settings'] = $this
      ->getConfiguration();
    if ($theme = $this
      ->getThemeHook()) {
      $build['#theme'] = $theme;
    }
    if ($library = $this
      ->getLibrary()) {
      $build['#attached']['library'][] = $library;
    }
    return $build;
  }

  /**
   * {@inheritdoc}
   */
  public function buildConfigurationForm(array $form, FormStateInterface $form_state) {
    return $form;
  }

  /**
   * {@inheritdoc}
   */
  public function validateConfigurationForm(array &$form, FormStateInterface $form_state) {
  }

  /**
   * {@inheritdoc}
   */
  public function submitConfigurationForm(array &$form, FormStateInterface $form_state) {
    $this->configuration = $form_state
      ->getValues();
  }

  /**
   * {@inheritdoc}
   */
  public function getConfiguration() {
    return array_merge($this
      ->defaultConfiguration(), $this->configuration);
  }

  /**
   * {@inheritdoc}
   */
  public function setConfiguration(array $configuration) {
    $this->configuration = $configuration;
  }

  /**
   * {@inheritdoc}
   */
  public function defaultConfiguration() {
    return [];
  }

  /**
   * {@inheritdoc}
   */
  public function calculateDependencies() {
    return isset($this->configuration['dependencies']) ? $this->configuration['dependencies'] : [];
  }

}

Classes

Namesort descending Description
LayoutBase Provides a base class for Layout plugins.