# frozen_string_literal: true module Mobility =begin Stores shared Mobility configuration referenced by all backends. =end class Configuration RESERVED_OPTION_KEYS = %i[backend model_class].freeze # Alias for mobility_accessor (defaults to +translates+) # @return [Symbol] attr_accessor :accessor_method # Name of query scope/dataset method (defaults to +i18n+) # @return [Symbol] attr_accessor :query_method # Default set of options. These will be merged with any backend options # when defining translated attributes (with +translates+). Default options # may not include the keys 'backend' or 'model_class'. # @return [Hash] attr_reader :default_options # @deprecated The default_options= setter has been deprecated. Set each # option on the default_options hash instead. def default_options=(options) warn %{ WARNING: The default_options= setter has been deprecated. Set each option on the default_options hash instead, like this: config.default_options[:fallbacks] = { ... } config.default_options[:dirty] = true } if (keys = options.keys & RESERVED_OPTION_KEYS).present? raise ReservedOptionKey, "Default options may not contain the following reserved keys: #{keys.join(', ')}" else @default_options = options end end # Plugins to apply. Order of plugins is important, as this becomes the # order in which plugins modules are included into the backend class or # attributes instance. # @return [Array] attr_accessor :plugins # Generate new fallbacks instance # @note This method will call the proc defined in the variable set by the # +fallbacks_generator=+ setter, passing the first argument to its `call` # method. By default the generator returns an instance of # +I18n::Locale::Fallbacks+. # @param fallbacks [Hash] Fallbacks hash passed to generator # @return [I18n::Locale::Fallbacks] def new_fallbacks(fallbacks = {}) @fallbacks_generator.call(fallbacks) end # Assign proc which, passed a set of fallbacks, returns a default fallbacks # instance. By default this is a proc which takes fallbacks and returns an # instance of +I18n::Locale::Fallbacks+. # @param [Proc] fallbacks generator attr_writer :fallbacks_generator # @deprecated Use {#new_fallbacks} instead. def default_fallbacks(fallbacks = {}) warn %{ WARNING: The default_fallbacks configuration getter has been renamed new_fallbacks to avoid confusion. The original method default_fallbacks will be removed in the next major version of Mobility. } new_fallbacks(fallbacks) end # @deprecated Use {#fallbacks_generator=} instead. def default_fallbacks=(fallbacks) warn %{ WARNING: The default_fallbacks= configuration setter has been renamed fallbacks_generator= to avoid confusion. The original method default_fallbacks= will be removed in the next major version of Mobility. } self.fallbacks_generator = fallbacks end # Default backend to use (can be symbol or actual backend class) # @return [Symbol,Class] attr_accessor :default_backend # Returns set of default accessor locles to use (defaults to # +I18n.available_locales+) # @return [Array] def default_accessor_locales if @default_accessor_locales.is_a?(Proc) @default_accessor_locales.call else @default_accessor_locales end end attr_writer :default_accessor_locales def initialize @accessor_method = :translates @query_method = :i18n @fallbacks_generator = lambda { |fallbacks| Mobility::Fallbacks.build(fallbacks) } @default_accessor_locales = lambda { I18n.available_locales } @default_options = Options[{ cache: true, presence: true, }] @plugins = %i[ cache dirty fallbacks presence default attribute_methods fallthrough_accessors locale_accessors ] end class ReservedOptionKey < Exception; end class Options < Hash def []=(key, _) if RESERVED_OPTION_KEYS.include?(key) raise Configuration::ReservedOptionKey, "Default options may not contain the following reserved key: #{key}" end super end end end end