From 23aed0ac017c9a20bda94c98818d9e8880de7845 Mon Sep 17 00:00:00 2001 From: Milan Zazrivec Date: Wed, 18 Jul 2018 16:28:00 +0200 Subject: [PATCH] locale:po_to_json: add support for including catalogs from js plugins (cherry picked from commit 60bac8255f8fbd95fde2c44356b9b70771b34413) https://bugzilla.redhat.com/show_bug.cgi?id=1592571 --- lib/tasks/locale.rake | 72 ++++++++++++++++++++++++++++++------------- 1 file changed, 51 insertions(+), 21 deletions(-) diff --git a/lib/tasks/locale.rake b/lib/tasks/locale.rake index 5eeb7197e4e..0d51718c8a7 100644 --- a/lib/tasks/locale.rake +++ b/lib/tasks/locale.rake @@ -190,29 +190,59 @@ namespace :locale do desc "Convert PO files from all plugins to JS files" task "po_to_json" => :environment do - require_relative 'gettext_task_override.rb' - require Rails.root.join("lib/vmdb/gettext/domains") - - po_files = {} - Vmdb::Gettext::Domains.paths.each do |path| - files = ::Pathname.glob(::File.join(path, "**", "*.po")) - files.each do |file| - locale = file.dirname.basename.to_s - po_files[locale] ||= [] - po_files[locale].push(file) + begin + require_relative 'gettext_task_override.rb' + require Rails.root.join('lib/manageiq/environment') + require Rails.root.join("lib/vmdb/gettext/domains") + + po_files = {} + Vmdb::Gettext::Domains.paths.each do |path| + files = ::Pathname.glob(::File.join(path, "**", "*.po")) + files.each do |file| + locale = file.dirname.basename.to_s + po_files[locale] ||= [] + po_files[locale].push(file) + end end - end - combined_dir = File.join(Rails.root, "locale/combined") - Dir.mkdir(combined_dir, 0700) - po_files.keys.each do |locale| - dir = File.join(combined_dir, locale) - po = File.join(dir, 'manageiq.po') - Dir.mkdir(dir, 0700) - system "rmsgcat -o #{po} #{po_files[locale].join(' ')}" - end + js_plugins = { + 'ui-components' => { + 'en' => 'https://raw.githubusercontent.com/ManageIQ/ui-components/gaprindashvili/locale/en/ui-components.po', + 'es' => 'https://raw.githubusercontent.com/ManageIQ/ui-components/gaprindashvili/locale/es/ui-components.po', + 'fr' => 'https://raw.githubusercontent.com/ManageIQ/ui-components/gaprindashvili/locale/fr/ui-components.po', + 'ja' => 'https://raw.githubusercontent.com/ManageIQ/ui-components/gaprindashvili/locale/ja/ui-components.po', + 'pt_BR' => 'https://raw.githubusercontent.com/ManageIQ/ui-components/gaprindashvili/locale/pt_BR/ui-components.po', + 'zh_CN' => 'https://raw.githubusercontent.com/ManageIQ/ui-components/gaprindashvili/locale/zh_CN/ui-components.po', + } + } + + plugins_dir = File.join(Rails.root, 'locale/plugins') + Dir.mkdir(plugins_dir, 0700) + js_plugins.each do |plugin, content| + plugin_dir = File.join(plugins_dir, plugin) + Dir.mkdir(plugin_dir) + content.each do |lang, url| + lang_dir = File.join(plugin_dir, lang) + Dir.mkdir(lang_dir) + lang_file = "#{lang_dir}/#{url.split('/')[-1]}" + ManageIQ::Environment.system! "curl -f -o #{lang_file} #{url}" + po_files[lang] ||= [] + po_files[lang].push(Pathname(lang_file)) + end + end + + combined_dir = File.join(Rails.root, "locale/combined") + Dir.mkdir(combined_dir, 0700) + po_files.each_key do |locale| + dir = File.join(combined_dir, locale) + po = File.join(dir, 'manageiq.po') + Dir.mkdir(dir, 0700) + system "rmsgcat -o #{po} #{po_files[locale].join(' ')}" + end - Rake::Task['gettext:po_to_json'].invoke - system "rm -rf #{combined_dir}" + Rake::Task['gettext:po_to_json'].invoke + ensure + system "rm -rf #{combined_dir} #{plugins_dir}" + end end end