⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 locale.rb

📁 A Hotel Management System based on Ruby on Rails.
💻 RB
字号:
module Globalize

  class NoBaseLanguageError < StandardError; end

=begin rdoc
  Locale defines the currenctly active _locale_. You'll mostly use it like this:
    Locale.set("en-US")

  +en+ is the code for English, and +US+ is the country code. The country code is 
  optional, but you'll need to define it to get a lot of the localization features.
=end   
  class Locale
    attr_reader :language, :country, :code
    attr_accessor :date_format, :currency_format, :currency_code,
      :thousands_sep, :decimal_sep, :currency_decimal_sep,
      :number_grouping_scheme

    @@cache = {}
    @@translator_class = DbViewTranslator
    @@translator = {}
    @@active = nil
    @@base_language = nil
    @@base_language_code = nil
    @@translator = @@translator_class.instance

    # Is there an active locale?
    def self.active?; !@@active.nil? end

    # This is the focal point of the class. Sets the locale in the familiar
    # RFC 3066 format (see: http://www.faqs.org/rfcs/rfc3066.html). It can
    # also take a Locale object. Set it to the +nil+ object, to deactivate 
    # the locale.
    def self.set(locale)
      if locale.kind_of? Locale
        @@active = locale
      elsif locale.nil?
        @@active = nil
      else
        @@active = ( @@cache[locale] ||= Locale.new(locale) )
      end
    end

    # Clears the locale cache -- used mostly for testing.
    def self.clear_cache
      @@cache.clear
    end

    # Returns the active locale.
    def self.active; @@active end

    # Sets the base language. The base language is the language that has
    # complete coverage in the database. For instance, if you have a +Category+
    # model with a +name+ field, the base language is the language in which names
    # are stored in the model itself, and not in the translations table.
    #
    # Takes either a language code (valid RFC 3066 code like +en+ or <tt>en-US</tt>) 
    # or a language object.
    #
    # May be set with a language code in environment.rb, without accessing the db.
    def self.set_base_language(lang)
      if lang.kind_of? Language
        @@base_language = lang
      else
        @@base_language_code = RFC_3066.parse lang
      end
    end

    # Returns the base language. Raises an exception if none is set.
    def self.base_language 
      @@base_language ? @@base_language :
        (@@base_language_code ? 
        (@@base_language = Language.pick(@@base_language_code)) :
        raise(NoBaseLanguageError, "base language must be defined"))
    end

    # Is the currently active language the base language?
    def self.base?
      active ? active.language == base_language : true
    end

    # Returns the currently active language model or +nil+.
    def self.language
      active? ? active.language : nil
    end

    # Returns the currently active language code or +nil+.
    def self.language_code
      active? ? language.code : nil
    end

    # Returns the currently active country model or +nil+.
    def self.country
      active? ? active.country : nil
    end

    # Creates a new locale object by looking up an RFC 3066 code in the database.
    def initialize(code)
      if code.nil?
        return
      end

      rfc = RFC_3066.parse(code)
      @code = rfc.locale

      @language = Language.pick(rfc)
      @country = Country.pick(rfc) 

      setup_fields
    end

    # Sets the translation for +key+.
    #
    # :call-seq:
    #   Locale.set_translation(key, language, *translations) 
    #   Locale.set_translation(key, *translations) 
    #
    # If +language+ is given, define a translation using that language
    # model, otherwise use the active language.
    #
    # Multiple translation strings may be given, in order to define plural forms.
    # In English, there are only two plural forms, singular and plural, so you 
    # would provide two strings at the most. The order is determined by the 
    # formula in the languages database. For English, the order is: singular form,
    # then plural.
    #
    # Example: 
    #   Locale.set_translation("There are %d items in your cart", 
    #   "There is one item in your cart", "There are %d items in your cart")
    def self.set_translation(key, *options)
      key = key.to_s.gsub('_', ' ') if key.kind_of? Symbol
      if options.first.kind_of? Language
        language = options.shift
      else
        language = self.language
      end

      raise ArgumentError, "No translations given" if options.empty?
      translator.set(key, language, *options)
    end

    def self.set_pluralized_translation(key, *options)
      key = key.to_s.gsub('_', ' ') if key.kind_of? Symbol
      if options.first.kind_of? Language
        language = options.shift
      else
        language = self.language
      end

      raise ArgumentError, "No translations given" if options.empty?
      translator.set_pluralized(key, language, *options)
    end
    
    def self.translate(key, default = nil, arg = nil) # :nodoc:
      key = key.to_s.gsub('_', ' ') if key.kind_of? Symbol

      translator.fetch(key, self.language, default, arg)
    end

    # Returns the translator object -- mostly for testing and adjusting the cache.
    def self.translator; @@translator end 

    private

      def setup_fields
        return if !@country

        [:date_format, :currency_format, :currency_code, :thousands_sep, 
          :decimal_sep, :currency_decimal_sep, :number_grouping_scheme
        ].each {|f| instance_variable_set "@#{f}", @country.send(f) }
      end
  end
end

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -