class TipPluginTextLegacy

Same name and namespace in other branches
  1. 10 core/modules/tour/tests/tour_test/src/Plugin/tour/tip/TipPluginTextLegacy.php \Drupal\tour_test\Plugin\tour\tip\TipPluginTextLegacy
  2. 11.x core/modules/tour/tests/tour_test/src/Plugin/tour/tip/TipPluginTextLegacy.php \Drupal\tour_test\Plugin\tour\tip\TipPluginTextLegacy

Displays some text as a tip.

Plugin annotation


@Tip(
  id = "text_legacy",
  title = @Translation("Text Legacy")
)

Hierarchy

Expanded class hierarchy of TipPluginTextLegacy

File

core/modules/tour/tests/tour_test/src/Plugin/tour/tip/TipPluginTextLegacy.php, line 19

Namespace

Drupal\tour_test\Plugin\tour\tip
View source
class TipPluginTextLegacy 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 TipPluginTextLegacy 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 an 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');
    }
    
    /**
     * {@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,
        ];
    }

}

Members

Title Sort descending Deprecated Modifiers Object type Summary Overriden Title
TipPluginBase::$attributes Deprecated protected property The attributes that will be applied to the markup of this tip.
TipPluginBase::$label protected property The label which is used for render of this tip.
TipPluginBase::$weight protected property Allows tips to take more priority that others.
TipPluginBase::get public function Used for returning values by key. Overrides TipPluginInterface::get
TipPluginBase::getLabel public function Returns label of the tip. Overrides TipPluginInterface::getLabel
TipPluginBase::getLocation public function Determines the placement of the tip relative to the element.
TipPluginBase::getSelector public function The selector the tour tip will attach to.
TipPluginBase::getWeight public function Returns weight of the tip. Overrides TipPluginInterface::getWeight
TipPluginBase::id public function Returns id of the tip. Overrides TipPluginInterface::id
TipPluginBase::set public function Used for returning values by key. Overrides TipPluginInterface::set
TipPluginTextLegacy::$ariaId protected property Unique aria-id.
TipPluginTextLegacy::$body protected property The body text which is used for render of this Text Tip.
TipPluginTextLegacy::$location protected property The forced position of where the tip will be located.
TipPluginTextLegacy::$token protected property Token service.
TipPluginTextLegacy::create public static function Creates an instance of the plugin. Overrides ContainerFactoryPluginInterface::create
TipPluginTextLegacy::getAriaId public function Returns an ID that is guaranteed uniqueness.
TipPluginTextLegacy::getAttributes public function @todo remove in https://drupal.org/node/3195193 Overrides TipPluginBase::getAttributes
TipPluginTextLegacy::getBody public function Returns body of the text tip.
TipPluginTextLegacy::getOutput public function This method should not be used. It is deprecated from TipPluginInterface. Overrides TipPluginBase::getOutput
TipPluginTextLegacy::__construct public function Constructs a TipPluginTextLegacy object. Overrides TipPluginBase::__construct

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