1<?php 2 3/* 4 * This file is part of the league/commonmark package. 5 * 6 * (c) Colin O'Dell <colinodell@gmail.com> 7 * 8 * For the full copyright and license information, please view the LICENSE 9 * file that was distributed with this source code. 10 */ 11 12namespace League\CommonMark\Extension\HeadingPermalink; 13 14use League\CommonMark\ElementRendererInterface; 15use League\CommonMark\HtmlElement; 16use League\CommonMark\Inline\Element\AbstractInline; 17use League\CommonMark\Inline\Renderer\InlineRendererInterface; 18use League\CommonMark\Util\ConfigurationAwareInterface; 19use League\CommonMark\Util\ConfigurationInterface; 20 21/** 22 * Renders the HeadingPermalink elements 23 */ 24final class HeadingPermalinkRenderer implements InlineRendererInterface, ConfigurationAwareInterface 25{ 26 /** @deprecated */ 27 const DEFAULT_INNER_CONTENTS = '<svg class="heading-permalink-icon" viewBox="0 0 16 16" version="1.1" width="16" height="16" aria-hidden="true"><path fill-rule="evenodd" d="M4 9h1v1H4c-1.5 0-3-1.69-3-3.5S2.55 3 4 3h4c1.45 0 3 1.69 3 3.5 0 1.41-.91 2.72-2 3.25V8.59c.58-.45 1-1.27 1-2.09C10 5.22 8.98 4 8 4H4c-.98 0-2 1.22-2 2.5S3 9 4 9zm9-3h-1v1h1c1 0 2 1.22 2 2.5S13.98 12 13 12H9c-.98 0-2-1.22-2-2.5 0-.83.42-1.64 1-2.09V6.25c-1.09.53-2 1.84-2 3.25C6 11.31 7.55 13 9 13h4c1.45 0 3-1.69 3-3.5S14.5 6 13 6z"></path></svg>'; 28 29 const DEFAULT_SYMBOL = '¶'; 30 31 /** @var ConfigurationInterface */ 32 private $config; 33 34 public function setConfiguration(ConfigurationInterface $configuration) 35 { 36 $this->config = $configuration; 37 } 38 39 public function render(AbstractInline $inline, ElementRendererInterface $htmlRenderer) 40 { 41 if (!$inline instanceof HeadingPermalink) { 42 throw new \InvalidArgumentException('Incompatible inline type: ' . \get_class($inline)); 43 } 44 45 $slug = $inline->getSlug(); 46 47 $idPrefix = (string) $this->config->get('heading_permalink/id_prefix', 'user-content'); 48 if ($idPrefix !== '') { 49 $idPrefix .= '-'; 50 } 51 52 $attrs = [ 53 'id' => $idPrefix . $slug, 54 'href' => '#' . $slug, 55 'name' => $slug, 56 'class' => $this->config->get('heading_permalink/html_class', 'heading-permalink'), 57 'aria-hidden' => 'true', 58 'title' => $this->config->get('heading_permalink/title', 'Permalink'), 59 ]; 60 61 $innerContents = $this->config->get('heading_permalink/inner_contents'); 62 if ($innerContents !== null) { 63 @trigger_error(sprintf('The %s config option is deprecated; use %s instead', 'inner_contents', 'symbol'), E_USER_DEPRECATED); 64 65 return new HtmlElement('a', $attrs, $innerContents, false); 66 } 67 68 $symbol = $this->config->get('heading_permalink/symbol', self::DEFAULT_SYMBOL); 69 70 return new HtmlElement('a', $attrs, \htmlspecialchars($symbol), false); 71 } 72} 73