If you have a model that is using single table inheritance, the simple
new, create, edit, and update methods and views might not do what you
want them to do.  I have an ActiveRecord::Base with just a name and a
type so I can define a Team (type) of "account" and a Dept of Education.
But suppose I misspell Education and I want to edit it.  What happens is
the edit method finds the record and makes it into a Dept (type or
class).  This confuses the form_for(@name) into producing URLs for Dept
which in my case isn't want I wanted.  I wanted to edit the entry as a
name.  (In my case, I don't have URLs and controllers for Team or Dept,
etc.)

The solution was to us becomes(klass) so the edit method becomes:

  def edit
    @name = Name.find(params[:id]).becomes(Name)
  end

I did that same thing after all of the calls to find **in this case**.
There are probably 99% of the time that you want find to change the
instance into the proper class but if you don't, this is a simple way to
cast it back to the parent class.

-- 
Posted via http://www.ruby-forum.com/.

-- 
You received this message because you are subscribed to the Google Groups "Ruby 
on Rails: Talk" group.
To post to this group, send email to rubyonrails-talk@googlegroups.com.
To unsubscribe from this group, send email to 
rubyonrails-talk+unsubscr...@googlegroups.com.
For more options, visit this group at 
http://groups.google.com/group/rubyonrails-talk?hl=en.

Reply via email to