mhujer/consistence-bundle

Add translator and form elements for enums from consistence/consistence

Installs: 20 403

Dependents: 0

Suggesters: 0

Security: 0

Stars: 1

Watchers: 2

Forks: 1

Open Issues: 0

Type:symfony-bundle

2.0.1 2023-12-09 15:22 UTC

This package is auto-updated.

Last update: 2025-01-09 17:51:28 UTC


README

Build Status Latest Stable Version Total Downloads License Coverage Status

This Bundle provides translator service, translator twig filter and form type for consistence/consistence enums.

Installation

Applications that use Symfony Flex

Open a command console, enter your project directory and execute:

$ composer require mhujer/consistence-bundle

Applications that don't use Symfony Flex

Step 1: Download the Bundle

Open a command console, enter your project directory and execute the following command to download the latest stable version of this bundle:

$ composer require mhujer/consistence-bundle

This command requires you to have Composer installed globally, as explained in the installation chapter of the Composer documentation.

Step 2: Enable the Bundle

Then, enable the bundle by adding it to the list of registered bundles in the config/bundles.php file of your project:

// config/bundles.php

return [
    // ...
    Mhujer\ConsistenceBundle\MhujerConsistenceBundle::class => ['all' => true],
];

Usage

Examples consider having the following enum:

<?php declare(strict_types = 1);

namespace App\Card;

final class CardColor extends \Consistence\Enum\Enum
{

    public const BLACK = 'black';
    public const RED = 'red';

}

Translation file

The translator automatically converts an instance of enum to a translation key consisting of FQCN of the enum, colon and its value, e.g.:

App\Card\CardColor:red

Best approach is to create a translation file using the PHP format (enums.en.php) which allows you to use the class name:

<?php declare(strict_types = 1);

use App\Card\CardColor;

return [
    CardColor::class . ':' . CardColor::RED => 'red',
    CardColor::class . ':' . CardColor::BLACK => 'black',
];

As you might have noticed, the translation domain is set to enums.

Twig

In Twig templates you can use transEnum filter to convert an enum to a translated string:

{{ variableContainingEnum | transEnum }}

Translation domain

Sometimes it is useful to have different translations for the same enum (e.g. when the enum is used in admin and frontend UI). This is achieved by an translationDomain parameter which can be passed to transEnum:

{{ variableContainingEnum | transEnum('enums-frontend') }}

It loads translations transparently from another domain using Symfony translator:

// enums-frontend.en.php
<?php declare(strict_types = 1);

use App\Card\CardColor;

return [
    CardColor::class . ':' . CardColor::RED => 'Red',
    CardColor::class . ':' . CardColor::BLACK => 'Black',
];

Forms

In forms, you can use EnumType as a field type. You need to set an option enum_class to an enum class:

public function buildForm(FormBuilderInterface $builder, array $options)
{
    $builder
        ->add('cardColor', EnumType::class, [
            'enum_class' => CardColor::class,
            'label' => 'Card Color',
        ])
    //...

Property in your request object should look like this (it contains an instance of CardColor):

/**
 * @Assert\NotBlank()
 * @var \App\Card\CardColor
 */
public $cardColor;

Requirements

Works with PHP 7.4 or higher and Symfony 5.4 or higher.

Submitting bugs and feature requests

Bugs and feature request are tracked on GitHub

Author

Martin Hujer

Changelog

2.0.1 (2023-12-09)

  • add Symfony 7 and PHP 8.2 support (dfridrich)

2.0.0 (2022-09-20)

  • require PHP 8.1
  • add support for native enums to make migration easier

1.4.0 (2021-12-04)

  • require Symfony 5.4+
  • allow PHP 8.1
  • allow Symfony 6.0

1.3.0 (2021-06-10)

  • BC break: optional parameter in transEnum is treated as translation domain

1.2.0 (2021-06-03)

  • add optional parameter $enumNamespace to transEnum method

1.1.0 (2021-02-28)

  • allow PHP 8.0
  • require PHP 7.4+

1.0.2 (2020-01-13)

  • Fixed #3: Undefined "translator" dependency in services.yaml

1.0.1 (2019-11-24)

  • Symfony 5 and Twig 3 compatibility

1.0.0 (2019-11-06)

  • initial release