-
Notifications
You must be signed in to change notification settings - Fork 761
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Basic i18n-tasks support with custom parser for Spree.t #640
base: main
Are you sure you want to change the base?
Changes from all commits
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -18,3 +18,4 @@ spec/dummy | |
public/spree | ||
.ruby-version | ||
.ruby-gemset | ||
config/locales/en.yml |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,151 @@ | ||
# 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 `File.find` patterns where translations are read from: | ||
read: | ||
## Default: | ||
# - config/locales/%{locale}.yml | ||
## More files: | ||
# - config/locales/**/*.%{locale}.yml | ||
## Another gem (replace %#= with %=): | ||
# - "<%#= %x[bundle show vagrant].chomp %>/templates/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: | ||
## For example, write devise and simple form keys to their respective files: | ||
# - ['{devise, simple_form}.*', 'config/locales/\1.%{locale}.yml'] | ||
## Catch-all default: | ||
# - config/locales/%{locale}.yml | ||
|
||
## Specify the router (see Readme for details). Valid values: conservative_router, pattern_router, or a custom class. | ||
# router: convervative_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 `File.find` patterns to search in: | ||
paths: | ||
# This currently cannot see into spree.t calls will be easier to support | ||
# in 0.9 | ||
<% spree_path = %x[bundle show spree].chomp %> | ||
- "<%=spree_path%>/core/app" | ||
- "<%=spree_path%>/frontend/app" | ||
- "<%=spree_path%>/backend/app" | ||
- "<%=spree_path%>/cmd/app" | ||
- "<%=spree_path%>/api/app" | ||
- "<%=spree_path%>/core/lib" | ||
- "<%=spree_path%>/frontend/lib" | ||
- "<%=spree_path%>/backend/lib" | ||
- "<%=spree_path%>/cmd/lib" | ||
- "<%=spree_path%>/api/lib" | ||
|
||
## Root directories for relative keys resolution. | ||
relative_roots: | ||
- app | ||
|
||
## Files or `File.fnmatch` patterns to exclude from search. Some files are always excluded regardless of this setting: | ||
## %w(*.jpg *.png *.gif *.svg *.ico *.eot *.otf *.ttf *.woff *.woff2 *.pdf *.css *.sass *.scss *.less *.yml *.json) | ||
exclude: | ||
- app/assets/images | ||
- app/assets/fonts | ||
|
||
## Alternatively, the only files or `File.fnmatch patterns` to search in `paths`: | ||
## If specified, this settings takes priority over `exclude`, but `exclude` still applies. | ||
# include: ["*.rb", "*.html.slim"] | ||
|
||
## Default scanner finds t() and I18n.t() calls. | ||
# scanner: I18nTasks::Scanners::SpreeTScanner | ||
|
||
## Google Translate | ||
# translation: | ||
# # Get an API key and set billing info at https://code.google.com/apis/console to use Google Translate | ||
# api_key: "AbC-dEf5" | ||
|
||
## Do not consider these keys missing: | ||
# ignore_missing: | ||
# - 'errors.messages.{accepted,blank,invalid,too_short,too_long}' | ||
# - '{devise,simple_form}.*' | ||
|
||
## Consider these keys used: | ||
# ignore_unused: | ||
# - 'activerecord.attributes.*' | ||
# - '{devise,kaminari,will_paginate}.*' | ||
# - 'simple_form.{yes,no}' | ||
# - 'simple_form.{placeholders,hints,labels}.*' | ||
# - 'simple_form.{error_notification,required}.:' | ||
|
||
## Exclude these keys from the `i18n-tasks eq-base' report: | ||
# ignore_eq_base: | ||
# all: | ||
# - common.ok | ||
# fr,es: | ||
# - common.brand | ||
|
||
## Ignore these keys completely: | ||
# ignore: | ||
# - kaminari.* | ||
|
||
# Hackity Hack | ||
# See https://github.com/glebm/i18n-tasks/issues/170 | ||
<% module AddMissingNil | ||
include ::I18n::Tasks::Command::Collection | ||
cmd :add_missing_nil, | ||
desc: 'Add missing keys with nil values', | ||
pos: '[locale ...]', | ||
args: [:locales] | ||
def add_missing_nil(opt = {}) | ||
add_missing opt.merge(value: nil) | ||
end | ||
end | ||
I18n::Tasks::Commands.send :include, AddMissingNil | ||
|
||
%> | ||
|
||
# Add in spree custom scanner in 0.9 | ||
<% | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Why is this inlined here? There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. As i18n_tasks runs outside the scope of the parent application. We could add a require but it would still need to be inlined. Basically that's what the i18n-tasks creator recommended. See glebm/i18n-tasks#170 There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. i18n-tasks add-missing supports a |
||
require './lib/i18n/spree_t_scanner.rb' | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
|
||
I18n::Tasks::Configuration::DEFAULTS[:search][:scanners] = [ | ||
[ | ||
'I18n::Scanners::SpreeTScanner', | ||
{ ignore_lines: { 'opal' => '^\\s*#(?!\\si18n-tasks-use)', | ||
'haml' => '^\\s*-\\s*#(?!\\si18n-tasks-use)', | ||
'slim' => '^\\s*(?:-#|/)(?!\\si18n-tasks-use)', | ||
'coffee' => '^\\s*#(?!\\si18n-tasks-use)', | ||
'erb' => '^\\s*<%\\s*#(?!\\si18n-tasks-use)' } | ||
} | ||
] | ||
|
||
] | ||
# Scope this down, so we don't hit Spree.t twice | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Not neccesary since v0.9.1. So you can have both by removing this and adding this to spree_t_scanner.rb instead: I18n::Tasks.add_scanner 'I18n::Scanners::SpreeTScanner',
ignore_lines: {'opal' => %q(^\s*#(?!\si18n-tasks-use)),
'haml' => %q(^\s*-\s*#(?!\si18n-tasks-use)),
'slim' => %q(^\s*(?:-#|/)(?!\si18n-tasks-use)),
'coffee' => %q(^\s*#(?!\si18n-tasks-use)),
'erb' => %q(^\s*<%\s*#(?!\si18n-tasks-use))} |
||
# if someone is better at regex, it's possible we can have both of these. | ||
# I18n::Tasks::Scanners::PatternScanner.class_eval do | ||
# def translate_call_re | ||
# /(?<=^|[^\w'\-])(?!Spree)t(?:ranslate)?/ | ||
# end | ||
# end | ||
%> |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
i18n-tasks add-missing --nil-value
.