HOME


Mini Shell 1.0
DIR: /home/dhnidqcz/journal.pragmaticsng.org/lib__47455f6/pkp/classes/i18n/translation/
Upload File :
Current File : //home/dhnidqcz/journal.pragmaticsng.org/lib__47455f6/pkp/classes/i18n/translation/Translator.php
<?php

declare(strict_types=1);

/**
 * @defgroup i18n I18N
 * Implements localization concerns such as locale files, time zones, and country lists.
 */

/**
 * @file classes/i18n/translation/Translator.php
 *
 * Copyright (c) 2014-2021 Simon Fraser University
 * Copyright (c) 2000-2021 John Willinsky
 * Distributed under the GNU GPL v3. For full terms see the file docs/COPYING.
 *
 * @class Translator
 *
 * @ingroup i18n
 *
 * @brief Extends the default GetText translator with serialization and the possibility to detect when translations failed
 */

namespace PKP\i18n\translation;

use Gettext\Translator as GetTextTranslator;
use PKP\core\ExportableTrait;

class Translator extends GetTextTranslator
{
    use ExportableTrait;

    /**
     * Builds a translator instance from arrays
     */
    public static function createFromTranslationsArray(array ...$translations): static
    {
        $translator = new static();
        foreach ($translations as $translationSet) {
            $translator->addTranslations($translationSet);
        }
        return $translator;
    }

    /**
     * Retrieves a singular translation
     */
    public function getSingular(string $original): ?string
    {
        $translation = $this->getTranslation(null, null, $original);
        return $translation[0] ?? null;
    }

    /**
     * Retrieves a plural translation
     */
    public function getPlural(string $original, int $value): ?string
    {
        $translation = $this->getTranslation(null, null, $original);
        $key = $this->getPluralIndex(null, $value, $translation === null);

        return $translation[$key] ?? null;
    }

    /**
     * Retrieves the raw translator data
     */
    public function getEntries(string $context = ''): array
    {
        return $this->dictionary[$this->domain][$context] ?? [];
    }
}