Refactor some of i18n for better codeclimate scores. In the process, make nested i18n files work like rails
This commit is contained in:
parent
86cd626084
commit
31f238f881
9 changed files with 109 additions and 69 deletions
|
@ -228,3 +228,17 @@ Feature: i18n Preview
|
||||||
Then I should see "Current locale: en"
|
Then I should see "Current locale: en"
|
||||||
Then I should see "Buenos días"
|
Then I should see "Buenos días"
|
||||||
Then I should see "Howdy"
|
Then I should see "Howdy"
|
||||||
|
|
||||||
|
Scenario: Nested i18n yaml
|
||||||
|
Given a fixture app "i18n-nested-app"
|
||||||
|
And a file named "config.rb" with:
|
||||||
|
"""
|
||||||
|
activate :i18n
|
||||||
|
"""
|
||||||
|
Given the Server is running at "i18n-nested-app"
|
||||||
|
When I go to "/"
|
||||||
|
Then I should see "Howdy"
|
||||||
|
Then I should see "More"
|
||||||
|
When I go to "/es/"
|
||||||
|
Then I should see "Como Esta?"
|
||||||
|
Then I should see "Mucho"
|
4
middleman-core/fixtures/i18n-nested-app/locales/en.yml
Normal file
4
middleman-core/fixtures/i18n-nested-app/locales/en.yml
Normal file
|
@ -0,0 +1,4 @@
|
||||||
|
---
|
||||||
|
en:
|
||||||
|
greetings: "Howdy"
|
||||||
|
hi: "Hello"
|
|
@ -0,0 +1,3 @@
|
||||||
|
---
|
||||||
|
en:
|
||||||
|
more: "More"
|
4
middleman-core/fixtures/i18n-nested-app/locales/es.yml
Normal file
4
middleman-core/fixtures/i18n-nested-app/locales/es.yml
Normal file
|
@ -0,0 +1,4 @@
|
||||||
|
---
|
||||||
|
es:
|
||||||
|
greetings: "Como Esta?"
|
||||||
|
hi: "Hola"
|
|
@ -0,0 +1,3 @@
|
||||||
|
---
|
||||||
|
es:
|
||||||
|
more: "Mucho"
|
|
@ -0,0 +1,3 @@
|
||||||
|
<%= t(:greetings) %>
|
||||||
|
|
||||||
|
<%= t(:more) %>
|
|
@ -37,24 +37,11 @@ module Middleman
|
||||||
cattr_accessor :middleman_app
|
cattr_accessor :middleman_app
|
||||||
|
|
||||||
def image(link, title, alt_text)
|
def image(link, title, alt_text)
|
||||||
if middleman_app && middleman_app.respond_to?(:image_tag)
|
|
||||||
middleman_app.image_tag(link, :title => title, :alt => alt_text)
|
middleman_app.image_tag(link, :title => title, :alt => alt_text)
|
||||||
else
|
|
||||||
img = "<img src=\"#{link}\""
|
|
||||||
img << " title=\"#{title}\"" if title
|
|
||||||
img << " alt=\"#{alt_text}\"" if alt_text
|
|
||||||
img << ">"
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
|
|
||||||
def link(link, title, content)
|
def link(link, title, content)
|
||||||
if middleman_app && middleman_app.respond_to?(:link_to)
|
|
||||||
middleman_app.link_to(content, link, :title => title)
|
middleman_app.link_to(content, link, :title => title)
|
||||||
else
|
|
||||||
a = "<a href=\"#{link}\""
|
|
||||||
a << " title=\"#{title}\"" if title
|
|
||||||
a << ">#{content}</a>"
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
module Middleman
|
module Middleman
|
||||||
# Current Version
|
# Current Version
|
||||||
# @return [String]
|
# @return [String]
|
||||||
VERSION = '3.1.0.rc.1' unless const_defined?(:VERSION)
|
VERSION = '3.1.0.rc.2' unless const_defined?(:VERSION)
|
||||||
end
|
end
|
||||||
|
|
|
@ -22,24 +22,15 @@ class Middleman::CoreExtensions::Internationalization < ::Middleman::Extension
|
||||||
end
|
end
|
||||||
|
|
||||||
def after_configuration
|
def after_configuration
|
||||||
@locales_glob = File.join(app.config[:locals_dir] || options[:data], "**", "*.{rb,yml,yaml}")
|
app.files.reload_path(app.config[:locals_dir] || options[:data])
|
||||||
|
|
||||||
# File.fnmatch doesn't support brackets: {rb,yml,yaml}
|
@locales_glob = File.join(app.config[:locals_dir] || options[:data], "**", "*.{rb,yml,yaml}")
|
||||||
regex = @locales_glob.sub(/\./, '\.').sub(File.join("**", "*"), ".*").sub(/\//, '\/').sub("{rb,yml,yaml}", "rb|ya?ml")
|
@locales_regex = convert_glob_to_regex(@locales_glob)
|
||||||
@locales_regex = %r{^#{regex}}
|
|
||||||
|
|
||||||
@maps = {}
|
@maps = {}
|
||||||
|
|
||||||
::I18n.load_path += Dir[File.join(app.root, @locales_glob)]
|
|
||||||
::I18n.reload!
|
|
||||||
|
|
||||||
@mount_at_root = options[:mount_at_root].nil? ? langs.first : options[:mount_at_root]
|
@mount_at_root = options[:mount_at_root].nil? ? langs.first : options[:mount_at_root]
|
||||||
|
|
||||||
::I18n.default_locale = @mount_at_root
|
configure_i18n
|
||||||
# Reset fallbacks to fall back to our new default
|
|
||||||
if ::I18n.respond_to? :fallbacks
|
|
||||||
::I18n.fallbacks = ::I18n::Locale::Fallbacks.new
|
|
||||||
end
|
|
||||||
|
|
||||||
if !app.build?
|
if !app.build?
|
||||||
logger.info "== Locales: #{langs.join(", ")} (Default #{@mount_at_root})"
|
logger.info "== Locales: #{langs.join(", ")} (Default #{@mount_at_root})"
|
||||||
|
@ -48,27 +39,7 @@ class Middleman::CoreExtensions::Internationalization < ::Middleman::Extension
|
||||||
# Don't output localizable files
|
# Don't output localizable files
|
||||||
app.ignore File.join(options[:templates_dir], "**")
|
app.ignore File.join(options[:templates_dir], "**")
|
||||||
|
|
||||||
app.sitemap.provides_metadata_for_path do |url|
|
app.sitemap.provides_metadata_for_path(&method(:metadata_for_path))
|
||||||
if d = get_localization_data(url)
|
|
||||||
lang, page_id = d
|
|
||||||
else
|
|
||||||
# Default to the @mount_at_root lang
|
|
||||||
page_id = nil
|
|
||||||
lang = @mount_at_root
|
|
||||||
end
|
|
||||||
|
|
||||||
instance_vars = Proc.new do
|
|
||||||
@lang = lang
|
|
||||||
@page_id = page_id
|
|
||||||
end
|
|
||||||
|
|
||||||
locals = { :lang => lang,
|
|
||||||
:page_id => page_id }
|
|
||||||
{ :blocks => [instance_vars],
|
|
||||||
:locals => locals,
|
|
||||||
:options => { :lang => lang } }
|
|
||||||
end
|
|
||||||
|
|
||||||
app.files.changed(&method(:on_file_changed))
|
app.files.changed(&method(:on_file_changed))
|
||||||
app.files.deleted(&method(:on_file_changed))
|
app.files.deleted(&method(:on_file_changed))
|
||||||
end
|
end
|
||||||
|
@ -81,25 +52,8 @@ class Middleman::CoreExtensions::Internationalization < ::Middleman::Extension
|
||||||
|
|
||||||
delegate :logger, :to => :app
|
delegate :logger, :to => :app
|
||||||
|
|
||||||
def on_file_changed(file)
|
|
||||||
if @locales_regex =~ file
|
|
||||||
::I18n.reload!
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
def langs
|
def langs
|
||||||
if options[:langs]
|
@_langs ||= get_known_languages
|
||||||
Array(options[:langs]).map(&:to_sym)
|
|
||||||
else
|
|
||||||
Dir[File.join(app.root, @locales_glob)].map { |file|
|
|
||||||
File.basename(file).sub(/\.ya?ml$/, "").sub(/\.rb$/, "")
|
|
||||||
}.sort.map(&:to_sym)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
def get_localization_data(path)
|
|
||||||
@_localization_data ||= {}
|
|
||||||
@_localization_data[path]
|
|
||||||
end
|
end
|
||||||
|
|
||||||
# Update the main sitemap resource list
|
# Update the main sitemap resource list
|
||||||
|
@ -129,6 +83,74 @@ class Middleman::CoreExtensions::Internationalization < ::Middleman::Extension
|
||||||
|
|
||||||
private
|
private
|
||||||
|
|
||||||
|
|
||||||
|
def on_file_changed(file)
|
||||||
|
if @locales_regex =~ file
|
||||||
|
@_langs = nil # Clear langs cache
|
||||||
|
::I18n.reload!
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
def convert_glob_to_regex(glob)
|
||||||
|
# File.fnmatch doesn't support brackets: {rb,yml,yaml}
|
||||||
|
regex = @locales_glob.sub(/\./, '\.').sub(File.join("**", "*"), ".*").sub(/\//, '\/').sub("{rb,yml,yaml}", "rb|ya?ml")
|
||||||
|
%r{^#{regex}}
|
||||||
|
end
|
||||||
|
|
||||||
|
def configure_i18n
|
||||||
|
::I18n.load_path += Dir[File.join(app.root, @locales_glob)]
|
||||||
|
::I18n.reload!
|
||||||
|
|
||||||
|
::I18n.default_locale = @mount_at_root
|
||||||
|
# Reset fallbacks to fall back to our new default
|
||||||
|
if ::I18n.respond_to? :fallbacks
|
||||||
|
::I18n.fallbacks = ::I18n::Locale::Fallbacks.new
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
def metadata_for_path(url)
|
||||||
|
if d = get_localization_data(url)
|
||||||
|
lang, page_id = d
|
||||||
|
else
|
||||||
|
# Default to the @mount_at_root lang
|
||||||
|
page_id = nil
|
||||||
|
lang = @mount_at_root
|
||||||
|
end
|
||||||
|
|
||||||
|
instance_vars = Proc.new do
|
||||||
|
@lang = lang
|
||||||
|
@page_id = page_id
|
||||||
|
end
|
||||||
|
|
||||||
|
locals = {
|
||||||
|
:lang => lang,
|
||||||
|
:page_id => page_id
|
||||||
|
}
|
||||||
|
|
||||||
|
{
|
||||||
|
:blocks => [instance_vars],
|
||||||
|
:locals => locals,
|
||||||
|
:options => { :lang => lang }
|
||||||
|
}
|
||||||
|
end
|
||||||
|
|
||||||
|
def get_known_languages
|
||||||
|
if options[:langs]
|
||||||
|
Array(options[:langs]).map(&:to_sym)
|
||||||
|
else
|
||||||
|
known_langs = app.files.known_paths.select do |p|
|
||||||
|
p.to_s.match(@locales_regex) && (p.to_s.split(File::SEPARATOR).length === 2)
|
||||||
|
end.map { |p|
|
||||||
|
File.basename(p.to_s).sub(/\.ya?ml$/, "").sub(/\.rb$/, "")
|
||||||
|
}.sort.map(&:to_sym)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
def get_localization_data(path)
|
||||||
|
@_localization_data ||= {}
|
||||||
|
@_localization_data[path]
|
||||||
|
end
|
||||||
|
|
||||||
# Parse locale extension filename
|
# Parse locale extension filename
|
||||||
# @return [lang, path, basename]
|
# @return [lang, path, basename]
|
||||||
# will return +nil+ if no locale extension
|
# will return +nil+ if no locale extension
|
||||||
|
|
Loading…
Reference in a new issue