1 | export const Api = (config) => { |
||
2 | const promise = new Promise((resolve) => { |
||
3 | |||
4 | if (!config.method) { |
||
5 | config.method = 'GET'; |
||
6 | } |
||
7 | |||
8 | if (config.data) { |
||
9 | config.data = JSON.stringify(config.data); |
||
10 | } |
||
11 | |||
12 | const request = new XMLHttpRequest(); |
||
0 ignored issues
–
show
|
|||
13 | |||
14 | config.route = buildQueryString(config).route; |
||
15 | |||
16 | request.open(config.method, config.route, true); |
||
17 | |||
18 | setRequestHeaders(request, config); |
||
19 | |||
20 | addAjaxEvents(request, config, resolve); |
||
21 | |||
22 | request.send(config.data || null); |
||
23 | |||
24 | }); |
||
25 | |||
26 | return promise; |
||
27 | }; |
||
28 | |||
29 | export const setRequestHeaders = (request = {}, config = {}) => { |
||
30 | |||
31 | if (!config.headers || !config.headers.contentType) { |
||
32 | request.setRequestHeader( |
||
33 | 'Content-Type', 'application/x-www-form-urlencoded' |
||
34 | ); |
||
35 | } |
||
36 | |||
37 | if (!config.headers) { |
||
38 | return false; |
||
39 | } |
||
40 | |||
41 | for (const key of Object.keys(config.headers)) { |
||
42 | request.setRequestHeader(key, config.headers[key]); |
||
43 | } |
||
0 ignored issues
–
show
|
|||
44 | }; |
||
45 | |||
46 | export const addAjaxEvents = (request, config, resolver) => { |
||
47 | |||
48 | const getResponse = () => { |
||
49 | try { |
||
50 | resolver(JSON.parse(request.responseText)); |
||
51 | } |
||
52 | catch (e) { |
||
53 | /* eslint-disable no-console */ |
||
54 | console.log(e); |
||
0 ignored issues
–
show
|
|||
55 | /* eslint-enable no-console */ |
||
56 | } |
||
57 | }; |
||
58 | |||
59 | request.addEventListener( |
||
60 | 'load', getResponse.bind(config.onSuccess, config.onSuccess) |
||
61 | ); |
||
62 | }; |
||
63 | |||
64 | export const buildQueryString = (config = {}) => { |
||
65 | |||
66 | const ret = { |
||
67 | route: config.route + '?' + '_dc=' + Date.now() + '&' |
||
68 | }; |
||
69 | |||
70 | if (!config.queryStringParams) { |
||
71 | return ret; |
||
72 | } |
||
73 | |||
74 | for (const key of Object.keys(config.queryStringParams)) { |
||
75 | if (config.queryStringParams[key]) { |
||
76 | ret.route += key + '=' + config.queryStringParams[key] + '&'; |
||
77 | } |
||
78 | } |
||
79 | |||
80 | return ret; |
||
81 | }; |
||
82 | |||
83 | export default Api; |
||
84 |
This checks looks for references to variables that have not been declared. This is most likey a typographical error or a variable has been renamed.
To learn more about declaring variables in Javascript, see the MDN.