class Dry::Schema::Messages::Abstract
@api public
Abstract class for message backends
def self.build(options = EMPTY_HASH)
- Api: - private
def self.build(options = EMPTY_HASH) messages = new messages.configure do |config| options.each do |key, value| config.public_send(:"#{key}=", value) end config.root = "#{config.top_namespace}.#{config.root}" config.rule_lookup_paths = config.rule_lookup_paths.map { |path| "#{config.top_namespace}.#{path}" } yield(config) if block_given? end messages.prepare end
def self.setting_names
- Api: - private
def self.setting_names # TODO: this is compatibility tweak to make it work with dry-configurable < 0.16.1 # and should be removed in dry-schema 2.0.0 @setting_names ||= settings .map { |setting| setting.respond_to?(:name) ? setting.name : setting } .map(&:to_sym) end
def call(predicate, options)
- Api: - public
Returns:
-
(Template)
-
def call(predicate, options) options = {locale: default_locale, **options} opts = options.reject { |k,| config.lookup_options.include?(k) } path = lookup_paths(predicate, options).detect { |key| key?(key, opts) } return unless path result = get(path, opts) [ Template.new( messages: self, key: path, options: opts ), result[:meta] ] end
def custom_top_namespace?(path)
- Api: - private
def custom_top_namespace?(path) path.to_s == DEFAULT_MESSAGES_PATH.to_s && config.top_namespace != DEFAULT_MESSAGES_ROOT end
def default_locale
- Api: - private
def default_locale config.default_locale end
def filled_lookup_paths(tokens)
- Api: - private
def filled_lookup_paths(tokens) config.lookup_paths.map { |path| path % tokens } end
def interpolatable_data(_key, _options, **_data)
- Api: - private
def interpolatable_data(_key, _options, **_data) raise NotImplementedError end
def interpolate(_key, _options, **_data)
- Api: - private
def interpolate(_key, _options, **_data) raise NotImplementedError end
def key?(_key, _options = EMPTY_HASH)
- Api: - public
Returns:
-
(Boolean)
-
def key?(_key, _options = EMPTY_HASH) raise NotImplementedError end
def looked_up_paths(predicate, options)
- Api: - public
Returns:
-
(String)
-
Parameters:
-
options
(Hash
) -- -
predicate
(Symbol
) --
def looked_up_paths(predicate, options) tokens = lookup_tokens(predicate, options) filled_lookup_paths(tokens) end
def lookup_paths(predicate, options)
- Api: - private
def lookup_paths(predicate, options) tokens = lookup_tokens(predicate, options) filled_lookup_paths(tokens) end
def lookup_tokens(predicate, options)
- Api: - private
def lookup_tokens(predicate, options) options.merge( predicate: predicate, root: options[:not] ? "#{root}.not" : root, arg_type: config.arg_types[options[:arg_type]], val_type: config.val_types[options[:val_type]], message_type: options[:message_type] || :failure ) end
def namespaced(namespace)
- Api: - public
Parameters:
-
namespace
(Symbol, String
) --
def namespaced(namespace) Dry::Schema::Messages::Namespaced.new(namespace, self) end
def root
- Api: - public
Returns:
-
(Pathname)
-
def root config.root end
def rule(name, options = {})
- Api: - private
def rule(name, options = {}) tokens = {name: name, locale: options.fetch(:locale, default_locale)} path = rule_lookup_paths(tokens).detect { |key| key?(key, options) } rule = get(path, options) if path rule.is_a?(Hash) ? rule[:text] : rule end
def rule_lookup_paths(tokens)
- Api: - private
def rule_lookup_paths(tokens) config.rule_lookup_paths.map { |key| key % tokens } end
def translate(key, locale: default_locale)
- Api: - private
def translate(key, locale: default_locale) t["#{config.top_namespace}.#{key}", locale: locale] end