├── .editorconfig ├── .env-cmdrc.json ├── .eslintignore ├── .eslintrc ├── .gitignore ├── .mocharc.json ├── .npmignore ├── .nycrc.json ├── .prettierignore ├── .prettierrc ├── .travis.yml ├── .vscode └── settings.json ├── LICENSE ├── README.md ├── esm ├── index.d.ts ├── index.d.ts.map ├── index.js └── index.js.map ├── lib ├── index.d.ts ├── index.d.ts.map ├── index.js └── index.js.map ├── package-lock.json ├── package.json ├── src ├── examples.ts ├── index.spec.ts ├── index.ts ├── issue-17.spec.ts └── issue-22.spec.ts ├── tsconfig.esm.json ├── tsconfig.json └── tsconfig.tests.json /.editorconfig: -------------------------------------------------------------------------------- 1 | # http://editorconfig.org 2 | root = true 3 | 4 | [*] 5 | indent_style = space 6 | indent_size = 2 7 | end_of_line = lf 8 | charset = utf-8 9 | trim_trailing_whitespace = true 10 | insert_final_newline = true 11 | -------------------------------------------------------------------------------- /.env-cmdrc.json: -------------------------------------------------------------------------------- 1 | { 2 | "mocha": { 3 | "TS_NODE_PROJECT": "tsconfig.tests.json" 4 | } 5 | } 6 | -------------------------------------------------------------------------------- /.eslintignore: -------------------------------------------------------------------------------- 1 | /.nyc_output 2 | /coverage 3 | /lib 4 | /esm 5 | /node_modules 6 | -------------------------------------------------------------------------------- /.eslintrc: -------------------------------------------------------------------------------- 1 | { 2 | "root": true, 3 | "parser": "@typescript-eslint/parser", 4 | "plugins": ["@typescript-eslint"], 5 | "extends": [ 6 | "eslint:recommended", 7 | "plugin:@typescript-eslint/recommended", 8 | "prettier" 9 | ] 10 | } 11 | -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | # IntelliJ IDEA 2 | .idea 3 | *.iml 4 | 5 | # NPM 6 | node_modules 7 | npm-*.log 8 | 9 | # OS X 10 | .DS_Store 11 | 12 | lib-cov 13 | coverage 14 | .nyc_output 15 | coverage.* 16 | .npmrc 17 | -------------------------------------------------------------------------------- /.mocharc.json: -------------------------------------------------------------------------------- 1 | { 2 | "require": "ts-node/register", 3 | "exclude": ["src/examples.ts"], 4 | "spec": "src/**/*.ts" 5 | } 6 | -------------------------------------------------------------------------------- /.npmignore: -------------------------------------------------------------------------------- 1 | .* 2 | coverage 3 | tsconfig.json 4 | tsconfig.tests.json 5 | -------------------------------------------------------------------------------- /.nycrc.json: -------------------------------------------------------------------------------- 1 | { 2 | "extension": [".ts"], 3 | "require": ["ts-node/register"], 4 | "reporter": ["text-summary", "html", "json"], 5 | 6 | "sourceMap": true, 7 | "instrument": true, 8 | 9 | "include": ["src/**/*.ts"], 10 | "exclude": ["src/**/*.spec.ts", "src/examples.ts", "node_modules"] 11 | } 12 | -------------------------------------------------------------------------------- /.prettierignore: -------------------------------------------------------------------------------- 1 | /.nyc_output 2 | /coverage 3 | /lib 4 | /esm 5 | -------------------------------------------------------------------------------- /.prettierrc: -------------------------------------------------------------------------------- 1 | { 2 | "singleQuote": true, 3 | "trailingComma": "all" 4 | } 5 | -------------------------------------------------------------------------------- /.travis.yml: -------------------------------------------------------------------------------- 1 | language: node_js 2 | 3 | node_js: 4 | - 14 5 | - 16 6 | 7 | script: 8 | - npm run lint 9 | - npm test 10 | - npm run build 11 | -------------------------------------------------------------------------------- /.vscode/settings.json: -------------------------------------------------------------------------------- 1 | { 2 | "editor.formatOnSave": true, 3 | "editor.codeActionsOnSave": { 4 | "source.fixAll": true 5 | }, 6 | "files.associations": { 7 | ".prettierignore": "ignore" 8 | } 9 | } 10 | -------------------------------------------------------------------------------- /LICENSE: -------------------------------------------------------------------------------- 1 | The MIT License (MIT) 2 | 3 | Copyright (c) 2017-2019 Dave Gradwell (xdave) 4 | Copyright (c) 2016 Daniel Lytkin 5 | 6 | Permission is hereby granted, free of charge, to any person obtaining a copy 7 | of this software and associated documentation files (the "Software"), to deal 8 | in the Software without restriction, including without limitation the rights 9 | to use, copy, modify, merge, publish, distribute, sublicense, and/or sell 10 | copies of the Software, and to permit persons to whom the Software is 11 | furnished to do so, subject to the following conditions: 12 | 13 | The above copyright notice and this permission notice shall be included in all 14 | copies or substantial portions of the Software. 15 | 16 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 17 | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 18 | FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 19 | AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 20 | LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, 21 | OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE 22 | SOFTWARE. 23 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # [TypeScript FSA](https://github.com/aikoven/typescript-fsa) utilities for redux-thunk 2 | 3 | [![npm (tag)](https://img.shields.io/npm/v/typescript-fsa-redux-thunk/beta.svg)](https://github.com/xdave/typescript-fsa-redux-thunk) 4 | [![npm](https://img.shields.io/npm/l/typescript-fsa-redux-thunk.svg)](https://github.com/xdave/typescript-fsa-redux-thunk/blob/v2/LICENSE.md) 5 | [![GitHub last commit (branch)](https://img.shields.io/github/last-commit/xdave/typescript-fsa-redux-thunk/v2.svg)](https://github.com/xdave/typescript-fsa-redux-thunk) 6 | [![Build Status][travis-image]][travis-url] 7 | [![codecov](https://codecov.io/gh/xdave/typescript-fsa-redux-thunk/branch/v2/graph/badge.svg)](https://codecov.io/gh/xdave/typescript-fsa-redux-thunk) 8 | 9 | ## NOTE: There's breaking changes from 1.x. Read on to find out more and check the notes at the bottom for more info 10 | 11 | ## Installation 12 | 13 | ```bash 14 | npm install typescript-fsa-redux-thunk redux redux-thunk 15 | ``` 16 | 17 | ## API 18 | 19 | ### `thunkToAction(ThunkActionCreator): ((Params) => Result)` 20 | 21 | Another useful cast function that can help when attempting to extract the return 22 | value out of your async action creator. If the action is being pre-bound to 23 | dispatch, then all we want back is the return value (the action object). 24 | Coming soon: an example. TL;DR: pass your async action creator into this before 25 | passing it to `bindActionCreators` or the `mapDispatchToProps` object (react-redux). 26 | 27 | ### `asyncFactory(ActionCreatorFactory): ((type: string, AsyncWorker) => ({ (params?): ThunkActionCreator, async: AsyncActionCreators }))` 28 | 29 | Factory function to easily create a typescript-fsa redux thunk. 30 | 31 | **Example** 32 | 33 | ```ts 34 | import 'isomorphic-fetch'; 35 | import { createStore, applyMiddleware, AnyAction } from 'redux'; 36 | import thunkMiddleware, { ThunkMiddleware } from 'redux-thunk'; 37 | import { reducerWithInitialState } from 'typescript-fsa-reducers'; 38 | import actionCreatorFactory from 'typescript-fsa'; 39 | import { asyncFactory } from 'typescript-fsa-redux-thunk'; 40 | 41 | /** You can optionally use custom Error types */ 42 | class CustomError extends Error {} 43 | 44 | /** Parameters used for logging in */ 45 | interface LoginParams { 46 | email: string; 47 | password: string; 48 | } 49 | 50 | /** The object that comes back from the server on successful login */ 51 | interface UserToken { 52 | token: string; 53 | } 54 | 55 | /** The shape of our Redux store's state */ 56 | interface State { 57 | title: string; 58 | userToken: UserToken; 59 | loggingIn?: boolean; 60 | error?: CustomError; 61 | } 62 | 63 | /** The typescript-fsa action creator factory function */ 64 | const create = actionCreatorFactory('examples'); 65 | 66 | /** The typescript-fsa-redux-thunk async action creator factory function */ 67 | const createAsync = asyncFactory(create); 68 | 69 | /** Normal synchronous action */ 70 | const changeTitle = create('Change the title'); 71 | 72 | /** The asynchronous login action; Error type is optional */ 73 | const login = createAsync( 74 | 'Login', 75 | async (params, dispatch) => { 76 | const url = `https://reqres.in/api/login`; 77 | const options: RequestInit = { 78 | method: 'POST', 79 | body: JSON.stringify(params), 80 | headers: { 81 | 'Content-Type': 'application/json; charset=utf-8', 82 | }, 83 | }; 84 | const res = await fetch(url, options); 85 | if (!res.ok) { 86 | throw new CustomError(`Error ${res.status}: ${res.statusText}`); 87 | } 88 | 89 | dispatch(changeTitle('You are logged-in')); 90 | 91 | return res.json(); 92 | }, 93 | ); 94 | 95 | /** An initial value for the application state */ 96 | const initial: State = { 97 | title: 'Please login', 98 | userToken: { 99 | token: '', 100 | }, 101 | }; 102 | 103 | /** Reducer, handling updates to indicate logging-in status/error */ 104 | const reducer = reducerWithInitialState(initial) 105 | .case(changeTitle, (state, title) => ({ 106 | ...state, 107 | title, 108 | })) 109 | .case(login.async.started, (state) => ({ 110 | ...state, 111 | loggingIn: true, 112 | error: undefined, 113 | })) 114 | .case(login.async.failed, (state, { error }) => ({ 115 | ...state, 116 | loggingIn: false, 117 | error, 118 | })) 119 | .case(login.async.done, (state, { result: userToken }) => ({ 120 | ...state, 121 | userToken, 122 | loggingIn: false, 123 | error: undefined, 124 | })); 125 | 126 | /** Putting it all together */ 127 | (async () => { 128 | // Declaring the type of the redux-thunk middleware is what makes 129 | // `store.dispatch` work. (redux@4.x, redux-thunk@2.3.x) 130 | const thunk: ThunkMiddleware = thunkMiddleware; 131 | const store = createStore(reducer, applyMiddleware(thunk)); 132 | 133 | console.log(store.getState().title); 134 | 135 | try { 136 | // See https://reqres.in/api/users for valid users on this site 137 | await store.dispatch( 138 | login({ 139 | email: 'eve.holt@reqres.in', 140 | password: 'cityslicka', 141 | }), 142 | ); 143 | 144 | const { title, userToken } = store.getState(); 145 | 146 | console.log(title, userToken); 147 | } catch (err) { 148 | console.log(err); 149 | } 150 | })(); 151 | ``` 152 | 153 | Note: A change from 1.x is the result type is not always assumed to be a 154 | Promise. If you want the result to be a promise, just return one from your 155 | worker function; but continue to specify the result as `T` rather than 156 | `Promise` (same as 1.x). 157 | 158 | The API has been simplified. This release is in preparation for a new project 159 | that works with react hooks. Coming soon! 160 | 161 | [travis-image]: https://travis-ci.org/xdave/typescript-fsa-redux-thunk.svg?branch=v2 162 | [travis-url]: https://travis-ci.org/xdave/typescript-fsa-redux-thunk 163 | 164 | ## `react-redux` integrated 165 | 166 | ```ts 167 | import { ThunkDispatch, AnyAction } from 'redux-thunk'; 168 | import { RootState } from 'to/your/reducers'; 169 | 170 | declare module 'react-redux' { 171 | interface DefaultRootState extends RootState {} 172 | 173 | function useDispatch(): ThunkDispatch; 174 | } 175 | 176 | declare module 'typescript-fsa-redux-thunk' { 177 | interface DefaultRootState extends RootState {} 178 | } 179 | ``` 180 | -------------------------------------------------------------------------------- /esm/index.d.ts: -------------------------------------------------------------------------------- 1 | import type { ThunkAction, ThunkDispatch } from 'redux-thunk'; 2 | import type { ActionCreatorFactory, AnyAction, AsyncActionCreators, Meta } from 'typescript-fsa'; 3 | /** 4 | * This interface can be augmented by users to add default types for the root state when 5 | * using `typescript-fsa-redux-thunk`. 6 | * Use module augmentation to append your own type definition in a your_custom_type.d.ts file. 7 | * https://www.typescriptlang.org/docs/handbook/declaration-merging.html#module-augmentation 8 | */ 9 | export interface DefaultRootState { 10 | } 11 | /** 12 | * It's either a promise, or it isn't 13 | */ 14 | export declare type MaybePromise = T | Promise; 15 | /** 16 | * A redux-thunk with the params as the first argument. You don't have to 17 | * return a promise; but, the result of the dispatch will be one. 18 | */ 19 | export declare type AsyncWorker = (params: InputType, dispatch: ThunkDispatch, getState: () => State, extraArgument: Extra) => MaybePromise; 20 | /** Workaround for typescript-fsa issue #77 */ 21 | export declare type ThunkReturnType = T extends void ? unknown : T extends Promise ? Promise : T; 22 | declare type SmartThunkFunction = unknown extends InputType ? ThunkFunctionWithoutParams, State, Error, Extra> : ThunkFunction, State, Error, Extra>; 23 | /** 24 | * Factory function to easily create a thunk 25 | * @param factory typescript-fsa action creator factory 26 | * @returns an function that takes 27 | * - the `type` of the action, 28 | * - the your worker thunk function 29 | * And returns object with the async actions and the thunk itself 30 | */ 31 | export declare const asyncFactory: (factory: ActionCreatorFactory, resolve?: () => Promise) => (type: string, worker: AsyncWorker, State, Extra>, commonMeta?: Meta | undefined) => SmartThunkFunction; 32 | export declare type ThunkFunctionAction = (dispatch: ThunkDispatch, getState: () => State, extraArgument: Extra) => Promise; 33 | export interface ThunkFunction { 34 | (params: InputType): ThunkFunctionAction; 35 | action(params: InputType): ThunkFunctionAction; 36 | async: AsyncActionCreators; 37 | } 38 | export interface ThunkFunctionWithoutParams { 39 | (): ThunkFunctionAction; 40 | action(): ThunkFunctionAction; 41 | async: AsyncActionCreators; 42 | } 43 | /** Utility type for a function that takes paras and returns a redux-thunk */ 44 | export declare type ThunkCreator = (params?: InputType) => ThunkAction, State, unknown, AnyAction>; 45 | /** The result type for thunkToAction below */ 46 | export declare type ThunkFn = (params?: InputType) => Promise; 47 | /** 48 | * Passing the result of this to bindActionCreators and then calling the result 49 | * is equivalent to calling `store.dispatch(thunkCreator(params))`. Useful 50 | * for when you pass it to `connect()` in an action creators map object. 51 | * @param thunkCreator The thunk action creator 52 | * @returns thunkAction as if it was bound 53 | */ 54 | export declare function thunkToAction(thunkCreator: ThunkCreator): ThunkFn; 55 | export default asyncFactory; 56 | //# sourceMappingURL=index.d.ts.map -------------------------------------------------------------------------------- /esm/index.d.ts.map: -------------------------------------------------------------------------------- 1 | {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,WAAW,EAAE,aAAa,EAAE,MAAM,aAAa,CAAC;AAC9D,OAAO,KAAK,EACV,oBAAoB,EACpB,SAAS,EACT,mBAAmB,EACnB,IAAI,EACL,MAAM,gBAAgB,CAAC;AAExB;;;;;GAKG;AAEH,MAAM,WAAW,gBAAgB;CAAG;AAEpC;;GAEG;AACH,oBAAY,YAAY,CAAC,CAAC,IAAI,CAAC,GAAG,OAAO,CAAC,CAAC,CAAC,CAAC;AAE7C;;;GAGG;AACH,oBAAY,WAAW,CACrB,SAAS,EACT,UAAU,EACV,KAAK,GAAG,gBAAgB,EACxB,KAAK,GAAG,OAAO,IACb,CACF,MAAM,EAAE,SAAS,EACjB,QAAQ,EAAE,aAAa,CAAC,KAAK,EAAE,KAAK,EAAE,SAAS,CAAC,EAChD,QAAQ,EAAE,MAAM,KAAK,EACrB,aAAa,EAAE,KAAK,KACjB,YAAY,CAAC,UAAU,CAAC,CAAC;AAE9B,8CAA8C;AAC9C,oBAAY,eAAe,CAAC,CAAC,IAAI,CAAC,SAAS,IAAI,GAC3C,OAAO,GACP,CAAC,SAAS,OAAO,CAAC,CAAC,CAAC,GACpB,OAAO,CAAC,CAAC,CAAC,GACV,CAAC,CAAC;AAEN,aAAK,kBAAkB,CAAC,KAAK,EAAE,SAAS,EAAE,UAAU,EAAE,KAAK,EAAE,KAAK,IAChE,OAAO,SAAS,SAAS,GACrB,0BAA0B,CACxB,eAAe,CAAC,UAAU,CAAC,EAC3B,KAAK,EACL,KAAK,EACL,KAAK,CACN,GACD,aAAa,CACX,SAAS,EACT,eAAe,CAAC,UAAU,CAAC,EAC3B,KAAK,EACL,KAAK,EACL,KAAK,CACN,CAAC;AAER;;;;;;;GAOG;AACH,eAAO,MAAM,YAAY,uDAEZ,oBAAoB,YACpB,MAAM,QAAQ,IAAI,CAAC,wDAGtB,MAAM,mLAwCb,CAAC;AAGJ,oBAAY,mBAAmB,CAC7B,UAAU,EACV,KAAK,GAAG,gBAAgB,EACxB,KAAK,GAAG,OAAO,IACb,CACF,QAAQ,EAAE,aAAa,CAAC,KAAK,EAAE,KAAK,EAAE,SAAS,CAAC,EAChD,QAAQ,EAAE,MAAM,KAAK,EACrB,aAAa,EAAE,KAAK,KACjB,OAAO,CAAC,UAAU,CAAC,CAAC;AAEzB,MAAM,WAAW,aAAa,CAC5B,SAAS,EACT,UAAU,EACV,KAAK,GAAG,gBAAgB,EACxB,KAAK,GAAG,OAAO,EACf,KAAK,GAAG,OAAO;IAEf,CAAC,MAAM,EAAE,SAAS,GAAG,mBAAmB,CAAC,UAAU,EAAE,KAAK,EAAE,KAAK,CAAC,CAAC;IACnE,MAAM,CAAC,MAAM,EAAE,SAAS,GAAG,mBAAmB,CAAC,UAAU,EAAE,KAAK,EAAE,KAAK,CAAC,CAAC;IACzE,KAAK,EAAE,mBAAmB,CAAC,SAAS,EAAE,UAAU,EAAE,KAAK,CAAC,CAAC;CAC1D;AAED,MAAM,WAAW,0BAA0B,CACzC,UAAU,EACV,KAAK,GAAG,gBAAgB,EACxB,KAAK,GAAG,OAAO,EACf,KAAK,GAAG,OAAO;IAEf,IAAI,mBAAmB,CAAC,UAAU,EAAE,KAAK,EAAE,KAAK,CAAC,CAAC;IAClD,MAAM,IAAI,mBAAmB,CAAC,UAAU,EAAE,KAAK,EAAE,KAAK,CAAC,CAAC;IACxD,KAAK,EAAE,mBAAmB,CAAC,OAAO,EAAE,UAAU,EAAE,KAAK,CAAC,CAAC;CACxD;AAED,6EAA6E;AAC7E,oBAAY,YAAY,CAAC,SAAS,EAAE,UAAU,EAAE,KAAK,GAAG,gBAAgB,IAAI,CAC1E,MAAM,CAAC,EAAE,SAAS,KACf,WAAW,CAAC,OAAO,CAAC,UAAU,CAAC,EAAE,KAAK,EAAE,OAAO,EAAE,SAAS,CAAC,CAAC;AAEjE,8CAA8C;AAC9C,oBAAY,OAAO,CAAC,SAAS,EAAE,UAAU,IAAI,CAC3C,MAAM,CAAC,EAAE,SAAS,KACf,OAAO,CAAC,UAAU,CAAC,CAAC;AAEzB;;;;;;GAMG;AACH,wBAAgB,aAAa,CAAC,SAAS,EAAE,UAAU,EAAE,KAAK,GAAG,gBAAgB,EAC3E,YAAY,EAAE,YAAY,CAAC,SAAS,EAAE,UAAU,EAAE,KAAK,CAAC,GACvD,OAAO,CAAC,SAAS,EAAE,UAAU,CAAC,CAEhC;AAED,eAAe,YAAY,CAAC"} -------------------------------------------------------------------------------- /esm/index.js: -------------------------------------------------------------------------------- 1 | /** 2 | * Factory function to easily create a thunk 3 | * @param factory typescript-fsa action creator factory 4 | * @returns an function that takes 5 | * - the `type` of the action, 6 | * - the your worker thunk function 7 | * And returns object with the async actions and the thunk itself 8 | */ 9 | export var asyncFactory = function (factory, resolve) { 10 | if (resolve === void 0) { resolve = Promise.resolve.bind(Promise); } 11 | return function (type, worker, commonMeta) { 12 | var async = factory.async(type, commonMeta); 13 | var fn = function (params) { return function (dispatch, getState, extraArgument) { 14 | return resolve() 15 | .then(function () { 16 | dispatch(async.started(params)); 17 | }) 18 | .then(function () { return worker(params, dispatch, getState, extraArgument); }) 19 | .then(function (result) { 20 | dispatch(async.done({ params: params, result: result })); 21 | return result; 22 | }, function (error) { 23 | dispatch(async.failed({ params: params, error: error })); 24 | throw error; 25 | }); 26 | }; }; 27 | fn.action = function (params) { return fn(params); }; 28 | fn.async = async; 29 | return fn; 30 | }; 31 | }; 32 | /** 33 | * Passing the result of this to bindActionCreators and then calling the result 34 | * is equivalent to calling `store.dispatch(thunkCreator(params))`. Useful 35 | * for when you pass it to `connect()` in an action creators map object. 36 | * @param thunkCreator The thunk action creator 37 | * @returns thunkAction as if it was bound 38 | */ 39 | export function thunkToAction(thunkCreator) { 40 | return thunkCreator; 41 | } 42 | export default asyncFactory; 43 | //# sourceMappingURL=index.js.map -------------------------------------------------------------------------------- /esm/index.js.map: -------------------------------------------------------------------------------- 1 | {"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AA6DA;;;;;;;GAOG;AACH,MAAM,CAAC,IAAM,YAAY,GACvB,UACE,OAA6B,EAC7B,OAA4D;IAA5D,wBAAA,EAAA,UAA+B,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC;IAE9D,OAAA,UACE,IAAY,EACZ,MAAyE,EACzE,UAAiB;QASjB,IAAM,KAAK,GAAG,OAAO,CAAC,KAAK,CACzB,IAAI,EACJ,UAAU,CACX,CAAC;QACF,IAAM,EAAE,GAAc,UAAC,MAAM,IAAK,OAAA,UAAC,QAAQ,EAAE,QAAQ,EAAE,aAAa;YAClE,OAAA,OAAO,EAAE;iBACN,IAAI,CAAC;gBACJ,QAAQ,CAAC,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC;YAClC,CAAC,CAAC;iBACD,IAAI,CAAC,cAAM,OAAA,MAAM,CAAC,MAAM,EAAE,QAAQ,EAAE,QAAQ,EAAE,aAAa,CAAC,EAAjD,CAAiD,CAAC;iBAC7D,IAAI,CACH,UAAC,MAAM;gBACL,QAAQ,CAAC,KAAK,CAAC,IAAI,CAAC,EAAE,MAAM,QAAA,EAAE,MAAM,QAAA,EAAE,CAAC,CAAC,CAAC;gBACzC,OAAO,MAAM,CAAC;YAChB,CAAC,EACD,UAAC,KAAK;gBACJ,QAAQ,CAAC,KAAK,CAAC,MAAM,CAAC,EAAE,MAAM,QAAA,EAAE,KAAK,OAAA,EAAE,CAAC,CAAC,CAAC;gBAC1C,MAAM,KAAK,CAAC;YACd,CAAC,CACF;QAdH,CAcG,EAf6B,CAe7B,CAAC;QACN,EAAE,CAAC,MAAM,GAAG,UAAC,MAAM,IAAK,OAAA,EAAE,CAAC,MAAM,CAAC,EAAV,CAAU,CAAC;QACnC,EAAE,CAAC,KAAK,GAAG,KAAK,CAAC;QACjB,OAAO,EAMN,CAAC;IACJ,CAAC;AAzCD,CAyCC,CAAC;AA8CJ;;;;;;GAMG;AACH,MAAM,UAAU,aAAa,CAC3B,YAAwD;IAExD,OAAO,YAAyD,CAAC;AACnE,CAAC;AAED,eAAe,YAAY,CAAC"} -------------------------------------------------------------------------------- /lib/index.d.ts: -------------------------------------------------------------------------------- 1 | import type { ThunkAction, ThunkDispatch } from 'redux-thunk'; 2 | import type { ActionCreatorFactory, AnyAction, AsyncActionCreators, Meta } from 'typescript-fsa'; 3 | /** 4 | * This interface can be augmented by users to add default types for the root state when 5 | * using `typescript-fsa-redux-thunk`. 6 | * Use module augmentation to append your own type definition in a your_custom_type.d.ts file. 7 | * https://www.typescriptlang.org/docs/handbook/declaration-merging.html#module-augmentation 8 | */ 9 | export interface DefaultRootState { 10 | } 11 | /** 12 | * It's either a promise, or it isn't 13 | */ 14 | export declare type MaybePromise = T | Promise; 15 | /** 16 | * A redux-thunk with the params as the first argument. You don't have to 17 | * return a promise; but, the result of the dispatch will be one. 18 | */ 19 | export declare type AsyncWorker = (params: InputType, dispatch: ThunkDispatch, getState: () => State, extraArgument: Extra) => MaybePromise; 20 | /** Workaround for typescript-fsa issue #77 */ 21 | export declare type ThunkReturnType = T extends void ? unknown : T extends Promise ? Promise : T; 22 | declare type SmartThunkFunction = unknown extends InputType ? ThunkFunctionWithoutParams, State, Error, Extra> : ThunkFunction, State, Error, Extra>; 23 | /** 24 | * Factory function to easily create a thunk 25 | * @param factory typescript-fsa action creator factory 26 | * @returns an function that takes 27 | * - the `type` of the action, 28 | * - the your worker thunk function 29 | * And returns object with the async actions and the thunk itself 30 | */ 31 | export declare const asyncFactory: (factory: ActionCreatorFactory, resolve?: () => Promise) => (type: string, worker: AsyncWorker, State, Extra>, commonMeta?: Meta | undefined) => SmartThunkFunction; 32 | export declare type ThunkFunctionAction = (dispatch: ThunkDispatch, getState: () => State, extraArgument: Extra) => Promise; 33 | export interface ThunkFunction { 34 | (params: InputType): ThunkFunctionAction; 35 | action(params: InputType): ThunkFunctionAction; 36 | async: AsyncActionCreators; 37 | } 38 | export interface ThunkFunctionWithoutParams { 39 | (): ThunkFunctionAction; 40 | action(): ThunkFunctionAction; 41 | async: AsyncActionCreators; 42 | } 43 | /** Utility type for a function that takes paras and returns a redux-thunk */ 44 | export declare type ThunkCreator = (params?: InputType) => ThunkAction, State, unknown, AnyAction>; 45 | /** The result type for thunkToAction below */ 46 | export declare type ThunkFn = (params?: InputType) => Promise; 47 | /** 48 | * Passing the result of this to bindActionCreators and then calling the result 49 | * is equivalent to calling `store.dispatch(thunkCreator(params))`. Useful 50 | * for when you pass it to `connect()` in an action creators map object. 51 | * @param thunkCreator The thunk action creator 52 | * @returns thunkAction as if it was bound 53 | */ 54 | export declare function thunkToAction(thunkCreator: ThunkCreator): ThunkFn; 55 | export default asyncFactory; 56 | //# sourceMappingURL=index.d.ts.map -------------------------------------------------------------------------------- /lib/index.d.ts.map: -------------------------------------------------------------------------------- 1 | {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,WAAW,EAAE,aAAa,EAAE,MAAM,aAAa,CAAC;AAC9D,OAAO,KAAK,EACV,oBAAoB,EACpB,SAAS,EACT,mBAAmB,EACnB,IAAI,EACL,MAAM,gBAAgB,CAAC;AAExB;;;;;GAKG;AAEH,MAAM,WAAW,gBAAgB;CAAG;AAEpC;;GAEG;AACH,oBAAY,YAAY,CAAC,CAAC,IAAI,CAAC,GAAG,OAAO,CAAC,CAAC,CAAC,CAAC;AAE7C;;;GAGG;AACH,oBAAY,WAAW,CACrB,SAAS,EACT,UAAU,EACV,KAAK,GAAG,gBAAgB,EACxB,KAAK,GAAG,OAAO,IACb,CACF,MAAM,EAAE,SAAS,EACjB,QAAQ,EAAE,aAAa,CAAC,KAAK,EAAE,KAAK,EAAE,SAAS,CAAC,EAChD,QAAQ,EAAE,MAAM,KAAK,EACrB,aAAa,EAAE,KAAK,KACjB,YAAY,CAAC,UAAU,CAAC,CAAC;AAE9B,8CAA8C;AAC9C,oBAAY,eAAe,CAAC,CAAC,IAAI,CAAC,SAAS,IAAI,GAC3C,OAAO,GACP,CAAC,SAAS,OAAO,CAAC,CAAC,CAAC,GACpB,OAAO,CAAC,CAAC,CAAC,GACV,CAAC,CAAC;AAEN,aAAK,kBAAkB,CAAC,KAAK,EAAE,SAAS,EAAE,UAAU,EAAE,KAAK,EAAE,KAAK,IAChE,OAAO,SAAS,SAAS,GACrB,0BAA0B,CACxB,eAAe,CAAC,UAAU,CAAC,EAC3B,KAAK,EACL,KAAK,EACL,KAAK,CACN,GACD,aAAa,CACX,SAAS,EACT,eAAe,CAAC,UAAU,CAAC,EAC3B,KAAK,EACL,KAAK,EACL,KAAK,CACN,CAAC;AAER;;;;;;;GAOG;AACH,eAAO,MAAM,YAAY,uDAEZ,oBAAoB,YACpB,MAAM,QAAQ,IAAI,CAAC,wDAGtB,MAAM,mLAwCb,CAAC;AAGJ,oBAAY,mBAAmB,CAC7B,UAAU,EACV,KAAK,GAAG,gBAAgB,EACxB,KAAK,GAAG,OAAO,IACb,CACF,QAAQ,EAAE,aAAa,CAAC,KAAK,EAAE,KAAK,EAAE,SAAS,CAAC,EAChD,QAAQ,EAAE,MAAM,KAAK,EACrB,aAAa,EAAE,KAAK,KACjB,OAAO,CAAC,UAAU,CAAC,CAAC;AAEzB,MAAM,WAAW,aAAa,CAC5B,SAAS,EACT,UAAU,EACV,KAAK,GAAG,gBAAgB,EACxB,KAAK,GAAG,OAAO,EACf,KAAK,GAAG,OAAO;IAEf,CAAC,MAAM,EAAE,SAAS,GAAG,mBAAmB,CAAC,UAAU,EAAE,KAAK,EAAE,KAAK,CAAC,CAAC;IACnE,MAAM,CAAC,MAAM,EAAE,SAAS,GAAG,mBAAmB,CAAC,UAAU,EAAE,KAAK,EAAE,KAAK,CAAC,CAAC;IACzE,KAAK,EAAE,mBAAmB,CAAC,SAAS,EAAE,UAAU,EAAE,KAAK,CAAC,CAAC;CAC1D;AAED,MAAM,WAAW,0BAA0B,CACzC,UAAU,EACV,KAAK,GAAG,gBAAgB,EACxB,KAAK,GAAG,OAAO,EACf,KAAK,GAAG,OAAO;IAEf,IAAI,mBAAmB,CAAC,UAAU,EAAE,KAAK,EAAE,KAAK,CAAC,CAAC;IAClD,MAAM,IAAI,mBAAmB,CAAC,UAAU,EAAE,KAAK,EAAE,KAAK,CAAC,CAAC;IACxD,KAAK,EAAE,mBAAmB,CAAC,OAAO,EAAE,UAAU,EAAE,KAAK,CAAC,CAAC;CACxD;AAED,6EAA6E;AAC7E,oBAAY,YAAY,CAAC,SAAS,EAAE,UAAU,EAAE,KAAK,GAAG,gBAAgB,IAAI,CAC1E,MAAM,CAAC,EAAE,SAAS,KACf,WAAW,CAAC,OAAO,CAAC,UAAU,CAAC,EAAE,KAAK,EAAE,OAAO,EAAE,SAAS,CAAC,CAAC;AAEjE,8CAA8C;AAC9C,oBAAY,OAAO,CAAC,SAAS,EAAE,UAAU,IAAI,CAC3C,MAAM,CAAC,EAAE,SAAS,KACf,OAAO,CAAC,UAAU,CAAC,CAAC;AAEzB;;;;;;GAMG;AACH,wBAAgB,aAAa,CAAC,SAAS,EAAE,UAAU,EAAE,KAAK,GAAG,gBAAgB,EAC3E,YAAY,EAAE,YAAY,CAAC,SAAS,EAAE,UAAU,EAAE,KAAK,CAAC,GACvD,OAAO,CAAC,SAAS,EAAE,UAAU,CAAC,CAEhC;AAED,eAAe,YAAY,CAAC"} -------------------------------------------------------------------------------- /lib/index.js: -------------------------------------------------------------------------------- 1 | "use strict"; 2 | Object.defineProperty(exports, "__esModule", { value: true }); 3 | exports.thunkToAction = exports.asyncFactory = void 0; 4 | /** 5 | * Factory function to easily create a thunk 6 | * @param factory typescript-fsa action creator factory 7 | * @returns an function that takes 8 | * - the `type` of the action, 9 | * - the your worker thunk function 10 | * And returns object with the async actions and the thunk itself 11 | */ 12 | var asyncFactory = function (factory, resolve) { 13 | if (resolve === void 0) { resolve = Promise.resolve.bind(Promise); } 14 | return function (type, worker, commonMeta) { 15 | var async = factory.async(type, commonMeta); 16 | var fn = function (params) { return function (dispatch, getState, extraArgument) { 17 | return resolve() 18 | .then(function () { 19 | dispatch(async.started(params)); 20 | }) 21 | .then(function () { return worker(params, dispatch, getState, extraArgument); }) 22 | .then(function (result) { 23 | dispatch(async.done({ params: params, result: result })); 24 | return result; 25 | }, function (error) { 26 | dispatch(async.failed({ params: params, error: error })); 27 | throw error; 28 | }); 29 | }; }; 30 | fn.action = function (params) { return fn(params); }; 31 | fn.async = async; 32 | return fn; 33 | }; 34 | }; 35 | exports.asyncFactory = asyncFactory; 36 | /** 37 | * Passing the result of this to bindActionCreators and then calling the result 38 | * is equivalent to calling `store.dispatch(thunkCreator(params))`. Useful 39 | * for when you pass it to `connect()` in an action creators map object. 40 | * @param thunkCreator The thunk action creator 41 | * @returns thunkAction as if it was bound 42 | */ 43 | function thunkToAction(thunkCreator) { 44 | return thunkCreator; 45 | } 46 | exports.thunkToAction = thunkToAction; 47 | exports.default = exports.asyncFactory; 48 | //# sourceMappingURL=index.js.map -------------------------------------------------------------------------------- /lib/index.js.map: -------------------------------------------------------------------------------- 1 | {"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;AA6DA;;;;;;;GAOG;AACI,IAAM,YAAY,GACvB,UACE,OAA6B,EAC7B,OAA4D;IAA5D,wBAAA,EAAA,UAA+B,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC;IAE9D,OAAA,UACE,IAAY,EACZ,MAAyE,EACzE,UAAiB;QASjB,IAAM,KAAK,GAAG,OAAO,CAAC,KAAK,CACzB,IAAI,EACJ,UAAU,CACX,CAAC;QACF,IAAM,EAAE,GAAc,UAAC,MAAM,IAAK,OAAA,UAAC,QAAQ,EAAE,QAAQ,EAAE,aAAa;YAClE,OAAA,OAAO,EAAE;iBACN,IAAI,CAAC;gBACJ,QAAQ,CAAC,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC;YAClC,CAAC,CAAC;iBACD,IAAI,CAAC,cAAM,OAAA,MAAM,CAAC,MAAM,EAAE,QAAQ,EAAE,QAAQ,EAAE,aAAa,CAAC,EAAjD,CAAiD,CAAC;iBAC7D,IAAI,CACH,UAAC,MAAM;gBACL,QAAQ,CAAC,KAAK,CAAC,IAAI,CAAC,EAAE,MAAM,QAAA,EAAE,MAAM,QAAA,EAAE,CAAC,CAAC,CAAC;gBACzC,OAAO,MAAM,CAAC;YAChB,CAAC,EACD,UAAC,KAAK;gBACJ,QAAQ,CAAC,KAAK,CAAC,MAAM,CAAC,EAAE,MAAM,QAAA,EAAE,KAAK,OAAA,EAAE,CAAC,CAAC,CAAC;gBAC1C,MAAM,KAAK,CAAC;YACd,CAAC,CACF;QAdH,CAcG,EAf6B,CAe7B,CAAC;QACN,EAAE,CAAC,MAAM,GAAG,UAAC,MAAM,IAAK,OAAA,EAAE,CAAC,MAAM,CAAC,EAAV,CAAU,CAAC;QACnC,EAAE,CAAC,KAAK,GAAG,KAAK,CAAC;QACjB,OAAO,EAMN,CAAC;IACJ,CAAC;AAzCD,CAyCC,CAAC;AA9CS,QAAA,YAAY,gBA8CrB;AA8CJ;;;;;;GAMG;AACH,SAAgB,aAAa,CAC3B,YAAwD;IAExD,OAAO,YAAyD,CAAC;AACnE,CAAC;AAJD,sCAIC;AAED,kBAAe,oBAAY,CAAC"} -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "typescript-fsa-redux-thunk", 3 | "version": "2.10.2", 4 | "lockfileVersion": 1, 5 | "requires": true, 6 | "dependencies": { 7 | "@babel/code-frame": { 8 | "version": "7.10.4", 9 | "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.10.4.tgz", 10 | "integrity": "sha512-vG6SvB6oYEhvgisZNFRmRCUkLz11c7rp+tbNTynGqc6mS1d5ATd/sGyV6W0KZZnXRKMTzZDRgQT3Ou9jhpAfUg==", 11 | "dev": true, 12 | "requires": { 13 | "@babel/highlight": "^7.10.4" 14 | } 15 | }, 16 | "@babel/core": { 17 | "version": "7.11.6", 18 | "resolved": "https://registry.npmjs.org/@babel/core/-/core-7.11.6.tgz", 19 | "integrity": "sha512-Wpcv03AGnmkgm6uS6k8iwhIwTrcP0m17TL1n1sy7qD0qelDu4XNeW0dN0mHfa+Gei211yDaLoEe/VlbXQzM4Bg==", 20 | "dev": true, 21 | "requires": { 22 | "@babel/code-frame": "^7.10.4", 23 | "@babel/generator": "^7.11.6", 24 | "@babel/helper-module-transforms": "^7.11.0", 25 | "@babel/helpers": "^7.10.4", 26 | "@babel/parser": "^7.11.5", 27 | "@babel/template": "^7.10.4", 28 | "@babel/traverse": "^7.11.5", 29 | "@babel/types": "^7.11.5", 30 | "convert-source-map": "^1.7.0", 31 | "debug": "^4.1.0", 32 | "gensync": "^1.0.0-beta.1", 33 | "json5": "^2.1.2", 34 | "lodash": "^4.17.19", 35 | "resolve": "^1.3.2", 36 | "semver": "^5.4.1", 37 | "source-map": "^0.5.0" 38 | }, 39 | "dependencies": { 40 | "semver": { 41 | "version": "5.7.1", 42 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz", 43 | "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==", 44 | "dev": true 45 | } 46 | } 47 | }, 48 | "@babel/generator": { 49 | "version": "7.11.6", 50 | "resolved": "https://registry.npmjs.org/@babel/generator/-/generator-7.11.6.tgz", 51 | "integrity": "sha512-DWtQ1PV3r+cLbySoHrwn9RWEgKMBLLma4OBQloPRyDYvc5msJM9kvTLo1YnlJd1P/ZuKbdli3ijr5q3FvAF3uA==", 52 | "dev": true, 53 | "requires": { 54 | "@babel/types": "^7.11.5", 55 | "jsesc": "^2.5.1", 56 | "source-map": "^0.5.0" 57 | } 58 | }, 59 | "@babel/helper-function-name": { 60 | "version": "7.10.4", 61 | "resolved": "https://registry.npmjs.org/@babel/helper-function-name/-/helper-function-name-7.10.4.tgz", 62 | "integrity": "sha512-YdaSyz1n8gY44EmN7x44zBn9zQ1Ry2Y+3GTA+3vH6Mizke1Vw0aWDM66FOYEPw8//qKkmqOckrGgTYa+6sceqQ==", 63 | "dev": true, 64 | "requires": { 65 | "@babel/helper-get-function-arity": "^7.10.4", 66 | "@babel/template": "^7.10.4", 67 | "@babel/types": "^7.10.4" 68 | } 69 | }, 70 | "@babel/helper-get-function-arity": { 71 | "version": "7.10.4", 72 | "resolved": "https://registry.npmjs.org/@babel/helper-get-function-arity/-/helper-get-function-arity-7.10.4.tgz", 73 | "integrity": "sha512-EkN3YDB+SRDgiIUnNgcmiD361ti+AVbL3f3Henf6dqqUyr5dMsorno0lJWJuLhDhkI5sYEpgj6y9kB8AOU1I2A==", 74 | "dev": true, 75 | "requires": { 76 | "@babel/types": "^7.10.4" 77 | } 78 | }, 79 | "@babel/helper-member-expression-to-functions": { 80 | "version": "7.11.0", 81 | "resolved": "https://registry.npmjs.org/@babel/helper-member-expression-to-functions/-/helper-member-expression-to-functions-7.11.0.tgz", 82 | "integrity": "sha512-JbFlKHFntRV5qKw3YC0CvQnDZ4XMwgzzBbld7Ly4Mj4cbFy3KywcR8NtNctRToMWJOVvLINJv525Gd6wwVEx/Q==", 83 | "dev": true, 84 | "requires": { 85 | "@babel/types": "^7.11.0" 86 | } 87 | }, 88 | "@babel/helper-module-imports": { 89 | "version": "7.10.4", 90 | "resolved": "https://registry.npmjs.org/@babel/helper-module-imports/-/helper-module-imports-7.10.4.tgz", 91 | "integrity": "sha512-nEQJHqYavI217oD9+s5MUBzk6x1IlvoS9WTPfgG43CbMEeStE0v+r+TucWdx8KFGowPGvyOkDT9+7DHedIDnVw==", 92 | "dev": true, 93 | "requires": { 94 | "@babel/types": "^7.10.4" 95 | } 96 | }, 97 | "@babel/helper-module-transforms": { 98 | "version": "7.11.0", 99 | "resolved": "https://registry.npmjs.org/@babel/helper-module-transforms/-/helper-module-transforms-7.11.0.tgz", 100 | "integrity": "sha512-02EVu8COMuTRO1TAzdMtpBPbe6aQ1w/8fePD2YgQmxZU4gpNWaL9gK3Jp7dxlkUlUCJOTaSeA+Hrm1BRQwqIhg==", 101 | "dev": true, 102 | "requires": { 103 | "@babel/helper-module-imports": "^7.10.4", 104 | "@babel/helper-replace-supers": "^7.10.4", 105 | "@babel/helper-simple-access": "^7.10.4", 106 | "@babel/helper-split-export-declaration": "^7.11.0", 107 | "@babel/template": "^7.10.4", 108 | "@babel/types": "^7.11.0", 109 | "lodash": "^4.17.19" 110 | } 111 | }, 112 | "@babel/helper-optimise-call-expression": { 113 | "version": "7.10.4", 114 | "resolved": "https://registry.npmjs.org/@babel/helper-optimise-call-expression/-/helper-optimise-call-expression-7.10.4.tgz", 115 | "integrity": "sha512-n3UGKY4VXwXThEiKrgRAoVPBMqeoPgHVqiHZOanAJCG9nQUL2pLRQirUzl0ioKclHGpGqRgIOkgcIJaIWLpygg==", 116 | "dev": true, 117 | "requires": { 118 | "@babel/types": "^7.10.4" 119 | } 120 | }, 121 | "@babel/helper-replace-supers": { 122 | "version": "7.10.4", 123 | "resolved": "https://registry.npmjs.org/@babel/helper-replace-supers/-/helper-replace-supers-7.10.4.tgz", 124 | "integrity": "sha512-sPxZfFXocEymYTdVK1UNmFPBN+Hv5mJkLPsYWwGBxZAxaWfFu+xqp7b6qWD0yjNuNL2VKc6L5M18tOXUP7NU0A==", 125 | "dev": true, 126 | "requires": { 127 | "@babel/helper-member-expression-to-functions": "^7.10.4", 128 | "@babel/helper-optimise-call-expression": "^7.10.4", 129 | "@babel/traverse": "^7.10.4", 130 | "@babel/types": "^7.10.4" 131 | } 132 | }, 133 | "@babel/helper-simple-access": { 134 | "version": "7.10.4", 135 | "resolved": "https://registry.npmjs.org/@babel/helper-simple-access/-/helper-simple-access-7.10.4.tgz", 136 | "integrity": "sha512-0fMy72ej/VEvF8ULmX6yb5MtHG4uH4Dbd6I/aHDb/JVg0bbivwt9Wg+h3uMvX+QSFtwr5MeItvazbrc4jtRAXw==", 137 | "dev": true, 138 | "requires": { 139 | "@babel/template": "^7.10.4", 140 | "@babel/types": "^7.10.4" 141 | } 142 | }, 143 | "@babel/helper-split-export-declaration": { 144 | "version": "7.11.0", 145 | "resolved": "https://registry.npmjs.org/@babel/helper-split-export-declaration/-/helper-split-export-declaration-7.11.0.tgz", 146 | "integrity": "sha512-74Vejvp6mHkGE+m+k5vHY93FX2cAtrw1zXrZXRlG4l410Nm9PxfEiVTn1PjDPV5SnmieiueY4AFg2xqhNFuuZg==", 147 | "dev": true, 148 | "requires": { 149 | "@babel/types": "^7.11.0" 150 | } 151 | }, 152 | "@babel/helper-validator-identifier": { 153 | "version": "7.10.4", 154 | "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.10.4.tgz", 155 | "integrity": "sha512-3U9y+43hz7ZM+rzG24Qe2mufW5KhvFg/NhnNph+i9mgCtdTCtMJuI1TMkrIUiK7Ix4PYlRF9I5dhqaLYA/ADXw==", 156 | "dev": true 157 | }, 158 | "@babel/helpers": { 159 | "version": "7.10.4", 160 | "resolved": "https://registry.npmjs.org/@babel/helpers/-/helpers-7.10.4.tgz", 161 | "integrity": "sha512-L2gX/XeUONeEbI78dXSrJzGdz4GQ+ZTA/aazfUsFaWjSe95kiCuOZ5HsXvkiw3iwF+mFHSRUfJU8t6YavocdXA==", 162 | "dev": true, 163 | "requires": { 164 | "@babel/template": "^7.10.4", 165 | "@babel/traverse": "^7.10.4", 166 | "@babel/types": "^7.10.4" 167 | } 168 | }, 169 | "@babel/highlight": { 170 | "version": "7.10.4", 171 | "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.10.4.tgz", 172 | "integrity": "sha512-i6rgnR/YgPEQzZZnbTHHuZdlE8qyoBNalD6F+q4vAFlcMEcqmkoG+mPqJYJCo63qPf74+Y1UZsl3l6f7/RIkmA==", 173 | "dev": true, 174 | "requires": { 175 | "@babel/helper-validator-identifier": "^7.10.4", 176 | "chalk": "^2.0.0", 177 | "js-tokens": "^4.0.0" 178 | }, 179 | "dependencies": { 180 | "chalk": { 181 | "version": "2.4.2", 182 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", 183 | "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", 184 | "dev": true, 185 | "requires": { 186 | "ansi-styles": "^3.2.1", 187 | "escape-string-regexp": "^1.0.5", 188 | "supports-color": "^5.3.0" 189 | } 190 | } 191 | } 192 | }, 193 | "@babel/parser": { 194 | "version": "7.11.5", 195 | "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.11.5.tgz", 196 | "integrity": "sha512-X9rD8qqm695vgmeaQ4fvz/o3+Wk4ZzQvSHkDBgpYKxpD4qTAUm88ZKtHkVqIOsYFFbIQ6wQYhC6q7pjqVK0E0Q==", 197 | "dev": true 198 | }, 199 | "@babel/template": { 200 | "version": "7.10.4", 201 | "resolved": "https://registry.npmjs.org/@babel/template/-/template-7.10.4.tgz", 202 | "integrity": "sha512-ZCjD27cGJFUB6nmCB1Enki3r+L5kJveX9pq1SvAUKoICy6CZ9yD8xO086YXdYhvNjBdnekm4ZnaP5yC8Cs/1tA==", 203 | "dev": true, 204 | "requires": { 205 | "@babel/code-frame": "^7.10.4", 206 | "@babel/parser": "^7.10.4", 207 | "@babel/types": "^7.10.4" 208 | } 209 | }, 210 | "@babel/traverse": { 211 | "version": "7.11.5", 212 | "resolved": "https://registry.npmjs.org/@babel/traverse/-/traverse-7.11.5.tgz", 213 | "integrity": "sha512-EjiPXt+r7LiCZXEfRpSJd+jUMnBd4/9OUv7Nx3+0u9+eimMwJmG0Q98lw4/289JCoxSE8OolDMNZaaF/JZ69WQ==", 214 | "dev": true, 215 | "requires": { 216 | "@babel/code-frame": "^7.10.4", 217 | "@babel/generator": "^7.11.5", 218 | "@babel/helper-function-name": "^7.10.4", 219 | "@babel/helper-split-export-declaration": "^7.11.0", 220 | "@babel/parser": "^7.11.5", 221 | "@babel/types": "^7.11.5", 222 | "debug": "^4.1.0", 223 | "globals": "^11.1.0", 224 | "lodash": "^4.17.19" 225 | }, 226 | "dependencies": { 227 | "globals": { 228 | "version": "11.12.0", 229 | "resolved": "https://registry.npmjs.org/globals/-/globals-11.12.0.tgz", 230 | "integrity": "sha512-WOBp/EEGUiIsJSp7wcv/y6MO+lV9UoncWqxuFfm8eBwzWNgyfBd6Gz+IeKQ9jCmyhoH99g15M3T+QaVHFjizVA==", 231 | "dev": true 232 | } 233 | } 234 | }, 235 | "@babel/types": { 236 | "version": "7.11.5", 237 | "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.11.5.tgz", 238 | "integrity": "sha512-bvM7Qz6eKnJVFIn+1LPtjlBFPVN5jNDc1XmN15vWe7Q3DPBufWWsLiIvUu7xW87uTG6QoggpIDnUgLQvPheU+Q==", 239 | "dev": true, 240 | "requires": { 241 | "@babel/helper-validator-identifier": "^7.10.4", 242 | "lodash": "^4.17.19", 243 | "to-fast-properties": "^2.0.0" 244 | } 245 | }, 246 | "@cspotcode/source-map-consumer": { 247 | "version": "0.8.0", 248 | "resolved": "https://registry.npmjs.org/@cspotcode/source-map-consumer/-/source-map-consumer-0.8.0.tgz", 249 | "integrity": "sha512-41qniHzTU8yAGbCp04ohlmSrZf8bkf/iJsl3V0dRGsQN/5GFfx+LbCSsCpp2gqrqjTVg/K6O8ycoV35JIwAzAg==", 250 | "dev": true 251 | }, 252 | "@cspotcode/source-map-support": { 253 | "version": "0.6.1", 254 | "resolved": "https://registry.npmjs.org/@cspotcode/source-map-support/-/source-map-support-0.6.1.tgz", 255 | "integrity": "sha512-DX3Z+T5dt1ockmPdobJS/FAsQPW4V4SrWEhD2iYQT2Cb2tQsiMnYxrcUH9By/Z3B+v0S5LMBkQtV/XOBbpLEOg==", 256 | "dev": true, 257 | "requires": { 258 | "@cspotcode/source-map-consumer": "0.8.0" 259 | } 260 | }, 261 | "@eslint/eslintrc": { 262 | "version": "0.4.3", 263 | "resolved": "https://registry.npmjs.org/@eslint/eslintrc/-/eslintrc-0.4.3.tgz", 264 | "integrity": "sha512-J6KFFz5QCYUJq3pf0mjEcCJVERbzv71PUIDczuh9JkwGEzced6CO5ADLHB1rbf/+oPBtoPfMYNOpGDzCANlbXw==", 265 | "dev": true, 266 | "requires": { 267 | "ajv": "^6.12.4", 268 | "debug": "^4.1.1", 269 | "espree": "^7.3.0", 270 | "globals": "^13.9.0", 271 | "ignore": "^4.0.6", 272 | "import-fresh": "^3.2.1", 273 | "js-yaml": "^3.13.1", 274 | "minimatch": "^3.0.4", 275 | "strip-json-comments": "^3.1.1" 276 | }, 277 | "dependencies": { 278 | "ignore": { 279 | "version": "4.0.6", 280 | "resolved": "https://registry.npmjs.org/ignore/-/ignore-4.0.6.tgz", 281 | "integrity": "sha512-cyFDKrqc/YdcWFniJhzI42+AzS+gNwmUzOSFcRCQYwySuBBBy/KjuxWLZ/FHEH6Moq1NizMOBWyTcv8O4OZIMg==", 282 | "dev": true 283 | } 284 | } 285 | }, 286 | "@humanwhocodes/config-array": { 287 | "version": "0.5.0", 288 | "resolved": "https://registry.npmjs.org/@humanwhocodes/config-array/-/config-array-0.5.0.tgz", 289 | "integrity": "sha512-FagtKFz74XrTl7y6HCzQpwDfXP0yhxe9lHLD1UZxjvZIcbyRz8zTFF/yYNfSfzU414eDwZ1SrO0Qvtyf+wFMQg==", 290 | "dev": true, 291 | "requires": { 292 | "@humanwhocodes/object-schema": "^1.2.0", 293 | "debug": "^4.1.1", 294 | "minimatch": "^3.0.4" 295 | } 296 | }, 297 | "@humanwhocodes/object-schema": { 298 | "version": "1.2.0", 299 | "resolved": "https://registry.npmjs.org/@humanwhocodes/object-schema/-/object-schema-1.2.0.tgz", 300 | "integrity": "sha512-wdppn25U8z/2yiaT6YGquE6X8sSv7hNMWSXYSSU1jGv/yd6XqjXgTDJ8KP4NgjTXfJ3GbRjeeb8RTV7a/VpM+w==", 301 | "dev": true 302 | }, 303 | "@istanbuljs/load-nyc-config": { 304 | "version": "1.1.0", 305 | "resolved": "https://registry.npmjs.org/@istanbuljs/load-nyc-config/-/load-nyc-config-1.1.0.tgz", 306 | "integrity": "sha512-VjeHSlIzpv/NyD3N0YuHfXOPDIixcA1q2ZV98wsMqcYlPmv2n3Yb2lYP9XMElnaFVXg5A7YLTeLu6V84uQDjmQ==", 307 | "dev": true, 308 | "requires": { 309 | "camelcase": "^5.3.1", 310 | "find-up": "^4.1.0", 311 | "get-package-type": "^0.1.0", 312 | "js-yaml": "^3.13.1", 313 | "resolve-from": "^5.0.0" 314 | }, 315 | "dependencies": { 316 | "find-up": { 317 | "version": "4.1.0", 318 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-4.1.0.tgz", 319 | "integrity": "sha512-PpOwAdQ/YlXQ2vj8a3h8IipDuYRi3wceVQQGYWxNINccq40Anw7BlsEXCMbt1Zt+OLA6Fq9suIpIWD0OsnISlw==", 320 | "dev": true, 321 | "requires": { 322 | "locate-path": "^5.0.0", 323 | "path-exists": "^4.0.0" 324 | } 325 | }, 326 | "locate-path": { 327 | "version": "5.0.0", 328 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-5.0.0.tgz", 329 | "integrity": "sha512-t7hw9pI+WvuwNJXwk5zVHpyhIqzg2qTlklJOf0mVxGSbe3Fp2VieZcduNYjaLDoy6p9uGpQEGWG87WpMKlNq8g==", 330 | "dev": true, 331 | "requires": { 332 | "p-locate": "^4.1.0" 333 | } 334 | }, 335 | "p-limit": { 336 | "version": "2.3.0", 337 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-2.3.0.tgz", 338 | "integrity": "sha512-//88mFWSJx8lxCzwdAABTJL2MyWB12+eIY7MDL2SqLmAkeKU9qxRvWuSyTjm3FUmpBEMuFfckAIqEaVGUDxb6w==", 339 | "dev": true, 340 | "requires": { 341 | "p-try": "^2.0.0" 342 | } 343 | }, 344 | "p-locate": { 345 | "version": "4.1.0", 346 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-4.1.0.tgz", 347 | "integrity": "sha512-R79ZZ/0wAxKGu3oYMlz8jy/kbhsNrS7SKZ7PxEHBgJ5+F2mtFW2fK2cOtBh1cHYkQsbzFV7I+EoRKe6Yt0oK7A==", 348 | "dev": true, 349 | "requires": { 350 | "p-limit": "^2.2.0" 351 | } 352 | }, 353 | "resolve-from": { 354 | "version": "5.0.0", 355 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-5.0.0.tgz", 356 | "integrity": "sha512-qYg9KP24dD5qka9J47d0aVky0N+b4fTU89LN9iDnjB5waksiC49rvMB0PrUJQGoTmH50XPiqOvAjDfaijGxYZw==", 357 | "dev": true 358 | } 359 | } 360 | }, 361 | "@istanbuljs/schema": { 362 | "version": "0.1.2", 363 | "resolved": "https://registry.npmjs.org/@istanbuljs/schema/-/schema-0.1.2.tgz", 364 | "integrity": "sha512-tsAQNx32a8CoFhjhijUIhI4kccIAgmGhy8LZMZgGfmXcpMbPRUqn5LWmgRttILi6yeGmBJd2xsPkFMs0PzgPCw==", 365 | "dev": true 366 | }, 367 | "@nodelib/fs.scandir": { 368 | "version": "2.1.5", 369 | "resolved": "https://registry.npmjs.org/@nodelib/fs.scandir/-/fs.scandir-2.1.5.tgz", 370 | "integrity": "sha512-vq24Bq3ym5HEQm2NKCr3yXDwjc7vTsEThRDnkp2DK9p1uqLR+DHurm/NOTo0KG7HYHU7eppKZj3MyqYuMBf62g==", 371 | "dev": true, 372 | "requires": { 373 | "@nodelib/fs.stat": "2.0.5", 374 | "run-parallel": "^1.1.9" 375 | } 376 | }, 377 | "@nodelib/fs.stat": { 378 | "version": "2.0.5", 379 | "resolved": "https://registry.npmjs.org/@nodelib/fs.stat/-/fs.stat-2.0.5.tgz", 380 | "integrity": "sha512-RkhPPp2zrqDAQA/2jNhnztcPAlv64XdhIp7a7454A5ovI7Bukxgt7MX7udwAu3zg1DcpPU0rz3VV1SeaqvY4+A==", 381 | "dev": true 382 | }, 383 | "@nodelib/fs.walk": { 384 | "version": "1.2.8", 385 | "resolved": "https://registry.npmjs.org/@nodelib/fs.walk/-/fs.walk-1.2.8.tgz", 386 | "integrity": "sha512-oGB+UxlgWcgQkgwo8GcEGwemoTFt3FIO9ababBmaGwXIoBKZ+GTy0pP185beGg7Llih/NSHSV2XAs1lnznocSg==", 387 | "dev": true, 388 | "requires": { 389 | "@nodelib/fs.scandir": "2.1.5", 390 | "fastq": "^1.6.0" 391 | } 392 | }, 393 | "@tootallnate/once": { 394 | "version": "1.1.2", 395 | "resolved": "https://registry.npmjs.org/@tootallnate/once/-/once-1.1.2.tgz", 396 | "integrity": "sha512-RbzJvlNzmRq5c3O09UipeuXno4tA1FE6ikOjxZK0tuxVv3412l64l5t1W5pj4+rJq9vpkm/kwiR07aZXnsKPxw==", 397 | "dev": true 398 | }, 399 | "@tsconfig/node10": { 400 | "version": "1.0.8", 401 | "resolved": "https://registry.npmjs.org/@tsconfig/node10/-/node10-1.0.8.tgz", 402 | "integrity": "sha512-6XFfSQmMgq0CFLY1MslA/CPUfhIL919M1rMsa5lP2P097N2Wd1sSX0tx1u4olM16fLNhtHZpRhedZJphNJqmZg==", 403 | "dev": true 404 | }, 405 | "@tsconfig/node12": { 406 | "version": "1.0.9", 407 | "resolved": "https://registry.npmjs.org/@tsconfig/node12/-/node12-1.0.9.tgz", 408 | "integrity": "sha512-/yBMcem+fbvhSREH+s14YJi18sp7J9jpuhYByADT2rypfajMZZN4WQ6zBGgBKp53NKmqI36wFYDb3yaMPurITw==", 409 | "dev": true 410 | }, 411 | "@tsconfig/node14": { 412 | "version": "1.0.1", 413 | "resolved": "https://registry.npmjs.org/@tsconfig/node14/-/node14-1.0.1.tgz", 414 | "integrity": "sha512-509r2+yARFfHHE7T6Puu2jjkoycftovhXRqW328PDXTVGKihlb1P8Z9mMZH04ebyajfRY7dedfGynlrFHJUQCg==", 415 | "dev": true 416 | }, 417 | "@tsconfig/node16": { 418 | "version": "1.0.2", 419 | "resolved": "https://registry.npmjs.org/@tsconfig/node16/-/node16-1.0.2.tgz", 420 | "integrity": "sha512-eZxlbI8GZscaGS7kkc/trHTT5xgrjH3/1n2JDwusC9iahPKWMRvRjJSAN5mCXviuTGQ/lHnhvv8Q1YTpnfz9gA==", 421 | "dev": true 422 | }, 423 | "@types/chai": { 424 | "version": "4.2.21", 425 | "resolved": "https://registry.npmjs.org/@types/chai/-/chai-4.2.21.tgz", 426 | "integrity": "sha512-yd+9qKmJxm496BOV9CMNaey8TWsikaZOwMRwPHQIjcOJM9oV+fi9ZMNw3JsVnbEEbo2gRTDnGEBv8pjyn67hNg==", 427 | "dev": true 428 | }, 429 | "@types/color-name": { 430 | "version": "1.1.1", 431 | "resolved": "https://registry.npmjs.org/@types/color-name/-/color-name-1.1.1.tgz", 432 | "integrity": "sha512-rr+OQyAjxze7GgWrSaJwydHStIhHq2lvY3BOC2Mj7KnzI7XK0Uw1TOOdI9lDoajEbSWLiYgoo4f1R51erQfhPQ==", 433 | "dev": true 434 | }, 435 | "@types/json-schema": { 436 | "version": "7.0.9", 437 | "resolved": "https://registry.npmjs.org/@types/json-schema/-/json-schema-7.0.9.tgz", 438 | "integrity": "sha512-qcUXuemtEu+E5wZSJHNxUXeCZhAfXKQ41D+duX+VYPde7xyEVZci+/oXKJL13tnRs9lR2pr4fod59GT6/X1/yQ==", 439 | "dev": true 440 | }, 441 | "@types/mocha": { 442 | "version": "9.0.0", 443 | "resolved": "https://registry.npmjs.org/@types/mocha/-/mocha-9.0.0.tgz", 444 | "integrity": "sha512-scN0hAWyLVAvLR9AyW7HoFF5sJZglyBsbPuHO4fv7JRvfmPBMfp1ozWqOf/e4wwPNxezBZXRfWzMb6iFLgEVRA==", 445 | "dev": true 446 | }, 447 | "@types/node": { 448 | "version": "16.7.10", 449 | "resolved": "https://registry.npmjs.org/@types/node/-/node-16.7.10.tgz", 450 | "integrity": "sha512-S63Dlv4zIPb8x6MMTgDq5WWRJQe56iBEY0O3SOFA9JrRienkOVDXSXBjjJw6HTNQYSE2JI6GMCR6LVbIMHJVvA==", 451 | "dev": true 452 | }, 453 | "@types/redux-mock-store": { 454 | "version": "1.0.3", 455 | "resolved": "https://registry.npmjs.org/@types/redux-mock-store/-/redux-mock-store-1.0.3.tgz", 456 | "integrity": "sha512-Wqe3tJa6x9MxMN4DJnMfZoBRBRak1XTPklqj4qkVm5VBpZnC8PSADf4kLuFQ9NAdHaowfWoEeUMz7NWc2GMtnA==", 457 | "dev": true, 458 | "requires": { 459 | "redux": "^4.0.5" 460 | } 461 | }, 462 | "@typescript-eslint/eslint-plugin": { 463 | "version": "4.30.0", 464 | "resolved": "https://registry.npmjs.org/@typescript-eslint/eslint-plugin/-/eslint-plugin-4.30.0.tgz", 465 | "integrity": "sha512-NgAnqk55RQ/SD+tZFD9aPwNSeHmDHHe5rtUyhIq0ZeCWZEvo4DK9rYz7v9HDuQZFvn320Ot+AikaCKMFKLlD0g==", 466 | "dev": true, 467 | "requires": { 468 | "@typescript-eslint/experimental-utils": "4.30.0", 469 | "@typescript-eslint/scope-manager": "4.30.0", 470 | "debug": "^4.3.1", 471 | "functional-red-black-tree": "^1.0.1", 472 | "regexpp": "^3.1.0", 473 | "semver": "^7.3.5", 474 | "tsutils": "^3.21.0" 475 | }, 476 | "dependencies": { 477 | "debug": { 478 | "version": "4.3.2", 479 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.2.tgz", 480 | "integrity": "sha512-mOp8wKcvj7XxC78zLgw/ZA+6TSgkoE2C/ienthhRD298T7UNwAg9diBpLRxC0mOezLl4B0xV7M0cCO6P/O0Xhw==", 481 | "dev": true, 482 | "requires": { 483 | "ms": "2.1.2" 484 | } 485 | } 486 | } 487 | }, 488 | "@typescript-eslint/experimental-utils": { 489 | "version": "4.30.0", 490 | "resolved": "https://registry.npmjs.org/@typescript-eslint/experimental-utils/-/experimental-utils-4.30.0.tgz", 491 | "integrity": "sha512-K8RNIX9GnBsv5v4TjtwkKtqMSzYpjqAQg/oSphtxf3xxdt6T0owqnpojztjjTcatSteH3hLj3t/kklKx87NPqw==", 492 | "dev": true, 493 | "requires": { 494 | "@types/json-schema": "^7.0.7", 495 | "@typescript-eslint/scope-manager": "4.30.0", 496 | "@typescript-eslint/types": "4.30.0", 497 | "@typescript-eslint/typescript-estree": "4.30.0", 498 | "eslint-scope": "^5.1.1", 499 | "eslint-utils": "^3.0.0" 500 | } 501 | }, 502 | "@typescript-eslint/parser": { 503 | "version": "4.30.0", 504 | "resolved": "https://registry.npmjs.org/@typescript-eslint/parser/-/parser-4.30.0.tgz", 505 | "integrity": "sha512-HJ0XuluSZSxeboLU7Q2VQ6eLlCwXPBOGnA7CqgBnz2Db3JRQYyBDJgQnop6TZ+rsbSx5gEdWhw4rE4mDa1FnZg==", 506 | "dev": true, 507 | "requires": { 508 | "@typescript-eslint/scope-manager": "4.30.0", 509 | "@typescript-eslint/types": "4.30.0", 510 | "@typescript-eslint/typescript-estree": "4.30.0", 511 | "debug": "^4.3.1" 512 | }, 513 | "dependencies": { 514 | "debug": { 515 | "version": "4.3.2", 516 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.2.tgz", 517 | "integrity": "sha512-mOp8wKcvj7XxC78zLgw/ZA+6TSgkoE2C/ienthhRD298T7UNwAg9diBpLRxC0mOezLl4B0xV7M0cCO6P/O0Xhw==", 518 | "dev": true, 519 | "requires": { 520 | "ms": "2.1.2" 521 | } 522 | } 523 | } 524 | }, 525 | "@typescript-eslint/scope-manager": { 526 | "version": "4.30.0", 527 | "resolved": "https://registry.npmjs.org/@typescript-eslint/scope-manager/-/scope-manager-4.30.0.tgz", 528 | "integrity": "sha512-VJ/jAXovxNh7rIXCQbYhkyV2Y3Ac/0cVHP/FruTJSAUUm4Oacmn/nkN5zfWmWFEanN4ggP0vJSHOeajtHq3f8A==", 529 | "dev": true, 530 | "requires": { 531 | "@typescript-eslint/types": "4.30.0", 532 | "@typescript-eslint/visitor-keys": "4.30.0" 533 | } 534 | }, 535 | "@typescript-eslint/types": { 536 | "version": "4.30.0", 537 | "resolved": "https://registry.npmjs.org/@typescript-eslint/types/-/types-4.30.0.tgz", 538 | "integrity": "sha512-YKldqbNU9K4WpTNwBqtAerQKLLW/X2A/j4yw92e3ZJYLx+BpKLeheyzoPfzIXHfM8BXfoleTdiYwpsvVPvHrDw==", 539 | "dev": true 540 | }, 541 | "@typescript-eslint/typescript-estree": { 542 | "version": "4.30.0", 543 | "resolved": "https://registry.npmjs.org/@typescript-eslint/typescript-estree/-/typescript-estree-4.30.0.tgz", 544 | "integrity": "sha512-6WN7UFYvykr/U0Qgy4kz48iGPWILvYL34xXJxvDQeiRE018B7POspNRVtAZscWntEPZpFCx4hcz/XBT+erenfg==", 545 | "dev": true, 546 | "requires": { 547 | "@typescript-eslint/types": "4.30.0", 548 | "@typescript-eslint/visitor-keys": "4.30.0", 549 | "debug": "^4.3.1", 550 | "globby": "^11.0.3", 551 | "is-glob": "^4.0.1", 552 | "semver": "^7.3.5", 553 | "tsutils": "^3.21.0" 554 | }, 555 | "dependencies": { 556 | "debug": { 557 | "version": "4.3.2", 558 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.2.tgz", 559 | "integrity": "sha512-mOp8wKcvj7XxC78zLgw/ZA+6TSgkoE2C/ienthhRD298T7UNwAg9diBpLRxC0mOezLl4B0xV7M0cCO6P/O0Xhw==", 560 | "dev": true, 561 | "requires": { 562 | "ms": "2.1.2" 563 | } 564 | } 565 | } 566 | }, 567 | "@typescript-eslint/visitor-keys": { 568 | "version": "4.30.0", 569 | "resolved": "https://registry.npmjs.org/@typescript-eslint/visitor-keys/-/visitor-keys-4.30.0.tgz", 570 | "integrity": "sha512-pNaaxDt/Ol/+JZwzP7MqWc8PJQTUhZwoee/PVlQ+iYoYhagccvoHnC9e4l+C/krQYYkENxznhVSDwClIbZVxRw==", 571 | "dev": true, 572 | "requires": { 573 | "@typescript-eslint/types": "4.30.0", 574 | "eslint-visitor-keys": "^2.0.0" 575 | } 576 | }, 577 | "@ungap/promise-all-settled": { 578 | "version": "1.1.2", 579 | "resolved": "https://registry.npmjs.org/@ungap/promise-all-settled/-/promise-all-settled-1.1.2.tgz", 580 | "integrity": "sha512-sL/cEvJWAnClXw0wHk85/2L0G6Sj8UB0Ctc1TEMbKSsmpRosqhwj9gWgFRZSrBr2f9tiXISwNhCPmlfqUqyb9Q==", 581 | "dev": true 582 | }, 583 | "acorn": { 584 | "version": "7.4.1", 585 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-7.4.1.tgz", 586 | "integrity": "sha512-nQyp0o1/mNdbTO1PO6kHkwSrmgZ0MT/jCCpNiwbUjGoRN4dlBhqJtoQuCnEOKzgTVwg0ZWiCoQy6SxMebQVh8A==", 587 | "dev": true 588 | }, 589 | "acorn-jsx": { 590 | "version": "5.3.2", 591 | "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.3.2.tgz", 592 | "integrity": "sha512-rq9s+JNhf0IChjtDXxllJ7g41oZk5SlXtp0LHwyA5cejwn7vKmKp4pPri6YEePv2PU65sAsegbXtIinmDFDXgQ==", 593 | "dev": true 594 | }, 595 | "acorn-walk": { 596 | "version": "8.1.1", 597 | "resolved": "https://registry.npmjs.org/acorn-walk/-/acorn-walk-8.1.1.tgz", 598 | "integrity": "sha512-FbJdceMlPHEAWJOILDk1fXD8lnTlEIWFkqtfk+MvmL5q/qlHfN7GEHcsFZWt/Tea9jRNPWUZG4G976nqAAmU9w==", 599 | "dev": true 600 | }, 601 | "agent-base": { 602 | "version": "6.0.2", 603 | "resolved": "https://registry.npmjs.org/agent-base/-/agent-base-6.0.2.tgz", 604 | "integrity": "sha512-RZNwNclF7+MS/8bDg70amg32dyeZGZxiDuQmZxKLAlQjr3jGyLx+4Kkk58UO7D2QdgFIQCovuSuZESne6RG6XQ==", 605 | "dev": true, 606 | "requires": { 607 | "debug": "4" 608 | } 609 | }, 610 | "aggregate-error": { 611 | "version": "3.1.0", 612 | "resolved": "https://registry.npmjs.org/aggregate-error/-/aggregate-error-3.1.0.tgz", 613 | "integrity": "sha512-4I7Td01quW/RpocfNayFdFVk1qSuoh0E7JrbRJ16nH01HhKFQ88INq9Sd+nd72zqRySlr9BmDA8xlEJ6vJMrYA==", 614 | "dev": true, 615 | "requires": { 616 | "clean-stack": "^2.0.0", 617 | "indent-string": "^4.0.0" 618 | } 619 | }, 620 | "ajv": { 621 | "version": "6.12.6", 622 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.12.6.tgz", 623 | "integrity": "sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g==", 624 | "dev": true, 625 | "requires": { 626 | "fast-deep-equal": "^3.1.1", 627 | "fast-json-stable-stringify": "^2.0.0", 628 | "json-schema-traverse": "^0.4.1", 629 | "uri-js": "^4.2.2" 630 | } 631 | }, 632 | "ansi-colors": { 633 | "version": "4.1.1", 634 | "resolved": "https://registry.npmjs.org/ansi-colors/-/ansi-colors-4.1.1.tgz", 635 | "integrity": "sha512-JoX0apGbHaUJBNl6yF+p6JAFYZ666/hhCGKN5t9QFjbJQKUU/g8MNbFDbvfrgKXvI1QpZplPOnwIo99lX/AAmA==", 636 | "dev": true 637 | }, 638 | "ansi-regex": { 639 | "version": "5.0.0", 640 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.0.tgz", 641 | "integrity": "sha512-bY6fj56OUQ0hU1KjFNDQuJFezqKdrAyFdIevADiqrWHwSlbmBNMHp5ak2f40Pm8JTFyM2mqxkG6ngkHO11f/lg==", 642 | "dev": true 643 | }, 644 | "ansi-styles": { 645 | "version": "3.2.1", 646 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", 647 | "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", 648 | "dev": true, 649 | "requires": { 650 | "color-convert": "^1.9.0" 651 | } 652 | }, 653 | "anymatch": { 654 | "version": "3.1.2", 655 | "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.2.tgz", 656 | "integrity": "sha512-P43ePfOAIupkguHUycrc4qJ9kz8ZiuOUijaETwX7THt0Y/GNK7v0aa8rY816xWjZ7rJdA5XdMcpVFTKMq+RvWg==", 657 | "dev": true, 658 | "requires": { 659 | "normalize-path": "^3.0.0", 660 | "picomatch": "^2.0.4" 661 | } 662 | }, 663 | "append-transform": { 664 | "version": "2.0.0", 665 | "resolved": "https://registry.npmjs.org/append-transform/-/append-transform-2.0.0.tgz", 666 | "integrity": "sha512-7yeyCEurROLQJFv5Xj4lEGTy0borxepjFv1g22oAdqFu//SrAlDl1O1Nxx15SH1RoliUml6p8dwJW9jvZughhg==", 667 | "dev": true, 668 | "requires": { 669 | "default-require-extensions": "^3.0.0" 670 | } 671 | }, 672 | "archy": { 673 | "version": "1.0.0", 674 | "resolved": "https://registry.npmjs.org/archy/-/archy-1.0.0.tgz", 675 | "integrity": "sha1-+cjBN1fMHde8N5rHeyxipcKGjEA=", 676 | "dev": true 677 | }, 678 | "arg": { 679 | "version": "4.1.3", 680 | "resolved": "https://registry.npmjs.org/arg/-/arg-4.1.3.tgz", 681 | "integrity": "sha512-58S9QDqG0Xx27YwPSt9fJxivjYl432YCwfDMfZ+71RAqUrZef7LrKQZ3LHLOwCS4FLNBplP533Zx895SeOCHvA==", 682 | "dev": true 683 | }, 684 | "argparse": { 685 | "version": "1.0.10", 686 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-1.0.10.tgz", 687 | "integrity": "sha512-o5Roy6tNG4SL/FOkCAN6RzjiakZS25RLYFrcMttJqbdd8BWrnA+fGz57iN5Pb06pvBGvl5gQ0B48dJlslXvoTg==", 688 | "dev": true, 689 | "requires": { 690 | "sprintf-js": "~1.0.2" 691 | } 692 | }, 693 | "argv": { 694 | "version": "0.0.2", 695 | "resolved": "https://registry.npmjs.org/argv/-/argv-0.0.2.tgz", 696 | "integrity": "sha1-7L0W+JSbFXGDcRsb2jNPN4QBhas=", 697 | "dev": true 698 | }, 699 | "array-union": { 700 | "version": "2.1.0", 701 | "resolved": "https://registry.npmjs.org/array-union/-/array-union-2.1.0.tgz", 702 | "integrity": "sha512-HGyxoOTYUyCM6stUe6EJgnd4EoewAI7zMdfqO+kGjnlZmBDz/cR5pf8r/cR4Wq60sL/p0IkcjUEEPwS3GFrIyw==", 703 | "dev": true 704 | }, 705 | "assertion-error": { 706 | "version": "1.1.0", 707 | "resolved": "https://registry.npmjs.org/assertion-error/-/assertion-error-1.1.0.tgz", 708 | "integrity": "sha512-jgsaNduz+ndvGyFt3uSuWqvy4lCnIJiovtouQN5JZHOKCS2QuhEdbcQHFhVksz2N2U9hXJo8odG7ETyWlEeuDw==", 709 | "dev": true 710 | }, 711 | "astral-regex": { 712 | "version": "2.0.0", 713 | "resolved": "https://registry.npmjs.org/astral-regex/-/astral-regex-2.0.0.tgz", 714 | "integrity": "sha512-Z7tMw1ytTXt5jqMcOP+OQteU1VuNK9Y02uuJtKQ1Sv69jXQKKg5cibLwGJow8yzZP+eAc18EmLGPal0bp36rvQ==", 715 | "dev": true 716 | }, 717 | "balanced-match": { 718 | "version": "1.0.0", 719 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz", 720 | "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=", 721 | "dev": true 722 | }, 723 | "binary-extensions": { 724 | "version": "2.2.0", 725 | "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.2.0.tgz", 726 | "integrity": "sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA==", 727 | "dev": true 728 | }, 729 | "brace-expansion": { 730 | "version": "1.1.11", 731 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 732 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 733 | "dev": true, 734 | "requires": { 735 | "balanced-match": "^1.0.0", 736 | "concat-map": "0.0.1" 737 | } 738 | }, 739 | "braces": { 740 | "version": "3.0.2", 741 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", 742 | "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", 743 | "dev": true, 744 | "requires": { 745 | "fill-range": "^7.0.1" 746 | } 747 | }, 748 | "browser-stdout": { 749 | "version": "1.3.1", 750 | "resolved": "https://registry.npmjs.org/browser-stdout/-/browser-stdout-1.3.1.tgz", 751 | "integrity": "sha512-qhAVI1+Av2X7qelOfAIYwXONood6XlZE/fXaBSmW/T5SzLAmCgzi+eiWE7fUvbHaeNBQH13UftjpXxsfLkMpgw==", 752 | "dev": true 753 | }, 754 | "caching-transform": { 755 | "version": "4.0.0", 756 | "resolved": "https://registry.npmjs.org/caching-transform/-/caching-transform-4.0.0.tgz", 757 | "integrity": "sha512-kpqOvwXnjjN44D89K5ccQC+RUrsy7jB/XLlRrx0D7/2HNcTPqzsb6XgYoErwko6QsV184CA2YgS1fxDiiDZMWA==", 758 | "dev": true, 759 | "requires": { 760 | "hasha": "^5.0.0", 761 | "make-dir": "^3.0.0", 762 | "package-hash": "^4.0.0", 763 | "write-file-atomic": "^3.0.0" 764 | } 765 | }, 766 | "callsites": { 767 | "version": "3.1.0", 768 | "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz", 769 | "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==", 770 | "dev": true 771 | }, 772 | "camelcase": { 773 | "version": "5.3.1", 774 | "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-5.3.1.tgz", 775 | "integrity": "sha512-L28STB170nwWS63UjtlEOE3dldQApaJXZkOI1uMFfzf3rRuPegHaHesyee+YxQ+W6SvRDQV6UrdOdRiR153wJg==", 776 | "dev": true 777 | }, 778 | "chai": { 779 | "version": "4.3.4", 780 | "resolved": "https://registry.npmjs.org/chai/-/chai-4.3.4.tgz", 781 | "integrity": "sha512-yS5H68VYOCtN1cjfwumDSuzn/9c+yza4f3reKXlE5rUg7SFcCEy90gJvydNgOYtblyf4Zi6jIWRnXOgErta0KA==", 782 | "dev": true, 783 | "requires": { 784 | "assertion-error": "^1.1.0", 785 | "check-error": "^1.0.2", 786 | "deep-eql": "^3.0.1", 787 | "get-func-name": "^2.0.0", 788 | "pathval": "^1.1.1", 789 | "type-detect": "^4.0.5" 790 | } 791 | }, 792 | "chalk": { 793 | "version": "4.1.2", 794 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", 795 | "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", 796 | "dev": true, 797 | "requires": { 798 | "ansi-styles": "^4.1.0", 799 | "supports-color": "^7.1.0" 800 | }, 801 | "dependencies": { 802 | "ansi-styles": { 803 | "version": "4.3.0", 804 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 805 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 806 | "dev": true, 807 | "requires": { 808 | "color-convert": "^2.0.1" 809 | } 810 | }, 811 | "color-convert": { 812 | "version": "2.0.1", 813 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 814 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 815 | "dev": true, 816 | "requires": { 817 | "color-name": "~1.1.4" 818 | } 819 | }, 820 | "color-name": { 821 | "version": "1.1.4", 822 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 823 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 824 | "dev": true 825 | }, 826 | "has-flag": { 827 | "version": "4.0.0", 828 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 829 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", 830 | "dev": true 831 | }, 832 | "supports-color": { 833 | "version": "7.2.0", 834 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", 835 | "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", 836 | "dev": true, 837 | "requires": { 838 | "has-flag": "^4.0.0" 839 | } 840 | } 841 | } 842 | }, 843 | "check-error": { 844 | "version": "1.0.2", 845 | "resolved": "https://registry.npmjs.org/check-error/-/check-error-1.0.2.tgz", 846 | "integrity": "sha1-V00xLt2Iu13YkS6Sht1sCu1KrII=", 847 | "dev": true 848 | }, 849 | "chokidar": { 850 | "version": "3.5.2", 851 | "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.5.2.tgz", 852 | "integrity": "sha512-ekGhOnNVPgT77r4K/U3GDhu+FQ2S8TnK/s2KbIGXi0SZWuwkZ2QNyfWdZW+TVfn84DpEP7rLeCt2UI6bJ8GwbQ==", 853 | "dev": true, 854 | "requires": { 855 | "anymatch": "~3.1.2", 856 | "braces": "~3.0.2", 857 | "fsevents": "~2.3.2", 858 | "glob-parent": "~5.1.2", 859 | "is-binary-path": "~2.1.0", 860 | "is-glob": "~4.0.1", 861 | "normalize-path": "~3.0.0", 862 | "readdirp": "~3.6.0" 863 | } 864 | }, 865 | "clean-stack": { 866 | "version": "2.2.0", 867 | "resolved": "https://registry.npmjs.org/clean-stack/-/clean-stack-2.2.0.tgz", 868 | "integrity": "sha512-4diC9HaTE+KRAMWhDhrGOECgWZxoevMc5TlkObMqNSsVU62PYzXZ/SMTjzyGAFF1YusgxGcSWTEXBhp0CPwQ1A==", 869 | "dev": true 870 | }, 871 | "cliui": { 872 | "version": "7.0.4", 873 | "resolved": "https://registry.npmjs.org/cliui/-/cliui-7.0.4.tgz", 874 | "integrity": "sha512-OcRE68cOsVMXp1Yvonl/fzkQOyjLSu/8bhPDfQt0e0/Eb283TKP20Fs2MqoPsr9SwA595rRCA+QMzYc9nBP+JQ==", 875 | "dev": true, 876 | "requires": { 877 | "string-width": "^4.2.0", 878 | "strip-ansi": "^6.0.0", 879 | "wrap-ansi": "^7.0.0" 880 | } 881 | }, 882 | "codecov": { 883 | "version": "3.8.3", 884 | "resolved": "https://registry.npmjs.org/codecov/-/codecov-3.8.3.tgz", 885 | "integrity": "sha512-Y8Hw+V3HgR7V71xWH2vQ9lyS358CbGCldWlJFR0JirqoGtOoas3R3/OclRTvgUYFK29mmJICDPauVKmpqbwhOA==", 886 | "dev": true, 887 | "requires": { 888 | "argv": "0.0.2", 889 | "ignore-walk": "3.0.4", 890 | "js-yaml": "3.14.1", 891 | "teeny-request": "7.1.1", 892 | "urlgrey": "1.0.0" 893 | }, 894 | "dependencies": { 895 | "js-yaml": { 896 | "version": "3.14.1", 897 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.14.1.tgz", 898 | "integrity": "sha512-okMH7OXXJ7YrN9Ok3/SXrnu4iX9yOk+25nqX4imS2npuvTYDmo/QEZoqwZkYaIDk3jVvBOTOIEgEhaLOynBS9g==", 899 | "dev": true, 900 | "requires": { 901 | "argparse": "^1.0.7", 902 | "esprima": "^4.0.0" 903 | } 904 | } 905 | } 906 | }, 907 | "color-convert": { 908 | "version": "1.9.3", 909 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", 910 | "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", 911 | "dev": true, 912 | "requires": { 913 | "color-name": "1.1.3" 914 | } 915 | }, 916 | "color-name": { 917 | "version": "1.1.3", 918 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", 919 | "integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=", 920 | "dev": true 921 | }, 922 | "commander": { 923 | "version": "4.1.1", 924 | "resolved": "https://registry.npmjs.org/commander/-/commander-4.1.1.tgz", 925 | "integrity": "sha512-NOKm8xhkzAjzFx8B2v5OAHT+u5pRQc2UCa2Vq9jYL/31o2wi9mxBA7LIFs3sV5VSC49z6pEhfbMULvShKj26WA==", 926 | "dev": true 927 | }, 928 | "commondir": { 929 | "version": "1.0.1", 930 | "resolved": "https://registry.npmjs.org/commondir/-/commondir-1.0.1.tgz", 931 | "integrity": "sha1-3dgA2gxmEnOTzKWVDqloo6rxJTs=", 932 | "dev": true 933 | }, 934 | "concat-map": { 935 | "version": "0.0.1", 936 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 937 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=", 938 | "dev": true 939 | }, 940 | "convert-source-map": { 941 | "version": "1.7.0", 942 | "resolved": "https://registry.npmjs.org/convert-source-map/-/convert-source-map-1.7.0.tgz", 943 | "integrity": "sha512-4FJkXzKXEDB1snCFZlLP4gpC3JILicCpGbzG9f9G7tGqGCzETQ2hWPrcinA9oU4wtf2biUaEH5065UnMeR33oA==", 944 | "dev": true, 945 | "requires": { 946 | "safe-buffer": "~5.1.1" 947 | }, 948 | "dependencies": { 949 | "safe-buffer": { 950 | "version": "5.1.2", 951 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 952 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==", 953 | "dev": true 954 | } 955 | } 956 | }, 957 | "create-require": { 958 | "version": "1.1.1", 959 | "resolved": "https://registry.npmjs.org/create-require/-/create-require-1.1.1.tgz", 960 | "integrity": "sha512-dcKFX3jn0MpIaXjisoRvexIJVEKzaq7z2rZKxf+MSr9TkdmHmsU4m2lcLojrj/FHl8mk5VxMmYA+ftRkP/3oKQ==", 961 | "dev": true 962 | }, 963 | "cross-spawn": { 964 | "version": "7.0.3", 965 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz", 966 | "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==", 967 | "dev": true, 968 | "requires": { 969 | "path-key": "^3.1.0", 970 | "shebang-command": "^2.0.0", 971 | "which": "^2.0.1" 972 | } 973 | }, 974 | "debug": { 975 | "version": "4.2.0", 976 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.2.0.tgz", 977 | "integrity": "sha512-IX2ncY78vDTjZMFUdmsvIRFY2Cf4FnD0wRs+nQwJU8Lu99/tPFdb0VybiiMTPe3I6rQmwsqQqRBvxU+bZ/I8sg==", 978 | "dev": true, 979 | "requires": { 980 | "ms": "2.1.2" 981 | } 982 | }, 983 | "decamelize": { 984 | "version": "1.2.0", 985 | "resolved": "https://registry.npmjs.org/decamelize/-/decamelize-1.2.0.tgz", 986 | "integrity": "sha1-9lNNFRSCabIDUue+4m9QH5oZEpA=", 987 | "dev": true 988 | }, 989 | "deep-eql": { 990 | "version": "3.0.1", 991 | "resolved": "https://registry.npmjs.org/deep-eql/-/deep-eql-3.0.1.tgz", 992 | "integrity": "sha512-+QeIQyN5ZuO+3Uk5DYh6/1eKO0m0YmJFGNmFHGACpf1ClL1nmlV/p4gNgbl2pJGxgXb4faqo6UE+M5ACEMyVcw==", 993 | "dev": true, 994 | "requires": { 995 | "type-detect": "^4.0.0" 996 | } 997 | }, 998 | "deep-is": { 999 | "version": "0.1.4", 1000 | "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.4.tgz", 1001 | "integrity": "sha512-oIPzksmTg4/MriiaYGO+okXDT7ztn/w3Eptv/+gSIdMdKsJo0u4CfYNFJPy+4SKMuCqGw2wxnA+URMg3t8a/bQ==", 1002 | "dev": true 1003 | }, 1004 | "default-require-extensions": { 1005 | "version": "3.0.0", 1006 | "resolved": "https://registry.npmjs.org/default-require-extensions/-/default-require-extensions-3.0.0.tgz", 1007 | "integrity": "sha512-ek6DpXq/SCpvjhpFsLFRVtIxJCRw6fUR42lYMVZuUMK7n8eMz4Uh5clckdBjEpLhn/gEBZo7hDJnJcwdKLKQjg==", 1008 | "dev": true, 1009 | "requires": { 1010 | "strip-bom": "^4.0.0" 1011 | } 1012 | }, 1013 | "diff": { 1014 | "version": "5.0.0", 1015 | "resolved": "https://registry.npmjs.org/diff/-/diff-5.0.0.tgz", 1016 | "integrity": "sha512-/VTCrvm5Z0JGty/BWHljh+BAiw3IK+2j87NGMu8Nwc/f48WoDAC395uomO9ZD117ZOBaHmkX1oyLvkVM/aIT3w==", 1017 | "dev": true 1018 | }, 1019 | "dir-glob": { 1020 | "version": "3.0.1", 1021 | "resolved": "https://registry.npmjs.org/dir-glob/-/dir-glob-3.0.1.tgz", 1022 | "integrity": "sha512-WkrWp9GR4KXfKGYzOLmTuGVi1UWFfws377n9cc55/tb6DuqyF6pcQ5AbiHEshaDpY9v6oaSr2XCDidGmMwdzIA==", 1023 | "dev": true, 1024 | "requires": { 1025 | "path-type": "^4.0.0" 1026 | } 1027 | }, 1028 | "doctrine": { 1029 | "version": "3.0.0", 1030 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-3.0.0.tgz", 1031 | "integrity": "sha512-yS+Q5i3hBf7GBkd4KG8a7eBNNWNGLTaEwwYWUijIYM7zrlYDM0BFXHjjPWlWZ1Rg7UaddZeIDmi9jF3HmqiQ2w==", 1032 | "dev": true, 1033 | "requires": { 1034 | "esutils": "^2.0.2" 1035 | } 1036 | }, 1037 | "emoji-regex": { 1038 | "version": "8.0.0", 1039 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 1040 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", 1041 | "dev": true 1042 | }, 1043 | "enquirer": { 1044 | "version": "2.3.6", 1045 | "resolved": "https://registry.npmjs.org/enquirer/-/enquirer-2.3.6.tgz", 1046 | "integrity": "sha512-yjNnPr315/FjS4zIsUxYguYUPP2e1NK4d7E7ZOLiyYCcbFBiTMyID+2wvm2w6+pZ/odMA7cRkjhsPbltwBOrLg==", 1047 | "dev": true, 1048 | "requires": { 1049 | "ansi-colors": "^4.1.1" 1050 | } 1051 | }, 1052 | "env-cmd": { 1053 | "version": "10.1.0", 1054 | "resolved": "https://registry.npmjs.org/env-cmd/-/env-cmd-10.1.0.tgz", 1055 | "integrity": "sha512-mMdWTT9XKN7yNth/6N6g2GuKuJTsKMDHlQFUDacb/heQRRWOTIZ42t1rMHnQu4jYxU1ajdTeJM+9eEETlqToMA==", 1056 | "dev": true, 1057 | "requires": { 1058 | "commander": "^4.0.0", 1059 | "cross-spawn": "^7.0.0" 1060 | } 1061 | }, 1062 | "es6-error": { 1063 | "version": "4.1.1", 1064 | "resolved": "https://registry.npmjs.org/es6-error/-/es6-error-4.1.1.tgz", 1065 | "integrity": "sha512-Um/+FxMr9CISWh0bi5Zv0iOD+4cFh5qLeks1qhAopKVAJw3drgKbKySikp7wGhDL0HPeaja0P5ULZrxLkniUVg==", 1066 | "dev": true 1067 | }, 1068 | "escalade": { 1069 | "version": "3.1.1", 1070 | "resolved": "https://registry.npmjs.org/escalade/-/escalade-3.1.1.tgz", 1071 | "integrity": "sha512-k0er2gUkLf8O0zKJiAhmkTnJlTvINGv7ygDNPbeIsX/TJjGJZHuh9B2UxbsaEkmlEo9MfhrSzmhIlhRlI2GXnw==", 1072 | "dev": true 1073 | }, 1074 | "escape-string-regexp": { 1075 | "version": "1.0.5", 1076 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", 1077 | "integrity": "sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ=", 1078 | "dev": true 1079 | }, 1080 | "eslint": { 1081 | "version": "7.32.0", 1082 | "resolved": "https://registry.npmjs.org/eslint/-/eslint-7.32.0.tgz", 1083 | "integrity": "sha512-VHZ8gX+EDfz+97jGcgyGCyRia/dPOd6Xh9yPv8Bl1+SoaIwD+a/vlrOmGRUyOYu7MwUhc7CxqeaDZU13S4+EpA==", 1084 | "dev": true, 1085 | "requires": { 1086 | "@babel/code-frame": "7.12.11", 1087 | "@eslint/eslintrc": "^0.4.3", 1088 | "@humanwhocodes/config-array": "^0.5.0", 1089 | "ajv": "^6.10.0", 1090 | "chalk": "^4.0.0", 1091 | "cross-spawn": "^7.0.2", 1092 | "debug": "^4.0.1", 1093 | "doctrine": "^3.0.0", 1094 | "enquirer": "^2.3.5", 1095 | "escape-string-regexp": "^4.0.0", 1096 | "eslint-scope": "^5.1.1", 1097 | "eslint-utils": "^2.1.0", 1098 | "eslint-visitor-keys": "^2.0.0", 1099 | "espree": "^7.3.1", 1100 | "esquery": "^1.4.0", 1101 | "esutils": "^2.0.2", 1102 | "fast-deep-equal": "^3.1.3", 1103 | "file-entry-cache": "^6.0.1", 1104 | "functional-red-black-tree": "^1.0.1", 1105 | "glob-parent": "^5.1.2", 1106 | "globals": "^13.6.0", 1107 | "ignore": "^4.0.6", 1108 | "import-fresh": "^3.0.0", 1109 | "imurmurhash": "^0.1.4", 1110 | "is-glob": "^4.0.0", 1111 | "js-yaml": "^3.13.1", 1112 | "json-stable-stringify-without-jsonify": "^1.0.1", 1113 | "levn": "^0.4.1", 1114 | "lodash.merge": "^4.6.2", 1115 | "minimatch": "^3.0.4", 1116 | "natural-compare": "^1.4.0", 1117 | "optionator": "^0.9.1", 1118 | "progress": "^2.0.0", 1119 | "regexpp": "^3.1.0", 1120 | "semver": "^7.2.1", 1121 | "strip-ansi": "^6.0.0", 1122 | "strip-json-comments": "^3.1.0", 1123 | "table": "^6.0.9", 1124 | "text-table": "^0.2.0", 1125 | "v8-compile-cache": "^2.0.3" 1126 | }, 1127 | "dependencies": { 1128 | "@babel/code-frame": { 1129 | "version": "7.12.11", 1130 | "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.12.11.tgz", 1131 | "integrity": "sha512-Zt1yodBx1UcyiePMSkWnU4hPqhwq7hGi2nFL1LeA3EUl+q2LQx16MISgJ0+z7dnmgvP9QtIleuETGOiOH1RcIw==", 1132 | "dev": true, 1133 | "requires": { 1134 | "@babel/highlight": "^7.10.4" 1135 | } 1136 | }, 1137 | "escape-string-regexp": { 1138 | "version": "4.0.0", 1139 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", 1140 | "integrity": "sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA==", 1141 | "dev": true 1142 | }, 1143 | "eslint-utils": { 1144 | "version": "2.1.0", 1145 | "resolved": "https://registry.npmjs.org/eslint-utils/-/eslint-utils-2.1.0.tgz", 1146 | "integrity": "sha512-w94dQYoauyvlDc43XnGB8lU3Zt713vNChgt4EWwhXAP2XkBvndfxF0AgIqKOOasjPIPzj9JqgwkwbCYD0/V3Zg==", 1147 | "dev": true, 1148 | "requires": { 1149 | "eslint-visitor-keys": "^1.1.0" 1150 | }, 1151 | "dependencies": { 1152 | "eslint-visitor-keys": { 1153 | "version": "1.3.0", 1154 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-1.3.0.tgz", 1155 | "integrity": "sha512-6J72N8UNa462wa/KFODt/PJ3IU60SDpC3QXC1Hjc1BXXpfL2C9R5+AU7jhe0F6GREqVMh4Juu+NY7xn+6dipUQ==", 1156 | "dev": true 1157 | } 1158 | } 1159 | }, 1160 | "ignore": { 1161 | "version": "4.0.6", 1162 | "resolved": "https://registry.npmjs.org/ignore/-/ignore-4.0.6.tgz", 1163 | "integrity": "sha512-cyFDKrqc/YdcWFniJhzI42+AzS+gNwmUzOSFcRCQYwySuBBBy/KjuxWLZ/FHEH6Moq1NizMOBWyTcv8O4OZIMg==", 1164 | "dev": true 1165 | } 1166 | } 1167 | }, 1168 | "eslint-config-prettier": { 1169 | "version": "8.3.0", 1170 | "resolved": "https://registry.npmjs.org/eslint-config-prettier/-/eslint-config-prettier-8.3.0.tgz", 1171 | "integrity": "sha512-BgZuLUSeKzvlL/VUjx/Yb787VQ26RU3gGjA3iiFvdsp/2bMfVIWUVP7tjxtjS0e+HP409cPlPvNkQloz8C91ew==", 1172 | "dev": true 1173 | }, 1174 | "eslint-scope": { 1175 | "version": "5.1.1", 1176 | "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-5.1.1.tgz", 1177 | "integrity": "sha512-2NxwbF/hZ0KpepYN0cNbo+FN6XoK7GaHlQhgx/hIZl6Va0bF45RQOOwhLIy8lQDbuCiadSLCBnH2CFYquit5bw==", 1178 | "dev": true, 1179 | "requires": { 1180 | "esrecurse": "^4.3.0", 1181 | "estraverse": "^4.1.1" 1182 | } 1183 | }, 1184 | "eslint-utils": { 1185 | "version": "3.0.0", 1186 | "resolved": "https://registry.npmjs.org/eslint-utils/-/eslint-utils-3.0.0.tgz", 1187 | "integrity": "sha512-uuQC43IGctw68pJA1RgbQS8/NP7rch6Cwd4j3ZBtgo4/8Flj4eGE7ZYSZRN3iq5pVUv6GPdW5Z1RFleo84uLDA==", 1188 | "dev": true, 1189 | "requires": { 1190 | "eslint-visitor-keys": "^2.0.0" 1191 | } 1192 | }, 1193 | "eslint-visitor-keys": { 1194 | "version": "2.1.0", 1195 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-2.1.0.tgz", 1196 | "integrity": "sha512-0rSmRBzXgDzIsD6mGdJgevzgezI534Cer5L/vyMX0kHzT/jiB43jRhd9YUlMGYLQy2zprNmoT8qasCGtY+QaKw==", 1197 | "dev": true 1198 | }, 1199 | "espree": { 1200 | "version": "7.3.1", 1201 | "resolved": "https://registry.npmjs.org/espree/-/espree-7.3.1.tgz", 1202 | "integrity": "sha512-v3JCNCE64umkFpmkFGqzVKsOT0tN1Zr+ueqLZfpV1Ob8e+CEgPWa+OxCoGH3tnhimMKIaBm4m/vaRpJ/krRz2g==", 1203 | "dev": true, 1204 | "requires": { 1205 | "acorn": "^7.4.0", 1206 | "acorn-jsx": "^5.3.1", 1207 | "eslint-visitor-keys": "^1.3.0" 1208 | }, 1209 | "dependencies": { 1210 | "eslint-visitor-keys": { 1211 | "version": "1.3.0", 1212 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-1.3.0.tgz", 1213 | "integrity": "sha512-6J72N8UNa462wa/KFODt/PJ3IU60SDpC3QXC1Hjc1BXXpfL2C9R5+AU7jhe0F6GREqVMh4Juu+NY7xn+6dipUQ==", 1214 | "dev": true 1215 | } 1216 | } 1217 | }, 1218 | "esprima": { 1219 | "version": "4.0.1", 1220 | "resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.1.tgz", 1221 | "integrity": "sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A==", 1222 | "dev": true 1223 | }, 1224 | "esquery": { 1225 | "version": "1.4.0", 1226 | "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.4.0.tgz", 1227 | "integrity": "sha512-cCDispWt5vHHtwMY2YrAQ4ibFkAL8RbH5YGBnZBc90MolvvfkkQcJro/aZiAQUlQ3qgrYS6D6v8Gc5G5CQsc9w==", 1228 | "dev": true, 1229 | "requires": { 1230 | "estraverse": "^5.1.0" 1231 | }, 1232 | "dependencies": { 1233 | "estraverse": { 1234 | "version": "5.2.0", 1235 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.2.0.tgz", 1236 | "integrity": "sha512-BxbNGGNm0RyRYvUdHpIwv9IWzeM9XClbOxwoATuFdOE7ZE6wHL+HQ5T8hoPM+zHvmKzzsEqhgy0GrQ5X13afiQ==", 1237 | "dev": true 1238 | } 1239 | } 1240 | }, 1241 | "esrecurse": { 1242 | "version": "4.3.0", 1243 | "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.3.0.tgz", 1244 | "integrity": "sha512-KmfKL3b6G+RXvP8N1vr3Tq1kL/oCFgn2NYXEtqP8/L3pKapUA4G8cFVaoF3SU323CD4XypR/ffioHmkti6/Tag==", 1245 | "dev": true, 1246 | "requires": { 1247 | "estraverse": "^5.2.0" 1248 | }, 1249 | "dependencies": { 1250 | "estraverse": { 1251 | "version": "5.2.0", 1252 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.2.0.tgz", 1253 | "integrity": "sha512-BxbNGGNm0RyRYvUdHpIwv9IWzeM9XClbOxwoATuFdOE7ZE6wHL+HQ5T8hoPM+zHvmKzzsEqhgy0GrQ5X13afiQ==", 1254 | "dev": true 1255 | } 1256 | } 1257 | }, 1258 | "estraverse": { 1259 | "version": "4.3.0", 1260 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-4.3.0.tgz", 1261 | "integrity": "sha512-39nnKffWz8xN1BU/2c79n9nB9HDzo0niYUqx6xyqUnyoAnQyyWpOTdZEeiCch8BBu515t4wp9ZmgVfVhn9EBpw==", 1262 | "dev": true 1263 | }, 1264 | "esutils": { 1265 | "version": "2.0.3", 1266 | "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz", 1267 | "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==", 1268 | "dev": true 1269 | }, 1270 | "fast-deep-equal": { 1271 | "version": "3.1.3", 1272 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz", 1273 | "integrity": "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==", 1274 | "dev": true 1275 | }, 1276 | "fast-glob": { 1277 | "version": "3.2.7", 1278 | "resolved": "https://registry.npmjs.org/fast-glob/-/fast-glob-3.2.7.tgz", 1279 | "integrity": "sha512-rYGMRwip6lUMvYD3BTScMwT1HtAs2d71SMv66Vrxs0IekGZEjhM0pcMfjQPnknBt2zeCwQMEupiN02ZP4DiT1Q==", 1280 | "dev": true, 1281 | "requires": { 1282 | "@nodelib/fs.stat": "^2.0.2", 1283 | "@nodelib/fs.walk": "^1.2.3", 1284 | "glob-parent": "^5.1.2", 1285 | "merge2": "^1.3.0", 1286 | "micromatch": "^4.0.4" 1287 | } 1288 | }, 1289 | "fast-json-stable-stringify": { 1290 | "version": "2.1.0", 1291 | "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz", 1292 | "integrity": "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==", 1293 | "dev": true 1294 | }, 1295 | "fast-levenshtein": { 1296 | "version": "2.0.6", 1297 | "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", 1298 | "integrity": "sha1-PYpcZog6FqMMqGQ+hR8Zuqd5eRc=", 1299 | "dev": true 1300 | }, 1301 | "fast-url-parser": { 1302 | "version": "1.1.3", 1303 | "resolved": "https://registry.npmjs.org/fast-url-parser/-/fast-url-parser-1.1.3.tgz", 1304 | "integrity": "sha1-9K8+qfNNiicc9YrSs3WfQx8LMY0=", 1305 | "dev": true, 1306 | "requires": { 1307 | "punycode": "^1.3.2" 1308 | } 1309 | }, 1310 | "fastq": { 1311 | "version": "1.12.0", 1312 | "resolved": "https://registry.npmjs.org/fastq/-/fastq-1.12.0.tgz", 1313 | "integrity": "sha512-VNX0QkHK3RsXVKr9KrlUv/FoTa0NdbYoHHl7uXHv2rzyHSlxjdNAKug2twd9luJxpcyNeAgf5iPPMutJO67Dfg==", 1314 | "dev": true, 1315 | "requires": { 1316 | "reusify": "^1.0.4" 1317 | } 1318 | }, 1319 | "file-entry-cache": { 1320 | "version": "6.0.1", 1321 | "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-6.0.1.tgz", 1322 | "integrity": "sha512-7Gps/XWymbLk2QLYK4NzpMOrYjMhdIxXuIvy2QBsLE6ljuodKvdkWs/cpyJJ3CVIVpH0Oi1Hvg1ovbMzLdFBBg==", 1323 | "dev": true, 1324 | "requires": { 1325 | "flat-cache": "^3.0.4" 1326 | } 1327 | }, 1328 | "fill-range": { 1329 | "version": "7.0.1", 1330 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", 1331 | "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", 1332 | "dev": true, 1333 | "requires": { 1334 | "to-regex-range": "^5.0.1" 1335 | } 1336 | }, 1337 | "find-cache-dir": { 1338 | "version": "3.3.1", 1339 | "resolved": "https://registry.npmjs.org/find-cache-dir/-/find-cache-dir-3.3.1.tgz", 1340 | "integrity": "sha512-t2GDMt3oGC/v+BMwzmllWDuJF/xcDtE5j/fCGbqDD7OLuJkj0cfh1YSA5VKPvwMeLFLNDBkwOKZ2X85jGLVftQ==", 1341 | "dev": true, 1342 | "requires": { 1343 | "commondir": "^1.0.1", 1344 | "make-dir": "^3.0.2", 1345 | "pkg-dir": "^4.1.0" 1346 | } 1347 | }, 1348 | "find-up": { 1349 | "version": "5.0.0", 1350 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-5.0.0.tgz", 1351 | "integrity": "sha512-78/PXT1wlLLDgTzDs7sjq9hzz0vXD+zn+7wypEe4fXQxCmdmqfGsEPQxmiCSQI3ajFV91bVSsvNtrJRiW6nGng==", 1352 | "dev": true, 1353 | "requires": { 1354 | "locate-path": "^6.0.0", 1355 | "path-exists": "^4.0.0" 1356 | } 1357 | }, 1358 | "flat": { 1359 | "version": "5.0.2", 1360 | "resolved": "https://registry.npmjs.org/flat/-/flat-5.0.2.tgz", 1361 | "integrity": "sha512-b6suED+5/3rTpUBdG1gupIl8MPFCAMA0QXwmljLhvCUKcUvdE4gWky9zpuGCcXHOsz4J9wPGNWq6OKpmIzz3hQ==", 1362 | "dev": true 1363 | }, 1364 | "flat-cache": { 1365 | "version": "3.0.4", 1366 | "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-3.0.4.tgz", 1367 | "integrity": "sha512-dm9s5Pw7Jc0GvMYbshN6zchCA9RgQlzzEZX3vylR9IqFfS8XciblUXOKfW6SiuJ0e13eDYZoZV5wdrev7P3Nwg==", 1368 | "dev": true, 1369 | "requires": { 1370 | "flatted": "^3.1.0", 1371 | "rimraf": "^3.0.2" 1372 | } 1373 | }, 1374 | "flatted": { 1375 | "version": "3.2.2", 1376 | "resolved": "https://registry.npmjs.org/flatted/-/flatted-3.2.2.tgz", 1377 | "integrity": "sha512-JaTY/wtrcSyvXJl4IMFHPKyFur1sE9AUqc0QnhOaJ0CxHtAoIV8pYDzeEfAaNEtGkOfq4gr3LBFmdXW5mOQFnA==", 1378 | "dev": true 1379 | }, 1380 | "foreground-child": { 1381 | "version": "2.0.0", 1382 | "resolved": "https://registry.npmjs.org/foreground-child/-/foreground-child-2.0.0.tgz", 1383 | "integrity": "sha512-dCIq9FpEcyQyXKCkyzmlPTFNgrCzPudOe+mhvJU5zAtlBnGVy2yKxtfsxK2tQBThwq225jcvBjpw1Gr40uzZCA==", 1384 | "dev": true, 1385 | "requires": { 1386 | "cross-spawn": "^7.0.0", 1387 | "signal-exit": "^3.0.2" 1388 | } 1389 | }, 1390 | "fromentries": { 1391 | "version": "1.2.1", 1392 | "resolved": "https://registry.npmjs.org/fromentries/-/fromentries-1.2.1.tgz", 1393 | "integrity": "sha512-Xu2Qh8yqYuDhQGOhD5iJGninErSfI9A3FrriD3tjUgV5VbJFeH8vfgZ9HnC6jWN80QDVNQK5vmxRAmEAp7Mevw==", 1394 | "dev": true 1395 | }, 1396 | "fs.realpath": { 1397 | "version": "1.0.0", 1398 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 1399 | "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=", 1400 | "dev": true 1401 | }, 1402 | "fsevents": { 1403 | "version": "2.3.2", 1404 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.2.tgz", 1405 | "integrity": "sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA==", 1406 | "dev": true, 1407 | "optional": true 1408 | }, 1409 | "functional-red-black-tree": { 1410 | "version": "1.0.1", 1411 | "resolved": "https://registry.npmjs.org/functional-red-black-tree/-/functional-red-black-tree-1.0.1.tgz", 1412 | "integrity": "sha1-GwqzvVU7Kg1jmdKcDj6gslIHgyc=", 1413 | "dev": true 1414 | }, 1415 | "gensync": { 1416 | "version": "1.0.0-beta.1", 1417 | "resolved": "https://registry.npmjs.org/gensync/-/gensync-1.0.0-beta.1.tgz", 1418 | "integrity": "sha512-r8EC6NO1sngH/zdD9fiRDLdcgnbayXah+mLgManTaIZJqEC1MZstmnox8KpnI2/fxQwrp5OpCOYWLp4rBl4Jcg==", 1419 | "dev": true 1420 | }, 1421 | "get-caller-file": { 1422 | "version": "2.0.5", 1423 | "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-2.0.5.tgz", 1424 | "integrity": "sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg==", 1425 | "dev": true 1426 | }, 1427 | "get-func-name": { 1428 | "version": "2.0.0", 1429 | "resolved": "https://registry.npmjs.org/get-func-name/-/get-func-name-2.0.0.tgz", 1430 | "integrity": "sha1-6td0q+5y4gQJQzoGY2YCPdaIekE=", 1431 | "dev": true 1432 | }, 1433 | "get-package-type": { 1434 | "version": "0.1.0", 1435 | "resolved": "https://registry.npmjs.org/get-package-type/-/get-package-type-0.1.0.tgz", 1436 | "integrity": "sha512-pjzuKtY64GYfWizNAJ0fr9VqttZkNiK2iS430LtIHzjBEr6bX8Am2zm4sW4Ro5wjWW5cAlRL1qAMTcXbjNAO2Q==", 1437 | "dev": true 1438 | }, 1439 | "glob": { 1440 | "version": "7.1.6", 1441 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.6.tgz", 1442 | "integrity": "sha512-LwaxwyZ72Lk7vZINtNNrywX0ZuLyStrdDtabefZKAY5ZGJhVtgdznluResxNmPitE0SAO+O26sWTHeKSI2wMBA==", 1443 | "dev": true, 1444 | "requires": { 1445 | "fs.realpath": "^1.0.0", 1446 | "inflight": "^1.0.4", 1447 | "inherits": "2", 1448 | "minimatch": "^3.0.4", 1449 | "once": "^1.3.0", 1450 | "path-is-absolute": "^1.0.0" 1451 | } 1452 | }, 1453 | "glob-parent": { 1454 | "version": "5.1.2", 1455 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", 1456 | "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", 1457 | "dev": true, 1458 | "requires": { 1459 | "is-glob": "^4.0.1" 1460 | } 1461 | }, 1462 | "globals": { 1463 | "version": "13.11.0", 1464 | "resolved": "https://registry.npmjs.org/globals/-/globals-13.11.0.tgz", 1465 | "integrity": "sha512-08/xrJ7wQjK9kkkRoI3OFUBbLx4f+6x3SGwcPvQ0QH6goFDrOU2oyAWrmh3dJezu65buo+HBMzAMQy6rovVC3g==", 1466 | "dev": true, 1467 | "requires": { 1468 | "type-fest": "^0.20.2" 1469 | }, 1470 | "dependencies": { 1471 | "type-fest": { 1472 | "version": "0.20.2", 1473 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.20.2.tgz", 1474 | "integrity": "sha512-Ne+eE4r0/iWnpAxD852z3A+N0Bt5RN//NjJwRd2VFHEmrywxf5vsZlh4R6lixl6B+wz/8d+maTSAkN1FIkI3LQ==", 1475 | "dev": true 1476 | } 1477 | } 1478 | }, 1479 | "globby": { 1480 | "version": "11.0.4", 1481 | "resolved": "https://registry.npmjs.org/globby/-/globby-11.0.4.tgz", 1482 | "integrity": "sha512-9O4MVG9ioZJ08ffbcyVYyLOJLk5JQ688pJ4eMGLpdWLHq/Wr1D9BlriLQyL0E+jbkuePVZXYFj47QM/v093wHg==", 1483 | "dev": true, 1484 | "requires": { 1485 | "array-union": "^2.1.0", 1486 | "dir-glob": "^3.0.1", 1487 | "fast-glob": "^3.1.1", 1488 | "ignore": "^5.1.4", 1489 | "merge2": "^1.3.0", 1490 | "slash": "^3.0.0" 1491 | } 1492 | }, 1493 | "graceful-fs": { 1494 | "version": "4.2.4", 1495 | "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.4.tgz", 1496 | "integrity": "sha512-WjKPNJF79dtJAVniUlGGWHYGz2jWxT6VhN/4m1NdkbZ2nOsEF+cI1Edgql5zCRhs/VsQYRvrXctxktVXZUkixw==", 1497 | "dev": true 1498 | }, 1499 | "growl": { 1500 | "version": "1.10.5", 1501 | "resolved": "https://registry.npmjs.org/growl/-/growl-1.10.5.tgz", 1502 | "integrity": "sha512-qBr4OuELkhPenW6goKVXiv47US3clb3/IbuWF9KNKEijAy9oeHxU9IgzjvJhHkUzhaj7rOUD7+YGWqUjLp5oSA==", 1503 | "dev": true 1504 | }, 1505 | "has-flag": { 1506 | "version": "3.0.0", 1507 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 1508 | "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=", 1509 | "dev": true 1510 | }, 1511 | "hasha": { 1512 | "version": "5.2.0", 1513 | "resolved": "https://registry.npmjs.org/hasha/-/hasha-5.2.0.tgz", 1514 | "integrity": "sha512-2W+jKdQbAdSIrggA8Q35Br8qKadTrqCTC8+XZvBWepKDK6m9XkX6Iz1a2yh2KP01kzAR/dpuMeUnocoLYDcskw==", 1515 | "dev": true, 1516 | "requires": { 1517 | "is-stream": "^2.0.0", 1518 | "type-fest": "^0.8.0" 1519 | }, 1520 | "dependencies": { 1521 | "is-stream": { 1522 | "version": "2.0.0", 1523 | "resolved": "https://registry.npmjs.org/is-stream/-/is-stream-2.0.0.tgz", 1524 | "integrity": "sha512-XCoy+WlUr7d1+Z8GgSuXmpuUFC9fOhRXglJMx+dwLKTkL44Cjd4W1Z5P+BQZpr+cR93aGP4S/s7Ftw6Nd/kiEw==", 1525 | "dev": true 1526 | } 1527 | } 1528 | }, 1529 | "he": { 1530 | "version": "1.2.0", 1531 | "resolved": "https://registry.npmjs.org/he/-/he-1.2.0.tgz", 1532 | "integrity": "sha512-F/1DnUGPopORZi0ni+CvrCgHQ5FyEAHRLSApuYWMmrbSwoN2Mn/7k+Gl38gJnR7yyDZk6WLXwiGod1JOWNDKGw==", 1533 | "dev": true 1534 | }, 1535 | "html-escaper": { 1536 | "version": "2.0.2", 1537 | "resolved": "https://registry.npmjs.org/html-escaper/-/html-escaper-2.0.2.tgz", 1538 | "integrity": "sha512-H2iMtd0I4Mt5eYiapRdIDjp+XzelXQ0tFE4JS7YFwFevXXMmOp9myNrUvCg0D6ws8iqkRPBfKHgbwig1SmlLfg==", 1539 | "dev": true 1540 | }, 1541 | "http-proxy-agent": { 1542 | "version": "4.0.1", 1543 | "resolved": "https://registry.npmjs.org/http-proxy-agent/-/http-proxy-agent-4.0.1.tgz", 1544 | "integrity": "sha512-k0zdNgqWTGA6aeIRVpvfVob4fL52dTfaehylg0Y4UvSySvOq/Y+BOyPrgpUrA7HylqvU8vIZGsRuXmspskV0Tg==", 1545 | "dev": true, 1546 | "requires": { 1547 | "@tootallnate/once": "1", 1548 | "agent-base": "6", 1549 | "debug": "4" 1550 | } 1551 | }, 1552 | "https-proxy-agent": { 1553 | "version": "5.0.0", 1554 | "resolved": "https://registry.npmjs.org/https-proxy-agent/-/https-proxy-agent-5.0.0.tgz", 1555 | "integrity": "sha512-EkYm5BcKUGiduxzSt3Eppko+PiNWNEpa4ySk9vTC6wDsQJW9rHSa+UhGNJoRYp7bz6Ht1eaRIa6QaJqO5rCFbA==", 1556 | "dev": true, 1557 | "requires": { 1558 | "agent-base": "6", 1559 | "debug": "4" 1560 | } 1561 | }, 1562 | "ignore": { 1563 | "version": "5.1.8", 1564 | "resolved": "https://registry.npmjs.org/ignore/-/ignore-5.1.8.tgz", 1565 | "integrity": "sha512-BMpfD7PpiETpBl/A6S498BaIJ6Y/ABT93ETbby2fP00v4EbvPBXWEoaR1UBPKs3iR53pJY7EtZk5KACI57i1Uw==", 1566 | "dev": true 1567 | }, 1568 | "ignore-walk": { 1569 | "version": "3.0.4", 1570 | "resolved": "https://registry.npmjs.org/ignore-walk/-/ignore-walk-3.0.4.tgz", 1571 | "integrity": "sha512-PY6Ii8o1jMRA1z4F2hRkH/xN59ox43DavKvD3oDpfurRlOJyAHpifIwpbdv1n4jt4ov0jSpw3kQ4GhJnpBL6WQ==", 1572 | "dev": true, 1573 | "requires": { 1574 | "minimatch": "^3.0.4" 1575 | } 1576 | }, 1577 | "import-fresh": { 1578 | "version": "3.3.0", 1579 | "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.3.0.tgz", 1580 | "integrity": "sha512-veYYhQa+D1QBKznvhUHxb8faxlrwUnxseDAbAp457E0wLNio2bOSKnjYDhMj+YiAq61xrMGhQk9iXVk5FzgQMw==", 1581 | "dev": true, 1582 | "requires": { 1583 | "parent-module": "^1.0.0", 1584 | "resolve-from": "^4.0.0" 1585 | } 1586 | }, 1587 | "imurmurhash": { 1588 | "version": "0.1.4", 1589 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", 1590 | "integrity": "sha1-khi5srkoojixPcT7a21XbyMUU+o=", 1591 | "dev": true 1592 | }, 1593 | "indent-string": { 1594 | "version": "4.0.0", 1595 | "resolved": "https://registry.npmjs.org/indent-string/-/indent-string-4.0.0.tgz", 1596 | "integrity": "sha512-EdDDZu4A2OyIK7Lr/2zG+w5jmbuk1DVBnEwREQvBzspBJkCEbRa8GxU1lghYcaGJCnRWibjDXlq779X1/y5xwg==", 1597 | "dev": true 1598 | }, 1599 | "inflight": { 1600 | "version": "1.0.6", 1601 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 1602 | "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", 1603 | "dev": true, 1604 | "requires": { 1605 | "once": "^1.3.0", 1606 | "wrappy": "1" 1607 | } 1608 | }, 1609 | "inherits": { 1610 | "version": "2.0.4", 1611 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 1612 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", 1613 | "dev": true 1614 | }, 1615 | "is-binary-path": { 1616 | "version": "2.1.0", 1617 | "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz", 1618 | "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==", 1619 | "dev": true, 1620 | "requires": { 1621 | "binary-extensions": "^2.0.0" 1622 | } 1623 | }, 1624 | "is-extglob": { 1625 | "version": "2.1.1", 1626 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 1627 | "integrity": "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=", 1628 | "dev": true 1629 | }, 1630 | "is-fullwidth-code-point": { 1631 | "version": "3.0.0", 1632 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 1633 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", 1634 | "dev": true 1635 | }, 1636 | "is-glob": { 1637 | "version": "4.0.1", 1638 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.1.tgz", 1639 | "integrity": "sha512-5G0tKtBTFImOqDnLB2hG6Bp2qcKEFduo4tZu9MT/H6NQv/ghhy30o55ufafxJ/LdH79LLs2Kfrn85TLKyA7BUg==", 1640 | "dev": true, 1641 | "requires": { 1642 | "is-extglob": "^2.1.1" 1643 | } 1644 | }, 1645 | "is-number": { 1646 | "version": "7.0.0", 1647 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", 1648 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", 1649 | "dev": true 1650 | }, 1651 | "is-plain-obj": { 1652 | "version": "2.1.0", 1653 | "resolved": "https://registry.npmjs.org/is-plain-obj/-/is-plain-obj-2.1.0.tgz", 1654 | "integrity": "sha512-YWnfyRwxL/+SsrWYfOpUtz5b3YD+nyfkHvjbcanzk8zgyO4ASD67uVMRt8k5bM4lLMDnXfriRhOpemw+NfT1eA==", 1655 | "dev": true 1656 | }, 1657 | "is-typedarray": { 1658 | "version": "1.0.0", 1659 | "resolved": "https://registry.npmjs.org/is-typedarray/-/is-typedarray-1.0.0.tgz", 1660 | "integrity": "sha1-5HnICFjfDBsR3dppQPlgEfzaSpo=", 1661 | "dev": true 1662 | }, 1663 | "is-unicode-supported": { 1664 | "version": "0.1.0", 1665 | "resolved": "https://registry.npmjs.org/is-unicode-supported/-/is-unicode-supported-0.1.0.tgz", 1666 | "integrity": "sha512-knxG2q4UC3u8stRGyAVJCOdxFmv5DZiRcdlIaAQXAbSfJya+OhopNotLQrstBhququ4ZpuKbDc/8S6mgXgPFPw==", 1667 | "dev": true 1668 | }, 1669 | "is-windows": { 1670 | "version": "1.0.2", 1671 | "resolved": "https://registry.npmjs.org/is-windows/-/is-windows-1.0.2.tgz", 1672 | "integrity": "sha512-eXK1UInq2bPmjyX6e3VHIzMLobc4J94i4AWn+Hpq3OU5KkrRC96OAcR3PRJ/pGu6m8TRnBHP9dkXQVsT/COVIA==", 1673 | "dev": true 1674 | }, 1675 | "isexe": { 1676 | "version": "2.0.0", 1677 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 1678 | "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=", 1679 | "dev": true 1680 | }, 1681 | "istanbul-lib-coverage": { 1682 | "version": "3.0.0", 1683 | "resolved": "https://registry.npmjs.org/istanbul-lib-coverage/-/istanbul-lib-coverage-3.0.0.tgz", 1684 | "integrity": "sha512-UiUIqxMgRDET6eR+o5HbfRYP1l0hqkWOs7vNxC/mggutCMUIhWMm8gAHb8tHlyfD3/l6rlgNA5cKdDzEAf6hEg==", 1685 | "dev": true 1686 | }, 1687 | "istanbul-lib-hook": { 1688 | "version": "3.0.0", 1689 | "resolved": "https://registry.npmjs.org/istanbul-lib-hook/-/istanbul-lib-hook-3.0.0.tgz", 1690 | "integrity": "sha512-Pt/uge1Q9s+5VAZ+pCo16TYMWPBIl+oaNIjgLQxcX0itS6ueeaA+pEfThZpH8WxhFgCiEb8sAJY6MdUKgiIWaQ==", 1691 | "dev": true, 1692 | "requires": { 1693 | "append-transform": "^2.0.0" 1694 | } 1695 | }, 1696 | "istanbul-lib-instrument": { 1697 | "version": "4.0.3", 1698 | "resolved": "https://registry.npmjs.org/istanbul-lib-instrument/-/istanbul-lib-instrument-4.0.3.tgz", 1699 | "integrity": "sha512-BXgQl9kf4WTCPCCpmFGoJkz/+uhvm7h7PFKUYxh7qarQd3ER33vHG//qaE8eN25l07YqZPpHXU9I09l/RD5aGQ==", 1700 | "dev": true, 1701 | "requires": { 1702 | "@babel/core": "^7.7.5", 1703 | "@istanbuljs/schema": "^0.1.2", 1704 | "istanbul-lib-coverage": "^3.0.0", 1705 | "semver": "^6.3.0" 1706 | }, 1707 | "dependencies": { 1708 | "semver": { 1709 | "version": "6.3.0", 1710 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", 1711 | "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==", 1712 | "dev": true 1713 | } 1714 | } 1715 | }, 1716 | "istanbul-lib-processinfo": { 1717 | "version": "2.0.2", 1718 | "resolved": "https://registry.npmjs.org/istanbul-lib-processinfo/-/istanbul-lib-processinfo-2.0.2.tgz", 1719 | "integrity": "sha512-kOwpa7z9hme+IBPZMzQ5vdQj8srYgAtaRqeI48NGmAQ+/5yKiHLV0QbYqQpxsdEF0+w14SoB8YbnHKcXE2KnYw==", 1720 | "dev": true, 1721 | "requires": { 1722 | "archy": "^1.0.0", 1723 | "cross-spawn": "^7.0.0", 1724 | "istanbul-lib-coverage": "^3.0.0-alpha.1", 1725 | "make-dir": "^3.0.0", 1726 | "p-map": "^3.0.0", 1727 | "rimraf": "^3.0.0", 1728 | "uuid": "^3.3.3" 1729 | } 1730 | }, 1731 | "istanbul-lib-report": { 1732 | "version": "3.0.0", 1733 | "resolved": "https://registry.npmjs.org/istanbul-lib-report/-/istanbul-lib-report-3.0.0.tgz", 1734 | "integrity": "sha512-wcdi+uAKzfiGT2abPpKZ0hSU1rGQjUQnLvtY5MpQ7QCTahD3VODhcu4wcfY1YtkGaDD5yuydOLINXsfbus9ROw==", 1735 | "dev": true, 1736 | "requires": { 1737 | "istanbul-lib-coverage": "^3.0.0", 1738 | "make-dir": "^3.0.0", 1739 | "supports-color": "^7.1.0" 1740 | }, 1741 | "dependencies": { 1742 | "has-flag": { 1743 | "version": "4.0.0", 1744 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 1745 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", 1746 | "dev": true 1747 | }, 1748 | "supports-color": { 1749 | "version": "7.2.0", 1750 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", 1751 | "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", 1752 | "dev": true, 1753 | "requires": { 1754 | "has-flag": "^4.0.0" 1755 | } 1756 | } 1757 | } 1758 | }, 1759 | "istanbul-lib-source-maps": { 1760 | "version": "4.0.0", 1761 | "resolved": "https://registry.npmjs.org/istanbul-lib-source-maps/-/istanbul-lib-source-maps-4.0.0.tgz", 1762 | "integrity": "sha512-c16LpFRkR8vQXyHZ5nLpY35JZtzj1PQY1iZmesUbf1FZHbIupcWfjgOXBY9YHkLEQ6puz1u4Dgj6qmU/DisrZg==", 1763 | "dev": true, 1764 | "requires": { 1765 | "debug": "^4.1.1", 1766 | "istanbul-lib-coverage": "^3.0.0", 1767 | "source-map": "^0.6.1" 1768 | }, 1769 | "dependencies": { 1770 | "source-map": { 1771 | "version": "0.6.1", 1772 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", 1773 | "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", 1774 | "dev": true 1775 | } 1776 | } 1777 | }, 1778 | "istanbul-reports": { 1779 | "version": "3.0.2", 1780 | "resolved": "https://registry.npmjs.org/istanbul-reports/-/istanbul-reports-3.0.2.tgz", 1781 | "integrity": "sha512-9tZvz7AiR3PEDNGiV9vIouQ/EAcqMXFmkcA1CDFTwOB98OZVDL0PH9glHotf5Ugp6GCOTypfzGWI/OqjWNCRUw==", 1782 | "dev": true, 1783 | "requires": { 1784 | "html-escaper": "^2.0.0", 1785 | "istanbul-lib-report": "^3.0.0" 1786 | } 1787 | }, 1788 | "js-tokens": { 1789 | "version": "4.0.0", 1790 | "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", 1791 | "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==", 1792 | "dev": true 1793 | }, 1794 | "js-yaml": { 1795 | "version": "3.13.1", 1796 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.13.1.tgz", 1797 | "integrity": "sha512-YfbcO7jXDdyj0DGxYVSlSeQNHbD7XPWvrVWeVUujrQEoZzWJIRrCPoyk6kL6IAjAG2IolMK4T0hNUe0HOUs5Jw==", 1798 | "dev": true, 1799 | "requires": { 1800 | "argparse": "^1.0.7", 1801 | "esprima": "^4.0.0" 1802 | } 1803 | }, 1804 | "jsesc": { 1805 | "version": "2.5.2", 1806 | "resolved": "https://registry.npmjs.org/jsesc/-/jsesc-2.5.2.tgz", 1807 | "integrity": "sha512-OYu7XEzjkCQ3C5Ps3QIZsQfNpqoJyZZA99wd9aWd05NCtC5pWOkShK2mkL6HXQR6/Cy2lbNdPlZBpuQHXE63gA==", 1808 | "dev": true 1809 | }, 1810 | "json-schema-traverse": { 1811 | "version": "0.4.1", 1812 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", 1813 | "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==", 1814 | "dev": true 1815 | }, 1816 | "json-stable-stringify-without-jsonify": { 1817 | "version": "1.0.1", 1818 | "resolved": "https://registry.npmjs.org/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz", 1819 | "integrity": "sha1-nbe1lJatPzz+8wp1FC0tkwrXJlE=", 1820 | "dev": true 1821 | }, 1822 | "json5": { 1823 | "version": "2.1.3", 1824 | "resolved": "https://registry.npmjs.org/json5/-/json5-2.1.3.tgz", 1825 | "integrity": "sha512-KXPvOm8K9IJKFM0bmdn8QXh7udDh1g/giieX0NLCaMnb4hEiVFqnop2ImTXCc5e0/oHz3LTqmHGtExn5hfMkOA==", 1826 | "dev": true, 1827 | "requires": { 1828 | "minimist": "^1.2.5" 1829 | } 1830 | }, 1831 | "levn": { 1832 | "version": "0.4.1", 1833 | "resolved": "https://registry.npmjs.org/levn/-/levn-0.4.1.tgz", 1834 | "integrity": "sha512-+bT2uH4E5LGE7h/n3evcS/sQlJXCpIp6ym8OWJ5eV6+67Dsql/LaaT7qJBAt2rzfoa/5QBGBhxDix1dMt2kQKQ==", 1835 | "dev": true, 1836 | "requires": { 1837 | "prelude-ls": "^1.2.1", 1838 | "type-check": "~0.4.0" 1839 | } 1840 | }, 1841 | "locate-path": { 1842 | "version": "6.0.0", 1843 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-6.0.0.tgz", 1844 | "integrity": "sha512-iPZK6eYjbxRu3uB4/WZ3EsEIMJFMqAoopl3R+zuq0UjcAm/MO6KCweDgPfP3elTztoKP3KtnVHxTn2NHBSDVUw==", 1845 | "dev": true, 1846 | "requires": { 1847 | "p-locate": "^5.0.0" 1848 | } 1849 | }, 1850 | "lodash": { 1851 | "version": "4.17.21", 1852 | "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.21.tgz", 1853 | "integrity": "sha512-v2kDEe57lecTulaDIuNTPy3Ry4gLGJ6Z1O3vE1krgXZNrsQ+LFTGHVxVjcXPs17LhbZVGedAJv8XZ1tvj5FvSg==", 1854 | "dev": true 1855 | }, 1856 | "lodash.clonedeep": { 1857 | "version": "4.5.0", 1858 | "resolved": "https://registry.npmjs.org/lodash.clonedeep/-/lodash.clonedeep-4.5.0.tgz", 1859 | "integrity": "sha1-4j8/nE+Pvd6HJSnBBxhXoIblzO8=", 1860 | "dev": true 1861 | }, 1862 | "lodash.flattendeep": { 1863 | "version": "4.4.0", 1864 | "resolved": "https://registry.npmjs.org/lodash.flattendeep/-/lodash.flattendeep-4.4.0.tgz", 1865 | "integrity": "sha1-+wMJF/hqMTTlvJvsDWngAT3f7bI=", 1866 | "dev": true 1867 | }, 1868 | "lodash.isplainobject": { 1869 | "version": "4.0.6", 1870 | "resolved": "https://registry.npmjs.org/lodash.isplainobject/-/lodash.isplainobject-4.0.6.tgz", 1871 | "integrity": "sha1-fFJqUtibRcRcxpC4gWO+BJf1UMs=", 1872 | "dev": true 1873 | }, 1874 | "lodash.merge": { 1875 | "version": "4.6.2", 1876 | "resolved": "https://registry.npmjs.org/lodash.merge/-/lodash.merge-4.6.2.tgz", 1877 | "integrity": "sha512-0KpjqXRVvrYyCsX1swR/XTK0va6VQkQM6MNo7PqW77ByjAhoARA8EfrP1N4+KlKj8YS0ZUCtRT/YUuhyYDujIQ==", 1878 | "dev": true 1879 | }, 1880 | "lodash.truncate": { 1881 | "version": "4.4.2", 1882 | "resolved": "https://registry.npmjs.org/lodash.truncate/-/lodash.truncate-4.4.2.tgz", 1883 | "integrity": "sha1-WjUNoLERO4N+z//VgSy+WNbq4ZM=", 1884 | "dev": true 1885 | }, 1886 | "log-symbols": { 1887 | "version": "4.1.0", 1888 | "resolved": "https://registry.npmjs.org/log-symbols/-/log-symbols-4.1.0.tgz", 1889 | "integrity": "sha512-8XPvpAA8uyhfteu8pIvQxpJZ7SYYdpUivZpGy6sFsBuKRY/7rQGavedeB8aK+Zkyq6upMFVL/9AW6vOYzfRyLg==", 1890 | "dev": true, 1891 | "requires": { 1892 | "chalk": "^4.1.0", 1893 | "is-unicode-supported": "^0.1.0" 1894 | } 1895 | }, 1896 | "loose-envify": { 1897 | "version": "1.4.0", 1898 | "resolved": "https://registry.npmjs.org/loose-envify/-/loose-envify-1.4.0.tgz", 1899 | "integrity": "sha512-lyuxPGr/Wfhrlem2CL/UcnUc1zcqKAImBDzukY7Y5F/yQiNdko6+fRLevlw1HgMySw7f611UIY408EtxRSoK3Q==", 1900 | "dev": true, 1901 | "requires": { 1902 | "js-tokens": "^3.0.0 || ^4.0.0" 1903 | } 1904 | }, 1905 | "lru-cache": { 1906 | "version": "6.0.0", 1907 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", 1908 | "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", 1909 | "dev": true, 1910 | "requires": { 1911 | "yallist": "^4.0.0" 1912 | } 1913 | }, 1914 | "make-dir": { 1915 | "version": "3.1.0", 1916 | "resolved": "https://registry.npmjs.org/make-dir/-/make-dir-3.1.0.tgz", 1917 | "integrity": "sha512-g3FeP20LNwhALb/6Cz6Dd4F2ngze0jz7tbzrD2wAV+o9FeNHe4rL+yK2md0J/fiSf1sa1ADhXqi5+oVwOM/eGw==", 1918 | "dev": true, 1919 | "requires": { 1920 | "semver": "^6.0.0" 1921 | }, 1922 | "dependencies": { 1923 | "semver": { 1924 | "version": "6.3.0", 1925 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", 1926 | "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==", 1927 | "dev": true 1928 | } 1929 | } 1930 | }, 1931 | "make-error": { 1932 | "version": "1.3.6", 1933 | "resolved": "https://registry.npmjs.org/make-error/-/make-error-1.3.6.tgz", 1934 | "integrity": "sha512-s8UhlNe7vPKomQhC1qFelMokr/Sc3AgNbso3n74mVPA5LTZwkB9NlXf4XPamLxJE8h0gh73rM94xvwRT2CVInw==", 1935 | "dev": true 1936 | }, 1937 | "merge2": { 1938 | "version": "1.4.1", 1939 | "resolved": "https://registry.npmjs.org/merge2/-/merge2-1.4.1.tgz", 1940 | "integrity": "sha512-8q7VEgMJW4J8tcfVPy8g09NcQwZdbwFEqhe/WZkoIzjn/3TGDwtOCYtXGxA3O8tPzpczCCDgv+P2P5y00ZJOOg==", 1941 | "dev": true 1942 | }, 1943 | "micromatch": { 1944 | "version": "4.0.4", 1945 | "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-4.0.4.tgz", 1946 | "integrity": "sha512-pRmzw/XUcwXGpD9aI9q/0XOwLNygjETJ8y0ao0wdqprrzDa4YnxLcz7fQRZr8voh8V10kGhABbNcHVk5wHgWwg==", 1947 | "dev": true, 1948 | "requires": { 1949 | "braces": "^3.0.1", 1950 | "picomatch": "^2.2.3" 1951 | } 1952 | }, 1953 | "minimatch": { 1954 | "version": "3.0.4", 1955 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", 1956 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", 1957 | "dev": true, 1958 | "requires": { 1959 | "brace-expansion": "^1.1.7" 1960 | } 1961 | }, 1962 | "minimist": { 1963 | "version": "1.2.5", 1964 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.5.tgz", 1965 | "integrity": "sha512-FM9nNUYrRBAELZQT3xeZQ7fmMOBg6nWNmJKTcgsJeaLstP/UODVpGsr5OhXhhXg6f+qtJ8uiZ+PUxkDWcgIXLw==", 1966 | "dev": true 1967 | }, 1968 | "mocha": { 1969 | "version": "9.1.1", 1970 | "resolved": "https://registry.npmjs.org/mocha/-/mocha-9.1.1.tgz", 1971 | "integrity": "sha512-0wE74YMgOkCgBUj8VyIDwmLUjTsS13WV1Pg7l0SHea2qzZzlq7MDnfbPsHKcELBRk3+izEVkRofjmClpycudCA==", 1972 | "dev": true, 1973 | "requires": { 1974 | "@ungap/promise-all-settled": "1.1.2", 1975 | "ansi-colors": "4.1.1", 1976 | "browser-stdout": "1.3.1", 1977 | "chokidar": "3.5.2", 1978 | "debug": "4.3.1", 1979 | "diff": "5.0.0", 1980 | "escape-string-regexp": "4.0.0", 1981 | "find-up": "5.0.0", 1982 | "glob": "7.1.7", 1983 | "growl": "1.10.5", 1984 | "he": "1.2.0", 1985 | "js-yaml": "4.1.0", 1986 | "log-symbols": "4.1.0", 1987 | "minimatch": "3.0.4", 1988 | "ms": "2.1.3", 1989 | "nanoid": "3.1.23", 1990 | "serialize-javascript": "6.0.0", 1991 | "strip-json-comments": "3.1.1", 1992 | "supports-color": "8.1.1", 1993 | "which": "2.0.2", 1994 | "wide-align": "1.1.3", 1995 | "workerpool": "6.1.5", 1996 | "yargs": "16.2.0", 1997 | "yargs-parser": "20.2.4", 1998 | "yargs-unparser": "2.0.0" 1999 | }, 2000 | "dependencies": { 2001 | "argparse": { 2002 | "version": "2.0.1", 2003 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-2.0.1.tgz", 2004 | "integrity": "sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==", 2005 | "dev": true 2006 | }, 2007 | "debug": { 2008 | "version": "4.3.1", 2009 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.1.tgz", 2010 | "integrity": "sha512-doEwdvm4PCeK4K3RQN2ZC2BYUBaxwLARCqZmMjtF8a51J2Rb0xpVloFRnCODwqjpwnAoao4pelN8l3RJdv3gRQ==", 2011 | "dev": true, 2012 | "requires": { 2013 | "ms": "2.1.2" 2014 | }, 2015 | "dependencies": { 2016 | "ms": { 2017 | "version": "2.1.2", 2018 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 2019 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 2020 | "dev": true 2021 | } 2022 | } 2023 | }, 2024 | "escape-string-regexp": { 2025 | "version": "4.0.0", 2026 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", 2027 | "integrity": "sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA==", 2028 | "dev": true 2029 | }, 2030 | "glob": { 2031 | "version": "7.1.7", 2032 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.7.tgz", 2033 | "integrity": "sha512-OvD9ENzPLbegENnYP5UUfJIirTg4+XwMWGaQfQTY0JenxNvvIKP3U3/tAQSPIu/lHxXYSZmpXlUHeqAIdKzBLQ==", 2034 | "dev": true, 2035 | "requires": { 2036 | "fs.realpath": "^1.0.0", 2037 | "inflight": "^1.0.4", 2038 | "inherits": "2", 2039 | "minimatch": "^3.0.4", 2040 | "once": "^1.3.0", 2041 | "path-is-absolute": "^1.0.0" 2042 | } 2043 | }, 2044 | "has-flag": { 2045 | "version": "4.0.0", 2046 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 2047 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", 2048 | "dev": true 2049 | }, 2050 | "js-yaml": { 2051 | "version": "4.1.0", 2052 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-4.1.0.tgz", 2053 | "integrity": "sha512-wpxZs9NoxZaJESJGIZTyDEaYpl0FKSA+FB9aJiyemKhMwkxQg63h4T1KJgUGHpTqPDNRcmmYLugrRjJlBtWvRA==", 2054 | "dev": true, 2055 | "requires": { 2056 | "argparse": "^2.0.1" 2057 | } 2058 | }, 2059 | "ms": { 2060 | "version": "2.1.3", 2061 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", 2062 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==", 2063 | "dev": true 2064 | }, 2065 | "supports-color": { 2066 | "version": "8.1.1", 2067 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-8.1.1.tgz", 2068 | "integrity": "sha512-MpUEN2OodtUzxvKQl72cUF7RQ5EiHsGvSsVG0ia9c5RbWGL2CI4C7EpPS8UTBIplnlzZiNuV56w+FuNxy3ty2Q==", 2069 | "dev": true, 2070 | "requires": { 2071 | "has-flag": "^4.0.0" 2072 | } 2073 | } 2074 | } 2075 | }, 2076 | "ms": { 2077 | "version": "2.1.2", 2078 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 2079 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 2080 | "dev": true 2081 | }, 2082 | "nanoid": { 2083 | "version": "3.1.23", 2084 | "resolved": "https://registry.npmjs.org/nanoid/-/nanoid-3.1.23.tgz", 2085 | "integrity": "sha512-FiB0kzdP0FFVGDKlRLEQ1BgDzU87dy5NnzjeW9YZNt+/c3+q82EQDUwniSAUxp/F0gFNI1ZhKU1FqYsMuqZVnw==", 2086 | "dev": true 2087 | }, 2088 | "natural-compare": { 2089 | "version": "1.4.0", 2090 | "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", 2091 | "integrity": "sha1-Sr6/7tdUHywnrPspvbvRXI1bpPc=", 2092 | "dev": true 2093 | }, 2094 | "node-fetch": { 2095 | "version": "2.6.1", 2096 | "resolved": "https://registry.npmjs.org/node-fetch/-/node-fetch-2.6.1.tgz", 2097 | "integrity": "sha512-V4aYg89jEoVRxRb2fJdAg8FHvI7cEyYdVAh94HH0UIK8oJxUfkjlDQN9RbMx+bEjP7+ggMiFRprSti032Oipxw==", 2098 | "dev": true 2099 | }, 2100 | "node-preload": { 2101 | "version": "0.2.1", 2102 | "resolved": "https://registry.npmjs.org/node-preload/-/node-preload-0.2.1.tgz", 2103 | "integrity": "sha512-RM5oyBy45cLEoHqCeh+MNuFAxO0vTFBLskvQbOKnEE7YTTSN4tbN8QWDIPQ6L+WvKsB/qLEGpYe2ZZ9d4W9OIQ==", 2104 | "dev": true, 2105 | "requires": { 2106 | "process-on-spawn": "^1.0.0" 2107 | } 2108 | }, 2109 | "normalize-path": { 2110 | "version": "3.0.0", 2111 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", 2112 | "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==", 2113 | "dev": true 2114 | }, 2115 | "nyc": { 2116 | "version": "15.1.0", 2117 | "resolved": "https://registry.npmjs.org/nyc/-/nyc-15.1.0.tgz", 2118 | "integrity": "sha512-jMW04n9SxKdKi1ZMGhvUTHBN0EICCRkHemEoE5jm6mTYcqcdas0ATzgUgejlQUHMvpnOZqGB5Xxsv9KxJW1j8A==", 2119 | "dev": true, 2120 | "requires": { 2121 | "@istanbuljs/load-nyc-config": "^1.0.0", 2122 | "@istanbuljs/schema": "^0.1.2", 2123 | "caching-transform": "^4.0.0", 2124 | "convert-source-map": "^1.7.0", 2125 | "decamelize": "^1.2.0", 2126 | "find-cache-dir": "^3.2.0", 2127 | "find-up": "^4.1.0", 2128 | "foreground-child": "^2.0.0", 2129 | "get-package-type": "^0.1.0", 2130 | "glob": "^7.1.6", 2131 | "istanbul-lib-coverage": "^3.0.0", 2132 | "istanbul-lib-hook": "^3.0.0", 2133 | "istanbul-lib-instrument": "^4.0.0", 2134 | "istanbul-lib-processinfo": "^2.0.2", 2135 | "istanbul-lib-report": "^3.0.0", 2136 | "istanbul-lib-source-maps": "^4.0.0", 2137 | "istanbul-reports": "^3.0.2", 2138 | "make-dir": "^3.0.0", 2139 | "node-preload": "^0.2.1", 2140 | "p-map": "^3.0.0", 2141 | "process-on-spawn": "^1.0.0", 2142 | "resolve-from": "^5.0.0", 2143 | "rimraf": "^3.0.0", 2144 | "signal-exit": "^3.0.2", 2145 | "spawn-wrap": "^2.0.0", 2146 | "test-exclude": "^6.0.0", 2147 | "yargs": "^15.0.2" 2148 | }, 2149 | "dependencies": { 2150 | "ansi-styles": { 2151 | "version": "4.2.1", 2152 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.2.1.tgz", 2153 | "integrity": "sha512-9VGjrMsG1vePxcSweQsN20KY/c4zN0h9fLjqAbwbPfahM3t+NL+M9HC8xeXG2I8pX5NoamTGNuomEUFI7fcUjA==", 2154 | "dev": true, 2155 | "requires": { 2156 | "@types/color-name": "^1.1.1", 2157 | "color-convert": "^2.0.1" 2158 | } 2159 | }, 2160 | "cliui": { 2161 | "version": "6.0.0", 2162 | "resolved": "https://registry.npmjs.org/cliui/-/cliui-6.0.0.tgz", 2163 | "integrity": "sha512-t6wbgtoCXvAzst7QgXxJYqPt0usEfbgQdftEPbLL/cvv6HPE5VgvqCuAIDR0NgU52ds6rFwqrgakNLrHEjCbrQ==", 2164 | "dev": true, 2165 | "requires": { 2166 | "string-width": "^4.2.0", 2167 | "strip-ansi": "^6.0.0", 2168 | "wrap-ansi": "^6.2.0" 2169 | } 2170 | }, 2171 | "color-convert": { 2172 | "version": "2.0.1", 2173 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 2174 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 2175 | "dev": true, 2176 | "requires": { 2177 | "color-name": "~1.1.4" 2178 | } 2179 | }, 2180 | "color-name": { 2181 | "version": "1.1.4", 2182 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 2183 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 2184 | "dev": true 2185 | }, 2186 | "emoji-regex": { 2187 | "version": "8.0.0", 2188 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 2189 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", 2190 | "dev": true 2191 | }, 2192 | "find-up": { 2193 | "version": "4.1.0", 2194 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-4.1.0.tgz", 2195 | "integrity": "sha512-PpOwAdQ/YlXQ2vj8a3h8IipDuYRi3wceVQQGYWxNINccq40Anw7BlsEXCMbt1Zt+OLA6Fq9suIpIWD0OsnISlw==", 2196 | "dev": true, 2197 | "requires": { 2198 | "locate-path": "^5.0.0", 2199 | "path-exists": "^4.0.0" 2200 | } 2201 | }, 2202 | "is-fullwidth-code-point": { 2203 | "version": "3.0.0", 2204 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 2205 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", 2206 | "dev": true 2207 | }, 2208 | "locate-path": { 2209 | "version": "5.0.0", 2210 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-5.0.0.tgz", 2211 | "integrity": "sha512-t7hw9pI+WvuwNJXwk5zVHpyhIqzg2qTlklJOf0mVxGSbe3Fp2VieZcduNYjaLDoy6p9uGpQEGWG87WpMKlNq8g==", 2212 | "dev": true, 2213 | "requires": { 2214 | "p-locate": "^4.1.0" 2215 | } 2216 | }, 2217 | "p-limit": { 2218 | "version": "2.3.0", 2219 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-2.3.0.tgz", 2220 | "integrity": "sha512-//88mFWSJx8lxCzwdAABTJL2MyWB12+eIY7MDL2SqLmAkeKU9qxRvWuSyTjm3FUmpBEMuFfckAIqEaVGUDxb6w==", 2221 | "dev": true, 2222 | "requires": { 2223 | "p-try": "^2.0.0" 2224 | } 2225 | }, 2226 | "p-locate": { 2227 | "version": "4.1.0", 2228 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-4.1.0.tgz", 2229 | "integrity": "sha512-R79ZZ/0wAxKGu3oYMlz8jy/kbhsNrS7SKZ7PxEHBgJ5+F2mtFW2fK2cOtBh1cHYkQsbzFV7I+EoRKe6Yt0oK7A==", 2230 | "dev": true, 2231 | "requires": { 2232 | "p-limit": "^2.2.0" 2233 | } 2234 | }, 2235 | "resolve-from": { 2236 | "version": "5.0.0", 2237 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-5.0.0.tgz", 2238 | "integrity": "sha512-qYg9KP24dD5qka9J47d0aVky0N+b4fTU89LN9iDnjB5waksiC49rvMB0PrUJQGoTmH50XPiqOvAjDfaijGxYZw==", 2239 | "dev": true 2240 | }, 2241 | "string-width": { 2242 | "version": "4.2.0", 2243 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.0.tgz", 2244 | "integrity": "sha512-zUz5JD+tgqtuDjMhwIg5uFVV3dtqZ9yQJlZVfq4I01/K5Paj5UHj7VyrQOJvzawSVlKpObApbfD0Ed6yJc+1eg==", 2245 | "dev": true, 2246 | "requires": { 2247 | "emoji-regex": "^8.0.0", 2248 | "is-fullwidth-code-point": "^3.0.0", 2249 | "strip-ansi": "^6.0.0" 2250 | } 2251 | }, 2252 | "wrap-ansi": { 2253 | "version": "6.2.0", 2254 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-6.2.0.tgz", 2255 | "integrity": "sha512-r6lPcBGxZXlIcymEu7InxDMhdW0KDxpLgoFLcguasxCaJ/SOIZwINatK9KY/tf+ZrlywOKU0UDj3ATXUBfxJXA==", 2256 | "dev": true, 2257 | "requires": { 2258 | "ansi-styles": "^4.0.0", 2259 | "string-width": "^4.1.0", 2260 | "strip-ansi": "^6.0.0" 2261 | } 2262 | }, 2263 | "yargs": { 2264 | "version": "15.4.1", 2265 | "resolved": "https://registry.npmjs.org/yargs/-/yargs-15.4.1.tgz", 2266 | "integrity": "sha512-aePbxDmcYW++PaqBsJ+HYUFwCdv4LVvdnhBy78E57PIor8/OVvhMrADFFEDh8DHDFRv/O9i3lPhsENjO7QX0+A==", 2267 | "dev": true, 2268 | "requires": { 2269 | "cliui": "^6.0.0", 2270 | "decamelize": "^1.2.0", 2271 | "find-up": "^4.1.0", 2272 | "get-caller-file": "^2.0.1", 2273 | "require-directory": "^2.1.1", 2274 | "require-main-filename": "^2.0.0", 2275 | "set-blocking": "^2.0.0", 2276 | "string-width": "^4.2.0", 2277 | "which-module": "^2.0.0", 2278 | "y18n": "^4.0.0", 2279 | "yargs-parser": "^18.1.2" 2280 | } 2281 | }, 2282 | "yargs-parser": { 2283 | "version": "18.1.3", 2284 | "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-18.1.3.tgz", 2285 | "integrity": "sha512-o50j0JeToy/4K6OZcaQmW6lyXXKhq7csREXcDwk2omFPJEwUNOVtJKvmDr9EI1fAJZUyZcRF7kxGBWmRXudrCQ==", 2286 | "dev": true, 2287 | "requires": { 2288 | "camelcase": "^5.0.0", 2289 | "decamelize": "^1.2.0" 2290 | } 2291 | } 2292 | } 2293 | }, 2294 | "once": { 2295 | "version": "1.4.0", 2296 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 2297 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", 2298 | "dev": true, 2299 | "requires": { 2300 | "wrappy": "1" 2301 | } 2302 | }, 2303 | "optionator": { 2304 | "version": "0.9.1", 2305 | "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.9.1.tgz", 2306 | "integrity": "sha512-74RlY5FCnhq4jRxVUPKDaRwrVNXMqsGsiW6AJw4XK8hmtm10wC0ypZBLw5IIp85NZMr91+qd1RvvENwg7jjRFw==", 2307 | "dev": true, 2308 | "requires": { 2309 | "deep-is": "^0.1.3", 2310 | "fast-levenshtein": "^2.0.6", 2311 | "levn": "^0.4.1", 2312 | "prelude-ls": "^1.2.1", 2313 | "type-check": "^0.4.0", 2314 | "word-wrap": "^1.2.3" 2315 | } 2316 | }, 2317 | "p-limit": { 2318 | "version": "3.1.0", 2319 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-3.1.0.tgz", 2320 | "integrity": "sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ==", 2321 | "dev": true, 2322 | "requires": { 2323 | "yocto-queue": "^0.1.0" 2324 | } 2325 | }, 2326 | "p-locate": { 2327 | "version": "5.0.0", 2328 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-5.0.0.tgz", 2329 | "integrity": "sha512-LaNjtRWUBY++zB5nE/NwcaoMylSPk+S+ZHNB1TzdbMJMny6dynpAGt7X/tl/QYq3TIeE6nxHppbo2LGymrG5Pw==", 2330 | "dev": true, 2331 | "requires": { 2332 | "p-limit": "^3.0.2" 2333 | } 2334 | }, 2335 | "p-map": { 2336 | "version": "3.0.0", 2337 | "resolved": "https://registry.npmjs.org/p-map/-/p-map-3.0.0.tgz", 2338 | "integrity": "sha512-d3qXVTF/s+W+CdJ5A29wywV2n8CQQYahlgz2bFiA+4eVNJbHJodPZ+/gXwPGh0bOqA+j8S+6+ckmvLGPk1QpxQ==", 2339 | "dev": true, 2340 | "requires": { 2341 | "aggregate-error": "^3.0.0" 2342 | } 2343 | }, 2344 | "p-try": { 2345 | "version": "2.2.0", 2346 | "resolved": "https://registry.npmjs.org/p-try/-/p-try-2.2.0.tgz", 2347 | "integrity": "sha512-R4nPAVTAU0B9D35/Gk3uJf/7XYbQcyohSKdvAxIRSNghFl4e71hVoGnBNQz9cWaXxO2I10KTC+3jMdvvoKw6dQ==", 2348 | "dev": true 2349 | }, 2350 | "package-hash": { 2351 | "version": "4.0.0", 2352 | "resolved": "https://registry.npmjs.org/package-hash/-/package-hash-4.0.0.tgz", 2353 | "integrity": "sha512-whdkPIooSu/bASggZ96BWVvZTRMOFxnyUG5PnTSGKoJE2gd5mbVNmR2Nj20QFzxYYgAXpoqC+AiXzl+UMRh7zQ==", 2354 | "dev": true, 2355 | "requires": { 2356 | "graceful-fs": "^4.1.15", 2357 | "hasha": "^5.0.0", 2358 | "lodash.flattendeep": "^4.4.0", 2359 | "release-zalgo": "^1.0.0" 2360 | } 2361 | }, 2362 | "parent-module": { 2363 | "version": "1.0.1", 2364 | "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz", 2365 | "integrity": "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==", 2366 | "dev": true, 2367 | "requires": { 2368 | "callsites": "^3.0.0" 2369 | } 2370 | }, 2371 | "path-exists": { 2372 | "version": "4.0.0", 2373 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz", 2374 | "integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==", 2375 | "dev": true 2376 | }, 2377 | "path-is-absolute": { 2378 | "version": "1.0.1", 2379 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 2380 | "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=", 2381 | "dev": true 2382 | }, 2383 | "path-key": { 2384 | "version": "3.1.1", 2385 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", 2386 | "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", 2387 | "dev": true 2388 | }, 2389 | "path-parse": { 2390 | "version": "1.0.7", 2391 | "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.7.tgz", 2392 | "integrity": "sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw==", 2393 | "dev": true 2394 | }, 2395 | "path-type": { 2396 | "version": "4.0.0", 2397 | "resolved": "https://registry.npmjs.org/path-type/-/path-type-4.0.0.tgz", 2398 | "integrity": "sha512-gDKb8aZMDeD/tZWs9P6+q0J9Mwkdl6xMV8TjnGP3qJVJ06bdMgkbBlLU8IdfOsIsFz2BW1rNVT3XuNEl8zPAvw==", 2399 | "dev": true 2400 | }, 2401 | "pathval": { 2402 | "version": "1.1.1", 2403 | "resolved": "https://registry.npmjs.org/pathval/-/pathval-1.1.1.tgz", 2404 | "integrity": "sha512-Dp6zGqpTdETdR63lehJYPeIOqpiNBNtc7BpWSLrOje7UaIsE5aY92r/AunQA7rsXvet3lrJ3JnZX29UPTKXyKQ==", 2405 | "dev": true 2406 | }, 2407 | "picomatch": { 2408 | "version": "2.3.0", 2409 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.0.tgz", 2410 | "integrity": "sha512-lY1Q/PiJGC2zOv/z391WOTD+Z02bCgsFfvxoXXf6h7kv9o+WmsmzYqrAwY63sNgOxE4xEdq0WyUnXfKeBrSvYw==", 2411 | "dev": true 2412 | }, 2413 | "pkg-dir": { 2414 | "version": "4.2.0", 2415 | "resolved": "https://registry.npmjs.org/pkg-dir/-/pkg-dir-4.2.0.tgz", 2416 | "integrity": "sha512-HRDzbaKjC+AOWVXxAU/x54COGeIv9eb+6CkDSQoNTt4XyWoIJvuPsXizxu/Fr23EiekbtZwmh1IcIG/l/a10GQ==", 2417 | "dev": true, 2418 | "requires": { 2419 | "find-up": "^4.0.0" 2420 | }, 2421 | "dependencies": { 2422 | "find-up": { 2423 | "version": "4.1.0", 2424 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-4.1.0.tgz", 2425 | "integrity": "sha512-PpOwAdQ/YlXQ2vj8a3h8IipDuYRi3wceVQQGYWxNINccq40Anw7BlsEXCMbt1Zt+OLA6Fq9suIpIWD0OsnISlw==", 2426 | "dev": true, 2427 | "requires": { 2428 | "locate-path": "^5.0.0", 2429 | "path-exists": "^4.0.0" 2430 | } 2431 | }, 2432 | "locate-path": { 2433 | "version": "5.0.0", 2434 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-5.0.0.tgz", 2435 | "integrity": "sha512-t7hw9pI+WvuwNJXwk5zVHpyhIqzg2qTlklJOf0mVxGSbe3Fp2VieZcduNYjaLDoy6p9uGpQEGWG87WpMKlNq8g==", 2436 | "dev": true, 2437 | "requires": { 2438 | "p-locate": "^4.1.0" 2439 | } 2440 | }, 2441 | "p-limit": { 2442 | "version": "2.3.0", 2443 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-2.3.0.tgz", 2444 | "integrity": "sha512-//88mFWSJx8lxCzwdAABTJL2MyWB12+eIY7MDL2SqLmAkeKU9qxRvWuSyTjm3FUmpBEMuFfckAIqEaVGUDxb6w==", 2445 | "dev": true, 2446 | "requires": { 2447 | "p-try": "^2.0.0" 2448 | } 2449 | }, 2450 | "p-locate": { 2451 | "version": "4.1.0", 2452 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-4.1.0.tgz", 2453 | "integrity": "sha512-R79ZZ/0wAxKGu3oYMlz8jy/kbhsNrS7SKZ7PxEHBgJ5+F2mtFW2fK2cOtBh1cHYkQsbzFV7I+EoRKe6Yt0oK7A==", 2454 | "dev": true, 2455 | "requires": { 2456 | "p-limit": "^2.2.0" 2457 | } 2458 | } 2459 | } 2460 | }, 2461 | "prelude-ls": { 2462 | "version": "1.2.1", 2463 | "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.2.1.tgz", 2464 | "integrity": "sha512-vkcDPrRZo1QZLbn5RLGPpg/WmIQ65qoWWhcGKf/b5eplkkarX0m9z8ppCat4mlOqUsWpyNuYgO3VRyrYHSzX5g==", 2465 | "dev": true 2466 | }, 2467 | "prettier": { 2468 | "version": "2.3.2", 2469 | "resolved": "https://registry.npmjs.org/prettier/-/prettier-2.3.2.tgz", 2470 | "integrity": "sha512-lnJzDfJ66zkMy58OL5/NY5zp70S7Nz6KqcKkXYzn2tMVrNxvbqaBpg7H3qHaLxCJ5lNMsGuM8+ohS7cZrthdLQ==", 2471 | "dev": true 2472 | }, 2473 | "process-on-spawn": { 2474 | "version": "1.0.0", 2475 | "resolved": "https://registry.npmjs.org/process-on-spawn/-/process-on-spawn-1.0.0.tgz", 2476 | "integrity": "sha512-1WsPDsUSMmZH5LeMLegqkPDrsGgsWwk1Exipy2hvB0o/F0ASzbpIctSCcZIK1ykJvtTJULEH+20WOFjMvGnCTg==", 2477 | "dev": true, 2478 | "requires": { 2479 | "fromentries": "^1.2.0" 2480 | } 2481 | }, 2482 | "progress": { 2483 | "version": "2.0.3", 2484 | "resolved": "https://registry.npmjs.org/progress/-/progress-2.0.3.tgz", 2485 | "integrity": "sha512-7PiHtLll5LdnKIMw100I+8xJXR5gW2QwWYkT6iJva0bXitZKa/XMrSbdmg3r2Xnaidz9Qumd0VPaMrZlF9V9sA==", 2486 | "dev": true 2487 | }, 2488 | "punycode": { 2489 | "version": "1.4.1", 2490 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-1.4.1.tgz", 2491 | "integrity": "sha1-wNWmOycYgArY4esPpSachN1BhF4=", 2492 | "dev": true 2493 | }, 2494 | "queue-microtask": { 2495 | "version": "1.2.3", 2496 | "resolved": "https://registry.npmjs.org/queue-microtask/-/queue-microtask-1.2.3.tgz", 2497 | "integrity": "sha512-NuaNSa6flKT5JaSYQzJok04JzTL1CA6aGhv5rfLW3PgqA+M2ChpZQnAC8h8i4ZFkBS8X5RqkDBHA7r4hej3K9A==", 2498 | "dev": true 2499 | }, 2500 | "randombytes": { 2501 | "version": "2.1.0", 2502 | "resolved": "https://registry.npmjs.org/randombytes/-/randombytes-2.1.0.tgz", 2503 | "integrity": "sha512-vYl3iOX+4CKUWuxGi9Ukhie6fsqXqS9FE2Zaic4tNFD2N2QQaXOMFbuKK4QmDHC0JO6B1Zp41J0LpT0oR68amQ==", 2504 | "dev": true, 2505 | "requires": { 2506 | "safe-buffer": "^5.1.0" 2507 | } 2508 | }, 2509 | "readdirp": { 2510 | "version": "3.6.0", 2511 | "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.6.0.tgz", 2512 | "integrity": "sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==", 2513 | "dev": true, 2514 | "requires": { 2515 | "picomatch": "^2.2.1" 2516 | } 2517 | }, 2518 | "redux": { 2519 | "version": "4.0.5", 2520 | "resolved": "https://registry.npmjs.org/redux/-/redux-4.0.5.tgz", 2521 | "integrity": "sha512-VSz1uMAH24DM6MF72vcojpYPtrTUu3ByVWfPL1nPfVRb5mZVTve5GnNCUV53QM/BZ66xfWrm0CTWoM+Xlz8V1w==", 2522 | "dev": true, 2523 | "requires": { 2524 | "loose-envify": "^1.4.0", 2525 | "symbol-observable": "^1.2.0" 2526 | } 2527 | }, 2528 | "redux-mock-store": { 2529 | "version": "1.5.4", 2530 | "resolved": "https://registry.npmjs.org/redux-mock-store/-/redux-mock-store-1.5.4.tgz", 2531 | "integrity": "sha512-xmcA0O/tjCLXhh9Fuiq6pMrJCwFRaouA8436zcikdIpYWWCjU76CRk+i2bHx8EeiSiMGnB85/lZdU3wIJVXHTA==", 2532 | "dev": true, 2533 | "requires": { 2534 | "lodash.isplainobject": "^4.0.6" 2535 | } 2536 | }, 2537 | "redux-thunk": { 2538 | "version": "2.3.0", 2539 | "resolved": "https://registry.npmjs.org/redux-thunk/-/redux-thunk-2.3.0.tgz", 2540 | "integrity": "sha512-km6dclyFnmcvxhAcrQV2AkZmPQjzPDjgVlQtR0EQjxZPyJ0BnMf3in1ryuR8A2qU0HldVRfxYXbFSKlI3N7Slw==", 2541 | "dev": true 2542 | }, 2543 | "regexpp": { 2544 | "version": "3.2.0", 2545 | "resolved": "https://registry.npmjs.org/regexpp/-/regexpp-3.2.0.tgz", 2546 | "integrity": "sha512-pq2bWo9mVD43nbts2wGv17XLiNLya+GklZ8kaDLV2Z08gDCsGpnKn9BFMepvWuHCbyVvY7J5o5+BVvoQbmlJLg==", 2547 | "dev": true 2548 | }, 2549 | "release-zalgo": { 2550 | "version": "1.0.0", 2551 | "resolved": "https://registry.npmjs.org/release-zalgo/-/release-zalgo-1.0.0.tgz", 2552 | "integrity": "sha1-CXALflB0Mpc5Mw5TXFqQ+2eFFzA=", 2553 | "dev": true, 2554 | "requires": { 2555 | "es6-error": "^4.0.1" 2556 | } 2557 | }, 2558 | "require-directory": { 2559 | "version": "2.1.1", 2560 | "resolved": "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz", 2561 | "integrity": "sha1-jGStX9MNqxyXbiNE/+f3kqam30I=", 2562 | "dev": true 2563 | }, 2564 | "require-from-string": { 2565 | "version": "2.0.2", 2566 | "resolved": "https://registry.npmjs.org/require-from-string/-/require-from-string-2.0.2.tgz", 2567 | "integrity": "sha512-Xf0nWe6RseziFMu+Ap9biiUbmplq6S9/p+7w7YXP/JBHhrUDDUhwa+vANyubuqfZWTveU//DYVGsDG7RKL/vEw==", 2568 | "dev": true 2569 | }, 2570 | "require-main-filename": { 2571 | "version": "2.0.0", 2572 | "resolved": "https://registry.npmjs.org/require-main-filename/-/require-main-filename-2.0.0.tgz", 2573 | "integrity": "sha512-NKN5kMDylKuldxYLSUfrbo5Tuzh4hd+2E8NPPX02mZtn1VuREQToYe/ZdlJy+J3uCpfaiGF05e7B8W0iXbQHmg==", 2574 | "dev": true 2575 | }, 2576 | "resolve": { 2577 | "version": "1.17.0", 2578 | "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.17.0.tgz", 2579 | "integrity": "sha512-ic+7JYiV8Vi2yzQGFWOkiZD5Z9z7O2Zhm9XMaTxdJExKasieFCr+yXZ/WmXsckHiKl12ar0y6XiXDx3m4RHn1w==", 2580 | "dev": true, 2581 | "requires": { 2582 | "path-parse": "^1.0.6" 2583 | } 2584 | }, 2585 | "resolve-from": { 2586 | "version": "4.0.0", 2587 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz", 2588 | "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==", 2589 | "dev": true 2590 | }, 2591 | "reusify": { 2592 | "version": "1.0.4", 2593 | "resolved": "https://registry.npmjs.org/reusify/-/reusify-1.0.4.tgz", 2594 | "integrity": "sha512-U9nH88a3fc/ekCF1l0/UP1IosiuIjyTh7hBvXVMHYgVcfGvt897Xguj2UOLDeI5BG2m7/uwyaLVT6fbtCwTyzw==", 2595 | "dev": true 2596 | }, 2597 | "rimraf": { 2598 | "version": "3.0.2", 2599 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-3.0.2.tgz", 2600 | "integrity": "sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA==", 2601 | "dev": true, 2602 | "requires": { 2603 | "glob": "^7.1.3" 2604 | } 2605 | }, 2606 | "run-parallel": { 2607 | "version": "1.2.0", 2608 | "resolved": "https://registry.npmjs.org/run-parallel/-/run-parallel-1.2.0.tgz", 2609 | "integrity": "sha512-5l4VyZR86LZ/lDxZTR6jqL8AFE2S0IFLMP26AbjsLVADxHdhB/c0GUsH+y39UfCi3dzz8OlQuPmnaJOMoDHQBA==", 2610 | "dev": true, 2611 | "requires": { 2612 | "queue-microtask": "^1.2.2" 2613 | } 2614 | }, 2615 | "safe-buffer": { 2616 | "version": "5.2.1", 2617 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz", 2618 | "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==", 2619 | "dev": true 2620 | }, 2621 | "semver": { 2622 | "version": "7.3.5", 2623 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.3.5.tgz", 2624 | "integrity": "sha512-PoeGJYh8HK4BTO/a9Tf6ZG3veo/A7ZVsYrSA6J8ny9nb3B1VrpkuN+z9OE5wfE5p6H4LchYZsegiQgbJD94ZFQ==", 2625 | "dev": true, 2626 | "requires": { 2627 | "lru-cache": "^6.0.0" 2628 | } 2629 | }, 2630 | "serialize-javascript": { 2631 | "version": "6.0.0", 2632 | "resolved": "https://registry.npmjs.org/serialize-javascript/-/serialize-javascript-6.0.0.tgz", 2633 | "integrity": "sha512-Qr3TosvguFt8ePWqsvRfrKyQXIiW+nGbYpy8XK24NQHE83caxWt+mIymTT19DGFbNWNLfEwsrkSmN64lVWB9ag==", 2634 | "dev": true, 2635 | "requires": { 2636 | "randombytes": "^2.1.0" 2637 | } 2638 | }, 2639 | "set-blocking": { 2640 | "version": "2.0.0", 2641 | "resolved": "https://registry.npmjs.org/set-blocking/-/set-blocking-2.0.0.tgz", 2642 | "integrity": "sha1-BF+XgtARrppoA93TgrJDkrPYkPc=", 2643 | "dev": true 2644 | }, 2645 | "shebang-command": { 2646 | "version": "2.0.0", 2647 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", 2648 | "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", 2649 | "dev": true, 2650 | "requires": { 2651 | "shebang-regex": "^3.0.0" 2652 | } 2653 | }, 2654 | "shebang-regex": { 2655 | "version": "3.0.0", 2656 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", 2657 | "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", 2658 | "dev": true 2659 | }, 2660 | "signal-exit": { 2661 | "version": "3.0.3", 2662 | "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.3.tgz", 2663 | "integrity": "sha512-VUJ49FC8U1OxwZLxIbTTrDvLnf/6TDgxZcK8wxR8zs13xpx7xbG60ndBlhNrFi2EMuFRoeDoJO7wthSLq42EjA==", 2664 | "dev": true 2665 | }, 2666 | "slash": { 2667 | "version": "3.0.0", 2668 | "resolved": "https://registry.npmjs.org/slash/-/slash-3.0.0.tgz", 2669 | "integrity": "sha512-g9Q1haeby36OSStwb4ntCGGGaKsaVSjQ68fBxoQcutl5fS1vuY18H3wSt3jFyFtrkx+Kz0V1G85A4MyAdDMi2Q==", 2670 | "dev": true 2671 | }, 2672 | "slice-ansi": { 2673 | "version": "4.0.0", 2674 | "resolved": "https://registry.npmjs.org/slice-ansi/-/slice-ansi-4.0.0.tgz", 2675 | "integrity": "sha512-qMCMfhY040cVHT43K9BFygqYbUPFZKHOg7K73mtTWJRb8pyP3fzf4Ixd5SzdEJQ6MRUg/WBnOLxghZtKKurENQ==", 2676 | "dev": true, 2677 | "requires": { 2678 | "ansi-styles": "^4.0.0", 2679 | "astral-regex": "^2.0.0", 2680 | "is-fullwidth-code-point": "^3.0.0" 2681 | }, 2682 | "dependencies": { 2683 | "ansi-styles": { 2684 | "version": "4.3.0", 2685 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 2686 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 2687 | "dev": true, 2688 | "requires": { 2689 | "color-convert": "^2.0.1" 2690 | } 2691 | }, 2692 | "color-convert": { 2693 | "version": "2.0.1", 2694 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 2695 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 2696 | "dev": true, 2697 | "requires": { 2698 | "color-name": "~1.1.4" 2699 | } 2700 | }, 2701 | "color-name": { 2702 | "version": "1.1.4", 2703 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 2704 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 2705 | "dev": true 2706 | } 2707 | } 2708 | }, 2709 | "source-map": { 2710 | "version": "0.5.7", 2711 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.5.7.tgz", 2712 | "integrity": "sha1-igOdLRAh0i0eoUyA2OpGi6LvP8w=", 2713 | "dev": true 2714 | }, 2715 | "spawn-wrap": { 2716 | "version": "2.0.0", 2717 | "resolved": "https://registry.npmjs.org/spawn-wrap/-/spawn-wrap-2.0.0.tgz", 2718 | "integrity": "sha512-EeajNjfN9zMnULLwhZZQU3GWBoFNkbngTUPfaawT4RkMiviTxcX0qfhVbGey39mfctfDHkWtuecgQ8NJcyQWHg==", 2719 | "dev": true, 2720 | "requires": { 2721 | "foreground-child": "^2.0.0", 2722 | "is-windows": "^1.0.2", 2723 | "make-dir": "^3.0.0", 2724 | "rimraf": "^3.0.0", 2725 | "signal-exit": "^3.0.2", 2726 | "which": "^2.0.1" 2727 | } 2728 | }, 2729 | "sprintf-js": { 2730 | "version": "1.0.3", 2731 | "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.0.3.tgz", 2732 | "integrity": "sha1-BOaSb2YolTVPPdAVIDYzuFcpfiw=", 2733 | "dev": true 2734 | }, 2735 | "stream-events": { 2736 | "version": "1.0.5", 2737 | "resolved": "https://registry.npmjs.org/stream-events/-/stream-events-1.0.5.tgz", 2738 | "integrity": "sha512-E1GUzBSgvct8Jsb3v2X15pjzN1tYebtbLaMg+eBOUOAxgbLoSbT2NS91ckc5lJD1KfLjId+jXJRgo0qnV5Nerg==", 2739 | "dev": true, 2740 | "requires": { 2741 | "stubs": "^3.0.0" 2742 | } 2743 | }, 2744 | "string-width": { 2745 | "version": "4.2.2", 2746 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.2.tgz", 2747 | "integrity": "sha512-XBJbT3N4JhVumXE0eoLU9DCjcaF92KLNqTmFCnG1pf8duUxFGwtP6AD6nkjw9a3IdiRtL3E2w3JDiE/xi3vOeA==", 2748 | "dev": true, 2749 | "requires": { 2750 | "emoji-regex": "^8.0.0", 2751 | "is-fullwidth-code-point": "^3.0.0", 2752 | "strip-ansi": "^6.0.0" 2753 | } 2754 | }, 2755 | "strip-ansi": { 2756 | "version": "6.0.0", 2757 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.0.tgz", 2758 | "integrity": "sha512-AuvKTrTfQNYNIctbR1K/YGTR1756GycPsg7b9bdV9Duqur4gv6aKqHXah67Z8ImS7WEz5QVcOtlfW2rZEugt6w==", 2759 | "dev": true, 2760 | "requires": { 2761 | "ansi-regex": "^5.0.0" 2762 | } 2763 | }, 2764 | "strip-bom": { 2765 | "version": "4.0.0", 2766 | "resolved": "https://registry.npmjs.org/strip-bom/-/strip-bom-4.0.0.tgz", 2767 | "integrity": "sha512-3xurFv5tEgii33Zi8Jtp55wEIILR9eh34FAW00PZf+JnSsTmV/ioewSgQl97JHvgjoRGwPShsWm+IdrxB35d0w==", 2768 | "dev": true 2769 | }, 2770 | "strip-json-comments": { 2771 | "version": "3.1.1", 2772 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz", 2773 | "integrity": "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==", 2774 | "dev": true 2775 | }, 2776 | "stubs": { 2777 | "version": "3.0.0", 2778 | "resolved": "https://registry.npmjs.org/stubs/-/stubs-3.0.0.tgz", 2779 | "integrity": "sha1-6NK6H6nJBXAwPAMLaQD31fiavls=", 2780 | "dev": true 2781 | }, 2782 | "supports-color": { 2783 | "version": "5.5.0", 2784 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 2785 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 2786 | "dev": true, 2787 | "requires": { 2788 | "has-flag": "^3.0.0" 2789 | } 2790 | }, 2791 | "symbol-observable": { 2792 | "version": "1.2.0", 2793 | "resolved": "https://registry.npmjs.org/symbol-observable/-/symbol-observable-1.2.0.tgz", 2794 | "integrity": "sha512-e900nM8RRtGhlV36KGEU9k65K3mPb1WV70OdjfxlG2EAuM1noi/E/BaW/uMhL7bPEssK8QV57vN3esixjUvcXQ==", 2795 | "dev": true 2796 | }, 2797 | "table": { 2798 | "version": "6.7.1", 2799 | "resolved": "https://registry.npmjs.org/table/-/table-6.7.1.tgz", 2800 | "integrity": "sha512-ZGum47Yi6KOOFDE8m223td53ath2enHcYLgOCjGr5ngu8bdIARQk6mN/wRMv4yMRcHnCSnHbCEha4sobQx5yWg==", 2801 | "dev": true, 2802 | "requires": { 2803 | "ajv": "^8.0.1", 2804 | "lodash.clonedeep": "^4.5.0", 2805 | "lodash.truncate": "^4.4.2", 2806 | "slice-ansi": "^4.0.0", 2807 | "string-width": "^4.2.0", 2808 | "strip-ansi": "^6.0.0" 2809 | }, 2810 | "dependencies": { 2811 | "ajv": { 2812 | "version": "8.6.2", 2813 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-8.6.2.tgz", 2814 | "integrity": "sha512-9807RlWAgT564wT+DjeyU5OFMPjmzxVobvDFmNAhY+5zD6A2ly3jDp6sgnfyDtlIQ+7H97oc/DGCzzfu9rjw9w==", 2815 | "dev": true, 2816 | "requires": { 2817 | "fast-deep-equal": "^3.1.1", 2818 | "json-schema-traverse": "^1.0.0", 2819 | "require-from-string": "^2.0.2", 2820 | "uri-js": "^4.2.2" 2821 | } 2822 | }, 2823 | "json-schema-traverse": { 2824 | "version": "1.0.0", 2825 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-1.0.0.tgz", 2826 | "integrity": "sha512-NM8/P9n3XjXhIZn1lLhkFaACTOURQXjWhV4BA/RnOv8xvgqtqpAX9IO4mRQxSx1Rlo4tqzeqb0sOlruaOy3dug==", 2827 | "dev": true 2828 | } 2829 | } 2830 | }, 2831 | "teeny-request": { 2832 | "version": "7.1.1", 2833 | "resolved": "https://registry.npmjs.org/teeny-request/-/teeny-request-7.1.1.tgz", 2834 | "integrity": "sha512-iwY6rkW5DDGq8hE2YgNQlKbptYpY5Nn2xecjQiNjOXWbKzPGUfmeUBCSQbbr306d7Z7U2N0TPl+/SwYRfua1Dg==", 2835 | "dev": true, 2836 | "requires": { 2837 | "http-proxy-agent": "^4.0.0", 2838 | "https-proxy-agent": "^5.0.0", 2839 | "node-fetch": "^2.6.1", 2840 | "stream-events": "^1.0.5", 2841 | "uuid": "^8.0.0" 2842 | }, 2843 | "dependencies": { 2844 | "node-fetch": { 2845 | "version": "2.6.1", 2846 | "resolved": "https://registry.npmjs.org/node-fetch/-/node-fetch-2.6.1.tgz", 2847 | "integrity": "sha512-V4aYg89jEoVRxRb2fJdAg8FHvI7cEyYdVAh94HH0UIK8oJxUfkjlDQN9RbMx+bEjP7+ggMiFRprSti032Oipxw==", 2848 | "dev": true 2849 | }, 2850 | "uuid": { 2851 | "version": "8.3.2", 2852 | "resolved": "https://registry.npmjs.org/uuid/-/uuid-8.3.2.tgz", 2853 | "integrity": "sha512-+NYs2QeMWy+GWFOEm9xnn6HCDp0l7QBD7ml8zLUmJ+93Q5NF0NocErnwkTkXVFNiX3/fpC6afS8Dhb/gz7R7eg==", 2854 | "dev": true 2855 | } 2856 | } 2857 | }, 2858 | "test-exclude": { 2859 | "version": "6.0.0", 2860 | "resolved": "https://registry.npmjs.org/test-exclude/-/test-exclude-6.0.0.tgz", 2861 | "integrity": "sha512-cAGWPIyOHU6zlmg88jwm7VRyXnMN7iV68OGAbYDk/Mh/xC/pzVPlQtY6ngoIH/5/tciuhGfvESU8GrHrcxD56w==", 2862 | "dev": true, 2863 | "requires": { 2864 | "@istanbuljs/schema": "^0.1.2", 2865 | "glob": "^7.1.4", 2866 | "minimatch": "^3.0.4" 2867 | } 2868 | }, 2869 | "text-table": { 2870 | "version": "0.2.0", 2871 | "resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz", 2872 | "integrity": "sha1-f17oI66AUgfACvLfSoTsP8+lcLQ=", 2873 | "dev": true 2874 | }, 2875 | "to-fast-properties": { 2876 | "version": "2.0.0", 2877 | "resolved": "https://registry.npmjs.org/to-fast-properties/-/to-fast-properties-2.0.0.tgz", 2878 | "integrity": "sha1-3F5pjL0HkmW8c+A3doGk5Og/YW4=", 2879 | "dev": true 2880 | }, 2881 | "to-regex-range": { 2882 | "version": "5.0.1", 2883 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", 2884 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", 2885 | "dev": true, 2886 | "requires": { 2887 | "is-number": "^7.0.0" 2888 | } 2889 | }, 2890 | "ts-node": { 2891 | "version": "10.2.1", 2892 | "resolved": "https://registry.npmjs.org/ts-node/-/ts-node-10.2.1.tgz", 2893 | "integrity": "sha512-hCnyOyuGmD5wHleOQX6NIjJtYVIO8bPP8F2acWkB4W06wdlkgyvJtubO/I9NkI88hCFECbsEgoLc0VNkYmcSfw==", 2894 | "dev": true, 2895 | "requires": { 2896 | "@cspotcode/source-map-support": "0.6.1", 2897 | "@tsconfig/node10": "^1.0.7", 2898 | "@tsconfig/node12": "^1.0.7", 2899 | "@tsconfig/node14": "^1.0.0", 2900 | "@tsconfig/node16": "^1.0.2", 2901 | "acorn": "^8.4.1", 2902 | "acorn-walk": "^8.1.1", 2903 | "arg": "^4.1.0", 2904 | "create-require": "^1.1.0", 2905 | "diff": "^4.0.1", 2906 | "make-error": "^1.1.1", 2907 | "yn": "3.1.1" 2908 | }, 2909 | "dependencies": { 2910 | "acorn": { 2911 | "version": "8.4.1", 2912 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.4.1.tgz", 2913 | "integrity": "sha512-asabaBSkEKosYKMITunzX177CXxQ4Q8BSSzMTKD+FefUhipQC70gfW5SiUDhYQ3vk8G+81HqQk7Fv9OXwwn9KA==", 2914 | "dev": true 2915 | }, 2916 | "diff": { 2917 | "version": "4.0.2", 2918 | "resolved": "https://registry.npmjs.org/diff/-/diff-4.0.2.tgz", 2919 | "integrity": "sha512-58lmxKSA4BNyLz+HHMUzlOEpg09FV+ev6ZMe3vJihgdxzgcwZ8VoEEPmALCZG9LmqfVoNMMKpttIYTVG6uDY7A==", 2920 | "dev": true 2921 | } 2922 | } 2923 | }, 2924 | "tslib": { 2925 | "version": "1.14.1", 2926 | "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.14.1.tgz", 2927 | "integrity": "sha512-Xni35NKzjgMrwevysHTCArtLDpPvye8zV/0E4EyYn43P7/7qvQwPh9BGkHewbMulVntbigmcT7rdX3BNo9wRJg==", 2928 | "dev": true 2929 | }, 2930 | "tsutils": { 2931 | "version": "3.21.0", 2932 | "resolved": "https://registry.npmjs.org/tsutils/-/tsutils-3.21.0.tgz", 2933 | "integrity": "sha512-mHKK3iUXL+3UF6xL5k0PEhKRUBKPBCv/+RkEOpjRWxxx27KKRBmmA60A9pgOUvMi8GKhRMPEmjBRPzs2W7O1OA==", 2934 | "dev": true, 2935 | "requires": { 2936 | "tslib": "^1.8.1" 2937 | } 2938 | }, 2939 | "type-check": { 2940 | "version": "0.4.0", 2941 | "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.4.0.tgz", 2942 | "integrity": "sha512-XleUoc9uwGXqjWwXaUTZAmzMcFZ5858QA2vvx1Ur5xIcixXIP+8LnFDgRplU30us6teqdlskFfu+ae4K79Ooew==", 2943 | "dev": true, 2944 | "requires": { 2945 | "prelude-ls": "^1.2.1" 2946 | } 2947 | }, 2948 | "type-detect": { 2949 | "version": "4.0.8", 2950 | "resolved": "https://registry.npmjs.org/type-detect/-/type-detect-4.0.8.tgz", 2951 | "integrity": "sha512-0fr/mIH1dlO+x7TlcMy+bIDqKPsw/70tVyeHW787goQjhmqaZe10uwLujubK9q9Lg6Fiho1KUKDYz0Z7k7g5/g==", 2952 | "dev": true 2953 | }, 2954 | "type-fest": { 2955 | "version": "0.8.1", 2956 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.8.1.tgz", 2957 | "integrity": "sha512-4dbzIzqvjtgiM5rw1k5rEHtBANKmdudhGyBEajN01fEyhaAIhsoKNy6y7+IN93IfpFtwY9iqi7kD+xwKhQsNJA==", 2958 | "dev": true 2959 | }, 2960 | "typedarray-to-buffer": { 2961 | "version": "3.1.5", 2962 | "resolved": "https://registry.npmjs.org/typedarray-to-buffer/-/typedarray-to-buffer-3.1.5.tgz", 2963 | "integrity": "sha512-zdu8XMNEDepKKR+XYOXAVPtWui0ly0NtohUscw+UmaHiAWT8hrV1rr//H6V+0DvJ3OQ19S979M0laLfX8rm82Q==", 2964 | "dev": true, 2965 | "requires": { 2966 | "is-typedarray": "^1.0.0" 2967 | } 2968 | }, 2969 | "typescript": { 2970 | "version": "4.4.2", 2971 | "resolved": "https://registry.npmjs.org/typescript/-/typescript-4.4.2.tgz", 2972 | "integrity": "sha512-gzP+t5W4hdy4c+68bfcv0t400HVJMMd2+H9B7gae1nQlBzCqvrXX+6GL/b3GAgyTH966pzrZ70/fRjwAtZksSQ==", 2973 | "dev": true 2974 | }, 2975 | "typescript-fsa": { 2976 | "version": "3.0.0", 2977 | "resolved": "https://registry.npmjs.org/typescript-fsa/-/typescript-fsa-3.0.0.tgz", 2978 | "integrity": "sha512-xiXAib35i0QHl/+wMobzPibjAH5TJLDj+qGq5jwVLG9qR4FUswZURBw2qihBm0m06tHoyb3FzpnJs1GRhRwVag==", 2979 | "dev": true 2980 | }, 2981 | "typescript-fsa-reducers": { 2982 | "version": "1.2.2", 2983 | "resolved": "https://registry.npmjs.org/typescript-fsa-reducers/-/typescript-fsa-reducers-1.2.2.tgz", 2984 | "integrity": "sha512-IQ2VsIqUvmzVgWNDjxkeOxX97itl/rq+2u82jGsRdzCSFi9OtV4qf1Ec1urvj/eDlPHOaihIL7wMZzLYx9GvFg==", 2985 | "dev": true 2986 | }, 2987 | "uri-js": { 2988 | "version": "4.4.1", 2989 | "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.4.1.tgz", 2990 | "integrity": "sha512-7rKUyy33Q1yc98pQ1DAmLtwX109F7TIfWlW1Ydo8Wl1ii1SeHieeh0HHfPeL2fMXK6z0s8ecKs9frCuLJvndBg==", 2991 | "dev": true, 2992 | "requires": { 2993 | "punycode": "^2.1.0" 2994 | }, 2995 | "dependencies": { 2996 | "punycode": { 2997 | "version": "2.1.1", 2998 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.1.1.tgz", 2999 | "integrity": "sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A==", 3000 | "dev": true 3001 | } 3002 | } 3003 | }, 3004 | "urlgrey": { 3005 | "version": "1.0.0", 3006 | "resolved": "https://registry.npmjs.org/urlgrey/-/urlgrey-1.0.0.tgz", 3007 | "integrity": "sha512-hJfIzMPJmI9IlLkby8QrsCykQ+SXDeO2W5Q9QTW3QpqZVTx4a/K7p8/5q+/isD8vsbVaFgql/gvAoQCRQ2Cb5w==", 3008 | "dev": true, 3009 | "requires": { 3010 | "fast-url-parser": "^1.1.3" 3011 | } 3012 | }, 3013 | "uuid": { 3014 | "version": "3.4.0", 3015 | "resolved": "https://registry.npmjs.org/uuid/-/uuid-3.4.0.tgz", 3016 | "integrity": "sha512-HjSDRw6gZE5JMggctHBcjVak08+KEVhSIiDzFnT9S9aegmp85S/bReBVTb4QTFaRNptJ9kuYaNhnbNEOkbKb/A==", 3017 | "dev": true 3018 | }, 3019 | "v8-compile-cache": { 3020 | "version": "2.3.0", 3021 | "resolved": "https://registry.npmjs.org/v8-compile-cache/-/v8-compile-cache-2.3.0.tgz", 3022 | "integrity": "sha512-l8lCEmLcLYZh4nbunNZvQCJc5pv7+RCwa8q/LdUx8u7lsWvPDKmpodJAJNwkAhJC//dFY48KuIEmjtd4RViDrA==", 3023 | "dev": true 3024 | }, 3025 | "which": { 3026 | "version": "2.0.2", 3027 | "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", 3028 | "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", 3029 | "dev": true, 3030 | "requires": { 3031 | "isexe": "^2.0.0" 3032 | } 3033 | }, 3034 | "which-module": { 3035 | "version": "2.0.0", 3036 | "resolved": "https://registry.npmjs.org/which-module/-/which-module-2.0.0.tgz", 3037 | "integrity": "sha1-2e8H3Od7mQK4o6j6SzHD4/fm6Ho=", 3038 | "dev": true 3039 | }, 3040 | "wide-align": { 3041 | "version": "1.1.3", 3042 | "resolved": "https://registry.npmjs.org/wide-align/-/wide-align-1.1.3.tgz", 3043 | "integrity": "sha512-QGkOQc8XL6Bt5PwnsExKBPuMKBxnGxWWW3fU55Xt4feHozMUhdUMaBCk290qpm/wG5u/RSKzwdAC4i51YigihA==", 3044 | "dev": true, 3045 | "requires": { 3046 | "string-width": "^1.0.2 || 2" 3047 | }, 3048 | "dependencies": { 3049 | "ansi-regex": { 3050 | "version": "3.0.0", 3051 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-3.0.0.tgz", 3052 | "integrity": "sha1-7QMXwyIGT3lGbAKWa922Bas32Zg=", 3053 | "dev": true 3054 | }, 3055 | "is-fullwidth-code-point": { 3056 | "version": "2.0.0", 3057 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", 3058 | "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=", 3059 | "dev": true 3060 | }, 3061 | "string-width": { 3062 | "version": "2.1.1", 3063 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-2.1.1.tgz", 3064 | "integrity": "sha512-nOqH59deCq9SRHlxq1Aw85Jnt4w6KvLKqWVik6oA9ZklXLNIOlqg4F2yrT1MVaTjAqvVwdfeZ7w7aCvJD7ugkw==", 3065 | "dev": true, 3066 | "requires": { 3067 | "is-fullwidth-code-point": "^2.0.0", 3068 | "strip-ansi": "^4.0.0" 3069 | } 3070 | }, 3071 | "strip-ansi": { 3072 | "version": "4.0.0", 3073 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-4.0.0.tgz", 3074 | "integrity": "sha1-qEeQIusaw2iocTibY1JixQXuNo8=", 3075 | "dev": true, 3076 | "requires": { 3077 | "ansi-regex": "^3.0.0" 3078 | } 3079 | } 3080 | } 3081 | }, 3082 | "word-wrap": { 3083 | "version": "1.2.3", 3084 | "resolved": "https://registry.npmjs.org/word-wrap/-/word-wrap-1.2.3.tgz", 3085 | "integrity": "sha512-Hz/mrNwitNRh/HUAtM/VT/5VH+ygD6DV7mYKZAtHOrbs8U7lvPS6xf7EJKMF0uW1KJCl0H701g3ZGus+muE5vQ==", 3086 | "dev": true 3087 | }, 3088 | "workerpool": { 3089 | "version": "6.1.5", 3090 | "resolved": "https://registry.npmjs.org/workerpool/-/workerpool-6.1.5.tgz", 3091 | "integrity": "sha512-XdKkCK0Zqc6w3iTxLckiuJ81tiD/o5rBE/m+nXpRCB+/Sq4DqkfXZ/x0jW02DG1tGsfUGXbTJyZDP+eu67haSw==", 3092 | "dev": true 3093 | }, 3094 | "wrap-ansi": { 3095 | "version": "7.0.0", 3096 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz", 3097 | "integrity": "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==", 3098 | "dev": true, 3099 | "requires": { 3100 | "ansi-styles": "^4.0.0", 3101 | "string-width": "^4.1.0", 3102 | "strip-ansi": "^6.0.0" 3103 | }, 3104 | "dependencies": { 3105 | "ansi-styles": { 3106 | "version": "4.3.0", 3107 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 3108 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 3109 | "dev": true, 3110 | "requires": { 3111 | "color-convert": "^2.0.1" 3112 | } 3113 | }, 3114 | "color-convert": { 3115 | "version": "2.0.1", 3116 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 3117 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 3118 | "dev": true, 3119 | "requires": { 3120 | "color-name": "~1.1.4" 3121 | } 3122 | }, 3123 | "color-name": { 3124 | "version": "1.1.4", 3125 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 3126 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 3127 | "dev": true 3128 | } 3129 | } 3130 | }, 3131 | "wrappy": { 3132 | "version": "1.0.2", 3133 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 3134 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=", 3135 | "dev": true 3136 | }, 3137 | "write-file-atomic": { 3138 | "version": "3.0.3", 3139 | "resolved": "https://registry.npmjs.org/write-file-atomic/-/write-file-atomic-3.0.3.tgz", 3140 | "integrity": "sha512-AvHcyZ5JnSfq3ioSyjrBkH9yW4m7Ayk8/9My/DD9onKeu/94fwrMocemO2QAJFAlnnDN+ZDS+ZjAR5ua1/PV/Q==", 3141 | "dev": true, 3142 | "requires": { 3143 | "imurmurhash": "^0.1.4", 3144 | "is-typedarray": "^1.0.0", 3145 | "signal-exit": "^3.0.2", 3146 | "typedarray-to-buffer": "^3.1.5" 3147 | } 3148 | }, 3149 | "y18n": { 3150 | "version": "4.0.3", 3151 | "resolved": "https://registry.npmjs.org/y18n/-/y18n-4.0.3.tgz", 3152 | "integrity": "sha512-JKhqTOwSrqNA1NY5lSztJ1GrBiUodLMmIZuLiDaMRJ+itFd+ABVE8XBjOvIWL+rSqNDC74LCSFmlb/U4UZ4hJQ==", 3153 | "dev": true 3154 | }, 3155 | "yallist": { 3156 | "version": "4.0.0", 3157 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", 3158 | "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", 3159 | "dev": true 3160 | }, 3161 | "yargs": { 3162 | "version": "16.2.0", 3163 | "resolved": "https://registry.npmjs.org/yargs/-/yargs-16.2.0.tgz", 3164 | "integrity": "sha512-D1mvvtDG0L5ft/jGWkLpG1+m0eQxOfaBvTNELraWj22wSVUMWxZUvYgJYcKh6jGGIkJFhH4IZPQhR4TKpc8mBw==", 3165 | "dev": true, 3166 | "requires": { 3167 | "cliui": "^7.0.2", 3168 | "escalade": "^3.1.1", 3169 | "get-caller-file": "^2.0.5", 3170 | "require-directory": "^2.1.1", 3171 | "string-width": "^4.2.0", 3172 | "y18n": "^5.0.5", 3173 | "yargs-parser": "^20.2.2" 3174 | }, 3175 | "dependencies": { 3176 | "y18n": { 3177 | "version": "5.0.8", 3178 | "resolved": "https://registry.npmjs.org/y18n/-/y18n-5.0.8.tgz", 3179 | "integrity": "sha512-0pfFzegeDWJHJIAmTLRP2DwHjdF5s7jo9tuztdQxAhINCdvS+3nGINqPd00AphqJR/0LhANUS6/+7SCb98YOfA==", 3180 | "dev": true 3181 | } 3182 | } 3183 | }, 3184 | "yargs-parser": { 3185 | "version": "20.2.4", 3186 | "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-20.2.4.tgz", 3187 | "integrity": "sha512-WOkpgNhPTlE73h4VFAFsOnomJVaovO8VqLDzy5saChRBFQFBoMYirowyW+Q9HB4HFF4Z7VZTiG3iSzJJA29yRA==", 3188 | "dev": true 3189 | }, 3190 | "yargs-unparser": { 3191 | "version": "2.0.0", 3192 | "resolved": "https://registry.npmjs.org/yargs-unparser/-/yargs-unparser-2.0.0.tgz", 3193 | "integrity": "sha512-7pRTIA9Qc1caZ0bZ6RYRGbHJthJWuakf+WmHK0rVeLkNrrGhfoabBNdue6kdINI6r4if7ocq9aD/n7xwKOdzOA==", 3194 | "dev": true, 3195 | "requires": { 3196 | "camelcase": "^6.0.0", 3197 | "decamelize": "^4.0.0", 3198 | "flat": "^5.0.2", 3199 | "is-plain-obj": "^2.1.0" 3200 | }, 3201 | "dependencies": { 3202 | "camelcase": { 3203 | "version": "6.2.0", 3204 | "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-6.2.0.tgz", 3205 | "integrity": "sha512-c7wVvbw3f37nuobQNtgsgG9POC9qMbNuMQmTCqZv23b6MIz0fcYpBiOlv9gEN/hdLdnZTDQhg6e9Dq5M1vKvfg==", 3206 | "dev": true 3207 | }, 3208 | "decamelize": { 3209 | "version": "4.0.0", 3210 | "resolved": "https://registry.npmjs.org/decamelize/-/decamelize-4.0.0.tgz", 3211 | "integrity": "sha512-9iE1PgSik9HeIIw2JO94IidnE3eBoQrFJ3w7sFuzSX4DpmZ3v5sZpUiV5Swcf6mQEF+Y0ru8Neo+p+nyh2J+hQ==", 3212 | "dev": true 3213 | } 3214 | } 3215 | }, 3216 | "yn": { 3217 | "version": "3.1.1", 3218 | "resolved": "https://registry.npmjs.org/yn/-/yn-3.1.1.tgz", 3219 | "integrity": "sha512-Ux4ygGWsu2c7isFWe8Yu1YluJmqVhxqK2cLXNQA5AcC3QfbGNpM7fu0Y8b/z16pXLnFxZYvWhd3fhBY9DLmC6Q==", 3220 | "dev": true 3221 | }, 3222 | "yocto-queue": { 3223 | "version": "0.1.0", 3224 | "resolved": "https://registry.npmjs.org/yocto-queue/-/yocto-queue-0.1.0.tgz", 3225 | "integrity": "sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q==", 3226 | "dev": true 3227 | } 3228 | } 3229 | } 3230 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "typescript-fsa-redux-thunk", 3 | "version": "2.10.2", 4 | "description": "TypeScript FSA utilities for redux-thunk", 5 | "keywords": [ 6 | "action", 7 | "action creator", 8 | "flux standard action", 9 | "redux", 10 | "redux-thunk", 11 | "thunk", 12 | "typescript", 13 | "typescript-fsa" 14 | ], 15 | "repository": "https://github.com/xdave/typescript-fsa-redux-thunk", 16 | "license": "MIT", 17 | "author": "Dave Gradwell ", 18 | "main": "lib/index.js", 19 | "module": "esm/index.js", 20 | "scripts": { 21 | "build": "npm run build:lib", 22 | "build:lib": "tsc && tsc -p tsconfig.esm.json", 23 | "clean": "rimraf lib .nyc_output coverage", 24 | "format": "prettier --write .", 25 | "lint": "eslint --ext .ts .", 26 | "prepublishOnly": "npm run build:lib", 27 | "test": "env-cmd -e mocha nyc mocha", 28 | "posttest": "test $CI && codecov -f coverage/*.json || true", 29 | "test:watch": "npm test -- --reporter min --watch src/**/*.ts --watch-extensions ts" 30 | }, 31 | "devDependencies": { 32 | "@types/chai": "^4.2.21", 33 | "@types/mocha": "^9.0.0", 34 | "@types/node": "^16.7.10", 35 | "@types/redux-mock-store": "^1.0.3", 36 | "@typescript-eslint/eslint-plugin": "^4.30.0", 37 | "@typescript-eslint/parser": "^4.30.0", 38 | "chai": "^4.3.4", 39 | "codecov": "^3.8.3", 40 | "env-cmd": "^10.1.0", 41 | "eslint": "^7.32.0", 42 | "eslint-config-prettier": "^8.3.0", 43 | "mocha": "^9.1.1", 44 | "node-fetch": "^2.6.1", 45 | "nyc": "^15.1.0", 46 | "prettier": "^2.3.2", 47 | "redux": "^4.0.5", 48 | "redux-mock-store": "^1.5.4", 49 | "redux-thunk": "^2.3.0", 50 | "rimraf": "^3.0.2", 51 | "ts-node": "^10.2.1", 52 | "typescript": "^4.4.2", 53 | "typescript-fsa": "^3.0.0", 54 | "typescript-fsa-reducers": "^1.2.2" 55 | }, 56 | "peerDependencies": { 57 | "redux": ">=4.x", 58 | "redux-thunk": ">=2.3.x", 59 | "typescript-fsa": ">=3.x" 60 | }, 61 | "dependencies": {} 62 | } 63 | -------------------------------------------------------------------------------- /src/examples.ts: -------------------------------------------------------------------------------- 1 | /* eslint-disable @typescript-eslint/no-var-requires */ 2 | import { AnyAction, applyMiddleware, createStore } from 'redux'; 3 | import thunkMiddleware, { ThunkMiddleware } from 'redux-thunk'; 4 | import actionCreatorFactory from 'typescript-fsa'; 5 | import { reducerWithInitialState } from 'typescript-fsa-reducers'; 6 | import { asyncFactory } from './index'; 7 | 8 | // https://github.com/node-fetch/node-fetch/issues/1266 9 | const fetch = require('node-fetch'); 10 | 11 | /** You can optionally use custom Error types */ 12 | class CustomError extends Error {} 13 | 14 | /** Parameters used for logging in */ 15 | interface LoginParams { 16 | email: string; 17 | password: string; 18 | } 19 | 20 | /** The object that comes back from the server on successful login */ 21 | interface UserToken { 22 | token: string; 23 | } 24 | 25 | /** The shape of our Redux store's state */ 26 | interface State { 27 | title: string; 28 | userToken: UserToken; 29 | loggingIn?: boolean; 30 | error?: CustomError; 31 | } 32 | 33 | /** The typescript-fsa action creator factory function */ 34 | const create = actionCreatorFactory('examples'); 35 | 36 | /** The typescript-fsa-redux-thunk async action creator factory function */ 37 | const createAsync = asyncFactory(create); 38 | 39 | /** Normal synchronous action */ 40 | const changeTitle = create('Change the title'); 41 | 42 | /** The asynchronous login action; Error type is optional */ 43 | const login = createAsync( 44 | 'Login', 45 | async (params, dispatch) => { 46 | const url = `https://reqres.in/api/login`; 47 | const options = { 48 | method: 'POST', 49 | body: JSON.stringify(params), 50 | headers: { 51 | 'Content-Type': 'application/json; charset=utf-8', 52 | }, 53 | }; 54 | const res = await fetch(url, options); 55 | if (!res.ok) { 56 | throw new CustomError(`Error ${res.status}: ${res.statusText}`); 57 | } 58 | 59 | dispatch(changeTitle('You are logged-in')); 60 | 61 | return (await res.json()) as UserToken; 62 | }, 63 | ); 64 | 65 | /** An initial value for the application state */ 66 | const initial: State = { 67 | title: 'Please login', 68 | userToken: { 69 | token: '', 70 | }, 71 | }; 72 | 73 | /** Reducer, handling updates to indicate logging-in status/error */ 74 | const reducer = reducerWithInitialState(initial) 75 | .case(changeTitle, (state, title) => ({ 76 | ...state, 77 | title, 78 | })) 79 | .case(login.async.started, (state) => ({ 80 | ...state, 81 | loggingIn: true, 82 | error: undefined, 83 | })) 84 | .case(login.async.failed, (state, { error }) => ({ 85 | ...state, 86 | loggingIn: false, 87 | error, 88 | })) 89 | .case(login.async.done, (state, { result: userToken }) => ({ 90 | ...state, 91 | userToken, 92 | loggingIn: false, 93 | error: undefined, 94 | })) 95 | .build(); 96 | 97 | /** Putting it all together */ 98 | (async () => { 99 | // Declaring the type of the redux-thunk middleware is what makes 100 | // `store.dispatch` work. (redux@4.x, redux-thunk@2.3.x) 101 | const thunk: ThunkMiddleware = thunkMiddleware; 102 | const store = createStore(reducer, applyMiddleware(thunk)); 103 | 104 | console.log(store.getState().title); 105 | 106 | try { 107 | // See https://reqres.in/api/users for valid users on this site 108 | await store.dispatch( 109 | login({ 110 | email: 'eve.holt@reqres.in', 111 | password: 'cityslicka', 112 | }), 113 | ); 114 | 115 | const { title, userToken } = store.getState(); 116 | 117 | console.log(title, userToken); 118 | } catch (err) { 119 | console.log(err); 120 | } 121 | })(); 122 | -------------------------------------------------------------------------------- /src/index.spec.ts: -------------------------------------------------------------------------------- 1 | import { expect } from 'chai'; 2 | import { Middleware, AnyAction } from 'redux'; 3 | import thunkMiddleware, { ThunkDispatch } from 'redux-thunk'; 4 | import configureStore, { MockStore } from 'redux-mock-store'; 5 | import factory from 'typescript-fsa'; 6 | import { reducerWithInitialState } from 'typescript-fsa-reducers'; 7 | import { thunkToAction, asyncFactory } from '.'; 8 | 9 | interface Ext { 10 | dispatch: ThunkDispatch; 11 | } 12 | 13 | const fakeError = new Error('Fake Error'); 14 | 15 | class OtherError extends Error {} 16 | 17 | const otherError = new OtherError('Another fake error'); 18 | 19 | interface State { 20 | foo: string; 21 | updating?: boolean; 22 | error?: Error; 23 | otherError?: OtherError; 24 | } 25 | 26 | interface Params { 27 | param: number; 28 | } 29 | type Succ = string; 30 | 31 | const create = factory('test'); 32 | const createAsync = asyncFactory(create); 33 | 34 | const successTest = createAsync('success', () => { 35 | /* noop */ 36 | }); 37 | // const failureTest = createAsync('failure', () => { throw fakeError; }); 38 | 39 | const test1 = createAsync('test1', async ({ param }) => { 40 | if (param === 2) { 41 | throw fakeError; 42 | } 43 | return ''; 44 | }); 45 | 46 | const test2 = createAsync('test2', () => ''); 47 | 48 | const test3 = createAsync('test3', () => { 49 | throw fakeError; 50 | }); 51 | 52 | const test4 = createAsync( 53 | 'test4', 54 | async ({ param }, dispatch) => { 55 | await dispatch(test1.action({ param })); 56 | await dispatch(test2()); 57 | try { 58 | await dispatch(test3()); 59 | } catch (err) { 60 | // noop 61 | } 62 | return 'This is a test.'; 63 | }, 64 | ); 65 | 66 | const test5 = createAsync( 67 | 'test5', 68 | async ({ param }) => { 69 | if (param === 2) { 70 | throw otherError; 71 | } 72 | return ''; 73 | }, 74 | ); 75 | 76 | const test6 = createAsync('test6', Promise.resolve); 77 | const test7 = createAsync('test7', () => { 78 | /* noop */ 79 | }); 80 | 81 | const initial: State = { foo: 'test' }; 82 | 83 | const reducer = reducerWithInitialState(initial) 84 | .case(test4.async.started, (state) => ({ 85 | ...state, 86 | updating: true, 87 | })) 88 | .case(test4.async.failed, (state, { error }) => ({ 89 | ...state, 90 | updating: false, 91 | error, 92 | })) 93 | .case(test4.async.done, (state, { result: foo }) => ({ 94 | ...state, 95 | updating: false, 96 | foo, 97 | })) 98 | .case(test5.async.failed, (state, { error: otherError }) => ({ 99 | ...state, 100 | otherError, 101 | })) 102 | .case(test6.async.started, (state) => state) 103 | .case(test6.async.failed, (state) => state) 104 | .case(test6.async.done, (state) => state) 105 | .case(test7.async.started, (state) => state) 106 | .case(test7.async.failed, (state) => state) 107 | .case(test7.async.done, (state) => state) 108 | .build(); 109 | 110 | describe('typescript-fsa-redux-thunk', () => { 111 | type StoreType = MockStore & Ext; 112 | let middleware: Middleware[] = []; 113 | let createMockStore: (initial: State) => StoreType; 114 | let store: StoreType; 115 | 116 | beforeEach(() => { 117 | middleware = [thunkMiddleware]; 118 | createMockStore = configureStore(middleware); 119 | store = createMockStore(initial); 120 | }); 121 | 122 | describe('ThunkActionCreators', () => { 123 | it('started', () => { 124 | const result = store.dispatch(test1.async.started({ param: 1 })); 125 | expect(result).to.eql({ 126 | type: 'test/test1_STARTED', 127 | payload: { param: 1 }, 128 | }); 129 | }); 130 | it('failed', () => { 131 | const result = store.dispatch( 132 | test1.async.failed({ 133 | params: { param: 1 }, 134 | error: fakeError, 135 | }), 136 | ); 137 | expect(result).to.eql({ 138 | type: 'test/test1_FAILED', 139 | error: true, 140 | payload: { 141 | params: { param: 1 }, 142 | error: fakeError, 143 | }, 144 | }); 145 | }); 146 | it('done', async () => { 147 | const promise = await Promise.resolve(''); 148 | const result = store.dispatch( 149 | test1.async.done({ 150 | params: { param: 1 }, 151 | result: promise, 152 | }), 153 | ); 154 | expect(result).to.eql({ 155 | type: 'test/test1_DONE', 156 | payload: { 157 | params: { param: 1 }, 158 | result: promise, 159 | }, 160 | }); 161 | }); 162 | it('full dispatch (success)', async () => { 163 | await store.dispatch(test1({ param: 1 })); 164 | 165 | const actions = store.getActions(); 166 | expect(actions).to.eql([ 167 | { 168 | type: 'test/test1_STARTED', 169 | payload: { param: 1 }, 170 | }, 171 | { 172 | type: 'test/test1_DONE', 173 | payload: { 174 | params: { param: 1 }, 175 | result: '', 176 | }, 177 | }, 178 | ]); 179 | }); 180 | it('full dispatch (failure)', async () => { 181 | let thrown; 182 | try { 183 | await store.dispatch(test1({ param: 2 })); 184 | } catch (err) { 185 | thrown = err; 186 | } 187 | 188 | expect(thrown).to.eql(fakeError); 189 | 190 | const actions = store.getActions(); 191 | expect(actions).to.eql([ 192 | { 193 | type: 'test/test1_STARTED', 194 | payload: { param: 2 }, 195 | }, 196 | { 197 | type: 'test/test1_FAILED', 198 | error: true, 199 | payload: { 200 | params: { param: 2 }, 201 | error: fakeError, 202 | }, 203 | }, 204 | ]); 205 | }); 206 | it('full dispatch (failure with error type)', async () => { 207 | let thrown; 208 | try { 209 | await store.dispatch(test5({ param: 2 })); 210 | } catch (err) { 211 | thrown = err; 212 | } 213 | 214 | expect(thrown).to.eql(otherError); 215 | 216 | const actions = store.getActions(); 217 | expect(actions).to.eql([ 218 | { 219 | type: 'test/test5_STARTED', 220 | payload: { param: 2 }, 221 | }, 222 | { 223 | type: 'test/test5_FAILED', 224 | error: true, 225 | payload: { 226 | params: { param: 2 }, 227 | error: otherError, 228 | }, 229 | }, 230 | ]); 231 | 232 | const [, failed] = actions; 233 | const initialState = store.getState(); 234 | const failedState = reducer(initialState, failed); 235 | expect(failedState).to.eql({ 236 | ...initialState, 237 | otherError, 238 | }); 239 | }); 240 | it('dispatch without an argument', async () => { 241 | await store.dispatch(test2()); 242 | 243 | const actions = store.getActions(); 244 | expect(actions).to.eql([ 245 | { 246 | type: 'test/test2_STARTED', 247 | payload: undefined, 248 | }, 249 | { 250 | type: 'test/test2_DONE', 251 | payload: { 252 | params: undefined, 253 | result: '', 254 | }, 255 | }, 256 | ]); 257 | }); 258 | 259 | it('dispatch without an argument (failure)', async () => { 260 | let thrown; 261 | try { 262 | await store.dispatch(test3()); 263 | } catch (err) { 264 | thrown = err; 265 | } 266 | 267 | expect(thrown).to.eql(fakeError); 268 | 269 | const actions = store.getActions(); 270 | expect(actions).to.eql([ 271 | { 272 | type: 'test/test3_STARTED', 273 | payload: undefined, 274 | }, 275 | { 276 | type: 'test/test3_FAILED', 277 | error: true, 278 | payload: { 279 | params: undefined, 280 | error: fakeError, 281 | }, 282 | }, 283 | ]); 284 | }); 285 | 286 | it('full test', async () => { 287 | await store.dispatch(test4({ param: 1 })); 288 | 289 | const actions = store.getActions(); 290 | expect(actions).to.eql([ 291 | { 292 | type: 'test/test4_STARTED', 293 | payload: { param: 1 }, 294 | }, 295 | { 296 | type: 'test/test1_STARTED', 297 | payload: { param: 1 }, 298 | }, 299 | { 300 | type: 'test/test1_DONE', 301 | payload: { 302 | params: { param: 1 }, 303 | result: '', 304 | }, 305 | }, 306 | { 307 | type: 'test/test2_STARTED', 308 | payload: undefined, 309 | }, 310 | { 311 | type: 'test/test2_DONE', 312 | payload: { 313 | params: undefined, 314 | result: '', 315 | }, 316 | }, 317 | { 318 | type: 'test/test3_STARTED', 319 | payload: undefined, 320 | }, 321 | { 322 | type: 'test/test3_FAILED', 323 | error: true, 324 | payload: { 325 | params: undefined, 326 | error: fakeError, 327 | }, 328 | }, 329 | { 330 | type: 'test/test4_DONE', 331 | payload: { 332 | params: { param: 1 }, 333 | result: 'This is a test.', 334 | }, 335 | }, 336 | ]); 337 | }); 338 | 339 | it('thunkToAction', async () => { 340 | const action = thunkToAction(successTest); 341 | expect(action).to.eql(successTest); 342 | }); 343 | 344 | it('reducer test', async () => { 345 | await store.dispatch(test4({ param: 1 })); 346 | 347 | const [started, done] = store 348 | .getActions() 349 | .filter((action) => action.type.includes('test4')); 350 | 351 | const beforeState = store.getState(); 352 | expect(beforeState).to.eql(initial); 353 | 354 | const startedState = reducer(beforeState, started); 355 | expect(startedState).to.eql({ 356 | ...beforeState, 357 | updating: true, 358 | }); 359 | 360 | const doneState = reducer(startedState, done); 361 | expect(doneState).to.eql({ 362 | ...startedState, 363 | updating: false, 364 | foo: 'This is a test.', 365 | }); 366 | }); 367 | }); 368 | }); 369 | -------------------------------------------------------------------------------- /src/index.ts: -------------------------------------------------------------------------------- 1 | import type { ThunkAction, ThunkDispatch } from 'redux-thunk'; 2 | import type { 3 | ActionCreatorFactory, 4 | AnyAction, 5 | AsyncActionCreators, 6 | Meta, 7 | } from 'typescript-fsa'; 8 | 9 | /** 10 | * This interface can be augmented by users to add default types for the root state when 11 | * using `typescript-fsa-redux-thunk`. 12 | * Use module augmentation to append your own type definition in a your_custom_type.d.ts file. 13 | * https://www.typescriptlang.org/docs/handbook/declaration-merging.html#module-augmentation 14 | */ 15 | // eslint-disable-next-line @typescript-eslint/no-empty-interface 16 | export interface DefaultRootState {} 17 | 18 | /** 19 | * It's either a promise, or it isn't 20 | */ 21 | export type MaybePromise = T | Promise; 22 | 23 | /** 24 | * A redux-thunk with the params as the first argument. You don't have to 25 | * return a promise; but, the result of the dispatch will be one. 26 | */ 27 | export type AsyncWorker< 28 | InputType, 29 | ReturnType, 30 | State = DefaultRootState, 31 | Extra = unknown, 32 | > = ( 33 | params: InputType, 34 | dispatch: ThunkDispatch, 35 | getState: () => State, 36 | extraArgument: Extra, 37 | ) => MaybePromise; 38 | 39 | /** Workaround for typescript-fsa issue #77 */ 40 | export type ThunkReturnType = T extends void 41 | ? unknown 42 | : T extends Promise 43 | ? Promise 44 | : T; 45 | 46 | type SmartThunkFunction = 47 | unknown extends InputType 48 | ? ThunkFunctionWithoutParams< 49 | ThunkReturnType, 50 | State, 51 | Error, 52 | Extra 53 | > 54 | : ThunkFunction< 55 | InputType, 56 | ThunkReturnType, 57 | State, 58 | Error, 59 | Extra 60 | >; 61 | 62 | /** 63 | * Factory function to easily create a thunk 64 | * @param factory typescript-fsa action creator factory 65 | * @returns an function that takes 66 | * - the `type` of the action, 67 | * - the your worker thunk function 68 | * And returns object with the async actions and the thunk itself 69 | */ 70 | export const asyncFactory = 71 | ( 72 | factory: ActionCreatorFactory, 73 | resolve: () => Promise = Promise.resolve.bind(Promise), 74 | ) => 75 | ( 76 | type: string, 77 | worker: AsyncWorker, State, Extra>, 78 | commonMeta?: Meta, 79 | ): SmartThunkFunction => { 80 | type Procedure = ThunkFunction< 81 | InputType, 82 | ThunkReturnType, 83 | State, 84 | Error, 85 | Extra 86 | >; 87 | const async = factory.async, Error>( 88 | type, 89 | commonMeta, 90 | ); 91 | const fn: Procedure = (params) => (dispatch, getState, extraArgument) => 92 | resolve() 93 | .then(() => { 94 | dispatch(async.started(params)); 95 | }) 96 | .then(() => worker(params, dispatch, getState, extraArgument)) 97 | .then( 98 | (result) => { 99 | dispatch(async.done({ params, result })); 100 | return result; 101 | }, 102 | (error) => { 103 | dispatch(async.failed({ params, error })); 104 | throw error; 105 | }, 106 | ); 107 | fn.action = (params) => fn(params); 108 | fn.async = async; 109 | return fn as unknown as SmartThunkFunction< 110 | State, 111 | InputType, 112 | ReturnType, 113 | Error, 114 | Extra 115 | >; 116 | }; 117 | /* eslint-enable @typescript-eslint/explicit-module-boundary-types */ 118 | 119 | export type ThunkFunctionAction< 120 | ReturnType, 121 | State = DefaultRootState, 122 | Extra = unknown, 123 | > = ( 124 | dispatch: ThunkDispatch, 125 | getState: () => State, 126 | extraArgument: Extra, 127 | ) => Promise; 128 | 129 | export interface ThunkFunction< 130 | InputType, 131 | ReturnType, 132 | State = DefaultRootState, 133 | Error = unknown, 134 | Extra = unknown, 135 | > { 136 | (params: InputType): ThunkFunctionAction; 137 | action(params: InputType): ThunkFunctionAction; 138 | async: AsyncActionCreators; 139 | } 140 | 141 | export interface ThunkFunctionWithoutParams< 142 | ReturnType, 143 | State = DefaultRootState, 144 | Error = unknown, 145 | Extra = unknown, 146 | > { 147 | (): ThunkFunctionAction; 148 | action(): ThunkFunctionAction; 149 | async: AsyncActionCreators; 150 | } 151 | 152 | /** Utility type for a function that takes paras and returns a redux-thunk */ 153 | export type ThunkCreator = ( 154 | params?: InputType, 155 | ) => ThunkAction, State, unknown, AnyAction>; 156 | 157 | /** The result type for thunkToAction below */ 158 | export type ThunkFn = ( 159 | params?: InputType, 160 | ) => Promise; 161 | 162 | /** 163 | * Passing the result of this to bindActionCreators and then calling the result 164 | * is equivalent to calling `store.dispatch(thunkCreator(params))`. Useful 165 | * for when you pass it to `connect()` in an action creators map object. 166 | * @param thunkCreator The thunk action creator 167 | * @returns thunkAction as if it was bound 168 | */ 169 | export function thunkToAction( 170 | thunkCreator: ThunkCreator, 171 | ): ThunkFn { 172 | return thunkCreator as unknown as ThunkFn; 173 | } 174 | 175 | export default asyncFactory; 176 | -------------------------------------------------------------------------------- /src/issue-17.spec.ts: -------------------------------------------------------------------------------- 1 | import actionCreatorFactory from 'typescript-fsa'; 2 | import { 3 | reducerWithInitialState, 4 | reducerWithoutInitialState, 5 | } from 'typescript-fsa-reducers'; 6 | import { asyncFactory } from './index'; 7 | 8 | interface TestState { 9 | foo: string; 10 | } 11 | 12 | describe(`issue #17`, () => { 13 | it(`should be able to return nothing (Promise)`, () => { 14 | const create = actionCreatorFactory(); 15 | const createAsync = asyncFactory(create); 16 | 17 | const example = createAsync('example', Promise.resolve); 18 | 19 | reducerWithoutInitialState().case(example.async.done, () => void 0); 20 | }); 21 | 22 | it(`should be able to return nothing (non-promise void)`, () => { 23 | const create = actionCreatorFactory(); 24 | const createAsync = asyncFactory(create); 25 | 26 | const example = createAsync('example', () => { 27 | /* noop */ 28 | }); 29 | 30 | reducerWithoutInitialState().case(example.async.done, () => void 0); 31 | }); 32 | 33 | it(`should be able to run normally (returning Promise)`, () => { 34 | const create = actionCreatorFactory(); 35 | const createAsync = asyncFactory(create); 36 | 37 | const example = createAsync( 38 | 'example', 39 | async (bar: string, dispatch, getState) => { 40 | return `${getState().foo} ${bar}`; 41 | }, 42 | ); 43 | 44 | reducerWithInitialState({ foo: 'foo' }).case( 45 | example.async.done, 46 | (state, { result }) => ({ foo: result }), 47 | ); 48 | }); 49 | 50 | it(`should be able to run normally (returning non-promise string)`, () => { 51 | const create = actionCreatorFactory(); 52 | const createAsync = asyncFactory(create); 53 | 54 | const example = createAsync( 55 | 'example', 56 | (bar: string, dispatch, getState) => { 57 | return `${getState().foo} ${bar}`; 58 | }, 59 | ); 60 | 61 | reducerWithoutInitialState().case( 62 | example.async.done, 63 | (state, { result }) => ({ foo: result }), 64 | ); 65 | }); 66 | }); 67 | -------------------------------------------------------------------------------- /src/issue-22.spec.ts: -------------------------------------------------------------------------------- 1 | import { expect } from 'chai'; 2 | import { AnyAction, applyMiddleware, createStore } from 'redux'; 3 | import thunk, { ThunkMiddleware } from 'redux-thunk'; 4 | import actionCreatorFactory from 'typescript-fsa'; 5 | import { reducerWithInitialState } from 'typescript-fsa-reducers'; 6 | import { asyncFactory } from './index'; 7 | 8 | /** Let this represent the thing we want as the extraArgument */ 9 | const FAKE_THING = { fake: 'thing' }; 10 | 11 | /** Initial application state */ 12 | const initialState = { 13 | someTest: { 14 | value: '', 15 | }, 16 | }; 17 | type State = typeof initialState; 18 | 19 | const create = actionCreatorFactory('test'); 20 | const createAsync = asyncFactory(create); 21 | 22 | const setStuff = createAsync( 23 | 'set stuff', 24 | async (params, dispatch, getState, extraArgument) => extraArgument, 25 | ); 26 | 27 | const reducer = reducerWithInitialState(initialState) 28 | .case(setStuff.async.done, (state, { result }) => ({ 29 | ...state, 30 | someTest: { 31 | value: result.fake, 32 | }, 33 | })) 34 | .build(); 35 | 36 | describe(`issue #22`, () => { 37 | it(`should be able to pass the extraArgument from middleware`, async () => { 38 | /** 39 | * You need to cast the type here, as the overload for withExtraArgument 40 | * is completely useless. 41 | */ 42 | const middleware: ThunkMiddleware = 43 | thunk.withExtraArgument(FAKE_THING); 44 | 45 | const store = createStore(reducer, applyMiddleware(middleware)); 46 | 47 | expect(store.getState()).to.eql(initialState); 48 | 49 | await store.dispatch(setStuff()); 50 | 51 | /** Verify that the extra arg was passed to the thunk */ 52 | expect(store.getState()).to.eql({ 53 | ...initialState, 54 | someTest: { 55 | value: FAKE_THING.fake, 56 | }, 57 | }); 58 | }); 59 | }); 60 | -------------------------------------------------------------------------------- /tsconfig.esm.json: -------------------------------------------------------------------------------- 1 | { 2 | "extends": "./tsconfig.json", 3 | "compilerOptions": { 4 | "module": "ES6", 5 | "outDir": "esm" 6 | } 7 | } 8 | -------------------------------------------------------------------------------- /tsconfig.json: -------------------------------------------------------------------------------- 1 | { 2 | "compilerOptions": { 3 | "target": "ES5", 4 | "module": "CommonJS", 5 | "moduleResolution": "node", 6 | "lib": ["ESNext"], 7 | "declaration": true, 8 | "declarationMap": true, 9 | "outDir": "lib", 10 | "strict": true, 11 | "noFallthroughCasesInSwitch": true, 12 | "noImplicitReturns": true, 13 | "noUnusedLocals": true, 14 | "sourceMap": true, 15 | "esModuleInterop": true 16 | }, 17 | "include": ["src"], 18 | "exclude": ["src/**/*.spec.ts", "src/examples.ts"] 19 | } 20 | -------------------------------------------------------------------------------- /tsconfig.tests.json: -------------------------------------------------------------------------------- 1 | { 2 | "extends": "./tsconfig.json", 3 | "compilerOptions": { 4 | "target": "ESNext" 5 | } 6 | } 7 | --------------------------------------------------------------------------------