<% require './lib/i18n_tasks/js_erb_locale_matcher.rb' %> <% require './lib/i18n_tasks/slim_row_locale_matcher.rb' %> # i18n_tasks finds and manages missing and unused translations: https://github.com/glebm/i18n-tasks # The "main" locale. base_locale: en ## All available locales are inferred from the data by default. Alternatively, specify them explicitly: # locales: [es, fr] ## Reporting locale, default: en. Available: en, ru. # internal_locale: en # Read and write translations. data: ## Translations are read from the file system. Supported format: YAML, JSON. ## Provide a custom adapter: # adapter: I18n::Tasks::Data::FileSystem # Locale files or `Find.find` patterns where translations are read from: read: ## Default: # - config/locales/%{locale}.yml ## More files: # - config/locales/**/*.%{locale}.yml - config/locales/%{locale}/*.yml - config/locales/%{locale}/**/*.yml # Locale files to write new keys to, based on a list of key pattern => file rules. Matched from top to bottom: # `i18n_tasks normalize -p` will force move the keys according to these rules write: - ['{application,breadcrumbs,locales,navigation,shared,will_paginate,activerecord.errors}.*', 'config/locales/%{locale}/meta/\1.yml'] - ['activerecord.:.{admin,code_ocean}.{:}.*', 'config/locales/%{locale}/\1/\2.yml'] - ['*.{*:}/:.*', 'config/locales/%{locale}/\1.yml'] - ['activerecord.:.{*:}s?.*', 'config/locales/%{locale}/\1.yml'] - ['{admin,code_ocean,linter,mailers}.{:}.*', 'config/locales/%{locale}/\1/\2.yml'] - ['{*:}s?.*', 'config/locales/%{locale}/\1.yml'] ## Catch-all default: # - config/locales/%{locale}/unsorted.yml # External locale data (e.g. gems). # This data is not considered unused and is never written to. external: ## Example (replace %#= with %=): # - "<%#= %x[bundle info vagrant --path].chomp %>/templates/locales/%{locale}.yml" ## Specify the router (see Readme for details). Valid values: conservative_router, pattern_router, or a custom class. # router: conservative_router yaml: write: # do not wrap lines at 80 characters line_width: -1 ## Pretty-print JSON: # json: # write: # indent: ' ' # space: ' ' # object_nl: "\n" # array_nl: "\n" # Find translate calls search: ## Paths or `Find.find` patterns to search in: paths: - app/ - spec/ - app/assets/javascripts/ ## Root directories for relative keys resolution. # relative_roots: # - app/controllers # - app/helpers # - app/mailers # - app/presenters # - app/views ## Directories where method names which should not be part of a relative key resolution. # By default, if a relative translation is used inside a method, the name of the method will be considered part of the resolved key. # Directories listed here will not consider the name of the method part of the resolved key # # relative_exclude_method_name_paths: # - ## Files or `File.fnmatch` patterns to exclude from search. Some files are always excluded regardless of this setting: ## *.jpg *.jpeg *.png *.gif *.svg *.ico *.eot *.otf *.ttf *.woff *.woff2 *.pdf *.css *.sass *.scss *.less ## *.yml *.json *.zip *.tar.gz *.swf *.flv *.mp3 *.wav *.flac *.webm *.mp4 *.ogg *.opus *.webp *.map *.xlsx exclude: - app/assets/images - app/assets/fonts - app/assets/videos - app/assets/builds - spec/fixtures ## Alternatively, the only files or `File.fnmatch patterns` to search in `paths`: ## If specified, this settings takes priority over `exclude`, but `exclude` still applies. # only: ["*.rb", "*.html.slim"] ## If `strict` is `false`, guess usages such as t("categories.#{category}.title"). The default is `true`. # strict: true ## Allows adding ast_matchers for finding translations using the AST-scanners ## The available matchers are: ## - RailsModelMatcher ## Matches ActiveRecord translations like ## User.human_attribute_name(:email) and User.model_name.human ## ## To implement your own, please see `I18n::Tasks::Scanners::AstMatchers::BaseMatcher`. # <%# I18n::Tasks.add_ast_matcher('I18n::Tasks::Scanners::AstMatchers::RailsModelMatcher') %> ## Multiple scanners can be used. Their results are merged. ## The options specified above are passed down to each scanner. Per-scanner options can be specified as well. ## See this example of a custom scanner: https://github.com/glebm/i18n-tasks/wiki/A-custom-scanner-example ## Translation Services # translation: # # Google Translate # # Get an API key and set billing info at https://code.google.com/apis/console to use Google Translate # google_translate_api_key: "AbC-dEf5" # # DeepL Pro Translate # # Get an API key and subscription at https://www.deepl.com/pro to use DeepL Pro # deepl_api_key: "48E92789-57A3-466A-9959-1A1A1A1A1A1A" # # deepl_host: "https://api.deepl.com" # # deepl_version: "v2" # # add additional options to the DeepL.translate call: https://www.deepl.com/docs-api/translate-text/translate-text/ # deepl_options: # formality: prefer_less ## Do not consider these keys missing: ignore_missing: - 'linter.*' ## Consider these keys used: ignore_unused: - 'activerecord.{attributes,errors,models}.*' - 'linter.*' - 'will_paginate.*' ## Exclude these keys from the `i18n_tasks eq-base' report: # ignore_eq_base: # all: # - common.ok # fr,es: # - common.brand ## Exclude these keys from the `i18n_tasks check-consistent-interpolations` report: ignore_inconsistent_interpolations: - 'shared.errors_one' - 'shared.errors_other' ## Ignore these keys completely: # ignore: ## Sometimes, it isn't possible for i18n_tasks to match the key correctly, ## e.g. in case of a relative key defined in a helper method. ## In these cases you can use the built-in PatternMapper to map patterns to keys, e.g.: # # <%# I18n::Tasks.add_scanner 'I18n::Tasks::Scanners::PatternMapper', # only: %w(*.html.haml *.html.slim), # patterns: [['= title\b', '.page_title']] %> # # The PatternMapper can also match key literals via a special %{key} interpolation, e.g.: # # <%# I18n::Tasks.add_scanner 'I18n::Tasks::Scanners::PatternMapper', # patterns: [['\bSpree\.t[( ]\s*%{key}', 'spree.%{key}']] %>