The plugin should automatically configure itself for project with dependencies on vue-i18n
and nuxt-i18n
, but adjustments could be needed for custom setup.
i18n Ally is applying inspections for files that have .vue
extension and are included into
a PhpStorm’s scope.
Create a new scope or adjust existing by clicking on …
button and handpicking only the meaningful directories and files.
Select Project files
to include all .vue
files in your project.
Extraction of strings with a special treatment of inline tags is not currently supported.
Translatable attributes are also checked for the translatable text:
You can add custom attributes, like data-content
, by appending a new attribute to the comma-separated list.
The “Replacement template” reflects the result of the hardcoded string extraction.function name and arguments template.
Recommended value for vue-i18n
and nuxt-i18n
packages: $t('%key%', %map%)
.
%key%
Short key or a natural language string that defines a translation.
%namespace%
Namespace (called ‘domain’ in Symfony) usually means a part of language file path from where translations would be searched for. The default
namespace is usually messages
, but could be changed by putting a namespace in first position in “Namespaces” field.
%map%
If there are no variables in the string, then nothing would be added.
Map will be replaced with an object if there are any placeholders detected:
$t('key', {foo: fooVariable, bar: barVariable})
.
Placeholder names will be determined automatically based on a respective variable, function or method name.
In language files placeholder syntax will be determined based on the Placeholder format setting of the language file.
%list%
If there are no variables in the string, then nothing would be added.
List will be replaced with an array if there are any placeholders detected:
$t('key', [fooVariable, barVariable])
.
In language files the ordered placeholder syntax {0}, {1}
will be enforced.
%varargs%
If there are no variables in the string, then nothing would be added.
Varargs will be replaced with placeholder passed directly to the translation function if there are any placeholders detected:
$t('key', fooVariable, barVariable)
.
In language files the ordered placeholder syntax {0}, {1}
will be enforced.
All strings inside tags and translatable attributes are checked.
{{ someFunc('Hello world!') }}
<i18n>
tag within single-file componentscamelCased
ones.It’s common to have small and simple branching for presentation purposes:
The best practice it to separate this message into two different ones so translators would have a full context and would be able to adjust word order according the target language grammar.
1st step: manually extract the condition out of the message to get two messages without condition
2nd step: replace simple messages with i18n Ally