Download the PHP package webwizo/laravel-shortcodes without Composer
On this page you can find all versions of the php package webwizo/laravel-shortcodes. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Download webwizo/laravel-shortcodes
More information about webwizo/laravel-shortcodes
Files in webwizo/laravel-shortcodes
Package laravel-shortcodes
Short Description Wordpress like shortcodes for Laravel 11, 12 and 13
License MIT
Homepage https://github.com/webwizo/laravel-shortcodes
Informations about the package laravel-shortcodes
Laravel-Shortcodes
WordPress-like shortcodes for Laravel 11, 12, and 13 (PHP 8.2+).

Documentation last updated: 2026-04-22
If you are looking for Laravel 4.2, see: https://github.com/patrickbrouwers/Laravel-Shortcodes
Install
Via Composer:
Laravel 11+ discovers the package automatically. On older setups, register Webwizo\Shortcodes\ShortcodesServiceProvider in config/app.php (or bootstrap/providers.php where applicable).
Service provider (manual registration)
You can use the facade for shorter code. Add this to your aliases (optional):
The class is bound to the ioC as shortcode
Usage
withShortcodes()
To enable the view compiling features:
This will enable shortcode rendering for that view only.
withShortcodes() in Mailables
You can also enable shortcode compilation for a mailable view:
Available since: v1.0.31
emails/newsletter.blade.php
The shortcode tags in that mailable view will be compiled during rendering.
Enable through class
Disable through class
Disabling some views from shortcode compiling
With the config set to true, you can disable the compiling per view.
Default compiling
To use default compiling:
Strip shortcodes from rendered view.
Strip shortcode through class
Shortcode syntax and parser
The compiler scans templates left to right. Behaviour relevant to authoring tags:
| Topic | Behaviour |
|---|---|
| Attributes | Quoted values may contain spaces. Keys may include hyphens (e.g. data-size="large"). Parsing follows the same general rules as WordPress shortcode attributes. |
| Void / self-closing | A tag such as [alert type="info"] with no matching [/alert] is treated as self-closing (no inner body). Use explicit [/tag] when you need wrapping content. |
| Nested same-name tags | Nested tags with the same name (e.g. [div]…[div]…[/div]…[/div]) are matched using balanced opening/closing pairs, innermost structure preserved. |
Unknown [ text |
Text in square brackets that does not start with a registered shortcode name is left unchanged (so prose like [I agree …] is not eaten). |
| Escaping | Use doubled brackets to output a literal shortcode: [[b]] → [b]. |
PHPUnit regression tests for these cases live under tests/GitHubIssue*.php.
Registering new shortcodes
Create a new ServiceProvider where you can register all the shortcodes.
After defining shortcodes, add the ServiceProvider to the providers array in config/app.php (or bootstrap/providers.php).
Example: register your shortcodes provider
Callback
Shortcodes can be registered within ShortcodesServiceProvider with a callback:
ShortcodesServiceProvider.php Class File
Default class for BoldShortcode
You can store each shortcode within their class app/Shortcodes/BoldShortcode.php
Class with custom method
You can store each shortcode within their class app/Shortcodes/ItalicShortcode.php
Register helpers
If you only want to show the html attribute when the attribute is provided in the shortcode, you can use $shortcode->get($attributeKey, $fallbackValue = null)
Shortcode Artisan Generator Command
This package provides an Artisan command to quickly generate shortcode classes:
- By default, this creates a new class in
app/Shortcodes/YourShortcodeNameShortcode.php. - If the file already exists, use the
--forceoption to overwrite:
Customizing the Stub
You can publish the stub file to customize the generated class:
This will copy the stub to resources/stubs/shortcode.stub in your Laravel app. Edit this file to change the template for new shortcode classes.
Testing
From the package root (after composer install):
Change log
Please see CHANGELOG for more information what has changed recently.
Contributing
Please see CONDUCT for details.
Security
If you discover any security related issues, please email [email protected] instead of using the issue tracker.
Credits
- Asif Iqbal
- All Contributors
Support me
License
The MIT License (MIT). Please see License File for more information.
All versions of laravel-shortcodes with dependencies
illuminate/support Version ^11.0|^12.0|^13.0
illuminate/contracts Version ^11.0|^12.0|^13.0
php Version ^8.2
