# HG changeset patch # User sylvain.thenault@logilab.fr # Date 1241074314 -7200 # Node ID de0548cb0ab854a85adb9dc7204843e6ce561ae1 # Parent f63d090eb34a5e4f81acedbb48a8c736339f920b# Parent b130c6cec8c2cf978f13e5597f023d524809ab4c merge diff -r f63d090eb34a -r de0548cb0ab8 web/data/cubicweb.ajax.js --- a/web/data/cubicweb.ajax.js Thu Apr 30 01:21:48 2009 +0200 +++ b/web/data/cubicweb.ajax.js Thu Apr 30 08:51:54 2009 +0200 @@ -29,7 +29,7 @@ */ function loadAjaxHtmlHead(node) { var head = jQuery('head'); - var node = jQuery(node).find('div.ajaxHtmlHead'); + node = jQuery(node).find('div.ajaxHtmlHead'); _loadAjaxHtmlHead(node, head, 'script', 'src'); _loadAjaxHtmlHead(node, head, 'link', 'href'); node.find('*').appendTo(head); @@ -144,18 +144,6 @@ } } -/* - * This function is the equivalent of MochiKit's loadJSONDoc but - * uses POST instead of GET - */ -function loadJSONDocUsingPOST(url, data) { - setProgressCursor(); - var deferred = loadJSON(url, data, 'POST'); - deferred = deferred.addErrback(remoteCallFailed); - deferred = deferred.addCallback(resetCursor); - return deferred; -} - /* * This function will call **synchronously** a remote method on the cubicweb server @@ -187,10 +175,16 @@ * * It looks at http headers to guess the response type. */ + function asyncRemoteExec(fname /* ... */) { + setProgressCursor(); var props = {'fname' : fname, 'pageid' : pageid, 'arg': map(jQuery.toJSON, sliceList(arguments, 1))}; - return loadJSONDocUsingPOST(JSON_BASE_URL, props); + var deferred = loadRemote(JSON_BASE_URL, props, 'POST'); + deferred = deferred.addErrback(remoteCallFailed); + deferred = deferred.addErrback(resetCursor); + deferred = deferred.addCallback(resetCursor); + return deferred; } diff -r f63d090eb34a -r de0548cb0ab8 web/data/cubicweb.compat.js --- a/web/data/cubicweb.compat.js Thu Apr 30 01:21:48 2009 +0200 +++ b/web/data/cubicweb.compat.js Thu Apr 30 08:51:54 2009 +0200 @@ -365,11 +365,16 @@ }; -function loadJSON(url, data, type) { +/* + * Asynchronously load an url and return a deferred + * whose callbacks args are decoded according to + * the Content-Type response header + */ +function loadRemote(url, data, reqtype) { var d = new Deferred(); jQuery.ajax({ url: url, - type: type, + type: reqtype, data: data, beforeSend: function(xhr) { @@ -377,6 +382,9 @@ }, success: function(data, status) { + if (d.req.getResponseHeader("content-type") == 'application/json') { + data = evalJSON(data); + } d.success(data); }, @@ -506,23 +514,7 @@ var KEYS = { KEY_ESC: 27, KEY_ENTER: 13 -} +}; -// XHR = null; -// function test() { -// var d = loadJSON('http://crater:9876/json?mode=remote&fname=i18n&pageid=xxx&arg=' + jQuery.toJSON(['modify'])); -// d = d.addCallback(function (result, xhr) { -// XHR = xhr; -// log('got ajax result 1' + result + xhr); -// log('got ajax result 1' + xhr); -// log('got ajax result 1' + xhr + 'arguments =', arguments.length); -// }); -// d.addCallback(function (x, req, y, z) { -// log('callback 2 x =' + x, ' req=', req, 'y =', y, 'z=',z); -// }, 12, 13) -// d.addErrback(function (error, xhr) { -// XHR = xhr; -// log('got err', error, ' code =', xhr.status, 'arguments length=', arguments.length); -// }) -// } + diff -r f63d090eb34a -r de0548cb0ab8 web/form.py --- a/web/form.py Thu Apr 30 01:21:48 2009 +0200 +++ b/web/form.py Thu Apr 30 08:51:54 2009 +0200 @@ -421,7 +421,7 @@ class EntityFieldsForm(FieldsForm): __select__ = (match_kwargs('entity') | (one_line_rset & non_final_entity())) - internal_fields = FieldsForm.internal_fields + ('__type', 'eid') + internal_fields = FieldsForm.internal_fields + ('__type', 'eid', '__maineid') domid = 'entityForm' def __init__(self, *args, **kwargs): diff -r f63d090eb34a -r de0548cb0ab8 web/formfields.py --- a/web/formfields.py Thu Apr 30 01:21:48 2009 +0200 +++ b/web/formfields.py Thu Apr 30 08:51:54 2009 +0200 @@ -94,9 +94,9 @@ Field.__creation_rank += 1 def __unicode__(self): - return u'<%s name=%r label=%r id=%r initial=%r @%x>' % ( + return u'<%s name=%r label=%r id=%r initial=%r visible=%r @%x>' % ( self.__class__.__name__, self.name, self.label, - self.id, self.initial, id(self)) + self.id, self.initial, self.is_visible(), id(self)) def __repr__(self): return self.__unicode__().encode('utf-8') @@ -406,7 +406,10 @@ relatedvocab = [(e.view('combobox'), e.eid) for e in rset.entities()] else: relatedvocab = [] - return res + form.form_field_vocabulary(self) + relatedvocab + vocab = res + form.form_field_vocabulary(self) + relatedvocab + if self.sort: + vocab = sorted(vocab) + return vocab def format_single_value(self, req, value): return value diff -r f63d090eb34a -r de0548cb0ab8 web/formwidgets.py --- a/web/formwidgets.py Thu Apr 30 01:21:48 2009 +0200 +++ b/web/formwidgets.py Thu Apr 30 08:51:54 2009 +0200 @@ -161,20 +161,16 @@ class Select(FieldWidget): """