class Parsedown in Markdown 8.2
Support for Parsedown by Emanuil Rusev.
Plugin annotation
@MarkdownAllowedHtml(
id = "parsedown",
)
@MarkdownParser(
id = "parsedown",
label = @Translation("Parsedown"),
description = @Translation("Parser for Markdown."),
weight = 21,
libraries = {
@ComposerPackage(
id = "erusev/parsedown",
object = "\Parsedown",
url = "https://parsedown.org",
),
}
)
Hierarchy
- class \Drupal\Component\Plugin\PluginBase implements DerivativeInspectionInterface, PluginInspectionInterface
- class \Drupal\Core\Plugin\PluginBase uses DependencySerializationTrait, MessengerTrait, StringTranslationTrait
- class \Drupal\markdown\Plugin\Markdown\AnnotatedPluginBase implements AnnotatedPluginInterface uses \Symfony\Component\DependencyInjection\ContainerAwareTrait
- class \Drupal\markdown\Plugin\Markdown\InstallablePluginBase implements InstallablePluginInterface uses PluginDependencyTrait, MoreInfoTrait
- class \Drupal\markdown\Plugin\Markdown\BaseParser implements PluginFormInterface, ParserInterface, FilterAwareInterface uses RefinableCacheableDependencyTrait, EnabledPluginTrait, FilterAwareTrait, SettingsTrait
- class \Drupal\markdown\Plugin\Markdown\Parsedown\Parsedown implements AllowedHtmlInterface, SettingsInterface uses ParserAllowedHtmlTrait
- class \Drupal\markdown\Plugin\Markdown\BaseParser implements PluginFormInterface, ParserInterface, FilterAwareInterface uses RefinableCacheableDependencyTrait, EnabledPluginTrait, FilterAwareTrait, SettingsTrait
- class \Drupal\markdown\Plugin\Markdown\InstallablePluginBase implements InstallablePluginInterface uses PluginDependencyTrait, MoreInfoTrait
- class \Drupal\markdown\Plugin\Markdown\AnnotatedPluginBase implements AnnotatedPluginInterface uses \Symfony\Component\DependencyInjection\ContainerAwareTrait
- class \Drupal\Core\Plugin\PluginBase uses DependencySerializationTrait, MessengerTrait, StringTranslationTrait
Expanded class hierarchy of Parsedown
File
- src/
Plugin/ Markdown/ Parsedown/ Parsedown.php, line 36
Namespace
Drupal\markdown\Plugin\Markdown\ParsedownView source
class Parsedown extends BaseParser implements AllowedHtmlInterface, SettingsInterface {
use ParserAllowedHtmlTrait {
allowedHtmlTags as allowedHtmlTagsTrait;
}
/**
* The Parsedown class to use.
*
* @var string
*/
protected static $parsedownClass = '\\Parsedown';
/**
* The parser version.
*
* @var string
*/
protected static $version;
/**
* The Parsedown instance.
*
* @var \Parsedown
*/
protected $parsedown;
/**
* {@inheritdoc}
*/
public function __sleep() {
unset($this->parsedown);
return parent::__sleep();
}
/**
* {@inheritdoc}
*/
public static function defaultSettings($pluginDefinition) {
/* @var \Drupal\markdown\Annotation\InstallablePlugin $pluginDefinition */
return [
'breaks_enabled' => FALSE,
'markup_escaped' => FALSE,
'safe_mode' => FALSE,
'strict_mode' => FALSE,
'urls_linked' => TRUE,
] + parent::defaultSettings($pluginDefinition);
}
/**
* {@inheritdoc}
*/
public function allowedHtmlTags(ParserInterface $parser, ActiveTheme $activeTheme = NULL) {
return FilterHtml::mergeAllowedTags($this
->allowedHtmlTagsTrait($parser, $activeTheme), [
'caption' => [],
'col' => [
'span' => TRUE,
],
'colgroup' => [
'span' => TRUE,
],
'del' => [],
'table' => [],
'tbody' => [],
'td' => [
'colspan' => TRUE,
'headers' => TRUE,
'rowspan' => TRUE,
],
'tfoot' => [],
'th' => [
'abbr' => TRUE,
'colspan' => TRUE,
'headers' => TRUE,
'rowspan' => TRUE,
'scope' => TRUE,
],
'thead' => [],
'tr' => [],
]);
}
/**
* {@inheritdoc}
*/
public function buildConfigurationForm(array $element, FormStateInterface $form_state) {
/** @var \Drupal\markdown\Form\SubformStateInterface $form_state */
$element = parent::buildConfigurationForm($element, $form_state);
$element += $this
->createSettingElement('breaks_enabled', [
'#access' => !!$this
->getSettingMethod('breaks_enabled'),
'#type' => 'checkbox',
'#title' => $this
->t('Automatic line breaks'),
'#description' => $this
->t('Enabling this will use line breaks (<code><br></code>) when a new line is detected instead of creating separate paragraphs (<code><p></code>).'),
], $form_state);
$element += $this
->createSettingElement('markup_escaped', [
'#access' => !!$this
->getSettingMethod('markup_escaped'),
'#type' => 'checkbox',
'#title' => $this
->t('Markup Escaped'),
'#description' => $this
->t('Enabling this will escape HTML markup.'),
], $form_state);
$this
->renderStrategyDisabledSettingState($form_state, $element['markup_escaped']);
$element += $this
->createSettingElement('safe_mode', [
'#access' => !!$this
->getSettingMethod('safe_mode'),
'#type' => 'checkbox',
'#title' => $this
->t('Safe Mode'),
'#description' => $this
->t('Enabling this will apply sanitization to additional scripting vectors (such as scripting link destinations) that are introduced by the markdown syntax itself.'),
], $form_state);
$this
->renderStrategyDisabledSettingState($form_state, $element['safe_mode']);
// Always disable safe_mode and markup_escaped when using a render strategy.
if ($this
->getRenderStrategy() !== static::NONE) {
$element['markup_escaped']['#value'] = FALSE;
$element['safe_mode']['#value'] = FALSE;
}
$element += $this
->createSettingElement('strict_mode', [
'#access' => !!$this
->getSettingMethod('strict_mode'),
'#type' => 'checkbox',
'#title' => $this
->t('Strict Mode'),
'#description' => $this
->t('Enables strict CommonMark compliance.'),
], $form_state);
$element += $this
->createSettingElement('urls_linked', [
'#access' => !!$this
->getSettingMethod('urls_linked'),
'#type' => 'checkbox',
'#title' => $this
->t('URLs linked'),
'#description' => $this
->t('Enabling this will automatically create links for URLs.'),
], $form_state);
return $element;
}
/**
* {@inheritdoc}
*/
protected function convertToHtml($markdown, LanguageInterface $language = NULL) {
return $this
->getParsedown()
->text($markdown);
}
/**
* Retrieves the Parsedown instance.
*
* @return \Parsedown
* A PHP Markdown parser.
*/
public function getParsedown() {
if (!$this->parsedown) {
$this->parsedown = new static::$parsedownClass();
$settings = $this
->getSettings();
// Unless the render strategy is set to "none", force the
// following settings to be disabled.
if ($this
->getRenderStrategy() !== static::NONE) {
$settings['markup_escaped'] = FALSE;
$settings['safe_mode'] = FALSE;
}
foreach ($settings as $name => $value) {
if ($method = $this
->getSettingMethod($name)) {
$this->parsedown
->{$method}($value);
}
}
}
return $this->parsedown;
}
/**
* {@inheritdoc}
*/
public function settingExists($name) {
return !!$this
->getSettingMethod($name);
}
/**
* Retrieves the method used to configure a specific setting.
*
* @param string $name
* The name of the setting.
*
* @return string|null
* The method name or NULL if method does not exist.
*/
protected function getSettingMethod($name) {
$map = static::settingMethodMap();
return isset($map[$name]) && method_exists(static::$parsedownClass, $map[$name]) ? $map[$name] : NULL;
}
/**
* A map of setting <-> method.
*
* @return array
* An associative array containing key/value pairs, where the key is the
* setting and the value is the method.
*/
protected static function settingMethodMap() {
return [
'breaks_enabled' => 'setBreaksEnabled',
'markup_escaped' => 'setMarkupEscaped',
'safe_mode' => 'setSafeMode',
'strict_mode' => 'setStrictMode',
'urls_linked' => 'setUrlsLinked',
];
}
}
Members
Name![]() |
Modifiers | Type | Description | Overrides |
---|---|---|---|---|
AnnotatedPluginBase:: |
protected | property | The original plugin_id that was called, not a fallback identifier. | |
AnnotatedPluginBase:: |
public static | function |
Creates an instance of the plugin. Overrides ContainerFactoryPluginInterface:: |
|
AnnotatedPluginBase:: |
public | function |
Retrieves the configuration overrides for the plugin. Overrides AnnotatedPluginInterface:: |
|
AnnotatedPluginBase:: |
public | function |
Retrieves the description of the plugin, if set. Overrides AnnotatedPluginInterface:: |
|
AnnotatedPluginBase:: |
public | function |
Retrieves the original plugin identifier. Overrides AnnotatedPluginInterface:: |
|
AnnotatedPluginBase:: |
public | function |
Returns the provider (extension name) of the plugin. Overrides AnnotatedPluginInterface:: |
|
AnnotatedPluginBase:: |
public | function |
Returns the weight of the plugin (used for sorting). Overrides AnnotatedPluginInterface:: |
|
AnnotatedPluginBase:: |
public | function |
Constructs a \Drupal\Component\Plugin\PluginBase object. Overrides PluginBase:: |
|
AnnotatedPluginBase:: |
public | function | ||
BaseParser:: |
protected | property | ||
BaseParser:: |
public | function |
Overrides RenderStrategyInterface:: |
|
BaseParser:: |
public | function |
Retrieves the allowed HTML plugins relevant to the object. Overrides RenderStrategyInterface:: |
|
BaseParser:: |
public | function |
Gets this plugin's configuration. Overrides InstallablePluginBase:: |
2 |
BaseParser:: |
protected | function |
Determines the configuration sort order by weight. Overrides InstallablePluginBase:: |
1 |
BaseParser:: |
protected | function | Builds context around a markdown parser's hierarchy filter format chain. | |
BaseParser:: |
public | function |
Retrieves the custom (user provided) allowed HTML. Overrides RenderStrategyInterface:: |
|
BaseParser:: |
public | function |
Retrieves the render strategy to use. Overrides RenderStrategyInterface:: |
|
BaseParser:: |
public | function |
Parses markdown into HTML. Overrides ParserInterface:: |
|
BaseParser:: |
protected | function | A description explaining why a setting is disabled due to render strategy. | |
BaseParser:: |
protected | function | Adds a conditional state for a setting element based on render strategy. | |
BaseParser:: |
public static | function | Validates parser settings. | |
CacheableDependencyTrait:: |
protected | property | Cache contexts. | |
CacheableDependencyTrait:: |
protected | property | Cache max-age. | |
CacheableDependencyTrait:: |
protected | property | Cache tags. | |
CacheableDependencyTrait:: |
public | function | 3 | |
CacheableDependencyTrait:: |
public | function | 3 | |
CacheableDependencyTrait:: |
public | function | 3 | |
CacheableDependencyTrait:: |
protected | function | Sets cacheability; useful for value object constructors. | |
DependencySerializationTrait:: |
protected | property | An array of entity type IDs keyed by the property name of their storages. | |
DependencySerializationTrait:: |
protected | property | An array of service IDs keyed by property name used for serialization. | |
DependencySerializationTrait:: |
public | function | 2 | |
DependencyTrait:: |
protected | property | The object's dependencies. | |
DependencyTrait:: |
protected | function | Adds multiple dependencies. | |
DependencyTrait:: |
protected | function | Adds a dependency. | |
EnabledPluginTrait:: |
public | function | 1 | |
EnabledPluginTrait:: |
public | function | ||
FilterAwareTrait:: |
protected | property | A Filter plugin. | |
FilterAwareTrait:: |
public | function | ||
FilterAwareTrait:: |
public | function | ||
InstallablePluginBase:: |
protected | property | The config for this plugin. | |
InstallablePluginBase:: |
public | function |
Builds a display for a library. Overrides InstallablePluginInterface:: |
|
InstallablePluginBase:: |
public | function |
Builds a display status based on the current state of the plugin. Overrides InstallablePluginInterface:: |
|
InstallablePluginBase:: |
public | function |
Calculates dependencies for the configured plugin. Overrides DependentPluginInterface:: |
|
InstallablePluginBase:: |
public | function |
Retrieves the config instance for this plugin. Overrides InstallablePluginInterface:: |
|
InstallablePluginBase:: |
protected static | function | ||
InstallablePluginBase:: |
public | function |
Gets default configuration for this plugin. Overrides AnnotatedPluginBase:: |
1 |
InstallablePluginBase:: |
public | function | Retrieves available installs. | |
InstallablePluginBase:: |
protected | function | Returns the configuration name for the plugin. | |
InstallablePluginBase:: |
public | function | Retrieves the container. | |
InstallablePluginBase:: |
public | function |
Retrieves the deprecation message, if any. Overrides InstallablePluginInterface:: |
|
InstallablePluginBase:: |
public | function |
Retrieves the experimental message. Overrides InstallablePluginInterface:: |
|
InstallablePluginBase:: |
public | function |
Retrieves the composer package name of the installable library, if any. Overrides InstallablePluginInterface:: |
|
InstallablePluginBase:: |
public | function |
Retrieves the installed library used by the plugin. Overrides InstallablePluginInterface:: |
|
InstallablePluginBase:: |
public | function |
Displays the human-readable label of the plugin. Overrides AnnotatedPluginBase:: |
|
InstallablePluginBase:: |
public | function |
Retrieves the plugin as a link using its label and URL. Overrides InstallablePluginInterface:: |
|
InstallablePluginBase:: |
public | function |
@TODO: Refactor to use variadic parameters. Overrides InstallablePluginInterface:: |
|
InstallablePluginBase:: |
public | function |
Retrieves the class name of the object defined by the installed library. Overrides InstallablePluginInterface:: |
|
InstallablePluginBase:: |
protected | function | 1 | |
InstallablePluginBase:: |
public | function |
Retrieves the preferred library of the plugin. Overrides InstallablePluginInterface:: |
|
InstallablePluginBase:: |
public | function |
Retrieves the configuration for the plugin, but sorted. Overrides InstallablePluginInterface:: |
|
InstallablePluginBase:: |
public | function |
Retrieves the URL of the plugin, if set. Overrides InstallablePluginInterface:: |
|
InstallablePluginBase:: |
public | function |
The current version of the plugin. Overrides InstallablePluginInterface:: |
|
InstallablePluginBase:: |
public | function | ||
InstallablePluginBase:: |
public | function |
Indicates whether plugin has multiple installs to check. Overrides InstallablePluginInterface:: |
|
InstallablePluginBase:: |
public | function |
Indicates whether the plugin is installed. Overrides InstallablePluginInterface:: |
|
InstallablePluginBase:: |
public | function |
Indicates whether the plugin is using the preferred library. Overrides InstallablePluginInterface:: |
|
InstallablePluginBase:: |
public | function |
Indicates whether the preferred library is installed. Overrides InstallablePluginInterface:: |
|
InstallablePluginBase:: |
public | function |
Sets the configuration for this plugin instance. Overrides AnnotatedPluginBase:: |
3 |
InstallablePluginBase:: |
public | function |
Indicates whether the plugin should be shown in the UI. Overrides InstallablePluginInterface:: |
|
MessengerTrait:: |
protected | property | The messenger. | 29 |
MessengerTrait:: |
public | function | Gets the messenger. | 29 |
MessengerTrait:: |
public | function | Sets the messenger. | |
MoreInfoTrait:: |
protected | function | Appends existing content with a "More Info" link. | |
Parsedown:: |
protected | property | The Parsedown instance. | |
Parsedown:: |
protected static | property | The Parsedown class to use. | 1 |
Parsedown:: |
protected static | property | The parser version. | |
Parsedown:: |
public | function |
Retrieves the allowed HTML tags. Overrides AllowedHtmlInterface:: |
1 |
Parsedown:: |
public | function |
Form constructor. Overrides BaseParser:: |
|
Parsedown:: |
protected | function |
Converts Markdown into HTML. Overrides BaseParser:: |
|
Parsedown:: |
public static | function |
Provides the default settings for the plugin. Overrides SettingsTrait:: |
|
Parsedown:: |
public | function | Retrieves the Parsedown instance. | |
Parsedown:: |
protected | function | Retrieves the method used to configure a specific setting. | |
Parsedown:: |
public | function |
Flag indicating whether a setting exists. Overrides SettingsTrait:: |
|
Parsedown:: |
protected static | function | A map of setting <-> method. | |
Parsedown:: |
public | function |
Overrides DependencySerializationTrait:: |
|
ParserAllowedHtmlTrait:: |
public | function | Aliased as: allowedHtmlTagsTrait | 1 |
PluginBase:: |
protected | property | Configuration information passed into the plugin. | 1 |
PluginBase:: |
protected | property | The plugin implementation definition. | 1 |
PluginBase:: |
protected | property | The plugin_id. | |
PluginBase:: |
constant | A string which is used to separate base plugin IDs from the derivative ID. | ||
PluginBase:: |
public | function |
Gets the base_plugin_id of the plugin instance. Overrides DerivativeInspectionInterface:: |
|
PluginBase:: |
public | function |
Gets the derivative_id of the plugin instance. Overrides DerivativeInspectionInterface:: |
|
PluginBase:: |
public | function |
Gets the definition of the plugin implementation. Overrides PluginInspectionInterface:: |
3 |
PluginBase:: |
public | function |
Gets the plugin_id of the plugin instance. Overrides PluginInspectionInterface:: |
|
PluginBase:: |
public | function | Determines if the plugin is configurable. | |
PluginDependencyTrait:: |
protected | function | Calculates and adds dependencies of a specific plugin instance. | |
PluginDependencyTrait:: |
protected | function | Calculates and returns dependencies of a specific plugin instance. Aliased as: getPluginDependenciesTrait | |
PluginDependencyTrait:: |
protected | function | Wraps the module handler. | |
PluginDependencyTrait:: |
protected | function | Wraps the theme handler. | |
RefinableCacheableDependencyTrait:: |
public | function | 1 | |
RefinableCacheableDependencyTrait:: |
public | function | ||
RefinableCacheableDependencyTrait:: |
public | function | ||
RefinableCacheableDependencyTrait:: |
public | function | ||
RendererTrait:: |
protected static | property | The Renderer service. | |
RendererTrait:: |
protected | function | Retrieves the Renderer service. | |
RenderStrategyInterface:: |
constant | The documentation URL for further explaining render strategies. | ||
RenderStrategyInterface:: |
constant | Strategy used to escape HTML input prior to parsing markdown. | ||
RenderStrategyInterface:: |
constant | Strategy used to filter the output of parsed markdown. | ||
RenderStrategyInterface:: |
constant | The URL for explaining Markdown and XSS; render strategies. | ||
RenderStrategyInterface:: |
constant | No render strategy. | ||
RenderStrategyInterface:: |
constant | Strategy used to remove HTML input prior to parsing markdown. | ||
SettingsTrait:: |
protected | function | Creates a setting element. | |
SettingsTrait:: |
public | function | ||
SettingsTrait:: |
public | function | ||
SettingsTrait:: |
public | function | ||
SettingsTrait:: |
public | function | ||
SettingsTrait:: |
public | function | 6 | |
SettingsTrait:: |
public | function | ||
SettingsTrait:: |
public | function | 2 | |
StringTranslationTrait:: |
protected | property | The string translation service. | 1 |
StringTranslationTrait:: |
protected | function | Formats a string containing a count of items. | |
StringTranslationTrait:: |
protected | function | Returns the number of plurals supported by a given language. | |
StringTranslationTrait:: |
protected | function | Gets the string translation service. | |
StringTranslationTrait:: |
public | function | Sets the string translation service to use. | 2 |
StringTranslationTrait:: |
protected | function | Translates a string to the current language or to a given language. |