ergebnis / twig-front-matter
Provides a Twig loader for files with YAML front-matter.
Installs: 16 293
Dependents: 0
Suggesters: 0
Security: 0
Stars: 2
Watchers: 3
Forks: 0
Open Issues: 11
Requires
- php: ~8.1.0 || ~8.2.0 || ~8.3.0
- ergebnis/front-matter: ^3.1.0
- twig/twig: ^3.4.3
Requires (Dev)
- ergebnis/composer-normalize: ^2.39.0
- ergebnis/data-provider: ^3.0.0
- ergebnis/license: ^2.2.0
- ergebnis/php-cs-fixer-config: ^6.10.0
- ergebnis/phpstan-rules: ^2.1.0
- ergebnis/phpunit-slow-test-detector: ^2.3.2
- fakerphp/faker: ^1.23.0
- infection/infection: ~0.27.6
- phpunit/phpunit: ^10.4.2
- psalm/plugin-phpunit: ~0.18.4
- rector/rector: ~0.18.6
- vimeo/psalm: ^5.15.0
- dev-main
- 1.1.0
- 1.0.1
- 1.0.0
- dev-dependabot/composer/symfony/process-6.4.14
- dev-dependabot/composer/rector/rector-1.2.9
- dev-dependabot/composer/ergebnis/phpunit-slow-test-detector-2.16.1
- dev-dependabot/github_actions/actions/checkout-4.2.2
- dev-dependabot/github_actions/actions/cache-4.1.2
- dev-dependabot/github_actions/codecov/codecov-action-4.6.0
- dev-dependabot/composer/ergebnis/composer-normalize-2.44.0
- dev-dependabot/composer/ergebnis/data-provider-3.3.0
- dev-dependabot/composer/ergebnis/license-2.5.0
- dev-dependabot/composer/ergebnis/php-cs-fixer-config-6.37.0
- dev-dependabot/composer/vimeo/psalm-5.26.1
This package is auto-updated.
Last update: 2024-11-06 18:17:37 UTC
README
This project provides a composer
package with a Twig loader for files with YAML front-matter.
Installation
Run
composer require ergebnis/twig-front-matter
Usage
Loading Twig templates with the FrontMatterLoader
This project ships with a FrontMatterLoader
that you can use to load Twig templates with YAML front-matter.
The FrontMatterLoader
- parses a Twig template and separates the front-matter from the body-matter using `ergebnis/front-matter
- converts the front-matter data to Twig assignments using an implementation of
Converter\FrontMatterConverter
- returns a new Twig Source that merges the Twig assignments from the front-matter data with the body-matter from the Twig template
YAML front-matter
Assume that you have a Twig template with the following YAML front-matter:
foo: bar number: 1234 pi: 3.14159 date: 2016-05-27 empty: ~ invalid-key: "hmm" multiline: | Multiple Line String object: key: value datetime: 2020-11-12 12:54:12 values: - one - two
Converting YAML front-matter to Twig assignments with the Converter/ToMultipleAssignmentsFrontMatterConverter
This project ships with a Converter/ToMultipleAssignmentsFrontMatterConverter.php
that you can use to convert the YAML front-matter to multiple Twig assignments.
The example below will convert the parsed YAML front-matter data to multiple Twig assignments that will assign data to Twig variables with force:
declare(strict_types=1); use Ergebnis\Twig; $frontMatterConverter = new Twig\FrontMatter\Converter\ToMultipleAssignmentsFrontMatterConverter(true); echo $frontMatterConverter->convert($data);
{% set foo = "bar" %} {% set number = 1234 %} {% set pi = 3.14159 %} {% set date = (1464307200|date_modify('0sec')) %} {% set empty = null %} {% set multiline = "Multiple\nLine\nString\n" %} {% set object = { key: "value", datetime: (1605185652|date_modify('0sec')), values: { 0: "one", 1: "two" } } %}
The example below will convert the parsed YAML front-matter data to multiple Twig assignments that will assign data to Twig variables without force (taking into account that you may pass variables to the template and prefer not to override these variables with front-matter):
declare(strict_types=1); use Ergebnis\Twig; $frontMatterConverter = new Twig\FrontMatter\Converter\ToMultipleAssignmentsFrontMatterConverter(false); echo $frontMatterConverter->convert($data);
{% set foo = foo is defined ? foo : "bar" %} {% set number = number is defined ? number : 1234 %} {% set pi = pi is defined ? pi : 3.14159 %} {% set date = date is defined ? date : (1464307200|date_modify('0sec')) %} {% set empty = empty is defined ? empty : null %} {% set multiline = multiline is defined ? multiline : "Multiple\nLine\nString\n" %} {% set object = object is defined ? object|merge({ key: "value", datetime: (1605185652|date_modify('0sec')), values: { 0: "one", 1: "two" } }) : { key: "value", datetime: (1605185652|date_modify('0sec')), values: { 0: "one", 1: "two" } } %}
Converting YAML front-matter to a Twig assignment with the Converter/ToSingleAssignmentFrontMatterConverter
This project ships with a Converter/ToSingleAssignmentFrontMatterConverter.php
that you can use to convert the YAML front-matter to a single Twig assignment.
The example below will convert the parsed YAML front-matter data to a single Twig assignment that will assign data to a Twig variable with force:
declare(strict_types=1); use Ergebnis\Twig; $frontMatterConverter = new Twig\FrontMatter\Converter\ToSingleAssignmentFrontMatterConverter( Twig\Expression\Name::fromString('data'), false, ); echo $frontMatterConverter->convert($data);
{% set data = { foo: "bar", number: 1234, pi: 3.14159, date: (1464307200|date_modify('0sec')), empty: null, invalid-key: "hmm", multiline: "Multiple\\nLine\\nString\\n", object: { key: "value", datetime: (1605185652|date_modify('0sec')), values: { 0: "one", 1: "two" } } } %}
The example below will convert the parsed YAML front-matter data to a single Twig assignment that will assign data to a Twig variables without force (taking into account that you may pass a variable to the template and prefer not to override this variable with front-matter):
declare(strict_types=1); use Ergebnis\Twig; $frontMatterConverter = new Twig\FrontMatter\Converter\ToSingleAssignmentFrontMatterConverter( Twig\Expression\Name::fromString('data'), false, ); echo $frontMatterConverter->convert($data);
{% set data = data is defined ? data|merge({ foo: "bar", number: 1234, pi: 3.14159, date: (1464307200|date_modify('0sec')), empty: null, invalid-key: "hmm", multiline: "Multiple\\nLine\\nString\\n", object: { key: "value", datetime: (1605185652|date_modify('0sec')), values: { 0: "one", 1: "two" } } }) : { foo: "bar", number: 1234, pi: 3.14159, date: (1464307200|date_modify('0sec')), empty: null, invalid-key: "hmm", multiline: "Multiple\\nLine\\nString\\n", object: { key: "value", datetime: (1605185652|date_modify('0sec')), values: { 0: "one", 1: "two" } } } %}
Configuring services in a Symfony project
Adjust your config/services.php
as follows to register a FrontMatterLoader
with a Converter\ToMultipleAssignmentsFrontMatterConverter
:
<?php declare(strict_types=1); use Ergebnis\FrontMatter; use Ergebnis\Twig; use Symfony\Component\DependencyInjection; return static function (DependencyInjection\Loader\Configurator\ContainerConfigurator $containerConfigurator): void { $services = $containerConfigurator->services(); $services->defaults() ->autoconfigure() ->autowire(); $services->alias( FrontMatter\Parser::class, FrontMatter\YamlParser::class, ); $services->set(FrontMatter\YamlParser::class) ->class(FrontMatter\YamlParser::class); $services->set(Twig\FrontMatter\Converter\FrontMatterConverter::class) ->class(Twig\FrontMatter\Converter\ToMultipleAssignmentsFrontMatterConverter::class) ->args([ '$force' => false, // or true, as you prefer ]); $services->set(Twig\FrontMatter\FrontMatterLoader::class) ->args([ '$loader' => new DependencyInjection\Loader\Configurator\ReferenceConfigurator('twig.loader.native_filesystem'), ]); });
Changelog
The maintainers of this project record notable changes to this project in a changelog.
Contributing
The maintainers of this project suggest following the contribution guide.
Code of Conduct
The maintainers of this project ask contributors to follow the code of conduct.
General Support Policy
The maintainers of this project provide limited support.
You can support the maintenance of this project by sponsoring @localheinz or requesting an invoice for services related to this project.
PHP Version Support Policy
This project supports PHP versions with active and security support.
The maintainers of this project add support for a PHP version following its initial release and drop support for a PHP version when it has reached the end of security support.
Security Policy
This project has a security policy.
License
This project uses the MIT license.
Social
Follow @localheinz and @ergebnis on Twitter.