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