> > hello dear i cant move dialog object in this code to the page center how move it?
from gluon.sqlhtml import * class SELECT_OR_ADD_OPTION(object): def __init__(self, controller=None, function=None, form_title=None, button_text = None, dialog_width=500 ): if form_title == None: self.form_title = T('') else: self.form_title = T(form_title) if button_text == None: self.button_text = T('Add') else: self.button_text = T(button_text) self.dialog_width = dialog_width self.controller = controller self.function = function def widget(self, field, value): #generate the standard widget for this field select_widget = OptionsWidget.widget(field, value ) #get the widget's id (need to know later on so can tell receiving controller what to update) my_select_id = select_widget.attributes.get('_id', None) add_args = [my_select_id] #create a div that will load the specified controller via ajax form_loader_div = DIV(LOAD(c=self.controller, f=self.function, args=add_args,ajax=True ), _id=my_select_id+"_dialog-form", _title=self.form_title ) #generate the "add" button that will appear next the options widget and open our dialog activator_button = A(T(self.button_text), _id=my_select_id+"_option_add_trigger" ) #create javascript for creating and opening the dialog js = '$( "#%s_dialog-form" ).dialog({autoOpen: false, show: "blind", hide: "explode" , width:"400" }).css({ margin:"50px"}).css({});' % (my_select_id) js += '$( "#%s_option_add_trigger" ).click(function() { $( "#%s_dialog-form" ).dialog( "open" );return false;}).css({float:"right"}); ' % (my_select_id, my_select_id) #decorate our activator button for good measure js += '$(function() { $( "#%s_option_add_trigger" ).button({text: true, icons: { primary: "ui-icon-circle-plus"} }); });' % (my_select_id) jq_script=SCRIPT(js, _type="text/javascript" ) wrapper = DIV(_id=my_select_id+"_adder_wrapper" ) wrapper.components.extend([select_widget, form_loader_div, activator_button, jq_script]) return wrapper On Wednesday, April 25, 2012 at 6:17:48 PM UTC+4:30, Richard wrote: > > Hello, > > Sorry to duplicate this question, but I really need help and think that my > subject title was not that clear. > > My problem is that I can't find how to display correctly the Autocomplete > widget (only get the address of the instance of the autocomplete class to > display in the form) if I combined it with SELECT_OR_ADD_OPTION widget > (web2py slice). > > Here what I chage in the SELECT_OR_ADD_OPTION widget class so far : > > class SELECT_OR_ADD_OPTION(object): > > def __init__(self, controller=None, function=None, form_title=None, > button_text = None, dialog_width=1000): > if form_title == None: > self.form_title = T('Add New') > else: > self.form_title = T(form_title) > if button_text == None: > self.button_text = T('Add') > else: > self.button_text = T(button_text) > self.dialog_width = dialog_width > > self.controller = controller > self.function = function > def widget(self, field, value): > #from gluon.sqlhtml import * > #generate the standard widget for this field > select_widget =* AutocompleteWidget(request, > db.ref_eregistry.exp_num,* > * id_field=db.ref_eregistry.eregistry_id, limitby=(0,10), > min_length=2)* > #get the widget's id (need to know later on so can tell receiving > controller what to update) > my_select_id =* 'table1_eregistry_id'* > #select_widget.attributes.get('_id', > None) > add_args = [my_select_id] > #create a div that will load the specified controller via ajax > form_loader_div = DIV(LOAD(c=self.controller, f=self.function, > args=add_args,ajax=True), _id=my_select_id+"_dialog-form", > _title=self.form_title) > #generate the "add" button that will appear next the options > widget and open our dialog > activator_button = A(T(self.button_text), > _id=my_select_id+"_option_add_trigger") > #create javascript for creating and opening the dialog > js = '$( "#%s_dialog-form" ).dialog({autoOpen: false, show: > "fade", hide: "fade", width: %s});' % (my_select_id, self.dialog_width) > js += '$( "#%s_option_add_trigger" ).click(function() { $( > "#%s_dialog-form" ).dialog( "open" );return false;}); ' % (my_select_id, > my_select_id) > #decorate our activator button for good measure > js += '$(function() { $( "#%s_option_add_trigger" ).button({text: > true, icons: { primary: "ui-icon-circle-plus"} }); });' % (my_select_id) > jq_script=SCRIPT(js, _type="text/javascript") > > wrapper = DIV(_id=my_select_id+"_adder_wrapper") > wrapper.components.extend([ select_widget, form_loader_div, > activator_button, jq_script]) > return wrapper > > I appreciate any input if this possible or not... > > Thanks > > Richard > > -- Resources: - http://web2py.com - http://web2py.com/book (Documentation) - http://github.com/web2py/web2py (Source code) - https://code.google.com/p/web2py/issues/list (Report Issues) --- You received this message because you are subscribed to the Google Groups "web2py-users" group. To unsubscribe from this group and stop receiving emails from it, send an email to web2py+unsubscr...@googlegroups.com. For more options, visit https://groups.google.com/d/optout.