2010-06-01 14:38:41 +02:00
|
|
|
/**
|
|
|
|
* eGroupWare API: JSON - Contains the client side javascript implementation of class.egw_json.inc.php
|
|
|
|
*
|
|
|
|
* @link http://www.egroupware.org
|
|
|
|
* @license http://opensource.org/licenses/gpl-license.php GPL - GNU General Public License
|
|
|
|
* @package api
|
|
|
|
* @subpackage ajax
|
2010-06-01 20:54:31 +02:00
|
|
|
* @author Andreas Stoeckel <as@stylite.de>
|
|
|
|
* @version $Id$
|
2010-06-01 14:38:41 +02:00
|
|
|
*/
|
|
|
|
|
|
|
|
/* The egw_json_request is the javaScript side implementation of class.egw_json.inc.php.*/
|
|
|
|
|
2010-06-09 15:24:59 +02:00
|
|
|
function egw_json_encode(input)
|
|
|
|
{
|
|
|
|
if (!input) return 'null';
|
|
|
|
|
|
|
|
switch (input.constructor) {
|
|
|
|
case String:
|
|
|
|
return '"' + input + '"';
|
|
|
|
|
|
|
|
case Number:
|
|
|
|
return input.toString();
|
|
|
|
|
|
|
|
case Boolean:
|
|
|
|
return input ? 'true' : 'false';
|
|
|
|
|
|
|
|
case Array :
|
|
|
|
var buf = [];
|
|
|
|
for (var i = 0; i < input.length; i++)
|
|
|
|
buf.push(egw_json_encode(input[i]));
|
|
|
|
return '[' + buf.join(',') + ']';
|
|
|
|
|
|
|
|
case Object:
|
|
|
|
var buf = [];
|
|
|
|
for (var k in input)
|
|
|
|
buf.push('"' + k + '":' + egw_json_encode(input[k]));
|
|
|
|
return '{' + buf.join(',') + '}';
|
|
|
|
|
|
|
|
default:
|
|
|
|
return 'null';
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2010-06-01 14:38:41 +02:00
|
|
|
/* The constructor of the egw_json_request class.
|
|
|
|
* @param string _menuaction the menuaction function which should be called and which handles the actual request
|
|
|
|
* @param array _parameters which should be passed to the menuaction function.
|
|
|
|
*/
|
2010-06-02 10:10:43 +02:00
|
|
|
function egw_json_request(_menuaction, _parameters)
|
2010-06-01 14:38:41 +02:00
|
|
|
{
|
|
|
|
//Copy the supplied parameters
|
|
|
|
this.menuaction = _menuaction;
|
2010-06-09 15:24:59 +02:00
|
|
|
|
|
|
|
if (typeof _parameters != 'undefined')
|
|
|
|
{
|
|
|
|
this.parameters = _parameters;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
this.parameters = new Array;
|
|
|
|
}
|
|
|
|
|
2010-06-09 12:40:17 +02:00
|
|
|
var url = window.egw_webserverUrl;
|
|
|
|
|
|
|
|
// Search up to parent if the current window is in a frame
|
|
|
|
if(typeof url == "undefined")
|
|
|
|
{
|
|
|
|
url = top.egw_webserverUrl;
|
|
|
|
}
|
|
|
|
|
|
|
|
this.url = url + '/json.php';
|
2010-06-09 15:24:59 +02:00
|
|
|
|
2010-06-01 14:38:41 +02:00
|
|
|
this.sender = null;
|
|
|
|
this.callback = null;
|
|
|
|
this.alertHandler = this.alertFunc;
|
2010-06-04 10:16:45 +02:00
|
|
|
if (window.egw_alertHandler)
|
2010-06-01 14:38:41 +02:00
|
|
|
{
|
2010-06-04 10:16:45 +02:00
|
|
|
this.alertHandler = window.egw_alertHandler;
|
2010-06-01 14:38:41 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Sends the AJAX JSON request.
|
|
|
|
* @param boolean _async specifies whether the request should be handeled asynchronously (true, the sendRequest function immediately returns to the caller) or asynchronously (false, the sendRequest function waits until the request is received)
|
|
|
|
* @param _callback is an additional callback function which should be called upon a "data" response is received
|
|
|
|
* @param _sender is the reference object the callback function should get
|
|
|
|
*/
|
|
|
|
egw_json_request.prototype.sendRequest = function(_async, _callback, _sender)
|
|
|
|
{
|
|
|
|
//Store the sender and callback parameter inside this class
|
|
|
|
this.sender = _sender;
|
|
|
|
if (typeof _callback != "undefined")
|
|
|
|
this.callback = _callback;
|
|
|
|
|
|
|
|
//Copy the async parameter which defaults to "true"
|
|
|
|
var is_async = true;
|
|
|
|
if (typeof _async != "undefined")
|
|
|
|
is_async = _async;
|
|
|
|
|
2010-06-09 15:24:59 +02:00
|
|
|
//Assemble the actual request object containing the json data string
|
|
|
|
var request_obj = {
|
|
|
|
"json_data": egw_json_encode(
|
2010-06-01 14:38:41 +02:00
|
|
|
{
|
2010-06-09 15:24:59 +02:00
|
|
|
"request": {
|
|
|
|
"parameters": this.parameters
|
|
|
|
}
|
|
|
|
})
|
2010-06-01 14:38:41 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
//Send the request via the jquery AJAX interface to the server
|
2010-06-01 16:20:55 +02:00
|
|
|
$.ajax({url: this.url + '?menuaction=' + this.menuaction,
|
2010-06-01 14:38:41 +02:00
|
|
|
async: is_async,
|
|
|
|
context: this,
|
|
|
|
data: request_obj,
|
|
|
|
dataType: 'json',
|
|
|
|
type: 'POST',
|
|
|
|
success: this.handleResponse});
|
|
|
|
}
|
|
|
|
|
|
|
|
egw_json_request.prototype.alertFunc = function(_message, _details)
|
|
|
|
{
|
|
|
|
alert(_message);
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Internal function which handles the response from the server */
|
|
|
|
egw_json_request.prototype.handleResponse = function(data, textStatus, XMLHttpRequest)
|
|
|
|
{
|
2010-06-04 17:22:01 +02:00
|
|
|
if (data && data.response)
|
2010-06-01 14:38:41 +02:00
|
|
|
{
|
|
|
|
var hasResponse = false;
|
|
|
|
for (var i = 0; i < data.response.length; i++)
|
|
|
|
{
|
|
|
|
switch (data.response[i].type)
|
|
|
|
{
|
|
|
|
case 'alert':
|
|
|
|
//Check whether all needed parameters have been passed and call the alertHandler function
|
|
|
|
if ((typeof data.response[i].data.message != 'undefined') &&
|
|
|
|
(typeof data.response[i].data.details != 'undefined'))
|
|
|
|
{
|
|
|
|
this.alertHandler(
|
|
|
|
data.response[i].data.message,
|
|
|
|
data.response[i].data.details)
|
|
|
|
hasResponse = true;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case 'assign':
|
|
|
|
//Check whether all needed parameters have been passed and call the alertHandler function
|
|
|
|
if ((typeof data.response[i].data.id != 'undefined') &&
|
|
|
|
(typeof data.response[i].data.key != 'undefined') &&
|
|
|
|
(typeof data.response[i].data.value != 'undefined'))
|
|
|
|
{
|
|
|
|
var obj = document.getElementById(data.response[i].data.id);
|
|
|
|
if (obj)
|
|
|
|
{
|
|
|
|
obj[data.response[i].data.key] = data.response[i].data.value;
|
2010-06-09 15:24:59 +02:00
|
|
|
hasResponse = true;
|
2010-06-01 14:38:41 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case 'data':
|
|
|
|
//Callback the caller in order to allow him to handle the data
|
2010-06-01 16:20:55 +02:00
|
|
|
if (this.callback)
|
|
|
|
{
|
|
|
|
this.callback.call(this.sender, data.response[i].data);
|
2010-06-09 15:24:59 +02:00
|
|
|
hasResponse = true;
|
2010-06-01 16:20:55 +02:00
|
|
|
}
|
2010-06-01 14:38:41 +02:00
|
|
|
break;
|
|
|
|
case 'script':
|
|
|
|
if (typeof data.response[i].data == 'string')
|
|
|
|
{
|
2010-06-09 15:24:59 +02:00
|
|
|
try
|
|
|
|
{
|
|
|
|
var func = function() {eval(data.response[i].data);};
|
|
|
|
func.call(window);
|
|
|
|
}
|
|
|
|
catch (e)
|
|
|
|
{
|
|
|
|
if (typeof console != "undefined" && typeof console.log != "undefined")
|
|
|
|
{
|
|
|
|
e.code = data.response[i].data;
|
|
|
|
console.log(e);
|
|
|
|
}
|
|
|
|
}
|
2010-06-01 14:38:41 +02:00
|
|
|
hasResponse = true;
|
|
|
|
}
|
|
|
|
break;
|
2010-06-02 10:10:43 +02:00
|
|
|
case 'redirect':
|
|
|
|
if (typeof data.response[i].data == 'string')
|
|
|
|
{
|
|
|
|
window.location.href = data.response[i].data;
|
|
|
|
}
|
|
|
|
break;
|
2010-06-01 14:38:41 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/* If no explicit response has been specified, call the callback (if one was set) */
|
|
|
|
if (!hasResponse && this.callback)
|
|
|
|
{
|
|
|
|
this.callback.call(this.sender, data.response[i].data);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2010-06-09 15:24:59 +02:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Deprecated legacy xajax wrapper functions for the new egw_json interface
|
|
|
|
*/
|
|
|
|
|
|
|
|
_xajax_doXMLHTTP = function(_async, _menuaction, _arguments)
|
|
|
|
{
|
|
|
|
/* Assemble the parameter array */
|
|
|
|
var paramarray = new Array();
|
|
|
|
for (var i = 1; i < _arguments.length; i++)
|
|
|
|
{
|
|
|
|
paramarray[paramarray.length] = _arguments[i];
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Create a new request, passing the menuaction and the parameter array */
|
|
|
|
var request = new egw_json_request(_menuaction, paramarray);
|
|
|
|
|
|
|
|
/* Send the request */
|
|
|
|
request.sendRequest(_async);
|
|
|
|
|
|
|
|
return request;
|
|
|
|
}
|
|
|
|
|
|
|
|
xajax_doXMLHTTP = function(_menuaction)
|
|
|
|
{
|
|
|
|
return _xajax_doXMLHTTP(true, _menuaction, arguments);
|
|
|
|
}
|
|
|
|
|
|
|
|
xajax_doXMLHTTPsync = function(_menuaction)
|
|
|
|
{
|
|
|
|
return _xajax_doXMLHTTP(false, _menuaction, arguments);
|
|
|
|
};
|
|
|
|
|
|
|
|
window.xajax = {
|
|
|
|
"getFormValues": function(_form)
|
|
|
|
{
|
|
|
|
var elem = null;
|
|
|
|
if (typeof _form == 'object')
|
|
|
|
{
|
|
|
|
elem = _form;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
elem = document.getElementsByName(_form)[0];
|
|
|
|
}
|
|
|
|
|
|
|
|
var serialized = $(_form).serializeArray();
|
|
|
|
alert("\nSerialized:\n" + serialized);
|
|
|
|
return serialized;
|
|
|
|
}
|
|
|
|
};
|