amp-8.x-3.5/src/Element/AmpProcessedText.php

src/Element/AmpProcessedText.php
<?php

namespace Drupal\amp\Element;

use Drupal\filter\Element\ProcessedText;
use Drupal\Component\Utility\Xss;

/**
 * Provides an amp-processed text render element.
 *
 * @RenderElement("amp_processed_text")
 */
class AmpProcessedText extends ProcessedText {

  /**
   * {@inheritdoc}
   */
  public function getInfo() {
    $class = get_class($this);
    return [
      '#text' => '',
      '#format' => NULL,
      '#filter_types_to_skip' => [],
      '#langcode' => '',
      '#pre_render' => [
        [$class, 'preRenderText'],
        [$class, 'preRenderAmpText'],
      ],
      '#cache' => [
        'contexts' => ['url.query_args:amp', 'url.query_args:debug'],
        'tags' => ['config:amp.settings'],
      ],
    ];
  }

  /**
   * Pre-render callback: Processes the amp markup and attaches libraries.
   */
  public static function preRenderAmpText($element) {
    /** @var \Drupal\amp\Service\AMPService $amp_service */
    $amp_service = \Drupal::service('amp.utilities');
    /** @var \Lullabot\AMP\AMP $amp */
    $amp = $amp_service->createAMPConverter();

    $amp->loadHtml($element['#markup']);
    $element['#markup'] = $amp->convertToAmpHtml();
    $element['#allowed_tags'] = array_merge(Xss::getAdminTagList(), ['amp-img']);
    $js = $amp->getComponentJs();
    if (!empty($js)) {
      $element['#attached']['library'] = $amp_service->addComponentLibraries($js);
      $element['#allowed_tags'] = array_merge($amp_service->getComponentTags($js), $element['#allowed_tags']);
    }
    return $element;
  }

}

Главная | Обратная связь

drupal hosting | друпал хостинг | it patrol .inc