Skip to content

Commit

Permalink
Make Translator usable on Storybook and the module
Browse files Browse the repository at this point in the history
  • Loading branch information
Quetzacoalt91 committed Jul 17, 2024
1 parent d3ff633 commit 2bfaed0
Show file tree
Hide file tree
Showing 14 changed files with 223 additions and 24 deletions.
3 changes: 2 additions & 1 deletion .php-cs-fixer.dist.php
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,7 @@
->setUsingCache(true)
->getFinder()
->in(__DIR__)
->exclude('vendor');
->exclude('vendor')
->exclude('node_modules');

return $config;
5 changes: 4 additions & 1 deletion autoupgrade.php
Original file line number Diff line number Diff line change
Expand Up @@ -184,7 +184,10 @@ public function trans($id, array $parameters = [], $domain = null, $locale = nul
{
require_once _PS_ROOT_DIR_ . '/modules/autoupgrade/classes/UpgradeTools/Translator.php';

$translator = new \PrestaShop\Module\AutoUpgrade\UpgradeTools\Translator();
$translator = new \PrestaShop\Module\AutoUpgrade\UpgradeTools\Translator(
_PS_ROOT_DIR_ . '/modules/autoupgrade/translations/',
\Context::getContext()->language->iso_code
);

return $translator->trans($id, $parameters);
}
Expand Down
11 changes: 10 additions & 1 deletion classes/UpgradeContainer.php
Original file line number Diff line number Diff line change
Expand Up @@ -492,7 +492,16 @@ public function getTranslationAdapter(): Translation

public function getTranslator(): Translator
{
return new Translator();
$locale = 'en';
// @phpstan-ignore booleanAnd.rightAlwaysTrue (If PrestaShop core is not instantiated properly, do not try to translate)
if (method_exists('\Context', 'getContext') && \Context::getContext()->language) {
$locale = \Context::getContext()->language->iso_code;
}

return new Translator(
$this->getProperty(self::PS_ROOT_PATH) . DIRECTORY_SEPARATOR . 'modules' . DIRECTORY_SEPARATOR . 'autoupgrade' . DIRECTORY_SEPARATOR . 'translations' . DIRECTORY_SEPARATOR,
$locale
);
}

/**
Expand Down
30 changes: 18 additions & 12 deletions classes/UpgradeTools/Translator.php
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,22 @@ class Translator
*/
private $translations = [];

/** @var string */
private $locale;

/** @var string */
private $translationsFilesPath;

/**
* @param string $translationsFilesPath
* @param string $locale
*/
public function __construct($translationsFilesPath, $locale = 'en')
{
$this->locale = $locale;
$this->translationsFilesPath = $translationsFilesPath;
}

/**
* Load translations from XLF files.
*
Expand All @@ -20,13 +36,8 @@ class Translator
*/
private function loadTranslations()
{
$language = \Context::getContext()->language->iso_code;

// Adjust the path to your XLF files as necessary
$basePath = _PS_MODULE_DIR_ . 'autoupgrade/translations/ModulesAutoupgradeAdmin';

// use generic language file (e.g., fr)
$path = $basePath . '.' . $language . '.xlf';
$path = $this->translationsFilesPath . "ModulesAutoupgradeAdmin.{$this->locale}.xlf";
if (file_exists($path)) {
$this->loadXlfFile($path);
}
Expand Down Expand Up @@ -63,11 +74,6 @@ private function loadXlfFile($filePath)
*/
public function trans($id, array $parameters = [], $domain = null, $locale = null)
{
// If PrestaShop core is not instantiated properly, do not try to translate
if (!method_exists('\Context', 'getContext') || null === \Context::getContext()->language) {
return $this->applyParameters($id, $parameters);
}

if (empty($this->translations)) {
try {
$this->loadTranslations();
Expand Down Expand Up @@ -111,6 +117,6 @@ public function applyParameters($id, array $parameters = [])
*/
public function getLocale()
{
return \Context::getContext()->language->locale;
return $this->locale;
}
}
4 changes: 4 additions & 0 deletions storybook/.storybook/global.d.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
/**
* List all the available locales in the translations/ folder
*/
declare const TRANSLATION_LOCALES: string[];
20 changes: 20 additions & 0 deletions storybook/.storybook/main.ts
Original file line number Diff line number Diff line change
Expand Up @@ -24,6 +24,9 @@
*/

import type { StorybookConfig } from "@sensiolabs/storybook-symfony-webpack5";
import webpack from "webpack";
import fs from 'fs';
import path from 'path';

const config: StorybookConfig = {
stories: ["../stories/**/*.stories.[tj]s", "../stories/**/*.mdx"],
Expand All @@ -45,6 +48,23 @@ const config: StorybookConfig = {
},
},
},
webpackFinal: async (config) => {
// List translations files on compilation to fill language selection list
const newPlugin = new webpack.DefinePlugin({
TRANSLATION_LOCALES: JSON.stringify(
fs.readdirSync(path.resolve(__dirname, '../../translations'))
.map((file) => new RegExp("^ModulesAutoupgradeAdmin.([a-z]+).xlf$", "i").exec(file)?.[1])
.filter((locale) => !!locale)
),
});
if (config.plugins?.length) {
config.plugins.push(newPlugin);
} else {
config.plugins = [newPlugin];
}

return config;
},
docs: {
autodocs: "tag",
},
Expand Down
18 changes: 18 additions & 0 deletions storybook/.storybook/preview.ts
Original file line number Diff line number Diff line change
Expand Up @@ -50,6 +50,24 @@ const preview: Preview = {
})),
},
},
_locale: {
description: 'Internationalization locale',
defaultValue: 'en',
toolbar: {
icon: 'globe',
items: TRANSLATION_LOCALES.map((languageLocale) => ({
value: languageLocale,
title: new Intl.DisplayNames(
[navigator.language || 'en'],
{type: 'language'},
).of(languageLocale),
right: String.fromCodePoint(...({'en': 'gb', 'cs': 'cz'}[languageLocale] || languageLocale)
.toUpperCase()
.split('')
.map(char => 127397 + char.charCodeAt())),
})),
},
},
},
decorators: [
(story, context) => {
Expand Down
1 change: 1 addition & 0 deletions storybook/composer.json
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,7 @@
"sensiolabs/storybook-bundle": "^0.1.1",
"symfony/console": "7.1.*",
"symfony/dotenv": "7.1.*",
"symfony/expression-language": "7.1.*",
"symfony/flex": "^2",
"symfony/framework-bundle": "7.1.*",
"symfony/runtime": "7.1.*",
Expand Down
68 changes: 66 additions & 2 deletions storybook/composer.lock

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

20 changes: 20 additions & 0 deletions storybook/config/services.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -6,10 +6,30 @@ services:
autowire: true
autoconfigure: true

PrestaShop\Module\AutoUpgrade\:
resource: '../../classes'
exclude: '../../classes/**/index.php'

# makes classes in src/ available to be used as services
# this creates a service per class whose id is the fully-qualified class name
App\:
resource: '../src/'
exclude:
- '../src/DependencyInjection/'
- '../src/Entity/'
- '../src/Kernel.php'

PrestaShop\Module\AutoUpgrade\UpgradeTools\Translator:
arguments:
$translationsFilesPath: '%kernel.project_dir%/../translations/'
$locale: '@=service("request_stack").getCurrentRequest()?.getPayload().all("args")["_locale"]'

twig.extension.trans:
class: Symfony\Bridge\Twig\Extension\TranslationExtension
public: false
arguments: ['@App\TranslatorBridge']
tags:
- { name: twig.extension }

# add more service definitions when explicit configuration is needed
# please note that last definitions always *replace* previous ones
27 changes: 27 additions & 0 deletions storybook/src/TranslatorBridge.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,27 @@
<?php

namespace App;

use PrestaShop\Module\AutoUpgrade\UpgradeTools\Translator;
use Symfony\Contracts\Translation\TranslatorInterface;

class TranslatorBridge implements TranslatorInterface
{
/** @var Translator */
private $translator;

public function __construct(Translator $translator)
{
$this->translator = $translator;
}

public function trans(string $id, array $parameters = [], ?string $domain = null, ?string $locale = null): string
{
return $this->translator->trans($id, $parameters, $domain, $locale);
}

public function getLocale(): string
{
return $this->translator->getLocale();
}
}
12 changes: 12 additions & 0 deletions tests/fixtures/ModulesAutoupgradeAdmin.fr.xlf
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
<?xml version="1.0" encoding="UTF-8"?>
<xliff xmlns="urn:oasis:names:tc:xliff:document:1.2" version="1.2">
<file original="classes/Task/AbstractTask.php" source-language="en" target-language="fr" datatype="plaintext">
<body>
<trans-unit id="435d516735dbf7f622c7d14585f66840" approved="yes">
<source>Action %s skipped</source>
<target state="final">L'action %s a été ignorée</target>
<note>Line: 143</note>
</trans-unit>
</body>
</file>
</xliff>
2 changes: 1 addition & 1 deletion tests/unit/UpgradeContainer/FilesystemAdapterTest.php
Original file line number Diff line number Diff line change
Expand Up @@ -286,7 +286,7 @@ public function testTempFolderIsNotAPrestashopReleaseAfterChanges()

protected function fillFolderWithPsAssets($folder)
{
mkdir($folder);
mkdir($folder, 0777, true);
mkdir($folder . DIRECTORY_SEPARATOR . 'classes');
mkdir($folder . DIRECTORY_SEPARATOR . 'config');
touch($folder . DIRECTORY_SEPARATOR . 'config' . DIRECTORY_SEPARATOR . 'defines.inc.php');
Expand Down
26 changes: 20 additions & 6 deletions tests/unit/UpgradeTools/Translator/TranslatorTest.php
Original file line number Diff line number Diff line change
Expand Up @@ -31,20 +31,34 @@
*/
class TranslatorTest extends TestCase
{
protected $translator;

protected function setUp()
public function testTranslationInFrench()
{
parent::setUp();
$this->translator = new Translator();
$translator = new Translator(
__DIR__ . '/../../../fixtures/',
'fr'
);

$source = 'Action %s skipped';
$parameters = ['Wololo'];

$expected = 'L\'action Wololo a été ignorée';

$this->assertSame(
$expected,
$translator->trans($source, $parameters)
);
}

/**
* @dataProvider translationsTestCaseProvider
*/
public function testTranslationWithoutParams($origin, $parameters, $expected)
{
$this->assertSame($expected, $this->translator->applyParameters($origin, $parameters));
$translator = new Translator(
__DIR__ . '/../../../../translations/',
'en'
);
$this->assertSame($expected, $translator->applyParameters($origin, $parameters));
}

public function translationsTestCaseProvider()
Expand Down

0 comments on commit 2bfaed0

Please sign in to comment.