Hi! The documentation is sparse, and my searches have turned up nothing
yet. Perhaps someone has some insight? Is there a how-to on this? or
what am I missing?
I have a web page with a drop-down list (high-level key like
Company) that once chosen, should populate another
item with a
list of matching low-order keys (like Product). I have coded something,
but it does not trigger the download of the second HTML snippet with the
new select. (nothing in http log, javascript console, etc)
layout has <%= javascript_include_tag “prototype” %>
controller (call) has
def index @clients = Client.find(:all, :order=>“name”)
end
def load_contacts
I need to get the selected client to here as well! params[?]
@contacts = ClientContacts.find :all, :order =>“name”
render :layout=>false
end
I had to implement similar behavior and got stuck just like you did. I
did
implement a solution that is less than optimal but it works. Perhaps
someone out
there has a better solution.
The way I have solved this is in your ajax callback from the first combo
list
spew out the select html for the second based on the observer pattern.
Thus when
the user changes the selection on combo1 you can define a div in the
original
page which content will populated using the html block returned by the
ajax
callback.
In you callback you ‘compute’ something like that:
The first parameter of observer_field should be the id and not the name
of
the select
So in your case it would have to be:
observe_field ‘call_client_id’
Thanks, Bogdan! That did the trick. I was trying different names, but I
had not thought about the tag id.
Also I needed to get the value selected from the first drop-down box to
build the data for the second. Here is what I determined I needed for
the controller to populate the second box.