decodelabs / tagged
PHP markup generation without the fuss
Installs: 9 603
Dependents: 6
Suggesters: 1
Security: 0
Stars: 5
Watchers: 3
Forks: 2
Open Issues: 0
Requires
- php: ^8.1
- ext-intl: *
- decodelabs/coercion: ^0.2
- decodelabs/collections: ^0.9
- decodelabs/cosmos: ^0.2
- decodelabs/elementary: ^0.4
- decodelabs/exceptional: ^0.4
- decodelabs/glitch-support: ^0.4
- decodelabs/veneer: ^0.11.6
- symfony/polyfill-mbstring: ^1.7
Requires (Dev)
Suggests
- nesbot/carbon: Support for time interval formatting
- dev-develop / 0.15.x-dev
- v0.15.6
- v0.15.5
- v0.15.4
- v0.15.3
- v0.15.2
- v0.15.1
- v0.15.0
- v0.14.14
- v0.14.13
- v0.14.12
- v0.14.11
- v0.14.10
- v0.14.9
- v0.14.8
- v0.14.7
- v0.14.6
- v0.14.5
- v0.14.4
- v0.14.3
- v0.14.2
- v0.14.1
- v0.14.0
- v0.13.0
- v0.12.0
- v0.11.10
- v0.11.9
- v0.11.8
- v0.11.7
- v0.11.6
- v0.11.5
- v0.11.4
- v0.11.3
- v0.11.2
- v0.11.1
- v0.11.0
- v0.10.1
- v0.10.0
- v0.9.1
- v0.9.0
- v0.8.10
- v0.8.9
- v0.8.8
- v0.8.7
- v0.8.6
- v0.8.5
- v0.8.4
- v0.8.3
- v0.8.2
- v0.8.1
- v0.8.0
- v0.7.0
- v0.6.9
- v0.6.8
- v0.6.7
- v0.6.6
- v0.6.5
- v0.6.4
- v0.6.3
- v0.6.2
- v0.6.1
- v0.6.0
- v0.5.0
- dev-main
This package is auto-updated.
Last update: 2025-01-06 18:14:21 UTC
README
PHP markup generation without the fuss.
Tagged provides a simple, powerful and beautiful way to create HTML markup without the spaghetti.
Get news and updates on the DecodeLabs blog.
Installation
composer require decodelabs/tagged
Usage
Tagged uses Veneer to provide a unified frontage under DecodeLabs\Tagged
.
You can access all the primary HTML functionality via this static frontage without compromising testing and dependency injection.
HTML markup
Generate markup using a simple, flexible interface.
use DecodeLabs\Tagged as Html; echo Html::{'div.my-class#my-id'}('This is element content', [ 'title' => 'This is a title' ]);
...creates:
<div class="my-class" id="my-id" title="This is a title">This is element content</div>
Create individual tags without content:
use DecodeLabs\Tagged as Html; $tag = Html::tag('div.my-class'); echo $tag->open(); echo 'Content'; echo $tag->close();
Wrap HTML strings to be used where an instance of Markup
is needed:
use DecodeLabs\Tagged as Html; $buffer = Html::raw('<span class="test">My span</span>');
Dump script data to Html:
yield Html::script(Html::raw(json_encode( $some_data )), [ 'type' => 'application/json' ]);
Prepare arbitrary input for Markup output:
use DecodeLabs\Tagged as Html; $markup = Html::wrap( function() { yield Html::h1('My title'); }, [Html::p(['This is ', Html::strong('mixed'), ' content'])] );
Nesting
You can nest elements in multiple ways:
use DecodeLabs\Tagged as Html; // Pass in nested elements via array echo Html::div([ Html::{'span.inner1'}('Inner 1'), ' ', Html::{'span.inner2'}('Inner 2') ]); // Return anything and everything via a generator echo Html::div(function($el) { // $el is the root element $el->addClass('container'); // Nest elements with a single call yield Html::{'header > h1'}('This is a header'); yield Html::p('This is a paragraph'); // Set attributes inline yield Html::{'p[data-target=open]'}('Target paragraph'); // Generator return values are rendered too return Html::{'div.awesome'}('This is awesome!'); });
Time and date
Format and wrap dates and intervals
use DecodeLabs\Tagged as Html; // Custom format Html::$time->format('now', 'd/m/Y', 'Europe/London'); // Locale format // When timezone is true it is fetched from Cosmos::$timezone Html::$time->locale('now', 'long', 'long', true); // Locale shortcuts Html::$time->dateTime('tomorrow'); // medium Html::$time->longTime('yesterday'); Html::$time->shortDate('yesterday'); // ...etc // Intervals Html::$time->since('yesterday'); // 1 day ago Html::$time->until('tomorrow'); // 1 day from now Html::$time->sinceAbs('yesterday'); // 1 day Html::$time->untilAbs('yesterday'); // -1 day Html::$time->between('yesterday', 'tomorrow'); // 1 day
Icons
Create the markup needed for font or SVG icons:
use DecodeLabs\Tagged as Html; Html::$icon->setFormat('font'); echo Html::$icon->aubergine; // <i class="icon icon-aubergine"></i> Html::$icon->setFormat('svg'); echo Html::$icon->aubergine; // <svg><use xlink:href="#aubergine" /></svg> Html::$icon->setSvgReference('path/to/my/file.svg'); echo Html::$icon->aubergine; // <svg><use xlink:href="path/to/my/file.svg#aubergine" /></svg>
Media embeds
Normalize embed codes shared from media sites:
use DecodeLabs\Tagged as Html; echo Html::$embed->video('https://www.youtube.com/watch?v=RG9TMn1FJzc');
Deprecated functionality
Looking for the functionality that was here before? It's likely been moved to a dedicated library:
XML handling
The XML manipulation functionality of Tagged has been moved to its own project, Exemplar.
Content parsing (Tagged::$parse and ::$toText plugins)
Content transformations are now handled by the Metamorph library.
Licensing
Tagged is licensed under the MIT License. See LICENSE for the full license text.