├── .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 |
3 |
4 |
5 |
6 |
7 |
CSI.JS 重建犯罪现场
8 |
9 | CSI.JS是一个前端日志系统,它将错误信息记录于本地localStorage中。无任何依赖、无入侵性。使用非常简单,很容易引入你的系统中,而且不会造成任何影响。
10 | 它可以帮你快速重建犯罪现场。
11 |
12 |
13 |
14 |
15 |
21 |
22 |
23 |
24 | 无入侵
|
25 | 轻量易用 |
26 | 功能强大 |
27 | 高性能 |
28 |
29 |
30 | 丢上去不管,我们承诺永不入侵你的业务! |
31 | 兼容各种系统,不管你使用的是jQuery、angular1/2、React、Vue,都可以使用它 |
32 | 完善的查错机制,截图预览、导出excel、直接上传到后台查看等 |
33 | 文件超小,Gzip 5k对你几乎毫无影响 |
34 |
35 |
36 |
37 |
38 |
39 |
40 |
41 | 
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 |
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 | // 插入