定制 wickedone/phrase-translation-provider 二次开发

按需修改功能、优化性能、对接业务系统,提供一站式技术支持

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

wickedone/phrase-translation-provider

最新稳定版本:3.0.0

Composer 安装命令:

composer require wickedone/phrase-translation-provider

包简介

symfony phrase translation provider bridge

README 文档

README

symfony phrase translation provider bridge

infection codecov stable downloads license php

⚠️ this translation provider has been integrated into symfony starting at version 6.4. this repository will be archived once lts expires for symfony 5.4

installation

composer require wickedone/phrase-translation-provider

dsn example

PHRASE_DSN=phrase://PROJECT_ID:API_TOKEN@default?userAgent=myProject

dsn elements

  • PROJECT_ID: can be retrieved in phrase from project settings > API > Project ID
  • API_TOKEN: can be created in your phrase profile settings
  • default: endpoint, defaults to api.phrase.com

required dsn query parameters

  • userAgent: please read this for some examples.

see fine tuning your phrase api calls for additional dsn options

service phrase provider

in your services.yaml add the following to enable the phrase provider.

Symfony\Component\Translation\Bridge\Phrase\PhraseProviderFactory:
    tags: ['translation.provider_factory']
    arguments:
        $defaultLocale: '%kernel.default_locale%'
        $loader: '@translation.loader.xliff'
        $xliffFileDumper: '@translation.dumper.xliff'
        $cache: '@cache.app'

and in your translations.yaml you can add:

framework:
    translator:
        providers:
            phrase:
                dsn: '%env(PHRASE_DSN)%'
                domains: ~
                locales: ~

phrase locale names

translations being imported using the symfony xlf format in phrase, locales are matched on locale name in phrase. therefor it's necessary the locale names should be as defined in RFC4646 (e.g. pt-BR rather than pt_BR). not doing so will result in phrase creating a new locale for the imported keys.

locale creation

if you define a locale in your translation.yaml which is not configured in your phrase project, it will be automatically created. deletion of locales however, is (currently) not managed by this provider.

domains as tags

translations will be tagged in phrase with the symfony translation domain they belong to. check the wickedone/phrase-tag-bundle if you need help managing your tags in phrase

cache

the read responses from phrase are cached to speed up the read and delete method of this provider. therefor the factory should be initialised with a PSR-6 compatible cache adapter.

events

to enable you to perform post-processing on translation values and / or keys, two events are dispatched by this provider class.

PhraseReadEvent

after reading the catalogue from phrase, the resulting TranslatorBag is dispatched in a PhraseReadEvent prior to being returned from the read method.

PhraseWriteEvent

before writing the catalogue to phrase, the TranslatorBag is dispatched in a PhraseWriteEvent.

fine tuning your phrase api calls

you can fine tune the read and write methods of this provider by adding query parameters to your dsn configuration. general usage is read|write[option_name]=value

example: phrase://PROJECT_ID:API_TOKEN@default?read[encoding]=UTF-8&write[update_descriptions]=0

see tables below for available options and, if applicable, their default values.

read

in order to read translations from phrase the download locale call is made to the phrase api. this call provides the following options.

name type default value comment
branch string
include_empty_translations bool 1
exclude_empty_zero_forms bool
include_translated_keys bool
keep_notranslate_tags bool
format_options array enclose_in_cdata
encoding string
skip_unverified_translations bool
include_unverified_translations bool
use_last_reviewed_version bool
fallback_locale_enabled bool 0 when the fallback locale is enabled, caching responses from phrase will be disabled

write

in order to write translations to phrase the upload call is made to the phrase api. this call provides the following options.

name type default value comment
update_translations bool 1
update_descriptions bool
skip_upload_tags bool
skip_unverification bool
file_encoding string
locale_mapping array
format_options array
autotranslate bool
mark_reviewed bool

统计信息

  • 总下载量: 3.44k
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 2
  • 点击次数: 1
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 2
  • Watchers: 1
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2022-12-28

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固