├── .eslintrc.js ├── .github └── workflows │ └── npm-publish.yml ├── .gitignore ├── .npmignore ├── LICENSE ├── README.md ├── demo └── demo.html ├── images ├── demo.gif ├── kefu.jpg └── logo.png ├── package-lock.json ├── package.json ├── rollup.config.js └── src ├── form ├── forms.js └── table.js ├── index.js ├── probe ├── ajaxerr.js ├── fetcherr.js ├── jsonperr.js └── winerr.js ├── show ├── panel.js └── showpage.js └── util ├── device.js ├── scriptloader.js ├── storage.js ├── store.js └── util.js /.eslintrc.js: -------------------------------------------------------------------------------- 1 | // 根据环境设置error等级 2 | // 2-error,1-warning,0-off 3 | const level = process.env.NODE_ENV === 'production' ? 1 : 0; 4 | 5 | module.exports = { 6 | root: true, 7 | env: { 8 | node: true, 9 | }, 10 | extends: [ 11 | 'eslint:recommended', 12 | ], 13 | parserOptions: { 14 | ecmaVersion: 2020, 15 | createDefaultProgram: true, 16 | }, 17 | rules: { 18 | 'no-console': level, 19 | 'no-debugger': level, 20 | 'no-param-reassign': 0, 21 | 'no-underscore-dangle': "off", 22 | 'no-useless-escape': "off", 23 | 'no-restricted-syntax': "off", 24 | 'no-empty': "off", 25 | }, 26 | overrides: [ 27 | { 28 | files: ['**/__tests__/*.js', '**/tests/unit/**/*.spec.{j,t}s?(x)'], 29 | env: { 30 | jest: true, 31 | }, 32 | }, 33 | ], 34 | }; 35 | -------------------------------------------------------------------------------- /.github/workflows/npm-publish.yml: -------------------------------------------------------------------------------- 1 | # This workflow will run tests using node and then publish a package to GitHub Packages when a release is created 2 | # For more information see: https://help.github.com/actions/language-and-framework-guides/publishing-nodejs-packages 3 | 4 | name: Node.js Package 5 | 6 | on: 7 | release: 8 | types: [created] 9 | 10 | jobs: 11 | build: 12 | runs-on: ubuntu-latest 13 | steps: 14 | - uses: actions/checkout@v2 15 | - uses: actions/setup-node@v2 16 | with: 17 | node-version: 16 18 | - run: npm ci 19 | - run: npm run build 20 | 21 | publish-npm: 22 | needs: build 23 | runs-on: ubuntu-latest 24 | steps: 25 | - uses: actions/checkout@v2 26 | - uses: actions/setup-node@v2 27 | with: 28 | node-version: 16 29 | registry-url: https://registry.npmjs.org/ 30 | - run: npm ci 31 | - run: npm run build 32 | - run: npm publish 33 | env: 34 | NODE_AUTH_TOKEN: ${{secrets.npm_token}} 35 | -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | # IDEs and editors 2 | .idea 3 | .vscode/* 4 | 5 | # Logs 6 | logs 7 | *.log 8 | npm-debug.log* 9 | yarn-debug.log* 10 | yarn-error.log* 11 | 12 | # Lerna 13 | lerna-debug.log 14 | 15 | # System Files 16 | .DS_Store 17 | Thumbs.db 18 | 19 | # node modules 20 | node_modules 21 | 22 | # build output 23 | dist 24 | -------------------------------------------------------------------------------- /.npmignore: -------------------------------------------------------------------------------- 1 | .idea 2 | src 3 | demo 4 | node_modules 5 | -------------------------------------------------------------------------------- /LICENSE: -------------------------------------------------------------------------------- 1 | MIT License 2 | 3 | Copyright (c) 2021 TNFE 4 | 5 | Permission is hereby granted, free of charge, to any person obtaining a copy 6 | of this software and associated documentation files (the "Software"), to deal 7 | in the Software without restriction, including without limitation the rights 8 | to use, copy, modify, merge, publish, distribute, sublicense, and/or sell 9 | copies of the Software, and to permit persons to whom the Software is 10 | furnished to do so, subject to the following conditions: 11 | 12 | The above copyright notice and this permission notice shall be included in all 13 | copies or substantial portions of the Software. 14 | 15 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 16 | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 17 | FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 18 | AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 19 | LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, 20 | OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE 21 | SOFTWARE. 22 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 |

2 | logo 3 |

4 | 5 |
6 |

7 |

CSI.JS 重建犯罪现场

8 |

9 | CSI.JS是一个前端日志系统,它将错误信息记录于本地localStorage中。无任何依赖、无入侵性。使用非常简单,很容易引入你的系统中,而且不会造成任何影响。 10 | 它可以帮你快速重建犯罪现场。 11 |
12 |
13 |

14 |

15 |
16 | Package License 17 | Code Style 18 | PRs 19 | Node Version 20 |
21 |
22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 | 32 | 33 | 34 | 35 |

无入侵

轻量易用

功能强大

高性能

丢上去不管,我们承诺永不入侵你的业务!兼容各种系统,不管你使用的是jQuery、angular1/2、React、Vue,都可以使用它完善的查错机制,截图预览、导出excel、直接上传到后台查看等文件超小,Gzip 5k对你几乎毫无影响
36 | 37 |

38 | kefu 39 |

