1 import params
from "../parameters"; //for server URL
3 // TODO: replace by fetch API ?
4 // https://www.sitepoint.com/xmlhttprequest-vs-the-fetch-api-whats-best-for-ajax-in-2019/
6 // From JSON (encoded string values!) to "arg1=...&arg2=..."
7 function toQueryString(data
)
10 Object
.keys(data
).forEach(k
=> {
11 data_str
+= k
+ "=" + encodeURIComponent(data
[k
]) + "&";
13 return data_str
.slice(0, -1); //remove last "&"
16 // data, error: optional
17 export function ajax(url
, method
, data
, success
, error
)
19 let xhr
= new XMLHttpRequest();
20 if (data
=== undefined || typeof(data
) === "function") //no data
27 success
= () => {}; //by default, do nothing
29 error
= errmsg
=> { alert(errmsg
); };
30 xhr
.onreadystatechange = function() {
31 if (this.readyState
== 4 && this.status
== 200)
35 res_json
= JSON
.parse(xhr
.responseText
);
37 // Plain text (e.g. for rules retrieval)
38 return success(xhr
.responseText
);
43 error(res_json
.errmsg
);
47 if (["GET","DELETE"].includes(method
) && !!data
)
49 // Append query params to URL
50 url
+= "/?" + toQueryString(data
);
52 xhr
.open(method
, params
.serverUrl
+ url
, true);
53 xhr
.setRequestHeader('X-Requested-With', "XMLHttpRequest");
54 // Next line to allow cross-domain cookies in dev mode (TODO: if...)
56 xhr
.withCredentials
= true;
57 if (["POST","PUT"].includes(method
))
59 xhr
.setRequestHeader("Content-Type", "application/json;charset=UTF-8");
60 xhr
.send(JSON
.stringify(data
));