avensome / commonmark-bundle
Integrates CommonMark into Symfony 4 apps.
Installs: 3 065
Dependents: 1
Suggesters: 0
Security: 0
Stars: 3
Watchers: 3
Forks: 2
Open Issues: 0
Type:symfony-bundle
Requires
- php: ^7.0
- aptoma/twig-markdown: ^3.0
- league/commonmark: ^0.17.5
- symfony/framework-bundle: ^4.0
This package is auto-updated.
Last update: 2024-09-20 12:00:11 UTC
README
Provides seamless integration of CommonMark with Symfony and Twig.
Requires PHP 7.0+ and Symfony 4.0+.
Installation
Install with Composer:
composer require avensome/commonmark-bundle
Then add Avensome\CommonMarkBundle\AvensomeCommonMarkBundle
to config/bundles.php
:
<?php return [ // ... Avensome\CommonMarkBundle\AvensomeCommonMarkBundle::class => ['all' => true], ];
Usage in services
CommonMarkConverter
is an injectable service:
<?php use League\CommonMark\CommonMarkConverter; class MyService { public function __construct(CommonMarkConverter $converter) { // Do something with $converter // https://github.com/thephpleague/commonmark#basic-usage } }
Usage in Twig
The markdown
filter and tag are available in Twig.
{{ '# This string will be turned into HTML' | markdown }} {% markdown %} Contents of *these tags* will become HTML! - Nunquam locus lanista. - Neuter, barbatus solems aegre prensionem de secundus, salvus galatae. - Rumor moris, tanquam castus verpa. {% endmarkdown %}
Configuration
The CommonMarkConverter
accepts configuration as one of its parameters. With this package you can adjust these in your Symfony configuration (config.yaml
or similar). Just add the avensome_commonmark
key, everything under it will be passed directly to the Converter.
# ... avensome_commonmark: html_input: allow allow_unsafe_links: true
Extensions
To enable a CommonMark extension, just register it as a service and tag it with avensome_commonmark.extension
.
For example to enable WebUni Table Extension, install it and edit your services.yaml
:
services: # ... Webuni\CommonMark\TableExtension\TableExtension: tags: - name: avensome_commonmark.extension