Comparing version 0.1.2 to 0.2.0
118
chain-xhr.js
@@ -735,13 +735,51 @@ function createCommonjsModule(fn, module) { | ||
function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) { | ||
try { | ||
var info = gen[key](arg); | ||
var value = info.value; | ||
} catch (error) { | ||
reject(error); | ||
return; | ||
} | ||
if (info.done) { | ||
resolve(value); | ||
} else { | ||
Promise.resolve(value).then(_next, _throw); | ||
} | ||
} | ||
function _asyncToGenerator(fn) { | ||
return function () { | ||
var self = this, | ||
args = arguments; | ||
return new Promise(function (resolve, reject) { | ||
var gen = fn.apply(self, args); | ||
function _next(value) { | ||
asyncGeneratorStep(gen, resolve, reject, _next, _throw, "next", value); | ||
} | ||
function _throw(err) { | ||
asyncGeneratorStep(gen, resolve, reject, _next, _throw, "throw", err); | ||
} | ||
_next(undefined); | ||
}); | ||
}; | ||
} | ||
var asyncToGenerator = _asyncToGenerator; | ||
var _typeof_1 = createCommonjsModule(function (module) { | ||
function _typeof2(obj) { if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof2 = function _typeof2(obj) { return typeof obj; }; } else { _typeof2 = function _typeof2(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof2(obj); } | ||
function _typeof(obj) { | ||
"@babel/helpers - typeof"; | ||
function _typeof(obj) { | ||
if (typeof Symbol === "function" && _typeof2(Symbol.iterator) === "symbol") { | ||
if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { | ||
module.exports = _typeof = function _typeof(obj) { | ||
return _typeof2(obj); | ||
return typeof obj; | ||
}; | ||
} else { | ||
module.exports = _typeof = function _typeof(obj) { | ||
return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : _typeof2(obj); | ||
return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; | ||
}; | ||
@@ -883,3 +921,3 @@ } | ||
if (!this.METHODS[methodNormalized]) throw new Error('An unsupported http request method was chosen'); | ||
if (!this.METHODS.hasOwnProperty(methodNormalized)) throw new Error('An unsupported http request method was chosen'); | ||
this._request.method = methodNormalized; | ||
@@ -1043,41 +1081,51 @@ return this; | ||
key: "send", | ||
value: function send() { | ||
var _this = this; | ||
value: function () { | ||
var _send = asyncToGenerator( | ||
/*#__PURE__*/ | ||
regenerator.mark(function _callee() { | ||
var _this = this; | ||
return regenerator.async(function send$(_context) { | ||
while (1) { | ||
switch (_context.prev = _context.next) { | ||
case 0: | ||
return _context.abrupt("return", new Promise(function (resolve, reject) { | ||
_this._request.queryParams.map(function (queryParam) { | ||
return _this._request.url.searchParams.append(queryParam.key, queryParam.value); | ||
}); | ||
return regenerator.wrap(function _callee$(_context) { | ||
while (1) { | ||
switch (_context.prev = _context.next) { | ||
case 0: | ||
return _context.abrupt("return", new Promise(function (resolve, reject) { | ||
_this._request.queryParams.map(function (queryParam) { | ||
return _this._request.url.searchParams.append(queryParam.key, queryParam.value); | ||
}); | ||
_this._XHR = new XMLHttpRequest(); | ||
_this._XHR = new XMLHttpRequest(); | ||
_this._XHR.addEventListener('readystatechange', function () { | ||
if (_this._XHR.readyState === 4 && _this._XHR.status >= 200) resolve(_this._XHR.response);else if (_this._XHR.status >= 400 && _this._XHR.status <= 600) reject(); | ||
}); | ||
_this._XHR.addEventListener('readystatechange', function () { | ||
if (_this._XHR.readyState === 4 && _this._XHR.status >= 200) resolve(_this._XHR.response);else if (_this._XHR.status >= 400 && _this._XHR.status <= 600) reject(); | ||
}); | ||
_this._XHR.addEventListener('error', function (err) { | ||
return reject(err); | ||
}); | ||
_this._XHR.addEventListener('error', function (err) { | ||
return reject(err); | ||
}); | ||
_this._XHR.open(_this._request.method, _this._request.url.href, true); | ||
_this._XHR.open(_this._request.method, _this._request.url.href, true); | ||
_this._XHR.responseType = _this._request.responseType; | ||
_this._XHR.withCredentials = _this._request.withCredentials; | ||
_this._XHR.responseType = _this._request.responseType; | ||
_this._XHR.withCredentials = _this._request.withCredentials; | ||
_this._XHR.setRequestHeader('Content-Type', _this._request.contentType); | ||
_this._XHR.setRequestHeader('Content-Type', _this._request.contentType); | ||
_this._XHR.send(_this._request.data); | ||
})); | ||
_this._XHR.send(_this._request.data); | ||
})); | ||
case 1: | ||
case "end": | ||
return _context.stop(); | ||
case 1: | ||
case "end": | ||
return _context.stop(); | ||
} | ||
} | ||
} | ||
}); | ||
} | ||
}, _callee); | ||
})); | ||
function send() { | ||
return _send.apply(this, arguments); | ||
} | ||
return send; | ||
}() | ||
}]); | ||
@@ -1084,0 +1132,0 @@ |
@@ -0,1 +1,15 @@ | ||
0.2.0 / 2019-02-02 | ||
================== | ||
* [FEATURE] Defined the Methods interface more clearly. | ||
* [TEST] Changed the test setup to use require instead of import. | ||
* [TEST] Added @ava/babel due to problems using import in tests. | ||
* [MISC] Updated dependencies to their latest versions. | ||
* [MISC] Updated license year to reflect year change. | ||
* [MISC] Removed unnecessary spacing. | ||
0.1.3 / 2019-12-19 | ||
================== | ||
* [MISC] Updated dependencies to their latest versions. | ||
* [MISC] Added more badges to README. | ||
0.1.2 / 2019-11-10 | ||
@@ -13,2 +27,2 @@ ================== | ||
================== | ||
* Initial release | ||
* Initial release |
export {}; |
@@ -7,2 +7,4 @@ 'use strict'; | ||
var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator")); | ||
var _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof")); | ||
@@ -97,3 +99,3 @@ | ||
if (!this.METHODS[methodNormalized]) throw new Error('An unsupported http request method was chosen'); | ||
if (!this.METHODS.hasOwnProperty(methodNormalized)) throw new Error('An unsupported http request method was chosen'); | ||
this._request.method = methodNormalized; | ||
@@ -257,44 +259,54 @@ return this; | ||
key: "send", | ||
value: function send() { | ||
var _this = this; | ||
value: function () { | ||
var _send = (0, _asyncToGenerator2["default"])( | ||
/*#__PURE__*/ | ||
_regenerator["default"].mark(function _callee() { | ||
var _this = this; | ||
return _regenerator["default"].async(function send$(_context) { | ||
while (1) { | ||
switch (_context.prev = _context.next) { | ||
case 0: | ||
return _context.abrupt("return", new Promise(function (resolve, reject) { | ||
_this._request.queryParams.map(function (queryParam) { | ||
return _this._request.url.searchParams.append(queryParam.key, queryParam.value); | ||
}); | ||
return _regenerator["default"].wrap(function _callee$(_context) { | ||
while (1) { | ||
switch (_context.prev = _context.next) { | ||
case 0: | ||
return _context.abrupt("return", new Promise(function (resolve, reject) { | ||
_this._request.queryParams.map(function (queryParam) { | ||
return _this._request.url.searchParams.append(queryParam.key, queryParam.value); | ||
}); | ||
_this._XHR = new XMLHttpRequest(); | ||
_this._XHR = new XMLHttpRequest(); | ||
_this._XHR.addEventListener('readystatechange', function () { | ||
if (_this._XHR.readyState === 4 && _this._XHR.status >= 200) resolve(_this._XHR.response);else if (_this._XHR.status >= 400 && _this._XHR.status <= 600) reject(); | ||
}); | ||
_this._XHR.addEventListener('readystatechange', function () { | ||
if (_this._XHR.readyState === 4 && _this._XHR.status >= 200) resolve(_this._XHR.response);else if (_this._XHR.status >= 400 && _this._XHR.status <= 600) reject(); | ||
}); | ||
_this._XHR.addEventListener('error', function (err) { | ||
return reject(err); | ||
}); | ||
_this._XHR.addEventListener('error', function (err) { | ||
return reject(err); | ||
}); | ||
_this._XHR.open(_this._request.method, _this._request.url.href, true); | ||
_this._XHR.open(_this._request.method, _this._request.url.href, true); | ||
_this._XHR.responseType = _this._request.responseType; | ||
_this._XHR.withCredentials = _this._request.withCredentials; | ||
_this._XHR.responseType = _this._request.responseType; | ||
_this._XHR.withCredentials = _this._request.withCredentials; | ||
_this._XHR.setRequestHeader('Content-Type', _this._request.contentType); | ||
_this._XHR.setRequestHeader('Content-Type', _this._request.contentType); | ||
_this._XHR.send(_this._request.data); | ||
})); | ||
_this._XHR.send(_this._request.data); | ||
})); | ||
case 1: | ||
case "end": | ||
return _context.stop(); | ||
case 1: | ||
case "end": | ||
return _context.stop(); | ||
} | ||
} | ||
} | ||
}); | ||
} | ||
}, _callee); | ||
})); | ||
function send() { | ||
return _send.apply(this, arguments); | ||
} | ||
return send; | ||
}() | ||
}]); | ||
return ChainXHR; | ||
}(), _temp); | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/index.ts"],"names":["module","exports","GET","POST","PUT","DELETE","method","METHODS","withCredentials","contentType","queryParams","responseType","url","_request","URL","methodNormalized","toUpperCase","Error","key","value","valueNormalized","toString","push","data","FormData","JSON","stringify","_XHR","abort","Promise","resolve","reject","map","queryParam","searchParams","append","XMLHttpRequest","addEventListener","readyState","status","response","err","open","href","setRequestHeader","send"],"mappings":"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","sourcesContent":["'use strict'\r\n\r\nimport Methods from './interfaces/Methods';\r\nimport Request from './interfaces/Request';\r\n\r\n/**\r\n * chain-xhr provides an easy to use promise bbased chainable API that makes it simple to create any kind of XHR request.\r\n */\r\nmodule.exports = class ChainXHR {\r\n\r\n  /**\r\n   * A constant that can be used to select the requested http request method from.\r\n   * \r\n   * Even if a request method is provided by hand, it will be double checked against the ones defined here to make sure that it\r\n   * is a valid request method.\r\n   * \r\n   * @property {Object}\r\n   */\r\n  METHODS: Methods = {\r\n    GET: 'GET',\r\n    POST: 'POST',\r\n    PUT: 'PUT',\r\n    DELETE: 'DELETE'\r\n  };\r\n\r\n  /**\r\n   * A reference to the request object that will be used to build and send the final request.\r\n   * \r\n   * @private\r\n   * \r\n   * @property {Request}\r\n   */\r\n  private _request: Request = {\r\n    method: this.METHODS.GET,\r\n    withCredentials: false,\r\n    contentType: 'application/json',\r\n    queryParams: [],\r\n    responseType: 'text'\r\n  };\r\n\r\n  /**\r\n   * A reference to the actual XMLHttpRequest.\r\n   * \r\n   * @private\r\n   * \r\n   * @property {XMLHttpRequest}\r\n   */\r\n  private _XHR!: XMLHttpRequest;\r\n\r\n  /**\r\n   * Set the URL that this request should be sent to.\r\n   * \r\n   * This request can fail if an invalid url is provided so it is recommended to wrap it in a try..catch if you believe there is any\r\n   * chance of that happening.\r\n   * \r\n   * @param {string} url The url to send this request to.\r\n   * \r\n   * @returns {ChainXHR} Returns this for chaining.\r\n   * \r\n   * @example\r\n   * \r\n   * const request = new ChainXHR();\r\n   * \r\n   * request\r\n   *  .url('https://example.com');\r\n   */\r\n  url(url: string): ChainXHR {\r\n\r\n    this._request.url = new URL(url);\r\n\r\n    return this;\r\n\r\n  }\r\n\r\n  /**\r\n   * Sets the http request method to be used by this XHR request.\r\n   * \r\n   * By default this property is set to 'GET'.\r\n   * \r\n   * You can choose to type in a string directly such as 'GET' or 'get' or you can use the REQUEST constant of ChainXHR to set this.\r\n   * \r\n   * @param {string} method The http request method to use for this XHR request.\r\n   * \r\n   * @returns {ChainXHR} Returns this for chaining.\r\n   * \r\n   * @example\r\n   * \r\n   * const request = new ChainXHR();\r\n   * \r\n   * // Using a string directly:\r\n   * request\r\n   *  .url('https://example.com')\r\n   *  .method('GET');\r\n   * \r\n   * // Using the constant:\r\n   * request\r\n   *  .url('https://example.com');\r\n   *  .method(request.METHOD.GET);\r\n   */\r\n  method(method: string): ChainXHR {\r\n\r\n    const methodNormalized = method.toUpperCase();\r\n\r\n    if (!this.METHODS[methodNormalized]) throw new Error('An unsupported http request method was chosen');\r\n\r\n    this._request.method = methodNormalized;\r\n\r\n    return this;\r\n\r\n  }\r\n\r\n  /**\r\n   * Sets this request to be made with credentials such as cookies, authorization headers, or TLS certificates.\r\n   * \r\n   * By default this property is set to false.\r\n   * \r\n   * This has no effect on same-site requests.\r\n   * \r\n   * @returns {ChainXHR} Returns this for chaining.\r\n   * \r\n   * @example\r\n   * \r\n   * const request = new ChainXHR();\r\n   * \r\n   * request\r\n   *  .withCredentials();\r\n   */\r\n  withCredentials(): ChainXHR {\r\n\r\n    this._request.withCredentials = true;\r\n\r\n    return this;\r\n\r\n  }\r\n\r\n  /**\r\n   * Sets the content type header which indicates what type of content is being send to the endpoint.\r\n   * \r\n   * By default this is set to 'application/json'.\r\n   * \r\n   * @param {string} contentType The type of content that is being sent to the server.\r\n   * \r\n   * @returns {ChainXHR}\r\n   * \r\n   * @example\r\n   * \r\n   * const request = new ChainXHR();\r\n   * \r\n   * request\r\n   *  .contentType('x-www-formdata');\r\n   */\r\n  contentType(contentType: string): ChainXHR {\r\n\r\n    this._request.contentType = contentType;\r\n\r\n    return this;\r\n\r\n  }\r\n\r\n  /**\r\n   * Adds a query parameter to send with the request.\r\n   * \r\n   * This should be chained multiple times to add multiple query parameters.\r\n   * \r\n   * @param {string} key The key of the query parameter to add.\r\n   * @param {string|number|boolean} value The value of the key added.\r\n   * \r\n   * @returns {ChainXHR}\r\n   * \r\n   * @example\r\n   * \r\n   * const request = new ChainXHR();\r\n   * \r\n   * request\r\n   *  .queryParam('hello', 'world')\r\n   *  .queryParam('count', 5);\r\n   */\r\n  queryParam(key: string, value: (string | number | boolean)): ChainXHR {\r\n\r\n    const valueNormalized: string = value.toString();\r\n\r\n    this._request.queryParams.push({ key: key, value: valueNormalized });\r\n\r\n    return this;\r\n\r\n  }\r\n\r\n  /**\r\n   * Sets the data to send through with the request.\r\n   * \r\n   * @param {*} data The data to send through with the request.\r\n   * \r\n   * @returns {ChainXHR}\r\n   * \r\n   * @example\r\n   * \r\n   * const request = new ChainXHR();\r\n   * \r\n   * // Sending an object.\r\n   * const obj = { hello: 'world', year: 2019 };\r\n   * \r\n   * request\r\n   *  .data(obj);\r\n   * \r\n   * // Sending key value pairs individually.\r\n   * request\r\n   *  .data('hello', 'world')\r\n   *  .data('year', 2019);\r\n   */\r\n  data(data: (Object | string)): ChainXHR {\r\n\r\n    if (typeof data === 'object' && ((data instanceof FormData) === false)) data = JSON.stringify(data);\r\n\r\n    this._request.data = data;\r\n\r\n    return this;\r\n\r\n  }\r\n\r\n  /**\r\n   * Specifies that the data returned should be JSON parsed.\r\n   * \r\n   * @returns {ChainXHR}\r\n   */\r\n  json(): ChainXHR {\r\n\r\n    this._request.responseType = 'json';\r\n\r\n    return this;\r\n\r\n  }\r\n\r\n  /**\r\n   * Aborts the request if it already has been sent.\r\n   * \r\n   * When a request is aborted, its readystate is changed to 0 and the status code is set to 0 also.\r\n   * \r\n   * @returns {ChainXHR}\r\n   */\r\n  abort(): ChainXHR {\r\n\r\n    this._XHR.abort();\r\n\r\n    return this;\r\n    \r\n  }\r\n\r\n  /**\r\n   * Indicates that the XHR request is finished being built and is ready to be sent.\r\n   * \r\n   * This should always be the final method used in all requests.\r\n   * \r\n   * @async\r\n   * \r\n   * @returns {Promise<any>}\r\n   * \r\n   * @example\r\n   * \r\n   * const request = new ChainXHR();\r\n   * \r\n   * request\r\n   *  .url('https://example.com')\r\n   *  .method('GET')\r\n   *  .send();\r\n   */\r\n  async send(): Promise<any> {\r\n\r\n    return new Promise((resolve, reject) => {\r\n\r\n      this._request.queryParams.map(queryParam => this._request.url!.searchParams.append(queryParam.key, queryParam.value));\r\n\r\n      this._XHR = new XMLHttpRequest();\r\n\r\n      this._XHR.addEventListener('readystatechange', () => {\r\n\r\n        if (this._XHR.readyState === 4 && this._XHR.status >= 200) resolve(this._XHR.response);\r\n\r\n        else if (this._XHR.status >= 400 && this._XHR.status <= 600) reject();\r\n\r\n      });\r\n\r\n      this._XHR.addEventListener('error', (err: Event) => reject(err));\r\n\r\n      this._XHR.open(this._request.method, this._request.url!.href, true);\r\n\r\n      this._XHR.responseType = <XMLHttpRequestResponseType>this._request.responseType;\r\n\r\n      this._XHR.withCredentials = this._request.withCredentials;\r\n\r\n      this._XHR.setRequestHeader('Content-Type', this._request.contentType);\r\n\r\n      this._XHR.send(this._request.data!);\r\n\r\n    });\r\n\r\n  }\r\n\r\n};"]} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/index.ts"],"names":["module","exports","GET","POST","PUT","DELETE","method","METHODS","withCredentials","contentType","queryParams","responseType","url","_request","URL","methodNormalized","toUpperCase","hasOwnProperty","Error","key","value","valueNormalized","toString","push","data","FormData","JSON","stringify","_XHR","abort","Promise","resolve","reject","map","queryParam","searchParams","append","XMLHttpRequest","addEventListener","readyState","status","response","err","open","href","setRequestHeader","send"],"mappings":"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","sourcesContent":["'use strict'\n\nimport Methods from './interfaces/Methods';\nimport Request from './interfaces/Request';\n\n/**\n * chain-xhr provides an easy to use promise bbased chainable API that makes it simple to create any kind of XHR request.\n */\nmodule.exports = class ChainXHR {\n  /** * A constant that can be used to select the requested http request method from.  * \n   * Even if a request method is provided by hand, it will be double checked against the ones defined here to make sure that it\n   * is a valid request method.\n   * \n   * @property {Object}\n   */\n  METHODS: Methods = {\n    GET: 'GET',\n    POST: 'POST',\n    PUT: 'PUT',\n    DELETE: 'DELETE'\n  };\n\n  /**\n   * A reference to the request object that will be used to build and send the final request.\n   * \n   * @private\n   * \n   * @property {Request}\n   */\n  private _request: Request = {\n    method: this.METHODS.GET,\n    withCredentials: false,\n    contentType: 'application/json',\n    queryParams: [],\n    responseType: 'text'\n  };\n\n  /**\n   * A reference to the actual XMLHttpRequest.\n   * \n   * @private\n   * \n   * @property {XMLHttpRequest}\n   */\n  private _XHR!: XMLHttpRequest;\n\n  /**\n   * Set the URL that this request should be sent to.\n   * \n   * This request can fail if an invalid url is provided so it is recommended to wrap it in a try..catch if you believe there is any\n   * chance of that happening.\n   * \n   * @param {string} url The url to send this request to.\n   * \n   * @returns {ChainXHR} Returns this for chaining.\n   * \n   * @example\n   * \n   * const request = new ChainXHR();\n   * \n   * request\n   *  .url('https://example.com');\n   */\n  url(url: string): ChainXHR {\n    this._request.url = new URL(url);\n\n    return this;\n  }\n\n  /**\n   * Sets the http request method to be used by this XHR request.\n   * \n   * By default this property is set to 'GET'.\n   * \n   * You can choose to type in a string directly such as 'GET' or 'get' or you can use the REQUEST constant of ChainXHR to set this.\n   * \n   * @param {string} method The http request method to use for this XHR request.\n   * \n   * @returns {ChainXHR} Returns this for chaining.\n   * \n   * @example\n   * \n   * const request = new ChainXHR();\n   * \n   * // Using a string directly:\n   * request\n   *  .url('https://example.com')\n   *  .method('GET');\n   * \n   * // Using the constant:\n   * request\n   *  .url('https://example.com');\n   *  .method(request.METHOD.GET);\n   */\n  method(method: string): ChainXHR {\n    const methodNormalized = method.toUpperCase();\n\n    if (!this.METHODS.hasOwnProperty(methodNormalized)) throw new Error('An unsupported http request method was chosen');\n\n    this._request.method = methodNormalized;\n\n    return this;\n  }\n\n  /**\n   * Sets this request to be made with credentials such as cookies, authorization headers, or TLS certificates.\n   * \n   * By default this property is set to false.\n   * \n   * This has no effect on same-site requests.\n   * \n   * @returns {ChainXHR} Returns this for chaining.\n   * \n   * @example\n   * \n   * const request = new ChainXHR();\n   * \n   * request\n   *  .withCredentials();\n   */\n  withCredentials(): ChainXHR {\n    this._request.withCredentials = true;\n\n    return this;\n  }\n\n  /**\n   * Sets the content type header which indicates what type of content is being send to the endpoint.\n   * \n   * By default this is set to 'application/json'.\n   * \n   * @param {string} contentType The type of content that is being sent to the server.\n   * \n   * @returns {ChainXHR}\n   * \n   * @example\n   * \n   * const request = new ChainXHR();\n   * \n   * request\n   *  .contentType('x-www-formdata');\n   */\n  contentType(contentType: string): ChainXHR {\n    this._request.contentType = contentType;\n\n    return this;\n  }\n\n  /**\n   * Adds a query parameter to send with the request.\n   * \n   * This should be chained multiple times to add multiple query parameters.\n   * \n   * @param {string} key The key of the query parameter to add.\n   * @param {string|number|boolean} value The value of the key added.\n   * \n   * @returns {ChainXHR}\n   * \n   * @example\n   * \n   * const request = new ChainXHR();\n   * \n   * request\n   *  .queryParam('hello', 'world')\n   *  .queryParam('count', 5);\n   */\n  queryParam(key: string, value: (string | number | boolean)): ChainXHR {\n    const valueNormalized: string = value.toString();\n\n    this._request.queryParams.push({ key: key, value: valueNormalized });\n\n    return this;\n  }\n\n  /**\n   * Sets the data to send through with the request.\n   * \n   * @param {*} data The data to send through with the request.\n   * \n   * @returns {ChainXHR}\n   * \n   * @example\n   * \n   * const request = new ChainXHR();\n   * \n   * // Sending an object.\n   * const obj = { hello: 'world', year: 2019 };\n   * \n   * request\n   *  .data(obj);\n   * \n   * // Sending key value pairs individually.\n   * request\n   *  .data('hello', 'world')\n   *  .data('year', 2019);\n   */\n  data(data: (Object | string)): ChainXHR {\n    if (typeof data === 'object' && ((data instanceof FormData) === false)) data = JSON.stringify(data);\n\n    this._request.data = data;\n\n    return this;\n  }\n\n  /**\n   * Specifies that the data returned should be JSON parsed.\n   * \n   * @returns {ChainXHR}\n   */\n  json(): ChainXHR {\n    this._request.responseType = 'json';\n\n    return this;\n  }\n\n  /**\n   * Aborts the request if it already has been sent.\n   * \n   * When a request is aborted, its readystate is changed to 0 and the status code is set to 0 also.\n   * \n   * @returns {ChainXHR}\n   */\n  abort(): ChainXHR {\n    this._XHR.abort();\n\n    return this;\n  }\n\n  /**\n   * Indicates that the XHR request is finished being built and is ready to be sent.\n   * \n   * This should always be the final method used in all requests.\n   * \n   * @async\n   * \n   * @returns {Promise<any>}\n   * \n   * @example\n   * \n   * const request = new ChainXHR();\n   * \n   * request\n   *  .url('https://example.com')\n   *  .method('GET')\n   *  .send();\n   */\n  async send(): Promise<any> {\n    return new Promise((resolve, reject) => {\n      this._request.queryParams.map(queryParam => this._request.url!.searchParams.append(queryParam.key, queryParam.value));\n\n      this._XHR = new XMLHttpRequest();\n\n      this._XHR.addEventListener('readystatechange', () => {\n        if (this._XHR.readyState === 4 && this._XHR.status >= 200) resolve(this._XHR.response);\n        else if (this._XHR.status >= 400 && this._XHR.status <= 600) reject();\n      });\n\n      this._XHR.addEventListener('error', (err: Event) => reject(err));\n\n      this._XHR.open(this._request.method, this._request.url!.href, true);\n\n      this._XHR.responseType = <XMLHttpRequestResponseType>this._request.responseType;\n\n      this._XHR.withCredentials = this._request.withCredentials;\n\n      this._XHR.setRequestHeader('Content-Type', this._request.contentType);\n\n      this._XHR.send(this._request.data!);\n    });\n  }\n};\n"]} |
@@ -5,3 +5,6 @@ /** | ||
export default interface Methods { | ||
[method: string]: string; | ||
GET: string; | ||
POST: string; | ||
PUT: string; | ||
DELETE: string; | ||
} |
@@ -7,2 +7,2 @@ 'use strict'; | ||
; | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9pbnRlcmZhY2VzL01ldGhvZHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7QUFFQTs7OztBQU9DIiwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBzdHJpY3QnXHJcblxyXG4vKipcclxuICogRGVmaW5lcyB0aGUgc3RydWN0dXJlIG9mIHRoZSBNRVRIT0RTIGNvbnN0YW50IE9iamVjdC5cclxuICovXHJcbmV4cG9ydCBkZWZhdWx0IGludGVyZmFjZSBNZXRob2RzIHtcclxuXHJcbiAgW21ldGhvZDogc3RyaW5nXTogc3RyaW5nO1xyXG5cclxufTsiXX0= | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9pbnRlcmZhY2VzL01ldGhvZHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7QUFFQTs7OztBQVFDIiwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBzdHJpY3QnXG5cbi8qKlxuICogRGVmaW5lcyB0aGUgc3RydWN0dXJlIG9mIHRoZSBNRVRIT0RTIGNvbnN0YW50IE9iamVjdC5cbiAqL1xuZXhwb3J0IGRlZmF1bHQgaW50ZXJmYWNlIE1ldGhvZHMge1xuICBHRVQ6IHN0cmluZztcbiAgUE9TVDogc3RyaW5nO1xuICBQVVQ6IHN0cmluZztcbiAgREVMRVRFOiBzdHJpbmc7XG59O1xuIl19 |
@@ -0,0 +0,0 @@ /** |
@@ -7,2 +7,2 @@ 'use strict'; | ||
; | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9pbnRlcmZhY2VzL1JlcXVlc3QudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7QUFFQTs7OztBQXdDQyIsInNvdXJjZXNDb250ZW50IjpbIid1c2Ugc3RyaWN0J1xyXG5cclxuLyoqXHJcbiAqIERlZmluZXMgdGhlIHN0cnVjdHVyZSBvZiBhIFhIUiByZXF1ZXN0LlxyXG4gKi9cclxuZXhwb3J0IGRlZmF1bHQgaW50ZXJmYWNlIFJlcXVlc3Qge1xyXG5cclxuICAvKipcclxuICAgKiBUaGUgVVJMIHRoYXQgdGhlIHJlcXVlc3Qgc2hvdWxkIGJlIHNlbnQgdG8uXHJcbiAgICovXHJcbiAgdXJsPzogVVJMO1xyXG5cclxuICAvKipcclxuICAgKiBUaGUgaHR0cCByZXF1ZXN0IG1ldGhvZCB0aGF0IHNob3VsZCBiZSB1c2VkIGZvciB0aGlzIHJlcXVlc3QuXHJcbiAgICovXHJcbiAgbWV0aG9kOiBzdHJpbmc7XHJcblxyXG4gIC8qKlxyXG4gICAqIEluZGljYXRlcyB3aGV0aGVyIHRoaXMgcmVxdWVzdCB3aWxsIGJlIG1hZGUgd2l0aCBjcmVkZW50aWFscyBvciBub3QuXHJcbiAgICovXHJcbiAgd2l0aENyZWRlbnRpYWxzOiBib29sZWFuO1xyXG5cclxuICAvKipcclxuICAgKiBUaGUgY29udGVudCB0eXBlIG9mIHRoZSBjb250ZW50IGJlaW5nIHNlbnQgdG8gdGhlIGVuZHBvaW50LlxyXG4gICAqL1xyXG4gIGNvbnRlbnRUeXBlOiBzdHJpbmc7XHJcblxyXG4gIC8qKlxyXG4gICAqIFRoZSBxdWVyeSBwYXJhbWV0ZXJzIHRvIGFkZCB0byB0aGUgZW5kIG9mIHRoZSByZXF1ZXN0IHVybC5cclxuICAgKi9cclxuICBxdWVyeVBhcmFtczogQXJyYXk8YW55PjtcclxuXHJcbiAgLyoqXHJcbiAgICogVGhlIHR5cGUgb2YgZGF0YSB0aGF0IHRoZSByZXNwb25zZSBzaG91bGQgYmUuXHJcbiAgICovXHJcbiAgcmVzcG9uc2VUeXBlOiBzdHJpbmc7XHJcblxyXG4gIC8qKlxyXG4gICAqIFRoZSBkYXRhIHRvIHNlbmQgd2l0aCB0aGUgcmVxdWVzdC5cclxuICAgKi9cclxuICBkYXRhPzogYW55O1xyXG5cclxufTsiXX0= | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9pbnRlcmZhY2VzL1JlcXVlc3QudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7QUFFQTs7OztBQXNDQyIsInNvdXJjZXNDb250ZW50IjpbIid1c2Ugc3RyaWN0J1xuXG4vKipcbiAqIERlZmluZXMgdGhlIHN0cnVjdHVyZSBvZiBhIFhIUiByZXF1ZXN0LlxuICovXG5leHBvcnQgZGVmYXVsdCBpbnRlcmZhY2UgUmVxdWVzdCB7XG4gIC8qKlxuICAgKiBUaGUgVVJMIHRoYXQgdGhlIHJlcXVlc3Qgc2hvdWxkIGJlIHNlbnQgdG8uXG4gICAqL1xuICB1cmw/OiBVUkw7XG5cbiAgLyoqXG4gICAqIFRoZSBodHRwIHJlcXVlc3QgbWV0aG9kIHRoYXQgc2hvdWxkIGJlIHVzZWQgZm9yIHRoaXMgcmVxdWVzdC5cbiAgICovXG4gIG1ldGhvZDogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBJbmRpY2F0ZXMgd2hldGhlciB0aGlzIHJlcXVlc3Qgd2lsbCBiZSBtYWRlIHdpdGggY3JlZGVudGlhbHMgb3Igbm90LlxuICAgKi9cbiAgd2l0aENyZWRlbnRpYWxzOiBib29sZWFuO1xuXG4gIC8qKlxuICAgKiBUaGUgY29udGVudCB0eXBlIG9mIHRoZSBjb250ZW50IGJlaW5nIHNlbnQgdG8gdGhlIGVuZHBvaW50LlxuICAgKi9cbiAgY29udGVudFR5cGU6IHN0cmluZztcblxuICAvKipcbiAgICogVGhlIHF1ZXJ5IHBhcmFtZXRlcnMgdG8gYWRkIHRvIHRoZSBlbmQgb2YgdGhlIHJlcXVlc3QgdXJsLlxuICAgKi9cbiAgcXVlcnlQYXJhbXM6IEFycmF5PGFueT47XG5cbiAgLyoqXG4gICAqIFRoZSB0eXBlIG9mIGRhdGEgdGhhdCB0aGUgcmVzcG9uc2Ugc2hvdWxkIGJlLlxuICAgKi9cbiAgcmVzcG9uc2VUeXBlOiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIFRoZSBkYXRhIHRvIHNlbmQgd2l0aCB0aGUgcmVxdWVzdC5cbiAgICovXG4gIGRhdGE/OiBhbnk7XG59O1xuIl19 |
{ | ||
"name": "chain-xhr", | ||
"version": "0.1.2", | ||
"description": "As stated in the MDN docs, a XMLHttpRequest is the safest and most reliable way to make HTTP requests. chain-xhr aims to make making XHR requests as simple as possible through a chainable API", | ||
"version": "0.2.0", | ||
"description": "A XMLHttpRequest is the safest and most reliable way to make HTTP requests and chain-xhr aims to make making XHR requests as simple as possible through a chainable API", | ||
"main": "chain-xhr.js", | ||
@@ -20,3 +20,4 @@ "scripts": { | ||
"./test/_setup-browser-env.js" | ||
] | ||
], | ||
"babel": true | ||
}, | ||
@@ -41,21 +42,22 @@ "repository": { | ||
"devDependencies": { | ||
"@babel/cli": "^7.7.0", | ||
"@babel/core": "^7.7.2", | ||
"@babel/plugin-proposal-class-properties": "^7.7.0", | ||
"@babel/plugin-proposal-numeric-separator": "^7.2.0", | ||
"@babel/plugin-proposal-object-rest-spread": "^7.6.2", | ||
"@babel/plugin-transform-runtime": "^7.6.2", | ||
"@babel/preset-env": "^7.7.1", | ||
"@babel/preset-typescript": "^7.7.2", | ||
"ava": "^2.4.0", | ||
"@ava/babel": "^1.0.0", | ||
"@babel/cli": "^7.8.4", | ||
"@babel/core": "^7.8.4", | ||
"@babel/plugin-proposal-class-properties": "^7.8.3", | ||
"@babel/plugin-proposal-numeric-separator": "^7.8.3", | ||
"@babel/plugin-proposal-object-rest-spread": "^7.8.3", | ||
"@babel/plugin-transform-runtime": "^7.8.3", | ||
"@babel/preset-env": "^7.8.4", | ||
"@babel/preset-typescript": "^7.8.3", | ||
"ava": "^3.2.0", | ||
"browser-env": "^3.3.0", | ||
"rollup": "^1.26.4", | ||
"rollup": "^1.31.0", | ||
"rollup-plugin-babel": "^4.3.3", | ||
"rollup-plugin-commonjs": "^10.1.0", | ||
"rollup-plugin-node-resolve": "^5.2.0", | ||
"typescript": "^3.7.2" | ||
"typescript": "^3.7.5" | ||
}, | ||
"dependencies": { | ||
"@babel/runtime": "^7.7.2" | ||
"@babel/runtime": "^7.8.4" | ||
} | ||
} |
@@ -13,8 +13,9 @@ <div align="center"> | ||
[![NPM version](https://img.shields.io/npm/v/chain-xhr.svg?style=flat)](https://www.npmjs.com/package/chain-xhr) | ||
[![Known Vulnerabilities](https://snyk.io/test/github/robertcorponoi/chain-xhr/badge.svg)](https://snyk.io/test/github/robertcorponoi/chain-xhr) | ||
[![NPM downloads](https://img.shields.io/npm/dm/chain-xhr.svg?style=flat)](https://www.npmjs.com/package/chain-xhr) | ||
<a href="https://badge.fury.io/js/chain-xhr"><img src="https://img.shields.io/github/issues/robertcorponoi/chain-xhr.svg" alt="issues" height="18"></a> | ||
<a href="https://badge.fury.io/js/chain-xhr"><img src="https://img.shields.io/github/license/robertcorponoi/chain-xhr.svg" alt="license" height="18"></a> | ||
[![Gitter](https://badges.gitter.im/gitterHQ/gitter.svg)](https://gitter.im/robertcorponoi) | ||
[![NPM version](https://img.shields.io/npm/v/chain-xhr.svg?style=flat)](https://www.npmjs.com/package/chain-xhr) | ||
[![Known Vulnerabilities](https://snyk.io/test/github/robertcorponoi/chain-xhr/badge.svg)](https://snyk.io/test/github/robertcorponoi/chain-xhr) | ||
![npm](https://img.shields.io/npm/dt/chain-xhr) | ||
[![NPM downloads](https://img.shields.io/npm/dm/chain-xhr.svg?style=flat)](https://www.npmjs.com/package/chain-xhr) | ||
<a href="https://badge.fury.io/js/chain-xhr"><img src="https://img.shields.io/github/issues/robertcorponoi/chain-xhr.svg" alt="issues" height="18"></a> | ||
<a href="https://badge.fury.io/js/chain-xhr"><img src="https://img.shields.io/github/license/robertcorponoi/chain-xhr.svg" alt="license" height="18"></a> | ||
[![Gitter](https://badges.gitter.im/gitterHQ/gitter.svg)](https://gitter.im/robertcorponoi) | ||
@@ -21,0 +22,0 @@ </div> |
@@ -0,0 +0,0 @@ 'use strict' |
@@ -10,6 +10,3 @@ 'use strict' | ||
module.exports = class ChainXHR { | ||
/** | ||
* A constant that can be used to select the requested http request method from. | ||
* | ||
/** * A constant that can be used to select the requested http request method from. * | ||
* Even if a request method is provided by hand, it will be double checked against the ones defined here to make sure that it | ||
@@ -69,7 +66,5 @@ * is a valid request method. | ||
url(url: string): ChainXHR { | ||
this._request.url = new URL(url); | ||
return this; | ||
} | ||
@@ -103,6 +98,5 @@ | ||
method(method: string): ChainXHR { | ||
const methodNormalized = method.toUpperCase(); | ||
if (!this.METHODS[methodNormalized]) throw new Error('An unsupported http request method was chosen'); | ||
if (!this.METHODS.hasOwnProperty(methodNormalized)) throw new Error('An unsupported http request method was chosen'); | ||
@@ -112,3 +106,2 @@ this._request.method = methodNormalized; | ||
return this; | ||
} | ||
@@ -133,7 +126,5 @@ | ||
withCredentials(): ChainXHR { | ||
this._request.withCredentials = true; | ||
return this; | ||
} | ||
@@ -158,7 +149,5 @@ | ||
contentType(contentType: string): ChainXHR { | ||
this._request.contentType = contentType; | ||
return this; | ||
} | ||
@@ -185,3 +174,2 @@ | ||
queryParam(key: string, value: (string | number | boolean)): ChainXHR { | ||
const valueNormalized: string = value.toString(); | ||
@@ -192,3 +180,2 @@ | ||
return this; | ||
} | ||
@@ -219,3 +206,2 @@ | ||
data(data: (Object | string)): ChainXHR { | ||
if (typeof data === 'object' && ((data instanceof FormData) === false)) data = JSON.stringify(data); | ||
@@ -226,3 +212,2 @@ | ||
return this; | ||
} | ||
@@ -236,7 +221,5 @@ | ||
json(): ChainXHR { | ||
this._request.responseType = 'json'; | ||
return this; | ||
} | ||
@@ -252,7 +235,5 @@ | ||
abort(): ChainXHR { | ||
this._XHR.abort(); | ||
return this; | ||
} | ||
@@ -279,5 +260,3 @@ | ||
async send(): Promise<any> { | ||
return new Promise((resolve, reject) => { | ||
this._request.queryParams.map(queryParam => this._request.url!.searchParams.append(queryParam.key, queryParam.value)); | ||
@@ -288,7 +267,4 @@ | ||
this._XHR.addEventListener('readystatechange', () => { | ||
if (this._XHR.readyState === 4 && this._XHR.status >= 200) resolve(this._XHR.response); | ||
else if (this._XHR.status >= 400 && this._XHR.status <= 600) reject(); | ||
}); | ||
@@ -307,7 +283,4 @@ | ||
this._XHR.send(this._request.data!); | ||
}); | ||
} | ||
}; | ||
}; |
@@ -7,5 +7,6 @@ 'use strict' | ||
export default interface Methods { | ||
[method: string]: string; | ||
}; | ||
GET: string; | ||
POST: string; | ||
PUT: string; | ||
DELETE: string; | ||
}; |
@@ -7,3 +7,2 @@ 'use strict' | ||
export default interface Request { | ||
/** | ||
@@ -43,3 +42,2 @@ * The URL that the request should be sent to. | ||
data?: any; | ||
}; | ||
}; |
'use strict'; | ||
import browserEnv from 'browser-env'; | ||
const browserEnv = require('browser-env'); | ||
browserEnv(); | ||
browserEnv(); |
@@ -0,0 +0,0 @@ 'use strict' |
@@ -0,0 +0,0 @@ { |
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
1723
326
88147
16
Updated@babel/runtime@^7.8.4