# HG changeset patch # User Alexandre Fayolle # Date 1261476427 -3600 # Node ID 0441165c7e59d6e97341127b0446c0ed9804030b # Parent f0ab2b6d3553f0f865313d94b7ce388d9748828a# Parent 92a10d2a09af897c1efb25cc6720feeccc0a2a05 merge diff -r f0ab2b6d3553 -r 0441165c7e59 web/data/cubicweb.ajax.js --- a/web/data/cubicweb.ajax.js Tue Dec 22 09:38:08 2009 +0100 +++ b/web/data/cubicweb.ajax.js Tue Dec 22 11:07:07 2009 +0100 @@ -13,54 +13,80 @@ var loaded = []; var jqtagfilter = tag + '[' + srcattr + ']'; jQuery('head ' + jqtagfilter).each(function(i) { - loaded.push(this.getAttribute(srcattr)); + loaded.push(this.getAttribute(srcattr)); }); node.find(tag).each(function(i) { - if (this.getAttribute(srcattr)) { - if (!loaded.contains(this.getAttribute(srcattr))) { - jQuery(this).appendTo(head); - } - } else { - jQuery(this).appendTo(head); - } + if (this.getAttribute(srcattr)) { + if (!loaded.contains(this.getAttribute(srcattr))) { + jQuery(this).appendTo(head); + } + } else { + jQuery(this).appendTo(head); + } }); node.find(jqtagfilter).remove(); } /* - * inspect dom response, search for a
node and - * put its content into the real document's head. + * inspect dom response (as returned by getDomFromResponse), search for + * a
node and put its content into the real + * document's head. * This enables dynamic css and js loading and is used by replacePageChunk */ -function loadAjaxHtmlHead(node) { - var head = jQuery('head'); - node = jQuery(node).find('div.ajaxHtmlHead'); - _loadAjaxHtmlHead(node, head, 'script', 'src'); - _loadAjaxHtmlHead(node, head, 'link', 'href'); - node.find('*').appendTo(head); +function loadAjaxHtmlHead(response) { + var $head = jQuery('head'); + var $responseHead = jQuery(response).find('div.ajaxHtmlHead'); + // no ajaxHtmlHead found, no processing required + if (!$responseHead.length) { + return response; + } + _loadAjaxHtmlHead($responseHead, $head, 'script', 'src'); + _loadAjaxHtmlHead($responseHead, $head, 'link', 'href'); + // add any remaining children (e.g. meta) + $responseHead.children().appendTo($head); + // remove original container, which is now empty + $responseHead.remove(); + // if there was only one actual node in the reponse besides + // the ajaxHtmlHead, then remove the wrapper created by + // getDomFromResponse() and return this single element + // For instance : + // 1/ CW returned the following content : + //
the-actual-content
...
+ // 2/ getDomFromReponse() wrapped this into a single DIV to hold everything + // in one, unique, dom element + // 3/ now that we've removed the ajaxHtmlHead div, the only + // node left in the wrapper if the 'real' node built by the view, + // we can safely return this node. Otherwise, the view itself + // returned several 'root' nodes and we need to keep the wrapper + // created by getDomFromResponse() + if (response.childNodes.length == 1 && + response.getAttribute('cubicweb:type') == 'cwResponseWrapper') { + return response.firstChild; + } + return response; } function preprocessAjaxLoad(node, newdomnode) { - loadAjaxHtmlHead(newdomnode); + return loadAjaxHtmlHead(newdomnode); } function postAjaxLoad(node) { // find sortable tables if there are some if (typeof(Sortable) != 'undefined') { - Sortable.sortTables(node); + Sortable.sortTables(node); } // find textareas and wrap them if there are some if (typeof(FCKeditor) != 'undefined') { - buildWysiwygEditors(); + buildWysiwygEditors(); } if (typeof initFacetBoxEvents != 'undefined') { - initFacetBoxEvents(node); + initFacetBoxEvents(node); } if (typeof buildWidgets != 'undefined') { - buildWidgets(node); + buildWidgets(node); } if (typeof roundedCorners != 'undefined') { - roundedCorners(node); + roundedCorners(node); } if (typeof setFormsTarget != 'undefined') { setFormsTarget(node); @@ -71,7 +97,7 @@ // we probably need to unbind the fired events // When this is done, jquery.treeview.js (for instance) // can be unpatched. - jQuery(CubicWeb).trigger('ajax-loaded'); + jQuery(CubicWeb).trigger('ajax-loaded'); } /* cubicweb loadxhtml plugin to make jquery handle xhtml response @@ -87,38 +113,38 @@ jQuery.fn.loadxhtml = function(url, data, reqtype, mode) { var ajax = null; if (reqtype == 'post') { - ajax = jQuery.post; + ajax = jQuery.post; } else { - ajax = jQuery.get; + ajax = jQuery.get; } if (this.size() > 1) { - log('loadxhtml was called with more than one element'); + log('loadxhtml was called with more than one element'); } var node = this.get(0); // only consider the first element mode = mode || 'replace'; var callback = null; if (data && data.callback) { - callback = data.callback; - delete data.callback; + callback = data.callback; + delete data.callback; } ajax(url, data, function(response) { - var domnode = getDomFromResponse(response); - preprocessAjaxLoad(node, domnode); - if (mode == 'swap') { - var origId = node.id; - node = swapDOM(node, domnode); - if (!node.id) { - node.id = origId; - } - } else if (mode == 'replace') { - jQuery(node).empty().append(domnode); - } else if (mode == 'append') { - jQuery(node).append(domnode); - } - postAjaxLoad(node); - while (jQuery.isFunction(callback)) { - callback = callback.apply(this, [domnode]); - } + var domnode = getDomFromResponse(response); + domnode = preprocessAjaxLoad(node, domnode); + if (mode == 'swap') { + var origId = node.id; + node = swapDOM(node, domnode); + if (!node.id) { + node.id = origId; + } + } else if (mode == 'replace') { + jQuery(node).empty().append(domnode); + } else if (mode == 'append') { + jQuery(node).append(domnode); + } + postAjaxLoad(node); + while (jQuery.isFunction(callback)) { + callback = callback.apply(this, [domnode]); + } }); }; @@ -129,43 +155,43 @@ */ function loadDynamicFragments(node) { if (node) { - var fragments = jQuery(node).find('div.dynamicFragment'); + var fragments = jQuery(node).find('div.dynamicFragment'); } else { - var fragments = jQuery('div.dynamicFragment'); + var fragments = jQuery('div.dynamicFragment'); } if (fragments.length == 0) { - return; + return; } if (typeof LOADING_MSG == 'undefined') { - LOADING_MSG = 'loading'; // this is only a safety belt, it should not happen + LOADING_MSG = 'loading'; // this is only a safety belt, it should not happen } for(var i=0; i'; - // if cubicweb:loadurl is set, just pick the url et send it to loadxhtml - var url = getNodeAttribute(fragment, 'cubicweb:loadurl'); - if (url) { - jQuery(fragment).loadxhtml(url); - continue; - } - // else: rebuild full url by fetching cubicweb:rql, cubicweb:vid, etc. - var rql = getNodeAttribute(fragment, 'cubicweb:rql'); - var items = getNodeAttribute(fragment, 'cubicweb:vid').split('&'); - var vid = items[0]; + var fragment = fragments[i]; + fragment.innerHTML = '

