ryangjchandler / commonmark-blade-block
Embed Laravel Blade code inside of your Markdown templates.
                                    Fund package maintenance!
                                                                            
                                                                                                                                        Ryan Chandler
                                                                                    
                                                                
Installs: 1 072
Dependents: 2
Suggesters: 0
Security: 0
Stars: 21
Watchers: 2
Forks: 1
Open Issues: 2
pkg:composer/ryangjchandler/commonmark-blade-block
Requires
- php: ^8.2
- illuminate/contracts: ^12.0
- league/commonmark: ^2.7
- spatie/laravel-package-tools: ^1.92.4
Requires (Dev)
- larastan/larastan: ^3.0
- laravel/pint: ^1.22.1
- nunomaduro/collision: ^8.0
- orchestra/testbench: ^10.0.0
- pestphp/pest: ^3.0
- pestphp/pest-plugin-arch: ^3.0
- pestphp/pest-plugin-laravel: ^3.0
- phpstan/extension-installer: ^1.4.3
- phpstan/phpstan-deprecation-rules: ^2.0
- phpstan/phpstan-phpunit: ^2.0
- spatie/laravel-ray: ^1.40.2
This package is auto-updated.
Last update: 2025-10-13 02:17:13 UTC
README
This package provides an extension for league/commonmark that lets you embed Laravel Blade code inside of your Markdown content.
Installation
You can install the package via Composer:
composer require ryangjchandler/commonmark-blade-block
Usage
Start by registering the extension.
use League\CommonMark\MarkdownConverter; use League\CommonMark\Environment\Environment; use League\CommonMark\Extension\CommonMark\CommonMarkCoreExtension; use RyanChandler\CommonmarkBladeBlock\BladeExtension; $environment = new Environment(); $environment ->addExtension(new CommonMarkCoreExtension) ->addExtension(new BladeExtension); $converter = new MarkdownConverter($environment);
Then start embedding Blade inside of your Markdown content with the @blade and @endblade tags.
# Hello, world! @blade <x-button> Click me! </x-button> @endblade
Using Laravel's Str or str() helpers
If you're using Str::markdown() or str()->markdown(), then you can register the extension through the extensions argument.
Str::markdown( <<<'MD' @blade <x-button></x-button> @endblade MD, extensions: [ new BladeExtension(), ] )
Testing
composer test
Changelog
Please see CHANGELOG for more information on what has changed recently.
Contributing
Please see CONTRIBUTING for details.
Security Vulnerabilities
Please review our security policy on how to report security vulnerabilities.
Credits
License
The MIT License (MIT). Please see License File for more information.