On Dec 25 2011, 12:32 am, Walter Lee Davis <wa...@wdstudio.com> wrote:
> On Dec 25, 2011, at 12:15 AM, Bob Smith wrote:
>
>
>
>
>
> > On Dec 24, 1:18 pm, Walter Lee Davis <wa...@wdstudio.com> wrote:
> > Use an :after_create callback in those cases; you will have the ID at
> > that point and you can use it. Remember, you will need to set any
> > relationship keys directly, not at the object level, since you can't
> > call save again in an after_create (I don't think). Here's my
> > after_save method from a similar setup:
>
> >  def set_primary
> >    self.update_attributes( :role_id => self.roles.first.id ) if
> > self.roles.first
> >  end
>
> >> This is from inside a Title, which has_many roles, has_many people through 
> >> roles, and belongs_to one role (designating the "primary" person, like the 
> >> author or the editor -- the one that people think of when they're looking 
> >> for that book, even though lots of people may have contributed to it).
>
> >> I needed to go this route because I was using Ryan Bates' nested_form gem, 
> >> and so I was adding roles to a title that hadn't been saved yet -- very 
> >> similar to your setup if I recall correctly. Since I can't designate a 
> >> primary in the #new method, because nothing has anIDyet, I use this 
> >> callback to sort things out, and count on my editors to always choose the 
> >> most important person first. I have a new_record? test in my view to hide 
> >> theradiobuttons in that case, and show them in the #edit view of the same 
> >> form.
>
> >> Walter
>
> > This is very close to what I wanted. It seems you were having the same
> > problem as I am using the new_record? test to remove the
> > radio_buttons. I am trying to find a way to get the id after the
> > create and putting it in the Household.hoh field. Maybe in the
> > after_create callback for each Person object. But how can I access the
> >radiobuttonand see who was selected from there ?? I see you
> > used .first to set the id. Will this help me see who was selected by
> > theradiobuttons ??
>
> No, this only hacks around the problem of setting the primary role in a new 
> title object by choosing the first member of the has_many roles collection 
> within the controller. The actual method of getting the role from 
> theradiobuttonis much simpler and more direct.
>
>         <%= radio_button_tag 'title[role_id]', f.object.id, (@title.role_id 
> == f.object.id) %>
>
> That's inside a partial called _role_fields.html.erb, and it's filled in 
> using the nested_form gem as I mentioned earlier. It's just named correctly 
> to act on the parent title object, and inside the partial, f.object points to 
> the individual role object.
>
> Walter
>
>
>
> > Bob
>
> > --
> > 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 
> > athttp://groups.google.com/group/rubyonrails-talk?hl=en.
>
>

Almost there... Thanks for the help.

The latest problem is with the radio button using a variable in the
parent to store the selected child record id. Setting
this in the view doesn't allow new records to have an id yet. Do you
know a way of having each radio button put a one in a
variable that is located in each child record ? If so, then it should
be easy for after_create to test each child record
for that value and when it's found there should already be an id to
put in the parent variable.

Thanks again

Bob

-- 
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