' + LOADING_MSG + ' ...

'; + // if cubicweb:loadurl is set, just pick the url et send it to loadxhtml + var url = getNodeAttribute(fragment, 'cubicweb:loadurl'); + if (url) { + jQuery(fragment).loadxhtml(url); + continue; + } + // else: rebuild full url by fetching cubicweb:rql, cubicweb:vid, etc. + var rql = getNodeAttribute(fragment, 'cubicweb:rql'); + var items = getNodeAttribute(fragment, 'cubicweb:vid').split('&'); + var vid = items[0]; var extraparams = {}; - // case where vid='myvid¶m1=val1¶m2=val2': this is a deprecated abuse-case - if (items.length > 1) { - console.log("[3.5] you're using extraargs in cubicweb:vid attribute, this is deprecated, consider using loadurl instead"); - for (var j=1; j 1) { + console.log("[3.5] you're using extraargs in cubicweb:vid attribute, this is deprecated, consider using loadurl instead"); + for (var j=1; j return the whole document - return jQuery(doc).clone().context; + // no child (error cases) => return the whole document + return jQuery(doc).clone().context; } children = stripEmptyTextNodes(children); if (children.length == 1) { - // only one child => return it - return jQuery(children[0]).clone().context; + // only one child => return it + return jQuery(children[0]).clone().context; } // several children => wrap them in a single node and return the wrap - return DIV(null, map(function(node) { - return jQuery(node).clone().context; - }, - children)); + return DIV({'cubicweb:type': "cwResponseWrapper"}, + map(function(node) { + return jQuery(node).clone().context; + }, children)); } function postJSON(url, data, callback) {