validates_timeliness/lib/validates_timeliness.rb
2010-10-14 18:57:53 +11:00

62 lines
2.0 KiB
Ruby

require 'date'
require 'active_support/concern'
require 'active_support/core_ext/module'
require 'active_support/core_ext/hash/except'
require 'active_support/core_ext/string/conversions'
require 'active_support/core_ext/date/acts_like'
require 'active_support/core_ext/date/conversions'
require 'active_support/core_ext/time/acts_like'
require 'active_support/core_ext/time/conversions'
require 'active_support/core_ext/date_time/acts_like'
require 'active_support/core_ext/date_time/conversions'
require 'timeliness'
module ValidatesTimeliness
autoload :VERSION, 'validates_timeliness/version'
class << self
delegate :parser, :default_timezone, :default_timezone=, :dummy_date_for_time_type, :to => Timeliness
end
# Extend ORM/ODMs for full support (:active_record, :mongoid).
mattr_accessor :extend_orms
@@extend_orms = []
# Ignore errors when restriction options are evaluated
mattr_accessor :ignore_restriction_errors
@@ignore_restriction_errors = false
# Shorthand time and date symbols for restrictions
mattr_accessor :restriction_shorthand_symbols
@@restriction_shorthand_symbols = {
:now => lambda { Time.current },
:today => lambda { Date.current }
}
# Use the plugin date/time parser which is stricter and extensible
mattr_accessor :use_plugin_parser
@@use_plugin_parser = false
# Default timezone
self.default_timezone = :utc
# Set the dummy date part for a time type values.
def self.dummy_date_for_time_type=(array)
Timeliness.date_for_time_type = array
end
self.dummy_date_for_time_type = [ 2000, 1, 1 ]
# Setup method for plugin configuration
def self.setup
yield self
extend_orms.each {|orm| require "validates_timeliness/orm/#{orm}" }
end
end
require 'validates_timeliness/conversion'
require 'validates_timeliness/validator'
require 'validates_timeliness/helper_methods'
require 'validates_timeliness/attribute_methods'
require 'validates_timeliness/extensions'
require 'validates_timeliness/railtie' if defined?(Rails)