Sha256: 3fd542629c456af14a85fd8ee246f8f2ae3246947490d1d82be633ff449e36b2

Contents?: true

Size: 1.58 KB

Versions: 4

Compression:

Stored size: 1.58 KB

Contents

module Reform::Form::ActiveRecord
  def self.included(base)
    base.class_eval do
      include Reform::Form::ActiveModel
      extend ClassMethods
    end
  end

  module ClassMethods
    def validates_uniqueness_of(attribute)
      validates_with UniquenessValidator, :attributes => [attribute]
    end
    def i18n_scope
      :activerecord
    end
  end

  class UniquenessValidator < ::ActiveRecord::Validations::UniquenessValidator
    # when calling validates it should create the Vali instance already and set @klass there! # TODO: fix this in AM.
    def validate(form)
      property = attributes.first

      # here is the thing: why does AM::UniquenessValidator require a filled-out record to work properly? also, why do we need to set
      # the class? it would be way easier to pass #validate a hash of attributes and get back an errors hash.
      # the class for the finder could either be infered from the record or set in the validator instance itself in the call to ::validates.
      record = form.model_for_property(property)
      record.send("#{property}=", form.send(property))

      @klass = record.class # this is usually done in the super-sucky #setup method.
      super(record).tap do |res|
        form.errors.add(property, record.errors.first.last) if record.errors.present?
      end
    end
  end


  def model_for_property(name)
    return model unless is_a?(Reform::Form::Composition) # i am too lazy for proper inheritance. there should be a ActiveRecord::Composition that handles this.

    model_name = mapper.representable_attrs[name][:on]
    model[model_name]
  end
end

Version data entries

4 entries across 4 versions & 1 rubygems

Version Path
reform-1.0.4 lib/reform/form/active_record.rb
reform-1.0.3 lib/reform/form/active_record.rb
reform-1.0.2 lib/reform/form/active_record.rb
reform-1.0.1 lib/reform/form/active_record.rb