From 00b47ad4a27ca970123e984edc43bb331651ef20 Mon Sep 17 00:00:00 2001 From: Damien Alexandre Date: Wed, 2 Nov 2022 22:23:49 +0100 Subject: [PATCH 1/2] doc(translatable): Improve the LocaleSubscriber implementation Also fix some English / improve the flow of the document. --- docs/translatable-api-platform.md | 49 +++++++++++++++++++------------ 1 file changed, 31 insertions(+), 18 deletions(-) diff --git a/docs/translatable-api-platform.md b/docs/translatable-api-platform.md index a9b60008..c15bdb43 100644 --- a/docs/translatable-api-platform.md +++ b/docs/translatable-api-platform.md @@ -1,6 +1,8 @@ # Translatable - API Platform -How to use Translatable with API platform. +## Expose translated properties + +How to use Translatable with API Platform. Let's say you have a Document Entity like so: @@ -13,7 +15,7 @@ use Knp\DoctrineBehaviors\Model\Translatable\TranslatableTrait; class Document implements TranslatableInterface { -use TranslatableTrait; + use TranslatableTrait; #[ORM\Id] #[ORM\GeneratedValue] @@ -22,8 +24,7 @@ use TranslatableTrait; public function getTitle(): string { - return $this->translate() - ->getTitle(); + return $this->translate()->getTitle(); } } ``` @@ -59,7 +60,23 @@ class DocumentTranslation implements TranslationInterface } ``` -Now we can implement an Event Subscriber to listen to the accept-language header on each request: +If you need serialisation groups you must add them on the root entity getter like this: + +```php +class Document implements TranslatableInterface +{ + use TranslatableTrait; + + #[Groups(['document:read', 'search:read'])] + public function getTitle(): string + { + return $this->translate()->getTitle(); + } +``` + +## Set the locale + +If you cannot enabled [Symfony `set_content_language_from_locale` option](https://symfony.com/doc/current/reference/configuration/framework.html#set-content-language-from-locale) (happens when you have other parts of your applications where the `Accept-Language` is not the locale provider) you can add your own Event Subscriber like this: ```php getRequest(); - $acceptLanguage = $request->headers->get('accept-language'); - if (empty($acceptLanguage)) { - return; - } - $arr = HeaderUtils::split($acceptLanguage, ',;'); - if (empty($arr[0][0])) { + // Only set your locale from the Accept Language header + if (!str_starts_with($request->getPathInfo(), '/api')) { return; } - // Symfony expects underscore instead of dash in locale - $locale = str_replace('-', '_', $arr[0][0]); - - $request->setLocale($locale); + $request->setLocale( + $request->getPreferredLanguage($this->availableLocales) + ); + $request->attributes->set('_vary_by_language', true); } } ``` -Now we can make a request to `/api/documents` do not for get to add the `Accept-Language` header value, in this case it's set to 'cz'. +## Demo + +Now we can make a request to `/api/documents`, do not forget to add the `Accept-Language` header value, in this case it's set to 'cz'. When you change the `Accept-Language` header value, notice the title change language. ```json @@ -128,5 +143,3 @@ When you change the `Accept-Language` header value, notice the title change lang ] } ``` - -That's it! From 56655f5e3a901da4ab7cb45d07bca875e9f18363 Mon Sep 17 00:00:00 2001 From: Damien Alexandre Date: Wed, 2 Nov 2022 22:27:35 +0100 Subject: [PATCH 2/2] doc(translatable): Fix the missing availableLocales property --- docs/translatable-api-platform.md | 7 +++++++ 1 file changed, 7 insertions(+) diff --git a/docs/translatable-api-platform.md b/docs/translatable-api-platform.md index c15bdb43..e9907e44 100644 --- a/docs/translatable-api-platform.md +++ b/docs/translatable-api-platform.md @@ -92,6 +92,13 @@ use Symfony\Component\HttpKernel\KernelEvents; class LocaleSubscriber implements EventSubscriberInterface { + /** + * @param array $availableLocales + */ + public function __construct(private readonly array $availableLocales) + { + } + /** * @return array> */