├── .gitignore
├── src
├── models.ts
├── index.ts
└── table.ts
├── public
├── index.html
└── js
│ └── index.js
├── tsconfig.json
├── package.json
├── webpack.config.js
└── README.md
/.gitignore:
--------------------------------------------------------------------------------
1 | .vscode
2 | node_modules/
3 |
--------------------------------------------------------------------------------
/src/models.ts:
--------------------------------------------------------------------------------
1 | export interface User{
2 | id: string;
3 | title: string;
4 | body: string;
5 | userId: number;
6 | }
--------------------------------------------------------------------------------
/public/index.html:
--------------------------------------------------------------------------------
1 |
2 |
3 | Listagem de usuários
4 |
5 |
6 |
--------------------------------------------------------------------------------
/src/index.ts:
--------------------------------------------------------------------------------
1 | import axios from 'axios';
2 | import UserTable from './table';
3 |
4 | const userTable = new UserTable()
5 | axios.get('https://reqres.in/api/users')
6 | .then(response => {
7 | userTable.populate(response.data.data);
8 | });
--------------------------------------------------------------------------------
/tsconfig.json:
--------------------------------------------------------------------------------
1 | {
2 | "compilerOptions": {
3 | "moduleResolution": "node",
4 | "outDir": "public",
5 | "module": "es6",
6 | "target": "es5",
7 | "sourceMap": true,
8 | "allowJs": true,
9 | "allowSyntheticDefaultImports": true
10 | }
11 | }
--------------------------------------------------------------------------------
/package.json:
--------------------------------------------------------------------------------
1 | {
2 | "name": "codeedu-typescript-starter",
3 | "version": "1.0.0",
4 | "description": "",
5 | "main": "public/js/index.js",
6 | "scripts": {
7 | "start": "webpack-dev-server",
8 | "dev": "webpack --mode=development",
9 | "build": "webpack --mode=production"
10 | },
11 | "author": "Luiz Carlos",
12 | "license": "ISC",
13 | "dependencies": {
14 | "@types/axios": "^0.14.0",
15 | "axios": "^0.19.2"
16 | },
17 | "devDependencies": {
18 | "ts-loader": "^7.0.5",
19 | "typescript": "^3.9.3",
20 | "webpack": "^4.43.0",
21 | "webpack-cli": "^3.3.11",
22 | "webpack-dev-server": "^3.11.0"
23 | }
24 | }
25 |
--------------------------------------------------------------------------------
/webpack.config.js:
--------------------------------------------------------------------------------
1 | const path = require('path');
2 | const webpack = require('webpack');
3 |
4 | module.exports = (env, argv) => ({
5 | mode: argv.mode === 'development' ? 'development': 'production',
6 | entry: './src/index.ts',
7 | devtool: argv.mode === 'development' ? 'inline-source-map' : false,
8 | output: {
9 | path: path.resolve(__dirname, 'public/js'),
10 | publicPath: '/js',
11 | filename: 'index.js'
12 | },
13 | module: {
14 | rules: [
15 | {
16 | test: /\.ts?$/,
17 | use: 'ts-loader',
18 | exclude: /node_modules/,
19 | },
20 | ],
21 | },
22 | resolve: {
23 | extensions: [ '.ts', '.js' ],
24 | },
25 | devServer: {
26 | contentBase: path.join(__dirname, 'public'),
27 | compress: true,
28 | port: 9000
29 | }
30 | })
--------------------------------------------------------------------------------
/src/table.ts:
--------------------------------------------------------------------------------
1 | import { User } from "./models";
2 |
3 | export default class UserTable {
4 |
5 | table: HTMLTableElement;
6 | thead: HTMLTableSectionElement;
7 | tbody: HTMLTableSectionElement;
8 |
9 | constructor() {
10 | this.table = document.createElement('table');
11 | this.createHeader();
12 | this.tbody = this.table.createTBody();
13 | const body = document.getElementsByTagName('body')[0];
14 | body.appendChild(this.table);
15 | }
16 |
17 | createHeader(){
18 | this.thead = this.table.createTHead();
19 | const hrow = this.thead.insertRow(0);
20 | const columns = ['ID', 'email', 'First Name', 'Last Name', 'Avatar'];
21 | columns.forEach(column => {
22 | const cell = hrow.insertCell(hrow.cells.length);
23 | cell.innerHTML = column;
24 | })
25 |
26 | }
27 |
28 | populate(users: User[]){
29 | users.forEach(user => {
30 | const row = this.tbody.insertRow(this.tbody.rows.length);
31 | for(const field of Object.keys(user)){
32 | const cell = row.insertCell(row.cells.length);
33 | cell.innerHTML = user[field];
34 | }
35 | })
36 | }
37 |
38 | }
--------------------------------------------------------------------------------
/README.md:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 | ## Descrição
6 |
7 | Projeto Front-end para se começar com TypeScript de forma produtiva.
8 |
9 | ## Motivação
10 |
11 | O entendimento do que é o TypeScript é simples, todos sabemos que é uma linguagem de programação com tipagem
12 | para dar outra dinâmica a programação JavaScript.
13 |
14 | Instalar o TypeScript e roda-lo em cima de scripts .ts também é simples.
15 |
16 | Porém, na hora de criar aplicações WEB a história pode ser um pouco diferente.
17 | Temos inicialmente dois problemas:
18 |
19 | * Qual sistema de módulos utilizar para carregar os arquivos JavaScript?
20 | * Como organizar os arquivos de bibliotecas para usar somente os arquivos necessários?
21 |
22 | Hoje já temos o sistema de módulos como ES6 Modules que ajudam a padronizar o carregamento de módulos JavaScript,
23 | porém muitos browsers ainda não suportam este sistema e existem muitas máquinas
24 | que ainda rodam browsers antigos, então retrocompatibilidade é essencial para aplicações WEB.
25 |
26 | E mesmo trabalhando com ES6 Modules e se temos várias bibliotecas de terceiros a usar? Queremos uma forma simples invocar estas bibliotecas
27 | e colocar no projeto apenas os arquivos necessários do projeto.
28 |
29 | Lembre-se que o TypeScript não irá ajudar a tomar estas decisões.
30 |
31 | O TypeScript apenas converterá os arquivos .ts para .js para a EcmaScript especificada e
32 | ficará por sua conta ter um carregamento de módulos funcionando no browser: AMD, CommonJS, ES6 Modules e etc.
33 |
34 | Isto pode desestimular seu uso ou desincentivar quem está começando, pois organizar módulos e bibliotecas de terceiros não é simples.
35 |
36 | Este pacote é uma forma produtiva de se começar com TypeScript.
37 |
38 | Veja o vídeo no nosso canal do Youtube para entender mais detalhes: [https://www.youtube.com/watch?v=9qJT3t9syFM](https://www.youtube.com/watch?v=9qJT3t9syFM)
39 |
40 | ## Instalação
41 |
42 | * Node.js
43 | * Faça o clone do projeto
44 | * Execute o comando ```npm install```
45 |
46 | ## Rodar o projeto
47 |
48 | * ```npm start``` - Compila o TypeScript e roda um servidor em http://localhost:9000 para testar o projeto.
49 | * ```npm run dev``` - Compila o TypeScript em modo desenvolvimento.
50 | * ```npm run prod``` - Compila o TypeScript em modo produção.
51 |
--------------------------------------------------------------------------------
/public/js/index.js:
--------------------------------------------------------------------------------
1 | /******/ (function(modules) { // webpackBootstrap
2 | /******/ // The module cache
3 | /******/ var installedModules = {};
4 | /******/
5 | /******/ // The require function
6 | /******/ function __webpack_require__(moduleId) {
7 | /******/
8 | /******/ // Check if module is in cache
9 | /******/ if(installedModules[moduleId]) {
10 | /******/ return installedModules[moduleId].exports;
11 | /******/ }
12 | /******/ // Create a new module (and put it into the cache)
13 | /******/ var module = installedModules[moduleId] = {
14 | /******/ i: moduleId,
15 | /******/ l: false,
16 | /******/ exports: {}
17 | /******/ };
18 | /******/
19 | /******/ // Execute the module function
20 | /******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__);
21 | /******/
22 | /******/ // Flag the module as loaded
23 | /******/ module.l = true;
24 | /******/
25 | /******/ // Return the exports of the module
26 | /******/ return module.exports;
27 | /******/ }
28 | /******/
29 | /******/
30 | /******/ // expose the modules object (__webpack_modules__)
31 | /******/ __webpack_require__.m = modules;
32 | /******/
33 | /******/ // expose the module cache
34 | /******/ __webpack_require__.c = installedModules;
35 | /******/
36 | /******/ // define getter function for harmony exports
37 | /******/ __webpack_require__.d = function(exports, name, getter) {
38 | /******/ if(!__webpack_require__.o(exports, name)) {
39 | /******/ Object.defineProperty(exports, name, { enumerable: true, get: getter });
40 | /******/ }
41 | /******/ };
42 | /******/
43 | /******/ // define __esModule on exports
44 | /******/ __webpack_require__.r = function(exports) {
45 | /******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
46 | /******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
47 | /******/ }
48 | /******/ Object.defineProperty(exports, '__esModule', { value: true });
49 | /******/ };
50 | /******/
51 | /******/ // create a fake namespace object
52 | /******/ // mode & 1: value is a module id, require it
53 | /******/ // mode & 2: merge all properties of value into the ns
54 | /******/ // mode & 4: return value when already ns object
55 | /******/ // mode & 8|1: behave like require
56 | /******/ __webpack_require__.t = function(value, mode) {
57 | /******/ if(mode & 1) value = __webpack_require__(value);
58 | /******/ if(mode & 8) return value;
59 | /******/ if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;
60 | /******/ var ns = Object.create(null);
61 | /******/ __webpack_require__.r(ns);
62 | /******/ Object.defineProperty(ns, 'default', { enumerable: true, value: value });
63 | /******/ if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));
64 | /******/ return ns;
65 | /******/ };
66 | /******/
67 | /******/ // getDefaultExport function for compatibility with non-harmony modules
68 | /******/ __webpack_require__.n = function(module) {
69 | /******/ var getter = module && module.__esModule ?
70 | /******/ function getDefault() { return module['default']; } :
71 | /******/ function getModuleExports() { return module; };
72 | /******/ __webpack_require__.d(getter, 'a', getter);
73 | /******/ return getter;
74 | /******/ };
75 | /******/
76 | /******/ // Object.prototype.hasOwnProperty.call
77 | /******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };
78 | /******/
79 | /******/ // __webpack_public_path__
80 | /******/ __webpack_require__.p = "/js";
81 | /******/
82 | /******/
83 | /******/ // Load entry module and return exports
84 | /******/ return __webpack_require__(__webpack_require__.s = "./src/index.ts");
85 | /******/ })
86 | /************************************************************************/
87 | /******/ ({
88 |
89 | /***/ "./node_modules/axios/index.js":
90 | /*!*************************************!*\
91 | !*** ./node_modules/axios/index.js ***!
92 | \*************************************/
93 | /*! no static exports found */
94 | /***/ (function(module, exports, __webpack_require__) {
95 |
96 | module.exports = __webpack_require__(/*! ./lib/axios */ "./node_modules/axios/lib/axios.js");
97 |
98 | /***/ }),
99 |
100 | /***/ "./node_modules/axios/lib/adapters/xhr.js":
101 | /*!************************************************!*\
102 | !*** ./node_modules/axios/lib/adapters/xhr.js ***!
103 | \************************************************/
104 | /*! no static exports found */
105 | /***/ (function(module, exports, __webpack_require__) {
106 |
107 | "use strict";
108 |
109 |
110 | var utils = __webpack_require__(/*! ./../utils */ "./node_modules/axios/lib/utils.js");
111 | var settle = __webpack_require__(/*! ./../core/settle */ "./node_modules/axios/lib/core/settle.js");
112 | var buildURL = __webpack_require__(/*! ./../helpers/buildURL */ "./node_modules/axios/lib/helpers/buildURL.js");
113 | var buildFullPath = __webpack_require__(/*! ../core/buildFullPath */ "./node_modules/axios/lib/core/buildFullPath.js");
114 | var parseHeaders = __webpack_require__(/*! ./../helpers/parseHeaders */ "./node_modules/axios/lib/helpers/parseHeaders.js");
115 | var isURLSameOrigin = __webpack_require__(/*! ./../helpers/isURLSameOrigin */ "./node_modules/axios/lib/helpers/isURLSameOrigin.js");
116 | var createError = __webpack_require__(/*! ../core/createError */ "./node_modules/axios/lib/core/createError.js");
117 |
118 | module.exports = function xhrAdapter(config) {
119 | return new Promise(function dispatchXhrRequest(resolve, reject) {
120 | var requestData = config.data;
121 | var requestHeaders = config.headers;
122 |
123 | if (utils.isFormData(requestData)) {
124 | delete requestHeaders['Content-Type']; // Let the browser set it
125 | }
126 |
127 | var request = new XMLHttpRequest();
128 |
129 | // HTTP basic authentication
130 | if (config.auth) {
131 | var username = config.auth.username || '';
132 | var password = config.auth.password || '';
133 | requestHeaders.Authorization = 'Basic ' + btoa(username + ':' + password);
134 | }
135 |
136 | var fullPath = buildFullPath(config.baseURL, config.url);
137 | request.open(config.method.toUpperCase(), buildURL(fullPath, config.params, config.paramsSerializer), true);
138 |
139 | // Set the request timeout in MS
140 | request.timeout = config.timeout;
141 |
142 | // Listen for ready state
143 | request.onreadystatechange = function handleLoad() {
144 | if (!request || request.readyState !== 4) {
145 | return;
146 | }
147 |
148 | // The request errored out and we didn't get a response, this will be
149 | // handled by onerror instead
150 | // With one exception: request that using file: protocol, most browsers
151 | // will return status as 0 even though it's a successful request
152 | if (request.status === 0 && !(request.responseURL && request.responseURL.indexOf('file:') === 0)) {
153 | return;
154 | }
155 |
156 | // Prepare the response
157 | var responseHeaders = 'getAllResponseHeaders' in request ? parseHeaders(request.getAllResponseHeaders()) : null;
158 | var responseData = !config.responseType || config.responseType === 'text' ? request.responseText : request.response;
159 | var response = {
160 | data: responseData,
161 | status: request.status,
162 | statusText: request.statusText,
163 | headers: responseHeaders,
164 | config: config,
165 | request: request
166 | };
167 |
168 | settle(resolve, reject, response);
169 |
170 | // Clean up request
171 | request = null;
172 | };
173 |
174 | // Handle browser request cancellation (as opposed to a manual cancellation)
175 | request.onabort = function handleAbort() {
176 | if (!request) {
177 | return;
178 | }
179 |
180 | reject(createError('Request aborted', config, 'ECONNABORTED', request));
181 |
182 | // Clean up request
183 | request = null;
184 | };
185 |
186 | // Handle low level network errors
187 | request.onerror = function handleError() {
188 | // Real errors are hidden from us by the browser
189 | // onerror should only fire if it's a network error
190 | reject(createError('Network Error', config, null, request));
191 |
192 | // Clean up request
193 | request = null;
194 | };
195 |
196 | // Handle timeout
197 | request.ontimeout = function handleTimeout() {
198 | var timeoutErrorMessage = 'timeout of ' + config.timeout + 'ms exceeded';
199 | if (config.timeoutErrorMessage) {
200 | timeoutErrorMessage = config.timeoutErrorMessage;
201 | }
202 | reject(createError(timeoutErrorMessage, config, 'ECONNABORTED',
203 | request));
204 |
205 | // Clean up request
206 | request = null;
207 | };
208 |
209 | // Add xsrf header
210 | // This is only done if running in a standard browser environment.
211 | // Specifically not if we're in a web worker, or react-native.
212 | if (utils.isStandardBrowserEnv()) {
213 | var cookies = __webpack_require__(/*! ./../helpers/cookies */ "./node_modules/axios/lib/helpers/cookies.js");
214 |
215 | // Add xsrf header
216 | var xsrfValue = (config.withCredentials || isURLSameOrigin(fullPath)) && config.xsrfCookieName ?
217 | cookies.read(config.xsrfCookieName) :
218 | undefined;
219 |
220 | if (xsrfValue) {
221 | requestHeaders[config.xsrfHeaderName] = xsrfValue;
222 | }
223 | }
224 |
225 | // Add headers to the request
226 | if ('setRequestHeader' in request) {
227 | utils.forEach(requestHeaders, function setRequestHeader(val, key) {
228 | if (typeof requestData === 'undefined' && key.toLowerCase() === 'content-type') {
229 | // Remove Content-Type if data is undefined
230 | delete requestHeaders[key];
231 | } else {
232 | // Otherwise add header to the request
233 | request.setRequestHeader(key, val);
234 | }
235 | });
236 | }
237 |
238 | // Add withCredentials to request if needed
239 | if (!utils.isUndefined(config.withCredentials)) {
240 | request.withCredentials = !!config.withCredentials;
241 | }
242 |
243 | // Add responseType to request if needed
244 | if (config.responseType) {
245 | try {
246 | request.responseType = config.responseType;
247 | } catch (e) {
248 | // Expected DOMException thrown by browsers not compatible XMLHttpRequest Level 2.
249 | // But, this can be suppressed for 'json' type as it can be parsed by default 'transformResponse' function.
250 | if (config.responseType !== 'json') {
251 | throw e;
252 | }
253 | }
254 | }
255 |
256 | // Handle progress if needed
257 | if (typeof config.onDownloadProgress === 'function') {
258 | request.addEventListener('progress', config.onDownloadProgress);
259 | }
260 |
261 | // Not all browsers support upload events
262 | if (typeof config.onUploadProgress === 'function' && request.upload) {
263 | request.upload.addEventListener('progress', config.onUploadProgress);
264 | }
265 |
266 | if (config.cancelToken) {
267 | // Handle cancellation
268 | config.cancelToken.promise.then(function onCanceled(cancel) {
269 | if (!request) {
270 | return;
271 | }
272 |
273 | request.abort();
274 | reject(cancel);
275 | // Clean up request
276 | request = null;
277 | });
278 | }
279 |
280 | if (requestData === undefined) {
281 | requestData = null;
282 | }
283 |
284 | // Send the request
285 | request.send(requestData);
286 | });
287 | };
288 |
289 |
290 | /***/ }),
291 |
292 | /***/ "./node_modules/axios/lib/axios.js":
293 | /*!*****************************************!*\
294 | !*** ./node_modules/axios/lib/axios.js ***!
295 | \*****************************************/
296 | /*! no static exports found */
297 | /***/ (function(module, exports, __webpack_require__) {
298 |
299 | "use strict";
300 |
301 |
302 | var utils = __webpack_require__(/*! ./utils */ "./node_modules/axios/lib/utils.js");
303 | var bind = __webpack_require__(/*! ./helpers/bind */ "./node_modules/axios/lib/helpers/bind.js");
304 | var Axios = __webpack_require__(/*! ./core/Axios */ "./node_modules/axios/lib/core/Axios.js");
305 | var mergeConfig = __webpack_require__(/*! ./core/mergeConfig */ "./node_modules/axios/lib/core/mergeConfig.js");
306 | var defaults = __webpack_require__(/*! ./defaults */ "./node_modules/axios/lib/defaults.js");
307 |
308 | /**
309 | * Create an instance of Axios
310 | *
311 | * @param {Object} defaultConfig The default config for the instance
312 | * @return {Axios} A new instance of Axios
313 | */
314 | function createInstance(defaultConfig) {
315 | var context = new Axios(defaultConfig);
316 | var instance = bind(Axios.prototype.request, context);
317 |
318 | // Copy axios.prototype to instance
319 | utils.extend(instance, Axios.prototype, context);
320 |
321 | // Copy context to instance
322 | utils.extend(instance, context);
323 |
324 | return instance;
325 | }
326 |
327 | // Create the default instance to be exported
328 | var axios = createInstance(defaults);
329 |
330 | // Expose Axios class to allow class inheritance
331 | axios.Axios = Axios;
332 |
333 | // Factory for creating new instances
334 | axios.create = function create(instanceConfig) {
335 | return createInstance(mergeConfig(axios.defaults, instanceConfig));
336 | };
337 |
338 | // Expose Cancel & CancelToken
339 | axios.Cancel = __webpack_require__(/*! ./cancel/Cancel */ "./node_modules/axios/lib/cancel/Cancel.js");
340 | axios.CancelToken = __webpack_require__(/*! ./cancel/CancelToken */ "./node_modules/axios/lib/cancel/CancelToken.js");
341 | axios.isCancel = __webpack_require__(/*! ./cancel/isCancel */ "./node_modules/axios/lib/cancel/isCancel.js");
342 |
343 | // Expose all/spread
344 | axios.all = function all(promises) {
345 | return Promise.all(promises);
346 | };
347 | axios.spread = __webpack_require__(/*! ./helpers/spread */ "./node_modules/axios/lib/helpers/spread.js");
348 |
349 | module.exports = axios;
350 |
351 | // Allow use of default import syntax in TypeScript
352 | module.exports.default = axios;
353 |
354 |
355 | /***/ }),
356 |
357 | /***/ "./node_modules/axios/lib/cancel/Cancel.js":
358 | /*!*************************************************!*\
359 | !*** ./node_modules/axios/lib/cancel/Cancel.js ***!
360 | \*************************************************/
361 | /*! no static exports found */
362 | /***/ (function(module, exports, __webpack_require__) {
363 |
364 | "use strict";
365 |
366 |
367 | /**
368 | * A `Cancel` is an object that is thrown when an operation is canceled.
369 | *
370 | * @class
371 | * @param {string=} message The message.
372 | */
373 | function Cancel(message) {
374 | this.message = message;
375 | }
376 |
377 | Cancel.prototype.toString = function toString() {
378 | return 'Cancel' + (this.message ? ': ' + this.message : '');
379 | };
380 |
381 | Cancel.prototype.__CANCEL__ = true;
382 |
383 | module.exports = Cancel;
384 |
385 |
386 | /***/ }),
387 |
388 | /***/ "./node_modules/axios/lib/cancel/CancelToken.js":
389 | /*!******************************************************!*\
390 | !*** ./node_modules/axios/lib/cancel/CancelToken.js ***!
391 | \******************************************************/
392 | /*! no static exports found */
393 | /***/ (function(module, exports, __webpack_require__) {
394 |
395 | "use strict";
396 |
397 |
398 | var Cancel = __webpack_require__(/*! ./Cancel */ "./node_modules/axios/lib/cancel/Cancel.js");
399 |
400 | /**
401 | * A `CancelToken` is an object that can be used to request cancellation of an operation.
402 | *
403 | * @class
404 | * @param {Function} executor The executor function.
405 | */
406 | function CancelToken(executor) {
407 | if (typeof executor !== 'function') {
408 | throw new TypeError('executor must be a function.');
409 | }
410 |
411 | var resolvePromise;
412 | this.promise = new Promise(function promiseExecutor(resolve) {
413 | resolvePromise = resolve;
414 | });
415 |
416 | var token = this;
417 | executor(function cancel(message) {
418 | if (token.reason) {
419 | // Cancellation has already been requested
420 | return;
421 | }
422 |
423 | token.reason = new Cancel(message);
424 | resolvePromise(token.reason);
425 | });
426 | }
427 |
428 | /**
429 | * Throws a `Cancel` if cancellation has been requested.
430 | */
431 | CancelToken.prototype.throwIfRequested = function throwIfRequested() {
432 | if (this.reason) {
433 | throw this.reason;
434 | }
435 | };
436 |
437 | /**
438 | * Returns an object that contains a new `CancelToken` and a function that, when called,
439 | * cancels the `CancelToken`.
440 | */
441 | CancelToken.source = function source() {
442 | var cancel;
443 | var token = new CancelToken(function executor(c) {
444 | cancel = c;
445 | });
446 | return {
447 | token: token,
448 | cancel: cancel
449 | };
450 | };
451 |
452 | module.exports = CancelToken;
453 |
454 |
455 | /***/ }),
456 |
457 | /***/ "./node_modules/axios/lib/cancel/isCancel.js":
458 | /*!***************************************************!*\
459 | !*** ./node_modules/axios/lib/cancel/isCancel.js ***!
460 | \***************************************************/
461 | /*! no static exports found */
462 | /***/ (function(module, exports, __webpack_require__) {
463 |
464 | "use strict";
465 |
466 |
467 | module.exports = function isCancel(value) {
468 | return !!(value && value.__CANCEL__);
469 | };
470 |
471 |
472 | /***/ }),
473 |
474 | /***/ "./node_modules/axios/lib/core/Axios.js":
475 | /*!**********************************************!*\
476 | !*** ./node_modules/axios/lib/core/Axios.js ***!
477 | \**********************************************/
478 | /*! no static exports found */
479 | /***/ (function(module, exports, __webpack_require__) {
480 |
481 | "use strict";
482 |
483 |
484 | var utils = __webpack_require__(/*! ./../utils */ "./node_modules/axios/lib/utils.js");
485 | var buildURL = __webpack_require__(/*! ../helpers/buildURL */ "./node_modules/axios/lib/helpers/buildURL.js");
486 | var InterceptorManager = __webpack_require__(/*! ./InterceptorManager */ "./node_modules/axios/lib/core/InterceptorManager.js");
487 | var dispatchRequest = __webpack_require__(/*! ./dispatchRequest */ "./node_modules/axios/lib/core/dispatchRequest.js");
488 | var mergeConfig = __webpack_require__(/*! ./mergeConfig */ "./node_modules/axios/lib/core/mergeConfig.js");
489 |
490 | /**
491 | * Create a new instance of Axios
492 | *
493 | * @param {Object} instanceConfig The default config for the instance
494 | */
495 | function Axios(instanceConfig) {
496 | this.defaults = instanceConfig;
497 | this.interceptors = {
498 | request: new InterceptorManager(),
499 | response: new InterceptorManager()
500 | };
501 | }
502 |
503 | /**
504 | * Dispatch a request
505 | *
506 | * @param {Object} config The config specific for this request (merged with this.defaults)
507 | */
508 | Axios.prototype.request = function request(config) {
509 | /*eslint no-param-reassign:0*/
510 | // Allow for axios('example/url'[, config]) a la fetch API
511 | if (typeof config === 'string') {
512 | config = arguments[1] || {};
513 | config.url = arguments[0];
514 | } else {
515 | config = config || {};
516 | }
517 |
518 | config = mergeConfig(this.defaults, config);
519 |
520 | // Set config.method
521 | if (config.method) {
522 | config.method = config.method.toLowerCase();
523 | } else if (this.defaults.method) {
524 | config.method = this.defaults.method.toLowerCase();
525 | } else {
526 | config.method = 'get';
527 | }
528 |
529 | // Hook up interceptors middleware
530 | var chain = [dispatchRequest, undefined];
531 | var promise = Promise.resolve(config);
532 |
533 | this.interceptors.request.forEach(function unshiftRequestInterceptors(interceptor) {
534 | chain.unshift(interceptor.fulfilled, interceptor.rejected);
535 | });
536 |
537 | this.interceptors.response.forEach(function pushResponseInterceptors(interceptor) {
538 | chain.push(interceptor.fulfilled, interceptor.rejected);
539 | });
540 |
541 | while (chain.length) {
542 | promise = promise.then(chain.shift(), chain.shift());
543 | }
544 |
545 | return promise;
546 | };
547 |
548 | Axios.prototype.getUri = function getUri(config) {
549 | config = mergeConfig(this.defaults, config);
550 | return buildURL(config.url, config.params, config.paramsSerializer).replace(/^\?/, '');
551 | };
552 |
553 | // Provide aliases for supported request methods
554 | utils.forEach(['delete', 'get', 'head', 'options'], function forEachMethodNoData(method) {
555 | /*eslint func-names:0*/
556 | Axios.prototype[method] = function(url, config) {
557 | return this.request(utils.merge(config || {}, {
558 | method: method,
559 | url: url
560 | }));
561 | };
562 | });
563 |
564 | utils.forEach(['post', 'put', 'patch'], function forEachMethodWithData(method) {
565 | /*eslint func-names:0*/
566 | Axios.prototype[method] = function(url, data, config) {
567 | return this.request(utils.merge(config || {}, {
568 | method: method,
569 | url: url,
570 | data: data
571 | }));
572 | };
573 | });
574 |
575 | module.exports = Axios;
576 |
577 |
578 | /***/ }),
579 |
580 | /***/ "./node_modules/axios/lib/core/InterceptorManager.js":
581 | /*!***********************************************************!*\
582 | !*** ./node_modules/axios/lib/core/InterceptorManager.js ***!
583 | \***********************************************************/
584 | /*! no static exports found */
585 | /***/ (function(module, exports, __webpack_require__) {
586 |
587 | "use strict";
588 |
589 |
590 | var utils = __webpack_require__(/*! ./../utils */ "./node_modules/axios/lib/utils.js");
591 |
592 | function InterceptorManager() {
593 | this.handlers = [];
594 | }
595 |
596 | /**
597 | * Add a new interceptor to the stack
598 | *
599 | * @param {Function} fulfilled The function to handle `then` for a `Promise`
600 | * @param {Function} rejected The function to handle `reject` for a `Promise`
601 | *
602 | * @return {Number} An ID used to remove interceptor later
603 | */
604 | InterceptorManager.prototype.use = function use(fulfilled, rejected) {
605 | this.handlers.push({
606 | fulfilled: fulfilled,
607 | rejected: rejected
608 | });
609 | return this.handlers.length - 1;
610 | };
611 |
612 | /**
613 | * Remove an interceptor from the stack
614 | *
615 | * @param {Number} id The ID that was returned by `use`
616 | */
617 | InterceptorManager.prototype.eject = function eject(id) {
618 | if (this.handlers[id]) {
619 | this.handlers[id] = null;
620 | }
621 | };
622 |
623 | /**
624 | * Iterate over all the registered interceptors
625 | *
626 | * This method is particularly useful for skipping over any
627 | * interceptors that may have become `null` calling `eject`.
628 | *
629 | * @param {Function} fn The function to call for each interceptor
630 | */
631 | InterceptorManager.prototype.forEach = function forEach(fn) {
632 | utils.forEach(this.handlers, function forEachHandler(h) {
633 | if (h !== null) {
634 | fn(h);
635 | }
636 | });
637 | };
638 |
639 | module.exports = InterceptorManager;
640 |
641 |
642 | /***/ }),
643 |
644 | /***/ "./node_modules/axios/lib/core/buildFullPath.js":
645 | /*!******************************************************!*\
646 | !*** ./node_modules/axios/lib/core/buildFullPath.js ***!
647 | \******************************************************/
648 | /*! no static exports found */
649 | /***/ (function(module, exports, __webpack_require__) {
650 |
651 | "use strict";
652 |
653 |
654 | var isAbsoluteURL = __webpack_require__(/*! ../helpers/isAbsoluteURL */ "./node_modules/axios/lib/helpers/isAbsoluteURL.js");
655 | var combineURLs = __webpack_require__(/*! ../helpers/combineURLs */ "./node_modules/axios/lib/helpers/combineURLs.js");
656 |
657 | /**
658 | * Creates a new URL by combining the baseURL with the requestedURL,
659 | * only when the requestedURL is not already an absolute URL.
660 | * If the requestURL is absolute, this function returns the requestedURL untouched.
661 | *
662 | * @param {string} baseURL The base URL
663 | * @param {string} requestedURL Absolute or relative URL to combine
664 | * @returns {string} The combined full path
665 | */
666 | module.exports = function buildFullPath(baseURL, requestedURL) {
667 | if (baseURL && !isAbsoluteURL(requestedURL)) {
668 | return combineURLs(baseURL, requestedURL);
669 | }
670 | return requestedURL;
671 | };
672 |
673 |
674 | /***/ }),
675 |
676 | /***/ "./node_modules/axios/lib/core/createError.js":
677 | /*!****************************************************!*\
678 | !*** ./node_modules/axios/lib/core/createError.js ***!
679 | \****************************************************/
680 | /*! no static exports found */
681 | /***/ (function(module, exports, __webpack_require__) {
682 |
683 | "use strict";
684 |
685 |
686 | var enhanceError = __webpack_require__(/*! ./enhanceError */ "./node_modules/axios/lib/core/enhanceError.js");
687 |
688 | /**
689 | * Create an Error with the specified message, config, error code, request and response.
690 | *
691 | * @param {string} message The error message.
692 | * @param {Object} config The config.
693 | * @param {string} [code] The error code (for example, 'ECONNABORTED').
694 | * @param {Object} [request] The request.
695 | * @param {Object} [response] The response.
696 | * @returns {Error} The created error.
697 | */
698 | module.exports = function createError(message, config, code, request, response) {
699 | var error = new Error(message);
700 | return enhanceError(error, config, code, request, response);
701 | };
702 |
703 |
704 | /***/ }),
705 |
706 | /***/ "./node_modules/axios/lib/core/dispatchRequest.js":
707 | /*!********************************************************!*\
708 | !*** ./node_modules/axios/lib/core/dispatchRequest.js ***!
709 | \********************************************************/
710 | /*! no static exports found */
711 | /***/ (function(module, exports, __webpack_require__) {
712 |
713 | "use strict";
714 |
715 |
716 | var utils = __webpack_require__(/*! ./../utils */ "./node_modules/axios/lib/utils.js");
717 | var transformData = __webpack_require__(/*! ./transformData */ "./node_modules/axios/lib/core/transformData.js");
718 | var isCancel = __webpack_require__(/*! ../cancel/isCancel */ "./node_modules/axios/lib/cancel/isCancel.js");
719 | var defaults = __webpack_require__(/*! ../defaults */ "./node_modules/axios/lib/defaults.js");
720 |
721 | /**
722 | * Throws a `Cancel` if cancellation has been requested.
723 | */
724 | function throwIfCancellationRequested(config) {
725 | if (config.cancelToken) {
726 | config.cancelToken.throwIfRequested();
727 | }
728 | }
729 |
730 | /**
731 | * Dispatch a request to the server using the configured adapter.
732 | *
733 | * @param {object} config The config that is to be used for the request
734 | * @returns {Promise} The Promise to be fulfilled
735 | */
736 | module.exports = function dispatchRequest(config) {
737 | throwIfCancellationRequested(config);
738 |
739 | // Ensure headers exist
740 | config.headers = config.headers || {};
741 |
742 | // Transform request data
743 | config.data = transformData(
744 | config.data,
745 | config.headers,
746 | config.transformRequest
747 | );
748 |
749 | // Flatten headers
750 | config.headers = utils.merge(
751 | config.headers.common || {},
752 | config.headers[config.method] || {},
753 | config.headers
754 | );
755 |
756 | utils.forEach(
757 | ['delete', 'get', 'head', 'post', 'put', 'patch', 'common'],
758 | function cleanHeaderConfig(method) {
759 | delete config.headers[method];
760 | }
761 | );
762 |
763 | var adapter = config.adapter || defaults.adapter;
764 |
765 | return adapter(config).then(function onAdapterResolution(response) {
766 | throwIfCancellationRequested(config);
767 |
768 | // Transform response data
769 | response.data = transformData(
770 | response.data,
771 | response.headers,
772 | config.transformResponse
773 | );
774 |
775 | return response;
776 | }, function onAdapterRejection(reason) {
777 | if (!isCancel(reason)) {
778 | throwIfCancellationRequested(config);
779 |
780 | // Transform response data
781 | if (reason && reason.response) {
782 | reason.response.data = transformData(
783 | reason.response.data,
784 | reason.response.headers,
785 | config.transformResponse
786 | );
787 | }
788 | }
789 |
790 | return Promise.reject(reason);
791 | });
792 | };
793 |
794 |
795 | /***/ }),
796 |
797 | /***/ "./node_modules/axios/lib/core/enhanceError.js":
798 | /*!*****************************************************!*\
799 | !*** ./node_modules/axios/lib/core/enhanceError.js ***!
800 | \*****************************************************/
801 | /*! no static exports found */
802 | /***/ (function(module, exports, __webpack_require__) {
803 |
804 | "use strict";
805 |
806 |
807 | /**
808 | * Update an Error with the specified config, error code, and response.
809 | *
810 | * @param {Error} error The error to update.
811 | * @param {Object} config The config.
812 | * @param {string} [code] The error code (for example, 'ECONNABORTED').
813 | * @param {Object} [request] The request.
814 | * @param {Object} [response] The response.
815 | * @returns {Error} The error.
816 | */
817 | module.exports = function enhanceError(error, config, code, request, response) {
818 | error.config = config;
819 | if (code) {
820 | error.code = code;
821 | }
822 |
823 | error.request = request;
824 | error.response = response;
825 | error.isAxiosError = true;
826 |
827 | error.toJSON = function() {
828 | return {
829 | // Standard
830 | message: this.message,
831 | name: this.name,
832 | // Microsoft
833 | description: this.description,
834 | number: this.number,
835 | // Mozilla
836 | fileName: this.fileName,
837 | lineNumber: this.lineNumber,
838 | columnNumber: this.columnNumber,
839 | stack: this.stack,
840 | // Axios
841 | config: this.config,
842 | code: this.code
843 | };
844 | };
845 | return error;
846 | };
847 |
848 |
849 | /***/ }),
850 |
851 | /***/ "./node_modules/axios/lib/core/mergeConfig.js":
852 | /*!****************************************************!*\
853 | !*** ./node_modules/axios/lib/core/mergeConfig.js ***!
854 | \****************************************************/
855 | /*! no static exports found */
856 | /***/ (function(module, exports, __webpack_require__) {
857 |
858 | "use strict";
859 |
860 |
861 | var utils = __webpack_require__(/*! ../utils */ "./node_modules/axios/lib/utils.js");
862 |
863 | /**
864 | * Config-specific merge-function which creates a new config-object
865 | * by merging two configuration objects together.
866 | *
867 | * @param {Object} config1
868 | * @param {Object} config2
869 | * @returns {Object} New object resulting from merging config2 to config1
870 | */
871 | module.exports = function mergeConfig(config1, config2) {
872 | // eslint-disable-next-line no-param-reassign
873 | config2 = config2 || {};
874 | var config = {};
875 |
876 | var valueFromConfig2Keys = ['url', 'method', 'params', 'data'];
877 | var mergeDeepPropertiesKeys = ['headers', 'auth', 'proxy'];
878 | var defaultToConfig2Keys = [
879 | 'baseURL', 'url', 'transformRequest', 'transformResponse', 'paramsSerializer',
880 | 'timeout', 'withCredentials', 'adapter', 'responseType', 'xsrfCookieName',
881 | 'xsrfHeaderName', 'onUploadProgress', 'onDownloadProgress',
882 | 'maxContentLength', 'validateStatus', 'maxRedirects', 'httpAgent',
883 | 'httpsAgent', 'cancelToken', 'socketPath'
884 | ];
885 |
886 | utils.forEach(valueFromConfig2Keys, function valueFromConfig2(prop) {
887 | if (typeof config2[prop] !== 'undefined') {
888 | config[prop] = config2[prop];
889 | }
890 | });
891 |
892 | utils.forEach(mergeDeepPropertiesKeys, function mergeDeepProperties(prop) {
893 | if (utils.isObject(config2[prop])) {
894 | config[prop] = utils.deepMerge(config1[prop], config2[prop]);
895 | } else if (typeof config2[prop] !== 'undefined') {
896 | config[prop] = config2[prop];
897 | } else if (utils.isObject(config1[prop])) {
898 | config[prop] = utils.deepMerge(config1[prop]);
899 | } else if (typeof config1[prop] !== 'undefined') {
900 | config[prop] = config1[prop];
901 | }
902 | });
903 |
904 | utils.forEach(defaultToConfig2Keys, function defaultToConfig2(prop) {
905 | if (typeof config2[prop] !== 'undefined') {
906 | config[prop] = config2[prop];
907 | } else if (typeof config1[prop] !== 'undefined') {
908 | config[prop] = config1[prop];
909 | }
910 | });
911 |
912 | var axiosKeys = valueFromConfig2Keys
913 | .concat(mergeDeepPropertiesKeys)
914 | .concat(defaultToConfig2Keys);
915 |
916 | var otherKeys = Object
917 | .keys(config2)
918 | .filter(function filterAxiosKeys(key) {
919 | return axiosKeys.indexOf(key) === -1;
920 | });
921 |
922 | utils.forEach(otherKeys, function otherKeysDefaultToConfig2(prop) {
923 | if (typeof config2[prop] !== 'undefined') {
924 | config[prop] = config2[prop];
925 | } else if (typeof config1[prop] !== 'undefined') {
926 | config[prop] = config1[prop];
927 | }
928 | });
929 |
930 | return config;
931 | };
932 |
933 |
934 | /***/ }),
935 |
936 | /***/ "./node_modules/axios/lib/core/settle.js":
937 | /*!***********************************************!*\
938 | !*** ./node_modules/axios/lib/core/settle.js ***!
939 | \***********************************************/
940 | /*! no static exports found */
941 | /***/ (function(module, exports, __webpack_require__) {
942 |
943 | "use strict";
944 |
945 |
946 | var createError = __webpack_require__(/*! ./createError */ "./node_modules/axios/lib/core/createError.js");
947 |
948 | /**
949 | * Resolve or reject a Promise based on response status.
950 | *
951 | * @param {Function} resolve A function that resolves the promise.
952 | * @param {Function} reject A function that rejects the promise.
953 | * @param {object} response The response.
954 | */
955 | module.exports = function settle(resolve, reject, response) {
956 | var validateStatus = response.config.validateStatus;
957 | if (!validateStatus || validateStatus(response.status)) {
958 | resolve(response);
959 | } else {
960 | reject(createError(
961 | 'Request failed with status code ' + response.status,
962 | response.config,
963 | null,
964 | response.request,
965 | response
966 | ));
967 | }
968 | };
969 |
970 |
971 | /***/ }),
972 |
973 | /***/ "./node_modules/axios/lib/core/transformData.js":
974 | /*!******************************************************!*\
975 | !*** ./node_modules/axios/lib/core/transformData.js ***!
976 | \******************************************************/
977 | /*! no static exports found */
978 | /***/ (function(module, exports, __webpack_require__) {
979 |
980 | "use strict";
981 |
982 |
983 | var utils = __webpack_require__(/*! ./../utils */ "./node_modules/axios/lib/utils.js");
984 |
985 | /**
986 | * Transform the data for a request or a response
987 | *
988 | * @param {Object|String} data The data to be transformed
989 | * @param {Array} headers The headers for the request or response
990 | * @param {Array|Function} fns A single function or Array of functions
991 | * @returns {*} The resulting transformed data
992 | */
993 | module.exports = function transformData(data, headers, fns) {
994 | /*eslint no-param-reassign:0*/
995 | utils.forEach(fns, function transform(fn) {
996 | data = fn(data, headers);
997 | });
998 |
999 | return data;
1000 | };
1001 |
1002 |
1003 | /***/ }),
1004 |
1005 | /***/ "./node_modules/axios/lib/defaults.js":
1006 | /*!********************************************!*\
1007 | !*** ./node_modules/axios/lib/defaults.js ***!
1008 | \********************************************/
1009 | /*! no static exports found */
1010 | /***/ (function(module, exports, __webpack_require__) {
1011 |
1012 | "use strict";
1013 | /* WEBPACK VAR INJECTION */(function(process) {
1014 |
1015 | var utils = __webpack_require__(/*! ./utils */ "./node_modules/axios/lib/utils.js");
1016 | var normalizeHeaderName = __webpack_require__(/*! ./helpers/normalizeHeaderName */ "./node_modules/axios/lib/helpers/normalizeHeaderName.js");
1017 |
1018 | var DEFAULT_CONTENT_TYPE = {
1019 | 'Content-Type': 'application/x-www-form-urlencoded'
1020 | };
1021 |
1022 | function setContentTypeIfUnset(headers, value) {
1023 | if (!utils.isUndefined(headers) && utils.isUndefined(headers['Content-Type'])) {
1024 | headers['Content-Type'] = value;
1025 | }
1026 | }
1027 |
1028 | function getDefaultAdapter() {
1029 | var adapter;
1030 | if (typeof XMLHttpRequest !== 'undefined') {
1031 | // For browsers use XHR adapter
1032 | adapter = __webpack_require__(/*! ./adapters/xhr */ "./node_modules/axios/lib/adapters/xhr.js");
1033 | } else if (typeof process !== 'undefined' && Object.prototype.toString.call(process) === '[object process]') {
1034 | // For node use HTTP adapter
1035 | adapter = __webpack_require__(/*! ./adapters/http */ "./node_modules/axios/lib/adapters/xhr.js");
1036 | }
1037 | return adapter;
1038 | }
1039 |
1040 | var defaults = {
1041 | adapter: getDefaultAdapter(),
1042 |
1043 | transformRequest: [function transformRequest(data, headers) {
1044 | normalizeHeaderName(headers, 'Accept');
1045 | normalizeHeaderName(headers, 'Content-Type');
1046 | if (utils.isFormData(data) ||
1047 | utils.isArrayBuffer(data) ||
1048 | utils.isBuffer(data) ||
1049 | utils.isStream(data) ||
1050 | utils.isFile(data) ||
1051 | utils.isBlob(data)
1052 | ) {
1053 | return data;
1054 | }
1055 | if (utils.isArrayBufferView(data)) {
1056 | return data.buffer;
1057 | }
1058 | if (utils.isURLSearchParams(data)) {
1059 | setContentTypeIfUnset(headers, 'application/x-www-form-urlencoded;charset=utf-8');
1060 | return data.toString();
1061 | }
1062 | if (utils.isObject(data)) {
1063 | setContentTypeIfUnset(headers, 'application/json;charset=utf-8');
1064 | return JSON.stringify(data);
1065 | }
1066 | return data;
1067 | }],
1068 |
1069 | transformResponse: [function transformResponse(data) {
1070 | /*eslint no-param-reassign:0*/
1071 | if (typeof data === 'string') {
1072 | try {
1073 | data = JSON.parse(data);
1074 | } catch (e) { /* Ignore */ }
1075 | }
1076 | return data;
1077 | }],
1078 |
1079 | /**
1080 | * A timeout in milliseconds to abort a request. If set to 0 (default) a
1081 | * timeout is not created.
1082 | */
1083 | timeout: 0,
1084 |
1085 | xsrfCookieName: 'XSRF-TOKEN',
1086 | xsrfHeaderName: 'X-XSRF-TOKEN',
1087 |
1088 | maxContentLength: -1,
1089 |
1090 | validateStatus: function validateStatus(status) {
1091 | return status >= 200 && status < 300;
1092 | }
1093 | };
1094 |
1095 | defaults.headers = {
1096 | common: {
1097 | 'Accept': 'application/json, text/plain, */*'
1098 | }
1099 | };
1100 |
1101 | utils.forEach(['delete', 'get', 'head'], function forEachMethodNoData(method) {
1102 | defaults.headers[method] = {};
1103 | });
1104 |
1105 | utils.forEach(['post', 'put', 'patch'], function forEachMethodWithData(method) {
1106 | defaults.headers[method] = utils.merge(DEFAULT_CONTENT_TYPE);
1107 | });
1108 |
1109 | module.exports = defaults;
1110 |
1111 | /* WEBPACK VAR INJECTION */}.call(this, __webpack_require__(/*! ./../../process/browser.js */ "./node_modules/process/browser.js")))
1112 |
1113 | /***/ }),
1114 |
1115 | /***/ "./node_modules/axios/lib/helpers/bind.js":
1116 | /*!************************************************!*\
1117 | !*** ./node_modules/axios/lib/helpers/bind.js ***!
1118 | \************************************************/
1119 | /*! no static exports found */
1120 | /***/ (function(module, exports, __webpack_require__) {
1121 |
1122 | "use strict";
1123 |
1124 |
1125 | module.exports = function bind(fn, thisArg) {
1126 | return function wrap() {
1127 | var args = new Array(arguments.length);
1128 | for (var i = 0; i < args.length; i++) {
1129 | args[i] = arguments[i];
1130 | }
1131 | return fn.apply(thisArg, args);
1132 | };
1133 | };
1134 |
1135 |
1136 | /***/ }),
1137 |
1138 | /***/ "./node_modules/axios/lib/helpers/buildURL.js":
1139 | /*!****************************************************!*\
1140 | !*** ./node_modules/axios/lib/helpers/buildURL.js ***!
1141 | \****************************************************/
1142 | /*! no static exports found */
1143 | /***/ (function(module, exports, __webpack_require__) {
1144 |
1145 | "use strict";
1146 |
1147 |
1148 | var utils = __webpack_require__(/*! ./../utils */ "./node_modules/axios/lib/utils.js");
1149 |
1150 | function encode(val) {
1151 | return encodeURIComponent(val).
1152 | replace(/%40/gi, '@').
1153 | replace(/%3A/gi, ':').
1154 | replace(/%24/g, '$').
1155 | replace(/%2C/gi, ',').
1156 | replace(/%20/g, '+').
1157 | replace(/%5B/gi, '[').
1158 | replace(/%5D/gi, ']');
1159 | }
1160 |
1161 | /**
1162 | * Build a URL by appending params to the end
1163 | *
1164 | * @param {string} url The base of the url (e.g., http://www.google.com)
1165 | * @param {object} [params] The params to be appended
1166 | * @returns {string} The formatted url
1167 | */
1168 | module.exports = function buildURL(url, params, paramsSerializer) {
1169 | /*eslint no-param-reassign:0*/
1170 | if (!params) {
1171 | return url;
1172 | }
1173 |
1174 | var serializedParams;
1175 | if (paramsSerializer) {
1176 | serializedParams = paramsSerializer(params);
1177 | } else if (utils.isURLSearchParams(params)) {
1178 | serializedParams = params.toString();
1179 | } else {
1180 | var parts = [];
1181 |
1182 | utils.forEach(params, function serialize(val, key) {
1183 | if (val === null || typeof val === 'undefined') {
1184 | return;
1185 | }
1186 |
1187 | if (utils.isArray(val)) {
1188 | key = key + '[]';
1189 | } else {
1190 | val = [val];
1191 | }
1192 |
1193 | utils.forEach(val, function parseValue(v) {
1194 | if (utils.isDate(v)) {
1195 | v = v.toISOString();
1196 | } else if (utils.isObject(v)) {
1197 | v = JSON.stringify(v);
1198 | }
1199 | parts.push(encode(key) + '=' + encode(v));
1200 | });
1201 | });
1202 |
1203 | serializedParams = parts.join('&');
1204 | }
1205 |
1206 | if (serializedParams) {
1207 | var hashmarkIndex = url.indexOf('#');
1208 | if (hashmarkIndex !== -1) {
1209 | url = url.slice(0, hashmarkIndex);
1210 | }
1211 |
1212 | url += (url.indexOf('?') === -1 ? '?' : '&') + serializedParams;
1213 | }
1214 |
1215 | return url;
1216 | };
1217 |
1218 |
1219 | /***/ }),
1220 |
1221 | /***/ "./node_modules/axios/lib/helpers/combineURLs.js":
1222 | /*!*******************************************************!*\
1223 | !*** ./node_modules/axios/lib/helpers/combineURLs.js ***!
1224 | \*******************************************************/
1225 | /*! no static exports found */
1226 | /***/ (function(module, exports, __webpack_require__) {
1227 |
1228 | "use strict";
1229 |
1230 |
1231 | /**
1232 | * Creates a new URL by combining the specified URLs
1233 | *
1234 | * @param {string} baseURL The base URL
1235 | * @param {string} relativeURL The relative URL
1236 | * @returns {string} The combined URL
1237 | */
1238 | module.exports = function combineURLs(baseURL, relativeURL) {
1239 | return relativeURL
1240 | ? baseURL.replace(/\/+$/, '') + '/' + relativeURL.replace(/^\/+/, '')
1241 | : baseURL;
1242 | };
1243 |
1244 |
1245 | /***/ }),
1246 |
1247 | /***/ "./node_modules/axios/lib/helpers/cookies.js":
1248 | /*!***************************************************!*\
1249 | !*** ./node_modules/axios/lib/helpers/cookies.js ***!
1250 | \***************************************************/
1251 | /*! no static exports found */
1252 | /***/ (function(module, exports, __webpack_require__) {
1253 |
1254 | "use strict";
1255 |
1256 |
1257 | var utils = __webpack_require__(/*! ./../utils */ "./node_modules/axios/lib/utils.js");
1258 |
1259 | module.exports = (
1260 | utils.isStandardBrowserEnv() ?
1261 |
1262 | // Standard browser envs support document.cookie
1263 | (function standardBrowserEnv() {
1264 | return {
1265 | write: function write(name, value, expires, path, domain, secure) {
1266 | var cookie = [];
1267 | cookie.push(name + '=' + encodeURIComponent(value));
1268 |
1269 | if (utils.isNumber(expires)) {
1270 | cookie.push('expires=' + new Date(expires).toGMTString());
1271 | }
1272 |
1273 | if (utils.isString(path)) {
1274 | cookie.push('path=' + path);
1275 | }
1276 |
1277 | if (utils.isString(domain)) {
1278 | cookie.push('domain=' + domain);
1279 | }
1280 |
1281 | if (secure === true) {
1282 | cookie.push('secure');
1283 | }
1284 |
1285 | document.cookie = cookie.join('; ');
1286 | },
1287 |
1288 | read: function read(name) {
1289 | var match = document.cookie.match(new RegExp('(^|;\\s*)(' + name + ')=([^;]*)'));
1290 | return (match ? decodeURIComponent(match[3]) : null);
1291 | },
1292 |
1293 | remove: function remove(name) {
1294 | this.write(name, '', Date.now() - 86400000);
1295 | }
1296 | };
1297 | })() :
1298 |
1299 | // Non standard browser env (web workers, react-native) lack needed support.
1300 | (function nonStandardBrowserEnv() {
1301 | return {
1302 | write: function write() {},
1303 | read: function read() { return null; },
1304 | remove: function remove() {}
1305 | };
1306 | })()
1307 | );
1308 |
1309 |
1310 | /***/ }),
1311 |
1312 | /***/ "./node_modules/axios/lib/helpers/isAbsoluteURL.js":
1313 | /*!*********************************************************!*\
1314 | !*** ./node_modules/axios/lib/helpers/isAbsoluteURL.js ***!
1315 | \*********************************************************/
1316 | /*! no static exports found */
1317 | /***/ (function(module, exports, __webpack_require__) {
1318 |
1319 | "use strict";
1320 |
1321 |
1322 | /**
1323 | * Determines whether the specified URL is absolute
1324 | *
1325 | * @param {string} url The URL to test
1326 | * @returns {boolean} True if the specified URL is absolute, otherwise false
1327 | */
1328 | module.exports = function isAbsoluteURL(url) {
1329 | // A URL is considered absolute if it begins with "://" or "//" (protocol-relative URL).
1330 | // RFC 3986 defines scheme name as a sequence of characters beginning with a letter and followed
1331 | // by any combination of letters, digits, plus, period, or hyphen.
1332 | return /^([a-z][a-z\d\+\-\.]*:)?\/\//i.test(url);
1333 | };
1334 |
1335 |
1336 | /***/ }),
1337 |
1338 | /***/ "./node_modules/axios/lib/helpers/isURLSameOrigin.js":
1339 | /*!***********************************************************!*\
1340 | !*** ./node_modules/axios/lib/helpers/isURLSameOrigin.js ***!
1341 | \***********************************************************/
1342 | /*! no static exports found */
1343 | /***/ (function(module, exports, __webpack_require__) {
1344 |
1345 | "use strict";
1346 |
1347 |
1348 | var utils = __webpack_require__(/*! ./../utils */ "./node_modules/axios/lib/utils.js");
1349 |
1350 | module.exports = (
1351 | utils.isStandardBrowserEnv() ?
1352 |
1353 | // Standard browser envs have full support of the APIs needed to test
1354 | // whether the request URL is of the same origin as current location.
1355 | (function standardBrowserEnv() {
1356 | var msie = /(msie|trident)/i.test(navigator.userAgent);
1357 | var urlParsingNode = document.createElement('a');
1358 | var originURL;
1359 |
1360 | /**
1361 | * Parse a URL to discover it's components
1362 | *
1363 | * @param {String} url The URL to be parsed
1364 | * @returns {Object}
1365 | */
1366 | function resolveURL(url) {
1367 | var href = url;
1368 |
1369 | if (msie) {
1370 | // IE needs attribute set twice to normalize properties
1371 | urlParsingNode.setAttribute('href', href);
1372 | href = urlParsingNode.href;
1373 | }
1374 |
1375 | urlParsingNode.setAttribute('href', href);
1376 |
1377 | // urlParsingNode provides the UrlUtils interface - http://url.spec.whatwg.org/#urlutils
1378 | return {
1379 | href: urlParsingNode.href,
1380 | protocol: urlParsingNode.protocol ? urlParsingNode.protocol.replace(/:$/, '') : '',
1381 | host: urlParsingNode.host,
1382 | search: urlParsingNode.search ? urlParsingNode.search.replace(/^\?/, '') : '',
1383 | hash: urlParsingNode.hash ? urlParsingNode.hash.replace(/^#/, '') : '',
1384 | hostname: urlParsingNode.hostname,
1385 | port: urlParsingNode.port,
1386 | pathname: (urlParsingNode.pathname.charAt(0) === '/') ?
1387 | urlParsingNode.pathname :
1388 | '/' + urlParsingNode.pathname
1389 | };
1390 | }
1391 |
1392 | originURL = resolveURL(window.location.href);
1393 |
1394 | /**
1395 | * Determine if a URL shares the same origin as the current location
1396 | *
1397 | * @param {String} requestURL The URL to test
1398 | * @returns {boolean} True if URL shares the same origin, otherwise false
1399 | */
1400 | return function isURLSameOrigin(requestURL) {
1401 | var parsed = (utils.isString(requestURL)) ? resolveURL(requestURL) : requestURL;
1402 | return (parsed.protocol === originURL.protocol &&
1403 | parsed.host === originURL.host);
1404 | };
1405 | })() :
1406 |
1407 | // Non standard browser envs (web workers, react-native) lack needed support.
1408 | (function nonStandardBrowserEnv() {
1409 | return function isURLSameOrigin() {
1410 | return true;
1411 | };
1412 | })()
1413 | );
1414 |
1415 |
1416 | /***/ }),
1417 |
1418 | /***/ "./node_modules/axios/lib/helpers/normalizeHeaderName.js":
1419 | /*!***************************************************************!*\
1420 | !*** ./node_modules/axios/lib/helpers/normalizeHeaderName.js ***!
1421 | \***************************************************************/
1422 | /*! no static exports found */
1423 | /***/ (function(module, exports, __webpack_require__) {
1424 |
1425 | "use strict";
1426 |
1427 |
1428 | var utils = __webpack_require__(/*! ../utils */ "./node_modules/axios/lib/utils.js");
1429 |
1430 | module.exports = function normalizeHeaderName(headers, normalizedName) {
1431 | utils.forEach(headers, function processHeader(value, name) {
1432 | if (name !== normalizedName && name.toUpperCase() === normalizedName.toUpperCase()) {
1433 | headers[normalizedName] = value;
1434 | delete headers[name];
1435 | }
1436 | });
1437 | };
1438 |
1439 |
1440 | /***/ }),
1441 |
1442 | /***/ "./node_modules/axios/lib/helpers/parseHeaders.js":
1443 | /*!********************************************************!*\
1444 | !*** ./node_modules/axios/lib/helpers/parseHeaders.js ***!
1445 | \********************************************************/
1446 | /*! no static exports found */
1447 | /***/ (function(module, exports, __webpack_require__) {
1448 |
1449 | "use strict";
1450 |
1451 |
1452 | var utils = __webpack_require__(/*! ./../utils */ "./node_modules/axios/lib/utils.js");
1453 |
1454 | // Headers whose duplicates are ignored by node
1455 | // c.f. https://nodejs.org/api/http.html#http_message_headers
1456 | var ignoreDuplicateOf = [
1457 | 'age', 'authorization', 'content-length', 'content-type', 'etag',
1458 | 'expires', 'from', 'host', 'if-modified-since', 'if-unmodified-since',
1459 | 'last-modified', 'location', 'max-forwards', 'proxy-authorization',
1460 | 'referer', 'retry-after', 'user-agent'
1461 | ];
1462 |
1463 | /**
1464 | * Parse headers into an object
1465 | *
1466 | * ```
1467 | * Date: Wed, 27 Aug 2014 08:58:49 GMT
1468 | * Content-Type: application/json
1469 | * Connection: keep-alive
1470 | * Transfer-Encoding: chunked
1471 | * ```
1472 | *
1473 | * @param {String} headers Headers needing to be parsed
1474 | * @returns {Object} Headers parsed into an object
1475 | */
1476 | module.exports = function parseHeaders(headers) {
1477 | var parsed = {};
1478 | var key;
1479 | var val;
1480 | var i;
1481 |
1482 | if (!headers) { return parsed; }
1483 |
1484 | utils.forEach(headers.split('\n'), function parser(line) {
1485 | i = line.indexOf(':');
1486 | key = utils.trim(line.substr(0, i)).toLowerCase();
1487 | val = utils.trim(line.substr(i + 1));
1488 |
1489 | if (key) {
1490 | if (parsed[key] && ignoreDuplicateOf.indexOf(key) >= 0) {
1491 | return;
1492 | }
1493 | if (key === 'set-cookie') {
1494 | parsed[key] = (parsed[key] ? parsed[key] : []).concat([val]);
1495 | } else {
1496 | parsed[key] = parsed[key] ? parsed[key] + ', ' + val : val;
1497 | }
1498 | }
1499 | });
1500 |
1501 | return parsed;
1502 | };
1503 |
1504 |
1505 | /***/ }),
1506 |
1507 | /***/ "./node_modules/axios/lib/helpers/spread.js":
1508 | /*!**************************************************!*\
1509 | !*** ./node_modules/axios/lib/helpers/spread.js ***!
1510 | \**************************************************/
1511 | /*! no static exports found */
1512 | /***/ (function(module, exports, __webpack_require__) {
1513 |
1514 | "use strict";
1515 |
1516 |
1517 | /**
1518 | * Syntactic sugar for invoking a function and expanding an array for arguments.
1519 | *
1520 | * Common use case would be to use `Function.prototype.apply`.
1521 | *
1522 | * ```js
1523 | * function f(x, y, z) {}
1524 | * var args = [1, 2, 3];
1525 | * f.apply(null, args);
1526 | * ```
1527 | *
1528 | * With `spread` this example can be re-written.
1529 | *
1530 | * ```js
1531 | * spread(function(x, y, z) {})([1, 2, 3]);
1532 | * ```
1533 | *
1534 | * @param {Function} callback
1535 | * @returns {Function}
1536 | */
1537 | module.exports = function spread(callback) {
1538 | return function wrap(arr) {
1539 | return callback.apply(null, arr);
1540 | };
1541 | };
1542 |
1543 |
1544 | /***/ }),
1545 |
1546 | /***/ "./node_modules/axios/lib/utils.js":
1547 | /*!*****************************************!*\
1548 | !*** ./node_modules/axios/lib/utils.js ***!
1549 | \*****************************************/
1550 | /*! no static exports found */
1551 | /***/ (function(module, exports, __webpack_require__) {
1552 |
1553 | "use strict";
1554 |
1555 |
1556 | var bind = __webpack_require__(/*! ./helpers/bind */ "./node_modules/axios/lib/helpers/bind.js");
1557 |
1558 | /*global toString:true*/
1559 |
1560 | // utils is a library of generic helper functions non-specific to axios
1561 |
1562 | var toString = Object.prototype.toString;
1563 |
1564 | /**
1565 | * Determine if a value is an Array
1566 | *
1567 | * @param {Object} val The value to test
1568 | * @returns {boolean} True if value is an Array, otherwise false
1569 | */
1570 | function isArray(val) {
1571 | return toString.call(val) === '[object Array]';
1572 | }
1573 |
1574 | /**
1575 | * Determine if a value is undefined
1576 | *
1577 | * @param {Object} val The value to test
1578 | * @returns {boolean} True if the value is undefined, otherwise false
1579 | */
1580 | function isUndefined(val) {
1581 | return typeof val === 'undefined';
1582 | }
1583 |
1584 | /**
1585 | * Determine if a value is a Buffer
1586 | *
1587 | * @param {Object} val The value to test
1588 | * @returns {boolean} True if value is a Buffer, otherwise false
1589 | */
1590 | function isBuffer(val) {
1591 | return val !== null && !isUndefined(val) && val.constructor !== null && !isUndefined(val.constructor)
1592 | && typeof val.constructor.isBuffer === 'function' && val.constructor.isBuffer(val);
1593 | }
1594 |
1595 | /**
1596 | * Determine if a value is an ArrayBuffer
1597 | *
1598 | * @param {Object} val The value to test
1599 | * @returns {boolean} True if value is an ArrayBuffer, otherwise false
1600 | */
1601 | function isArrayBuffer(val) {
1602 | return toString.call(val) === '[object ArrayBuffer]';
1603 | }
1604 |
1605 | /**
1606 | * Determine if a value is a FormData
1607 | *
1608 | * @param {Object} val The value to test
1609 | * @returns {boolean} True if value is an FormData, otherwise false
1610 | */
1611 | function isFormData(val) {
1612 | return (typeof FormData !== 'undefined') && (val instanceof FormData);
1613 | }
1614 |
1615 | /**
1616 | * Determine if a value is a view on an ArrayBuffer
1617 | *
1618 | * @param {Object} val The value to test
1619 | * @returns {boolean} True if value is a view on an ArrayBuffer, otherwise false
1620 | */
1621 | function isArrayBufferView(val) {
1622 | var result;
1623 | if ((typeof ArrayBuffer !== 'undefined') && (ArrayBuffer.isView)) {
1624 | result = ArrayBuffer.isView(val);
1625 | } else {
1626 | result = (val) && (val.buffer) && (val.buffer instanceof ArrayBuffer);
1627 | }
1628 | return result;
1629 | }
1630 |
1631 | /**
1632 | * Determine if a value is a String
1633 | *
1634 | * @param {Object} val The value to test
1635 | * @returns {boolean} True if value is a String, otherwise false
1636 | */
1637 | function isString(val) {
1638 | return typeof val === 'string';
1639 | }
1640 |
1641 | /**
1642 | * Determine if a value is a Number
1643 | *
1644 | * @param {Object} val The value to test
1645 | * @returns {boolean} True if value is a Number, otherwise false
1646 | */
1647 | function isNumber(val) {
1648 | return typeof val === 'number';
1649 | }
1650 |
1651 | /**
1652 | * Determine if a value is an Object
1653 | *
1654 | * @param {Object} val The value to test
1655 | * @returns {boolean} True if value is an Object, otherwise false
1656 | */
1657 | function isObject(val) {
1658 | return val !== null && typeof val === 'object';
1659 | }
1660 |
1661 | /**
1662 | * Determine if a value is a Date
1663 | *
1664 | * @param {Object} val The value to test
1665 | * @returns {boolean} True if value is a Date, otherwise false
1666 | */
1667 | function isDate(val) {
1668 | return toString.call(val) === '[object Date]';
1669 | }
1670 |
1671 | /**
1672 | * Determine if a value is a File
1673 | *
1674 | * @param {Object} val The value to test
1675 | * @returns {boolean} True if value is a File, otherwise false
1676 | */
1677 | function isFile(val) {
1678 | return toString.call(val) === '[object File]';
1679 | }
1680 |
1681 | /**
1682 | * Determine if a value is a Blob
1683 | *
1684 | * @param {Object} val The value to test
1685 | * @returns {boolean} True if value is a Blob, otherwise false
1686 | */
1687 | function isBlob(val) {
1688 | return toString.call(val) === '[object Blob]';
1689 | }
1690 |
1691 | /**
1692 | * Determine if a value is a Function
1693 | *
1694 | * @param {Object} val The value to test
1695 | * @returns {boolean} True if value is a Function, otherwise false
1696 | */
1697 | function isFunction(val) {
1698 | return toString.call(val) === '[object Function]';
1699 | }
1700 |
1701 | /**
1702 | * Determine if a value is a Stream
1703 | *
1704 | * @param {Object} val The value to test
1705 | * @returns {boolean} True if value is a Stream, otherwise false
1706 | */
1707 | function isStream(val) {
1708 | return isObject(val) && isFunction(val.pipe);
1709 | }
1710 |
1711 | /**
1712 | * Determine if a value is a URLSearchParams object
1713 | *
1714 | * @param {Object} val The value to test
1715 | * @returns {boolean} True if value is a URLSearchParams object, otherwise false
1716 | */
1717 | function isURLSearchParams(val) {
1718 | return typeof URLSearchParams !== 'undefined' && val instanceof URLSearchParams;
1719 | }
1720 |
1721 | /**
1722 | * Trim excess whitespace off the beginning and end of a string
1723 | *
1724 | * @param {String} str The String to trim
1725 | * @returns {String} The String freed of excess whitespace
1726 | */
1727 | function trim(str) {
1728 | return str.replace(/^\s*/, '').replace(/\s*$/, '');
1729 | }
1730 |
1731 | /**
1732 | * Determine if we're running in a standard browser environment
1733 | *
1734 | * This allows axios to run in a web worker, and react-native.
1735 | * Both environments support XMLHttpRequest, but not fully standard globals.
1736 | *
1737 | * web workers:
1738 | * typeof window -> undefined
1739 | * typeof document -> undefined
1740 | *
1741 | * react-native:
1742 | * navigator.product -> 'ReactNative'
1743 | * nativescript
1744 | * navigator.product -> 'NativeScript' or 'NS'
1745 | */
1746 | function isStandardBrowserEnv() {
1747 | if (typeof navigator !== 'undefined' && (navigator.product === 'ReactNative' ||
1748 | navigator.product === 'NativeScript' ||
1749 | navigator.product === 'NS')) {
1750 | return false;
1751 | }
1752 | return (
1753 | typeof window !== 'undefined' &&
1754 | typeof document !== 'undefined'
1755 | );
1756 | }
1757 |
1758 | /**
1759 | * Iterate over an Array or an Object invoking a function for each item.
1760 | *
1761 | * If `obj` is an Array callback will be called passing
1762 | * the value, index, and complete array for each item.
1763 | *
1764 | * If 'obj' is an Object callback will be called passing
1765 | * the value, key, and complete object for each property.
1766 | *
1767 | * @param {Object|Array} obj The object to iterate
1768 | * @param {Function} fn The callback to invoke for each item
1769 | */
1770 | function forEach(obj, fn) {
1771 | // Don't bother if no value provided
1772 | if (obj === null || typeof obj === 'undefined') {
1773 | return;
1774 | }
1775 |
1776 | // Force an array if not already something iterable
1777 | if (typeof obj !== 'object') {
1778 | /*eslint no-param-reassign:0*/
1779 | obj = [obj];
1780 | }
1781 |
1782 | if (isArray(obj)) {
1783 | // Iterate over array values
1784 | for (var i = 0, l = obj.length; i < l; i++) {
1785 | fn.call(null, obj[i], i, obj);
1786 | }
1787 | } else {
1788 | // Iterate over object keys
1789 | for (var key in obj) {
1790 | if (Object.prototype.hasOwnProperty.call(obj, key)) {
1791 | fn.call(null, obj[key], key, obj);
1792 | }
1793 | }
1794 | }
1795 | }
1796 |
1797 | /**
1798 | * Accepts varargs expecting each argument to be an object, then
1799 | * immutably merges the properties of each object and returns result.
1800 | *
1801 | * When multiple objects contain the same key the later object in
1802 | * the arguments list will take precedence.
1803 | *
1804 | * Example:
1805 | *
1806 | * ```js
1807 | * var result = merge({foo: 123}, {foo: 456});
1808 | * console.log(result.foo); // outputs 456
1809 | * ```
1810 | *
1811 | * @param {Object} obj1 Object to merge
1812 | * @returns {Object} Result of all merge properties
1813 | */
1814 | function merge(/* obj1, obj2, obj3, ... */) {
1815 | var result = {};
1816 | function assignValue(val, key) {
1817 | if (typeof result[key] === 'object' && typeof val === 'object') {
1818 | result[key] = merge(result[key], val);
1819 | } else {
1820 | result[key] = val;
1821 | }
1822 | }
1823 |
1824 | for (var i = 0, l = arguments.length; i < l; i++) {
1825 | forEach(arguments[i], assignValue);
1826 | }
1827 | return result;
1828 | }
1829 |
1830 | /**
1831 | * Function equal to merge with the difference being that no reference
1832 | * to original objects is kept.
1833 | *
1834 | * @see merge
1835 | * @param {Object} obj1 Object to merge
1836 | * @returns {Object} Result of all merge properties
1837 | */
1838 | function deepMerge(/* obj1, obj2, obj3, ... */) {
1839 | var result = {};
1840 | function assignValue(val, key) {
1841 | if (typeof result[key] === 'object' && typeof val === 'object') {
1842 | result[key] = deepMerge(result[key], val);
1843 | } else if (typeof val === 'object') {
1844 | result[key] = deepMerge({}, val);
1845 | } else {
1846 | result[key] = val;
1847 | }
1848 | }
1849 |
1850 | for (var i = 0, l = arguments.length; i < l; i++) {
1851 | forEach(arguments[i], assignValue);
1852 | }
1853 | return result;
1854 | }
1855 |
1856 | /**
1857 | * Extends object a by mutably adding to it the properties of object b.
1858 | *
1859 | * @param {Object} a The object to be extended
1860 | * @param {Object} b The object to copy properties from
1861 | * @param {Object} thisArg The object to bind function to
1862 | * @return {Object} The resulting value of object a
1863 | */
1864 | function extend(a, b, thisArg) {
1865 | forEach(b, function assignValue(val, key) {
1866 | if (thisArg && typeof val === 'function') {
1867 | a[key] = bind(val, thisArg);
1868 | } else {
1869 | a[key] = val;
1870 | }
1871 | });
1872 | return a;
1873 | }
1874 |
1875 | module.exports = {
1876 | isArray: isArray,
1877 | isArrayBuffer: isArrayBuffer,
1878 | isBuffer: isBuffer,
1879 | isFormData: isFormData,
1880 | isArrayBufferView: isArrayBufferView,
1881 | isString: isString,
1882 | isNumber: isNumber,
1883 | isObject: isObject,
1884 | isUndefined: isUndefined,
1885 | isDate: isDate,
1886 | isFile: isFile,
1887 | isBlob: isBlob,
1888 | isFunction: isFunction,
1889 | isStream: isStream,
1890 | isURLSearchParams: isURLSearchParams,
1891 | isStandardBrowserEnv: isStandardBrowserEnv,
1892 | forEach: forEach,
1893 | merge: merge,
1894 | deepMerge: deepMerge,
1895 | extend: extend,
1896 | trim: trim
1897 | };
1898 |
1899 |
1900 | /***/ }),
1901 |
1902 | /***/ "./node_modules/process/browser.js":
1903 | /*!*****************************************!*\
1904 | !*** ./node_modules/process/browser.js ***!
1905 | \*****************************************/
1906 | /*! no static exports found */
1907 | /***/ (function(module, exports) {
1908 |
1909 | // shim for using process in browser
1910 | var process = module.exports = {};
1911 |
1912 | // cached from whatever global is present so that test runners that stub it
1913 | // don't break things. But we need to wrap it in a try catch in case it is
1914 | // wrapped in strict mode code which doesn't define any globals. It's inside a
1915 | // function because try/catches deoptimize in certain engines.
1916 |
1917 | var cachedSetTimeout;
1918 | var cachedClearTimeout;
1919 |
1920 | function defaultSetTimout() {
1921 | throw new Error('setTimeout has not been defined');
1922 | }
1923 | function defaultClearTimeout () {
1924 | throw new Error('clearTimeout has not been defined');
1925 | }
1926 | (function () {
1927 | try {
1928 | if (typeof setTimeout === 'function') {
1929 | cachedSetTimeout = setTimeout;
1930 | } else {
1931 | cachedSetTimeout = defaultSetTimout;
1932 | }
1933 | } catch (e) {
1934 | cachedSetTimeout = defaultSetTimout;
1935 | }
1936 | try {
1937 | if (typeof clearTimeout === 'function') {
1938 | cachedClearTimeout = clearTimeout;
1939 | } else {
1940 | cachedClearTimeout = defaultClearTimeout;
1941 | }
1942 | } catch (e) {
1943 | cachedClearTimeout = defaultClearTimeout;
1944 | }
1945 | } ())
1946 | function runTimeout(fun) {
1947 | if (cachedSetTimeout === setTimeout) {
1948 | //normal enviroments in sane situations
1949 | return setTimeout(fun, 0);
1950 | }
1951 | // if setTimeout wasn't available but was latter defined
1952 | if ((cachedSetTimeout === defaultSetTimout || !cachedSetTimeout) && setTimeout) {
1953 | cachedSetTimeout = setTimeout;
1954 | return setTimeout(fun, 0);
1955 | }
1956 | try {
1957 | // when when somebody has screwed with setTimeout but no I.E. maddness
1958 | return cachedSetTimeout(fun, 0);
1959 | } catch(e){
1960 | try {
1961 | // When we are in I.E. but the script has been evaled so I.E. doesn't trust the global object when called normally
1962 | return cachedSetTimeout.call(null, fun, 0);
1963 | } catch(e){
1964 | // same as above but when it's a version of I.E. that must have the global object for 'this', hopfully our context correct otherwise it will throw a global error
1965 | return cachedSetTimeout.call(this, fun, 0);
1966 | }
1967 | }
1968 |
1969 |
1970 | }
1971 | function runClearTimeout(marker) {
1972 | if (cachedClearTimeout === clearTimeout) {
1973 | //normal enviroments in sane situations
1974 | return clearTimeout(marker);
1975 | }
1976 | // if clearTimeout wasn't available but was latter defined
1977 | if ((cachedClearTimeout === defaultClearTimeout || !cachedClearTimeout) && clearTimeout) {
1978 | cachedClearTimeout = clearTimeout;
1979 | return clearTimeout(marker);
1980 | }
1981 | try {
1982 | // when when somebody has screwed with setTimeout but no I.E. maddness
1983 | return cachedClearTimeout(marker);
1984 | } catch (e){
1985 | try {
1986 | // When we are in I.E. but the script has been evaled so I.E. doesn't trust the global object when called normally
1987 | return cachedClearTimeout.call(null, marker);
1988 | } catch (e){
1989 | // same as above but when it's a version of I.E. that must have the global object for 'this', hopfully our context correct otherwise it will throw a global error.
1990 | // Some versions of I.E. have different rules for clearTimeout vs setTimeout
1991 | return cachedClearTimeout.call(this, marker);
1992 | }
1993 | }
1994 |
1995 |
1996 |
1997 | }
1998 | var queue = [];
1999 | var draining = false;
2000 | var currentQueue;
2001 | var queueIndex = -1;
2002 |
2003 | function cleanUpNextTick() {
2004 | if (!draining || !currentQueue) {
2005 | return;
2006 | }
2007 | draining = false;
2008 | if (currentQueue.length) {
2009 | queue = currentQueue.concat(queue);
2010 | } else {
2011 | queueIndex = -1;
2012 | }
2013 | if (queue.length) {
2014 | drainQueue();
2015 | }
2016 | }
2017 |
2018 | function drainQueue() {
2019 | if (draining) {
2020 | return;
2021 | }
2022 | var timeout = runTimeout(cleanUpNextTick);
2023 | draining = true;
2024 |
2025 | var len = queue.length;
2026 | while(len) {
2027 | currentQueue = queue;
2028 | queue = [];
2029 | while (++queueIndex < len) {
2030 | if (currentQueue) {
2031 | currentQueue[queueIndex].run();
2032 | }
2033 | }
2034 | queueIndex = -1;
2035 | len = queue.length;
2036 | }
2037 | currentQueue = null;
2038 | draining = false;
2039 | runClearTimeout(timeout);
2040 | }
2041 |
2042 | process.nextTick = function (fun) {
2043 | var args = new Array(arguments.length - 1);
2044 | if (arguments.length > 1) {
2045 | for (var i = 1; i < arguments.length; i++) {
2046 | args[i - 1] = arguments[i];
2047 | }
2048 | }
2049 | queue.push(new Item(fun, args));
2050 | if (queue.length === 1 && !draining) {
2051 | runTimeout(drainQueue);
2052 | }
2053 | };
2054 |
2055 | // v8 likes predictible objects
2056 | function Item(fun, array) {
2057 | this.fun = fun;
2058 | this.array = array;
2059 | }
2060 | Item.prototype.run = function () {
2061 | this.fun.apply(null, this.array);
2062 | };
2063 | process.title = 'browser';
2064 | process.browser = true;
2065 | process.env = {};
2066 | process.argv = [];
2067 | process.version = ''; // empty string to avoid regexp issues
2068 | process.versions = {};
2069 |
2070 | function noop() {}
2071 |
2072 | process.on = noop;
2073 | process.addListener = noop;
2074 | process.once = noop;
2075 | process.off = noop;
2076 | process.removeListener = noop;
2077 | process.removeAllListeners = noop;
2078 | process.emit = noop;
2079 | process.prependListener = noop;
2080 | process.prependOnceListener = noop;
2081 |
2082 | process.listeners = function (name) { return [] }
2083 |
2084 | process.binding = function (name) {
2085 | throw new Error('process.binding is not supported');
2086 | };
2087 |
2088 | process.cwd = function () { return '/' };
2089 | process.chdir = function (dir) {
2090 | throw new Error('process.chdir is not supported');
2091 | };
2092 | process.umask = function() { return 0; };
2093 |
2094 |
2095 | /***/ }),
2096 |
2097 | /***/ "./src/index.ts":
2098 | /*!**********************!*\
2099 | !*** ./src/index.ts ***!
2100 | \**********************/
2101 | /*! no exports provided */
2102 | /***/ (function(module, __webpack_exports__, __webpack_require__) {
2103 |
2104 | "use strict";
2105 | __webpack_require__.r(__webpack_exports__);
2106 | /* harmony import */ var axios__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! axios */ "./node_modules/axios/index.js");
2107 | /* harmony import */ var axios__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(axios__WEBPACK_IMPORTED_MODULE_0__);
2108 | /* harmony import */ var _table__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./table */ "./src/table.ts");
2109 |
2110 |
2111 | var userTable = new _table__WEBPACK_IMPORTED_MODULE_1__["default"]();
2112 | axios__WEBPACK_IMPORTED_MODULE_0___default.a.get('https://reqres.in/api/users')
2113 | .then(function (response) {
2114 | userTable.populate(response.data.data);
2115 | });
2116 |
2117 |
2118 | /***/ }),
2119 |
2120 | /***/ "./src/table.ts":
2121 | /*!**********************!*\
2122 | !*** ./src/table.ts ***!
2123 | \**********************/
2124 | /*! exports provided: default */
2125 | /***/ (function(module, __webpack_exports__, __webpack_require__) {
2126 |
2127 | "use strict";
2128 | __webpack_require__.r(__webpack_exports__);
2129 | var UserTable = /** @class */ (function () {
2130 | function UserTable() {
2131 | this.table = document.createElement('table');
2132 | this.createHeader();
2133 | this.tbody = this.table.createTBody();
2134 | var body = document.getElementsByTagName('body')[0];
2135 | body.appendChild(this.table);
2136 | }
2137 | UserTable.prototype.createHeader = function () {
2138 | this.thead = this.table.createTHead();
2139 | var hrow = this.thead.insertRow(0);
2140 | var columns = ['ID', 'email', 'First Name', 'Last Name', 'Avatar'];
2141 | columns.forEach(function (column) {
2142 | var cell = hrow.insertCell(hrow.cells.length);
2143 | cell.innerHTML = column;
2144 | });
2145 | };
2146 | UserTable.prototype.populate = function (users) {
2147 | var _this = this;
2148 | users.forEach(function (user) {
2149 | var row = _this.tbody.insertRow(_this.tbody.rows.length);
2150 | for (var _i = 0, _a = Object.keys(user); _i < _a.length; _i++) {
2151 | var field = _a[_i];
2152 | var cell = row.insertCell(row.cells.length);
2153 | cell.innerHTML = user[field];
2154 | }
2155 | });
2156 | };
2157 | return UserTable;
2158 | }());
2159 | /* harmony default export */ __webpack_exports__["default"] = (UserTable);
2160 |
2161 |
2162 | /***/ })
2163 |
2164 | /******/ });
2165 | //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack:///webpack/bootstrap","webpack:///./node_modules/axios/index.js","webpack:///./node_modules/axios/lib/adapters/xhr.js","webpack:///./node_modules/axios/lib/axios.js","webpack:///./node_modules/axios/lib/cancel/Cancel.js","webpack:///./node_modules/axios/lib/cancel/CancelToken.js","webpack:///./node_modules/axios/lib/cancel/isCancel.js","webpack:///./node_modules/axios/lib/core/Axios.js","webpack:///./node_modules/axios/lib/core/InterceptorManager.js","webpack:///./node_modules/axios/lib/core/buildFullPath.js","webpack:///./node_modules/axios/lib/core/createError.js","webpack:///./node_modules/axios/lib/core/dispatchRequest.js","webpack:///./node_modules/axios/lib/core/enhanceError.js","webpack:///./node_modules/axios/lib/core/mergeConfig.js","webpack:///./node_modules/axios/lib/core/settle.js","webpack:///./node_modules/axios/lib/core/transformData.js","webpack:///./node_modules/axios/lib/defaults.js","webpack:///./node_modules/axios/lib/helpers/bind.js","webpack:///./node_modules/axios/lib/helpers/buildURL.js","webpack:///./node_modules/axios/lib/helpers/combineURLs.js","webpack:///./node_modules/axios/lib/helpers/cookies.js","webpack:///./node_modules/axios/lib/helpers/isAbsoluteURL.js","webpack:///./node_modules/axios/lib/helpers/isURLSameOrigin.js","webpack:///./node_modules/axios/lib/helpers/normalizeHeaderName.js","webpack:///./node_modules/axios/lib/helpers/parseHeaders.js","webpack:///./node_modules/axios/lib/helpers/spread.js","webpack:///./node_modules/axios/lib/utils.js","webpack:///./node_modules/process/browser.js","webpack:///./src/index.ts","webpack:///./src/table.ts"],"names":[],"mappings":";QAAA;QACA;;QAEA;QACA;;QAEA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;;QAEA;QACA;;QAEA;QACA;;QAEA;QACA;QACA;;;QAGA;QACA;;QAEA;QACA;;QAEA;QACA;QACA;QACA,0CAA0C,gCAAgC;QAC1E;QACA;;QAEA;QACA;QACA;QACA,wDAAwD,kBAAkB;QAC1E;QACA,iDAAiD,cAAc;QAC/D;;QAEA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA,yCAAyC,iCAAiC;QAC1E,gHAAgH,mBAAmB,EAAE;QACrI;QACA;;QAEA;QACA;QACA;QACA,2BAA2B,0BAA0B,EAAE;QACvD,iCAAiC,eAAe;QAChD;QACA;QACA;;QAEA;QACA,sDAAsD,+DAA+D;;QAErH;QACA;;;QAGA;QACA;;;;;;;;;;;;AClFA,iBAAiB,mBAAO,CAAC,sDAAa,E;;;;;;;;;;;;ACAzB;;AAEb,YAAY,mBAAO,CAAC,qDAAY;AAChC,aAAa,mBAAO,CAAC,iEAAkB;AACvC,eAAe,mBAAO,CAAC,2EAAuB;AAC9C,oBAAoB,mBAAO,CAAC,6EAAuB;AACnD,mBAAmB,mBAAO,CAAC,mFAA2B;AACtD,sBAAsB,mBAAO,CAAC,yFAA8B;AAC5D,kBAAkB,mBAAO,CAAC,yEAAqB;;AAE/C;AACA;AACA;AACA;;AAEA;AACA,4CAA4C;AAC5C;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,oBAAoB,mBAAO,CAAC,yEAAsB;;AAElD;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA,OAAO;AACP;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,OAAO;AACP;;AAEA;AACA;AACA;;AAEA;AACA;AACA,GAAG;AACH;;;;;;;;;;;;;ACnLa;;AAEb,YAAY,mBAAO,CAAC,kDAAS;AAC7B,WAAW,mBAAO,CAAC,gEAAgB;AACnC,YAAY,mBAAO,CAAC,4DAAc;AAClC,kBAAkB,mBAAO,CAAC,wEAAoB;AAC9C,eAAe,mBAAO,CAAC,wDAAY;;AAEnC;AACA;AACA;AACA,WAAW,OAAO;AAClB,YAAY,MAAM;AAClB;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA,eAAe,mBAAO,CAAC,kEAAiB;AACxC,oBAAoB,mBAAO,CAAC,4EAAsB;AAClD,iBAAiB,mBAAO,CAAC,sEAAmB;;AAE5C;AACA;AACA;AACA;AACA,eAAe,mBAAO,CAAC,oEAAkB;;AAEzC;;AAEA;AACA;;;;;;;;;;;;;ACpDa;;AAEb;AACA;AACA;AACA;AACA,WAAW,QAAQ;AACnB;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;;;;;;;;;;;;;AClBa;;AAEb,aAAa,mBAAO,CAAC,2DAAU;;AAE/B;AACA;AACA;AACA;AACA,WAAW,SAAS;AACpB;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,GAAG;;AAEH;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,GAAG;AACH;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;;AAEA;;;;;;;;;;;;;ACxDa;;AAEb;AACA;AACA;;;;;;;;;;;;;ACJa;;AAEb,YAAY,mBAAO,CAAC,qDAAY;AAChC,eAAe,mBAAO,CAAC,yEAAqB;AAC5C,yBAAyB,mBAAO,CAAC,iFAAsB;AACvD,sBAAsB,mBAAO,CAAC,2EAAmB;AACjD,kBAAkB,mBAAO,CAAC,mEAAe;;AAEzC;AACA;AACA;AACA,WAAW,OAAO;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAW,OAAO;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;;AAEA;;AAEA;AACA;AACA;AACA,GAAG;AACH;AACA,GAAG;AACH;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA,GAAG;;AAEH;AACA;AACA,GAAG;;AAEH;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,gDAAgD;AAChD;AACA;AACA,KAAK;AACL;AACA,CAAC;;AAED;AACA;AACA;AACA,gDAAgD;AAChD;AACA;AACA;AACA,KAAK;AACL;AACA,CAAC;;AAED;;;;;;;;;;;;;AC7Fa;;AAEb,YAAY,mBAAO,CAAC,qDAAY;;AAEhC;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAW,SAAS;AACpB,WAAW,SAAS;AACpB;AACA,YAAY,OAAO;AACnB;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;;AAEA;AACA;AACA;AACA,WAAW,OAAO;AAClB;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,SAAS;AACpB;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;;AAEA;;;;;;;;;;;;;ACnDa;;AAEb,oBAAoB,mBAAO,CAAC,mFAA0B;AACtD,kBAAkB,mBAAO,CAAC,+EAAwB;;AAElD;AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,WAAW,OAAO;AAClB,aAAa,OAAO;AACpB;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;;;;ACnBa;;AAEb,mBAAmB,mBAAO,CAAC,qEAAgB;;AAE3C;AACA;AACA;AACA,WAAW,OAAO;AAClB,WAAW,OAAO;AAClB,WAAW,OAAO;AAClB,WAAW,OAAO;AAClB,WAAW,OAAO;AAClB,aAAa,MAAM;AACnB;AACA;AACA;AACA;AACA;;;;;;;;;;;;;ACjBa;;AAEb,YAAY,mBAAO,CAAC,qDAAY;AAChC,oBAAoB,mBAAO,CAAC,uEAAiB;AAC7C,eAAe,mBAAO,CAAC,uEAAoB;AAC3C,eAAe,mBAAO,CAAC,yDAAa;;AAEpC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAW,OAAO;AAClB,aAAa,QAAQ;AACrB;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,+BAA+B;AAC/B,uCAAuC;AACvC;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,GAAG;AACH;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,GAAG;AACH;;;;;;;;;;;;;AC9Ea;;AAEb;AACA;AACA;AACA,WAAW,MAAM;AACjB,WAAW,OAAO;AAClB,WAAW,OAAO;AAClB,WAAW,OAAO;AAClB,WAAW,OAAO;AAClB,aAAa,MAAM;AACnB;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;;;;ACzCa;;AAEb,YAAY,mBAAO,CAAC,mDAAU;;AAE9B;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,WAAW,OAAO;AAClB,aAAa,OAAO;AACpB;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;AACA;AACA,KAAK;AACL;AACA,KAAK;AACL;AACA,KAAK;AACL;AACA;AACA,GAAG;;AAEH;AACA;AACA;AACA,KAAK;AACL;AACA;AACA,GAAG;;AAEH;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,KAAK;;AAEL;AACA;AACA;AACA,KAAK;AACL;AACA;AACA,GAAG;;AAEH;AACA;;;;;;;;;;;;;ACxEa;;AAEb,kBAAkB,mBAAO,CAAC,mEAAe;;AAEzC;AACA;AACA;AACA,WAAW,SAAS;AACpB,WAAW,SAAS;AACpB,WAAW,OAAO;AAClB;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;;;;ACxBa;;AAEb,YAAY,mBAAO,CAAC,qDAAY;;AAEhC;AACA;AACA;AACA,WAAW,cAAc;AACzB,WAAW,MAAM;AACjB,WAAW,eAAe;AAC1B,aAAa,EAAE;AACf;AACA;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;;;;;;;;;;;;;ACnBA,+CAAa;;AAEb,YAAY,mBAAO,CAAC,kDAAS;AAC7B,0BAA0B,mBAAO,CAAC,8FAA+B;;AAEjE;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,cAAc,mBAAO,CAAC,gEAAgB;AACtC,GAAG;AACH;AACA,cAAc,mBAAO,CAAC,iEAAiB;AACvC;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,wEAAwE;AACxE;AACA;AACA;AACA,uDAAuD;AACvD;AACA;AACA;AACA,GAAG;;AAEH;AACA;AACA;AACA;AACA;AACA,OAAO,YAAY;AACnB;AACA;AACA,GAAG;;AAEH;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,CAAC;;AAED;AACA;AACA,CAAC;;AAED;;;;;;;;;;;;;;AChGa;;AAEb;AACA;AACA;AACA,mBAAmB,iBAAiB;AACpC;AACA;AACA;AACA;AACA;;;;;;;;;;;;;ACVa;;AAEb,YAAY,mBAAO,CAAC,qDAAY;;AAEhC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAW,OAAO;AAClB,WAAW,OAAO;AAClB,aAAa,OAAO;AACpB;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,GAAG;AACH;AACA,GAAG;AACH;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA,OAAO;AACP;AACA;;AAEA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA,OAAO;AACP,KAAK;;AAEL;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;;;;;;;;;;;;ACtEa;;AAEb;AACA;AACA;AACA,WAAW,OAAO;AAClB,WAAW,OAAO;AAClB,aAAa,OAAO;AACpB;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;;;;ACba;;AAEb,YAAY,mBAAO,CAAC,qDAAY;;AAEhC;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA,0CAA0C;AAC1C,SAAS;;AAET;AACA,4DAA4D,wBAAwB;AACpF;AACA,SAAS;;AAET;AACA;AACA;AACA;AACA,KAAK;;AAEL;AACA;AACA;AACA,kCAAkC;AAClC,+BAA+B,aAAa,EAAE;AAC9C;AACA;AACA,KAAK;AACL;;;;;;;;;;;;;ACpDa;;AAEb;AACA;AACA;AACA,WAAW,OAAO;AAClB,aAAa,QAAQ;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;;;;ACba;;AAEb,YAAY,mBAAO,CAAC,qDAAY;;AAEhC;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,cAAc,OAAO;AACrB,gBAAgB;AAChB;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA,cAAc,OAAO;AACrB,gBAAgB,QAAQ;AACxB;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;;AAEL;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;;;;;;;;;;;;;ACnEa;;AAEb,YAAY,mBAAO,CAAC,mDAAU;;AAE9B;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;;;;;;;;;;;;;ACXa;;AAEb,YAAY,mBAAO,CAAC,qDAAY;;AAEhC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,aAAa,OAAO;AACpB;AACA;AACA;AACA;AACA;AACA;;AAEA,iBAAiB,eAAe;;AAEhC;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA,GAAG;;AAEH;AACA;;;;;;;;;;;;;ACpDa;;AAEb;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,+BAA+B;AAC/B;AACA;AACA,WAAW,SAAS;AACpB,aAAa;AACb;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;;;;AC1Ba;;AAEb,WAAW,mBAAO,CAAC,gEAAgB;;AAEnC;;AAEA;;AAEA;;AAEA;AACA;AACA;AACA,WAAW,OAAO;AAClB,aAAa,QAAQ;AACrB;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAW,OAAO;AAClB,aAAa,QAAQ;AACrB;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAW,OAAO;AAClB,aAAa,QAAQ;AACrB;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAW,OAAO;AAClB,aAAa,QAAQ;AACrB;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAW,OAAO;AAClB,aAAa,QAAQ;AACrB;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAW,OAAO;AAClB,aAAa,QAAQ;AACrB;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAW,OAAO;AAClB,aAAa,QAAQ;AACrB;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAW,OAAO;AAClB,aAAa,QAAQ;AACrB;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAW,OAAO;AAClB,aAAa,QAAQ;AACrB;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAW,OAAO;AAClB,aAAa,QAAQ;AACrB;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAW,OAAO;AAClB,aAAa,QAAQ;AACrB;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAW,OAAO;AAClB,aAAa,QAAQ;AACrB;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAW,OAAO;AAClB,aAAa,QAAQ;AACrB;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAW,OAAO;AAClB,aAAa,QAAQ;AACrB;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAW,OAAO;AAClB,aAAa,QAAQ;AACrB;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAW,OAAO;AAClB,aAAa,OAAO;AACpB;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,aAAa;AACxB,WAAW,SAAS;AACpB;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,mCAAmC,OAAO;AAC1C;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,uBAAuB,SAAS,GAAG,SAAS;AAC5C,2BAA2B;AAC3B;AACA;AACA,WAAW,OAAO;AAClB,aAAa,OAAO;AACpB;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;;AAEA,uCAAuC,OAAO;AAC9C;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,aAAa,OAAO;AACpB;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL,gCAAgC;AAChC,KAAK;AACL;AACA;AACA;;AAEA,uCAAuC,OAAO;AAC9C;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAW,OAAO;AAClB,WAAW,OAAO;AAClB,WAAW,OAAO;AAClB,YAAY,OAAO;AACnB;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA,GAAG;AACH;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;;;ACvVA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA,CAAC;AACD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;;;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;;;;AAIA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,uBAAuB,sBAAsB;AAC7C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,qBAAqB;AACrB;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,qCAAqC;;AAErC;AACA;AACA;;AAEA,2BAA2B;AAC3B;AACA;AACA;AACA,4BAA4B,UAAU;;;;;;;;;;;;;ACvLtC;AAAA;AAAA;AAAA;AAA0B;AACM;AAEhC,IAAM,SAAS,GAAG,IAAI,8CAAS,EAAE;AACjC,4CAAK,CAAC,GAAG,CAAC,6BAA6B,CAAC;KACnC,IAAI,CAAC,kBAAQ;IACV,SAAS,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;AAC3C,CAAC,CAAC,CAAC;;;;;;;;;;;;;ACLP;AAAA;IAMI;QACI,IAAI,CAAC,KAAK,GAAG,QAAQ,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC;QAC7C,IAAI,CAAC,YAAY,EAAE,CAAC;QACpB,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,WAAW,EAAE,CAAC;QACtC,IAAM,IAAI,GAAG,QAAQ,CAAC,oBAAoB,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;QACtD,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACjC,CAAC;IAED,gCAAY,GAAZ;QACI,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,WAAW,EAAE,CAAC;QACtC,IAAM,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC;QACrC,IAAM,OAAO,GAAG,CAAC,IAAI,EAAE,OAAO,EAAE,YAAY,EAAE,WAAW,EAAE,QAAQ,CAAC,CAAC;QACrE,OAAO,CAAC,OAAO,CAAC,gBAAM;YAClB,IAAM,IAAI,GAAG,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;YAChD,IAAI,CAAC,SAAS,GAAG,MAAM,CAAC;QAC5B,CAAC,CAAC;IAEN,CAAC;IAED,4BAAQ,GAAR,UAAS,KAAa;QAAtB,iBAQC;QAPG,KAAK,CAAC,OAAO,CAAC,cAAI;YACd,IAAM,GAAG,GAAG,KAAI,CAAC,KAAK,CAAC,SAAS,CAAC,KAAI,CAAC,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;YACzD,KAAmB,UAAiB,EAAjB,WAAM,CAAC,IAAI,CAAC,IAAI,CAAC,EAAjB,cAAiB,EAAjB,IAAiB,EAAC;gBAAjC,IAAM,KAAK;gBACX,IAAM,IAAI,GAAG,GAAG,CAAC,UAAU,CAAC,GAAG,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;gBAC9C,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC;aAChC;QACL,CAAC,CAAC;IACN,CAAC;IAEL,gBAAC;AAAD,CAAC","file":"index.js","sourcesContent":[" \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n \t\t}\n \t};\n\n \t// define __esModule on exports\n \t__webpack_require__.r = function(exports) {\n \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n \t\t}\n \t\tObject.defineProperty(exports, '__esModule', { value: true });\n \t};\n\n \t// create a fake namespace object\n \t// mode & 1: value is a module id, require it\n \t// mode & 2: merge all properties of value into the ns\n \t// mode & 4: return value when already ns object\n \t// mode & 8|1: behave like require\n \t__webpack_require__.t = function(value, mode) {\n \t\tif(mode & 1) value = __webpack_require__(value);\n \t\tif(mode & 8) return value;\n \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n \t\tvar ns = Object.create(null);\n \t\t__webpack_require__.r(ns);\n \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n \t\treturn ns;\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"/js\";\n\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = \"./src/index.ts\");\n","module.exports = require('./lib/axios');","'use strict';\n\nvar utils = require('./../utils');\nvar settle = require('./../core/settle');\nvar buildURL = require('./../helpers/buildURL');\nvar buildFullPath = require('../core/buildFullPath');\nvar parseHeaders = require('./../helpers/parseHeaders');\nvar isURLSameOrigin = require('./../helpers/isURLSameOrigin');\nvar createError = require('../core/createError');\n\nmodule.exports = function xhrAdapter(config) {\n  return new Promise(function dispatchXhrRequest(resolve, reject) {\n    var requestData = config.data;\n    var requestHeaders = config.headers;\n\n    if (utils.isFormData(requestData)) {\n      delete requestHeaders['Content-Type']; // Let the browser set it\n    }\n\n    var request = new XMLHttpRequest();\n\n    // HTTP basic authentication\n    if (config.auth) {\n      var username = config.auth.username || '';\n      var password = config.auth.password || '';\n      requestHeaders.Authorization = 'Basic ' + btoa(username + ':' + password);\n    }\n\n    var fullPath = buildFullPath(config.baseURL, config.url);\n    request.open(config.method.toUpperCase(), buildURL(fullPath, config.params, config.paramsSerializer), true);\n\n    // Set the request timeout in MS\n    request.timeout = config.timeout;\n\n    // Listen for ready state\n    request.onreadystatechange = function handleLoad() {\n      if (!request || request.readyState !== 4) {\n        return;\n      }\n\n      // The request errored out and we didn't get a response, this will be\n      // handled by onerror instead\n      // With one exception: request that using file: protocol, most browsers\n      // will return status as 0 even though it's a successful request\n      if (request.status === 0 && !(request.responseURL && request.responseURL.indexOf('file:') === 0)) {\n        return;\n      }\n\n      // Prepare the response\n      var responseHeaders = 'getAllResponseHeaders' in request ? parseHeaders(request.getAllResponseHeaders()) : null;\n      var responseData = !config.responseType || config.responseType === 'text' ? request.responseText : request.response;\n      var response = {\n        data: responseData,\n        status: request.status,\n        statusText: request.statusText,\n        headers: responseHeaders,\n        config: config,\n        request: request\n      };\n\n      settle(resolve, reject, response);\n\n      // Clean up request\n      request = null;\n    };\n\n    // Handle browser request cancellation (as opposed to a manual cancellation)\n    request.onabort = function handleAbort() {\n      if (!request) {\n        return;\n      }\n\n      reject(createError('Request aborted', config, 'ECONNABORTED', request));\n\n      // Clean up request\n      request = null;\n    };\n\n    // Handle low level network errors\n    request.onerror = function handleError() {\n      // Real errors are hidden from us by the browser\n      // onerror should only fire if it's a network error\n      reject(createError('Network Error', config, null, request));\n\n      // Clean up request\n      request = null;\n    };\n\n    // Handle timeout\n    request.ontimeout = function handleTimeout() {\n      var timeoutErrorMessage = 'timeout of ' + config.timeout + 'ms exceeded';\n      if (config.timeoutErrorMessage) {\n        timeoutErrorMessage = config.timeoutErrorMessage;\n      }\n      reject(createError(timeoutErrorMessage, config, 'ECONNABORTED',\n        request));\n\n      // Clean up request\n      request = null;\n    };\n\n    // Add xsrf header\n    // This is only done if running in a standard browser environment.\n    // Specifically not if we're in a web worker, or react-native.\n    if (utils.isStandardBrowserEnv()) {\n      var cookies = require('./../helpers/cookies');\n\n      // Add xsrf header\n      var xsrfValue = (config.withCredentials || isURLSameOrigin(fullPath)) && config.xsrfCookieName ?\n        cookies.read(config.xsrfCookieName) :\n        undefined;\n\n      if (xsrfValue) {\n        requestHeaders[config.xsrfHeaderName] = xsrfValue;\n      }\n    }\n\n    // Add headers to the request\n    if ('setRequestHeader' in request) {\n      utils.forEach(requestHeaders, function setRequestHeader(val, key) {\n        if (typeof requestData === 'undefined' && key.toLowerCase() === 'content-type') {\n          // Remove Content-Type if data is undefined\n          delete requestHeaders[key];\n        } else {\n          // Otherwise add header to the request\n          request.setRequestHeader(key, val);\n        }\n      });\n    }\n\n    // Add withCredentials to request if needed\n    if (!utils.isUndefined(config.withCredentials)) {\n      request.withCredentials = !!config.withCredentials;\n    }\n\n    // Add responseType to request if needed\n    if (config.responseType) {\n      try {\n        request.responseType = config.responseType;\n      } catch (e) {\n        // Expected DOMException thrown by browsers not compatible XMLHttpRequest Level 2.\n        // But, this can be suppressed for 'json' type as it can be parsed by default 'transformResponse' function.\n        if (config.responseType !== 'json') {\n          throw e;\n        }\n      }\n    }\n\n    // Handle progress if needed\n    if (typeof config.onDownloadProgress === 'function') {\n      request.addEventListener('progress', config.onDownloadProgress);\n    }\n\n    // Not all browsers support upload events\n    if (typeof config.onUploadProgress === 'function' && request.upload) {\n      request.upload.addEventListener('progress', config.onUploadProgress);\n    }\n\n    if (config.cancelToken) {\n      // Handle cancellation\n      config.cancelToken.promise.then(function onCanceled(cancel) {\n        if (!request) {\n          return;\n        }\n\n        request.abort();\n        reject(cancel);\n        // Clean up request\n        request = null;\n      });\n    }\n\n    if (requestData === undefined) {\n      requestData = null;\n    }\n\n    // Send the request\n    request.send(requestData);\n  });\n};\n","'use strict';\n\nvar utils = require('./utils');\nvar bind = require('./helpers/bind');\nvar Axios = require('./core/Axios');\nvar mergeConfig = require('./core/mergeConfig');\nvar defaults = require('./defaults');\n\n/**\n * Create an instance of Axios\n *\n * @param {Object} defaultConfig The default config for the instance\n * @return {Axios} A new instance of Axios\n */\nfunction createInstance(defaultConfig) {\n  var context = new Axios(defaultConfig);\n  var instance = bind(Axios.prototype.request, context);\n\n  // Copy axios.prototype to instance\n  utils.extend(instance, Axios.prototype, context);\n\n  // Copy context to instance\n  utils.extend(instance, context);\n\n  return instance;\n}\n\n// Create the default instance to be exported\nvar axios = createInstance(defaults);\n\n// Expose Axios class to allow class inheritance\naxios.Axios = Axios;\n\n// Factory for creating new instances\naxios.create = function create(instanceConfig) {\n  return createInstance(mergeConfig(axios.defaults, instanceConfig));\n};\n\n// Expose Cancel & CancelToken\naxios.Cancel = require('./cancel/Cancel');\naxios.CancelToken = require('./cancel/CancelToken');\naxios.isCancel = require('./cancel/isCancel');\n\n// Expose all/spread\naxios.all = function all(promises) {\n  return Promise.all(promises);\n};\naxios.spread = require('./helpers/spread');\n\nmodule.exports = axios;\n\n// Allow use of default import syntax in TypeScript\nmodule.exports.default = axios;\n","'use strict';\n\n/**\n * A `Cancel` is an object that is thrown when an operation is canceled.\n *\n * @class\n * @param {string=} message The message.\n */\nfunction Cancel(message) {\n  this.message = message;\n}\n\nCancel.prototype.toString = function toString() {\n  return 'Cancel' + (this.message ? ': ' + this.message : '');\n};\n\nCancel.prototype.__CANCEL__ = true;\n\nmodule.exports = Cancel;\n","'use strict';\n\nvar Cancel = require('./Cancel');\n\n/**\n * A `CancelToken` is an object that can be used to request cancellation of an operation.\n *\n * @class\n * @param {Function} executor The executor function.\n */\nfunction CancelToken(executor) {\n  if (typeof executor !== 'function') {\n    throw new TypeError('executor must be a function.');\n  }\n\n  var resolvePromise;\n  this.promise = new Promise(function promiseExecutor(resolve) {\n    resolvePromise = resolve;\n  });\n\n  var token = this;\n  executor(function cancel(message) {\n    if (token.reason) {\n      // Cancellation has already been requested\n      return;\n    }\n\n    token.reason = new Cancel(message);\n    resolvePromise(token.reason);\n  });\n}\n\n/**\n * Throws a `Cancel` if cancellation has been requested.\n */\nCancelToken.prototype.throwIfRequested = function throwIfRequested() {\n  if (this.reason) {\n    throw this.reason;\n  }\n};\n\n/**\n * Returns an object that contains a new `CancelToken` and a function that, when called,\n * cancels the `CancelToken`.\n */\nCancelToken.source = function source() {\n  var cancel;\n  var token = new CancelToken(function executor(c) {\n    cancel = c;\n  });\n  return {\n    token: token,\n    cancel: cancel\n  };\n};\n\nmodule.exports = CancelToken;\n","'use strict';\n\nmodule.exports = function isCancel(value) {\n  return !!(value && value.__CANCEL__);\n};\n","'use strict';\n\nvar utils = require('./../utils');\nvar buildURL = require('../helpers/buildURL');\nvar InterceptorManager = require('./InterceptorManager');\nvar dispatchRequest = require('./dispatchRequest');\nvar mergeConfig = require('./mergeConfig');\n\n/**\n * Create a new instance of Axios\n *\n * @param {Object} instanceConfig The default config for the instance\n */\nfunction Axios(instanceConfig) {\n  this.defaults = instanceConfig;\n  this.interceptors = {\n    request: new InterceptorManager(),\n    response: new InterceptorManager()\n  };\n}\n\n/**\n * Dispatch a request\n *\n * @param {Object} config The config specific for this request (merged with this.defaults)\n */\nAxios.prototype.request = function request(config) {\n  /*eslint no-param-reassign:0*/\n  // Allow for axios('example/url'[, config]) a la fetch API\n  if (typeof config === 'string') {\n    config = arguments[1] || {};\n    config.url = arguments[0];\n  } else {\n    config = config || {};\n  }\n\n  config = mergeConfig(this.defaults, config);\n\n  // Set config.method\n  if (config.method) {\n    config.method = config.method.toLowerCase();\n  } else if (this.defaults.method) {\n    config.method = this.defaults.method.toLowerCase();\n  } else {\n    config.method = 'get';\n  }\n\n  // Hook up interceptors middleware\n  var chain = [dispatchRequest, undefined];\n  var promise = Promise.resolve(config);\n\n  this.interceptors.request.forEach(function unshiftRequestInterceptors(interceptor) {\n    chain.unshift(interceptor.fulfilled, interceptor.rejected);\n  });\n\n  this.interceptors.response.forEach(function pushResponseInterceptors(interceptor) {\n    chain.push(interceptor.fulfilled, interceptor.rejected);\n  });\n\n  while (chain.length) {\n    promise = promise.then(chain.shift(), chain.shift());\n  }\n\n  return promise;\n};\n\nAxios.prototype.getUri = function getUri(config) {\n  config = mergeConfig(this.defaults, config);\n  return buildURL(config.url, config.params, config.paramsSerializer).replace(/^\\?/, '');\n};\n\n// Provide aliases for supported request methods\nutils.forEach(['delete', 'get', 'head', 'options'], function forEachMethodNoData(method) {\n  /*eslint func-names:0*/\n  Axios.prototype[method] = function(url, config) {\n    return this.request(utils.merge(config || {}, {\n      method: method,\n      url: url\n    }));\n  };\n});\n\nutils.forEach(['post', 'put', 'patch'], function forEachMethodWithData(method) {\n  /*eslint func-names:0*/\n  Axios.prototype[method] = function(url, data, config) {\n    return this.request(utils.merge(config || {}, {\n      method: method,\n      url: url,\n      data: data\n    }));\n  };\n});\n\nmodule.exports = Axios;\n","'use strict';\n\nvar utils = require('./../utils');\n\nfunction InterceptorManager() {\n  this.handlers = [];\n}\n\n/**\n * Add a new interceptor to the stack\n *\n * @param {Function} fulfilled The function to handle `then` for a `Promise`\n * @param {Function} rejected The function to handle `reject` for a `Promise`\n *\n * @return {Number} An ID used to remove interceptor later\n */\nInterceptorManager.prototype.use = function use(fulfilled, rejected) {\n  this.handlers.push({\n    fulfilled: fulfilled,\n    rejected: rejected\n  });\n  return this.handlers.length - 1;\n};\n\n/**\n * Remove an interceptor from the stack\n *\n * @param {Number} id The ID that was returned by `use`\n */\nInterceptorManager.prototype.eject = function eject(id) {\n  if (this.handlers[id]) {\n    this.handlers[id] = null;\n  }\n};\n\n/**\n * Iterate over all the registered interceptors\n *\n * This method is particularly useful for skipping over any\n * interceptors that may have become `null` calling `eject`.\n *\n * @param {Function} fn The function to call for each interceptor\n */\nInterceptorManager.prototype.forEach = function forEach(fn) {\n  utils.forEach(this.handlers, function forEachHandler(h) {\n    if (h !== null) {\n      fn(h);\n    }\n  });\n};\n\nmodule.exports = InterceptorManager;\n","'use strict';\n\nvar isAbsoluteURL = require('../helpers/isAbsoluteURL');\nvar combineURLs = require('../helpers/combineURLs');\n\n/**\n * Creates a new URL by combining the baseURL with the requestedURL,\n * only when the requestedURL is not already an absolute URL.\n * If the requestURL is absolute, this function returns the requestedURL untouched.\n *\n * @param {string} baseURL The base URL\n * @param {string} requestedURL Absolute or relative URL to combine\n * @returns {string} The combined full path\n */\nmodule.exports = function buildFullPath(baseURL, requestedURL) {\n  if (baseURL && !isAbsoluteURL(requestedURL)) {\n    return combineURLs(baseURL, requestedURL);\n  }\n  return requestedURL;\n};\n","'use strict';\n\nvar enhanceError = require('./enhanceError');\n\n/**\n * Create an Error with the specified message, config, error code, request and response.\n *\n * @param {string} message The error message.\n * @param {Object} config The config.\n * @param {string} [code] The error code (for example, 'ECONNABORTED').\n * @param {Object} [request] The request.\n * @param {Object} [response] The response.\n * @returns {Error} The created error.\n */\nmodule.exports = function createError(message, config, code, request, response) {\n  var error = new Error(message);\n  return enhanceError(error, config, code, request, response);\n};\n","'use strict';\n\nvar utils = require('./../utils');\nvar transformData = require('./transformData');\nvar isCancel = require('../cancel/isCancel');\nvar defaults = require('../defaults');\n\n/**\n * Throws a `Cancel` if cancellation has been requested.\n */\nfunction throwIfCancellationRequested(config) {\n  if (config.cancelToken) {\n    config.cancelToken.throwIfRequested();\n  }\n}\n\n/**\n * Dispatch a request to the server using the configured adapter.\n *\n * @param {object} config The config that is to be used for the request\n * @returns {Promise} The Promise to be fulfilled\n */\nmodule.exports = function dispatchRequest(config) {\n  throwIfCancellationRequested(config);\n\n  // Ensure headers exist\n  config.headers = config.headers || {};\n\n  // Transform request data\n  config.data = transformData(\n    config.data,\n    config.headers,\n    config.transformRequest\n  );\n\n  // Flatten headers\n  config.headers = utils.merge(\n    config.headers.common || {},\n    config.headers[config.method] || {},\n    config.headers\n  );\n\n  utils.forEach(\n    ['delete', 'get', 'head', 'post', 'put', 'patch', 'common'],\n    function cleanHeaderConfig(method) {\n      delete config.headers[method];\n    }\n  );\n\n  var adapter = config.adapter || defaults.adapter;\n\n  return adapter(config).then(function onAdapterResolution(response) {\n    throwIfCancellationRequested(config);\n\n    // Transform response data\n    response.data = transformData(\n      response.data,\n      response.headers,\n      config.transformResponse\n    );\n\n    return response;\n  }, function onAdapterRejection(reason) {\n    if (!isCancel(reason)) {\n      throwIfCancellationRequested(config);\n\n      // Transform response data\n      if (reason && reason.response) {\n        reason.response.data = transformData(\n          reason.response.data,\n          reason.response.headers,\n          config.transformResponse\n        );\n      }\n    }\n\n    return Promise.reject(reason);\n  });\n};\n","'use strict';\n\n/**\n * Update an Error with the specified config, error code, and response.\n *\n * @param {Error} error The error to update.\n * @param {Object} config The config.\n * @param {string} [code] The error code (for example, 'ECONNABORTED').\n * @param {Object} [request] The request.\n * @param {Object} [response] The response.\n * @returns {Error} The error.\n */\nmodule.exports = function enhanceError(error, config, code, request, response) {\n  error.config = config;\n  if (code) {\n    error.code = code;\n  }\n\n  error.request = request;\n  error.response = response;\n  error.isAxiosError = true;\n\n  error.toJSON = function() {\n    return {\n      // Standard\n      message: this.message,\n      name: this.name,\n      // Microsoft\n      description: this.description,\n      number: this.number,\n      // Mozilla\n      fileName: this.fileName,\n      lineNumber: this.lineNumber,\n      columnNumber: this.columnNumber,\n      stack: this.stack,\n      // Axios\n      config: this.config,\n      code: this.code\n    };\n  };\n  return error;\n};\n","'use strict';\n\nvar utils = require('../utils');\n\n/**\n * Config-specific merge-function which creates a new config-object\n * by merging two configuration objects together.\n *\n * @param {Object} config1\n * @param {Object} config2\n * @returns {Object} New object resulting from merging config2 to config1\n */\nmodule.exports = function mergeConfig(config1, config2) {\n  // eslint-disable-next-line no-param-reassign\n  config2 = config2 || {};\n  var config = {};\n\n  var valueFromConfig2Keys = ['url', 'method', 'params', 'data'];\n  var mergeDeepPropertiesKeys = ['headers', 'auth', 'proxy'];\n  var defaultToConfig2Keys = [\n    'baseURL', 'url', 'transformRequest', 'transformResponse', 'paramsSerializer',\n    'timeout', 'withCredentials', 'adapter', 'responseType', 'xsrfCookieName',\n    'xsrfHeaderName', 'onUploadProgress', 'onDownloadProgress',\n    'maxContentLength', 'validateStatus', 'maxRedirects', 'httpAgent',\n    'httpsAgent', 'cancelToken', 'socketPath'\n  ];\n\n  utils.forEach(valueFromConfig2Keys, function valueFromConfig2(prop) {\n    if (typeof config2[prop] !== 'undefined') {\n      config[prop] = config2[prop];\n    }\n  });\n\n  utils.forEach(mergeDeepPropertiesKeys, function mergeDeepProperties(prop) {\n    if (utils.isObject(config2[prop])) {\n      config[prop] = utils.deepMerge(config1[prop], config2[prop]);\n    } else if (typeof config2[prop] !== 'undefined') {\n      config[prop] = config2[prop];\n    } else if (utils.isObject(config1[prop])) {\n      config[prop] = utils.deepMerge(config1[prop]);\n    } else if (typeof config1[prop] !== 'undefined') {\n      config[prop] = config1[prop];\n    }\n  });\n\n  utils.forEach(defaultToConfig2Keys, function defaultToConfig2(prop) {\n    if (typeof config2[prop] !== 'undefined') {\n      config[prop] = config2[prop];\n    } else if (typeof config1[prop] !== 'undefined') {\n      config[prop] = config1[prop];\n    }\n  });\n\n  var axiosKeys = valueFromConfig2Keys\n    .concat(mergeDeepPropertiesKeys)\n    .concat(defaultToConfig2Keys);\n\n  var otherKeys = Object\n    .keys(config2)\n    .filter(function filterAxiosKeys(key) {\n      return axiosKeys.indexOf(key) === -1;\n    });\n\n  utils.forEach(otherKeys, function otherKeysDefaultToConfig2(prop) {\n    if (typeof config2[prop] !== 'undefined') {\n      config[prop] = config2[prop];\n    } else if (typeof config1[prop] !== 'undefined') {\n      config[prop] = config1[prop];\n    }\n  });\n\n  return config;\n};\n","'use strict';\n\nvar createError = require('./createError');\n\n/**\n * Resolve or reject a Promise based on response status.\n *\n * @param {Function} resolve A function that resolves the promise.\n * @param {Function} reject A function that rejects the promise.\n * @param {object} response The response.\n */\nmodule.exports = function settle(resolve, reject, response) {\n  var validateStatus = response.config.validateStatus;\n  if (!validateStatus || validateStatus(response.status)) {\n    resolve(response);\n  } else {\n    reject(createError(\n      'Request failed with status code ' + response.status,\n      response.config,\n      null,\n      response.request,\n      response\n    ));\n  }\n};\n","'use strict';\n\nvar utils = require('./../utils');\n\n/**\n * Transform the data for a request or a response\n *\n * @param {Object|String} data The data to be transformed\n * @param {Array} headers The headers for the request or response\n * @param {Array|Function} fns A single function or Array of functions\n * @returns {*} The resulting transformed data\n */\nmodule.exports = function transformData(data, headers, fns) {\n  /*eslint no-param-reassign:0*/\n  utils.forEach(fns, function transform(fn) {\n    data = fn(data, headers);\n  });\n\n  return data;\n};\n","'use strict';\n\nvar utils = require('./utils');\nvar normalizeHeaderName = require('./helpers/normalizeHeaderName');\n\nvar DEFAULT_CONTENT_TYPE = {\n  'Content-Type': 'application/x-www-form-urlencoded'\n};\n\nfunction setContentTypeIfUnset(headers, value) {\n  if (!utils.isUndefined(headers) && utils.isUndefined(headers['Content-Type'])) {\n    headers['Content-Type'] = value;\n  }\n}\n\nfunction getDefaultAdapter() {\n  var adapter;\n  if (typeof XMLHttpRequest !== 'undefined') {\n    // For browsers use XHR adapter\n    adapter = require('./adapters/xhr');\n  } else if (typeof process !== 'undefined' && Object.prototype.toString.call(process) === '[object process]') {\n    // For node use HTTP adapter\n    adapter = require('./adapters/http');\n  }\n  return adapter;\n}\n\nvar defaults = {\n  adapter: getDefaultAdapter(),\n\n  transformRequest: [function transformRequest(data, headers) {\n    normalizeHeaderName(headers, 'Accept');\n    normalizeHeaderName(headers, 'Content-Type');\n    if (utils.isFormData(data) ||\n      utils.isArrayBuffer(data) ||\n      utils.isBuffer(data) ||\n      utils.isStream(data) ||\n      utils.isFile(data) ||\n      utils.isBlob(data)\n    ) {\n      return data;\n    }\n    if (utils.isArrayBufferView(data)) {\n      return data.buffer;\n    }\n    if (utils.isURLSearchParams(data)) {\n      setContentTypeIfUnset(headers, 'application/x-www-form-urlencoded;charset=utf-8');\n      return data.toString();\n    }\n    if (utils.isObject(data)) {\n      setContentTypeIfUnset(headers, 'application/json;charset=utf-8');\n      return JSON.stringify(data);\n    }\n    return data;\n  }],\n\n  transformResponse: [function transformResponse(data) {\n    /*eslint no-param-reassign:0*/\n    if (typeof data === 'string') {\n      try {\n        data = JSON.parse(data);\n      } catch (e) { /* Ignore */ }\n    }\n    return data;\n  }],\n\n  /**\n   * A timeout in milliseconds to abort a request. If set to 0 (default) a\n   * timeout is not created.\n   */\n  timeout: 0,\n\n  xsrfCookieName: 'XSRF-TOKEN',\n  xsrfHeaderName: 'X-XSRF-TOKEN',\n\n  maxContentLength: -1,\n\n  validateStatus: function validateStatus(status) {\n    return status >= 200 && status < 300;\n  }\n};\n\ndefaults.headers = {\n  common: {\n    'Accept': 'application/json, text/plain, */*'\n  }\n};\n\nutils.forEach(['delete', 'get', 'head'], function forEachMethodNoData(method) {\n  defaults.headers[method] = {};\n});\n\nutils.forEach(['post', 'put', 'patch'], function forEachMethodWithData(method) {\n  defaults.headers[method] = utils.merge(DEFAULT_CONTENT_TYPE);\n});\n\nmodule.exports = defaults;\n","'use strict';\n\nmodule.exports = function bind(fn, thisArg) {\n  return function wrap() {\n    var args = new Array(arguments.length);\n    for (var i = 0; i < args.length; i++) {\n      args[i] = arguments[i];\n    }\n    return fn.apply(thisArg, args);\n  };\n};\n","'use strict';\n\nvar utils = require('./../utils');\n\nfunction encode(val) {\n  return encodeURIComponent(val).\n    replace(/%40/gi, '@').\n    replace(/%3A/gi, ':').\n    replace(/%24/g, '$').\n    replace(/%2C/gi, ',').\n    replace(/%20/g, '+').\n    replace(/%5B/gi, '[').\n    replace(/%5D/gi, ']');\n}\n\n/**\n * Build a URL by appending params to the end\n *\n * @param {string} url The base of the url (e.g., http://www.google.com)\n * @param {object} [params] The params to be appended\n * @returns {string} The formatted url\n */\nmodule.exports = function buildURL(url, params, paramsSerializer) {\n  /*eslint no-param-reassign:0*/\n  if (!params) {\n    return url;\n  }\n\n  var serializedParams;\n  if (paramsSerializer) {\n    serializedParams = paramsSerializer(params);\n  } else if (utils.isURLSearchParams(params)) {\n    serializedParams = params.toString();\n  } else {\n    var parts = [];\n\n    utils.forEach(params, function serialize(val, key) {\n      if (val === null || typeof val === 'undefined') {\n        return;\n      }\n\n      if (utils.isArray(val)) {\n        key = key + '[]';\n      } else {\n        val = [val];\n      }\n\n      utils.forEach(val, function parseValue(v) {\n        if (utils.isDate(v)) {\n          v = v.toISOString();\n        } else if (utils.isObject(v)) {\n          v = JSON.stringify(v);\n        }\n        parts.push(encode(key) + '=' + encode(v));\n      });\n    });\n\n    serializedParams = parts.join('&');\n  }\n\n  if (serializedParams) {\n    var hashmarkIndex = url.indexOf('#');\n    if (hashmarkIndex !== -1) {\n      url = url.slice(0, hashmarkIndex);\n    }\n\n    url += (url.indexOf('?') === -1 ? '?' : '&') + serializedParams;\n  }\n\n  return url;\n};\n","'use strict';\n\n/**\n * Creates a new URL by combining the specified URLs\n *\n * @param {string} baseURL The base URL\n * @param {string} relativeURL The relative URL\n * @returns {string} The combined URL\n */\nmodule.exports = function combineURLs(baseURL, relativeURL) {\n  return relativeURL\n    ? baseURL.replace(/\\/+$/, '') + '/' + relativeURL.replace(/^\\/+/, '')\n    : baseURL;\n};\n","'use strict';\n\nvar utils = require('./../utils');\n\nmodule.exports = (\n  utils.isStandardBrowserEnv() ?\n\n  // Standard browser envs support document.cookie\n    (function standardBrowserEnv() {\n      return {\n        write: function write(name, value, expires, path, domain, secure) {\n          var cookie = [];\n          cookie.push(name + '=' + encodeURIComponent(value));\n\n          if (utils.isNumber(expires)) {\n            cookie.push('expires=' + new Date(expires).toGMTString());\n          }\n\n          if (utils.isString(path)) {\n            cookie.push('path=' + path);\n          }\n\n          if (utils.isString(domain)) {\n            cookie.push('domain=' + domain);\n          }\n\n          if (secure === true) {\n            cookie.push('secure');\n          }\n\n          document.cookie = cookie.join('; ');\n        },\n\n        read: function read(name) {\n          var match = document.cookie.match(new RegExp('(^|;\\\\s*)(' + name + ')=([^;]*)'));\n          return (match ? decodeURIComponent(match[3]) : null);\n        },\n\n        remove: function remove(name) {\n          this.write(name, '', Date.now() - 86400000);\n        }\n      };\n    })() :\n\n  // Non standard browser env (web workers, react-native) lack needed support.\n    (function nonStandardBrowserEnv() {\n      return {\n        write: function write() {},\n        read: function read() { return null; },\n        remove: function remove() {}\n      };\n    })()\n);\n","'use strict';\n\n/**\n * Determines whether the specified URL is absolute\n *\n * @param {string} url The URL to test\n * @returns {boolean} True if the specified URL is absolute, otherwise false\n */\nmodule.exports = function isAbsoluteURL(url) {\n  // A URL is considered absolute if it begins with \"<scheme>://\" or \"//\" (protocol-relative URL).\n  // RFC 3986 defines scheme name as a sequence of characters beginning with a letter and followed\n  // by any combination of letters, digits, plus, period, or hyphen.\n  return /^([a-z][a-z\\d\\+\\-\\.]*:)?\\/\\//i.test(url);\n};\n","'use strict';\n\nvar utils = require('./../utils');\n\nmodule.exports = (\n  utils.isStandardBrowserEnv() ?\n\n  // Standard browser envs have full support of the APIs needed to test\n  // whether the request URL is of the same origin as current location.\n    (function standardBrowserEnv() {\n      var msie = /(msie|trident)/i.test(navigator.userAgent);\n      var urlParsingNode = document.createElement('a');\n      var originURL;\n\n      /**\n    * Parse a URL to discover it's components\n    *\n    * @param {String} url The URL to be parsed\n    * @returns {Object}\n    */\n      function resolveURL(url) {\n        var href = url;\n\n        if (msie) {\n        // IE needs attribute set twice to normalize properties\n          urlParsingNode.setAttribute('href', href);\n          href = urlParsingNode.href;\n        }\n\n        urlParsingNode.setAttribute('href', href);\n\n        // urlParsingNode provides the UrlUtils interface - http://url.spec.whatwg.org/#urlutils\n        return {\n          href: urlParsingNode.href,\n          protocol: urlParsingNode.protocol ? urlParsingNode.protocol.replace(/:$/, '') : '',\n          host: urlParsingNode.host,\n          search: urlParsingNode.search ? urlParsingNode.search.replace(/^\\?/, '') : '',\n          hash: urlParsingNode.hash ? urlParsingNode.hash.replace(/^#/, '') : '',\n          hostname: urlParsingNode.hostname,\n          port: urlParsingNode.port,\n          pathname: (urlParsingNode.pathname.charAt(0) === '/') ?\n            urlParsingNode.pathname :\n            '/' + urlParsingNode.pathname\n        };\n      }\n\n      originURL = resolveURL(window.location.href);\n\n      /**\n    * Determine if a URL shares the same origin as the current location\n    *\n    * @param {String} requestURL The URL to test\n    * @returns {boolean} True if URL shares the same origin, otherwise false\n    */\n      return function isURLSameOrigin(requestURL) {\n        var parsed = (utils.isString(requestURL)) ? resolveURL(requestURL) : requestURL;\n        return (parsed.protocol === originURL.protocol &&\n            parsed.host === originURL.host);\n      };\n    })() :\n\n  // Non standard browser envs (web workers, react-native) lack needed support.\n    (function nonStandardBrowserEnv() {\n      return function isURLSameOrigin() {\n        return true;\n      };\n    })()\n);\n","'use strict';\n\nvar utils = require('../utils');\n\nmodule.exports = function normalizeHeaderName(headers, normalizedName) {\n  utils.forEach(headers, function processHeader(value, name) {\n    if (name !== normalizedName && name.toUpperCase() === normalizedName.toUpperCase()) {\n      headers[normalizedName] = value;\n      delete headers[name];\n    }\n  });\n};\n","'use strict';\n\nvar utils = require('./../utils');\n\n// Headers whose duplicates are ignored by node\n// c.f. https://nodejs.org/api/http.html#http_message_headers\nvar ignoreDuplicateOf = [\n  'age', 'authorization', 'content-length', 'content-type', 'etag',\n  'expires', 'from', 'host', 'if-modified-since', 'if-unmodified-since',\n  'last-modified', 'location', 'max-forwards', 'proxy-authorization',\n  'referer', 'retry-after', 'user-agent'\n];\n\n/**\n * Parse headers into an object\n *\n * ```\n * Date: Wed, 27 Aug 2014 08:58:49 GMT\n * Content-Type: application/json\n * Connection: keep-alive\n * Transfer-Encoding: chunked\n * ```\n *\n * @param {String} headers Headers needing to be parsed\n * @returns {Object} Headers parsed into an object\n */\nmodule.exports = function parseHeaders(headers) {\n  var parsed = {};\n  var key;\n  var val;\n  var i;\n\n  if (!headers) { return parsed; }\n\n  utils.forEach(headers.split('\\n'), function parser(line) {\n    i = line.indexOf(':');\n    key = utils.trim(line.substr(0, i)).toLowerCase();\n    val = utils.trim(line.substr(i + 1));\n\n    if (key) {\n      if (parsed[key] && ignoreDuplicateOf.indexOf(key) >= 0) {\n        return;\n      }\n      if (key === 'set-cookie') {\n        parsed[key] = (parsed[key] ? parsed[key] : []).concat([val]);\n      } else {\n        parsed[key] = parsed[key] ? parsed[key] + ', ' + val : val;\n      }\n    }\n  });\n\n  return parsed;\n};\n","'use strict';\n\n/**\n * Syntactic sugar for invoking a function and expanding an array for arguments.\n *\n * Common use case would be to use `Function.prototype.apply`.\n *\n *  ```js\n *  function f(x, y, z) {}\n *  var args = [1, 2, 3];\n *  f.apply(null, args);\n *  ```\n *\n * With `spread` this example can be re-written.\n *\n *  ```js\n *  spread(function(x, y, z) {})([1, 2, 3]);\n *  ```\n *\n * @param {Function} callback\n * @returns {Function}\n */\nmodule.exports = function spread(callback) {\n  return function wrap(arr) {\n    return callback.apply(null, arr);\n  };\n};\n","'use strict';\n\nvar bind = require('./helpers/bind');\n\n/*global toString:true*/\n\n// utils is a library of generic helper functions non-specific to axios\n\nvar toString = Object.prototype.toString;\n\n/**\n * Determine if a value is an Array\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is an Array, otherwise false\n */\nfunction isArray(val) {\n  return toString.call(val) === '[object Array]';\n}\n\n/**\n * Determine if a value is undefined\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if the value is undefined, otherwise false\n */\nfunction isUndefined(val) {\n  return typeof val === 'undefined';\n}\n\n/**\n * Determine if a value is a Buffer\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is a Buffer, otherwise false\n */\nfunction isBuffer(val) {\n  return val !== null && !isUndefined(val) && val.constructor !== null && !isUndefined(val.constructor)\n    && typeof val.constructor.isBuffer === 'function' && val.constructor.isBuffer(val);\n}\n\n/**\n * Determine if a value is an ArrayBuffer\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is an ArrayBuffer, otherwise false\n */\nfunction isArrayBuffer(val) {\n  return toString.call(val) === '[object ArrayBuffer]';\n}\n\n/**\n * Determine if a value is a FormData\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is an FormData, otherwise false\n */\nfunction isFormData(val) {\n  return (typeof FormData !== 'undefined') && (val instanceof FormData);\n}\n\n/**\n * Determine if a value is a view on an ArrayBuffer\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is a view on an ArrayBuffer, otherwise false\n */\nfunction isArrayBufferView(val) {\n  var result;\n  if ((typeof ArrayBuffer !== 'undefined') && (ArrayBuffer.isView)) {\n    result = ArrayBuffer.isView(val);\n  } else {\n    result = (val) && (val.buffer) && (val.buffer instanceof ArrayBuffer);\n  }\n  return result;\n}\n\n/**\n * Determine if a value is a String\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is a String, otherwise false\n */\nfunction isString(val) {\n  return typeof val === 'string';\n}\n\n/**\n * Determine if a value is a Number\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is a Number, otherwise false\n */\nfunction isNumber(val) {\n  return typeof val === 'number';\n}\n\n/**\n * Determine if a value is an Object\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is an Object, otherwise false\n */\nfunction isObject(val) {\n  return val !== null && typeof val === 'object';\n}\n\n/**\n * Determine if a value is a Date\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is a Date, otherwise false\n */\nfunction isDate(val) {\n  return toString.call(val) === '[object Date]';\n}\n\n/**\n * Determine if a value is a File\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is a File, otherwise false\n */\nfunction isFile(val) {\n  return toString.call(val) === '[object File]';\n}\n\n/**\n * Determine if a value is a Blob\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is a Blob, otherwise false\n */\nfunction isBlob(val) {\n  return toString.call(val) === '[object Blob]';\n}\n\n/**\n * Determine if a value is a Function\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is a Function, otherwise false\n */\nfunction isFunction(val) {\n  return toString.call(val) === '[object Function]';\n}\n\n/**\n * Determine if a value is a Stream\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is a Stream, otherwise false\n */\nfunction isStream(val) {\n  return isObject(val) && isFunction(val.pipe);\n}\n\n/**\n * Determine if a value is a URLSearchParams object\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is a URLSearchParams object, otherwise false\n */\nfunction isURLSearchParams(val) {\n  return typeof URLSearchParams !== 'undefined' && val instanceof URLSearchParams;\n}\n\n/**\n * Trim excess whitespace off the beginning and end of a string\n *\n * @param {String} str The String to trim\n * @returns {String} The String freed of excess whitespace\n */\nfunction trim(str) {\n  return str.replace(/^\\s*/, '').replace(/\\s*$/, '');\n}\n\n/**\n * Determine if we're running in a standard browser environment\n *\n * This allows axios to run in a web worker, and react-native.\n * Both environments support XMLHttpRequest, but not fully standard globals.\n *\n * web workers:\n *  typeof window -> undefined\n *  typeof document -> undefined\n *\n * react-native:\n *  navigator.product -> 'ReactNative'\n * nativescript\n *  navigator.product -> 'NativeScript' or 'NS'\n */\nfunction isStandardBrowserEnv() {\n  if (typeof navigator !== 'undefined' && (navigator.product === 'ReactNative' ||\n                                           navigator.product === 'NativeScript' ||\n                                           navigator.product === 'NS')) {\n    return false;\n  }\n  return (\n    typeof window !== 'undefined' &&\n    typeof document !== 'undefined'\n  );\n}\n\n/**\n * Iterate over an Array or an Object invoking a function for each item.\n *\n * If `obj` is an Array callback will be called passing\n * the value, index, and complete array for each item.\n *\n * If 'obj' is an Object callback will be called passing\n * the value, key, and complete object for each property.\n *\n * @param {Object|Array} obj The object to iterate\n * @param {Function} fn The callback to invoke for each item\n */\nfunction forEach(obj, fn) {\n  // Don't bother if no value provided\n  if (obj === null || typeof obj === 'undefined') {\n    return;\n  }\n\n  // Force an array if not already something iterable\n  if (typeof obj !== 'object') {\n    /*eslint no-param-reassign:0*/\n    obj = [obj];\n  }\n\n  if (isArray(obj)) {\n    // Iterate over array values\n    for (var i = 0, l = obj.length; i < l; i++) {\n      fn.call(null, obj[i], i, obj);\n    }\n  } else {\n    // Iterate over object keys\n    for (var key in obj) {\n      if (Object.prototype.hasOwnProperty.call(obj, key)) {\n        fn.call(null, obj[key], key, obj);\n      }\n    }\n  }\n}\n\n/**\n * Accepts varargs expecting each argument to be an object, then\n * immutably merges the properties of each object and returns result.\n *\n * When multiple objects contain the same key the later object in\n * the arguments list will take precedence.\n *\n * Example:\n *\n * ```js\n * var result = merge({foo: 123}, {foo: 456});\n * console.log(result.foo); // outputs 456\n * ```\n *\n * @param {Object} obj1 Object to merge\n * @returns {Object} Result of all merge properties\n */\nfunction merge(/* obj1, obj2, obj3, ... */) {\n  var result = {};\n  function assignValue(val, key) {\n    if (typeof result[key] === 'object' && typeof val === 'object') {\n      result[key] = merge(result[key], val);\n    } else {\n      result[key] = val;\n    }\n  }\n\n  for (var i = 0, l = arguments.length; i < l; i++) {\n    forEach(arguments[i], assignValue);\n  }\n  return result;\n}\n\n/**\n * Function equal to merge with the difference being that no reference\n * to original objects is kept.\n *\n * @see merge\n * @param {Object} obj1 Object to merge\n * @returns {Object} Result of all merge properties\n */\nfunction deepMerge(/* obj1, obj2, obj3, ... */) {\n  var result = {};\n  function assignValue(val, key) {\n    if (typeof result[key] === 'object' && typeof val === 'object') {\n      result[key] = deepMerge(result[key], val);\n    } else if (typeof val === 'object') {\n      result[key] = deepMerge({}, val);\n    } else {\n      result[key] = val;\n    }\n  }\n\n  for (var i = 0, l = arguments.length; i < l; i++) {\n    forEach(arguments[i], assignValue);\n  }\n  return result;\n}\n\n/**\n * Extends object a by mutably adding to it the properties of object b.\n *\n * @param {Object} a The object to be extended\n * @param {Object} b The object to copy properties from\n * @param {Object} thisArg The object to bind function to\n * @return {Object} The resulting value of object a\n */\nfunction extend(a, b, thisArg) {\n  forEach(b, function assignValue(val, key) {\n    if (thisArg && typeof val === 'function') {\n      a[key] = bind(val, thisArg);\n    } else {\n      a[key] = val;\n    }\n  });\n  return a;\n}\n\nmodule.exports = {\n  isArray: isArray,\n  isArrayBuffer: isArrayBuffer,\n  isBuffer: isBuffer,\n  isFormData: isFormData,\n  isArrayBufferView: isArrayBufferView,\n  isString: isString,\n  isNumber: isNumber,\n  isObject: isObject,\n  isUndefined: isUndefined,\n  isDate: isDate,\n  isFile: isFile,\n  isBlob: isBlob,\n  isFunction: isFunction,\n  isStream: isStream,\n  isURLSearchParams: isURLSearchParams,\n  isStandardBrowserEnv: isStandardBrowserEnv,\n  forEach: forEach,\n  merge: merge,\n  deepMerge: deepMerge,\n  extend: extend,\n  trim: trim\n};\n","// shim for using process in browser\nvar process = module.exports = {};\n\n// cached from whatever global is present so that test runners that stub it\n// don't break things.  But we need to wrap it in a try catch in case it is\n// wrapped in strict mode code which doesn't define any globals.  It's inside a\n// function because try/catches deoptimize in certain engines.\n\nvar cachedSetTimeout;\nvar cachedClearTimeout;\n\nfunction defaultSetTimout() {\n    throw new Error('setTimeout has not been defined');\n}\nfunction defaultClearTimeout () {\n    throw new Error('clearTimeout has not been defined');\n}\n(function () {\n    try {\n        if (typeof setTimeout === 'function') {\n            cachedSetTimeout = setTimeout;\n        } else {\n            cachedSetTimeout = defaultSetTimout;\n        }\n    } catch (e) {\n        cachedSetTimeout = defaultSetTimout;\n    }\n    try {\n        if (typeof clearTimeout === 'function') {\n            cachedClearTimeout = clearTimeout;\n        } else {\n            cachedClearTimeout = defaultClearTimeout;\n        }\n    } catch (e) {\n        cachedClearTimeout = defaultClearTimeout;\n    }\n} ())\nfunction runTimeout(fun) {\n    if (cachedSetTimeout === setTimeout) {\n        //normal enviroments in sane situations\n        return setTimeout(fun, 0);\n    }\n    // if setTimeout wasn't available but was latter defined\n    if ((cachedSetTimeout === defaultSetTimout || !cachedSetTimeout) && setTimeout) {\n        cachedSetTimeout = setTimeout;\n        return setTimeout(fun, 0);\n    }\n    try {\n        // when when somebody has screwed with setTimeout but no I.E. maddness\n        return cachedSetTimeout(fun, 0);\n    } catch(e){\n        try {\n            // When we are in I.E. but the script has been evaled so I.E. doesn't trust the global object when called normally\n            return cachedSetTimeout.call(null, fun, 0);\n        } catch(e){\n            // same as above but when it's a version of I.E. that must have the global object for 'this', hopfully our context correct otherwise it will throw a global error\n            return cachedSetTimeout.call(this, fun, 0);\n        }\n    }\n\n\n}\nfunction runClearTimeout(marker) {\n    if (cachedClearTimeout === clearTimeout) {\n        //normal enviroments in sane situations\n        return clearTimeout(marker);\n    }\n    // if clearTimeout wasn't available but was latter defined\n    if ((cachedClearTimeout === defaultClearTimeout || !cachedClearTimeout) && clearTimeout) {\n        cachedClearTimeout = clearTimeout;\n        return clearTimeout(marker);\n    }\n    try {\n        // when when somebody has screwed with setTimeout but no I.E. maddness\n        return cachedClearTimeout(marker);\n    } catch (e){\n        try {\n            // When we are in I.E. but the script has been evaled so I.E. doesn't  trust the global object when called normally\n            return cachedClearTimeout.call(null, marker);\n        } catch (e){\n            // same as above but when it's a version of I.E. that must have the global object for 'this', hopfully our context correct otherwise it will throw a global error.\n            // Some versions of I.E. have different rules for clearTimeout vs setTimeout\n            return cachedClearTimeout.call(this, marker);\n        }\n    }\n\n\n\n}\nvar queue = [];\nvar draining = false;\nvar currentQueue;\nvar queueIndex = -1;\n\nfunction cleanUpNextTick() {\n    if (!draining || !currentQueue) {\n        return;\n    }\n    draining = false;\n    if (currentQueue.length) {\n        queue = currentQueue.concat(queue);\n    } else {\n        queueIndex = -1;\n    }\n    if (queue.length) {\n        drainQueue();\n    }\n}\n\nfunction drainQueue() {\n    if (draining) {\n        return;\n    }\n    var timeout = runTimeout(cleanUpNextTick);\n    draining = true;\n\n    var len = queue.length;\n    while(len) {\n        currentQueue = queue;\n        queue = [];\n        while (++queueIndex < len) {\n            if (currentQueue) {\n                currentQueue[queueIndex].run();\n            }\n        }\n        queueIndex = -1;\n        len = queue.length;\n    }\n    currentQueue = null;\n    draining = false;\n    runClearTimeout(timeout);\n}\n\nprocess.nextTick = function (fun) {\n    var args = new Array(arguments.length - 1);\n    if (arguments.length > 1) {\n        for (var i = 1; i < arguments.length; i++) {\n            args[i - 1] = arguments[i];\n        }\n    }\n    queue.push(new Item(fun, args));\n    if (queue.length === 1 && !draining) {\n        runTimeout(drainQueue);\n    }\n};\n\n// v8 likes predictible objects\nfunction Item(fun, array) {\n    this.fun = fun;\n    this.array = array;\n}\nItem.prototype.run = function () {\n    this.fun.apply(null, this.array);\n};\nprocess.title = 'browser';\nprocess.browser = true;\nprocess.env = {};\nprocess.argv = [];\nprocess.version = ''; // empty string to avoid regexp issues\nprocess.versions = {};\n\nfunction noop() {}\n\nprocess.on = noop;\nprocess.addListener = noop;\nprocess.once = noop;\nprocess.off = noop;\nprocess.removeListener = noop;\nprocess.removeAllListeners = noop;\nprocess.emit = noop;\nprocess.prependListener = noop;\nprocess.prependOnceListener = noop;\n\nprocess.listeners = function (name) { return [] }\n\nprocess.binding = function (name) {\n    throw new Error('process.binding is not supported');\n};\n\nprocess.cwd = function () { return '/' };\nprocess.chdir = function (dir) {\n    throw new Error('process.chdir is not supported');\n};\nprocess.umask = function() { return 0; };\n","import axios from 'axios';\r\nimport UserTable from './table';\r\n\r\nconst userTable = new UserTable()\r\naxios.get('https://reqres.in/api/users')\r\n    .then(response => {\r\n        userTable.populate(response.data.data);\r\n    });","import { User } from \"./models\";\r\n\r\nexport default class UserTable {\r\n\r\n    table: HTMLTableElement;\r\n    thead: HTMLTableSectionElement;\r\n    tbody: HTMLTableSectionElement;\r\n    \r\n    constructor() {\r\n        this.table = document.createElement('table');\r\n        this.createHeader();\r\n        this.tbody = this.table.createTBody();\r\n        const body = document.getElementsByTagName('body')[0];\r\n        body.appendChild(this.table);\r\n    }\r\n\r\n    createHeader(){\r\n        this.thead = this.table.createTHead();\r\n        const hrow = this.thead.insertRow(0);\r\n        const columns = ['ID', 'email', 'First Name', 'Last Name', 'Avatar'];\r\n        columns.forEach(column => {\r\n            const cell = hrow.insertCell(hrow.cells.length);\r\n            cell.innerHTML = column;\r\n        })\r\n        \r\n    }\r\n\r\n    populate(users: User[]){\r\n        users.forEach(user => {\r\n            const row = this.tbody.insertRow(this.tbody.rows.length);\r\n            for(const field of Object.keys(user)){\r\n                const cell = row.insertCell(row.cells.length);\r\n                cell.innerHTML = user[field];\r\n            }\r\n        })\r\n    }\r\n\r\n}"],"sourceRoot":""}
--------------------------------------------------------------------------------