TipPluginText.php

Same filename in other branches
  1. 9 core/modules/tour/src/Plugin/tour/tip/TipPluginText.php
  2. 10 core/modules/tour/src/Plugin/tour/tip/TipPluginText.php
  3. 11.x core/modules/tour/src/Plugin/tour/tip/TipPluginText.php

Namespace

Drupal\tour\Plugin\tour\tip

File

core/modules/tour/src/Plugin/tour/tip/TipPluginText.php

View source
<?php

namespace Drupal\tour\Plugin\tour\tip;

use Drupal\Component\Utility\Html;
use Drupal\Core\Plugin\ContainerFactoryPluginInterface;
use Drupal\Core\Utility\Token;
use Drupal\tour\TipPluginBase;
use Symfony\Component\DependencyInjection\ContainerInterface;

/**
 * Displays some text as a tip.
 *
 * @Tip(
 *   id = "text",
 *   title = @Translation("Text")
 * )
 */
class TipPluginText extends TipPluginBase implements ContainerFactoryPluginInterface {
    
    /**
     * The body text which is used for render of this Text Tip.
     *
     * @var string
     */
    protected $body;
    
    /**
     * Token service.
     *
     * @var \Drupal\Core\Utility\Token
     */
    protected $token;
    
    /**
     * The forced position of where the tip will be located.
     *
     * @var string
     */
    protected $location;
    
    /**
     * Unique aria-id.
     *
     * @var string
     */
    protected $ariaId;
    
    /**
     * Constructs a \Drupal\tour\Plugin\tour\tip\TipPluginText object.
     *
     * @param array $configuration
     *   A configuration array containing information about the plugin instance.
     * @param string $plugin_id
     *   The plugin_id for the plugin instance.
     * @param mixed $plugin_definition
     *   The plugin implementation definition.
     * @param \Drupal\Core\Utility\Token $token
     *   The token service.
     */
    public function __construct(array $configuration, $plugin_id, $plugin_definition, Token $token) {
        parent::__construct($configuration, $plugin_id, $plugin_definition);
        $this->token = $token;
    }
    
    /**
     * {@inheritdoc}
     */
    public static function create(ContainerInterface $container, array $configuration, $plugin_id, $plugin_definition) {
        return new static($configuration, $plugin_id, $plugin_definition, $container->get('token'));
    }
    
    /**
     * Returns a ID that is guaranteed uniqueness.
     *
     * @return string
     *   A unique id to be used to generate aria attributes.
     */
    public function getAriaId() {
        if (!$this->ariaId) {
            $this->ariaId = Html::getUniqueId($this->get('id'));
        }
        return $this->ariaId;
    }
    
    /**
     * Returns body of the text tip.
     *
     * @return string
     *   The tip body.
     */
    public function getBody() {
        return $this->get('body');
    }
    
    /**
     * Returns location of the text tip.
     *
     * @return string
     *   The tip location.
     */
    public function getLocation() {
        return $this->get('location');
    }
    
    /**
     * {@inheritdoc}
     */
    public function getAttributes() {
        $attributes = parent::getAttributes();
        $attributes['data-aria-describedby'] = 'tour-tip-' . $this->getAriaId() . '-contents';
        $attributes['data-aria-labelledby'] = 'tour-tip-' . $this->getAriaId() . '-label';
        if ($location = $this->get('location')) {
            $attributes['data-options'] = 'tipLocation:' . $location;
        }
        return $attributes;
    }
    
    /**
     * {@inheritdoc}
     */
    public function getOutput() {
        $output = '<h2 class="tour-tip-label" id="tour-tip-' . $this->getAriaId() . '-label">' . Html::escape($this->getLabel()) . '</h2>';
        $output .= '<p class="tour-tip-body" id="tour-tip-' . $this->getAriaId() . '-contents">' . $this->token
            ->replace($this->getBody()) . '</p>';
        return [
            '#markup' => $output,
        ];
    }

}

Classes

Title Deprecated Summary
TipPluginText Displays some text as a tip.

Buggy or inaccurate documentation? Please file an issue. Need support? Need help programming? Connect with the Drupal community.