Add rule for 'body' container and QLink property 'target'

QLinks can now define the target for their link. Additionally, the
targte 'body' is now always the <body> tag. This allows the
modulemanager to reload the whole page (with the navigation bar).

refs #4092
This commit is contained in:
Jannis Moßhammer 2013-06-20 14:02:58 +02:00 committed by Marius Hein
parent e9ade7a339
commit beaac3a68d
1 changed files with 6 additions and 32 deletions

View File

@ -3,15 +3,14 @@
"use strict"; "use strict";
var asyncMgrInstance = null; var asyncMgrInstance = null;
define(['icinga/container','logging','jquery'],function(containerMgr,log,$) { define(['icinga/container','logging','icinga/behaviour','jquery'],function(containerMgr,log,behaviour,$) {
var headerListeners = {};
var pending = { var pending = {
}; };
var getDOMForDestination = function(destination) { var getDOMForDestination = function(destination) {
var target = destination; var target = destination;
if (typeof destination === "string") { if(typeof destination === "string") {
target = containerMgr.getContainer(destination)[0]; target = containerMgr.getContainer(destination)[0];
} else if(typeof destination.context !== "undefined") { } else if(typeof destination.context !== "undefined") {
target = destination[0]; target = destination[0];
@ -19,30 +18,12 @@
return target; return target;
}; };
var applyHeaderListeners = function(headers) { var handleResponse = function(html) {
for (var header in headerListeners) {
if (headers.getResponseHeader(header) === null) {
// see if the browser/server converts headers to lowercase
if (headers.getResponseHeader(header.toLowerCase()) === null) {
continue;
}
header = header.toLowerCase();
}
var value = headers.getResponseHeader(header);
var listeners = headerListeners[header];
for (var i=0;i<listeners.length;i++) {
listeners[i].fn.apply(listeners[i].scope, [value, header, headers]);
}
}
};
var handleResponse = function(html, status, response) {
applyHeaderListeners(response);
if(this.destination) { if(this.destination) {
containerMgr.updateContainer(this.destination,html,this); containerMgr.updateContainer(this.destination,html,this);
} else { } else {
// tbd containerMgr.createPopupContainer(html,this);
// containerMgr.createPopupContainer(html,this);
} }
}; };
@ -68,8 +49,6 @@
var CallInterface = function() { var CallInterface = function() {
this.__internalXHRImplementation = $.ajax;
this.clearPendingRequestsFor = function(destination) { this.clearPendingRequestsFor = function(destination) {
if(!$.isArray(pending)) { if(!$.isArray(pending)) {
pending = []; pending = [];
@ -89,7 +68,7 @@
}; };
this.createRequest = function(url,data) { this.createRequest = function(url,data) {
var req = this.__internalXHRImplementation({ var req = $.ajax({
type : data ? 'POST' : 'GET', type : data ? 'POST' : 'GET',
url : url, url : url,
data : data, data : data,
@ -110,7 +89,7 @@
if(destination) { if(destination) {
pending.push({ pending.push({
request: req, request: req,
DOM: getDOMForDestination(destination) DOM: getDOMForDestination(destination)
}); });
req.destination = destination; req.destination = destination;
} }
@ -122,11 +101,6 @@
this.loadCSS = function(name) { this.loadCSS = function(name) {
}; };
this.registerHeaderListener = function(header, fn, scope) {
headerListeners[header] = headerListeners[header] || [];
headerListeners[header].push({fn: fn, scope:scope});
};
}; };
return new CallInterface(); return new CallInterface();
}); });