40 | 41 | ![](https://raw.githubusercontent.com/tnfe/csijs/master/images/demo.gif) 42 | 43 | 44 | ## 一、快速开始 45 | 46 | ### 1、npm安装 47 | ```shell script 48 | npm i csijs --save 49 | or 50 | yarn add csijs 51 | ``` 52 | 53 | ### 2、使用 54 | ```javascript 55 | import CSI from 'csijs'; 56 | 57 | // 示例:自定义上报 58 | const csi = new CSI({ 59 | feID: '', // 项目id,日志区分项目使用 60 | report: (lines) => { 61 | // todo 自定义你的上报逻辑 62 | console.log('error lins', lines); 63 | }, 64 | }); 65 | 66 | // 如果你想主动上报 67 | csi.report(); 68 | ``` 69 | 70 | ## 二、日志查看 71 | 72 | 查看日志快捷键: Ctrl+6 73 | 74 | 75 | ## 三、本地开发 76 | 77 | ```shell 78 | // 本地开发 79 | npm run start 80 | // 发布环境 81 | npm run build 82 | ``` 83 | 84 | ## 四、MR 流程 85 | 86 | TNTWeb 团队会查看所有的 MR,我们会运行一些代码检查和测试,一经测试通过,我们会接受这次 MR,但不会立即发布外网,会有一些延迟。 87 | 88 | 当您准备 MR 时,请确保已经完成以下几个步骤: 89 | 90 | 1. 将主仓库代码 Fork 到自己名下。 91 | 1. 基于 `master` 分支创建您的开发分支。 92 | 1. 如果您更改了 API(s) 请更新代码及文档。 93 | 1. 检查您的代码语法及格式。 94 | 1. 提一个 MR 到主仓库的 `master` 分支上。 95 | 96 | ## 五、如何加入 97 | 98 | 我们十分期待您的任何贡献,无论是修复错别字、提 Bug 还是提交一个新的特性。 99 | 100 | 如果您使用过程中发现 Bug,请通过 [issues](https://github.com/tnfe/csijs/issues) 来提交并描述相关的问题,您也可以在这里查看其它的 issue,通过解决这些 issue 来贡献代码。 101 | 102 | 如果您是第一次贡献代码,请阅读 [CONTRIBUTING](https://github.com/tnfe/csijs/blob/master/contribution) 了解我们的贡献流程,并提交 Merge Request 给我们。 103 | 104 | ## 六、License 105 | The MIT License (MIT). Please see [License File](https://github.com/tnfe/csijs/blob/master/LICENSE) for more information. 106 | -------------------------------------------------------------------------------- /demo/demo.html: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | 10 | T.E.S.T 11 | 34 | 35 | 36 | 37 |

csijs前端日志系统,测试网页地址

38 |
39 |
制造错误
40 |
发送日志
41 |
42 | 43 | 61 | 62 | -------------------------------------------------------------------------------- /images/demo.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/aliaszz/csijs/4f6deb48b5e8d2a60cfe0ed0f49556da6298df12/images/demo.gif -------------------------------------------------------------------------------- /images/kefu.jpg: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/aliaszz/csijs/4f6deb48b5e8d2a60cfe0ed0f49556da6298df12/images/kefu.jpg -------------------------------------------------------------------------------- /images/logo.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/aliaszz/csijs/4f6deb48b5e8d2a60cfe0ed0f49556da6298df12/images/logo.png -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "csijs", 3 | "version": "1.0.9", 4 | "lockfileVersion": 1, 5 | "requires": true, 6 | "dependencies": { 7 | "@babel/code-frame": { 8 | "version": "7.16.0", 9 | "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.16.0.tgz", 10 | "integrity": "sha512-IF4EOMEV+bfYwOmNxGzSnjR2EmQod7f1UXOpZM3l4i4o4QNwzjtJAu/HxdjHq0aYBvdqMuQEY1eg0nqW9ZPORA==", 11 | "dev": true, 12 | "requires": { 13 | "@babel/highlight": "^7.16.0" 14 | } 15 | }, 16 | "@babel/compat-data": { 17 | "version": "7.16.4", 18 | "resolved": "https://registry.npmjs.org/@babel/compat-data/-/compat-data-7.16.4.tgz", 19 | "integrity": "sha512-1o/jo7D+kC9ZjHX5v+EHrdjl3PhxMrLSOTGsOdHJ+KL8HCaEK6ehrVL2RS6oHDZp+L7xLirLrPmQtEng769J/Q==", 20 | "dev": true 21 | }, 22 | "@babel/core": { 23 | "version": "7.16.0", 24 | "resolved": "https://registry.npmjs.org/@babel/core/-/core-7.16.0.tgz", 25 | "integrity": "sha512-mYZEvshBRHGsIAiyH5PzCFTCfbWfoYbO/jcSdXQSUQu1/pW0xDZAUP7KEc32heqWTAfAHhV9j1vH8Sav7l+JNQ==", 26 | "dev": true, 27 | "requires": { 28 | "@babel/code-frame": "^7.16.0", 29 | "@babel/generator": "^7.16.0", 30 | "@babel/helper-compilation-targets": "^7.16.0", 31 | "@babel/helper-module-transforms": "^7.16.0", 32 | "@babel/helpers": "^7.16.0", 33 | "@babel/parser": "^7.16.0", 34 | "@babel/template": "^7.16.0", 35 | "@babel/traverse": "^7.16.0", 36 | "@babel/types": "^7.16.0", 37 | "convert-source-map": "^1.7.0", 38 | "debug": "^4.1.0", 39 | "gensync": "^1.0.0-beta.2", 40 | "json5": "^2.1.2", 41 | "semver": "^6.3.0", 42 | "source-map": "^0.5.0" 43 | } 44 | }, 45 | "@babel/generator": { 46 | "version": "7.16.0", 47 | "resolved": "https://registry.npmjs.org/@babel/generator/-/generator-7.16.0.tgz", 48 | "integrity": "sha512-RR8hUCfRQn9j9RPKEVXo9LiwoxLPYn6hNZlvUOR8tSnaxlD0p0+la00ZP9/SnRt6HchKr+X0fO2r8vrETiJGew==", 49 | "dev": true, 50 | "requires": { 51 | "@babel/types": "^7.16.0", 52 | "jsesc": "^2.5.1", 53 | "source-map": "^0.5.0" 54 | } 55 | }, 56 | "@babel/helper-compilation-targets": { 57 | "version": "7.16.3", 58 | "resolved": "https://registry.npmjs.org/@babel/helper-compilation-targets/-/helper-compilation-targets-7.16.3.tgz", 59 | "integrity": "sha512-vKsoSQAyBmxS35JUOOt+07cLc6Nk/2ljLIHwmq2/NM6hdioUaqEXq/S+nXvbvXbZkNDlWOymPanJGOc4CBjSJA==", 60 | "dev": true, 61 | "requires": { 62 | "@babel/compat-data": "^7.16.0", 63 | "@babel/helper-validator-option": "^7.14.5", 64 | "browserslist": "^4.17.5", 65 | "semver": "^6.3.0" 66 | } 67 | }, 68 | "@babel/helper-function-name": { 69 | "version": "7.16.0", 70 | "resolved": "https://registry.npmjs.org/@babel/helper-function-name/-/helper-function-name-7.16.0.tgz", 71 | "integrity": "sha512-BZh4mEk1xi2h4HFjWUXRQX5AEx4rvaZxHgax9gcjdLWdkjsY7MKt5p0otjsg5noXw+pB+clMCjw+aEVYADMjog==", 72 | "dev": true, 73 | "requires": { 74 | "@babel/helper-get-function-arity": "^7.16.0", 75 | "@babel/template": "^7.16.0", 76 | "@babel/types": "^7.16.0" 77 | } 78 | }, 79 | "@babel/helper-get-function-arity": { 80 | "version": "7.16.0", 81 | "resolved": "https://registry.npmjs.org/@babel/helper-get-function-arity/-/helper-get-function-arity-7.16.0.tgz", 82 | "integrity": "sha512-ASCquNcywC1NkYh/z7Cgp3w31YW8aojjYIlNg4VeJiHkqyP4AzIvr4qx7pYDb4/s8YcsZWqqOSxgkvjUz1kpDQ==", 83 | "dev": true, 84 | "requires": { 85 | "@babel/types": "^7.16.0" 86 | } 87 | }, 88 | "@babel/helper-hoist-variables": { 89 | "version": "7.16.0", 90 | "resolved": "https://registry.npmjs.org/@babel/helper-hoist-variables/-/helper-hoist-variables-7.16.0.tgz", 91 | "integrity": "sha512-1AZlpazjUR0EQZQv3sgRNfM9mEVWPK3M6vlalczA+EECcPz3XPh6VplbErL5UoMpChhSck5wAJHthlj1bYpcmg==", 92 | "dev": true, 93 | "requires": { 94 | "@babel/types": "^7.16.0" 95 | } 96 | }, 97 | "@babel/helper-member-expression-to-functions": { 98 | "version": "7.16.0", 99 | "resolved": "https://registry.npmjs.org/@babel/helper-member-expression-to-functions/-/helper-member-expression-to-functions-7.16.0.tgz", 100 | "integrity": "sha512-bsjlBFPuWT6IWhl28EdrQ+gTvSvj5tqVP5Xeftp07SEuz5pLnsXZuDkDD3Rfcxy0IsHmbZ+7B2/9SHzxO0T+sQ==", 101 | "dev": true, 102 | "requires": { 103 | "@babel/types": "^7.16.0" 104 | } 105 | }, 106 | "@babel/helper-module-imports": { 107 | "version": "7.16.0", 108 | "resolved": "https://registry.npmjs.org/@babel/helper-module-imports/-/helper-module-imports-7.16.0.tgz", 109 | "integrity": "sha512-kkH7sWzKPq0xt3H1n+ghb4xEMP8k0U7XV3kkB+ZGy69kDk2ySFW1qPi06sjKzFY3t1j6XbJSqr4mF9L7CYVyhg==", 110 | "dev": true, 111 | "requires": { 112 | "@babel/types": "^7.16.0" 113 | } 114 | }, 115 | "@babel/helper-module-transforms": { 116 | "version": "7.16.0", 117 | "resolved": "https://registry.npmjs.org/@babel/helper-module-transforms/-/helper-module-transforms-7.16.0.tgz", 118 | "integrity": "sha512-My4cr9ATcaBbmaEa8M0dZNA74cfI6gitvUAskgDtAFmAqyFKDSHQo5YstxPbN+lzHl2D9l/YOEFqb2mtUh4gfA==", 119 | "dev": true, 120 | "requires": { 121 | "@babel/helper-module-imports": "^7.16.0", 122 | "@babel/helper-replace-supers": "^7.16.0", 123 | "@babel/helper-simple-access": "^7.16.0", 124 | "@babel/helper-split-export-declaration": "^7.16.0", 125 | "@babel/helper-validator-identifier": "^7.15.7", 126 | "@babel/template": "^7.16.0", 127 | "@babel/traverse": "^7.16.0", 128 | "@babel/types": "^7.16.0" 129 | } 130 | }, 131 | "@babel/helper-optimise-call-expression": { 132 | "version": "7.16.0", 133 | "resolved": "https://registry.npmjs.org/@babel/helper-optimise-call-expression/-/helper-optimise-call-expression-7.16.0.tgz", 134 | "integrity": "sha512-SuI467Gi2V8fkofm2JPnZzB/SUuXoJA5zXe/xzyPP2M04686RzFKFHPK6HDVN6JvWBIEW8tt9hPR7fXdn2Lgpw==", 135 | "dev": true, 136 | "requires": { 137 | "@babel/types": "^7.16.0" 138 | } 139 | }, 140 | "@babel/helper-replace-supers": { 141 | "version": "7.16.0", 142 | "resolved": "https://registry.npmjs.org/@babel/helper-replace-supers/-/helper-replace-supers-7.16.0.tgz", 143 | "integrity": "sha512-TQxuQfSCdoha7cpRNJvfaYxxxzmbxXw/+6cS7V02eeDYyhxderSoMVALvwupA54/pZcOTtVeJ0xccp1nGWladA==", 144 | "dev": true, 145 | "requires": { 146 | "@babel/helper-member-expression-to-functions": "^7.16.0", 147 | "@babel/helper-optimise-call-expression": "^7.16.0", 148 | "@babel/traverse": "^7.16.0", 149 | "@babel/types": "^7.16.0" 150 | } 151 | }, 152 | "@babel/helper-simple-access": { 153 | "version": "7.16.0", 154 | "resolved": "https://registry.npmjs.org/@babel/helper-simple-access/-/helper-simple-access-7.16.0.tgz", 155 | "integrity": "sha512-o1rjBT/gppAqKsYfUdfHq5Rk03lMQrkPHG1OWzHWpLgVXRH4HnMM9Et9CVdIqwkCQlobnGHEJMsgWP/jE1zUiw==", 156 | "dev": true, 157 | "requires": { 158 | "@babel/types": "^7.16.0" 159 | } 160 | }, 161 | "@babel/helper-split-export-declaration": { 162 | "version": "7.16.0", 163 | "resolved": "https://registry.npmjs.org/@babel/helper-split-export-declaration/-/helper-split-export-declaration-7.16.0.tgz", 164 | "integrity": "sha512-0YMMRpuDFNGTHNRiiqJX19GjNXA4H0E8jZ2ibccfSxaCogbm3am5WN/2nQNj0YnQwGWM1J06GOcQ2qnh3+0paw==", 165 | "dev": true, 166 | "requires": { 167 | "@babel/types": "^7.16.0" 168 | } 169 | }, 170 | "@babel/helper-validator-identifier": { 171 | "version": "7.15.7", 172 | "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.15.7.tgz", 173 | "integrity": "sha512-K4JvCtQqad9OY2+yTU8w+E82ywk/fe+ELNlt1G8z3bVGlZfn/hOcQQsUhGhW/N+tb3fxK800wLtKOE/aM0m72w==", 174 | "dev": true 175 | }, 176 | "@babel/helper-validator-option": { 177 | "version": "7.14.5", 178 | "resolved": "https://registry.npmjs.org/@babel/helper-validator-option/-/helper-validator-option-7.14.5.tgz", 179 | "integrity": "sha512-OX8D5eeX4XwcroVW45NMvoYaIuFI+GQpA2a8Gi+X/U/cDUIRsV37qQfF905F0htTRCREQIB4KqPeaveRJUl3Ow==", 180 | "dev": true 181 | }, 182 | "@babel/helpers": { 183 | "version": "7.16.3", 184 | "resolved": "https://registry.npmjs.org/@babel/helpers/-/helpers-7.16.3.tgz", 185 | "integrity": "sha512-Xn8IhDlBPhvYTvgewPKawhADichOsbkZuzN7qz2BusOM0brChsyXMDJvldWaYMMUNiCQdQzNEioXTp3sC8Nt8w==", 186 | "dev": true, 187 | "requires": { 188 | "@babel/template": "^7.16.0", 189 | "@babel/traverse": "^7.16.3", 190 | "@babel/types": "^7.16.0" 191 | } 192 | }, 193 | "@babel/highlight": { 194 | "version": "7.16.0", 195 | "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.16.0.tgz", 196 | "integrity": "sha512-t8MH41kUQylBtu2+4IQA3atqevA2lRgqA2wyVB/YiWmsDSuylZZuXOUy9ric30hfzauEFfdsuk/eXTRrGrfd0g==", 197 | "dev": true, 198 | "requires": { 199 | "@babel/helper-validator-identifier": "^7.15.7", 200 | "chalk": "^2.0.0", 201 | "js-tokens": "^4.0.0" 202 | } 203 | }, 204 | "@babel/parser": { 205 | "version": "7.16.4", 206 | "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.16.4.tgz", 207 | "integrity": "sha512-6V0qdPUaiVHH3RtZeLIsc+6pDhbYzHR8ogA8w+f+Wc77DuXto19g2QUwveINoS34Uw+W8/hQDGJCx+i4n7xcng==", 208 | "dev": true 209 | }, 210 | "@babel/template": { 211 | "version": "7.16.0", 212 | "resolved": "https://registry.npmjs.org/@babel/template/-/template-7.16.0.tgz", 213 | "integrity": "sha512-MnZdpFD/ZdYhXwiunMqqgyZyucaYsbL0IrjoGjaVhGilz+x8YB++kRfygSOIj1yOtWKPlx7NBp+9I1RQSgsd5A==", 214 | "dev": true, 215 | "requires": { 216 | "@babel/code-frame": "^7.16.0", 217 | "@babel/parser": "^7.16.0", 218 | "@babel/types": "^7.16.0" 219 | } 220 | }, 221 | "@babel/traverse": { 222 | "version": "7.16.3", 223 | "resolved": "https://registry.npmjs.org/@babel/traverse/-/traverse-7.16.3.tgz", 224 | "integrity": "sha512-eolumr1vVMjqevCpwVO99yN/LoGL0EyHiLO5I043aYQvwOJ9eR5UsZSClHVCzfhBduMAsSzgA/6AyqPjNayJag==", 225 | "dev": true, 226 | "requires": { 227 | "@babel/code-frame": "^7.16.0", 228 | "@babel/generator": "^7.16.0", 229 | "@babel/helper-function-name": "^7.16.0", 230 | "@babel/helper-hoist-variables": "^7.16.0", 231 | "@babel/helper-split-export-declaration": "^7.16.0", 232 | "@babel/parser": "^7.16.3", 233 | "@babel/types": "^7.16.0", 234 | "debug": "^4.1.0", 235 | "globals": "^11.1.0" 236 | } 237 | }, 238 | "@babel/types": { 239 | "version": "7.16.0", 240 | "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.16.0.tgz", 241 | "integrity": "sha512-PJgg/k3SdLsGb3hhisFvtLOw5ts113klrpLuIPtCJIU+BB24fqq6lf8RWqKJEjzqXR9AEH1rIb5XTqwBHB+kQg==", 242 | "dev": true, 243 | "requires": { 244 | "@babel/helper-validator-identifier": "^7.15.7", 245 | "to-fast-properties": "^2.0.0" 246 | } 247 | }, 248 | "@eslint/eslintrc": { 249 | "version": "0.4.3", 250 | "resolved": "https://registry.npmjs.org/@eslint/eslintrc/-/eslintrc-0.4.3.tgz", 251 | "integrity": "sha512-J6KFFz5QCYUJq3pf0mjEcCJVERbzv71PUIDczuh9JkwGEzced6CO5ADLHB1rbf/+oPBtoPfMYNOpGDzCANlbXw==", 252 | "dev": true, 253 | "requires": { 254 | "ajv": "^6.12.4", 255 | "debug": "^4.1.1", 256 | "espree": "^7.3.0", 257 | "globals": "^13.9.0", 258 | "ignore": "^4.0.6", 259 | "import-fresh": "^3.2.1", 260 | "js-yaml": "^3.13.1", 261 | "minimatch": "^3.0.4", 262 | "strip-json-comments": "^3.1.1" 263 | }, 264 | "dependencies": { 265 | "globals": { 266 | "version": "13.12.0", 267 | "resolved": "https://registry.npmjs.org/globals/-/globals-13.12.0.tgz", 268 | "integrity": "sha512-uS8X6lSKN2JumVoXrbUz+uG4BYG+eiawqm3qFcT7ammfbUHeCBoJMlHcec/S3krSk73/AE/f0szYFmgAA3kYZg==", 269 | "dev": true, 270 | "requires": { 271 | "type-fest": "^0.20.2" 272 | } 273 | } 274 | } 275 | }, 276 | "@humanwhocodes/config-array": { 277 | "version": "0.5.0", 278 | "resolved": "https://registry.npmjs.org/@humanwhocodes/config-array/-/config-array-0.5.0.tgz", 279 | "integrity": "sha512-FagtKFz74XrTl7y6HCzQpwDfXP0yhxe9lHLD1UZxjvZIcbyRz8zTFF/yYNfSfzU414eDwZ1SrO0Qvtyf+wFMQg==", 280 | "dev": true, 281 | "requires": { 282 | "@humanwhocodes/object-schema": "^1.2.0", 283 | "debug": "^4.1.1", 284 | "minimatch": "^3.0.4" 285 | } 286 | }, 287 | "@humanwhocodes/object-schema": { 288 | "version": "1.2.1", 289 | "resolved": "https://registry.npmjs.org/@humanwhocodes/object-schema/-/object-schema-1.2.1.tgz", 290 | "integrity": "sha512-ZnQMnLV4e7hDlUvw8H+U8ASL02SS2Gn6+9Ac3wGGLIe7+je2AeAOxPY+izIPJDfFDb7eDjev0Us8MO1iFRN8hA==", 291 | "dev": true 292 | }, 293 | "@rollup/plugin-babel": { 294 | "version": "5.3.0", 295 | "resolved": "https://registry.npmjs.org/@rollup/plugin-babel/-/plugin-babel-5.3.0.tgz", 296 | "integrity": "sha512-9uIC8HZOnVLrLHxayq/PTzw+uS25E14KPUBh5ktF+18Mjo5yK0ToMMx6epY0uEgkjwJw0aBW4x2horYXh8juWw==", 297 | "dev": true, 298 | "requires": { 299 | "@babel/helper-module-imports": "^7.10.4", 300 | "@rollup/pluginutils": "^3.1.0" 301 | } 302 | }, 303 | "@rollup/plugin-commonjs": { 304 | "version": "18.1.0", 305 | "resolved": "https://registry.npmjs.org/@rollup/plugin-commonjs/-/plugin-commonjs-18.1.0.tgz", 306 | "integrity": "sha512-h3e6T9rUxVMAQswpDIobfUHn/doMzM9sgkMrsMWCFLmB84PSoC8mV8tOloAJjSRwdqhXBqstlX2BwBpHJvbhxg==", 307 | "dev": true, 308 | "requires": { 309 | "@rollup/pluginutils": "^3.1.0", 310 | "commondir": "^1.0.1", 311 | "estree-walker": "^2.0.1", 312 | "glob": "^7.1.6", 313 | "is-reference": "^1.2.1", 314 | "magic-string": "^0.25.7", 315 | "resolve": "^1.17.0" 316 | }, 317 | "dependencies": { 318 | "estree-walker": { 319 | "version": "2.0.2", 320 | "resolved": "https://registry.npmjs.org/estree-walker/-/estree-walker-2.0.2.tgz", 321 | "integrity": "sha512-Rfkk/Mp/DL7JVje3u18FxFujQlTNR2q6QfMSMB7AvCBx91NGj/ba3kCfza0f6dVDbw7YlRf/nDrn7pQrCCyQ/w==", 322 | "dev": true 323 | } 324 | } 325 | }, 326 | "@rollup/plugin-node-resolve": { 327 | "version": "13.0.6", 328 | "resolved": "https://registry.npmjs.org/@rollup/plugin-node-resolve/-/plugin-node-resolve-13.0.6.tgz", 329 | "integrity": "sha512-sFsPDMPd4gMqnh2gS0uIxELnoRUp5kBl5knxD2EO0778G1oOJv4G1vyT2cpWz75OU2jDVcXhjVUuTAczGyFNKA==", 330 | "dev": true, 331 | "requires": { 332 | "@rollup/pluginutils": "^3.1.0", 333 | "@types/resolve": "1.17.1", 334 | "builtin-modules": "^3.1.0", 335 | "deepmerge": "^4.2.2", 336 | "is-module": "^1.0.0", 337 | "resolve": "^1.19.0" 338 | } 339 | }, 340 | "@rollup/pluginutils": { 341 | "version": "3.1.0", 342 | "resolved": "https://registry.npmjs.org/@rollup/pluginutils/-/pluginutils-3.1.0.tgz", 343 | "integrity": "sha512-GksZ6pr6TpIjHm8h9lSQ8pi8BE9VeubNT0OMJ3B5uZJ8pz73NPiqOtCog/x2/QzM1ENChPKxMDhiQuRHsqc+lg==", 344 | "dev": true, 345 | "requires": { 346 | "@types/estree": "0.0.39", 347 | "estree-walker": "^1.0.1", 348 | "picomatch": "^2.2.2" 349 | } 350 | }, 351 | "@types/estree": { 352 | "version": "0.0.39", 353 | "resolved": "https://registry.npmjs.org/@types/estree/-/estree-0.0.39.tgz", 354 | "integrity": "sha512-EYNwp3bU+98cpU4lAWYYL7Zz+2gryWH1qbdDTidVd6hkiR6weksdbMadyXKXNPEkQFhXM+hVO9ZygomHXp+AIw==", 355 | "dev": true 356 | }, 357 | "@types/node": { 358 | "version": "16.11.11", 359 | "resolved": "https://registry.npmjs.org/@types/node/-/node-16.11.11.tgz", 360 | "integrity": "sha512-KB0sixD67CeecHC33MYn+eYARkqTheIRNuu97y2XMjR7Wu3XibO1vaY6VBV6O/a89SPI81cEUIYT87UqUWlZNw==", 361 | "dev": true 362 | }, 363 | "@types/resolve": { 364 | "version": "1.17.1", 365 | "resolved": "https://registry.npmjs.org/@types/resolve/-/resolve-1.17.1.tgz", 366 | "integrity": "sha512-yy7HuzQhj0dhGpD8RLXSZWEkLsV9ibvxvi6EiJ3bkqLAO1RGo0WbkWQiwpRlSFymTJRz0d3k5LM3kkx8ArDbLw==", 367 | "dev": true, 368 | "requires": { 369 | "@types/node": "*" 370 | } 371 | }, 372 | "acorn": { 373 | "version": "7.4.1", 374 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-7.4.1.tgz", 375 | "integrity": "sha512-nQyp0o1/mNdbTO1PO6kHkwSrmgZ0MT/jCCpNiwbUjGoRN4dlBhqJtoQuCnEOKzgTVwg0ZWiCoQy6SxMebQVh8A==", 376 | "dev": true 377 | }, 378 | "acorn-jsx": { 379 | "version": "5.3.2", 380 | "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.3.2.tgz", 381 | "integrity": "sha512-rq9s+JNhf0IChjtDXxllJ7g41oZk5SlXtp0LHwyA5cejwn7vKmKp4pPri6YEePv2PU65sAsegbXtIinmDFDXgQ==", 382 | "dev": true 383 | }, 384 | "ajv": { 385 | "version": "6.12.6", 386 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.12.6.tgz", 387 | "integrity": "sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g==", 388 | "dev": true, 389 | "requires": { 390 | "fast-deep-equal": "^3.1.1", 391 | "fast-json-stable-stringify": "^2.0.0", 392 | "json-schema-traverse": "^0.4.1", 393 | "uri-js": "^4.2.2" 394 | } 395 | }, 396 | "ansi-colors": { 397 | "version": "4.1.1", 398 | "resolved": "https://registry.npmjs.org/ansi-colors/-/ansi-colors-4.1.1.tgz", 399 | "integrity": "sha512-JoX0apGbHaUJBNl6yF+p6JAFYZ666/hhCGKN5t9QFjbJQKUU/g8MNbFDbvfrgKXvI1QpZplPOnwIo99lX/AAmA==", 400 | "dev": true 401 | }, 402 | "ansi-regex": { 403 | "version": "5.0.1", 404 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 405 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 406 | "dev": true 407 | }, 408 | "ansi-styles": { 409 | "version": "3.2.1", 410 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", 411 | "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", 412 | "dev": true, 413 | "requires": { 414 | "color-convert": "^1.9.0" 415 | } 416 | }, 417 | "argparse": { 418 | "version": "1.0.10", 419 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-1.0.10.tgz", 420 | "integrity": "sha512-o5Roy6tNG4SL/FOkCAN6RzjiakZS25RLYFrcMttJqbdd8BWrnA+fGz57iN5Pb06pvBGvl5gQ0B48dJlslXvoTg==", 421 | "dev": true, 422 | "requires": { 423 | "sprintf-js": "~1.0.2" 424 | } 425 | }, 426 | "astral-regex": { 427 | "version": "2.0.0", 428 | "resolved": "https://registry.npmjs.org/astral-regex/-/astral-regex-2.0.0.tgz", 429 | "integrity": "sha512-Z7tMw1ytTXt5jqMcOP+OQteU1VuNK9Y02uuJtKQ1Sv69jXQKKg5cibLwGJow8yzZP+eAc18EmLGPal0bp36rvQ==", 430 | "dev": true 431 | }, 432 | "balanced-match": { 433 | "version": "1.0.2", 434 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", 435 | "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==", 436 | "dev": true 437 | }, 438 | "brace-expansion": { 439 | "version": "1.1.11", 440 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 441 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 442 | "dev": true, 443 | "requires": { 444 | "balanced-match": "^1.0.0", 445 | "concat-map": "0.0.1" 446 | } 447 | }, 448 | "browserslist": { 449 | "version": "4.18.1", 450 | "resolved": "https://registry.npmjs.org/browserslist/-/browserslist-4.18.1.tgz", 451 | "integrity": "sha512-8ScCzdpPwR2wQh8IT82CA2VgDwjHyqMovPBZSNH54+tm4Jk2pCuv90gmAdH6J84OCRWi0b4gMe6O6XPXuJnjgQ==", 452 | "dev": true, 453 | "requires": { 454 | "caniuse-lite": "^1.0.30001280", 455 | "electron-to-chromium": "^1.3.896", 456 | "escalade": "^3.1.1", 457 | "node-releases": "^2.0.1", 458 | "picocolors": "^1.0.0" 459 | } 460 | }, 461 | "buffer-from": { 462 | "version": "1.1.2", 463 | "resolved": "https://registry.npmjs.org/buffer-from/-/buffer-from-1.1.2.tgz", 464 | "integrity": "sha512-E+XQCRwSbaaiChtv6k6Dwgc+bx+Bs6vuKJHHl5kox/BaKbhiXzqQOwK4cO22yElGp2OCmjwVhT3HmxgyPGnJfQ==", 465 | "dev": true 466 | }, 467 | "builtin-modules": { 468 | "version": "3.2.0", 469 | "resolved": "https://registry.npmjs.org/builtin-modules/-/builtin-modules-3.2.0.tgz", 470 | "integrity": "sha512-lGzLKcioL90C7wMczpkY0n/oART3MbBa8R9OFGE1rJxoVI86u4WAGfEk8Wjv10eKSyTHVGkSo3bvBylCEtk7LA==", 471 | "dev": true 472 | }, 473 | "callsites": { 474 | "version": "3.1.0", 475 | "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz", 476 | "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==", 477 | "dev": true 478 | }, 479 | "caniuse-lite": { 480 | "version": "1.0.30001283", 481 | "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001283.tgz", 482 | "integrity": "sha512-9RoKo841j1GQFSJz/nCXOj0sD7tHBtlowjYlrqIUS812x9/emfBLBt6IyMz1zIaYc/eRL8Cs6HPUVi2Hzq4sIg==", 483 | "dev": true 484 | }, 485 | "chalk": { 486 | "version": "2.4.2", 487 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", 488 | "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", 489 | "dev": true, 490 | "requires": { 491 | "ansi-styles": "^3.2.1", 492 | "escape-string-regexp": "^1.0.5", 493 | "supports-color": "^5.3.0" 494 | } 495 | }, 496 | "color-convert": { 497 | "version": "1.9.3", 498 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", 499 | "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", 500 | "dev": true, 501 | "requires": { 502 | "color-name": "1.1.3" 503 | } 504 | }, 505 | "color-name": { 506 | "version": "1.1.3", 507 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", 508 | "integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=", 509 | "dev": true 510 | }, 511 | "commander": { 512 | "version": "2.20.3", 513 | "resolved": "https://registry.npmjs.org/commander/-/commander-2.20.3.tgz", 514 | "integrity": "sha512-GpVkmM8vF2vQUkj2LvZmD35JxeJOLCwJ9cUkugyk2nuhbv3+mJvpLYYt+0+USMxE+oj+ey/lJEnhZw75x/OMcQ==", 515 | "dev": true 516 | }, 517 | "commondir": { 518 | "version": "1.0.1", 519 | "resolved": "https://registry.npmjs.org/commondir/-/commondir-1.0.1.tgz", 520 | "integrity": "sha1-3dgA2gxmEnOTzKWVDqloo6rxJTs=", 521 | "dev": true 522 | }, 523 | "concat-map": { 524 | "version": "0.0.1", 525 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 526 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=", 527 | "dev": true 528 | }, 529 | "convert-source-map": { 530 | "version": "1.8.0", 531 | "resolved": "https://registry.npmjs.org/convert-source-map/-/convert-source-map-1.8.0.tgz", 532 | "integrity": "sha512-+OQdjP49zViI/6i7nIJpA8rAl4sV/JdPfU9nZs3VqOwGIgizICvuN2ru6fMd+4llL0tar18UYJXfZ/TWtmhUjA==", 533 | "dev": true, 534 | "requires": { 535 | "safe-buffer": "~5.1.1" 536 | } 537 | }, 538 | "cross-spawn": { 539 | "version": "7.0.3", 540 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz", 541 | "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==", 542 | "dev": true, 543 | "requires": { 544 | "path-key": "^3.1.0", 545 | "shebang-command": "^2.0.0", 546 | "which": "^2.0.1" 547 | } 548 | }, 549 | "debug": { 550 | "version": "4.3.3", 551 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.3.tgz", 552 | "integrity": "sha512-/zxw5+vh1Tfv+4Qn7a5nsbcJKPaSvCDhojn6FEl9vupwK2VCSDtEiEtqr8DFtzYFOdz63LBkxec7DYuc2jon6Q==", 553 | "dev": true, 554 | "requires": { 555 | "ms": "2.1.2" 556 | } 557 | }, 558 | "deep-is": { 559 | "version": "0.1.4", 560 | "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.4.tgz", 561 | "integrity": "sha512-oIPzksmTg4/MriiaYGO+okXDT7ztn/w3Eptv/+gSIdMdKsJo0u4CfYNFJPy+4SKMuCqGw2wxnA+URMg3t8a/bQ==", 562 | "dev": true 563 | }, 564 | "deepmerge": { 565 | "version": "4.2.2", 566 | "resolved": "https://registry.npmjs.org/deepmerge/-/deepmerge-4.2.2.tgz", 567 | "integrity": "sha512-FJ3UgI4gIl+PHZm53knsuSFpE+nESMr7M4v9QcgB7S63Kj/6WqMiFQJpBBYz1Pt+66bZpP3Q7Lye0Oo9MPKEdg==", 568 | "dev": true 569 | }, 570 | "doctrine": { 571 | "version": "3.0.0", 572 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-3.0.0.tgz", 573 | "integrity": "sha512-yS+Q5i3hBf7GBkd4KG8a7eBNNWNGLTaEwwYWUijIYM7zrlYDM0BFXHjjPWlWZ1Rg7UaddZeIDmi9jF3HmqiQ2w==", 574 | "dev": true, 575 | "requires": { 576 | "esutils": "^2.0.2" 577 | } 578 | }, 579 | "electron-to-chromium": { 580 | "version": "1.4.8", 581 | "resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.4.8.tgz", 582 | "integrity": "sha512-Cu5+dbg55+1E3ohlsa8HT0s4b8D0gBewXEGG8s5wBl8ynWv60VuvYW25GpsOeTVXpulhyU/U8JYZH+yxASSJBQ==", 583 | "dev": true 584 | }, 585 | "emoji-regex": { 586 | "version": "8.0.0", 587 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 588 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", 589 | "dev": true 590 | }, 591 | "enquirer": { 592 | "version": "2.3.6", 593 | "resolved": "https://registry.npmjs.org/enquirer/-/enquirer-2.3.6.tgz", 594 | "integrity": "sha512-yjNnPr315/FjS4zIsUxYguYUPP2e1NK4d7E7ZOLiyYCcbFBiTMyID+2wvm2w6+pZ/odMA7cRkjhsPbltwBOrLg==", 595 | "dev": true, 596 | "requires": { 597 | "ansi-colors": "^4.1.1" 598 | } 599 | }, 600 | "escalade": { 601 | "version": "3.1.1", 602 | "resolved": "https://registry.npmjs.org/escalade/-/escalade-3.1.1.tgz", 603 | "integrity": "sha512-k0er2gUkLf8O0zKJiAhmkTnJlTvINGv7ygDNPbeIsX/TJjGJZHuh9B2UxbsaEkmlEo9MfhrSzmhIlhRlI2GXnw==", 604 | "dev": true 605 | }, 606 | "escape-string-regexp": { 607 | "version": "1.0.5", 608 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", 609 | "integrity": "sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ=", 610 | "dev": true 611 | }, 612 | "eslint": { 613 | "version": "7.32.0", 614 | "resolved": "https://registry.npmjs.org/eslint/-/eslint-7.32.0.tgz", 615 | "integrity": "sha512-VHZ8gX+EDfz+97jGcgyGCyRia/dPOd6Xh9yPv8Bl1+SoaIwD+a/vlrOmGRUyOYu7MwUhc7CxqeaDZU13S4+EpA==", 616 | "dev": true, 617 | "requires": { 618 | "@babel/code-frame": "7.12.11", 619 | "@eslint/eslintrc": "^0.4.3", 620 | "@humanwhocodes/config-array": "^0.5.0", 621 | "ajv": "^6.10.0", 622 | "chalk": "^4.0.0", 623 | "cross-spawn": "^7.0.2", 624 | "debug": "^4.0.1", 625 | "doctrine": "^3.0.0", 626 | "enquirer": "^2.3.5", 627 | "escape-string-regexp": "^4.0.0", 628 | "eslint-scope": "^5.1.1", 629 | "eslint-utils": "^2.1.0", 630 | "eslint-visitor-keys": "^2.0.0", 631 | "espree": "^7.3.1", 632 | "esquery": "^1.4.0", 633 | "esutils": "^2.0.2", 634 | "fast-deep-equal": "^3.1.3", 635 | "file-entry-cache": "^6.0.1", 636 | "functional-red-black-tree": "^1.0.1", 637 | "glob-parent": "^5.1.2", 638 | "globals": "^13.6.0", 639 | "ignore": "^4.0.6", 640 | "import-fresh": "^3.0.0", 641 | "imurmurhash": "^0.1.4", 642 | "is-glob": "^4.0.0", 643 | "js-yaml": "^3.13.1", 644 | "json-stable-stringify-without-jsonify": "^1.0.1", 645 | "levn": "^0.4.1", 646 | "lodash.merge": "^4.6.2", 647 | "minimatch": "^3.0.4", 648 | "natural-compare": "^1.4.0", 649 | "optionator": "^0.9.1", 650 | "progress": "^2.0.0", 651 | "regexpp": "^3.1.0", 652 | "semver": "^7.2.1", 653 | "strip-ansi": "^6.0.0", 654 | "strip-json-comments": "^3.1.0", 655 | "table": "^6.0.9", 656 | "text-table": "^0.2.0", 657 | "v8-compile-cache": "^2.0.3" 658 | }, 659 | "dependencies": { 660 | "@babel/code-frame": { 661 | "version": "7.12.11", 662 | "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.12.11.tgz", 663 | "integrity": "sha512-Zt1yodBx1UcyiePMSkWnU4hPqhwq7hGi2nFL1LeA3EUl+q2LQx16MISgJ0+z7dnmgvP9QtIleuETGOiOH1RcIw==", 664 | "dev": true, 665 | "requires": { 666 | "@babel/highlight": "^7.10.4" 667 | } 668 | }, 669 | "ansi-styles": { 670 | "version": "4.3.0", 671 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 672 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 673 | "dev": true, 674 | "requires": { 675 | "color-convert": "^2.0.1" 676 | } 677 | }, 678 | "chalk": { 679 | "version": "4.1.2", 680 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", 681 | "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", 682 | "dev": true, 683 | "requires": { 684 | "ansi-styles": "^4.1.0", 685 | "supports-color": "^7.1.0" 686 | } 687 | }, 688 | "color-convert": { 689 | "version": "2.0.1", 690 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 691 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 692 | "dev": true, 693 | "requires": { 694 | "color-name": "~1.1.4" 695 | } 696 | }, 697 | "color-name": { 698 | "version": "1.1.4", 699 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 700 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 701 | "dev": true 702 | }, 703 | "escape-string-regexp": { 704 | "version": "4.0.0", 705 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", 706 | "integrity": "sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA==", 707 | "dev": true 708 | }, 709 | "globals": { 710 | "version": "13.12.0", 711 | "resolved": "https://registry.npmjs.org/globals/-/globals-13.12.0.tgz", 712 | "integrity": "sha512-uS8X6lSKN2JumVoXrbUz+uG4BYG+eiawqm3qFcT7ammfbUHeCBoJMlHcec/S3krSk73/AE/f0szYFmgAA3kYZg==", 713 | "dev": true, 714 | "requires": { 715 | "type-fest": "^0.20.2" 716 | } 717 | }, 718 | "has-flag": { 719 | "version": "4.0.0", 720 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 721 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", 722 | "dev": true 723 | }, 724 | "semver": { 725 | "version": "7.3.5", 726 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.3.5.tgz", 727 | "integrity": "sha512-PoeGJYh8HK4BTO/a9Tf6ZG3veo/A7ZVsYrSA6J8ny9nb3B1VrpkuN+z9OE5wfE5p6H4LchYZsegiQgbJD94ZFQ==", 728 | "dev": true, 729 | "requires": { 730 | "lru-cache": "^6.0.0" 731 | } 732 | }, 733 | "supports-color": { 734 | "version": "7.2.0", 735 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", 736 | "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", 737 | "dev": true, 738 | "requires": { 739 | "has-flag": "^4.0.0" 740 | } 741 | } 742 | } 743 | }, 744 | "eslint-plugin-prettier": { 745 | "version": "3.4.1", 746 | "resolved": "https://registry.npmjs.org/eslint-plugin-prettier/-/eslint-plugin-prettier-3.4.1.tgz", 747 | "integrity": "sha512-htg25EUYUeIhKHXjOinK4BgCcDwtLHjqaxCDsMy5nbnUMkKFvIhMVCp+5GFUXQ4Nr8lBsPqtGAqBenbpFqAA2g==", 748 | "dev": true, 749 | "requires": { 750 | "prettier-linter-helpers": "^1.0.0" 751 | } 752 | }, 753 | "eslint-scope": { 754 | "version": "5.1.1", 755 | "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-5.1.1.tgz", 756 | "integrity": "sha512-2NxwbF/hZ0KpepYN0cNbo+FN6XoK7GaHlQhgx/hIZl6Va0bF45RQOOwhLIy8lQDbuCiadSLCBnH2CFYquit5bw==", 757 | "dev": true, 758 | "requires": { 759 | "esrecurse": "^4.3.0", 760 | "estraverse": "^4.1.1" 761 | } 762 | }, 763 | "eslint-utils": { 764 | "version": "2.1.0", 765 | "resolved": "https://registry.npmjs.org/eslint-utils/-/eslint-utils-2.1.0.tgz", 766 | "integrity": "sha512-w94dQYoauyvlDc43XnGB8lU3Zt713vNChgt4EWwhXAP2XkBvndfxF0AgIqKOOasjPIPzj9JqgwkwbCYD0/V3Zg==", 767 | "dev": true, 768 | "requires": { 769 | "eslint-visitor-keys": "^1.1.0" 770 | }, 771 | "dependencies": { 772 | "eslint-visitor-keys": { 773 | "version": "1.3.0", 774 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-1.3.0.tgz", 775 | "integrity": "sha512-6J72N8UNa462wa/KFODt/PJ3IU60SDpC3QXC1Hjc1BXXpfL2C9R5+AU7jhe0F6GREqVMh4Juu+NY7xn+6dipUQ==", 776 | "dev": true 777 | } 778 | } 779 | }, 780 | "eslint-visitor-keys": { 781 | "version": "2.1.0", 782 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-2.1.0.tgz", 783 | "integrity": "sha512-0rSmRBzXgDzIsD6mGdJgevzgezI534Cer5L/vyMX0kHzT/jiB43jRhd9YUlMGYLQy2zprNmoT8qasCGtY+QaKw==", 784 | "dev": true 785 | }, 786 | "espree": { 787 | "version": "7.3.1", 788 | "resolved": "https://registry.npmjs.org/espree/-/espree-7.3.1.tgz", 789 | "integrity": "sha512-v3JCNCE64umkFpmkFGqzVKsOT0tN1Zr+ueqLZfpV1Ob8e+CEgPWa+OxCoGH3tnhimMKIaBm4m/vaRpJ/krRz2g==", 790 | "dev": true, 791 | "requires": { 792 | "acorn": "^7.4.0", 793 | "acorn-jsx": "^5.3.1", 794 | "eslint-visitor-keys": "^1.3.0" 795 | }, 796 | "dependencies": { 797 | "eslint-visitor-keys": { 798 | "version": "1.3.0", 799 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-1.3.0.tgz", 800 | "integrity": "sha512-6J72N8UNa462wa/KFODt/PJ3IU60SDpC3QXC1Hjc1BXXpfL2C9R5+AU7jhe0F6GREqVMh4Juu+NY7xn+6dipUQ==", 801 | "dev": true 802 | } 803 | } 804 | }, 805 | "esprima": { 806 | "version": "4.0.1", 807 | "resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.1.tgz", 808 | "integrity": "sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A==", 809 | "dev": true 810 | }, 811 | "esquery": { 812 | "version": "1.4.0", 813 | "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.4.0.tgz", 814 | "integrity": "sha512-cCDispWt5vHHtwMY2YrAQ4ibFkAL8RbH5YGBnZBc90MolvvfkkQcJro/aZiAQUlQ3qgrYS6D6v8Gc5G5CQsc9w==", 815 | "dev": true, 816 | "requires": { 817 | "estraverse": "^5.1.0" 818 | }, 819 | "dependencies": { 820 | "estraverse": { 821 | "version": "5.3.0", 822 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.3.0.tgz", 823 | "integrity": "sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==", 824 | "dev": true 825 | } 826 | } 827 | }, 828 | "esrecurse": { 829 | "version": "4.3.0", 830 | "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.3.0.tgz", 831 | "integrity": "sha512-KmfKL3b6G+RXvP8N1vr3Tq1kL/oCFgn2NYXEtqP8/L3pKapUA4G8cFVaoF3SU323CD4XypR/ffioHmkti6/Tag==", 832 | "dev": true, 833 | "requires": { 834 | "estraverse": "^5.2.0" 835 | }, 836 | "dependencies": { 837 | "estraverse": { 838 | "version": "5.3.0", 839 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.3.0.tgz", 840 | "integrity": "sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==", 841 | "dev": true 842 | } 843 | } 844 | }, 845 | "estraverse": { 846 | "version": "4.3.0", 847 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-4.3.0.tgz", 848 | "integrity": "sha512-39nnKffWz8xN1BU/2c79n9nB9HDzo0niYUqx6xyqUnyoAnQyyWpOTdZEeiCch8BBu515t4wp9ZmgVfVhn9EBpw==", 849 | "dev": true 850 | }, 851 | "estree-walker": { 852 | "version": "1.0.1", 853 | "resolved": "https://registry.npmjs.org/estree-walker/-/estree-walker-1.0.1.tgz", 854 | "integrity": "sha512-1fMXF3YP4pZZVozF8j/ZLfvnR8NSIljt56UhbZ5PeeDmmGHpgpdwQt7ITlGvYaQukCvuBRMLEiKiYC+oeIg4cg==", 855 | "dev": true 856 | }, 857 | "esutils": { 858 | "version": "2.0.3", 859 | "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz", 860 | "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==", 861 | "dev": true 862 | }, 863 | "excellentexport": { 864 | "version": "3.7.3", 865 | "resolved": "https://registry.npmjs.org/excellentexport/-/excellentexport-3.7.3.tgz", 866 | "integrity": "sha512-cPGzYpKYHqyPh9EhcArDzf+ORkjKNo6NrSGQc9ubtPClk/941F0wyEg0uN0AZehuCI4qF1ZWE7QZumRv9LLLMA==" 867 | }, 868 | "fast-deep-equal": { 869 | "version": "3.1.3", 870 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz", 871 | "integrity": "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==", 872 | "dev": true 873 | }, 874 | "fast-diff": { 875 | "version": "1.2.0", 876 | "resolved": "https://registry.npmjs.org/fast-diff/-/fast-diff-1.2.0.tgz", 877 | "integrity": "sha512-xJuoT5+L99XlZ8twedaRf6Ax2TgQVxvgZOYoPKqZufmJib0tL2tegPBOZb1pVNgIhlqDlA0eO0c3wBvQcmzx4w==", 878 | "dev": true 879 | }, 880 | "fast-json-stable-stringify": { 881 | "version": "2.1.0", 882 | "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz", 883 | "integrity": "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==", 884 | "dev": true 885 | }, 886 | "fast-levenshtein": { 887 | "version": "2.0.6", 888 | "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", 889 | "integrity": "sha1-PYpcZog6FqMMqGQ+hR8Zuqd5eRc=", 890 | "dev": true 891 | }, 892 | "file-entry-cache": { 893 | "version": "6.0.1", 894 | "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-6.0.1.tgz", 895 | "integrity": "sha512-7Gps/XWymbLk2QLYK4NzpMOrYjMhdIxXuIvy2QBsLE6ljuodKvdkWs/cpyJJ3CVIVpH0Oi1Hvg1ovbMzLdFBBg==", 896 | "dev": true, 897 | "requires": { 898 | "flat-cache": "^3.0.4" 899 | } 900 | }, 901 | "flat-cache": { 902 | "version": "3.0.4", 903 | "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-3.0.4.tgz", 904 | "integrity": "sha512-dm9s5Pw7Jc0GvMYbshN6zchCA9RgQlzzEZX3vylR9IqFfS8XciblUXOKfW6SiuJ0e13eDYZoZV5wdrev7P3Nwg==", 905 | "dev": true, 906 | "requires": { 907 | "flatted": "^3.1.0", 908 | "rimraf": "^3.0.2" 909 | } 910 | }, 911 | "flatted": { 912 | "version": "3.2.4", 913 | "resolved": "https://registry.npmjs.org/flatted/-/flatted-3.2.4.tgz", 914 | "integrity": "sha512-8/sOawo8tJ4QOBX8YlQBMxL8+RLZfxMQOif9o0KUKTNTjMYElWPE0r/m5VNFxTRd0NSw8qSy8dajrwX4RYI1Hw==", 915 | "dev": true 916 | }, 917 | "fs.realpath": { 918 | "version": "1.0.0", 919 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 920 | "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=", 921 | "dev": true 922 | }, 923 | "fsevents": { 924 | "version": "2.3.2", 925 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.2.tgz", 926 | "integrity": "sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA==", 927 | "dev": true, 928 | "optional": true 929 | }, 930 | "function-bind": { 931 | "version": "1.1.1", 932 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", 933 | "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==", 934 | "dev": true 935 | }, 936 | "functional-red-black-tree": { 937 | "version": "1.0.1", 938 | "resolved": "https://registry.npmjs.org/functional-red-black-tree/-/functional-red-black-tree-1.0.1.tgz", 939 | "integrity": "sha1-GwqzvVU7Kg1jmdKcDj6gslIHgyc=", 940 | "dev": true 941 | }, 942 | "gensync": { 943 | "version": "1.0.0-beta.2", 944 | "resolved": "https://registry.npmjs.org/gensync/-/gensync-1.0.0-beta.2.tgz", 945 | "integrity": "sha512-3hN7NaskYvMDLQY55gnW3NQ+mesEAepTqlg+VEbj7zzqEMBVNhzcGYYeqFo/TlYz6eQiFcp1HcsCZO+nGgS8zg==", 946 | "dev": true 947 | }, 948 | "glob": { 949 | "version": "7.2.0", 950 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.0.tgz", 951 | "integrity": "sha512-lmLf6gtyrPq8tTjSmrO94wBeQbFR3HbLHbuyD69wuyQkImp2hWqMGB47OX65FBkPffO641IP9jWa1z4ivqG26Q==", 952 | "dev": true, 953 | "requires": { 954 | "fs.realpath": "^1.0.0", 955 | "inflight": "^1.0.4", 956 | "inherits": "2", 957 | "minimatch": "^3.0.4", 958 | "once": "^1.3.0", 959 | "path-is-absolute": "^1.0.0" 960 | } 961 | }, 962 | "glob-parent": { 963 | "version": "5.1.2", 964 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", 965 | "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", 966 | "dev": true, 967 | "requires": { 968 | "is-glob": "^4.0.1" 969 | } 970 | }, 971 | "globals": { 972 | "version": "11.12.0", 973 | "resolved": "https://registry.npmjs.org/globals/-/globals-11.12.0.tgz", 974 | "integrity": "sha512-WOBp/EEGUiIsJSp7wcv/y6MO+lV9UoncWqxuFfm8eBwzWNgyfBd6Gz+IeKQ9jCmyhoH99g15M3T+QaVHFjizVA==", 975 | "dev": true 976 | }, 977 | "has": { 978 | "version": "1.0.3", 979 | "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz", 980 | "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==", 981 | "dev": true, 982 | "requires": { 983 | "function-bind": "^1.1.1" 984 | } 985 | }, 986 | "has-flag": { 987 | "version": "3.0.0", 988 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 989 | "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=", 990 | "dev": true 991 | }, 992 | "ignore": { 993 | "version": "4.0.6", 994 | "resolved": "https://registry.npmjs.org/ignore/-/ignore-4.0.6.tgz", 995 | "integrity": "sha512-cyFDKrqc/YdcWFniJhzI42+AzS+gNwmUzOSFcRCQYwySuBBBy/KjuxWLZ/FHEH6Moq1NizMOBWyTcv8O4OZIMg==", 996 | "dev": true 997 | }, 998 | "import-fresh": { 999 | "version": "3.3.0", 1000 | "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.3.0.tgz", 1001 | "integrity": "sha512-veYYhQa+D1QBKznvhUHxb8faxlrwUnxseDAbAp457E0wLNio2bOSKnjYDhMj+YiAq61xrMGhQk9iXVk5FzgQMw==", 1002 | "dev": true, 1003 | "requires": { 1004 | "parent-module": "^1.0.0", 1005 | "resolve-from": "^4.0.0" 1006 | } 1007 | }, 1008 | "imurmurhash": { 1009 | "version": "0.1.4", 1010 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", 1011 | "integrity": "sha1-khi5srkoojixPcT7a21XbyMUU+o=", 1012 | "dev": true 1013 | }, 1014 | "inflight": { 1015 | "version": "1.0.6", 1016 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 1017 | "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", 1018 | "dev": true, 1019 | "requires": { 1020 | "once": "^1.3.0", 1021 | "wrappy": "1" 1022 | } 1023 | }, 1024 | "inherits": { 1025 | "version": "2.0.4", 1026 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 1027 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", 1028 | "dev": true 1029 | }, 1030 | "is-core-module": { 1031 | "version": "2.8.0", 1032 | "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.8.0.tgz", 1033 | "integrity": "sha512-vd15qHsaqrRL7dtH6QNuy0ndJmRDrS9HAM1CAiSifNUFv4x1a0CCVsj18hJ1mShxIG6T2i1sO78MkP56r0nYRw==", 1034 | "dev": true, 1035 | "requires": { 1036 | "has": "^1.0.3" 1037 | } 1038 | }, 1039 | "is-extglob": { 1040 | "version": "2.1.1", 1041 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 1042 | "integrity": "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=", 1043 | "dev": true 1044 | }, 1045 | "is-fullwidth-code-point": { 1046 | "version": "3.0.0", 1047 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 1048 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", 1049 | "dev": true 1050 | }, 1051 | "is-glob": { 1052 | "version": "4.0.3", 1053 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", 1054 | "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", 1055 | "dev": true, 1056 | "requires": { 1057 | "is-extglob": "^2.1.1" 1058 | } 1059 | }, 1060 | "is-module": { 1061 | "version": "1.0.0", 1062 | "resolved": "https://registry.npmjs.org/is-module/-/is-module-1.0.0.tgz", 1063 | "integrity": "sha1-Mlj7afeMFNW4FdZkM2tM/7ZEFZE=", 1064 | "dev": true 1065 | }, 1066 | "is-reference": { 1067 | "version": "1.2.1", 1068 | "resolved": "https://registry.npmjs.org/is-reference/-/is-reference-1.2.1.tgz", 1069 | "integrity": "sha512-U82MsXXiFIrjCK4otLT+o2NA2Cd2g5MLoOVXUZjIOhLurrRxpEXzI8O0KZHr3IjLvlAH1kTPYSuqer5T9ZVBKQ==", 1070 | "dev": true, 1071 | "requires": { 1072 | "@types/estree": "*" 1073 | } 1074 | }, 1075 | "isexe": { 1076 | "version": "2.0.0", 1077 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 1078 | "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=", 1079 | "dev": true 1080 | }, 1081 | "jest-worker": { 1082 | "version": "26.6.2", 1083 | "resolved": "https://registry.npmjs.org/jest-worker/-/jest-worker-26.6.2.tgz", 1084 | "integrity": "sha512-KWYVV1c4i+jbMpaBC+U++4Va0cp8OisU185o73T1vo99hqi7w8tSJfUXYswwqqrjzwxa6KpRK54WhPvwf5w6PQ==", 1085 | "dev": true, 1086 | "requires": { 1087 | "@types/node": "*", 1088 | "merge-stream": "^2.0.0", 1089 | "supports-color": "^7.0.0" 1090 | }, 1091 | "dependencies": { 1092 | "has-flag": { 1093 | "version": "4.0.0", 1094 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 1095 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", 1096 | "dev": true 1097 | }, 1098 | "supports-color": { 1099 | "version": "7.2.0", 1100 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", 1101 | "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", 1102 | "dev": true, 1103 | "requires": { 1104 | "has-flag": "^4.0.0" 1105 | } 1106 | } 1107 | } 1108 | }, 1109 | "js-tokens": { 1110 | "version": "4.0.0", 1111 | "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", 1112 | "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==", 1113 | "dev": true 1114 | }, 1115 | "js-yaml": { 1116 | "version": "3.14.1", 1117 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.14.1.tgz", 1118 | "integrity": "sha512-okMH7OXXJ7YrN9Ok3/SXrnu4iX9yOk+25nqX4imS2npuvTYDmo/QEZoqwZkYaIDk3jVvBOTOIEgEhaLOynBS9g==", 1119 | "dev": true, 1120 | "requires": { 1121 | "argparse": "^1.0.7", 1122 | "esprima": "^4.0.0" 1123 | } 1124 | }, 1125 | "jsesc": { 1126 | "version": "2.5.2", 1127 | "resolved": "https://registry.npmjs.org/jsesc/-/jsesc-2.5.2.tgz", 1128 | "integrity": "sha512-OYu7XEzjkCQ3C5Ps3QIZsQfNpqoJyZZA99wd9aWd05NCtC5pWOkShK2mkL6HXQR6/Cy2lbNdPlZBpuQHXE63gA==", 1129 | "dev": true 1130 | }, 1131 | "json-schema-traverse": { 1132 | "version": "0.4.1", 1133 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", 1134 | "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==", 1135 | "dev": true 1136 | }, 1137 | "json-stable-stringify-without-jsonify": { 1138 | "version": "1.0.1", 1139 | "resolved": "https://registry.npmjs.org/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz", 1140 | "integrity": "sha1-nbe1lJatPzz+8wp1FC0tkwrXJlE=", 1141 | "dev": true 1142 | }, 1143 | "json5": { 1144 | "version": "2.2.0", 1145 | "resolved": "https://registry.npmjs.org/json5/-/json5-2.2.0.tgz", 1146 | "integrity": "sha512-f+8cldu7X/y7RAJurMEJmdoKXGB/X550w2Nr3tTbezL6RwEE/iMcm+tZnXeoZtKuOq6ft8+CqzEkrIgx1fPoQA==", 1147 | "dev": true, 1148 | "requires": { 1149 | "minimist": "^1.2.5" 1150 | } 1151 | }, 1152 | "levn": { 1153 | "version": "0.4.1", 1154 | "resolved": "https://registry.npmjs.org/levn/-/levn-0.4.1.tgz", 1155 | "integrity": "sha512-+bT2uH4E5LGE7h/n3evcS/sQlJXCpIp6ym8OWJ5eV6+67Dsql/LaaT7qJBAt2rzfoa/5QBGBhxDix1dMt2kQKQ==", 1156 | "dev": true, 1157 | "requires": { 1158 | "prelude-ls": "^1.2.1", 1159 | "type-check": "~0.4.0" 1160 | } 1161 | }, 1162 | "lodash.merge": { 1163 | "version": "4.6.2", 1164 | "resolved": "https://registry.npmjs.org/lodash.merge/-/lodash.merge-4.6.2.tgz", 1165 | "integrity": "sha512-0KpjqXRVvrYyCsX1swR/XTK0va6VQkQM6MNo7PqW77ByjAhoARA8EfrP1N4+KlKj8YS0ZUCtRT/YUuhyYDujIQ==", 1166 | "dev": true 1167 | }, 1168 | "lodash.truncate": { 1169 | "version": "4.4.2", 1170 | "resolved": "https://registry.npmjs.org/lodash.truncate/-/lodash.truncate-4.4.2.tgz", 1171 | "integrity": "sha1-WjUNoLERO4N+z//VgSy+WNbq4ZM=", 1172 | "dev": true 1173 | }, 1174 | "lru-cache": { 1175 | "version": "6.0.0", 1176 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", 1177 | "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", 1178 | "dev": true, 1179 | "requires": { 1180 | "yallist": "^4.0.0" 1181 | } 1182 | }, 1183 | "magic-string": { 1184 | "version": "0.25.7", 1185 | "resolved": "https://registry.npmjs.org/magic-string/-/magic-string-0.25.7.tgz", 1186 | "integrity": "sha512-4CrMT5DOHTDk4HYDlzmwu4FVCcIYI8gauveasrdCu2IKIFOJ3f0v/8MDGJCDL9oD2ppz/Av1b0Nj345H9M+XIA==", 1187 | "dev": true, 1188 | "requires": { 1189 | "sourcemap-codec": "^1.4.4" 1190 | } 1191 | }, 1192 | "merge-stream": { 1193 | "version": "2.0.0", 1194 | "resolved": "https://registry.npmjs.org/merge-stream/-/merge-stream-2.0.0.tgz", 1195 | "integrity": "sha512-abv/qOcuPfk3URPfDzmZU1LKmuw8kT+0nIHvKrKgFrwifol/doWcdA4ZqsWQ8ENrFKkd67Mfpo/LovbIUsbt3w==", 1196 | "dev": true 1197 | }, 1198 | "mime": { 1199 | "version": "3.0.0", 1200 | "resolved": "https://registry.npmjs.org/mime/-/mime-3.0.0.tgz", 1201 | "integrity": "sha512-jSCU7/VB1loIWBZe14aEYHU/+1UMEHoaO7qxCOVJOw9GgH72VAWppxNcjU+x9a2k3GSIBXNKxXQFqRvvZ7vr3A==", 1202 | "dev": true 1203 | }, 1204 | "minimatch": { 1205 | "version": "3.0.4", 1206 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", 1207 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", 1208 | "dev": true, 1209 | "requires": { 1210 | "brace-expansion": "^1.1.7" 1211 | } 1212 | }, 1213 | "minimist": { 1214 | "version": "1.2.5", 1215 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.5.tgz", 1216 | "integrity": "sha512-FM9nNUYrRBAELZQT3xeZQ7fmMOBg6nWNmJKTcgsJeaLstP/UODVpGsr5OhXhhXg6f+qtJ8uiZ+PUxkDWcgIXLw==", 1217 | "dev": true 1218 | }, 1219 | "ms": { 1220 | "version": "2.1.2", 1221 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 1222 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 1223 | "dev": true 1224 | }, 1225 | "natural-compare": { 1226 | "version": "1.4.0", 1227 | "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", 1228 | "integrity": "sha1-Sr6/7tdUHywnrPspvbvRXI1bpPc=", 1229 | "dev": true 1230 | }, 1231 | "node-releases": { 1232 | "version": "2.0.1", 1233 | "resolved": "https://registry.npmjs.org/node-releases/-/node-releases-2.0.1.tgz", 1234 | "integrity": "sha512-CqyzN6z7Q6aMeF/ktcMVTzhAHCEpf8SOarwpzpf8pNBY2k5/oM34UHldUwp8VKI7uxct2HxSRdJjBaZeESzcxA==", 1235 | "dev": true 1236 | }, 1237 | "once": { 1238 | "version": "1.4.0", 1239 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 1240 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", 1241 | "dev": true, 1242 | "requires": { 1243 | "wrappy": "1" 1244 | } 1245 | }, 1246 | "opener": { 1247 | "version": "1.5.2", 1248 | "resolved": "https://registry.npmjs.org/opener/-/opener-1.5.2.tgz", 1249 | "integrity": "sha512-ur5UIdyw5Y7yEj9wLzhqXiy6GZ3Mwx0yGI+5sMn2r0N0v3cKJvUmFH5yPP+WXh9e0xfyzyJX95D8l088DNFj7A==", 1250 | "dev": true 1251 | }, 1252 | "optionator": { 1253 | "version": "0.9.1", 1254 | "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.9.1.tgz", 1255 | "integrity": "sha512-74RlY5FCnhq4jRxVUPKDaRwrVNXMqsGsiW6AJw4XK8hmtm10wC0ypZBLw5IIp85NZMr91+qd1RvvENwg7jjRFw==", 1256 | "dev": true, 1257 | "requires": { 1258 | "deep-is": "^0.1.3", 1259 | "fast-levenshtein": "^2.0.6", 1260 | "levn": "^0.4.1", 1261 | "prelude-ls": "^1.2.1", 1262 | "type-check": "^0.4.0", 1263 | "word-wrap": "^1.2.3" 1264 | } 1265 | }, 1266 | "parent-module": { 1267 | "version": "1.0.1", 1268 | "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz", 1269 | "integrity": "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==", 1270 | "dev": true, 1271 | "requires": { 1272 | "callsites": "^3.0.0" 1273 | } 1274 | }, 1275 | "path-is-absolute": { 1276 | "version": "1.0.1", 1277 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 1278 | "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=", 1279 | "dev": true 1280 | }, 1281 | "path-key": { 1282 | "version": "3.1.1", 1283 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", 1284 | "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", 1285 | "dev": true 1286 | }, 1287 | "path-parse": { 1288 | "version": "1.0.7", 1289 | "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.7.tgz", 1290 | "integrity": "sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw==", 1291 | "dev": true 1292 | }, 1293 | "picocolors": { 1294 | "version": "1.0.0", 1295 | "resolved": "https://registry.npmjs.org/picocolors/-/picocolors-1.0.0.tgz", 1296 | "integrity": "sha512-1fygroTLlHu66zi26VoTDv8yRgm0Fccecssto+MhsZ0D/DGW2sm8E8AjW7NU5VVTRt5GxbeZ5qBuJr+HyLYkjQ==", 1297 | "dev": true 1298 | }, 1299 | "picomatch": { 1300 | "version": "2.3.0", 1301 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.0.tgz", 1302 | "integrity": "sha512-lY1Q/PiJGC2zOv/z391WOTD+Z02bCgsFfvxoXXf6h7kv9o+WmsmzYqrAwY63sNgOxE4xEdq0WyUnXfKeBrSvYw==", 1303 | "dev": true 1304 | }, 1305 | "prelude-ls": { 1306 | "version": "1.2.1", 1307 | "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.2.1.tgz", 1308 | "integrity": "sha512-vkcDPrRZo1QZLbn5RLGPpg/WmIQ65qoWWhcGKf/b5eplkkarX0m9z8ppCat4mlOqUsWpyNuYgO3VRyrYHSzX5g==", 1309 | "dev": true 1310 | }, 1311 | "prettier-linter-helpers": { 1312 | "version": "1.0.0", 1313 | "resolved": "https://registry.npmjs.org/prettier-linter-helpers/-/prettier-linter-helpers-1.0.0.tgz", 1314 | "integrity": "sha512-GbK2cP9nraSSUF9N2XwUwqfzlAFlMNYYl+ShE/V+H8a9uNl/oUqB1w2EL54Jh0OlyRSd8RfWYJ3coVS4TROP2w==", 1315 | "dev": true, 1316 | "requires": { 1317 | "fast-diff": "^1.1.2" 1318 | } 1319 | }, 1320 | "progress": { 1321 | "version": "2.0.3", 1322 | "resolved": "https://registry.npmjs.org/progress/-/progress-2.0.3.tgz", 1323 | "integrity": "sha512-7PiHtLll5LdnKIMw100I+8xJXR5gW2QwWYkT6iJva0bXitZKa/XMrSbdmg3r2Xnaidz9Qumd0VPaMrZlF9V9sA==", 1324 | "dev": true 1325 | }, 1326 | "punycode": { 1327 | "version": "2.1.1", 1328 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.1.1.tgz", 1329 | "integrity": "sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A==", 1330 | "dev": true 1331 | }, 1332 | "randombytes": { 1333 | "version": "2.1.0", 1334 | "resolved": "https://registry.npmjs.org/randombytes/-/randombytes-2.1.0.tgz", 1335 | "integrity": "sha512-vYl3iOX+4CKUWuxGi9Ukhie6fsqXqS9FE2Zaic4tNFD2N2QQaXOMFbuKK4QmDHC0JO6B1Zp41J0LpT0oR68amQ==", 1336 | "dev": true, 1337 | "requires": { 1338 | "safe-buffer": "^5.1.0" 1339 | } 1340 | }, 1341 | "regexpp": { 1342 | "version": "3.2.0", 1343 | "resolved": "https://registry.npmjs.org/regexpp/-/regexpp-3.2.0.tgz", 1344 | "integrity": "sha512-pq2bWo9mVD43nbts2wGv17XLiNLya+GklZ8kaDLV2Z08gDCsGpnKn9BFMepvWuHCbyVvY7J5o5+BVvoQbmlJLg==", 1345 | "dev": true 1346 | }, 1347 | "require-from-string": { 1348 | "version": "2.0.2", 1349 | "resolved": "https://registry.npmjs.org/require-from-string/-/require-from-string-2.0.2.tgz", 1350 | "integrity": "sha512-Xf0nWe6RseziFMu+Ap9biiUbmplq6S9/p+7w7YXP/JBHhrUDDUhwa+vANyubuqfZWTveU//DYVGsDG7RKL/vEw==", 1351 | "dev": true 1352 | }, 1353 | "resolve": { 1354 | "version": "1.20.0", 1355 | "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.20.0.tgz", 1356 | "integrity": "sha512-wENBPt4ySzg4ybFQW2TT1zMQucPK95HSh/nq2CFTZVOGut2+pQvSsgtda4d26YrYcr067wjbmzOG8byDPBX63A==", 1357 | "dev": true, 1358 | "requires": { 1359 | "is-core-module": "^2.2.0", 1360 | "path-parse": "^1.0.6" 1361 | } 1362 | }, 1363 | "resolve-from": { 1364 | "version": "4.0.0", 1365 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz", 1366 | "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==", 1367 | "dev": true 1368 | }, 1369 | "rimraf": { 1370 | "version": "3.0.2", 1371 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-3.0.2.tgz", 1372 | "integrity": "sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA==", 1373 | "dev": true, 1374 | "requires": { 1375 | "glob": "^7.1.3" 1376 | } 1377 | }, 1378 | "rollup": { 1379 | "version": "2.60.2", 1380 | "resolved": "https://registry.npmjs.org/rollup/-/rollup-2.60.2.tgz", 1381 | "integrity": "sha512-1Bgjpq61sPjgoZzuiDSGvbI1tD91giZABgjCQBKM5aYLnzjq52GoDuWVwT/cm/MCxCMPU8gqQvkj8doQ5C8Oqw==", 1382 | "dev": true, 1383 | "requires": { 1384 | "fsevents": "~2.3.2" 1385 | } 1386 | }, 1387 | "rollup-plugin-serve": { 1388 | "version": "1.1.0", 1389 | "resolved": "https://registry.npmjs.org/rollup-plugin-serve/-/rollup-plugin-serve-1.1.0.tgz", 1390 | "integrity": "sha512-pYkSsuA0/psKqhhictkJw1c2klya5b+LlCvipWqI9OE1aG2M97mRumZCbBlry5CMEOzYBBgSDgd1694sNbmyIw==", 1391 | "dev": true, 1392 | "requires": { 1393 | "mime": ">=2.4.6", 1394 | "opener": "1" 1395 | } 1396 | }, 1397 | "rollup-plugin-terser": { 1398 | "version": "7.0.2", 1399 | "resolved": "https://registry.npmjs.org/rollup-plugin-terser/-/rollup-plugin-terser-7.0.2.tgz", 1400 | "integrity": "sha512-w3iIaU4OxcF52UUXiZNsNeuXIMDvFrr+ZXK6bFZ0Q60qyVfq4uLptoS4bbq3paG3x216eQllFZX7zt6TIImguQ==", 1401 | "dev": true, 1402 | "requires": { 1403 | "@babel/code-frame": "^7.10.4", 1404 | "jest-worker": "^26.2.1", 1405 | "serialize-javascript": "^4.0.0", 1406 | "terser": "^5.0.0" 1407 | } 1408 | }, 1409 | "safe-buffer": { 1410 | "version": "5.1.2", 1411 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 1412 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==", 1413 | "dev": true 1414 | }, 1415 | "semver": { 1416 | "version": "6.3.0", 1417 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", 1418 | "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==", 1419 | "dev": true 1420 | }, 1421 | "serialize-javascript": { 1422 | "version": "4.0.0", 1423 | "resolved": "https://registry.npmjs.org/serialize-javascript/-/serialize-javascript-4.0.0.tgz", 1424 | "integrity": "sha512-GaNA54380uFefWghODBWEGisLZFj00nS5ACs6yHa9nLqlLpVLO8ChDGeKRjZnV4Nh4n0Qi7nhYZD/9fCPzEqkw==", 1425 | "dev": true, 1426 | "requires": { 1427 | "randombytes": "^2.1.0" 1428 | } 1429 | }, 1430 | "shebang-command": { 1431 | "version": "2.0.0", 1432 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", 1433 | "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", 1434 | "dev": true, 1435 | "requires": { 1436 | "shebang-regex": "^3.0.0" 1437 | } 1438 | }, 1439 | "shebang-regex": { 1440 | "version": "3.0.0", 1441 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", 1442 | "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", 1443 | "dev": true 1444 | }, 1445 | "slice-ansi": { 1446 | "version": "4.0.0", 1447 | "resolved": "https://registry.npmjs.org/slice-ansi/-/slice-ansi-4.0.0.tgz", 1448 | "integrity": "sha512-qMCMfhY040cVHT43K9BFygqYbUPFZKHOg7K73mtTWJRb8pyP3fzf4Ixd5SzdEJQ6MRUg/WBnOLxghZtKKurENQ==", 1449 | "dev": true, 1450 | "requires": { 1451 | "ansi-styles": "^4.0.0", 1452 | "astral-regex": "^2.0.0", 1453 | "is-fullwidth-code-point": "^3.0.0" 1454 | }, 1455 | "dependencies": { 1456 | "ansi-styles": { 1457 | "version": "4.3.0", 1458 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 1459 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 1460 | "dev": true, 1461 | "requires": { 1462 | "color-convert": "^2.0.1" 1463 | } 1464 | }, 1465 | "color-convert": { 1466 | "version": "2.0.1", 1467 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 1468 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 1469 | "dev": true, 1470 | "requires": { 1471 | "color-name": "~1.1.4" 1472 | } 1473 | }, 1474 | "color-name": { 1475 | "version": "1.1.4", 1476 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 1477 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 1478 | "dev": true 1479 | } 1480 | } 1481 | }, 1482 | "source-map": { 1483 | "version": "0.5.7", 1484 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.5.7.tgz", 1485 | "integrity": "sha1-igOdLRAh0i0eoUyA2OpGi6LvP8w=", 1486 | "dev": true 1487 | }, 1488 | "source-map-support": { 1489 | "version": "0.5.21", 1490 | "resolved": "https://registry.npmjs.org/source-map-support/-/source-map-support-0.5.21.tgz", 1491 | "integrity": "sha512-uBHU3L3czsIyYXKX88fdrGovxdSCoTGDRZ6SYXtSRxLZUzHg5P/66Ht6uoUlHu9EZod+inXhKo3qQgwXUT/y1w==", 1492 | "dev": true, 1493 | "requires": { 1494 | "buffer-from": "^1.0.0", 1495 | "source-map": "^0.6.0" 1496 | }, 1497 | "dependencies": { 1498 | "source-map": { 1499 | "version": "0.6.1", 1500 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", 1501 | "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", 1502 | "dev": true 1503 | } 1504 | } 1505 | }, 1506 | "sourcemap-codec": { 1507 | "version": "1.4.8", 1508 | "resolved": "https://registry.npmjs.org/sourcemap-codec/-/sourcemap-codec-1.4.8.tgz", 1509 | "integrity": "sha512-9NykojV5Uih4lgo5So5dtw+f0JgJX30KCNI8gwhz2J9A15wD0Ml6tjHKwf6fTSa6fAdVBdZeNOs9eJ71qCk8vA==", 1510 | "dev": true 1511 | }, 1512 | "sprintf-js": { 1513 | "version": "1.0.3", 1514 | "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.0.3.tgz", 1515 | "integrity": "sha1-BOaSb2YolTVPPdAVIDYzuFcpfiw=", 1516 | "dev": true 1517 | }, 1518 | "string-width": { 1519 | "version": "4.2.3", 1520 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", 1521 | "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", 1522 | "dev": true, 1523 | "requires": { 1524 | "emoji-regex": "^8.0.0", 1525 | "is-fullwidth-code-point": "^3.0.0", 1526 | "strip-ansi": "^6.0.1" 1527 | } 1528 | }, 1529 | "strip-ansi": { 1530 | "version": "6.0.1", 1531 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", 1532 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", 1533 | "dev": true, 1534 | "requires": { 1535 | "ansi-regex": "^5.0.1" 1536 | } 1537 | }, 1538 | "strip-json-comments": { 1539 | "version": "3.1.1", 1540 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz", 1541 | "integrity": "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==", 1542 | "dev": true 1543 | }, 1544 | "supports-color": { 1545 | "version": "5.5.0", 1546 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 1547 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 1548 | "dev": true, 1549 | "requires": { 1550 | "has-flag": "^3.0.0" 1551 | } 1552 | }, 1553 | "table": { 1554 | "version": "6.7.5", 1555 | "resolved": "https://registry.npmjs.org/table/-/table-6.7.5.tgz", 1556 | "integrity": "sha512-LFNeryOqiQHqCVKzhkymKwt6ozeRhlm8IL1mE8rNUurkir4heF6PzMyRgaTa4tlyPTGGgXuvVOF/OLWiH09Lqw==", 1557 | "dev": true, 1558 | "requires": { 1559 | "ajv": "^8.0.1", 1560 | "lodash.truncate": "^4.4.2", 1561 | "slice-ansi": "^4.0.0", 1562 | "string-width": "^4.2.3", 1563 | "strip-ansi": "^6.0.1" 1564 | }, 1565 | "dependencies": { 1566 | "ajv": { 1567 | "version": "8.8.2", 1568 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-8.8.2.tgz", 1569 | "integrity": "sha512-x9VuX+R/jcFj1DHo/fCp99esgGDWiHENrKxaCENuCxpoMCmAt/COCGVDwA7kleEpEzJjDnvh3yGoOuLu0Dtllw==", 1570 | "dev": true, 1571 | "requires": { 1572 | "fast-deep-equal": "^3.1.1", 1573 | "json-schema-traverse": "^1.0.0", 1574 | "require-from-string": "^2.0.2", 1575 | "uri-js": "^4.2.2" 1576 | } 1577 | }, 1578 | "json-schema-traverse": { 1579 | "version": "1.0.0", 1580 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-1.0.0.tgz", 1581 | "integrity": "sha512-NM8/P9n3XjXhIZn1lLhkFaACTOURQXjWhV4BA/RnOv8xvgqtqpAX9IO4mRQxSx1Rlo4tqzeqb0sOlruaOy3dug==", 1582 | "dev": true 1583 | } 1584 | } 1585 | }, 1586 | "terser": { 1587 | "version": "5.10.0", 1588 | "resolved": "https://registry.npmjs.org/terser/-/terser-5.10.0.tgz", 1589 | "integrity": "sha512-AMmF99DMfEDiRJfxfY5jj5wNH/bYO09cniSqhfoyxc8sFoYIgkJy86G04UoZU5VjlpnplVu0K6Tx6E9b5+DlHA==", 1590 | "dev": true, 1591 | "requires": { 1592 | "commander": "^2.20.0", 1593 | "source-map": "~0.7.2", 1594 | "source-map-support": "~0.5.20" 1595 | }, 1596 | "dependencies": { 1597 | "source-map": { 1598 | "version": "0.7.3", 1599 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.7.3.tgz", 1600 | "integrity": "sha512-CkCj6giN3S+n9qrYiBTX5gystlENnRW5jZeNLHpe6aue+SrHcG5VYwujhW9s4dY31mEGsxBDrHR6oI69fTXsaQ==", 1601 | "dev": true 1602 | } 1603 | } 1604 | }, 1605 | "text-table": { 1606 | "version": "0.2.0", 1607 | "resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz", 1608 | "integrity": "sha1-f17oI66AUgfACvLfSoTsP8+lcLQ=", 1609 | "dev": true 1610 | }, 1611 | "to-fast-properties": { 1612 | "version": "2.0.0", 1613 | "resolved": "https://registry.npmjs.org/to-fast-properties/-/to-fast-properties-2.0.0.tgz", 1614 | "integrity": "sha1-3F5pjL0HkmW8c+A3doGk5Og/YW4=", 1615 | "dev": true 1616 | }, 1617 | "type-check": { 1618 | "version": "0.4.0", 1619 | "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.4.0.tgz", 1620 | "integrity": "sha512-XleUoc9uwGXqjWwXaUTZAmzMcFZ5858QA2vvx1Ur5xIcixXIP+8LnFDgRplU30us6teqdlskFfu+ae4K79Ooew==", 1621 | "dev": true, 1622 | "requires": { 1623 | "prelude-ls": "^1.2.1" 1624 | } 1625 | }, 1626 | "type-fest": { 1627 | "version": "0.20.2", 1628 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.20.2.tgz", 1629 | "integrity": "sha512-Ne+eE4r0/iWnpAxD852z3A+N0Bt5RN//NjJwRd2VFHEmrywxf5vsZlh4R6lixl6B+wz/8d+maTSAkN1FIkI3LQ==", 1630 | "dev": true 1631 | }, 1632 | "uri-js": { 1633 | "version": "4.4.1", 1634 | "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.4.1.tgz", 1635 | "integrity": "sha512-7rKUyy33Q1yc98pQ1DAmLtwX109F7TIfWlW1Ydo8Wl1ii1SeHieeh0HHfPeL2fMXK6z0s8ecKs9frCuLJvndBg==", 1636 | "dev": true, 1637 | "requires": { 1638 | "punycode": "^2.1.0" 1639 | } 1640 | }, 1641 | "v8-compile-cache": { 1642 | "version": "2.3.0", 1643 | "resolved": "https://registry.npmjs.org/v8-compile-cache/-/v8-compile-cache-2.3.0.tgz", 1644 | "integrity": "sha512-l8lCEmLcLYZh4nbunNZvQCJc5pv7+RCwa8q/LdUx8u7lsWvPDKmpodJAJNwkAhJC//dFY48KuIEmjtd4RViDrA==", 1645 | "dev": true 1646 | }, 1647 | "which": { 1648 | "version": "2.0.2", 1649 | "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", 1650 | "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", 1651 | "dev": true, 1652 | "requires": { 1653 | "isexe": "^2.0.0" 1654 | } 1655 | }, 1656 | "word-wrap": { 1657 | "version": "1.2.3", 1658 | "resolved": "https://registry.npmjs.org/word-wrap/-/word-wrap-1.2.3.tgz", 1659 | "integrity": "sha512-Hz/mrNwitNRh/HUAtM/VT/5VH+ygD6DV7mYKZAtHOrbs8U7lvPS6xf7EJKMF0uW1KJCl0H701g3ZGus+muE5vQ==", 1660 | "dev": true 1661 | }, 1662 | "wrappy": { 1663 | "version": "1.0.2", 1664 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 1665 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=", 1666 | "dev": true 1667 | }, 1668 | "yallist": { 1669 | "version": "4.0.0", 1670 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", 1671 | "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", 1672 | "dev": true 1673 | } 1674 | } 1675 | } 1676 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "csijs", 3 | "version": "1.0.9", 4 | "description": "csijs是一个前端日志系统,它将错误信息记录于本地localStorage中。无任何依赖、无入侵性。", 5 | "main": "./dist/csijs.es.js", 6 | "directories": { 7 | "test": "test" 8 | }, 9 | "scripts": { 10 | "start": "rollup -c -w", 11 | "build": "rm -rf ./dist && rollup -c", 12 | "dev": "serve", 13 | "lint": "eslint ./src", 14 | "lintfix": "eslint ./src --fix" 15 | }, 16 | "repository": { 17 | "type": "git", 18 | "url": "git@github.com:tnfe/csijs.git" 19 | }, 20 | "author": "TNFE", 21 | "license": "ISC", 22 | "keywords": [ 23 | "csijs / felog / tntlog / log / frontendlog" 24 | ], 25 | "files": [ 26 | "dist", 27 | "package.json", 28 | "README.md", 29 | ".gitignore", 30 | ".npmignore" 31 | ], 32 | "devDependencies": { 33 | "@babel/core": "^7.14.0", 34 | "@rollup/plugin-babel": "^5.3.0", 35 | "@rollup/plugin-commonjs": "^18.1.0", 36 | "@rollup/plugin-node-resolve": "^13.0.0", 37 | "eslint": "^7.26.0", 38 | "eslint-plugin-prettier": "^3.4.0", 39 | "rollup": "^2.47.0", 40 | "rollup-plugin-serve": "^1.1.0", 41 | "rollup-plugin-terser": "^7.0.2" 42 | }, 43 | "dependencies": { 44 | "excellentexport": "^3.7.0" 45 | } 46 | } 47 | -------------------------------------------------------------------------------- /rollup.config.js: -------------------------------------------------------------------------------- 1 | import * as path from "path"; 2 | import nodeResolve from '@rollup/plugin-node-resolve'; 3 | import commonjs from '@rollup/plugin-commonjs'; 4 | import { babel } from '@rollup/plugin-babel'; 5 | import { terser } from "rollup-plugin-terser"; 6 | import serve from 'rollup-plugin-serve'; 7 | 8 | const config = { 9 | input: { 10 | index: path.resolve(__dirname, 'src/index.js'), 11 | }, 12 | output: { 13 | dir: path.resolve(__dirname, 'dist/'), 14 | entryFileNames: `csijs.es.js`, 15 | chunkFileNames: 'chunks/dep-[hash].js', 16 | format: 'es', 17 | exports: 'named', 18 | externalLiveBindings: false, 19 | freeze: false, 20 | }, 21 | treeshake: { 22 | moduleSideEffects: 'no-external', 23 | propertyReadSideEffects: false, 24 | tryCatchDeoptimization: false, 25 | }, 26 | plugins: [ 27 | nodeResolve({ 28 | preferBuiltins: true, 29 | }), 30 | babel({ 31 | babelHelpers: 'bundled', 32 | exclude: "node_modules/**", 33 | }), 34 | commonjs({ 35 | extensions: ['.js'], 36 | ignoreDynamicRequires: true, 37 | }), 38 | terser(), 39 | process.argv.indexOf('-w') !== -1 && serve({ 40 | open: true, 41 | port: 8888, 42 | openPage: '/demo/demo.html', 43 | }), 44 | ], 45 | }; 46 | 47 | export default config; 48 | -------------------------------------------------------------------------------- /src/form/forms.js: -------------------------------------------------------------------------------- 1 | import Table from './table.js'; 2 | 3 | const Forms = function (feID) { 4 | this.norTable = new Table(feID, 'nor'); 5 | this.errTable = new Table(feID, 'err'); 6 | }; 7 | Forms.prototype = { 8 | addLine(type, data) { 9 | const table = (type === 'err' || type === 'error' || type === 'ERROR') ? this.errTable : this.norTable; 10 | // 防止阻塞 11 | setTimeout(() => { 12 | table.addLine(data); 13 | }, 0); 14 | }, 15 | }; 16 | 17 | export default Forms; 18 | -------------------------------------------------------------------------------- /src/form/table.js: -------------------------------------------------------------------------------- 1 | /** 2 | * 3 | * [表格格式] 4 | * 5 | * 1.基础信息 --- 键名: felog_info 6 | * ------------------------------------------------------------------------------- 7 | * fid (上报id) | uid (用户id) | length (条数) | min (最小索引) | max (最大索引) 8 | * ------------------------------------------------------------------------------- 9 | * 10 | * 补充数据 11 | * ---------------------------------------- 12 | * name (用户名字) | describe (详细描述) 13 | * ---------------------------------------- 14 | * 15 | * 2.单条信息 --- 键名: felog_[type]_[index] (felog_err_5) 16 | * -------------------------------------------------------------------------------------------------- 17 | * pid (单条记录id) | index (该条索引) | time (操作时间) | ua (用户信息) | type[nor/err] (类型) 18 | * -------------------------------------------------------------------------------------------------- 19 | * 20 | * -------------------------------------------------------------------------------------------------- 21 | * etype (错误类型) | msg (详细描述) | url (js文件地址或ajax地址) | other (其他信息,如cookie/head等) 22 | * -------------------------------------------------------------------------------------------------- 23 | * 24 | */ 25 | 26 | import { extend, getID, reset } from '../util/util'; 27 | import { read, write, remove } from '../util/store'; 28 | import { getUserAgent } from '../util/device'; 29 | 30 | const MAX_LENGTH = 45; 31 | 32 | const Info = function () { 33 | this.fid = ''; 34 | this.uid = ''; 35 | this.min = 0; 36 | this.max = 0; 37 | this.type = ''; 38 | this.length = ''; 39 | }; 40 | 41 | const Line = function () { 42 | this.pid = ''; 43 | this.index = ''; 44 | this.time = ''; 45 | this.ua = ''; 46 | 47 | this.etype = ''; 48 | this.msg = ''; 49 | this.url = ''; 50 | this.other = ''; 51 | }; 52 | 53 | 54 | const Table = function (feID, type) { 55 | const initInfo = { 56 | feid: feID, 57 | uid: getID(), 58 | min: 0, 59 | max: 0, 60 | type, 61 | length: 0, 62 | }; 63 | 64 | this.info = extend(new Info(), initInfo, read('info')); 65 | this.line = new Line(); 66 | }; 67 | 68 | Table.prototype = { 69 | 70 | // 添加一行信息 71 | addLine(data) { 72 | const initLine = { 73 | pid: getID(6), 74 | index: parseInt(this.info.max, 10) + 1, 75 | time: Date.now(), 76 | ua: getUserAgent(), 77 | }; 78 | reset(this.line); 79 | extend(this.line, initLine, data); 80 | 81 | const keyName = `${this.info.type}_${this.line.index}`; 82 | write(keyName, this.line); 83 | 84 | this.updateInfo(this.line); 85 | }, 86 | 87 | // 更新表格信息 88 | updateInfo(line) { 89 | const max = parseInt(line.index, 10); 90 | let min = parseInt(this.info.min, 10); 91 | min = !min ? max : min; 92 | 93 | let length = max - min + 1; 94 | if (length > MAX_LENGTH) { 95 | const n = length - MAX_LENGTH; 96 | for (let i = 0; i < n; i++) { 97 | const keyName = `${this.info.type}_${min + i}`; 98 | remove(keyName); 99 | } 100 | 101 | length = MAX_LENGTH; 102 | } 103 | 104 | this.info.length = length; 105 | this.info.min = max - length + 1; 106 | this.info.max = max; 107 | 108 | write('info', this.info); 109 | }, 110 | }; 111 | 112 | 113 | export default Table; 114 | -------------------------------------------------------------------------------- /src/index.js: -------------------------------------------------------------------------------- 1 | import { getUserAgent, Device } from './util/device'; 2 | import Panel from './show/panel'; 3 | import WinErr from './probe/winerr'; 4 | import AjaxErr from './probe/ajaxerr'; 5 | import FetchErr from './probe/fetcherr'; 6 | import Forms from './form/forms'; 7 | import { readLines } from './util/store'; 8 | import { arrIsNull } from './util/util'; 9 | 10 | const letIE9 = () => { 11 | getUserAgent(); 12 | const { browser } = Device; 13 | const { name } = browser; 14 | const version = parseFloat(browser.version); 15 | return name === 'ie' && version < 9; 16 | }; 17 | 18 | /** 19 | * @param opts.feID: 项目Id, 必传 20 | * @param opts.report: 函数,自定义上报函数 21 | */ 22 | class CSI { 23 | constructor(opts = {}) { 24 | this.inited = false; 25 | this.checkParams(opts); 26 | this.init(opts); 27 | } 28 | 29 | checkParams(opts) { 30 | console.log(opts); 31 | if (!opts.feID) { 32 | throw Error('feID必传'); 33 | } 34 | if (!opts.report || typeof opts.report !== 'function') { 35 | throw Error('请填写自定义上报函数'); 36 | } 37 | } 38 | 39 | // 初始化 40 | init(opts) { 41 | if (this.inited || letIE9()) return; 42 | try { 43 | this.opts = opts; 44 | const formObj = new Forms(opts.feID); 45 | (new Panel(this)).init(); 46 | (new WinErr(formObj)).probe(); 47 | (new AjaxErr(formObj)).probe(); 48 | (new FetchErr(formObj)).probe(); 49 | this.inited = true; 50 | } catch (e) { 51 | console.log(e); 52 | } 53 | } 54 | 55 | // 自定义错误 56 | probe(msg) { 57 | if (letIE9()) return; 58 | this.forms.addLine('ERROR', { 59 | etype: 'custom error', 60 | msg, 61 | }); 62 | } 63 | 64 | // 数据上报 65 | report() { 66 | if (letIE9()) return; 67 | const lines = readLines(); 68 | if (arrIsNull(lines)) return; 69 | this.opts.report(lines); 70 | } 71 | } 72 | 73 | export default CSI; 74 | -------------------------------------------------------------------------------- /src/probe/ajaxerr.js: -------------------------------------------------------------------------------- 1 | const xhrs = []; 2 | const AjaxErr = function (forms) { 3 | this.forms = forms; 4 | }; 5 | 6 | // overwrite XMLHttpRequest 7 | AjaxErr.prototype.probe = function () { 8 | const that = this; 9 | const { open } = XMLHttpRequest.prototype; 10 | XMLHttpRequest.prototype.open = (...args) => { 11 | that.addListener(this, args); 12 | open.apply(this, args); 13 | }; 14 | }; 15 | 16 | AjaxErr.prototype.addListener = function (xhr, args) { 17 | if (xhrs.indexOf(xhr) >= 0) return; 18 | xhrs.push(xhr); 19 | 20 | const { onloadend } = xhr; 21 | const { ontimeout } = xhr; 22 | 23 | xhr.onloadend = (...params) => { 24 | const status = `${xhr.status}`; 25 | if (!/^2[0-9]{1,3}/ig.test(status) && status !== '0') { 26 | this.forms.addLine('ERROR', { 27 | etype: 'ajax error', 28 | msg: `status:${xhr.status}`, 29 | js: args.join(' :'), 30 | }); 31 | 32 | onloadend && onloadend.apply(this, params); 33 | } 34 | }; 35 | 36 | xhr.ontimeout = (...params) => { 37 | this.forms.addLine('ERROR', { 38 | etype: 'ajax error', 39 | msg: `timeout ${xhr.status}`, 40 | js: args.join(' :'), 41 | }); 42 | 43 | ontimeout && ontimeout.apply(this, params); 44 | }; 45 | }; 46 | 47 | export default AjaxErr; 48 | -------------------------------------------------------------------------------- /src/probe/fetcherr.js: -------------------------------------------------------------------------------- 1 | const FetchErr = function (forms) { 2 | this.forms = forms; 3 | }; 4 | FetchErr.prototype.probe = function () { 5 | if (!window.fetch) return; 6 | const originFetch = window.fetch; 7 | window.fetch = (input, initObject) => { 8 | let method = 'GET'; 9 | let url = input || ''; 10 | if (typeof input === 'string') { 11 | method = initObject && initObject.method ? initObject.method : method; 12 | } else if (Object.prototype.toString.call(input) === '[object Request]') { 13 | method = input.method || method; 14 | url = input.url || ''; 15 | } 16 | 17 | return originFetch(input, initObject) 18 | .then((resp) => { 19 | const status = `${resp.status}`; 20 | if (!/^2[0-9]{1,3}/gi.test(status) && +status !== 0) { 21 | this.forms.addLine('ERROR', { 22 | etype: 'fetch error', 23 | msg: `status:${resp.status}`, 24 | js: `${method} :${url}`, 25 | }); 26 | } 27 | return resp; 28 | }) 29 | .catch((err) => { 30 | let msg; 31 | try { 32 | msg = err && err.message ? err.message : JSON.stringify(err); 33 | } catch (e) { 34 | msg = err && err.message ? err.message : err; 35 | } 36 | this.forms.addLine('ERROR', { 37 | etype: 'fetch error', 38 | msg, 39 | js: `${method} :${url}`, 40 | }); 41 | throw err; 42 | }); 43 | }; 44 | }; 45 | 46 | export default FetchErr; 47 | -------------------------------------------------------------------------------- /src/probe/jsonperr.js: -------------------------------------------------------------------------------- 1 | const JsonpErr = function (forms) { 2 | this.forms = forms; 3 | }; 4 | JsonpErr.prototype.probe = function () { 5 | const { createElement } = window.document; 6 | window.document.createElement = (...args) => { 7 | const dom = createElement.apply(this, args); 8 | if (args[0] === 'script') { 9 | this.addListener(dom); 10 | } 11 | return dom; 12 | }; 13 | }; 14 | 15 | // jsonp错误或者seajs/requirejs错误 16 | JsonpErr.prototype.addListener = function (dom) { 17 | dom.onerror = (e) => { 18 | this.forms.add({ 19 | msg: `script tag error${e}`, 20 | url: dom.getAttribute('src'), 21 | }); 22 | }; 23 | }; 24 | 25 | export default JsonpErr; 26 | -------------------------------------------------------------------------------- /src/probe/winerr.js: -------------------------------------------------------------------------------- 1 | // W3C 关于 ErrorEvent 的文档 2 | // https://w3c.github.io/html/webappapis.html#the-errorevent-interface 3 | // 探针 4 | const probe = (forms, message, url, line) => { 5 | forms.addLine('ERROR', { 6 | etype: 'win error', 7 | msg: message, 8 | js: `${url} : ${line}`, 9 | }); 10 | return true; 11 | }; 12 | 13 | const WinErr = function (forms) { 14 | this.forms = forms; 15 | }; 16 | 17 | WinErr.prototype.probe = function () { 18 | const { onerror } = window; 19 | window.onerror = (...args) => { 20 | if (typeof onerror === 'function') onerror.apply(this, args); 21 | // probe(this.forms, message, url, line); 22 | probe(this.forms, args[0], args[1], args[2]); 23 | }; 24 | }; 25 | 26 | export default WinErr; 27 | -------------------------------------------------------------------------------- /src/show/panel.js: -------------------------------------------------------------------------------- 1 | import ShowPage from './showpage'; 2 | 3 | function Panel(csi) { 4 | this.csi = csi; 5 | } 6 | 7 | Panel.prototype = { 8 | init() { 9 | const showPage = new ShowPage(this.csi.report.bind(this.csi)); 10 | 11 | document.addEventListener('keydown', (event) => { 12 | event = event || window.event; 13 | if (event.ctrlKey && parseInt(event.key, 10) === 6) { 14 | showPage.toggleShow(); 15 | } 16 | }); 17 | }, 18 | }; 19 | 20 | export default Panel; 21 | -------------------------------------------------------------------------------- /src/show/showpage.js: -------------------------------------------------------------------------------- 1 | import { readLines } from '../util/store'; 2 | import { arrIsNull, formatTime } from '../util/util'; 3 | import ExcellentExport from 'excellentexport'; 4 | 5 | function createBtn(text) { 6 | const btn = document.createElement('a'); 7 | btn.className = 'screenshots'; 8 | btn.innerText = text; 9 | btn.style.width = '120px'; 10 | btn.style.height = '40px'; 11 | btn.style.backgroundColor = '#0064CD'; 12 | btn.style.color = '#fff'; 13 | btn.style.lineHeight = '40px'; 14 | btn.style.cursor = 'pointer'; 15 | btn.style.textAlign = 'center'; 16 | btn.style.borderRadius = '20px'; 17 | return btn; 18 | } 19 | 20 | // 添加td 21 | function addTD(html) { 22 | const td = document.createElement('td'); 23 | td.style.border = '1px solid #0064CD'; 24 | td.style.padding = '5px 5px 5px 10px'; 25 | td.innerHTML = html; 26 | return td; 27 | } 28 | 29 | function addElement(tag, style) { 30 | const ele = document.createElement(tag); 31 | for (const key in style) { 32 | ele.style[key] = style[key]; 33 | } 34 | return ele; 35 | } 36 | 37 | function ShowPage(report) { 38 | this.page = null; 39 | this.blackBg = null; 40 | this.table = null; 41 | this.appended = false; 42 | this.canReport = true; 43 | this.csiReport = report; 44 | } 45 | 46 | // 创建页面 47 | ShowPage.prototype.createPage = function () { 48 | this.page = this.page || addElement('div', { 49 | zIndex: 9999, 50 | position: 'fixed', 51 | top: '0', 52 | left: '0', 53 | width: '100%', 54 | height: '100%', 55 | }); 56 | 57 | this.blackBg = this.blackBg || addElement('div', { 58 | zIndex: 0, 59 | position: 'absolute', 60 | width: '100%', 61 | height: '100%', 62 | backgroundColor: 'rgba(0,0,0,0.6)', 63 | }); 64 | 65 | this.title = this.title || addElement('div', { 66 | zIndex: 2, 67 | position: 'absolute', 68 | width: '400px', 69 | left: '50%', 70 | top: '30px', 71 | fontSize: '26px', 72 | color: '#000', 73 | textAlign: 'center', 74 | marginLeft: '-200px', 75 | }); 76 | 77 | this.container = this.container || addElement('div', { 78 | zIndex: 1, 79 | position: 'absolute', 80 | width: '1000px', 81 | height: '60vh', 82 | left: '50%', 83 | top: '30px', 84 | marginLeft: '-500px', 85 | }); 86 | 87 | this.tableCon = this.tableCon || addElement('div', { 88 | // width: "100%", 89 | height: '100%', 90 | border: '12px solid #0064CD', 91 | backgroundColor: '#fff', 92 | overflow: 'scroll', 93 | // overflowX: "hidden" 94 | }); 95 | 96 | this.table = this.table || addElement('table', { 97 | color: '#333333', 98 | width: '100%', 99 | borderCollapse: 'collapse', 100 | }); 101 | 102 | this.btnCon = this.btnCon || addElement('div', { 103 | margin: '20px auto', 104 | width: '400px', 105 | display: 'block', 106 | overflow: 'hidden', 107 | }); 108 | 109 | if (!this.btn1) { 110 | this.btn1 = createBtn('下载'); 111 | this.btn1.style.float = 'left'; 112 | } 113 | if (!this.btn2) { 114 | this.btn2 = createBtn('上报'); 115 | this.btn2.style.float = 'right'; 116 | } 117 | 118 | this.page.append(this.blackBg); 119 | this.page.append(this.container); 120 | this.page.append(this.title); 121 | 122 | this.container.append(this.tableCon); 123 | this.tableCon.append(this.table); 124 | 125 | this.container.append(this.btnCon); 126 | this.btnCon.append(this.btn1); 127 | this.btnCon.append(this.btn2); 128 | 129 | setTimeout(() => { 130 | this.addEventListener(); 131 | }, 300); 132 | }; 133 | 134 | // 添加事件侦听 135 | ShowPage.prototype.addEventListener = function () { 136 | if (this.addEvented) return; 137 | const self = this; 138 | console.log(self); 139 | this.blackBg.addEventListener('click', () => { 140 | this.remove(); 141 | }); 142 | 143 | this.btn1.addEventListener('click', () => { 144 | ExcellentExport.excel(this.btn1, this.table); 145 | }); 146 | 147 | this.btn2.addEventListener('click', () => { 148 | if (this.canReport) { 149 | const lines = readLines(); 150 | if (!arrIsNull(lines) && this.csiReport) { 151 | this.csiReport(); 152 | } 153 | } else { 154 | alert('对不起该功能现在没有支持!'); 155 | } 156 | }); 157 | 158 | this.addEvented = true; 159 | }; 160 | 161 | // 填充内容 162 | ShowPage.prototype.fillContent = function () { 163 | const lines = readLines(); 164 | 165 | if (arrIsNull(lines)) { 166 | const info = addElement('div', { 167 | width: '100%', 168 | position: 'absolute', 169 | top: '100px', 170 | textAlign: 'center', 171 | fontSize: '24px', 172 | }); 173 | info.innerText = '暂时没有错误信息'; 174 | this.table.append(info); 175 | } else { 176 | for (let i = lines.length - 1; i >= 0; i--) { 177 | const line = lines[i]; 178 | 179 | if (!line) continue; 180 | 181 | // 添加内容 182 | const tr = addElement('tr', { 183 | border: '1px solid #0064CD', 184 | }); 185 | const td1 = addTD(formatTime(line.time)); 186 | const td2 = addTD(line.etype); 187 | const td3 = addTD(line.js); 188 | const td4 = addTD(line.msg); 189 | td4.style.color = '#ff0000'; 190 | const td5 = addTD(line.ua); 191 | 192 | tr.append(td1); 193 | tr.append(td2); 194 | tr.append(td3); 195 | tr.append(td4); 196 | tr.append(td5); 197 | 198 | this.table.append(tr); 199 | } 200 | } 201 | }; 202 | 203 | // 添加标题 204 | ShowPage.prototype.addTitle = function () { 205 | const tr = addElement('tr', { 206 | height: '35px', 207 | textAlign: 'center', 208 | backgroundColor: '#ccc', 209 | }); 210 | 211 | const td1 = document.createElement('td'); 212 | td1.append(document.createTextNode('time')); 213 | const td2 = document.createElement('td'); 214 | td2.append(document.createTextNode('type')); 215 | const td3 = document.createElement('td'); 216 | td3.append(document.createTextNode('js')); 217 | const td4 = document.createElement('td'); 218 | td4.append(document.createTextNode('msg')); 219 | const td5 = document.createElement('td'); 220 | td5.append(document.createTextNode('UA')); 221 | tr.append(td1); 222 | tr.append(td2); 223 | tr.append(td3); 224 | tr.append(td4); 225 | tr.append(td5); 226 | this.table.append(tr); 227 | }; 228 | 229 | // ------------------------------------------------------------------------------ 230 | // 切换 231 | // ------------------------------------------------------------------------------ 232 | ShowPage.prototype.appendTo = function () { 233 | this.createPage(); 234 | this.table.innerHTML = ''; 235 | this.addTitle(); 236 | 237 | this.fillContent(); 238 | 239 | this.appended = true; 240 | document.body.append(this.page); 241 | }; 242 | 243 | ShowPage.prototype.remove = function () { 244 | this.appended = false; 245 | this.page.remove(); 246 | }; 247 | 248 | ShowPage.prototype.toggleShow = function () { 249 | if (this.appended) this.remove(); 250 | else this.appendTo(); 251 | }; 252 | 253 | export default ShowPage; 254 | -------------------------------------------------------------------------------- /src/util/device.js: -------------------------------------------------------------------------------- 1 | let composeUserAgent; 2 | // //////////////////////////////////////////////////////////////// 3 | // 4 | // 浏览器检测 http://www.bkjia.com/Javascript/1153785.html 5 | // 6 | // //////////////////////////////////////////////////////////////// 7 | const BROWSER = { 8 | qq: /\bm?qqbrowser\/([0-9.]+)/, 9 | 360: (ua) => { 10 | if (ua.indexOf('360 aphone browser') !== -1) return /\b360 aphone browser \(([^\)]+)\)/; 11 | return /\b360(?:se|ee|chrome|browser)\b/; 12 | }, 13 | aoyou: /\baoyou/, 14 | webview: /\bcpu(?: iphone)? os (?:[0-9._]+).+\bapplewebkit\b/, 15 | firefox: /\bfirefox\/([0-9.ab]+)/, 16 | chrome: / (?:chrome|crios|crmo)\/([0-9.]+)/, 17 | ie: /\b(?:msie |ie |trident\/[0-9].*rv[ :])([0-9.]+)/, 18 | // Android 默认浏览器。该规则需要在 safari 之前。 19 | android: (ua) => { 20 | if (ua.indexOf('android') === -1) { 21 | return ''; 22 | } 23 | return /\bversion\/([0-9.]+(?: beta)?)/; 24 | }, 25 | safari: /\bversion\/([0-9.]+(?: beta)?)(?: mobile(?:\/[a-z0-9]+)?)? safari\//, 26 | opera: /\bopera/, 27 | unknow: 'unknow', 28 | }; 29 | 30 | // //////////////////////////////////////////////////////////////// 31 | // 32 | // 系统检测 33 | // 34 | // //////////////////////////////////////////////////////////////// 35 | const OS = { 36 | windows: /\bwindows nt ([0-9.]+)/, 37 | macosx: /\bmac os x ([0-9._]+)/, 38 | linux: 'linux', 39 | 40 | wphone: (ua) => { 41 | if (ua.indexOf('windows phone ') !== -1) { 42 | return /\bwindows phone (?:os )?([0-9.]+)/; 43 | } 44 | if (ua.indexOf('xblwp') !== -1) { 45 | return /\bxblwp([0-9.]+)/; 46 | } 47 | if (ua.indexOf('zunewp') !== -1) { 48 | return /\bzunewp([0-9.]+)/; 49 | } 50 | return 'windows phone'; 51 | }, 52 | 53 | ios: (ua) => { 54 | if (/\bcpu(?: iphone)? os /.test(ua)) { 55 | return /\bcpu(?: iphone)? os ([0-9._]+)/; 56 | } 57 | if (ua.indexOf('iph os ') !== -1) { 58 | return /\biph os ([0-9_]+)/; 59 | } 60 | return /\bios\b/; 61 | }, 62 | 63 | android: (ua) => { 64 | if (ua.indexOf('android') >= 0) { 65 | return /\bandroid[ \/-]?([0-9.x]+)?/; 66 | } 67 | if (ua.indexOf('adr') >= 0) { 68 | if (ua.indexOf('mqqbrowser') >= 0) { 69 | return /\badr[ ]\(linux; u; ([0-9.]+)?/; 70 | } 71 | return /\badr(?:[ ]([0-9.]+))?/; 72 | } 73 | 74 | return 'android'; 75 | }, 76 | 77 | unknow: 'unknow', 78 | }; 79 | 80 | // //////////////////////////////////////////////////////////////// 81 | // 82 | // 平台检测 83 | // 84 | // //////////////////////////////////////////////////////////////// 85 | const PLATFORM = { 86 | weixin: /micromessenger/gi, 87 | qqvideo: /qqlivebrowser/gi, 88 | qqvideoipad: /qqlivehdbrowser/gi, 89 | shouqq: /qq\//gi, 90 | qqnews: /qqnews/gi, 91 | qzone: /qzone\//gi, 92 | unknow: 'unknow', 93 | }; 94 | 95 | // //////////////////////////////////////////////////////////////// 96 | // 97 | // 类型检测 98 | // 99 | // //////////////////////////////////////////////////////////////// 100 | const typeIs = (obj, type) => Object.prototype.toString.call(obj) === `[object ${type}]`; 101 | 102 | const detect = (type, expression) => { 103 | const info = Device[type.toLowerCase()]; 104 | for (const name in expression) { 105 | const fun = expression[name]; 106 | const result = typeIs(fun, 'Function') ? fun(getLocalUserAgent()) : fun; 107 | 108 | info.name = name; 109 | 110 | if (result === true) { 111 | break; 112 | } else if (toString(result) === '[object String]') { 113 | if (getLocalUserAgent().indexOf(result) !== -1) { 114 | break; 115 | } 116 | } else if (typeIs(result, 'Object')) { 117 | if (result.version !== undefined) { 118 | info.version = result.version; 119 | break; 120 | } 121 | } else if (result && result.exec) { 122 | const m = result.exec(getLocalUserAgent()); 123 | if (m) { 124 | if (m.length >= 2 && m[1]) info.version = m[1].replace(/_/g, '.'); 125 | else info.version = '0.0.0'; 126 | 127 | break; 128 | } 129 | } 130 | } 131 | 132 | return info; 133 | }; 134 | 135 | // //////////////////////////////////////////////////////////////// 136 | // 137 | // 获取userAgent 138 | // 139 | // //////////////////////////////////////////////////////////////// 140 | const getLocalUserAgent = () => { 141 | if (!composeUserAgent) { 142 | const gap = '__'; 143 | const userAgent = navigator.userAgent || ''; 144 | const platform = navigator.platform || ''; 145 | const appVersion = navigator.appVersion || ''; 146 | const vendor = navigator.vendor || ''; 147 | composeUserAgent = userAgent + gap + platform + gap + appVersion + gap + vendor; 148 | composeUserAgent = composeUserAgent.toLowerCase(); 149 | } 150 | 151 | return composeUserAgent; 152 | }; 153 | export const test = () => { 154 | detect('os', OS); 155 | detect('platform', PLATFORM); 156 | detect('browser', BROWSER); 157 | }; 158 | export const testOnce = () => { 159 | if (!composeUserAgent) { 160 | detect('os', OS); 161 | detect('platform', PLATFORM); 162 | detect('browser', BROWSER); 163 | } 164 | }; 165 | 166 | export const getUserAgent = (type) => { 167 | testOnce(); 168 | 169 | const gap = ' '; 170 | if (type === 'all' || type === 'full') return getLocalUserAgent(); 171 | if (type !== undefined) return Device[type].name; 172 | return `${Device.os.name}${gap}_${Device.os.version} ${Device.browser.name}${gap}_${Device.browser.version}`; 173 | }; 174 | 175 | export const Device = { 176 | os: { 177 | name: 'unknow', 178 | version: '0.0.0', 179 | }, 180 | platform: { 181 | name: 'unknow', 182 | version: '0.0.0', 183 | }, 184 | browser: { 185 | name: 'unknow', 186 | version: '0.0.0', 187 | }, 188 | }; 189 | -------------------------------------------------------------------------------- /src/util/scriptloader.js: -------------------------------------------------------------------------------- 1 | const urlStorage = {}; 2 | // //////////////////////////////////////////////////////////////////// 3 | // 4 | // 插入