├── .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":""} --------------------------------------------------------------------------------