1 //<script type="text/javascript">
4 * Handles generic requests - an extension of Roo.data.Connection that runs the request
5 * on construction. shows error messages, and parses results.
8 var t = new Pman.Request({
9 url: baseURL + '/Images/Download/0/myfile.jpg',
11 success : function(res) {
21 * @param {Object} cfg Configuration object.
22 * @cfg {String} url Location to download from.
23 * @cfg {String} method GET or POST (default GET), POST will create a form, and post that into the hidden frame.
24 * @cfg {Object/String/Function} params (Optional) An object containing properties which are used as parameters to the
25 * request, a url encoded string or a function to call to get either.
26 * @cfg {Function} success called with ( JSON decoded data of the data.. )
27 * @cfg {Function} success called with ( JSON decoded data of the data.. )
30 Pman.Request = function(config){
32 Pman.Request.superclass.constructor.call(this, config);
36 Roo.extend(Pman.Request, Roo.data.Connection, {
38 processResponse : function(response) {
39 // convert the Roo Connection response into JSON data.
43 res = Roo.decode(response.responseText);
45 if (typeof(res) != 'object') {
46 res = { success : false, errorMsg : res, errors : true };
48 if (typeof(res.success) == 'undefined') {
53 res = { success : false, errorMsg : response.responseText || Roo.encode(response), errors : true };
58 handleResponse : function(response){
60 var options = response.argument.options;
61 response.argument = options ? options.argument : null;
62 this.fireEvent("requestcomplete", this, response, options);
64 var res = this.processResponse(response);
66 if (!res.success) { // error!
67 if (options.failure) {
68 // failure is handled... - do not show error..
69 if (true === Roo.callback(options.failure, options.scope, [res, options])) {
73 Roo.MessageBox.hide(); // hide any existing messages..
74 Roo.MessageBox.alert("Error", res.errorMsg ? res.errorMsg : "Error Sending");
77 Roo.callback(options.success, options.scope, [res, options]);
80 handleFailure : function(response, e){
82 var options = response.argument.options;
83 response.argument = options ? options.argument : null;
84 this.fireEvent("requestexception", this, response, options, e);
85 var res = Roo.callback(options.failure, options.scope, [response, options]);
88 var decode = this.processResponse(response);
90 Roo.MessageBox.hide(); // hide any existing messages..
91 Roo.MessageBox.alert("Error", "Error Sending" + decode.errorMsg);