diff --git a/CHANGELOG.md b/CHANGELOG.md index 93f397a..3fb4a66 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -3,6 +3,7 @@ ## 2.2.0 under development - New #94: Add `getMessages()` method to `CategorySource` (@xepozz) +- New #95: Add `write()` method to `CategorySource` (@xepozz) ## 2.1.1 November 23, 2022 diff --git a/config/common.php b/config/common.php index 7dabe98..67afddd 100644 --- a/config/common.php +++ b/config/common.php @@ -19,6 +19,7 @@ // return new \Yiisoft\Translator\CategorySource( // $params['yiisoft/translator']['defaultCategory'], // $messageSource, + // $messageSource, // $messageFormatter, // ); // }, diff --git a/src/CategorySource.php b/src/CategorySource.php index 6806d66..341e33f 100644 --- a/src/CategorySource.php +++ b/src/CategorySource.php @@ -17,15 +17,18 @@ final class CategorySource * @param string $name Category name. * @param MessageReaderInterface $reader Message reader to get messages from for this category. * @param MessageFormatterInterface|null $formatter Message formatter to format messages with for this category. + * @param MessageWriterInterface|null $writer Message writer to write messages for this category. */ public function __construct( string $name, private MessageReaderInterface $reader, - private ?MessageFormatterInterface $formatter = null + private ?MessageFormatterInterface $formatter = null, + private ?MessageWriterInterface $writer = null, ) { if (!preg_match('/^[a-z0-9_-]+$/i', $name)) { throw new RuntimeException('Category name is invalid. Only letters and numbers are allowed.'); } + $this->name = $name; } @@ -80,6 +83,38 @@ public function getMessages(string $locale): array return $this->reader->getMessages($this->name, $locale); } + /** + * Writes a set of messages for a specified category and locale. + * + * @psalm-param array> $messages + * + * @param string $locale Locale to write messages for. + * @param array $messages A set of messages to write. The format is the following: + * ```php + * [ + * 'key1' => [ + * 'message' => 'translation1', + * // Extra metadata that writer may use: + * 'comment' => 'Translate carefully!', + * ], + * 'key2' => [ + * 'message' => 'translation2', + * // Extra metadata that writer may use: + * 'comment' => 'Translate carefully!', + * ], + * ] + * ``` + * + * @throws UnwritableCategorySourceException When $write is not configured, or it's impossible to write the messages into the source. + */ + public function write(string $locale, array $messages): void + { + if ($this->writer === null) { + throw new UnwritableCategorySourceException($this->name); + } + $this->writer->write($this->name, $locale, $messages); + } + /** * Format the message given parameters and locale. * diff --git a/src/UnwritableCategorySourceException.php b/src/UnwritableCategorySourceException.php new file mode 100644 index 0000000..3ac8924 --- /dev/null +++ b/src/UnwritableCategorySourceException.php @@ -0,0 +1,20 @@ +createMessageReader(), + $this->createMessageFormatter(), + ); + + $this->expectException(UnwritableCategorySourceException::class); + $this->expectExceptionCode(0); + $this->expectExceptionMessage('The category source "app" does not support writing.'); + $category->write('en', []); + } + + public function testWriterAvailable(): void + { + $category = new CategorySource( + 'app', + $this->createMessageReader(), + $this->createMessageFormatter(), + $this->createMock(MessageWriterInterface::class) + ); + + $category->write('en', []); + $this->expectNotToPerformAssertions(); + } + public function dataWithoutFormatter(): array { return [