X-Git-Url: https://git.llucax.com/z.facultad/75.52/sercom.git/blobdiff_plain/80066ce43bd7bac9343044fd8a6f304a5ff841c3..19cb7e8320e2d5bf3dd0f8fb26c79616bf9b1f0e:/sercom/widgets.py?ds=sidebyside diff --git a/sercom/widgets.py b/sercom/widgets.py index 309adc0..5d35606 100644 --- a/sercom/widgets.py +++ b/sercom/widgets.py @@ -19,32 +19,78 @@ class CustomTextField(widgets.TextField): ''' -AlumnoMultiSelectAjax = ''' - function agregar_a_la_lista(texto, lista) +MultiSelectAjax = ''' + + function _on_alumno_get_result(lista, loading, results) { - t = MochiKit.DOM.getElement(texto); - MochiKit.DOM.appendChildNodes(lista, OPTION(t.value)); - t.value = ""; + load = MochiKit.DOM.getElement(loading); + load.style.visibility = 'hidden'; + if (results.error) { + alert(results.msg); + return; + } + MochiKit.DOM.appendChildNodes(lista, OPTION({'value':results.msg.id}, results.msg.value)); + l = MochiKit.DOM.getElement(lista); + } + + function _on_alumno_get_error(loading, results) + { + alert(results) + load = MochiKit.DOM.getElement(loading); + load.style.visibility = 'hidden'; } function sacar_de_la_lista(lista) { l = MochiKit.DOM.getElement(lista); if (l.selectedIndex < 0) return; + + /* caso especial, 1 solo item */ + if (l.options.length == 1) { + l.options.length = 0 + return; + } for (i=l.selectedIndex; i - - - - +
+
+ + + +
+
- - - +
+ - - +
+
''' - javascript = [widgets.JSSource(AlumnoMultiSelectAjax)] + javascript = [widgets.JSSource(MultiSelectAjax)] + on_add = "alert('Not defined action');" + def __init__(self, **kw): + self.params.append('on_add') + self.on_add = "alert('Not defined action');" + widgets.MultipleSelectField.__init__(self, **kw)