decodelabs / metamorph
A flexible framework for content transformations
Installs: 1 587
Dependents: 3
Suggesters: 0
Security: 0
Stars: 0
Watchers: 3
Forks: 0
Open Issues: 0
Requires
- php: ^8.1
- decodelabs/archetype: ^0.3
- decodelabs/coercion: ^0.2
- decodelabs/exceptional: ^0.4
- decodelabs/tagged: ^0.15
- symfony/polyfill-mbstring: ^1.7
Requires (Dev)
- decodelabs/phpstan-decodelabs: ^0.6
- erusev/parsedown: ^1.7
- michelf/php-markdown: ^1.9|^2
- soundasleep/html2text: ^1.1|^2
Suggests
- erusev/parsedown: Add support for Markdown parsing
- michelf/php-markdown: Alternative Markdown parsing provider
- soundasleep/html2text: Better HTML to text conversion
README
A flexible framework for content transformations
Metamorph provides an extensible framework for transforming content from one format to another through a simple and intuitive interface.
Get news and updates on the DecodeLabs blog.
Installation
composer require decodelabs/metamorph
Usage
Importing
Metamorph uses Veneer to provide a unified frontage under DecodeLabs\Metamorph
.
You can access all the primary functionality via this static frontage without compromising testing and dependency injection.
Transformations
Use the Metamorph frontage to manipulate and output different formats of content.
Options can be passed as the second parameter and named macros allow for bundles of options to be passed as part of the call.
Metamorph uses Archetype to load Handler
classes - the base package comes with a small set of handlers out of the box:
Markdown
The built-in Markdown Handler will use whichever appropriate Markdown library has been installed via composer.
use DecodeLabs\Metamorph; // Default Markdown renders echo Metamorph::markdown($markdownContent); // Ensure output is secure from exploits with "safe" macro echo Metamorph::{'markdown.safe'}($markdownContent); // Output inline markup echo Metamorph::{'markdown.inline'}($markdownContent);
Text
The Text Handler considers input to be plain text and allows for various manipulations. HTML wrapping is turned on by default, converting the text to Tagged Markup.
echo Metamorph::text('Hello world', [ 'maxLength' => 5 // shorten output with ellipsis 'ellipsis' => '...' // Character(s) used while shortening string (optional) 'wrap' => true // Wrap output as HTML markup ]); // wrap=false echo Metamorph::{'text.raw'}($longText); // maxLength=50, wrap=true echo Metamorph::{'text.preview'}($longText); // maxLength=50, wrap=false echo Metamorph::{'text.preview.raw'}($longText);
HtmlToText
The HtmlToText Handler works in the opposite direction, taking HTML input and converting it to readable plain text.
echo Metamorph::htmlToText('<p>This is an HTML paragraph</p>', [ 'maxLength' => 5 // shorten stripped output with ellipsis 'ellipsis' => '...' // Character(s) used while shortening string (optional) 'wrap' => true // Wrap the stripped text in Markup element ]); // Strip and re-wrap HTML echo Metamorph::{'htmlToText.wrap'}($html); // maxLength=50, wrap=true echo Metamorph::{'htmlToText.preview'}($html);
Other implementations
See Idiom and Chirp for other custom implementations of Metamorph Handlers.
Licensing
Metamorph is licensed under the MIT License. See LICENSE for the full license text.