git subrepo commit mailcow/src/mailcow-dockerized
subrepo: subdir: "mailcow/src/mailcow-dockerized"
merged: "308860af"
upstream: origin: "https://github.com/mailcow/mailcow-dockerized.git"
branch: "master"
commit: "3f1a5af8"
git-subrepo: version: "0.4.5"
origin: "???"
commit: "???"
Change-Id: I5d51c14b45db54fe706be40a591ddbfcea50d4b0
diff --git a/mailcow/src/mailcow-dockerized/data/web/inc/lib/vendor/symfony/translation/Command/TranslationPushCommand.php b/mailcow/src/mailcow-dockerized/data/web/inc/lib/vendor/symfony/translation/Command/TranslationPushCommand.php
index b28d3e1..dba2164 100644
--- a/mailcow/src/mailcow-dockerized/data/web/inc/lib/vendor/symfony/translation/Command/TranslationPushCommand.php
+++ b/mailcow/src/mailcow-dockerized/data/web/inc/lib/vendor/symfony/translation/Command/TranslationPushCommand.php
@@ -11,7 +11,10 @@
namespace Symfony\Component\Translation\Command;
+use Symfony\Component\Console\Attribute\AsCommand;
use Symfony\Component\Console\Command\Command;
+use Symfony\Component\Console\Completion\CompletionInput;
+use Symfony\Component\Console\Completion\CompletionSuggestions;
use Symfony\Component\Console\Exception\InvalidArgumentException;
use Symfony\Component\Console\Input\InputArgument;
use Symfony\Component\Console\Input\InputInterface;
@@ -24,20 +27,16 @@
/**
* @author Mathieu Santostefano <msantostefano@protonmail.com>
- *
- * @experimental in 5.3
*/
+#[AsCommand(name: 'translation:push', description: 'Push translations to a given provider.')]
final class TranslationPushCommand extends Command
{
use TranslationTrait;
- protected static $defaultName = 'translation:push';
- protected static $defaultDescription = 'Push translations to a given provider.';
-
private $providers;
private $reader;
- private $transPaths;
- private $enabledLocales;
+ private array $transPaths;
+ private array $enabledLocales;
public function __construct(TranslationProviderCollection $providers, TranslationReaderInterface $reader, array $transPaths = [], array $enabledLocales = [])
{
@@ -49,6 +48,30 @@
parent::__construct();
}
+ public function complete(CompletionInput $input, CompletionSuggestions $suggestions): void
+ {
+ if ($input->mustSuggestArgumentValuesFor('provider')) {
+ $suggestions->suggestValues($this->providers->keys());
+
+ return;
+ }
+
+ if ($input->mustSuggestOptionValuesFor('domains')) {
+ $provider = $this->providers->get($input->getArgument('provider'));
+
+ if ($provider && method_exists($provider, 'getDomains')) {
+ $domains = $provider->getDomains();
+ $suggestions->suggestValues($domains);
+ }
+
+ return;
+ }
+
+ if ($input->mustSuggestOptionValuesFor('locales')) {
+ $suggestions->suggestValues($this->enabledLocales);
+ }
+ }
+
/**
* {@inheritdoc}
*/
@@ -79,7 +102,7 @@
Full example:
- <info>php %command.full_name% provider --force --delete-missing --domains=messages,validators --locales=en</>
+ <info>php %command.full_name% provider --force --delete-missing --domains=messages --domains=validators --locales=en</>
This command pushes all translations associated with the <comment>messages</> and <comment>validators</> domains for the <comment>en</> locale.
Provider translations for the specified domains and locale are deleted if they're not present locally and overwritten if it's the case.