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;
}
}
