module TranslationCenter # Return the default translator by building and returning the translator object def self.prepare_translator translator = TranslationCenter::CONFIG['translator_type'].camelize.constantize.where(TranslationCenter::CONFIG['identifier_type'] => TranslationCenter::CONFIG['yaml_translator_identifier']).first # if translator doesn't exist then create him if translator.blank? translator = TranslationCenter::CONFIG['translator_type'].camelize.constantize.new translator.send "#{TranslationCenter::CONFIG['identifier_type']}=", TranslationCenter::CONFIG['yaml_translator_identifier'] begin translator.save(validate: false) # needed if the user is using confirmable with devise translator.update_attribute(:confirmed_at, Time.now) if translator.attributes.has_key?('confirmed_at') rescue translator = nil end end translator end def self.included(base) base.class_eval do alias_method_chain :translate, :adding if(TranslationCenter::CONFIG['enabled']) end end # wraps a span if inspector option is set to all def wrap_span(translation, translation_key) # put the inspector class if inspector is all and the key doesn't belongs to translation_center if TranslationCenter::CONFIG['inspector'] == 'all' && translation_key.name.to_s.split('.').first != 'translation_center' " #{translation} ".html_safe else translation end end # make sure the complete key is build using the options such as scope and count def prepare_key(key, options) complete_key = key # if a scope is passed in options then build the full key complete_key = options[:scope].present? ? "#{options[:scope].to_s}.#{complete_key}" : complete_key # add the correct count suffix if options[:count].present? && options[:count] == 1 complete_key = "#{complete_key}.one" elsif options[:count].present? && options[:count] != 1 complete_key = "#{complete_key}.other" end complete_key end def translate_with_adding(locale, key, options = {}) # handle calling translation with a blank key # or translation center tables don't exist return translate_without_adding(locale, key, options) if key.blank? || !ActiveRecord::Base.connection.table_exists?('translation_center_translation_keys') complete_key = prepare_key(key, options) # prepare complete key # add the new key or update it translation_key = TranslationCenter::TranslationKey.find_or_create_by(name: complete_key) # UNCOMMENT THIS LATER TO SET LAST ACCESSED AT # translation_key.update_attribute(:last_accessed, Time.now) # save the default value (Which is the titleized key name as the translation) if the option is enabled and no translation exists for that key in the db translation_key.create_default_translation if TranslationCenter::CONFIG['save_default_translation'] && translation_key.translations.in(:en).empty? && !translation_key.has_children? # if i18n_source is set to db and not overriden by options then fetch from db if TranslationCenter::CONFIG['i18n_source'] == 'db' && options.delete(:yaml).blank? val = translation_key.accepted_translation_in(locale).try(:value) || options[:default] # replace variables in a translation with passed values options.each_pair{ |key, value| val.gsub!("%{#{key.to_s}}", value.to_s) } if val.is_a?(String) if val.blank? && !translation_key.has_children? # if the key has no translation show the key last identifier to modify throw(:exception, I18n::MissingTranslation.new(locale, complete_key, options)) #translation_value = key.split('.').last #return wrap_span(translation_value, translation_key) elsif translation_key.has_children? # TODO should use ancestors for keys #return translation_key.children_translations(locale) return wrap_span(translation_key.children_translations(locale), translation_key) end wrap_span(val, translation_key) else translation_value = translate_without_adding(locale, key, options) translation_value.class == Hash ? translation_value : wrap_span(translation_value, translation_key) end end # load tha translation config if FileTest.exists?("config/translation_center.yml") TranslationCenter::CONFIG = YAML.load_file("config/translation_center.yml")[Rails.env] # identifier is by default email TranslationCenter::CONFIG['identifier_type'] ||= 'email' TranslationCenter::CONFIG['translator_type'] ||= 'User' else puts "WARNING: translation_center will be using default options if config/translation_center.yml doesn't exists" TranslationCenter::CONFIG = {'enabled' => false, 'inspector' => 'missing', 'lang' => {'en' => {'name' => 'English', 'direction' => 'ltr'}}, 'yaml_translator_identifier' => 'coder@tc.com', 'i18n_source' => 'yaml', 'yaml2db_translations_accepted' => true, 'accept_admin_translations' => true, 'save_default_translation' => true, 'identifier_type' => 'email', 'translator_type' => 'User' } end I18n.available_locales = TranslationCenter::CONFIG['lang'].keys end # override html_message to add a class to the returned span module I18n class MissingTranslation module Base # added another class to be used def html_message category = keys.first key = keys.last.to_s.gsub('_', ' ').gsub(/\b('?[a-z])/) { $1.capitalize } translation_key = keys # remove locale translation_key.shift translation_key = TranslationCenter::TranslationKey.find_by_name(translation_key.join('.')) # don't put the inspector class if inspector is off or the key belongs to translation_center if TranslationCenter::CONFIG['inspector'] == 'off' || category == 'translation_center' %(#{key}) else %(#{key}) end end end end end I18n::Backend::Base.send :include, TranslationCenter