├── .github ├── FUNDING.yml └── workflows │ └── test.yml ├── .gitignore ├── LICENSE.txt ├── README.md ├── bin └── sync-vendor-libs.sh ├── css └── demo.css ├── index.html ├── js ├── compile.js ├── demo │ └── demo.js ├── runtime.js ├── tmpl.js ├── tmpl.min.js └── tmpl.min.js.map ├── package-lock.json ├── package.json └── test ├── index.html ├── test.js └── vendor ├── chai.js ├── mocha.css └── mocha.js /.github/FUNDING.yml: -------------------------------------------------------------------------------- 1 | github: [blueimp] 2 | -------------------------------------------------------------------------------- /.github/workflows/test.yml: -------------------------------------------------------------------------------- 1 | name: Test 2 | 3 | on: [push, pull_request] 4 | 5 | jobs: 6 | test: 7 | runs-on: ubuntu-latest 8 | strategy: 9 | matrix: 10 | node-version: [14, 16] 11 | steps: 12 | - uses: actions/checkout@v2 13 | - uses: actions/setup-node@v2 14 | with: 15 | node-version: ${{ matrix.node-version }} 16 | - run: npm install 17 | - run: npm run build --if-present 18 | - run: npm run test 19 | -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | node_modules 2 | -------------------------------------------------------------------------------- /LICENSE.txt: -------------------------------------------------------------------------------- 1 | MIT License 2 | 3 | Copyright © 2011 Sebastian Tschan, https://blueimp.net 4 | 5 | Permission is hereby granted, free of charge, to any person obtaining a copy of 6 | this software and associated documentation files (the "Software"), to deal in 7 | the Software without restriction, including without limitation the rights to 8 | use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of 9 | the Software, and to permit persons to whom the Software is furnished to do so, 10 | 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, FITNESS 17 | FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR 18 | COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER 19 | IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN 20 | CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. 21 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # JavaScript Templates 2 | 3 | ## Contents 4 | 5 | - [Demo](https://blueimp.github.io/JavaScript-Templates/) 6 | - [Description](#description) 7 | - [Usage](#usage) 8 | - [Client-side](#client-side) 9 | - [Server-side](#server-side) 10 | - [Requirements](#requirements) 11 | - [API](#api) 12 | - [tmpl() function](#tmpl-function) 13 | - [Templates cache](#templates-cache) 14 | - [Output encoding](#output-encoding) 15 | - [Local helper variables](#local-helper-variables) 16 | - [Template function argument](#template-function-argument) 17 | - [Template parsing](#template-parsing) 18 | - [Templates syntax](#templates-syntax) 19 | - [Interpolation](#interpolation) 20 | - [Evaluation](#evaluation) 21 | - [Compiled templates](#compiled-templates) 22 | - [Tests](#tests) 23 | - [License](#license) 24 | 25 | ## Description 26 | 27 | 1KB lightweight, fast & powerful JavaScript templating engine with zero 28 | dependencies. 29 | Compatible with server-side environments like [Node.js](https://nodejs.org/), 30 | module loaders like [RequireJS](https://requirejs.org/) or 31 | [webpack](https://webpack.js.org/) and all web browsers. 32 | 33 | ## Usage 34 | 35 | ### Client-side 36 | 37 | Install the **blueimp-tmpl** package with [NPM](https://www.npmjs.org/): 38 | 39 | ```sh 40 | npm install blueimp-tmpl 41 | ``` 42 | 43 | Include the (minified) JavaScript Templates script in your HTML markup: 44 | 45 | ```html 46 | 47 | ``` 48 | 49 | Add a script section with type **"text/x-tmpl"**, a unique **id** property and 50 | your template definition as content: 51 | 52 | ```html 53 | 64 | ``` 65 | 66 | **"o"** (the lowercase letter) is a reference to the data parameter of the 67 | template function (see the API section on how to modify this identifier). 68 | 69 | In your application code, create a JavaScript object to use as data for the 70 | template: 71 | 72 | ```js 73 | var data = { 74 | title: 'JavaScript Templates', 75 | license: { 76 | name: 'MIT license', 77 | url: 'https://opensource.org/licenses/MIT' 78 | }, 79 | features: ['lightweight & fast', 'powerful', 'zero dependencies'] 80 | } 81 | ``` 82 | 83 | In a real application, this data could be the result of retrieving a 84 | [JSON](https://json.org/) resource. 85 | 86 | Render the result by calling the **tmpl()** method with the id of the template 87 | and the data object as arguments: 88 | 89 | ```js 90 | document.getElementById('result').innerHTML = tmpl('tmpl-demo', data) 91 | ``` 92 | 93 | ### Server-side 94 | 95 | The following is an example how to use the JavaScript Templates engine on the 96 | server-side with [Node.js](https://nodejs.org/). 97 | 98 | Install the **blueimp-tmpl** package with [NPM](https://www.npmjs.org/): 99 | 100 | ```sh 101 | npm install blueimp-tmpl 102 | ``` 103 | 104 | Add a file **template.html** with the following content: 105 | 106 | ```html 107 | 108 | {%=o.title%} 109 |

{%=o.title%}

110 |

Features

111 | 116 | ``` 117 | 118 | Add a file **server.js** with the following content: 119 | 120 | ```js 121 | require('http') 122 | .createServer(function (req, res) { 123 | var fs = require('fs'), 124 | // The tmpl module exports the tmpl() function: 125 | tmpl = require('./tmpl'), 126 | // Use the following version if you installed the package with npm: 127 | // tmpl = require("blueimp-tmpl"), 128 | // Sample data: 129 | data = { 130 | title: 'JavaScript Templates', 131 | url: 'https://github.com/blueimp/JavaScript-Templates', 132 | features: ['lightweight & fast', 'powerful', 'zero dependencies'] 133 | } 134 | // Override the template loading method: 135 | tmpl.load = function (id) { 136 | var filename = id + '.html' 137 | console.log('Loading ' + filename) 138 | return fs.readFileSync(filename, 'utf8') 139 | } 140 | res.writeHead(200, { 'Content-Type': 'text/x-tmpl' }) 141 | // Render the content: 142 | res.end(tmpl('template', data)) 143 | }) 144 | .listen(8080, 'localhost') 145 | console.log('Server running at http://localhost:8080/') 146 | ``` 147 | 148 | Run the application with the following command: 149 | 150 | ```sh 151 | node server.js 152 | ``` 153 | 154 | ## Requirements 155 | 156 | The JavaScript Templates script has zero dependencies. 157 | 158 | ## API 159 | 160 | ### tmpl() function 161 | 162 | The **tmpl()** function is added to the global **window** object and can be 163 | called as global function: 164 | 165 | ```js 166 | var result = tmpl('tmpl-demo', data) 167 | ``` 168 | 169 | The **tmpl()** function can be called with the id of a template, or with a 170 | template string: 171 | 172 | ```js 173 | var result = tmpl('

{%=o.title%}

', data) 174 | ``` 175 | 176 | If called without second argument, **tmpl()** returns a reusable template 177 | function: 178 | 179 | ```js 180 | var func = tmpl('

{%=o.title%}

') 181 | document.getElementById('result').innerHTML = func(data) 182 | ``` 183 | 184 | ### Templates cache 185 | 186 | Templates loaded by id are cached in the map **tmpl.cache**: 187 | 188 | ```js 189 | var func = tmpl('tmpl-demo'), // Loads and parses the template 190 | cached = typeof tmpl.cache['tmpl-demo'] === 'function', // true 191 | result = tmpl('tmpl-demo', data) // Uses cached template function 192 | 193 | tmpl.cache['tmpl-demo'] = null 194 | result = tmpl('tmpl-demo', data) // Loads and parses the template again 195 | ``` 196 | 197 | ### Output encoding 198 | 199 | The method **tmpl.encode** is used to escape HTML special characters in the 200 | template output: 201 | 202 | ```js 203 | var output = tmpl.encode('<>&"\'\x00') // Renders "<>&"'" 204 | ``` 205 | 206 | **tmpl.encode** makes use of the regular expression **tmpl.encReg** and the 207 | encoding map **tmpl.encMap** to match and replace special characters, which can 208 | be modified to change the behavior of the output encoding. 209 | Strings matched by the regular expression, but not found in the encoding map are 210 | removed from the output. This allows for example to automatically trim input 211 | values (removing whitespace from the start and end of the string): 212 | 213 | ```js 214 | tmpl.encReg = /(^\s+)|(\s+$)|[<>&"'\x00]/g 215 | var output = tmpl.encode(' Banana! ') // Renders "Banana" (without whitespace) 216 | ``` 217 | 218 | ### Local helper variables 219 | 220 | The local variables available inside the templates are the following: 221 | 222 | - **o**: The data object given as parameter to the template function (see the 223 | next section on how to modify the parameter name). 224 | - **tmpl**: A reference to the **tmpl** function object. 225 | - **\_s**: The string for the rendered result content. 226 | - **\_e**: A reference to the **tmpl.encode** method. 227 | - **print**: Helper function to add content to the rendered result string. 228 | - **include**: Helper function to include the return value of a different 229 | template in the result. 230 | 231 | To introduce additional local helper variables, the string **tmpl.helper** can 232 | be extended. The following adds a convenience function for _console.log_ and a 233 | streaming function, that streams the template rendering result back to the 234 | callback argument (note the comma at the beginning of each variable 235 | declaration): 236 | 237 | ```js 238 | tmpl.helper += 239 | ',log=function(){console.log.apply(console, arguments)}' + 240 | ",st='',stream=function(cb){var l=st.length;st=_s;cb( _s.slice(l));}" 241 | ``` 242 | 243 | Those new helper functions could be used to stream the template contents to the 244 | console output: 245 | 246 | ```html 247 | 263 | ``` 264 | 265 | ### Template function argument 266 | 267 | The generated template functions accept one argument, which is the data object 268 | given to the **tmpl(id, data)** function. This argument is available inside the 269 | template definitions as parameter **o** (the lowercase letter). 270 | 271 | The argument name can be modified by overriding **tmpl.arg**: 272 | 273 | ```js 274 | tmpl.arg = 'p' 275 | 276 | // Renders "

JavaScript Templates

": 277 | var result = tmpl('

{%=p.title%}

', { title: 'JavaScript Templates' }) 278 | ``` 279 | 280 | ### Template parsing 281 | 282 | The template contents are matched and replaced using the regular expression 283 | **tmpl.regexp** and the replacement function **tmpl.func**. The replacement 284 | function operates based on the 285 | [parenthesized submatch strings](https://developer.mozilla.org/en/JavaScript/Reference/Global_Objects/String/replace#Specifying_a_function_as_a_parameter). 286 | 287 | To use different tags for the template syntax, override **tmpl.regexp** with a 288 | modified regular expression, by exchanging all occurrences of "{%" and "%}", 289 | e.g. with "[%" and "%]": 290 | 291 | ```js 292 | tmpl.regexp = /([\s'\\])(?!(?:[^[]|\[(?!%))*%\])|(?:\[%(=|#)([\s\S]+?)%\])|(\[%)|(%\])/g 293 | ``` 294 | 295 | By default, the plugin preserves whitespace (newlines, carriage returns, tabs 296 | and spaces). To strip unnecessary whitespace, you can override the **tmpl.func** 297 | function, e.g. with the following code: 298 | 299 | ```js 300 | var originalFunc = tmpl.func 301 | tmpl.func = function (s, p1, p2, p3, p4, p5, offset, str) { 302 | if (p1 && /\s/.test(p1)) { 303 | if ( 304 | !offset || 305 | /\s/.test(str.charAt(offset - 1)) || 306 | /^\s+$/g.test(str.slice(offset)) 307 | ) { 308 | return '' 309 | } 310 | return ' ' 311 | } 312 | return originalFunc.apply(tmpl, arguments) 313 | } 314 | ``` 315 | 316 | ## Templates syntax 317 | 318 | ### Interpolation 319 | 320 | Print variable with HTML special characters escaped: 321 | 322 | ```html 323 |

{%=o.title%}

324 | ``` 325 | 326 | Print variable without escaping: 327 | 328 | ```html 329 |

{%#o.user_id%}

330 | ``` 331 | 332 | Print output of function calls: 333 | 334 | ```html 335 | Website 336 | ``` 337 | 338 | Use dot notation to print nested properties: 339 | 340 | ```html 341 | {%=o.author.name%} 342 | ``` 343 | 344 | ### Evaluation 345 | 346 | Use **print(str)** to add escaped content to the output: 347 | 348 | ```html 349 | Year: {% var d=new Date(); print(d.getFullYear()); %} 350 | ``` 351 | 352 | Use **print(str, true)** to add unescaped content to the output: 353 | 354 | ```html 355 | {% print("Fast & powerful", true); %} 356 | ``` 357 | 358 | Use **include(str, obj)** to include content from a different template: 359 | 360 | ```html 361 |
362 | {% include('tmpl-link', {name: "Website", url: "https://example.org"}); %} 363 |
364 | ``` 365 | 366 | **If else condition**: 367 | 368 | ```html 369 | {% if (o.author.url) { %} 370 | {%=o.author.name%} 371 | {% } else { %} 372 | No author url. 373 | {% } %} 374 | ``` 375 | 376 | **For loop**: 377 | 378 | ```html 379 | 384 | ``` 385 | 386 | ## Compiled templates 387 | 388 | The JavaScript Templates project comes with a compilation script, that allows 389 | you to compile your templates into JavaScript code and combine them with a 390 | minimal Templates runtime into one combined JavaScript file. 391 | 392 | The compilation script is built for [Node.js](https://nodejs.org/). 393 | To use it, first install the JavaScript Templates project via 394 | [NPM](https://www.npmjs.org/): 395 | 396 | ```sh 397 | npm install blueimp-tmpl 398 | ``` 399 | 400 | This will put the executable **tmpl.js** into the folder **node_modules/.bin**. 401 | It will also make it available on your PATH if you install the package globally 402 | (by adding the **-g** flag to the install command). 403 | 404 | The **tmpl.js** executable accepts the paths to one or multiple template files 405 | as command line arguments and prints the generated JavaScript code to the 406 | console output. The following command line shows you how to store the generated 407 | code in a new JavaScript file that can be included in your project: 408 | 409 | ```sh 410 | tmpl.js index.html > tmpl.js 411 | ``` 412 | 413 | The files given as command line arguments to **tmpl.js** can either be pure 414 | template files or HTML documents with embedded template script sections. For the 415 | pure template files, the file names (without extension) serve as template ids. 416 | The generated file can be included in your project as a replacement for the 417 | original **tmpl.js** runtime. It provides you with the same API and provides a 418 | **tmpl(id, data)** function that accepts the id of one of your templates as 419 | first and a data object as optional second parameter. 420 | 421 | ## Tests 422 | 423 | The JavaScript Templates project comes with 424 | [Unit Tests](https://en.wikipedia.org/wiki/Unit_testing). 425 | There are two different ways to run the tests: 426 | 427 | - Open test/index.html in your browser or 428 | - run `npm test` in the Terminal in the root path of the repository package. 429 | 430 | The first one tests the browser integration, the second one the 431 | [Node.js](https://nodejs.org/) integration. 432 | 433 | ## License 434 | 435 | The JavaScript Templates script is released under the 436 | [MIT license](https://opensource.org/licenses/MIT). 437 | -------------------------------------------------------------------------------- /bin/sync-vendor-libs.sh: -------------------------------------------------------------------------------- 1 | #!/bin/sh 2 | cd "$(dirname "$0")/.." 3 | cp node_modules/chai/chai.js test/vendor/ 4 | cp node_modules/mocha/mocha.js test/vendor/ 5 | cp node_modules/mocha/mocha.css test/vendor/ 6 | -------------------------------------------------------------------------------- /css/demo.css: -------------------------------------------------------------------------------- 1 | /* 2 | * JavaScript Templates Demo CSS 3 | * https://github.com/blueimp/JavaScript-Templates 4 | * 5 | * Copyright 2013, Sebastian Tschan 6 | * https://blueimp.net 7 | * 8 | * Licensed under the MIT license: 9 | * https://opensource.org/licenses/MIT 10 | */ 11 | 12 | body { 13 | max-width: 990px; 14 | margin: 0 auto; 15 | padding: 1em; 16 | font-family: system-ui, -apple-system, 'Segoe UI', Roboto, 'Helvetica Neue', 17 | Arial, sans-serif; 18 | -webkit-text-size-adjust: 100%; 19 | line-height: 1.4; 20 | background: #212121; 21 | color: #dedede; 22 | } 23 | a { 24 | color: #61afef; 25 | text-decoration: none; 26 | } 27 | a:visited { 28 | color: #56b6c2; 29 | } 30 | a:hover { 31 | color: #98c379; 32 | } 33 | h1, 34 | h2, 35 | h3, 36 | h4, 37 | h5, 38 | h6 { 39 | margin-top: 1.5em; 40 | margin-bottom: 0.5em; 41 | } 42 | h1 { 43 | margin-top: 0.5em; 44 | } 45 | label { 46 | display: inline-block; 47 | margin-bottom: 0.25em; 48 | } 49 | button, 50 | select, 51 | input, 52 | textarea, 53 | div.result { 54 | -webkit-appearance: none; 55 | box-sizing: border-box; 56 | margin: 0; 57 | padding: 0.5em 0.75em; 58 | font-family: inherit; 59 | font-size: 100%; 60 | line-height: 1.4; 61 | background: #414141; 62 | color: #dedede; 63 | border: 1px solid #363636; 64 | border-radius: 5px; 65 | box-shadow: 0 0 4px rgba(0, 0, 0, 0.07); 66 | } 67 | input, 68 | textarea, 69 | div.result { 70 | width: 100%; 71 | box-shadow: inset 0 0 4px rgba(0, 0, 0, 0.07); 72 | } 73 | textarea { 74 | display: block; 75 | overflow: auto; 76 | } 77 | button { 78 | background: #3c76a7; 79 | background: linear-gradient(180deg, #3c76a7, #225c8d); 80 | border-color: #225c8d; 81 | color: #fff; 82 | } 83 | button[type='submit'] { 84 | background: #6fa349; 85 | background: linear-gradient(180deg, #6fa349, #568a30); 86 | border-color: #568a30; 87 | } 88 | button[type='reset'] { 89 | background: #d79435; 90 | background: linear-gradient(180deg, #d79435, #be7b1c); 91 | border-color: #be7b1c; 92 | } 93 | button:active { 94 | box-shadow: inset 0 0 8px rgba(0, 0, 0, 0.5); 95 | } 96 | 97 | pre, 98 | textarea.code { 99 | font-family: SFMono-Regular, Consolas, Liberation Mono, Menlo, monospace; 100 | } 101 | 102 | @media (prefers-color-scheme: light) { 103 | body { 104 | background: #ececec; 105 | color: #212121; 106 | } 107 | a { 108 | color: #225c8d; 109 | } 110 | a:visited { 111 | color: #378f9a; 112 | } 113 | a:hover { 114 | color: #6fa349; 115 | } 116 | input, 117 | textarea, 118 | div.result { 119 | background: #fff; 120 | border-color: #d1d1d1; 121 | color: #212121; 122 | } 123 | } 124 | 125 | @media (min-width: 540px) { 126 | #navigation { 127 | list-style: none; 128 | padding: 0; 129 | } 130 | #navigation li { 131 | display: inline-block; 132 | } 133 | #navigation li:not(:first-child)::before { 134 | content: ' | '; 135 | } 136 | } 137 | -------------------------------------------------------------------------------- /index.html: -------------------------------------------------------------------------------- 1 | 2 | 14 | 15 | 16 | 19 | 20 | JavaScript Templates Demo 21 | 25 | 26 | 27 | 28 | 29 |

JavaScript Templates Demo

30 |

31 | 1KB lightweight, fast & powerful 32 | JavaScript 33 | templating engine with zero dependencies.
34 | Compatible with server-side environments like 35 | Node.js, module loaders like 36 | RequireJS or 37 | webpack and all web browsers. 38 |

39 | 59 |
60 |

61 | 62 | 63 |

64 |

65 | 66 | 67 |

68 |

69 | 70 | 71 |

72 |

Result

73 |
74 |
75 | 86 | 100 | 104 | 105 | 106 | 107 | 108 | -------------------------------------------------------------------------------- /js/compile.js: -------------------------------------------------------------------------------- 1 | #!/usr/bin/env node 2 | /* 3 | * JavaScript Templates Compiler 4 | * https://github.com/blueimp/JavaScript-Templates 5 | * 6 | * Copyright 2011, Sebastian Tschan 7 | * https://blueimp.net 8 | * 9 | * Licensed under the MIT license: 10 | * https://opensource.org/licenses/MIT 11 | */ 12 | 13 | /* eslint-disable strict */ 14 | /* eslint-disable no-console */ 15 | 16 | ;(function () { 17 | 'use strict' 18 | var path = require('path') 19 | var tmpl = require(path.join(__dirname, 'tmpl.js')) 20 | var fs = require('fs') 21 | // Retrieve the content of the minimal runtime: 22 | var runtime = fs.readFileSync(path.join(__dirname, 'runtime.js'), 'utf8') 23 | // A regular expression to parse templates from script tags in a HTML page: 24 | var regexp = 25 | /([\s\S]+?)<\/script>/gi 26 | // A regular expression to match the helper function names: 27 | var helperRegexp = new RegExp( 28 | tmpl.helper.match(/\w+(?=\s*=\s*function\s*\()/g).join('\\s*\\(|') + 29 | '\\s*\\(' 30 | ) 31 | // A list to store the function bodies: 32 | var list = [] 33 | var code 34 | // Extend the Templating engine with a print method for the generated functions: 35 | tmpl.print = function (str) { 36 | // Only add helper functions if they are used inside of the template: 37 | var helper = helperRegexp.test(str) ? tmpl.helper : '' 38 | var body = str.replace(tmpl.regexp, tmpl.func) 39 | if (helper || /_e\s*\(/.test(body)) { 40 | helper = '_e=tmpl.encode' + helper + ',' 41 | } 42 | return ( 43 | 'function(' + 44 | tmpl.arg + 45 | ',tmpl){' + 46 | ('var ' + helper + "_s='" + body + "';return _s;") 47 | .split("_s+='';") 48 | .join('') + 49 | '}' 50 | ) 51 | } 52 | // Loop through the command line arguments: 53 | process.argv.forEach(function (file, index) { 54 | var listLength = list.length 55 | var stats 56 | var content 57 | var result 58 | var id 59 | // Skip the first two arguments, which are "node" and the script: 60 | if (index > 1) { 61 | stats = fs.statSync(file) 62 | if (!stats.isFile()) { 63 | console.error(file + ' is not a file.') 64 | return 65 | } 66 | content = fs.readFileSync(file, 'utf8') 67 | // eslint-disable-next-line no-constant-condition 68 | while (true) { 69 | // Find templates in script tags: 70 | result = regexp.exec(content) 71 | if (!result) { 72 | break 73 | } 74 | id = result[2] || result[4] 75 | list.push("'" + id + "':" + tmpl.print(result[5])) 76 | } 77 | if (listLength === list.length) { 78 | // No template script tags found, use the complete content: 79 | id = path.basename(file, path.extname(file)) 80 | list.push("'" + id + "':" + tmpl.print(content)) 81 | } 82 | } 83 | }) 84 | if (!list.length) { 85 | console.error('Missing input file.') 86 | return 87 | } 88 | // Combine the generated functions as cache of the minimal runtime: 89 | code = runtime.replace('{}', '{' + list.join(',') + '}') 90 | // Print the resulting code to the console output: 91 | console.log(code) 92 | })() 93 | -------------------------------------------------------------------------------- /js/demo/demo.js: -------------------------------------------------------------------------------- 1 | /* 2 | * JavaScript Templates Demo 3 | * https://github.com/blueimp/JavaScript-Templates 4 | * 5 | * Copyright 2013, Sebastian Tschan 6 | * https://blueimp.net 7 | * 8 | * Licensed under the MIT license: 9 | * https://opensource.org/licenses/MIT 10 | */ 11 | 12 | /* global tmpl */ 13 | 14 | /* eslint-disable strict */ 15 | 16 | ;(function () { 17 | 'use strict' 18 | 19 | var templateInput = document.getElementById('template') 20 | var dataInput = document.getElementById('data') 21 | var resultNode = document.getElementById('result') 22 | var templateDemoNode = document.getElementById('tmpl-demo') 23 | var templateDataNode = document.getElementById('tmpl-data') 24 | 25 | /** 26 | * Renders error messages 27 | * 28 | * @param {string} title Error title 29 | * @param {Error} error Error object 30 | */ 31 | function renderError(title, error) { 32 | resultNode.innerHTML = tmpl('tmpl-error', { title: title, error: error }) 33 | } 34 | 35 | /** 36 | * Renders the templating result 37 | * 38 | * @param {event} event Click event 39 | */ 40 | function render(event) { 41 | event.preventDefault() 42 | var data 43 | try { 44 | data = JSON.parse(dataInput.value) 45 | } catch (e) { 46 | renderError('JSON parsing failed', e) 47 | return 48 | } 49 | try { 50 | resultNode.innerHTML = tmpl(templateInput.value, data) 51 | } catch (e) { 52 | renderError('Template rendering failed', e) 53 | } 54 | } 55 | 56 | /** 57 | * Removes all child elements from a Node 58 | * 59 | * @param {HTMLElement} node HTML element node 60 | */ 61 | function empty(node) { 62 | while (node.lastChild) { 63 | node.removeChild(node.lastChild) 64 | } 65 | } 66 | 67 | /** 68 | * Initialization function 69 | * 70 | * @param {event} [event] Initialixation event 71 | */ 72 | function init(event) { 73 | if (event) { 74 | event.preventDefault() 75 | } 76 | templateInput.value = templateDemoNode.innerHTML.replace( 77 | // Replace unnecessary whitespace: 78 | /^\n|\s+$| {6}/g, 79 | '' 80 | ) 81 | dataInput.value = JSON.stringify( 82 | JSON.parse(templateDataNode.innerHTML), 83 | null, 84 | 2 85 | ) 86 | empty(resultNode) 87 | } 88 | 89 | document.getElementById('render').addEventListener('click', render) 90 | document.getElementById('reset').addEventListener('click', init) 91 | 92 | init() 93 | })() 94 | -------------------------------------------------------------------------------- /js/runtime.js: -------------------------------------------------------------------------------- 1 | /* 2 | * JavaScript Templates Runtime 3 | * https://github.com/blueimp/JavaScript-Templates 4 | * 5 | * Copyright 2011, Sebastian Tschan 6 | * https://blueimp.net 7 | * 8 | * Licensed under the MIT license: 9 | * https://opensource.org/licenses/MIT 10 | */ 11 | 12 | /* global define */ 13 | 14 | /* eslint-disable strict */ 15 | 16 | ;(function ($) { 17 | 'use strict' 18 | var tmpl = function (id, data) { 19 | var f = tmpl.cache[id] 20 | return data 21 | ? f(data, tmpl) 22 | : function (data) { 23 | return f(data, tmpl) 24 | } 25 | } 26 | tmpl.cache = {} 27 | tmpl.encReg = /[<>&"'\x00]/g // eslint-disable-line no-control-regex 28 | tmpl.encMap = { 29 | '<': '<', 30 | '>': '>', 31 | '&': '&', 32 | '"': '"', 33 | "'": ''' 34 | } 35 | tmpl.encode = function (s) { 36 | // eslint-disable-next-line eqeqeq 37 | return (s == null ? '' : '' + s).replace(tmpl.encReg, function (c) { 38 | return tmpl.encMap[c] || '' 39 | }) 40 | } 41 | if (typeof define === 'function' && define.amd) { 42 | define(function () { 43 | return tmpl 44 | }) 45 | } else if (typeof module === 'object' && module.exports) { 46 | module.exports = tmpl 47 | } else { 48 | $.tmpl = tmpl 49 | } 50 | })(this) 51 | -------------------------------------------------------------------------------- /js/tmpl.js: -------------------------------------------------------------------------------- 1 | /* 2 | * JavaScript Templates 3 | * https://github.com/blueimp/JavaScript-Templates 4 | * 5 | * Copyright 2011, Sebastian Tschan 6 | * https://blueimp.net 7 | * 8 | * Licensed under the MIT license: 9 | * https://opensource.org/licenses/MIT 10 | * 11 | * Inspired by John Resig's JavaScript Micro-Templating: 12 | * http://ejohn.org/blog/javascript-micro-templating/ 13 | */ 14 | 15 | /* global define */ 16 | 17 | /* eslint-disable strict */ 18 | 19 | ;(function ($) { 20 | 'use strict' 21 | var tmpl = function (str, data) { 22 | var f = !/[^\w\-.:]/.test(str) 23 | ? (tmpl.cache[str] = tmpl.cache[str] || tmpl(tmpl.load(str))) 24 | : new Function( // eslint-disable-line no-new-func 25 | tmpl.arg + ',tmpl', 26 | 'var _e=tmpl.encode' + 27 | tmpl.helper + 28 | ",_s='" + 29 | str.replace(tmpl.regexp, tmpl.func) + 30 | "';return _s;" 31 | ) 32 | return data 33 | ? f(data, tmpl) 34 | : function (data) { 35 | return f(data, tmpl) 36 | } 37 | } 38 | tmpl.cache = {} 39 | tmpl.load = function (id) { 40 | return document.getElementById(id).innerHTML 41 | } 42 | tmpl.regexp = 43 | /([\s'\\])(?!(?:[^{]|\{(?!%))*%\})|(?:\{%(=|#)([\s\S]+?)%\})|(\{%)|(%\})/g 44 | tmpl.func = function (s, p1, p2, p3, p4, p5) { 45 | if (p1) { 46 | // whitespace, quote and backspace in HTML context 47 | return ( 48 | { 49 | '\n': '\\n', 50 | '\r': '\\r', 51 | '\t': '\\t', 52 | ' ': ' ' 53 | }[p1] || '\\' + p1 54 | ) 55 | } 56 | if (p2) { 57 | // interpolation: {%=prop%}, or unescaped: {%#prop%} 58 | if (p2 === '=') { 59 | return "'+_e(" + p3 + ")+'" 60 | } 61 | return "'+(" + p3 + "==null?'':" + p3 + ")+'" 62 | } 63 | if (p4) { 64 | // evaluation start tag: {% 65 | return "';" 66 | } 67 | if (p5) { 68 | // evaluation end tag: %} 69 | return "_s+='" 70 | } 71 | } 72 | tmpl.encReg = /[<>&"'\x00]/g // eslint-disable-line no-control-regex 73 | tmpl.encMap = { 74 | '<': '<', 75 | '>': '>', 76 | '&': '&', 77 | '"': '"', 78 | "'": ''' 79 | } 80 | tmpl.encode = function (s) { 81 | // eslint-disable-next-line eqeqeq 82 | return (s == null ? '' : '' + s).replace(tmpl.encReg, function (c) { 83 | return tmpl.encMap[c] || '' 84 | }) 85 | } 86 | tmpl.arg = 'o' 87 | tmpl.helper = 88 | ",print=function(s,e){_s+=e?(s==null?'':s):_e(s);}" + 89 | ',include=function(s,d){_s+=tmpl(s,d);}' 90 | if (typeof define === 'function' && define.amd) { 91 | define(function () { 92 | return tmpl 93 | }) 94 | } else if (typeof module === 'object' && module.exports) { 95 | module.exports = tmpl 96 | } else { 97 | $.tmpl = tmpl 98 | } 99 | })(this) 100 | -------------------------------------------------------------------------------- /js/tmpl.min.js: -------------------------------------------------------------------------------- 1 | !function(e){"use strict";function r(e,n){var t=/[^\w\-.:]/.test(e)?new Function(r.arg+",tmpl","var _e=tmpl.encode"+r.helper+",_s='"+e.replace(r.regexp,r.func)+"';return _s;"):r.cache[e]=r.cache[e]||r(r.load(e));return n?t(n,r):function(e){return t(e,r)}}r.cache={},r.load=function(e){return document.getElementById(e).innerHTML},r.regexp=/([\s'\\])(?!(?:[^{]|\{(?!%))*%\})|(?:\{%(=|#)([\s\S]+?)%\})|(\{%)|(%\})/g,r.func=function(e,n,t,r,c,u){return n?{"\n":"\\n","\r":"\\r","\t":"\\t"," ":" "}[n]||"\\"+n:t?"="===t?"'+_e("+r+")+'":"'+("+r+"==null?'':"+r+")+'":c?"';":u?"_s+='":void 0},r.encReg=/[<>&"'\x00]/g,r.encMap={"<":"<",">":">","&":"&",'"':""","'":"'"},r.encode=function(e){return(null==e?"":""+e).replace(r.encReg,function(e){return r.encMap[e]||""})},r.arg="o",r.helper=",print=function(s,e){_s+=e?(s==null?'':s):_e(s);},include=function(s,d){_s+=tmpl(s,d);}","function"==typeof define&&define.amd?define(function(){return r}):"object"==typeof module&&module.exports?module.exports=r:e.tmpl=r}(this); 2 | //# sourceMappingURL=tmpl.min.js.map -------------------------------------------------------------------------------- /js/tmpl.min.js.map: -------------------------------------------------------------------------------- 1 | {"version":3,"sources":["tmpl.js"],"names":["$","tmpl","str","data","f","test","Function","arg","helper","replace","regexp","func","cache","load","id","document","getElementById","innerHTML","s","p1","p2","p3","p4","p5","\n","\r","\t"," ","encReg","encMap","<",">","&","\"","'","encode","c","define","amd","module","exports","this"],"mappings":"CAkBC,SAAWA,gBAEC,SAAPC,EAAiBC,EAAKC,GACxB,IAAIC,EAAK,YAAYC,KAAKH,GAEtB,IAAII,SACFL,EAAKM,IAAM,QACX,qBACEN,EAAKO,OACL,QACAN,EAAIO,QAAQR,EAAKS,OAAQT,EAAKU,MAC9B,gBAPHV,EAAKW,MAAMV,GAAOD,EAAKW,MAAMV,IAAQD,EAAKA,EAAKY,KAAKX,IASzD,OAAOC,EACHC,EAAED,EAAMF,GACR,SAAUE,GACR,OAAOC,EAAED,EAAMF,IAGvBA,EAAKW,MAAQ,GACbX,EAAKY,KAAO,SAAUC,GACpB,OAAOC,SAASC,eAAeF,GAAIG,WAErChB,EAAKS,OACH,2EACFT,EAAKU,KAAO,SAAUO,EAAGC,EAAIC,EAAIC,EAAIC,EAAIC,GACvC,OAAIJ,EAGA,CACEK,KAAM,MACNC,KAAM,MACNC,KAAM,MACNC,IAAK,KACLR,IAAO,KAAOA,EAGhBC,EAES,MAAPA,EACK,QAAUC,EAAK,MAEjB,MAAQA,EAAK,aAAeA,EAAK,MAEtCC,EAEK,KAELC,EAEK,aAFT,GAKFtB,EAAK2B,OAAS,eACd3B,EAAK4B,OAAS,CACZC,IAAK,OACLC,IAAK,OACLC,IAAK,QACLC,IAAK,SACLC,IAAK,SAEPjC,EAAKkC,OAAS,SAAUjB,GAEtB,OAAa,MAALA,EAAY,GAAK,GAAKA,GAAGT,QAAQR,EAAK2B,OAAQ,SAAUQ,GAC9D,OAAOnC,EAAK4B,OAAOO,IAAM,MAG7BnC,EAAKM,IAAM,IACXN,EAAKO,OACH,0FAEoB,mBAAX6B,QAAyBA,OAAOC,IACzCD,OAAO,WACL,OAAOpC,IAEkB,iBAAXsC,QAAuBA,OAAOC,QAC9CD,OAAOC,QAAUvC,EAEjBD,EAAEC,KAAOA,EA9EZ,CAgFEwC"} -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "blueimp-tmpl", 3 | "version": "3.20.0", 4 | "lockfileVersion": 2, 5 | "requires": true, 6 | "packages": { 7 | "": { 8 | "name": "blueimp-tmpl", 9 | "version": "3.20.0", 10 | "license": "MIT", 11 | "bin": { 12 | "tmpl.js": "js/compile.js" 13 | }, 14 | "devDependencies": { 15 | "chai": "4", 16 | "eslint": "7", 17 | "eslint-config-blueimp": "2", 18 | "eslint-config-prettier": "8", 19 | "eslint-plugin-jsdoc": "36", 20 | "eslint-plugin-prettier": "4", 21 | "mocha": "9", 22 | "prettier": "2", 23 | "uglify-js": "3" 24 | } 25 | }, 26 | "node_modules/@babel/code-frame": { 27 | "version": "7.12.11", 28 | "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.12.11.tgz", 29 | "integrity": "sha512-Zt1yodBx1UcyiePMSkWnU4hPqhwq7hGi2nFL1LeA3EUl+q2LQx16MISgJ0+z7dnmgvP9QtIleuETGOiOH1RcIw==", 30 | "dev": true, 31 | "dependencies": { 32 | "@babel/highlight": "^7.10.4" 33 | } 34 | }, 35 | "node_modules/@babel/helper-validator-identifier": { 36 | "version": "7.15.7", 37 | "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.15.7.tgz", 38 | "integrity": "sha512-K4JvCtQqad9OY2+yTU8w+E82ywk/fe+ELNlt1G8z3bVGlZfn/hOcQQsUhGhW/N+tb3fxK800wLtKOE/aM0m72w==", 39 | "dev": true, 40 | "engines": { 41 | "node": ">=6.9.0" 42 | } 43 | }, 44 | "node_modules/@babel/highlight": { 45 | "version": "7.14.5", 46 | "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.14.5.tgz", 47 | "integrity": "sha512-qf9u2WFWVV0MppaL877j2dBtQIDgmidgjGk5VIMw3OadXvYaXn66U1BFlH2t4+t3i+8PhedppRv+i40ABzd+gg==", 48 | "dev": true, 49 | "dependencies": { 50 | "@babel/helper-validator-identifier": "^7.14.5", 51 | "chalk": "^2.0.0", 52 | "js-tokens": "^4.0.0" 53 | }, 54 | "engines": { 55 | "node": ">=6.9.0" 56 | } 57 | }, 58 | "node_modules/@babel/highlight/node_modules/ansi-styles": { 59 | "version": "3.2.1", 60 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", 61 | "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", 62 | "dev": true, 63 | "dependencies": { 64 | "color-convert": "^1.9.0" 65 | }, 66 | "engines": { 67 | "node": ">=4" 68 | } 69 | }, 70 | "node_modules/@babel/highlight/node_modules/chalk": { 71 | "version": "2.4.2", 72 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", 73 | "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", 74 | "dev": true, 75 | "dependencies": { 76 | "ansi-styles": "^3.2.1", 77 | "escape-string-regexp": "^1.0.5", 78 | "supports-color": "^5.3.0" 79 | }, 80 | "engines": { 81 | "node": ">=4" 82 | } 83 | }, 84 | "node_modules/@babel/highlight/node_modules/color-convert": { 85 | "version": "1.9.3", 86 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", 87 | "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", 88 | "dev": true, 89 | "dependencies": { 90 | "color-name": "1.1.3" 91 | } 92 | }, 93 | "node_modules/@babel/highlight/node_modules/color-name": { 94 | "version": "1.1.3", 95 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", 96 | "integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=", 97 | "dev": true 98 | }, 99 | "node_modules/@babel/highlight/node_modules/escape-string-regexp": { 100 | "version": "1.0.5", 101 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", 102 | "integrity": "sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ=", 103 | "dev": true, 104 | "engines": { 105 | "node": ">=0.8.0" 106 | } 107 | }, 108 | "node_modules/@babel/highlight/node_modules/has-flag": { 109 | "version": "3.0.0", 110 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 111 | "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=", 112 | "dev": true, 113 | "engines": { 114 | "node": ">=4" 115 | } 116 | }, 117 | "node_modules/@babel/highlight/node_modules/supports-color": { 118 | "version": "5.5.0", 119 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 120 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 121 | "dev": true, 122 | "dependencies": { 123 | "has-flag": "^3.0.0" 124 | }, 125 | "engines": { 126 | "node": ">=4" 127 | } 128 | }, 129 | "node_modules/@es-joy/jsdoccomment": { 130 | "version": "0.10.8", 131 | "resolved": "https://registry.npmjs.org/@es-joy/jsdoccomment/-/jsdoccomment-0.10.8.tgz", 132 | "integrity": "sha512-3P1JiGL4xaR9PoTKUHa2N/LKwa2/eUdRqGwijMWWgBqbFEqJUVpmaOi2TcjcemrsRMgFLBzQCK4ToPhrSVDiFQ==", 133 | "dev": true, 134 | "dependencies": { 135 | "comment-parser": "1.2.4", 136 | "esquery": "^1.4.0", 137 | "jsdoc-type-pratt-parser": "1.1.1" 138 | }, 139 | "engines": { 140 | "node": "^12 || ^14 || ^16" 141 | } 142 | }, 143 | "node_modules/@eslint/eslintrc": { 144 | "version": "0.4.3", 145 | "resolved": "https://registry.npmjs.org/@eslint/eslintrc/-/eslintrc-0.4.3.tgz", 146 | "integrity": "sha512-J6KFFz5QCYUJq3pf0mjEcCJVERbzv71PUIDczuh9JkwGEzced6CO5ADLHB1rbf/+oPBtoPfMYNOpGDzCANlbXw==", 147 | "dev": true, 148 | "dependencies": { 149 | "ajv": "^6.12.4", 150 | "debug": "^4.1.1", 151 | "espree": "^7.3.0", 152 | "globals": "^13.9.0", 153 | "ignore": "^4.0.6", 154 | "import-fresh": "^3.2.1", 155 | "js-yaml": "^3.13.1", 156 | "minimatch": "^3.0.4", 157 | "strip-json-comments": "^3.1.1" 158 | }, 159 | "engines": { 160 | "node": "^10.12.0 || >=12.0.0" 161 | } 162 | }, 163 | "node_modules/@humanwhocodes/config-array": { 164 | "version": "0.5.0", 165 | "resolved": "https://registry.npmjs.org/@humanwhocodes/config-array/-/config-array-0.5.0.tgz", 166 | "integrity": "sha512-FagtKFz74XrTl7y6HCzQpwDfXP0yhxe9lHLD1UZxjvZIcbyRz8zTFF/yYNfSfzU414eDwZ1SrO0Qvtyf+wFMQg==", 167 | "dev": true, 168 | "dependencies": { 169 | "@humanwhocodes/object-schema": "^1.2.0", 170 | "debug": "^4.1.1", 171 | "minimatch": "^3.0.4" 172 | }, 173 | "engines": { 174 | "node": ">=10.10.0" 175 | } 176 | }, 177 | "node_modules/@humanwhocodes/object-schema": { 178 | "version": "1.2.0", 179 | "resolved": "https://registry.npmjs.org/@humanwhocodes/object-schema/-/object-schema-1.2.0.tgz", 180 | "integrity": "sha512-wdppn25U8z/2yiaT6YGquE6X8sSv7hNMWSXYSSU1jGv/yd6XqjXgTDJ8KP4NgjTXfJ3GbRjeeb8RTV7a/VpM+w==", 181 | "dev": true 182 | }, 183 | "node_modules/@ungap/promise-all-settled": { 184 | "version": "1.1.2", 185 | "resolved": "https://registry.npmjs.org/@ungap/promise-all-settled/-/promise-all-settled-1.1.2.tgz", 186 | "integrity": "sha512-sL/cEvJWAnClXw0wHk85/2L0G6Sj8UB0Ctc1TEMbKSsmpRosqhwj9gWgFRZSrBr2f9tiXISwNhCPmlfqUqyb9Q==", 187 | "dev": true 188 | }, 189 | "node_modules/acorn": { 190 | "version": "7.4.1", 191 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-7.4.1.tgz", 192 | "integrity": "sha512-nQyp0o1/mNdbTO1PO6kHkwSrmgZ0MT/jCCpNiwbUjGoRN4dlBhqJtoQuCnEOKzgTVwg0ZWiCoQy6SxMebQVh8A==", 193 | "dev": true, 194 | "bin": { 195 | "acorn": "bin/acorn" 196 | }, 197 | "engines": { 198 | "node": ">=0.4.0" 199 | } 200 | }, 201 | "node_modules/acorn-jsx": { 202 | "version": "5.3.2", 203 | "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.3.2.tgz", 204 | "integrity": "sha512-rq9s+JNhf0IChjtDXxllJ7g41oZk5SlXtp0LHwyA5cejwn7vKmKp4pPri6YEePv2PU65sAsegbXtIinmDFDXgQ==", 205 | "dev": true, 206 | "peerDependencies": { 207 | "acorn": "^6.0.0 || ^7.0.0 || ^8.0.0" 208 | } 209 | }, 210 | "node_modules/ajv": { 211 | "version": "6.12.6", 212 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.12.6.tgz", 213 | "integrity": "sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g==", 214 | "dev": true, 215 | "dependencies": { 216 | "fast-deep-equal": "^3.1.1", 217 | "fast-json-stable-stringify": "^2.0.0", 218 | "json-schema-traverse": "^0.4.1", 219 | "uri-js": "^4.2.2" 220 | }, 221 | "funding": { 222 | "type": "github", 223 | "url": "https://github.com/sponsors/epoberezkin" 224 | } 225 | }, 226 | "node_modules/ansi-colors": { 227 | "version": "4.1.1", 228 | "resolved": "https://registry.npmjs.org/ansi-colors/-/ansi-colors-4.1.1.tgz", 229 | "integrity": "sha512-JoX0apGbHaUJBNl6yF+p6JAFYZ666/hhCGKN5t9QFjbJQKUU/g8MNbFDbvfrgKXvI1QpZplPOnwIo99lX/AAmA==", 230 | "dev": true, 231 | "engines": { 232 | "node": ">=6" 233 | } 234 | }, 235 | "node_modules/ansi-regex": { 236 | "version": "5.0.1", 237 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 238 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 239 | "dev": true, 240 | "engines": { 241 | "node": ">=8" 242 | } 243 | }, 244 | "node_modules/ansi-styles": { 245 | "version": "4.3.0", 246 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 247 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 248 | "dev": true, 249 | "dependencies": { 250 | "color-convert": "^2.0.1" 251 | }, 252 | "engines": { 253 | "node": ">=8" 254 | }, 255 | "funding": { 256 | "url": "https://github.com/chalk/ansi-styles?sponsor=1" 257 | } 258 | }, 259 | "node_modules/anymatch": { 260 | "version": "3.1.2", 261 | "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.2.tgz", 262 | "integrity": "sha512-P43ePfOAIupkguHUycrc4qJ9kz8ZiuOUijaETwX7THt0Y/GNK7v0aa8rY816xWjZ7rJdA5XdMcpVFTKMq+RvWg==", 263 | "dev": true, 264 | "dependencies": { 265 | "normalize-path": "^3.0.0", 266 | "picomatch": "^2.0.4" 267 | }, 268 | "engines": { 269 | "node": ">= 8" 270 | } 271 | }, 272 | "node_modules/argparse": { 273 | "version": "1.0.10", 274 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-1.0.10.tgz", 275 | "integrity": "sha512-o5Roy6tNG4SL/FOkCAN6RzjiakZS25RLYFrcMttJqbdd8BWrnA+fGz57iN5Pb06pvBGvl5gQ0B48dJlslXvoTg==", 276 | "dev": true, 277 | "dependencies": { 278 | "sprintf-js": "~1.0.2" 279 | } 280 | }, 281 | "node_modules/assertion-error": { 282 | "version": "1.1.0", 283 | "resolved": "https://registry.npmjs.org/assertion-error/-/assertion-error-1.1.0.tgz", 284 | "integrity": "sha512-jgsaNduz+ndvGyFt3uSuWqvy4lCnIJiovtouQN5JZHOKCS2QuhEdbcQHFhVksz2N2U9hXJo8odG7ETyWlEeuDw==", 285 | "dev": true, 286 | "engines": { 287 | "node": "*" 288 | } 289 | }, 290 | "node_modules/astral-regex": { 291 | "version": "2.0.0", 292 | "resolved": "https://registry.npmjs.org/astral-regex/-/astral-regex-2.0.0.tgz", 293 | "integrity": "sha512-Z7tMw1ytTXt5jqMcOP+OQteU1VuNK9Y02uuJtKQ1Sv69jXQKKg5cibLwGJow8yzZP+eAc18EmLGPal0bp36rvQ==", 294 | "dev": true, 295 | "engines": { 296 | "node": ">=8" 297 | } 298 | }, 299 | "node_modules/balanced-match": { 300 | "version": "1.0.2", 301 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", 302 | "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==", 303 | "dev": true 304 | }, 305 | "node_modules/binary-extensions": { 306 | "version": "2.2.0", 307 | "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.2.0.tgz", 308 | "integrity": "sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA==", 309 | "dev": true, 310 | "engines": { 311 | "node": ">=8" 312 | } 313 | }, 314 | "node_modules/brace-expansion": { 315 | "version": "1.1.11", 316 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 317 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 318 | "dev": true, 319 | "dependencies": { 320 | "balanced-match": "^1.0.0", 321 | "concat-map": "0.0.1" 322 | } 323 | }, 324 | "node_modules/braces": { 325 | "version": "3.0.2", 326 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", 327 | "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", 328 | "dev": true, 329 | "dependencies": { 330 | "fill-range": "^7.0.1" 331 | }, 332 | "engines": { 333 | "node": ">=8" 334 | } 335 | }, 336 | "node_modules/browser-stdout": { 337 | "version": "1.3.1", 338 | "resolved": "https://registry.npmjs.org/browser-stdout/-/browser-stdout-1.3.1.tgz", 339 | "integrity": "sha512-qhAVI1+Av2X7qelOfAIYwXONood6XlZE/fXaBSmW/T5SzLAmCgzi+eiWE7fUvbHaeNBQH13UftjpXxsfLkMpgw==", 340 | "dev": true 341 | }, 342 | "node_modules/callsites": { 343 | "version": "3.1.0", 344 | "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz", 345 | "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==", 346 | "dev": true, 347 | "engines": { 348 | "node": ">=6" 349 | } 350 | }, 351 | "node_modules/camelcase": { 352 | "version": "6.2.0", 353 | "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-6.2.0.tgz", 354 | "integrity": "sha512-c7wVvbw3f37nuobQNtgsgG9POC9qMbNuMQmTCqZv23b6MIz0fcYpBiOlv9gEN/hdLdnZTDQhg6e9Dq5M1vKvfg==", 355 | "dev": true, 356 | "engines": { 357 | "node": ">=10" 358 | }, 359 | "funding": { 360 | "url": "https://github.com/sponsors/sindresorhus" 361 | } 362 | }, 363 | "node_modules/chai": { 364 | "version": "4.3.4", 365 | "resolved": "https://registry.npmjs.org/chai/-/chai-4.3.4.tgz", 366 | "integrity": "sha512-yS5H68VYOCtN1cjfwumDSuzn/9c+yza4f3reKXlE5rUg7SFcCEy90gJvydNgOYtblyf4Zi6jIWRnXOgErta0KA==", 367 | "dev": true, 368 | "dependencies": { 369 | "assertion-error": "^1.1.0", 370 | "check-error": "^1.0.2", 371 | "deep-eql": "^3.0.1", 372 | "get-func-name": "^2.0.0", 373 | "pathval": "^1.1.1", 374 | "type-detect": "^4.0.5" 375 | }, 376 | "engines": { 377 | "node": ">=4" 378 | } 379 | }, 380 | "node_modules/chalk": { 381 | "version": "4.1.2", 382 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", 383 | "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", 384 | "dev": true, 385 | "dependencies": { 386 | "ansi-styles": "^4.1.0", 387 | "supports-color": "^7.1.0" 388 | }, 389 | "engines": { 390 | "node": ">=10" 391 | }, 392 | "funding": { 393 | "url": "https://github.com/chalk/chalk?sponsor=1" 394 | } 395 | }, 396 | "node_modules/check-error": { 397 | "version": "1.0.2", 398 | "resolved": "https://registry.npmjs.org/check-error/-/check-error-1.0.2.tgz", 399 | "integrity": "sha1-V00xLt2Iu13YkS6Sht1sCu1KrII=", 400 | "dev": true, 401 | "engines": { 402 | "node": "*" 403 | } 404 | }, 405 | "node_modules/chokidar": { 406 | "version": "3.5.2", 407 | "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.5.2.tgz", 408 | "integrity": "sha512-ekGhOnNVPgT77r4K/U3GDhu+FQ2S8TnK/s2KbIGXi0SZWuwkZ2QNyfWdZW+TVfn84DpEP7rLeCt2UI6bJ8GwbQ==", 409 | "dev": true, 410 | "dependencies": { 411 | "anymatch": "~3.1.2", 412 | "braces": "~3.0.2", 413 | "glob-parent": "~5.1.2", 414 | "is-binary-path": "~2.1.0", 415 | "is-glob": "~4.0.1", 416 | "normalize-path": "~3.0.0", 417 | "readdirp": "~3.6.0" 418 | }, 419 | "engines": { 420 | "node": ">= 8.10.0" 421 | }, 422 | "optionalDependencies": { 423 | "fsevents": "~2.3.2" 424 | } 425 | }, 426 | "node_modules/cliui": { 427 | "version": "7.0.4", 428 | "resolved": "https://registry.npmjs.org/cliui/-/cliui-7.0.4.tgz", 429 | "integrity": "sha512-OcRE68cOsVMXp1Yvonl/fzkQOyjLSu/8bhPDfQt0e0/Eb283TKP20Fs2MqoPsr9SwA595rRCA+QMzYc9nBP+JQ==", 430 | "dev": true, 431 | "dependencies": { 432 | "string-width": "^4.2.0", 433 | "strip-ansi": "^6.0.0", 434 | "wrap-ansi": "^7.0.0" 435 | } 436 | }, 437 | "node_modules/color-convert": { 438 | "version": "2.0.1", 439 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 440 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 441 | "dev": true, 442 | "dependencies": { 443 | "color-name": "~1.1.4" 444 | }, 445 | "engines": { 446 | "node": ">=7.0.0" 447 | } 448 | }, 449 | "node_modules/color-name": { 450 | "version": "1.1.4", 451 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 452 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 453 | "dev": true 454 | }, 455 | "node_modules/comment-parser": { 456 | "version": "1.2.4", 457 | "resolved": "https://registry.npmjs.org/comment-parser/-/comment-parser-1.2.4.tgz", 458 | "integrity": "sha512-pm0b+qv+CkWNriSTMsfnjChF9kH0kxz55y44Wo5le9qLxMj5xDQAaEd9ZN1ovSuk9CsrncWaFwgpOMg7ClJwkw==", 459 | "dev": true, 460 | "engines": { 461 | "node": ">= 12.0.0" 462 | } 463 | }, 464 | "node_modules/concat-map": { 465 | "version": "0.0.1", 466 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 467 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=", 468 | "dev": true 469 | }, 470 | "node_modules/cross-spawn": { 471 | "version": "7.0.3", 472 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz", 473 | "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==", 474 | "dev": true, 475 | "dependencies": { 476 | "path-key": "^3.1.0", 477 | "shebang-command": "^2.0.0", 478 | "which": "^2.0.1" 479 | }, 480 | "engines": { 481 | "node": ">= 8" 482 | } 483 | }, 484 | "node_modules/debug": { 485 | "version": "4.3.2", 486 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.2.tgz", 487 | "integrity": "sha512-mOp8wKcvj7XxC78zLgw/ZA+6TSgkoE2C/ienthhRD298T7UNwAg9diBpLRxC0mOezLl4B0xV7M0cCO6P/O0Xhw==", 488 | "dev": true, 489 | "dependencies": { 490 | "ms": "2.1.2" 491 | }, 492 | "engines": { 493 | "node": ">=6.0" 494 | }, 495 | "peerDependenciesMeta": { 496 | "supports-color": { 497 | "optional": true 498 | } 499 | } 500 | }, 501 | "node_modules/decamelize": { 502 | "version": "4.0.0", 503 | "resolved": "https://registry.npmjs.org/decamelize/-/decamelize-4.0.0.tgz", 504 | "integrity": "sha512-9iE1PgSik9HeIIw2JO94IidnE3eBoQrFJ3w7sFuzSX4DpmZ3v5sZpUiV5Swcf6mQEF+Y0ru8Neo+p+nyh2J+hQ==", 505 | "dev": true, 506 | "engines": { 507 | "node": ">=10" 508 | }, 509 | "funding": { 510 | "url": "https://github.com/sponsors/sindresorhus" 511 | } 512 | }, 513 | "node_modules/deep-eql": { 514 | "version": "3.0.1", 515 | "resolved": "https://registry.npmjs.org/deep-eql/-/deep-eql-3.0.1.tgz", 516 | "integrity": "sha512-+QeIQyN5ZuO+3Uk5DYh6/1eKO0m0YmJFGNmFHGACpf1ClL1nmlV/p4gNgbl2pJGxgXb4faqo6UE+M5ACEMyVcw==", 517 | "dev": true, 518 | "dependencies": { 519 | "type-detect": "^4.0.0" 520 | }, 521 | "engines": { 522 | "node": ">=0.12" 523 | } 524 | }, 525 | "node_modules/deep-is": { 526 | "version": "0.1.4", 527 | "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.4.tgz", 528 | "integrity": "sha512-oIPzksmTg4/MriiaYGO+okXDT7ztn/w3Eptv/+gSIdMdKsJo0u4CfYNFJPy+4SKMuCqGw2wxnA+URMg3t8a/bQ==", 529 | "dev": true 530 | }, 531 | "node_modules/diff": { 532 | "version": "5.0.0", 533 | "resolved": "https://registry.npmjs.org/diff/-/diff-5.0.0.tgz", 534 | "integrity": "sha512-/VTCrvm5Z0JGty/BWHljh+BAiw3IK+2j87NGMu8Nwc/f48WoDAC395uomO9ZD117ZOBaHmkX1oyLvkVM/aIT3w==", 535 | "dev": true, 536 | "engines": { 537 | "node": ">=0.3.1" 538 | } 539 | }, 540 | "node_modules/doctrine": { 541 | "version": "3.0.0", 542 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-3.0.0.tgz", 543 | "integrity": "sha512-yS+Q5i3hBf7GBkd4KG8a7eBNNWNGLTaEwwYWUijIYM7zrlYDM0BFXHjjPWlWZ1Rg7UaddZeIDmi9jF3HmqiQ2w==", 544 | "dev": true, 545 | "dependencies": { 546 | "esutils": "^2.0.2" 547 | }, 548 | "engines": { 549 | "node": ">=6.0.0" 550 | } 551 | }, 552 | "node_modules/emoji-regex": { 553 | "version": "8.0.0", 554 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 555 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", 556 | "dev": true 557 | }, 558 | "node_modules/enquirer": { 559 | "version": "2.3.6", 560 | "resolved": "https://registry.npmjs.org/enquirer/-/enquirer-2.3.6.tgz", 561 | "integrity": "sha512-yjNnPr315/FjS4zIsUxYguYUPP2e1NK4d7E7ZOLiyYCcbFBiTMyID+2wvm2w6+pZ/odMA7cRkjhsPbltwBOrLg==", 562 | "dev": true, 563 | "dependencies": { 564 | "ansi-colors": "^4.1.1" 565 | }, 566 | "engines": { 567 | "node": ">=8.6" 568 | } 569 | }, 570 | "node_modules/escalade": { 571 | "version": "3.1.1", 572 | "resolved": "https://registry.npmjs.org/escalade/-/escalade-3.1.1.tgz", 573 | "integrity": "sha512-k0er2gUkLf8O0zKJiAhmkTnJlTvINGv7ygDNPbeIsX/TJjGJZHuh9B2UxbsaEkmlEo9MfhrSzmhIlhRlI2GXnw==", 574 | "dev": true, 575 | "engines": { 576 | "node": ">=6" 577 | } 578 | }, 579 | "node_modules/escape-string-regexp": { 580 | "version": "4.0.0", 581 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", 582 | "integrity": "sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA==", 583 | "dev": true, 584 | "engines": { 585 | "node": ">=10" 586 | }, 587 | "funding": { 588 | "url": "https://github.com/sponsors/sindresorhus" 589 | } 590 | }, 591 | "node_modules/eslint": { 592 | "version": "7.32.0", 593 | "resolved": "https://registry.npmjs.org/eslint/-/eslint-7.32.0.tgz", 594 | "integrity": "sha512-VHZ8gX+EDfz+97jGcgyGCyRia/dPOd6Xh9yPv8Bl1+SoaIwD+a/vlrOmGRUyOYu7MwUhc7CxqeaDZU13S4+EpA==", 595 | "dev": true, 596 | "dependencies": { 597 | "@babel/code-frame": "7.12.11", 598 | "@eslint/eslintrc": "^0.4.3", 599 | "@humanwhocodes/config-array": "^0.5.0", 600 | "ajv": "^6.10.0", 601 | "chalk": "^4.0.0", 602 | "cross-spawn": "^7.0.2", 603 | "debug": "^4.0.1", 604 | "doctrine": "^3.0.0", 605 | "enquirer": "^2.3.5", 606 | "escape-string-regexp": "^4.0.0", 607 | "eslint-scope": "^5.1.1", 608 | "eslint-utils": "^2.1.0", 609 | "eslint-visitor-keys": "^2.0.0", 610 | "espree": "^7.3.1", 611 | "esquery": "^1.4.0", 612 | "esutils": "^2.0.2", 613 | "fast-deep-equal": "^3.1.3", 614 | "file-entry-cache": "^6.0.1", 615 | "functional-red-black-tree": "^1.0.1", 616 | "glob-parent": "^5.1.2", 617 | "globals": "^13.6.0", 618 | "ignore": "^4.0.6", 619 | "import-fresh": "^3.0.0", 620 | "imurmurhash": "^0.1.4", 621 | "is-glob": "^4.0.0", 622 | "js-yaml": "^3.13.1", 623 | "json-stable-stringify-without-jsonify": "^1.0.1", 624 | "levn": "^0.4.1", 625 | "lodash.merge": "^4.6.2", 626 | "minimatch": "^3.0.4", 627 | "natural-compare": "^1.4.0", 628 | "optionator": "^0.9.1", 629 | "progress": "^2.0.0", 630 | "regexpp": "^3.1.0", 631 | "semver": "^7.2.1", 632 | "strip-ansi": "^6.0.0", 633 | "strip-json-comments": "^3.1.0", 634 | "table": "^6.0.9", 635 | "text-table": "^0.2.0", 636 | "v8-compile-cache": "^2.0.3" 637 | }, 638 | "bin": { 639 | "eslint": "bin/eslint.js" 640 | }, 641 | "engines": { 642 | "node": "^10.12.0 || >=12.0.0" 643 | }, 644 | "funding": { 645 | "url": "https://opencollective.com/eslint" 646 | } 647 | }, 648 | "node_modules/eslint-config-blueimp": { 649 | "version": "2.3.0", 650 | "resolved": "https://registry.npmjs.org/eslint-config-blueimp/-/eslint-config-blueimp-2.3.0.tgz", 651 | "integrity": "sha512-OC1+7YHBpXYdl/Jt2PZMpIPAUogHf4iDnqf8vVMlmkKls1Xemu7DAZqdFgdYhZxgaJ/d+qXH8b66L/D/pU4btA==", 652 | "dev": true, 653 | "engines": { 654 | "node": ">=10.0.0" 655 | }, 656 | "peerDependencies": { 657 | "eslint": ">=7" 658 | } 659 | }, 660 | "node_modules/eslint-config-prettier": { 661 | "version": "8.3.0", 662 | "resolved": "https://registry.npmjs.org/eslint-config-prettier/-/eslint-config-prettier-8.3.0.tgz", 663 | "integrity": "sha512-BgZuLUSeKzvlL/VUjx/Yb787VQ26RU3gGjA3iiFvdsp/2bMfVIWUVP7tjxtjS0e+HP409cPlPvNkQloz8C91ew==", 664 | "dev": true, 665 | "bin": { 666 | "eslint-config-prettier": "bin/cli.js" 667 | }, 668 | "peerDependencies": { 669 | "eslint": ">=7.0.0" 670 | } 671 | }, 672 | "node_modules/eslint-plugin-jsdoc": { 673 | "version": "36.1.0", 674 | "resolved": "https://registry.npmjs.org/eslint-plugin-jsdoc/-/eslint-plugin-jsdoc-36.1.0.tgz", 675 | "integrity": "sha512-Qpied2AJCQcScxfzTObLKRiP5QgLXjMU/ITjBagEV5p2Q/HpumD1EQtazdRYdjDSwPmXhwOl2yquwOGQ4HOJNw==", 676 | "dev": true, 677 | "dependencies": { 678 | "@es-joy/jsdoccomment": "0.10.8", 679 | "comment-parser": "1.2.4", 680 | "debug": "^4.3.2", 681 | "esquery": "^1.4.0", 682 | "jsdoc-type-pratt-parser": "^1.1.1", 683 | "lodash": "^4.17.21", 684 | "regextras": "^0.8.0", 685 | "semver": "^7.3.5", 686 | "spdx-expression-parse": "^3.0.1" 687 | }, 688 | "engines": { 689 | "node": "^12 || ^14 || ^16" 690 | }, 691 | "peerDependencies": { 692 | "eslint": "^6.0.0 || ^7.0.0" 693 | } 694 | }, 695 | "node_modules/eslint-plugin-prettier": { 696 | "version": "4.0.0", 697 | "resolved": "https://registry.npmjs.org/eslint-plugin-prettier/-/eslint-plugin-prettier-4.0.0.tgz", 698 | "integrity": "sha512-98MqmCJ7vJodoQK359bqQWaxOE0CS8paAz/GgjaZLyex4TTk3g9HugoO89EqWCrFiOqn9EVvcoo7gZzONCWVwQ==", 699 | "dev": true, 700 | "dependencies": { 701 | "prettier-linter-helpers": "^1.0.0" 702 | }, 703 | "engines": { 704 | "node": ">=6.0.0" 705 | }, 706 | "peerDependencies": { 707 | "eslint": ">=7.28.0", 708 | "prettier": ">=2.0.0" 709 | }, 710 | "peerDependenciesMeta": { 711 | "eslint-config-prettier": { 712 | "optional": true 713 | } 714 | } 715 | }, 716 | "node_modules/eslint-scope": { 717 | "version": "5.1.1", 718 | "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-5.1.1.tgz", 719 | "integrity": "sha512-2NxwbF/hZ0KpepYN0cNbo+FN6XoK7GaHlQhgx/hIZl6Va0bF45RQOOwhLIy8lQDbuCiadSLCBnH2CFYquit5bw==", 720 | "dev": true, 721 | "dependencies": { 722 | "esrecurse": "^4.3.0", 723 | "estraverse": "^4.1.1" 724 | }, 725 | "engines": { 726 | "node": ">=8.0.0" 727 | } 728 | }, 729 | "node_modules/eslint-utils": { 730 | "version": "2.1.0", 731 | "resolved": "https://registry.npmjs.org/eslint-utils/-/eslint-utils-2.1.0.tgz", 732 | "integrity": "sha512-w94dQYoauyvlDc43XnGB8lU3Zt713vNChgt4EWwhXAP2XkBvndfxF0AgIqKOOasjPIPzj9JqgwkwbCYD0/V3Zg==", 733 | "dev": true, 734 | "dependencies": { 735 | "eslint-visitor-keys": "^1.1.0" 736 | }, 737 | "engines": { 738 | "node": ">=6" 739 | }, 740 | "funding": { 741 | "url": "https://github.com/sponsors/mysticatea" 742 | } 743 | }, 744 | "node_modules/eslint-utils/node_modules/eslint-visitor-keys": { 745 | "version": "1.3.0", 746 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-1.3.0.tgz", 747 | "integrity": "sha512-6J72N8UNa462wa/KFODt/PJ3IU60SDpC3QXC1Hjc1BXXpfL2C9R5+AU7jhe0F6GREqVMh4Juu+NY7xn+6dipUQ==", 748 | "dev": true, 749 | "engines": { 750 | "node": ">=4" 751 | } 752 | }, 753 | "node_modules/eslint-visitor-keys": { 754 | "version": "2.1.0", 755 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-2.1.0.tgz", 756 | "integrity": "sha512-0rSmRBzXgDzIsD6mGdJgevzgezI534Cer5L/vyMX0kHzT/jiB43jRhd9YUlMGYLQy2zprNmoT8qasCGtY+QaKw==", 757 | "dev": true, 758 | "engines": { 759 | "node": ">=10" 760 | } 761 | }, 762 | "node_modules/espree": { 763 | "version": "7.3.1", 764 | "resolved": "https://registry.npmjs.org/espree/-/espree-7.3.1.tgz", 765 | "integrity": "sha512-v3JCNCE64umkFpmkFGqzVKsOT0tN1Zr+ueqLZfpV1Ob8e+CEgPWa+OxCoGH3tnhimMKIaBm4m/vaRpJ/krRz2g==", 766 | "dev": true, 767 | "dependencies": { 768 | "acorn": "^7.4.0", 769 | "acorn-jsx": "^5.3.1", 770 | "eslint-visitor-keys": "^1.3.0" 771 | }, 772 | "engines": { 773 | "node": "^10.12.0 || >=12.0.0" 774 | } 775 | }, 776 | "node_modules/espree/node_modules/eslint-visitor-keys": { 777 | "version": "1.3.0", 778 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-1.3.0.tgz", 779 | "integrity": "sha512-6J72N8UNa462wa/KFODt/PJ3IU60SDpC3QXC1Hjc1BXXpfL2C9R5+AU7jhe0F6GREqVMh4Juu+NY7xn+6dipUQ==", 780 | "dev": true, 781 | "engines": { 782 | "node": ">=4" 783 | } 784 | }, 785 | "node_modules/esprima": { 786 | "version": "4.0.1", 787 | "resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.1.tgz", 788 | "integrity": "sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A==", 789 | "dev": true, 790 | "bin": { 791 | "esparse": "bin/esparse.js", 792 | "esvalidate": "bin/esvalidate.js" 793 | }, 794 | "engines": { 795 | "node": ">=4" 796 | } 797 | }, 798 | "node_modules/esquery": { 799 | "version": "1.4.0", 800 | "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.4.0.tgz", 801 | "integrity": "sha512-cCDispWt5vHHtwMY2YrAQ4ibFkAL8RbH5YGBnZBc90MolvvfkkQcJro/aZiAQUlQ3qgrYS6D6v8Gc5G5CQsc9w==", 802 | "dev": true, 803 | "dependencies": { 804 | "estraverse": "^5.1.0" 805 | }, 806 | "engines": { 807 | "node": ">=0.10" 808 | } 809 | }, 810 | "node_modules/esquery/node_modules/estraverse": { 811 | "version": "5.2.0", 812 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.2.0.tgz", 813 | "integrity": "sha512-BxbNGGNm0RyRYvUdHpIwv9IWzeM9XClbOxwoATuFdOE7ZE6wHL+HQ5T8hoPM+zHvmKzzsEqhgy0GrQ5X13afiQ==", 814 | "dev": true, 815 | "engines": { 816 | "node": ">=4.0" 817 | } 818 | }, 819 | "node_modules/esrecurse": { 820 | "version": "4.3.0", 821 | "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.3.0.tgz", 822 | "integrity": "sha512-KmfKL3b6G+RXvP8N1vr3Tq1kL/oCFgn2NYXEtqP8/L3pKapUA4G8cFVaoF3SU323CD4XypR/ffioHmkti6/Tag==", 823 | "dev": true, 824 | "dependencies": { 825 | "estraverse": "^5.2.0" 826 | }, 827 | "engines": { 828 | "node": ">=4.0" 829 | } 830 | }, 831 | "node_modules/esrecurse/node_modules/estraverse": { 832 | "version": "5.2.0", 833 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.2.0.tgz", 834 | "integrity": "sha512-BxbNGGNm0RyRYvUdHpIwv9IWzeM9XClbOxwoATuFdOE7ZE6wHL+HQ5T8hoPM+zHvmKzzsEqhgy0GrQ5X13afiQ==", 835 | "dev": true, 836 | "engines": { 837 | "node": ">=4.0" 838 | } 839 | }, 840 | "node_modules/estraverse": { 841 | "version": "4.3.0", 842 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-4.3.0.tgz", 843 | "integrity": "sha512-39nnKffWz8xN1BU/2c79n9nB9HDzo0niYUqx6xyqUnyoAnQyyWpOTdZEeiCch8BBu515t4wp9ZmgVfVhn9EBpw==", 844 | "dev": true, 845 | "engines": { 846 | "node": ">=4.0" 847 | } 848 | }, 849 | "node_modules/esutils": { 850 | "version": "2.0.3", 851 | "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz", 852 | "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==", 853 | "dev": true, 854 | "engines": { 855 | "node": ">=0.10.0" 856 | } 857 | }, 858 | "node_modules/fast-deep-equal": { 859 | "version": "3.1.3", 860 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz", 861 | "integrity": "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==", 862 | "dev": true 863 | }, 864 | "node_modules/fast-diff": { 865 | "version": "1.2.0", 866 | "resolved": "https://registry.npmjs.org/fast-diff/-/fast-diff-1.2.0.tgz", 867 | "integrity": "sha512-xJuoT5+L99XlZ8twedaRf6Ax2TgQVxvgZOYoPKqZufmJib0tL2tegPBOZb1pVNgIhlqDlA0eO0c3wBvQcmzx4w==", 868 | "dev": true 869 | }, 870 | "node_modules/fast-json-stable-stringify": { 871 | "version": "2.1.0", 872 | "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz", 873 | "integrity": "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==", 874 | "dev": true 875 | }, 876 | "node_modules/fast-levenshtein": { 877 | "version": "2.0.6", 878 | "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", 879 | "integrity": "sha1-PYpcZog6FqMMqGQ+hR8Zuqd5eRc=", 880 | "dev": true 881 | }, 882 | "node_modules/file-entry-cache": { 883 | "version": "6.0.1", 884 | "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-6.0.1.tgz", 885 | "integrity": "sha512-7Gps/XWymbLk2QLYK4NzpMOrYjMhdIxXuIvy2QBsLE6ljuodKvdkWs/cpyJJ3CVIVpH0Oi1Hvg1ovbMzLdFBBg==", 886 | "dev": true, 887 | "dependencies": { 888 | "flat-cache": "^3.0.4" 889 | }, 890 | "engines": { 891 | "node": "^10.12.0 || >=12.0.0" 892 | } 893 | }, 894 | "node_modules/fill-range": { 895 | "version": "7.0.1", 896 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", 897 | "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", 898 | "dev": true, 899 | "dependencies": { 900 | "to-regex-range": "^5.0.1" 901 | }, 902 | "engines": { 903 | "node": ">=8" 904 | } 905 | }, 906 | "node_modules/find-up": { 907 | "version": "5.0.0", 908 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-5.0.0.tgz", 909 | "integrity": "sha512-78/PXT1wlLLDgTzDs7sjq9hzz0vXD+zn+7wypEe4fXQxCmdmqfGsEPQxmiCSQI3ajFV91bVSsvNtrJRiW6nGng==", 910 | "dev": true, 911 | "dependencies": { 912 | "locate-path": "^6.0.0", 913 | "path-exists": "^4.0.0" 914 | }, 915 | "engines": { 916 | "node": ">=10" 917 | }, 918 | "funding": { 919 | "url": "https://github.com/sponsors/sindresorhus" 920 | } 921 | }, 922 | "node_modules/flat": { 923 | "version": "5.0.2", 924 | "resolved": "https://registry.npmjs.org/flat/-/flat-5.0.2.tgz", 925 | "integrity": "sha512-b6suED+5/3rTpUBdG1gupIl8MPFCAMA0QXwmljLhvCUKcUvdE4gWky9zpuGCcXHOsz4J9wPGNWq6OKpmIzz3hQ==", 926 | "dev": true, 927 | "bin": { 928 | "flat": "cli.js" 929 | } 930 | }, 931 | "node_modules/flat-cache": { 932 | "version": "3.0.4", 933 | "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-3.0.4.tgz", 934 | "integrity": "sha512-dm9s5Pw7Jc0GvMYbshN6zchCA9RgQlzzEZX3vylR9IqFfS8XciblUXOKfW6SiuJ0e13eDYZoZV5wdrev7P3Nwg==", 935 | "dev": true, 936 | "dependencies": { 937 | "flatted": "^3.1.0", 938 | "rimraf": "^3.0.2" 939 | }, 940 | "engines": { 941 | "node": "^10.12.0 || >=12.0.0" 942 | } 943 | }, 944 | "node_modules/flatted": { 945 | "version": "3.2.2", 946 | "resolved": "https://registry.npmjs.org/flatted/-/flatted-3.2.2.tgz", 947 | "integrity": "sha512-JaTY/wtrcSyvXJl4IMFHPKyFur1sE9AUqc0QnhOaJ0CxHtAoIV8pYDzeEfAaNEtGkOfq4gr3LBFmdXW5mOQFnA==", 948 | "dev": true 949 | }, 950 | "node_modules/fs.realpath": { 951 | "version": "1.0.0", 952 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 953 | "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=", 954 | "dev": true 955 | }, 956 | "node_modules/fsevents": { 957 | "version": "2.3.2", 958 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.2.tgz", 959 | "integrity": "sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA==", 960 | "dev": true, 961 | "hasInstallScript": true, 962 | "optional": true, 963 | "os": [ 964 | "darwin" 965 | ], 966 | "engines": { 967 | "node": "^8.16.0 || ^10.6.0 || >=11.0.0" 968 | } 969 | }, 970 | "node_modules/functional-red-black-tree": { 971 | "version": "1.0.1", 972 | "resolved": "https://registry.npmjs.org/functional-red-black-tree/-/functional-red-black-tree-1.0.1.tgz", 973 | "integrity": "sha1-GwqzvVU7Kg1jmdKcDj6gslIHgyc=", 974 | "dev": true 975 | }, 976 | "node_modules/get-caller-file": { 977 | "version": "2.0.5", 978 | "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-2.0.5.tgz", 979 | "integrity": "sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg==", 980 | "dev": true, 981 | "engines": { 982 | "node": "6.* || 8.* || >= 10.*" 983 | } 984 | }, 985 | "node_modules/get-func-name": { 986 | "version": "2.0.0", 987 | "resolved": "https://registry.npmjs.org/get-func-name/-/get-func-name-2.0.0.tgz", 988 | "integrity": "sha1-6td0q+5y4gQJQzoGY2YCPdaIekE=", 989 | "dev": true, 990 | "engines": { 991 | "node": "*" 992 | } 993 | }, 994 | "node_modules/glob": { 995 | "version": "7.1.7", 996 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.7.tgz", 997 | "integrity": "sha512-OvD9ENzPLbegENnYP5UUfJIirTg4+XwMWGaQfQTY0JenxNvvIKP3U3/tAQSPIu/lHxXYSZmpXlUHeqAIdKzBLQ==", 998 | "dev": true, 999 | "dependencies": { 1000 | "fs.realpath": "^1.0.0", 1001 | "inflight": "^1.0.4", 1002 | "inherits": "2", 1003 | "minimatch": "^3.0.4", 1004 | "once": "^1.3.0", 1005 | "path-is-absolute": "^1.0.0" 1006 | }, 1007 | "engines": { 1008 | "node": "*" 1009 | }, 1010 | "funding": { 1011 | "url": "https://github.com/sponsors/isaacs" 1012 | } 1013 | }, 1014 | "node_modules/glob-parent": { 1015 | "version": "5.1.2", 1016 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", 1017 | "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", 1018 | "dev": true, 1019 | "dependencies": { 1020 | "is-glob": "^4.0.1" 1021 | }, 1022 | "engines": { 1023 | "node": ">= 6" 1024 | } 1025 | }, 1026 | "node_modules/globals": { 1027 | "version": "13.11.0", 1028 | "resolved": "https://registry.npmjs.org/globals/-/globals-13.11.0.tgz", 1029 | "integrity": "sha512-08/xrJ7wQjK9kkkRoI3OFUBbLx4f+6x3SGwcPvQ0QH6goFDrOU2oyAWrmh3dJezu65buo+HBMzAMQy6rovVC3g==", 1030 | "dev": true, 1031 | "dependencies": { 1032 | "type-fest": "^0.20.2" 1033 | }, 1034 | "engines": { 1035 | "node": ">=8" 1036 | }, 1037 | "funding": { 1038 | "url": "https://github.com/sponsors/sindresorhus" 1039 | } 1040 | }, 1041 | "node_modules/growl": { 1042 | "version": "1.10.5", 1043 | "resolved": "https://registry.npmjs.org/growl/-/growl-1.10.5.tgz", 1044 | "integrity": "sha512-qBr4OuELkhPenW6goKVXiv47US3clb3/IbuWF9KNKEijAy9oeHxU9IgzjvJhHkUzhaj7rOUD7+YGWqUjLp5oSA==", 1045 | "dev": true, 1046 | "engines": { 1047 | "node": ">=4.x" 1048 | } 1049 | }, 1050 | "node_modules/has-flag": { 1051 | "version": "4.0.0", 1052 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 1053 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", 1054 | "dev": true, 1055 | "engines": { 1056 | "node": ">=8" 1057 | } 1058 | }, 1059 | "node_modules/he": { 1060 | "version": "1.2.0", 1061 | "resolved": "https://registry.npmjs.org/he/-/he-1.2.0.tgz", 1062 | "integrity": "sha512-F/1DnUGPopORZi0ni+CvrCgHQ5FyEAHRLSApuYWMmrbSwoN2Mn/7k+Gl38gJnR7yyDZk6WLXwiGod1JOWNDKGw==", 1063 | "dev": true, 1064 | "bin": { 1065 | "he": "bin/he" 1066 | } 1067 | }, 1068 | "node_modules/ignore": { 1069 | "version": "4.0.6", 1070 | "resolved": "https://registry.npmjs.org/ignore/-/ignore-4.0.6.tgz", 1071 | "integrity": "sha512-cyFDKrqc/YdcWFniJhzI42+AzS+gNwmUzOSFcRCQYwySuBBBy/KjuxWLZ/FHEH6Moq1NizMOBWyTcv8O4OZIMg==", 1072 | "dev": true, 1073 | "engines": { 1074 | "node": ">= 4" 1075 | } 1076 | }, 1077 | "node_modules/import-fresh": { 1078 | "version": "3.3.0", 1079 | "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.3.0.tgz", 1080 | "integrity": "sha512-veYYhQa+D1QBKznvhUHxb8faxlrwUnxseDAbAp457E0wLNio2bOSKnjYDhMj+YiAq61xrMGhQk9iXVk5FzgQMw==", 1081 | "dev": true, 1082 | "dependencies": { 1083 | "parent-module": "^1.0.0", 1084 | "resolve-from": "^4.0.0" 1085 | }, 1086 | "engines": { 1087 | "node": ">=6" 1088 | }, 1089 | "funding": { 1090 | "url": "https://github.com/sponsors/sindresorhus" 1091 | } 1092 | }, 1093 | "node_modules/imurmurhash": { 1094 | "version": "0.1.4", 1095 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", 1096 | "integrity": "sha1-khi5srkoojixPcT7a21XbyMUU+o=", 1097 | "dev": true, 1098 | "engines": { 1099 | "node": ">=0.8.19" 1100 | } 1101 | }, 1102 | "node_modules/inflight": { 1103 | "version": "1.0.6", 1104 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 1105 | "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", 1106 | "dev": true, 1107 | "dependencies": { 1108 | "once": "^1.3.0", 1109 | "wrappy": "1" 1110 | } 1111 | }, 1112 | "node_modules/inherits": { 1113 | "version": "2.0.4", 1114 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 1115 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", 1116 | "dev": true 1117 | }, 1118 | "node_modules/is-binary-path": { 1119 | "version": "2.1.0", 1120 | "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz", 1121 | "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==", 1122 | "dev": true, 1123 | "dependencies": { 1124 | "binary-extensions": "^2.0.0" 1125 | }, 1126 | "engines": { 1127 | "node": ">=8" 1128 | } 1129 | }, 1130 | "node_modules/is-extglob": { 1131 | "version": "2.1.1", 1132 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 1133 | "integrity": "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=", 1134 | "dev": true, 1135 | "engines": { 1136 | "node": ">=0.10.0" 1137 | } 1138 | }, 1139 | "node_modules/is-fullwidth-code-point": { 1140 | "version": "3.0.0", 1141 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 1142 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", 1143 | "dev": true, 1144 | "engines": { 1145 | "node": ">=8" 1146 | } 1147 | }, 1148 | "node_modules/is-glob": { 1149 | "version": "4.0.1", 1150 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.1.tgz", 1151 | "integrity": "sha512-5G0tKtBTFImOqDnLB2hG6Bp2qcKEFduo4tZu9MT/H6NQv/ghhy30o55ufafxJ/LdH79LLs2Kfrn85TLKyA7BUg==", 1152 | "dev": true, 1153 | "dependencies": { 1154 | "is-extglob": "^2.1.1" 1155 | }, 1156 | "engines": { 1157 | "node": ">=0.10.0" 1158 | } 1159 | }, 1160 | "node_modules/is-number": { 1161 | "version": "7.0.0", 1162 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", 1163 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", 1164 | "dev": true, 1165 | "engines": { 1166 | "node": ">=0.12.0" 1167 | } 1168 | }, 1169 | "node_modules/is-plain-obj": { 1170 | "version": "2.1.0", 1171 | "resolved": "https://registry.npmjs.org/is-plain-obj/-/is-plain-obj-2.1.0.tgz", 1172 | "integrity": "sha512-YWnfyRwxL/+SsrWYfOpUtz5b3YD+nyfkHvjbcanzk8zgyO4ASD67uVMRt8k5bM4lLMDnXfriRhOpemw+NfT1eA==", 1173 | "dev": true, 1174 | "engines": { 1175 | "node": ">=8" 1176 | } 1177 | }, 1178 | "node_modules/is-unicode-supported": { 1179 | "version": "0.1.0", 1180 | "resolved": "https://registry.npmjs.org/is-unicode-supported/-/is-unicode-supported-0.1.0.tgz", 1181 | "integrity": "sha512-knxG2q4UC3u8stRGyAVJCOdxFmv5DZiRcdlIaAQXAbSfJya+OhopNotLQrstBhququ4ZpuKbDc/8S6mgXgPFPw==", 1182 | "dev": true, 1183 | "engines": { 1184 | "node": ">=10" 1185 | }, 1186 | "funding": { 1187 | "url": "https://github.com/sponsors/sindresorhus" 1188 | } 1189 | }, 1190 | "node_modules/isexe": { 1191 | "version": "2.0.0", 1192 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 1193 | "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=", 1194 | "dev": true 1195 | }, 1196 | "node_modules/js-tokens": { 1197 | "version": "4.0.0", 1198 | "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", 1199 | "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==", 1200 | "dev": true 1201 | }, 1202 | "node_modules/js-yaml": { 1203 | "version": "3.14.1", 1204 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.14.1.tgz", 1205 | "integrity": "sha512-okMH7OXXJ7YrN9Ok3/SXrnu4iX9yOk+25nqX4imS2npuvTYDmo/QEZoqwZkYaIDk3jVvBOTOIEgEhaLOynBS9g==", 1206 | "dev": true, 1207 | "dependencies": { 1208 | "argparse": "^1.0.7", 1209 | "esprima": "^4.0.0" 1210 | }, 1211 | "bin": { 1212 | "js-yaml": "bin/js-yaml.js" 1213 | } 1214 | }, 1215 | "node_modules/jsdoc-type-pratt-parser": { 1216 | "version": "1.1.1", 1217 | "resolved": "https://registry.npmjs.org/jsdoc-type-pratt-parser/-/jsdoc-type-pratt-parser-1.1.1.tgz", 1218 | "integrity": "sha512-uelRmpghNwPBuZScwgBG/OzodaFk5RbO5xaivBdsAY70icWfShwZ7PCMO0x1zSkOa8T1FzHThmrdoyg/0AwV5g==", 1219 | "dev": true, 1220 | "engines": { 1221 | "node": ">=12.0.0" 1222 | } 1223 | }, 1224 | "node_modules/json-schema-traverse": { 1225 | "version": "0.4.1", 1226 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", 1227 | "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==", 1228 | "dev": true 1229 | }, 1230 | "node_modules/json-stable-stringify-without-jsonify": { 1231 | "version": "1.0.1", 1232 | "resolved": "https://registry.npmjs.org/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz", 1233 | "integrity": "sha1-nbe1lJatPzz+8wp1FC0tkwrXJlE=", 1234 | "dev": true 1235 | }, 1236 | "node_modules/levn": { 1237 | "version": "0.4.1", 1238 | "resolved": "https://registry.npmjs.org/levn/-/levn-0.4.1.tgz", 1239 | "integrity": "sha512-+bT2uH4E5LGE7h/n3evcS/sQlJXCpIp6ym8OWJ5eV6+67Dsql/LaaT7qJBAt2rzfoa/5QBGBhxDix1dMt2kQKQ==", 1240 | "dev": true, 1241 | "dependencies": { 1242 | "prelude-ls": "^1.2.1", 1243 | "type-check": "~0.4.0" 1244 | }, 1245 | "engines": { 1246 | "node": ">= 0.8.0" 1247 | } 1248 | }, 1249 | "node_modules/locate-path": { 1250 | "version": "6.0.0", 1251 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-6.0.0.tgz", 1252 | "integrity": "sha512-iPZK6eYjbxRu3uB4/WZ3EsEIMJFMqAoopl3R+zuq0UjcAm/MO6KCweDgPfP3elTztoKP3KtnVHxTn2NHBSDVUw==", 1253 | "dev": true, 1254 | "dependencies": { 1255 | "p-locate": "^5.0.0" 1256 | }, 1257 | "engines": { 1258 | "node": ">=10" 1259 | }, 1260 | "funding": { 1261 | "url": "https://github.com/sponsors/sindresorhus" 1262 | } 1263 | }, 1264 | "node_modules/lodash": { 1265 | "version": "4.17.21", 1266 | "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.21.tgz", 1267 | "integrity": "sha512-v2kDEe57lecTulaDIuNTPy3Ry4gLGJ6Z1O3vE1krgXZNrsQ+LFTGHVxVjcXPs17LhbZVGedAJv8XZ1tvj5FvSg==", 1268 | "dev": true 1269 | }, 1270 | "node_modules/lodash.clonedeep": { 1271 | "version": "4.5.0", 1272 | "resolved": "https://registry.npmjs.org/lodash.clonedeep/-/lodash.clonedeep-4.5.0.tgz", 1273 | "integrity": "sha1-4j8/nE+Pvd6HJSnBBxhXoIblzO8=", 1274 | "dev": true 1275 | }, 1276 | "node_modules/lodash.merge": { 1277 | "version": "4.6.2", 1278 | "resolved": "https://registry.npmjs.org/lodash.merge/-/lodash.merge-4.6.2.tgz", 1279 | "integrity": "sha512-0KpjqXRVvrYyCsX1swR/XTK0va6VQkQM6MNo7PqW77ByjAhoARA8EfrP1N4+KlKj8YS0ZUCtRT/YUuhyYDujIQ==", 1280 | "dev": true 1281 | }, 1282 | "node_modules/lodash.truncate": { 1283 | "version": "4.4.2", 1284 | "resolved": "https://registry.npmjs.org/lodash.truncate/-/lodash.truncate-4.4.2.tgz", 1285 | "integrity": "sha1-WjUNoLERO4N+z//VgSy+WNbq4ZM=", 1286 | "dev": true 1287 | }, 1288 | "node_modules/log-symbols": { 1289 | "version": "4.1.0", 1290 | "resolved": "https://registry.npmjs.org/log-symbols/-/log-symbols-4.1.0.tgz", 1291 | "integrity": "sha512-8XPvpAA8uyhfteu8pIvQxpJZ7SYYdpUivZpGy6sFsBuKRY/7rQGavedeB8aK+Zkyq6upMFVL/9AW6vOYzfRyLg==", 1292 | "dev": true, 1293 | "dependencies": { 1294 | "chalk": "^4.1.0", 1295 | "is-unicode-supported": "^0.1.0" 1296 | }, 1297 | "engines": { 1298 | "node": ">=10" 1299 | }, 1300 | "funding": { 1301 | "url": "https://github.com/sponsors/sindresorhus" 1302 | } 1303 | }, 1304 | "node_modules/lru-cache": { 1305 | "version": "6.0.0", 1306 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", 1307 | "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", 1308 | "dev": true, 1309 | "dependencies": { 1310 | "yallist": "^4.0.0" 1311 | }, 1312 | "engines": { 1313 | "node": ">=10" 1314 | } 1315 | }, 1316 | "node_modules/minimatch": { 1317 | "version": "3.0.4", 1318 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", 1319 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", 1320 | "dev": true, 1321 | "dependencies": { 1322 | "brace-expansion": "^1.1.7" 1323 | }, 1324 | "engines": { 1325 | "node": "*" 1326 | } 1327 | }, 1328 | "node_modules/mocha": { 1329 | "version": "9.1.2", 1330 | "resolved": "https://registry.npmjs.org/mocha/-/mocha-9.1.2.tgz", 1331 | "integrity": "sha512-ta3LtJ+63RIBP03VBjMGtSqbe6cWXRejF9SyM9Zyli1CKZJZ+vfCTj3oW24V7wAphMJdpOFLoMI3hjJ1LWbs0w==", 1332 | "dev": true, 1333 | "dependencies": { 1334 | "@ungap/promise-all-settled": "1.1.2", 1335 | "ansi-colors": "4.1.1", 1336 | "browser-stdout": "1.3.1", 1337 | "chokidar": "3.5.2", 1338 | "debug": "4.3.2", 1339 | "diff": "5.0.0", 1340 | "escape-string-regexp": "4.0.0", 1341 | "find-up": "5.0.0", 1342 | "glob": "7.1.7", 1343 | "growl": "1.10.5", 1344 | "he": "1.2.0", 1345 | "js-yaml": "4.1.0", 1346 | "log-symbols": "4.1.0", 1347 | "minimatch": "3.0.4", 1348 | "ms": "2.1.3", 1349 | "nanoid": "3.1.25", 1350 | "serialize-javascript": "6.0.0", 1351 | "strip-json-comments": "3.1.1", 1352 | "supports-color": "8.1.1", 1353 | "which": "2.0.2", 1354 | "workerpool": "6.1.5", 1355 | "yargs": "16.2.0", 1356 | "yargs-parser": "20.2.4", 1357 | "yargs-unparser": "2.0.0" 1358 | }, 1359 | "bin": { 1360 | "_mocha": "bin/_mocha", 1361 | "mocha": "bin/mocha" 1362 | }, 1363 | "engines": { 1364 | "node": ">= 12.0.0" 1365 | }, 1366 | "funding": { 1367 | "type": "opencollective", 1368 | "url": "https://opencollective.com/mochajs" 1369 | } 1370 | }, 1371 | "node_modules/mocha/node_modules/argparse": { 1372 | "version": "2.0.1", 1373 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-2.0.1.tgz", 1374 | "integrity": "sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==", 1375 | "dev": true 1376 | }, 1377 | "node_modules/mocha/node_modules/js-yaml": { 1378 | "version": "4.1.0", 1379 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-4.1.0.tgz", 1380 | "integrity": "sha512-wpxZs9NoxZaJESJGIZTyDEaYpl0FKSA+FB9aJiyemKhMwkxQg63h4T1KJgUGHpTqPDNRcmmYLugrRjJlBtWvRA==", 1381 | "dev": true, 1382 | "dependencies": { 1383 | "argparse": "^2.0.1" 1384 | }, 1385 | "bin": { 1386 | "js-yaml": "bin/js-yaml.js" 1387 | } 1388 | }, 1389 | "node_modules/mocha/node_modules/ms": { 1390 | "version": "2.1.3", 1391 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", 1392 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==", 1393 | "dev": true 1394 | }, 1395 | "node_modules/mocha/node_modules/supports-color": { 1396 | "version": "8.1.1", 1397 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-8.1.1.tgz", 1398 | "integrity": "sha512-MpUEN2OodtUzxvKQl72cUF7RQ5EiHsGvSsVG0ia9c5RbWGL2CI4C7EpPS8UTBIplnlzZiNuV56w+FuNxy3ty2Q==", 1399 | "dev": true, 1400 | "dependencies": { 1401 | "has-flag": "^4.0.0" 1402 | }, 1403 | "engines": { 1404 | "node": ">=10" 1405 | }, 1406 | "funding": { 1407 | "url": "https://github.com/chalk/supports-color?sponsor=1" 1408 | } 1409 | }, 1410 | "node_modules/ms": { 1411 | "version": "2.1.2", 1412 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 1413 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 1414 | "dev": true 1415 | }, 1416 | "node_modules/nanoid": { 1417 | "version": "3.1.25", 1418 | "resolved": "https://registry.npmjs.org/nanoid/-/nanoid-3.1.25.tgz", 1419 | "integrity": "sha512-rdwtIXaXCLFAQbnfqDRnI6jaRHp9fTcYBjtFKE8eezcZ7LuLjhUaQGNeMXf1HmRoCH32CLz6XwX0TtxEOS/A3Q==", 1420 | "dev": true, 1421 | "bin": { 1422 | "nanoid": "bin/nanoid.cjs" 1423 | }, 1424 | "engines": { 1425 | "node": "^10 || ^12 || ^13.7 || ^14 || >=15.0.1" 1426 | } 1427 | }, 1428 | "node_modules/natural-compare": { 1429 | "version": "1.4.0", 1430 | "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", 1431 | "integrity": "sha1-Sr6/7tdUHywnrPspvbvRXI1bpPc=", 1432 | "dev": true 1433 | }, 1434 | "node_modules/normalize-path": { 1435 | "version": "3.0.0", 1436 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", 1437 | "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==", 1438 | "dev": true, 1439 | "engines": { 1440 | "node": ">=0.10.0" 1441 | } 1442 | }, 1443 | "node_modules/once": { 1444 | "version": "1.4.0", 1445 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 1446 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", 1447 | "dev": true, 1448 | "dependencies": { 1449 | "wrappy": "1" 1450 | } 1451 | }, 1452 | "node_modules/optionator": { 1453 | "version": "0.9.1", 1454 | "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.9.1.tgz", 1455 | "integrity": "sha512-74RlY5FCnhq4jRxVUPKDaRwrVNXMqsGsiW6AJw4XK8hmtm10wC0ypZBLw5IIp85NZMr91+qd1RvvENwg7jjRFw==", 1456 | "dev": true, 1457 | "dependencies": { 1458 | "deep-is": "^0.1.3", 1459 | "fast-levenshtein": "^2.0.6", 1460 | "levn": "^0.4.1", 1461 | "prelude-ls": "^1.2.1", 1462 | "type-check": "^0.4.0", 1463 | "word-wrap": "^1.2.3" 1464 | }, 1465 | "engines": { 1466 | "node": ">= 0.8.0" 1467 | } 1468 | }, 1469 | "node_modules/p-limit": { 1470 | "version": "3.1.0", 1471 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-3.1.0.tgz", 1472 | "integrity": "sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ==", 1473 | "dev": true, 1474 | "dependencies": { 1475 | "yocto-queue": "^0.1.0" 1476 | }, 1477 | "engines": { 1478 | "node": ">=10" 1479 | }, 1480 | "funding": { 1481 | "url": "https://github.com/sponsors/sindresorhus" 1482 | } 1483 | }, 1484 | "node_modules/p-locate": { 1485 | "version": "5.0.0", 1486 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-5.0.0.tgz", 1487 | "integrity": "sha512-LaNjtRWUBY++zB5nE/NwcaoMylSPk+S+ZHNB1TzdbMJMny6dynpAGt7X/tl/QYq3TIeE6nxHppbo2LGymrG5Pw==", 1488 | "dev": true, 1489 | "dependencies": { 1490 | "p-limit": "^3.0.2" 1491 | }, 1492 | "engines": { 1493 | "node": ">=10" 1494 | }, 1495 | "funding": { 1496 | "url": "https://github.com/sponsors/sindresorhus" 1497 | } 1498 | }, 1499 | "node_modules/parent-module": { 1500 | "version": "1.0.1", 1501 | "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz", 1502 | "integrity": "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==", 1503 | "dev": true, 1504 | "dependencies": { 1505 | "callsites": "^3.0.0" 1506 | }, 1507 | "engines": { 1508 | "node": ">=6" 1509 | } 1510 | }, 1511 | "node_modules/path-exists": { 1512 | "version": "4.0.0", 1513 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz", 1514 | "integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==", 1515 | "dev": true, 1516 | "engines": { 1517 | "node": ">=8" 1518 | } 1519 | }, 1520 | "node_modules/path-is-absolute": { 1521 | "version": "1.0.1", 1522 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 1523 | "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=", 1524 | "dev": true, 1525 | "engines": { 1526 | "node": ">=0.10.0" 1527 | } 1528 | }, 1529 | "node_modules/path-key": { 1530 | "version": "3.1.1", 1531 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", 1532 | "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", 1533 | "dev": true, 1534 | "engines": { 1535 | "node": ">=8" 1536 | } 1537 | }, 1538 | "node_modules/pathval": { 1539 | "version": "1.1.1", 1540 | "resolved": "https://registry.npmjs.org/pathval/-/pathval-1.1.1.tgz", 1541 | "integrity": "sha512-Dp6zGqpTdETdR63lehJYPeIOqpiNBNtc7BpWSLrOje7UaIsE5aY92r/AunQA7rsXvet3lrJ3JnZX29UPTKXyKQ==", 1542 | "dev": true, 1543 | "engines": { 1544 | "node": "*" 1545 | } 1546 | }, 1547 | "node_modules/picomatch": { 1548 | "version": "2.3.0", 1549 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.0.tgz", 1550 | "integrity": "sha512-lY1Q/PiJGC2zOv/z391WOTD+Z02bCgsFfvxoXXf6h7kv9o+WmsmzYqrAwY63sNgOxE4xEdq0WyUnXfKeBrSvYw==", 1551 | "dev": true, 1552 | "engines": { 1553 | "node": ">=8.6" 1554 | }, 1555 | "funding": { 1556 | "url": "https://github.com/sponsors/jonschlinkert" 1557 | } 1558 | }, 1559 | "node_modules/prelude-ls": { 1560 | "version": "1.2.1", 1561 | "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.2.1.tgz", 1562 | "integrity": "sha512-vkcDPrRZo1QZLbn5RLGPpg/WmIQ65qoWWhcGKf/b5eplkkarX0m9z8ppCat4mlOqUsWpyNuYgO3VRyrYHSzX5g==", 1563 | "dev": true, 1564 | "engines": { 1565 | "node": ">= 0.8.0" 1566 | } 1567 | }, 1568 | "node_modules/prettier": { 1569 | "version": "2.4.1", 1570 | "resolved": "https://registry.npmjs.org/prettier/-/prettier-2.4.1.tgz", 1571 | "integrity": "sha512-9fbDAXSBcc6Bs1mZrDYb3XKzDLm4EXXL9sC1LqKP5rZkT6KRr/rf9amVUcODVXgguK/isJz0d0hP72WeaKWsvA==", 1572 | "dev": true, 1573 | "bin": { 1574 | "prettier": "bin-prettier.js" 1575 | }, 1576 | "engines": { 1577 | "node": ">=10.13.0" 1578 | } 1579 | }, 1580 | "node_modules/prettier-linter-helpers": { 1581 | "version": "1.0.0", 1582 | "resolved": "https://registry.npmjs.org/prettier-linter-helpers/-/prettier-linter-helpers-1.0.0.tgz", 1583 | "integrity": "sha512-GbK2cP9nraSSUF9N2XwUwqfzlAFlMNYYl+ShE/V+H8a9uNl/oUqB1w2EL54Jh0OlyRSd8RfWYJ3coVS4TROP2w==", 1584 | "dev": true, 1585 | "dependencies": { 1586 | "fast-diff": "^1.1.2" 1587 | }, 1588 | "engines": { 1589 | "node": ">=6.0.0" 1590 | } 1591 | }, 1592 | "node_modules/progress": { 1593 | "version": "2.0.3", 1594 | "resolved": "https://registry.npmjs.org/progress/-/progress-2.0.3.tgz", 1595 | "integrity": "sha512-7PiHtLll5LdnKIMw100I+8xJXR5gW2QwWYkT6iJva0bXitZKa/XMrSbdmg3r2Xnaidz9Qumd0VPaMrZlF9V9sA==", 1596 | "dev": true, 1597 | "engines": { 1598 | "node": ">=0.4.0" 1599 | } 1600 | }, 1601 | "node_modules/punycode": { 1602 | "version": "2.1.1", 1603 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.1.1.tgz", 1604 | "integrity": "sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A==", 1605 | "dev": true, 1606 | "engines": { 1607 | "node": ">=6" 1608 | } 1609 | }, 1610 | "node_modules/randombytes": { 1611 | "version": "2.1.0", 1612 | "resolved": "https://registry.npmjs.org/randombytes/-/randombytes-2.1.0.tgz", 1613 | "integrity": "sha512-vYl3iOX+4CKUWuxGi9Ukhie6fsqXqS9FE2Zaic4tNFD2N2QQaXOMFbuKK4QmDHC0JO6B1Zp41J0LpT0oR68amQ==", 1614 | "dev": true, 1615 | "dependencies": { 1616 | "safe-buffer": "^5.1.0" 1617 | } 1618 | }, 1619 | "node_modules/readdirp": { 1620 | "version": "3.6.0", 1621 | "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.6.0.tgz", 1622 | "integrity": "sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==", 1623 | "dev": true, 1624 | "dependencies": { 1625 | "picomatch": "^2.2.1" 1626 | }, 1627 | "engines": { 1628 | "node": ">=8.10.0" 1629 | } 1630 | }, 1631 | "node_modules/regexpp": { 1632 | "version": "3.2.0", 1633 | "resolved": "https://registry.npmjs.org/regexpp/-/regexpp-3.2.0.tgz", 1634 | "integrity": "sha512-pq2bWo9mVD43nbts2wGv17XLiNLya+GklZ8kaDLV2Z08gDCsGpnKn9BFMepvWuHCbyVvY7J5o5+BVvoQbmlJLg==", 1635 | "dev": true, 1636 | "engines": { 1637 | "node": ">=8" 1638 | }, 1639 | "funding": { 1640 | "url": "https://github.com/sponsors/mysticatea" 1641 | } 1642 | }, 1643 | "node_modules/regextras": { 1644 | "version": "0.8.0", 1645 | "resolved": "https://registry.npmjs.org/regextras/-/regextras-0.8.0.tgz", 1646 | "integrity": "sha512-k519uI04Z3SaY0fLX843MRXnDeG2+vHOFsyhiPZvNLe7r8rD2YNRjq4BQLZZ0oAr2NrtvZlICsXysGNFPGa3CQ==", 1647 | "dev": true, 1648 | "engines": { 1649 | "node": ">=0.1.14" 1650 | } 1651 | }, 1652 | "node_modules/require-directory": { 1653 | "version": "2.1.1", 1654 | "resolved": "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz", 1655 | "integrity": "sha1-jGStX9MNqxyXbiNE/+f3kqam30I=", 1656 | "dev": true, 1657 | "engines": { 1658 | "node": ">=0.10.0" 1659 | } 1660 | }, 1661 | "node_modules/require-from-string": { 1662 | "version": "2.0.2", 1663 | "resolved": "https://registry.npmjs.org/require-from-string/-/require-from-string-2.0.2.tgz", 1664 | "integrity": "sha512-Xf0nWe6RseziFMu+Ap9biiUbmplq6S9/p+7w7YXP/JBHhrUDDUhwa+vANyubuqfZWTveU//DYVGsDG7RKL/vEw==", 1665 | "dev": true, 1666 | "engines": { 1667 | "node": ">=0.10.0" 1668 | } 1669 | }, 1670 | "node_modules/resolve-from": { 1671 | "version": "4.0.0", 1672 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz", 1673 | "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==", 1674 | "dev": true, 1675 | "engines": { 1676 | "node": ">=4" 1677 | } 1678 | }, 1679 | "node_modules/rimraf": { 1680 | "version": "3.0.2", 1681 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-3.0.2.tgz", 1682 | "integrity": "sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA==", 1683 | "dev": true, 1684 | "dependencies": { 1685 | "glob": "^7.1.3" 1686 | }, 1687 | "bin": { 1688 | "rimraf": "bin.js" 1689 | }, 1690 | "funding": { 1691 | "url": "https://github.com/sponsors/isaacs" 1692 | } 1693 | }, 1694 | "node_modules/safe-buffer": { 1695 | "version": "5.2.1", 1696 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz", 1697 | "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==", 1698 | "dev": true, 1699 | "funding": [ 1700 | { 1701 | "type": "github", 1702 | "url": "https://github.com/sponsors/feross" 1703 | }, 1704 | { 1705 | "type": "patreon", 1706 | "url": "https://www.patreon.com/feross" 1707 | }, 1708 | { 1709 | "type": "consulting", 1710 | "url": "https://feross.org/support" 1711 | } 1712 | ] 1713 | }, 1714 | "node_modules/semver": { 1715 | "version": "7.3.5", 1716 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.3.5.tgz", 1717 | "integrity": "sha512-PoeGJYh8HK4BTO/a9Tf6ZG3veo/A7ZVsYrSA6J8ny9nb3B1VrpkuN+z9OE5wfE5p6H4LchYZsegiQgbJD94ZFQ==", 1718 | "dev": true, 1719 | "dependencies": { 1720 | "lru-cache": "^6.0.0" 1721 | }, 1722 | "bin": { 1723 | "semver": "bin/semver.js" 1724 | }, 1725 | "engines": { 1726 | "node": ">=10" 1727 | } 1728 | }, 1729 | "node_modules/serialize-javascript": { 1730 | "version": "6.0.0", 1731 | "resolved": "https://registry.npmjs.org/serialize-javascript/-/serialize-javascript-6.0.0.tgz", 1732 | "integrity": "sha512-Qr3TosvguFt8ePWqsvRfrKyQXIiW+nGbYpy8XK24NQHE83caxWt+mIymTT19DGFbNWNLfEwsrkSmN64lVWB9ag==", 1733 | "dev": true, 1734 | "dependencies": { 1735 | "randombytes": "^2.1.0" 1736 | } 1737 | }, 1738 | "node_modules/shebang-command": { 1739 | "version": "2.0.0", 1740 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", 1741 | "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", 1742 | "dev": true, 1743 | "dependencies": { 1744 | "shebang-regex": "^3.0.0" 1745 | }, 1746 | "engines": { 1747 | "node": ">=8" 1748 | } 1749 | }, 1750 | "node_modules/shebang-regex": { 1751 | "version": "3.0.0", 1752 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", 1753 | "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", 1754 | "dev": true, 1755 | "engines": { 1756 | "node": ">=8" 1757 | } 1758 | }, 1759 | "node_modules/slice-ansi": { 1760 | "version": "4.0.0", 1761 | "resolved": "https://registry.npmjs.org/slice-ansi/-/slice-ansi-4.0.0.tgz", 1762 | "integrity": "sha512-qMCMfhY040cVHT43K9BFygqYbUPFZKHOg7K73mtTWJRb8pyP3fzf4Ixd5SzdEJQ6MRUg/WBnOLxghZtKKurENQ==", 1763 | "dev": true, 1764 | "dependencies": { 1765 | "ansi-styles": "^4.0.0", 1766 | "astral-regex": "^2.0.0", 1767 | "is-fullwidth-code-point": "^3.0.0" 1768 | }, 1769 | "engines": { 1770 | "node": ">=10" 1771 | }, 1772 | "funding": { 1773 | "url": "https://github.com/chalk/slice-ansi?sponsor=1" 1774 | } 1775 | }, 1776 | "node_modules/spdx-exceptions": { 1777 | "version": "2.3.0", 1778 | "resolved": "https://registry.npmjs.org/spdx-exceptions/-/spdx-exceptions-2.3.0.tgz", 1779 | "integrity": "sha512-/tTrYOC7PPI1nUAgx34hUpqXuyJG+DTHJTnIULG4rDygi4xu/tfgmq1e1cIRwRzwZgo4NLySi+ricLkZkw4i5A==", 1780 | "dev": true 1781 | }, 1782 | "node_modules/spdx-expression-parse": { 1783 | "version": "3.0.1", 1784 | "resolved": "https://registry.npmjs.org/spdx-expression-parse/-/spdx-expression-parse-3.0.1.tgz", 1785 | "integrity": "sha512-cbqHunsQWnJNE6KhVSMsMeH5H/L9EpymbzqTQ3uLwNCLZ1Q481oWaofqH7nO6V07xlXwY6PhQdQ2IedWx/ZK4Q==", 1786 | "dev": true, 1787 | "dependencies": { 1788 | "spdx-exceptions": "^2.1.0", 1789 | "spdx-license-ids": "^3.0.0" 1790 | } 1791 | }, 1792 | "node_modules/spdx-license-ids": { 1793 | "version": "3.0.10", 1794 | "resolved": "https://registry.npmjs.org/spdx-license-ids/-/spdx-license-ids-3.0.10.tgz", 1795 | "integrity": "sha512-oie3/+gKf7QtpitB0LYLETe+k8SifzsX4KixvpOsbI6S0kRiRQ5MKOio8eMSAKQ17N06+wdEOXRiId+zOxo0hA==", 1796 | "dev": true 1797 | }, 1798 | "node_modules/sprintf-js": { 1799 | "version": "1.0.3", 1800 | "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.0.3.tgz", 1801 | "integrity": "sha1-BOaSb2YolTVPPdAVIDYzuFcpfiw=", 1802 | "dev": true 1803 | }, 1804 | "node_modules/string-width": { 1805 | "version": "4.2.3", 1806 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", 1807 | "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", 1808 | "dev": true, 1809 | "dependencies": { 1810 | "emoji-regex": "^8.0.0", 1811 | "is-fullwidth-code-point": "^3.0.0", 1812 | "strip-ansi": "^6.0.1" 1813 | }, 1814 | "engines": { 1815 | "node": ">=8" 1816 | } 1817 | }, 1818 | "node_modules/strip-ansi": { 1819 | "version": "6.0.1", 1820 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", 1821 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", 1822 | "dev": true, 1823 | "dependencies": { 1824 | "ansi-regex": "^5.0.1" 1825 | }, 1826 | "engines": { 1827 | "node": ">=8" 1828 | } 1829 | }, 1830 | "node_modules/strip-json-comments": { 1831 | "version": "3.1.1", 1832 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz", 1833 | "integrity": "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==", 1834 | "dev": true, 1835 | "engines": { 1836 | "node": ">=8" 1837 | }, 1838 | "funding": { 1839 | "url": "https://github.com/sponsors/sindresorhus" 1840 | } 1841 | }, 1842 | "node_modules/supports-color": { 1843 | "version": "7.2.0", 1844 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", 1845 | "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", 1846 | "dev": true, 1847 | "dependencies": { 1848 | "has-flag": "^4.0.0" 1849 | }, 1850 | "engines": { 1851 | "node": ">=8" 1852 | } 1853 | }, 1854 | "node_modules/table": { 1855 | "version": "6.7.1", 1856 | "resolved": "https://registry.npmjs.org/table/-/table-6.7.1.tgz", 1857 | "integrity": "sha512-ZGum47Yi6KOOFDE8m223td53ath2enHcYLgOCjGr5ngu8bdIARQk6mN/wRMv4yMRcHnCSnHbCEha4sobQx5yWg==", 1858 | "dev": true, 1859 | "dependencies": { 1860 | "ajv": "^8.0.1", 1861 | "lodash.clonedeep": "^4.5.0", 1862 | "lodash.truncate": "^4.4.2", 1863 | "slice-ansi": "^4.0.0", 1864 | "string-width": "^4.2.0", 1865 | "strip-ansi": "^6.0.0" 1866 | }, 1867 | "engines": { 1868 | "node": ">=10.0.0" 1869 | } 1870 | }, 1871 | "node_modules/table/node_modules/ajv": { 1872 | "version": "8.6.3", 1873 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-8.6.3.tgz", 1874 | "integrity": "sha512-SMJOdDP6LqTkD0Uq8qLi+gMwSt0imXLSV080qFVwJCpH9U6Mb+SUGHAXM0KNbcBPguytWyvFxcHgMLe2D2XSpw==", 1875 | "dev": true, 1876 | "dependencies": { 1877 | "fast-deep-equal": "^3.1.1", 1878 | "json-schema-traverse": "^1.0.0", 1879 | "require-from-string": "^2.0.2", 1880 | "uri-js": "^4.2.2" 1881 | }, 1882 | "funding": { 1883 | "type": "github", 1884 | "url": "https://github.com/sponsors/epoberezkin" 1885 | } 1886 | }, 1887 | "node_modules/table/node_modules/json-schema-traverse": { 1888 | "version": "1.0.0", 1889 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-1.0.0.tgz", 1890 | "integrity": "sha512-NM8/P9n3XjXhIZn1lLhkFaACTOURQXjWhV4BA/RnOv8xvgqtqpAX9IO4mRQxSx1Rlo4tqzeqb0sOlruaOy3dug==", 1891 | "dev": true 1892 | }, 1893 | "node_modules/text-table": { 1894 | "version": "0.2.0", 1895 | "resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz", 1896 | "integrity": "sha1-f17oI66AUgfACvLfSoTsP8+lcLQ=", 1897 | "dev": true 1898 | }, 1899 | "node_modules/to-regex-range": { 1900 | "version": "5.0.1", 1901 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", 1902 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", 1903 | "dev": true, 1904 | "dependencies": { 1905 | "is-number": "^7.0.0" 1906 | }, 1907 | "engines": { 1908 | "node": ">=8.0" 1909 | } 1910 | }, 1911 | "node_modules/type-check": { 1912 | "version": "0.4.0", 1913 | "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.4.0.tgz", 1914 | "integrity": "sha512-XleUoc9uwGXqjWwXaUTZAmzMcFZ5858QA2vvx1Ur5xIcixXIP+8LnFDgRplU30us6teqdlskFfu+ae4K79Ooew==", 1915 | "dev": true, 1916 | "dependencies": { 1917 | "prelude-ls": "^1.2.1" 1918 | }, 1919 | "engines": { 1920 | "node": ">= 0.8.0" 1921 | } 1922 | }, 1923 | "node_modules/type-detect": { 1924 | "version": "4.0.8", 1925 | "resolved": "https://registry.npmjs.org/type-detect/-/type-detect-4.0.8.tgz", 1926 | "integrity": "sha512-0fr/mIH1dlO+x7TlcMy+bIDqKPsw/70tVyeHW787goQjhmqaZe10uwLujubK9q9Lg6Fiho1KUKDYz0Z7k7g5/g==", 1927 | "dev": true, 1928 | "engines": { 1929 | "node": ">=4" 1930 | } 1931 | }, 1932 | "node_modules/type-fest": { 1933 | "version": "0.20.2", 1934 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.20.2.tgz", 1935 | "integrity": "sha512-Ne+eE4r0/iWnpAxD852z3A+N0Bt5RN//NjJwRd2VFHEmrywxf5vsZlh4R6lixl6B+wz/8d+maTSAkN1FIkI3LQ==", 1936 | "dev": true, 1937 | "engines": { 1938 | "node": ">=10" 1939 | }, 1940 | "funding": { 1941 | "url": "https://github.com/sponsors/sindresorhus" 1942 | } 1943 | }, 1944 | "node_modules/uglify-js": { 1945 | "version": "3.14.2", 1946 | "resolved": "https://registry.npmjs.org/uglify-js/-/uglify-js-3.14.2.tgz", 1947 | "integrity": "sha512-rtPMlmcO4agTUfz10CbgJ1k6UAoXM2gWb3GoMPPZB/+/Ackf8lNWk11K4rYi2D0apgoFRLtQOZhb+/iGNJq26A==", 1948 | "dev": true, 1949 | "bin": { 1950 | "uglifyjs": "bin/uglifyjs" 1951 | }, 1952 | "engines": { 1953 | "node": ">=0.8.0" 1954 | } 1955 | }, 1956 | "node_modules/uri-js": { 1957 | "version": "4.4.1", 1958 | "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.4.1.tgz", 1959 | "integrity": "sha512-7rKUyy33Q1yc98pQ1DAmLtwX109F7TIfWlW1Ydo8Wl1ii1SeHieeh0HHfPeL2fMXK6z0s8ecKs9frCuLJvndBg==", 1960 | "dev": true, 1961 | "dependencies": { 1962 | "punycode": "^2.1.0" 1963 | } 1964 | }, 1965 | "node_modules/v8-compile-cache": { 1966 | "version": "2.3.0", 1967 | "resolved": "https://registry.npmjs.org/v8-compile-cache/-/v8-compile-cache-2.3.0.tgz", 1968 | "integrity": "sha512-l8lCEmLcLYZh4nbunNZvQCJc5pv7+RCwa8q/LdUx8u7lsWvPDKmpodJAJNwkAhJC//dFY48KuIEmjtd4RViDrA==", 1969 | "dev": true 1970 | }, 1971 | "node_modules/which": { 1972 | "version": "2.0.2", 1973 | "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", 1974 | "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", 1975 | "dev": true, 1976 | "dependencies": { 1977 | "isexe": "^2.0.0" 1978 | }, 1979 | "bin": { 1980 | "node-which": "bin/node-which" 1981 | }, 1982 | "engines": { 1983 | "node": ">= 8" 1984 | } 1985 | }, 1986 | "node_modules/word-wrap": { 1987 | "version": "1.2.3", 1988 | "resolved": "https://registry.npmjs.org/word-wrap/-/word-wrap-1.2.3.tgz", 1989 | "integrity": "sha512-Hz/mrNwitNRh/HUAtM/VT/5VH+ygD6DV7mYKZAtHOrbs8U7lvPS6xf7EJKMF0uW1KJCl0H701g3ZGus+muE5vQ==", 1990 | "dev": true, 1991 | "engines": { 1992 | "node": ">=0.10.0" 1993 | } 1994 | }, 1995 | "node_modules/workerpool": { 1996 | "version": "6.1.5", 1997 | "resolved": "https://registry.npmjs.org/workerpool/-/workerpool-6.1.5.tgz", 1998 | "integrity": "sha512-XdKkCK0Zqc6w3iTxLckiuJ81tiD/o5rBE/m+nXpRCB+/Sq4DqkfXZ/x0jW02DG1tGsfUGXbTJyZDP+eu67haSw==", 1999 | "dev": true 2000 | }, 2001 | "node_modules/wrap-ansi": { 2002 | "version": "7.0.0", 2003 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz", 2004 | "integrity": "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==", 2005 | "dev": true, 2006 | "dependencies": { 2007 | "ansi-styles": "^4.0.0", 2008 | "string-width": "^4.1.0", 2009 | "strip-ansi": "^6.0.0" 2010 | }, 2011 | "engines": { 2012 | "node": ">=10" 2013 | }, 2014 | "funding": { 2015 | "url": "https://github.com/chalk/wrap-ansi?sponsor=1" 2016 | } 2017 | }, 2018 | "node_modules/wrappy": { 2019 | "version": "1.0.2", 2020 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 2021 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=", 2022 | "dev": true 2023 | }, 2024 | "node_modules/y18n": { 2025 | "version": "5.0.8", 2026 | "resolved": "https://registry.npmjs.org/y18n/-/y18n-5.0.8.tgz", 2027 | "integrity": "sha512-0pfFzegeDWJHJIAmTLRP2DwHjdF5s7jo9tuztdQxAhINCdvS+3nGINqPd00AphqJR/0LhANUS6/+7SCb98YOfA==", 2028 | "dev": true, 2029 | "engines": { 2030 | "node": ">=10" 2031 | } 2032 | }, 2033 | "node_modules/yallist": { 2034 | "version": "4.0.0", 2035 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", 2036 | "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", 2037 | "dev": true 2038 | }, 2039 | "node_modules/yargs": { 2040 | "version": "16.2.0", 2041 | "resolved": "https://registry.npmjs.org/yargs/-/yargs-16.2.0.tgz", 2042 | "integrity": "sha512-D1mvvtDG0L5ft/jGWkLpG1+m0eQxOfaBvTNELraWj22wSVUMWxZUvYgJYcKh6jGGIkJFhH4IZPQhR4TKpc8mBw==", 2043 | "dev": true, 2044 | "dependencies": { 2045 | "cliui": "^7.0.2", 2046 | "escalade": "^3.1.1", 2047 | "get-caller-file": "^2.0.5", 2048 | "require-directory": "^2.1.1", 2049 | "string-width": "^4.2.0", 2050 | "y18n": "^5.0.5", 2051 | "yargs-parser": "^20.2.2" 2052 | }, 2053 | "engines": { 2054 | "node": ">=10" 2055 | } 2056 | }, 2057 | "node_modules/yargs-parser": { 2058 | "version": "20.2.4", 2059 | "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-20.2.4.tgz", 2060 | "integrity": "sha512-WOkpgNhPTlE73h4VFAFsOnomJVaovO8VqLDzy5saChRBFQFBoMYirowyW+Q9HB4HFF4Z7VZTiG3iSzJJA29yRA==", 2061 | "dev": true, 2062 | "engines": { 2063 | "node": ">=10" 2064 | } 2065 | }, 2066 | "node_modules/yargs-unparser": { 2067 | "version": "2.0.0", 2068 | "resolved": "https://registry.npmjs.org/yargs-unparser/-/yargs-unparser-2.0.0.tgz", 2069 | "integrity": "sha512-7pRTIA9Qc1caZ0bZ6RYRGbHJthJWuakf+WmHK0rVeLkNrrGhfoabBNdue6kdINI6r4if7ocq9aD/n7xwKOdzOA==", 2070 | "dev": true, 2071 | "dependencies": { 2072 | "camelcase": "^6.0.0", 2073 | "decamelize": "^4.0.0", 2074 | "flat": "^5.0.2", 2075 | "is-plain-obj": "^2.1.0" 2076 | }, 2077 | "engines": { 2078 | "node": ">=10" 2079 | } 2080 | }, 2081 | "node_modules/yocto-queue": { 2082 | "version": "0.1.0", 2083 | "resolved": "https://registry.npmjs.org/yocto-queue/-/yocto-queue-0.1.0.tgz", 2084 | "integrity": "sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q==", 2085 | "dev": true, 2086 | "engines": { 2087 | "node": ">=10" 2088 | }, 2089 | "funding": { 2090 | "url": "https://github.com/sponsors/sindresorhus" 2091 | } 2092 | } 2093 | }, 2094 | "dependencies": { 2095 | "@babel/code-frame": { 2096 | "version": "7.12.11", 2097 | "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.12.11.tgz", 2098 | "integrity": "sha512-Zt1yodBx1UcyiePMSkWnU4hPqhwq7hGi2nFL1LeA3EUl+q2LQx16MISgJ0+z7dnmgvP9QtIleuETGOiOH1RcIw==", 2099 | "dev": true, 2100 | "requires": { 2101 | "@babel/highlight": "^7.10.4" 2102 | } 2103 | }, 2104 | "@babel/helper-validator-identifier": { 2105 | "version": "7.15.7", 2106 | "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.15.7.tgz", 2107 | "integrity": "sha512-K4JvCtQqad9OY2+yTU8w+E82ywk/fe+ELNlt1G8z3bVGlZfn/hOcQQsUhGhW/N+tb3fxK800wLtKOE/aM0m72w==", 2108 | "dev": true 2109 | }, 2110 | "@babel/highlight": { 2111 | "version": "7.14.5", 2112 | "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.14.5.tgz", 2113 | "integrity": "sha512-qf9u2WFWVV0MppaL877j2dBtQIDgmidgjGk5VIMw3OadXvYaXn66U1BFlH2t4+t3i+8PhedppRv+i40ABzd+gg==", 2114 | "dev": true, 2115 | "requires": { 2116 | "@babel/helper-validator-identifier": "^7.14.5", 2117 | "chalk": "^2.0.0", 2118 | "js-tokens": "^4.0.0" 2119 | }, 2120 | "dependencies": { 2121 | "ansi-styles": { 2122 | "version": "3.2.1", 2123 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", 2124 | "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", 2125 | "dev": true, 2126 | "requires": { 2127 | "color-convert": "^1.9.0" 2128 | } 2129 | }, 2130 | "chalk": { 2131 | "version": "2.4.2", 2132 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", 2133 | "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", 2134 | "dev": true, 2135 | "requires": { 2136 | "ansi-styles": "^3.2.1", 2137 | "escape-string-regexp": "^1.0.5", 2138 | "supports-color": "^5.3.0" 2139 | } 2140 | }, 2141 | "color-convert": { 2142 | "version": "1.9.3", 2143 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", 2144 | "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", 2145 | "dev": true, 2146 | "requires": { 2147 | "color-name": "1.1.3" 2148 | } 2149 | }, 2150 | "color-name": { 2151 | "version": "1.1.3", 2152 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", 2153 | "integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=", 2154 | "dev": true 2155 | }, 2156 | "escape-string-regexp": { 2157 | "version": "1.0.5", 2158 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", 2159 | "integrity": "sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ=", 2160 | "dev": true 2161 | }, 2162 | "has-flag": { 2163 | "version": "3.0.0", 2164 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 2165 | "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=", 2166 | "dev": true 2167 | }, 2168 | "supports-color": { 2169 | "version": "5.5.0", 2170 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 2171 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 2172 | "dev": true, 2173 | "requires": { 2174 | "has-flag": "^3.0.0" 2175 | } 2176 | } 2177 | } 2178 | }, 2179 | "@es-joy/jsdoccomment": { 2180 | "version": "0.10.8", 2181 | "resolved": "https://registry.npmjs.org/@es-joy/jsdoccomment/-/jsdoccomment-0.10.8.tgz", 2182 | "integrity": "sha512-3P1JiGL4xaR9PoTKUHa2N/LKwa2/eUdRqGwijMWWgBqbFEqJUVpmaOi2TcjcemrsRMgFLBzQCK4ToPhrSVDiFQ==", 2183 | "dev": true, 2184 | "requires": { 2185 | "comment-parser": "1.2.4", 2186 | "esquery": "^1.4.0", 2187 | "jsdoc-type-pratt-parser": "1.1.1" 2188 | } 2189 | }, 2190 | "@eslint/eslintrc": { 2191 | "version": "0.4.3", 2192 | "resolved": "https://registry.npmjs.org/@eslint/eslintrc/-/eslintrc-0.4.3.tgz", 2193 | "integrity": "sha512-J6KFFz5QCYUJq3pf0mjEcCJVERbzv71PUIDczuh9JkwGEzced6CO5ADLHB1rbf/+oPBtoPfMYNOpGDzCANlbXw==", 2194 | "dev": true, 2195 | "requires": { 2196 | "ajv": "^6.12.4", 2197 | "debug": "^4.1.1", 2198 | "espree": "^7.3.0", 2199 | "globals": "^13.9.0", 2200 | "ignore": "^4.0.6", 2201 | "import-fresh": "^3.2.1", 2202 | "js-yaml": "^3.13.1", 2203 | "minimatch": "^3.0.4", 2204 | "strip-json-comments": "^3.1.1" 2205 | } 2206 | }, 2207 | "@humanwhocodes/config-array": { 2208 | "version": "0.5.0", 2209 | "resolved": "https://registry.npmjs.org/@humanwhocodes/config-array/-/config-array-0.5.0.tgz", 2210 | "integrity": "sha512-FagtKFz74XrTl7y6HCzQpwDfXP0yhxe9lHLD1UZxjvZIcbyRz8zTFF/yYNfSfzU414eDwZ1SrO0Qvtyf+wFMQg==", 2211 | "dev": true, 2212 | "requires": { 2213 | "@humanwhocodes/object-schema": "^1.2.0", 2214 | "debug": "^4.1.1", 2215 | "minimatch": "^3.0.4" 2216 | } 2217 | }, 2218 | "@humanwhocodes/object-schema": { 2219 | "version": "1.2.0", 2220 | "resolved": "https://registry.npmjs.org/@humanwhocodes/object-schema/-/object-schema-1.2.0.tgz", 2221 | "integrity": "sha512-wdppn25U8z/2yiaT6YGquE6X8sSv7hNMWSXYSSU1jGv/yd6XqjXgTDJ8KP4NgjTXfJ3GbRjeeb8RTV7a/VpM+w==", 2222 | "dev": true 2223 | }, 2224 | "@ungap/promise-all-settled": { 2225 | "version": "1.1.2", 2226 | "resolved": "https://registry.npmjs.org/@ungap/promise-all-settled/-/promise-all-settled-1.1.2.tgz", 2227 | "integrity": "sha512-sL/cEvJWAnClXw0wHk85/2L0G6Sj8UB0Ctc1TEMbKSsmpRosqhwj9gWgFRZSrBr2f9tiXISwNhCPmlfqUqyb9Q==", 2228 | "dev": true 2229 | }, 2230 | "acorn": { 2231 | "version": "7.4.1", 2232 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-7.4.1.tgz", 2233 | "integrity": "sha512-nQyp0o1/mNdbTO1PO6kHkwSrmgZ0MT/jCCpNiwbUjGoRN4dlBhqJtoQuCnEOKzgTVwg0ZWiCoQy6SxMebQVh8A==", 2234 | "dev": true 2235 | }, 2236 | "acorn-jsx": { 2237 | "version": "5.3.2", 2238 | "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.3.2.tgz", 2239 | "integrity": "sha512-rq9s+JNhf0IChjtDXxllJ7g41oZk5SlXtp0LHwyA5cejwn7vKmKp4pPri6YEePv2PU65sAsegbXtIinmDFDXgQ==", 2240 | "dev": true, 2241 | "requires": {} 2242 | }, 2243 | "ajv": { 2244 | "version": "6.12.6", 2245 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.12.6.tgz", 2246 | "integrity": "sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g==", 2247 | "dev": true, 2248 | "requires": { 2249 | "fast-deep-equal": "^3.1.1", 2250 | "fast-json-stable-stringify": "^2.0.0", 2251 | "json-schema-traverse": "^0.4.1", 2252 | "uri-js": "^4.2.2" 2253 | } 2254 | }, 2255 | "ansi-colors": { 2256 | "version": "4.1.1", 2257 | "resolved": "https://registry.npmjs.org/ansi-colors/-/ansi-colors-4.1.1.tgz", 2258 | "integrity": "sha512-JoX0apGbHaUJBNl6yF+p6JAFYZ666/hhCGKN5t9QFjbJQKUU/g8MNbFDbvfrgKXvI1QpZplPOnwIo99lX/AAmA==", 2259 | "dev": true 2260 | }, 2261 | "ansi-regex": { 2262 | "version": "5.0.1", 2263 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 2264 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 2265 | "dev": true 2266 | }, 2267 | "ansi-styles": { 2268 | "version": "4.3.0", 2269 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 2270 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 2271 | "dev": true, 2272 | "requires": { 2273 | "color-convert": "^2.0.1" 2274 | } 2275 | }, 2276 | "anymatch": { 2277 | "version": "3.1.2", 2278 | "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.2.tgz", 2279 | "integrity": "sha512-P43ePfOAIupkguHUycrc4qJ9kz8ZiuOUijaETwX7THt0Y/GNK7v0aa8rY816xWjZ7rJdA5XdMcpVFTKMq+RvWg==", 2280 | "dev": true, 2281 | "requires": { 2282 | "normalize-path": "^3.0.0", 2283 | "picomatch": "^2.0.4" 2284 | } 2285 | }, 2286 | "argparse": { 2287 | "version": "1.0.10", 2288 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-1.0.10.tgz", 2289 | "integrity": "sha512-o5Roy6tNG4SL/FOkCAN6RzjiakZS25RLYFrcMttJqbdd8BWrnA+fGz57iN5Pb06pvBGvl5gQ0B48dJlslXvoTg==", 2290 | "dev": true, 2291 | "requires": { 2292 | "sprintf-js": "~1.0.2" 2293 | } 2294 | }, 2295 | "assertion-error": { 2296 | "version": "1.1.0", 2297 | "resolved": "https://registry.npmjs.org/assertion-error/-/assertion-error-1.1.0.tgz", 2298 | "integrity": "sha512-jgsaNduz+ndvGyFt3uSuWqvy4lCnIJiovtouQN5JZHOKCS2QuhEdbcQHFhVksz2N2U9hXJo8odG7ETyWlEeuDw==", 2299 | "dev": true 2300 | }, 2301 | "astral-regex": { 2302 | "version": "2.0.0", 2303 | "resolved": "https://registry.npmjs.org/astral-regex/-/astral-regex-2.0.0.tgz", 2304 | "integrity": "sha512-Z7tMw1ytTXt5jqMcOP+OQteU1VuNK9Y02uuJtKQ1Sv69jXQKKg5cibLwGJow8yzZP+eAc18EmLGPal0bp36rvQ==", 2305 | "dev": true 2306 | }, 2307 | "balanced-match": { 2308 | "version": "1.0.2", 2309 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", 2310 | "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==", 2311 | "dev": true 2312 | }, 2313 | "binary-extensions": { 2314 | "version": "2.2.0", 2315 | "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.2.0.tgz", 2316 | "integrity": "sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA==", 2317 | "dev": true 2318 | }, 2319 | "brace-expansion": { 2320 | "version": "1.1.11", 2321 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 2322 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 2323 | "dev": true, 2324 | "requires": { 2325 | "balanced-match": "^1.0.0", 2326 | "concat-map": "0.0.1" 2327 | } 2328 | }, 2329 | "braces": { 2330 | "version": "3.0.2", 2331 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", 2332 | "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", 2333 | "dev": true, 2334 | "requires": { 2335 | "fill-range": "^7.0.1" 2336 | } 2337 | }, 2338 | "browser-stdout": { 2339 | "version": "1.3.1", 2340 | "resolved": "https://registry.npmjs.org/browser-stdout/-/browser-stdout-1.3.1.tgz", 2341 | "integrity": "sha512-qhAVI1+Av2X7qelOfAIYwXONood6XlZE/fXaBSmW/T5SzLAmCgzi+eiWE7fUvbHaeNBQH13UftjpXxsfLkMpgw==", 2342 | "dev": true 2343 | }, 2344 | "callsites": { 2345 | "version": "3.1.0", 2346 | "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz", 2347 | "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==", 2348 | "dev": true 2349 | }, 2350 | "camelcase": { 2351 | "version": "6.2.0", 2352 | "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-6.2.0.tgz", 2353 | "integrity": "sha512-c7wVvbw3f37nuobQNtgsgG9POC9qMbNuMQmTCqZv23b6MIz0fcYpBiOlv9gEN/hdLdnZTDQhg6e9Dq5M1vKvfg==", 2354 | "dev": true 2355 | }, 2356 | "chai": { 2357 | "version": "4.3.4", 2358 | "resolved": "https://registry.npmjs.org/chai/-/chai-4.3.4.tgz", 2359 | "integrity": "sha512-yS5H68VYOCtN1cjfwumDSuzn/9c+yza4f3reKXlE5rUg7SFcCEy90gJvydNgOYtblyf4Zi6jIWRnXOgErta0KA==", 2360 | "dev": true, 2361 | "requires": { 2362 | "assertion-error": "^1.1.0", 2363 | "check-error": "^1.0.2", 2364 | "deep-eql": "^3.0.1", 2365 | "get-func-name": "^2.0.0", 2366 | "pathval": "^1.1.1", 2367 | "type-detect": "^4.0.5" 2368 | } 2369 | }, 2370 | "chalk": { 2371 | "version": "4.1.2", 2372 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", 2373 | "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", 2374 | "dev": true, 2375 | "requires": { 2376 | "ansi-styles": "^4.1.0", 2377 | "supports-color": "^7.1.0" 2378 | } 2379 | }, 2380 | "check-error": { 2381 | "version": "1.0.2", 2382 | "resolved": "https://registry.npmjs.org/check-error/-/check-error-1.0.2.tgz", 2383 | "integrity": "sha1-V00xLt2Iu13YkS6Sht1sCu1KrII=", 2384 | "dev": true 2385 | }, 2386 | "chokidar": { 2387 | "version": "3.5.2", 2388 | "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.5.2.tgz", 2389 | "integrity": "sha512-ekGhOnNVPgT77r4K/U3GDhu+FQ2S8TnK/s2KbIGXi0SZWuwkZ2QNyfWdZW+TVfn84DpEP7rLeCt2UI6bJ8GwbQ==", 2390 | "dev": true, 2391 | "requires": { 2392 | "anymatch": "~3.1.2", 2393 | "braces": "~3.0.2", 2394 | "fsevents": "~2.3.2", 2395 | "glob-parent": "~5.1.2", 2396 | "is-binary-path": "~2.1.0", 2397 | "is-glob": "~4.0.1", 2398 | "normalize-path": "~3.0.0", 2399 | "readdirp": "~3.6.0" 2400 | } 2401 | }, 2402 | "cliui": { 2403 | "version": "7.0.4", 2404 | "resolved": "https://registry.npmjs.org/cliui/-/cliui-7.0.4.tgz", 2405 | "integrity": "sha512-OcRE68cOsVMXp1Yvonl/fzkQOyjLSu/8bhPDfQt0e0/Eb283TKP20Fs2MqoPsr9SwA595rRCA+QMzYc9nBP+JQ==", 2406 | "dev": true, 2407 | "requires": { 2408 | "string-width": "^4.2.0", 2409 | "strip-ansi": "^6.0.0", 2410 | "wrap-ansi": "^7.0.0" 2411 | } 2412 | }, 2413 | "color-convert": { 2414 | "version": "2.0.1", 2415 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 2416 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 2417 | "dev": true, 2418 | "requires": { 2419 | "color-name": "~1.1.4" 2420 | } 2421 | }, 2422 | "color-name": { 2423 | "version": "1.1.4", 2424 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 2425 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 2426 | "dev": true 2427 | }, 2428 | "comment-parser": { 2429 | "version": "1.2.4", 2430 | "resolved": "https://registry.npmjs.org/comment-parser/-/comment-parser-1.2.4.tgz", 2431 | "integrity": "sha512-pm0b+qv+CkWNriSTMsfnjChF9kH0kxz55y44Wo5le9qLxMj5xDQAaEd9ZN1ovSuk9CsrncWaFwgpOMg7ClJwkw==", 2432 | "dev": true 2433 | }, 2434 | "concat-map": { 2435 | "version": "0.0.1", 2436 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 2437 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=", 2438 | "dev": true 2439 | }, 2440 | "cross-spawn": { 2441 | "version": "7.0.3", 2442 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz", 2443 | "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==", 2444 | "dev": true, 2445 | "requires": { 2446 | "path-key": "^3.1.0", 2447 | "shebang-command": "^2.0.0", 2448 | "which": "^2.0.1" 2449 | } 2450 | }, 2451 | "debug": { 2452 | "version": "4.3.2", 2453 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.2.tgz", 2454 | "integrity": "sha512-mOp8wKcvj7XxC78zLgw/ZA+6TSgkoE2C/ienthhRD298T7UNwAg9diBpLRxC0mOezLl4B0xV7M0cCO6P/O0Xhw==", 2455 | "dev": true, 2456 | "requires": { 2457 | "ms": "2.1.2" 2458 | } 2459 | }, 2460 | "decamelize": { 2461 | "version": "4.0.0", 2462 | "resolved": "https://registry.npmjs.org/decamelize/-/decamelize-4.0.0.tgz", 2463 | "integrity": "sha512-9iE1PgSik9HeIIw2JO94IidnE3eBoQrFJ3w7sFuzSX4DpmZ3v5sZpUiV5Swcf6mQEF+Y0ru8Neo+p+nyh2J+hQ==", 2464 | "dev": true 2465 | }, 2466 | "deep-eql": { 2467 | "version": "3.0.1", 2468 | "resolved": "https://registry.npmjs.org/deep-eql/-/deep-eql-3.0.1.tgz", 2469 | "integrity": "sha512-+QeIQyN5ZuO+3Uk5DYh6/1eKO0m0YmJFGNmFHGACpf1ClL1nmlV/p4gNgbl2pJGxgXb4faqo6UE+M5ACEMyVcw==", 2470 | "dev": true, 2471 | "requires": { 2472 | "type-detect": "^4.0.0" 2473 | } 2474 | }, 2475 | "deep-is": { 2476 | "version": "0.1.4", 2477 | "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.4.tgz", 2478 | "integrity": "sha512-oIPzksmTg4/MriiaYGO+okXDT7ztn/w3Eptv/+gSIdMdKsJo0u4CfYNFJPy+4SKMuCqGw2wxnA+URMg3t8a/bQ==", 2479 | "dev": true 2480 | }, 2481 | "diff": { 2482 | "version": "5.0.0", 2483 | "resolved": "https://registry.npmjs.org/diff/-/diff-5.0.0.tgz", 2484 | "integrity": "sha512-/VTCrvm5Z0JGty/BWHljh+BAiw3IK+2j87NGMu8Nwc/f48WoDAC395uomO9ZD117ZOBaHmkX1oyLvkVM/aIT3w==", 2485 | "dev": true 2486 | }, 2487 | "doctrine": { 2488 | "version": "3.0.0", 2489 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-3.0.0.tgz", 2490 | "integrity": "sha512-yS+Q5i3hBf7GBkd4KG8a7eBNNWNGLTaEwwYWUijIYM7zrlYDM0BFXHjjPWlWZ1Rg7UaddZeIDmi9jF3HmqiQ2w==", 2491 | "dev": true, 2492 | "requires": { 2493 | "esutils": "^2.0.2" 2494 | } 2495 | }, 2496 | "emoji-regex": { 2497 | "version": "8.0.0", 2498 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 2499 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", 2500 | "dev": true 2501 | }, 2502 | "enquirer": { 2503 | "version": "2.3.6", 2504 | "resolved": "https://registry.npmjs.org/enquirer/-/enquirer-2.3.6.tgz", 2505 | "integrity": "sha512-yjNnPr315/FjS4zIsUxYguYUPP2e1NK4d7E7ZOLiyYCcbFBiTMyID+2wvm2w6+pZ/odMA7cRkjhsPbltwBOrLg==", 2506 | "dev": true, 2507 | "requires": { 2508 | "ansi-colors": "^4.1.1" 2509 | } 2510 | }, 2511 | "escalade": { 2512 | "version": "3.1.1", 2513 | "resolved": "https://registry.npmjs.org/escalade/-/escalade-3.1.1.tgz", 2514 | "integrity": "sha512-k0er2gUkLf8O0zKJiAhmkTnJlTvINGv7ygDNPbeIsX/TJjGJZHuh9B2UxbsaEkmlEo9MfhrSzmhIlhRlI2GXnw==", 2515 | "dev": true 2516 | }, 2517 | "escape-string-regexp": { 2518 | "version": "4.0.0", 2519 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", 2520 | "integrity": "sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA==", 2521 | "dev": true 2522 | }, 2523 | "eslint": { 2524 | "version": "7.32.0", 2525 | "resolved": "https://registry.npmjs.org/eslint/-/eslint-7.32.0.tgz", 2526 | "integrity": "sha512-VHZ8gX+EDfz+97jGcgyGCyRia/dPOd6Xh9yPv8Bl1+SoaIwD+a/vlrOmGRUyOYu7MwUhc7CxqeaDZU13S4+EpA==", 2527 | "dev": true, 2528 | "requires": { 2529 | "@babel/code-frame": "7.12.11", 2530 | "@eslint/eslintrc": "^0.4.3", 2531 | "@humanwhocodes/config-array": "^0.5.0", 2532 | "ajv": "^6.10.0", 2533 | "chalk": "^4.0.0", 2534 | "cross-spawn": "^7.0.2", 2535 | "debug": "^4.0.1", 2536 | "doctrine": "^3.0.0", 2537 | "enquirer": "^2.3.5", 2538 | "escape-string-regexp": "^4.0.0", 2539 | "eslint-scope": "^5.1.1", 2540 | "eslint-utils": "^2.1.0", 2541 | "eslint-visitor-keys": "^2.0.0", 2542 | "espree": "^7.3.1", 2543 | "esquery": "^1.4.0", 2544 | "esutils": "^2.0.2", 2545 | "fast-deep-equal": "^3.1.3", 2546 | "file-entry-cache": "^6.0.1", 2547 | "functional-red-black-tree": "^1.0.1", 2548 | "glob-parent": "^5.1.2", 2549 | "globals": "^13.6.0", 2550 | "ignore": "^4.0.6", 2551 | "import-fresh": "^3.0.0", 2552 | "imurmurhash": "^0.1.4", 2553 | "is-glob": "^4.0.0", 2554 | "js-yaml": "^3.13.1", 2555 | "json-stable-stringify-without-jsonify": "^1.0.1", 2556 | "levn": "^0.4.1", 2557 | "lodash.merge": "^4.6.2", 2558 | "minimatch": "^3.0.4", 2559 | "natural-compare": "^1.4.0", 2560 | "optionator": "^0.9.1", 2561 | "progress": "^2.0.0", 2562 | "regexpp": "^3.1.0", 2563 | "semver": "^7.2.1", 2564 | "strip-ansi": "^6.0.0", 2565 | "strip-json-comments": "^3.1.0", 2566 | "table": "^6.0.9", 2567 | "text-table": "^0.2.0", 2568 | "v8-compile-cache": "^2.0.3" 2569 | } 2570 | }, 2571 | "eslint-config-blueimp": { 2572 | "version": "2.3.0", 2573 | "resolved": "https://registry.npmjs.org/eslint-config-blueimp/-/eslint-config-blueimp-2.3.0.tgz", 2574 | "integrity": "sha512-OC1+7YHBpXYdl/Jt2PZMpIPAUogHf4iDnqf8vVMlmkKls1Xemu7DAZqdFgdYhZxgaJ/d+qXH8b66L/D/pU4btA==", 2575 | "dev": true, 2576 | "requires": {} 2577 | }, 2578 | "eslint-config-prettier": { 2579 | "version": "8.3.0", 2580 | "resolved": "https://registry.npmjs.org/eslint-config-prettier/-/eslint-config-prettier-8.3.0.tgz", 2581 | "integrity": "sha512-BgZuLUSeKzvlL/VUjx/Yb787VQ26RU3gGjA3iiFvdsp/2bMfVIWUVP7tjxtjS0e+HP409cPlPvNkQloz8C91ew==", 2582 | "dev": true, 2583 | "requires": {} 2584 | }, 2585 | "eslint-plugin-jsdoc": { 2586 | "version": "36.1.0", 2587 | "resolved": "https://registry.npmjs.org/eslint-plugin-jsdoc/-/eslint-plugin-jsdoc-36.1.0.tgz", 2588 | "integrity": "sha512-Qpied2AJCQcScxfzTObLKRiP5QgLXjMU/ITjBagEV5p2Q/HpumD1EQtazdRYdjDSwPmXhwOl2yquwOGQ4HOJNw==", 2589 | "dev": true, 2590 | "requires": { 2591 | "@es-joy/jsdoccomment": "0.10.8", 2592 | "comment-parser": "1.2.4", 2593 | "debug": "^4.3.2", 2594 | "esquery": "^1.4.0", 2595 | "jsdoc-type-pratt-parser": "^1.1.1", 2596 | "lodash": "^4.17.21", 2597 | "regextras": "^0.8.0", 2598 | "semver": "^7.3.5", 2599 | "spdx-expression-parse": "^3.0.1" 2600 | } 2601 | }, 2602 | "eslint-plugin-prettier": { 2603 | "version": "4.0.0", 2604 | "resolved": "https://registry.npmjs.org/eslint-plugin-prettier/-/eslint-plugin-prettier-4.0.0.tgz", 2605 | "integrity": "sha512-98MqmCJ7vJodoQK359bqQWaxOE0CS8paAz/GgjaZLyex4TTk3g9HugoO89EqWCrFiOqn9EVvcoo7gZzONCWVwQ==", 2606 | "dev": true, 2607 | "requires": { 2608 | "prettier-linter-helpers": "^1.0.0" 2609 | } 2610 | }, 2611 | "eslint-scope": { 2612 | "version": "5.1.1", 2613 | "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-5.1.1.tgz", 2614 | "integrity": "sha512-2NxwbF/hZ0KpepYN0cNbo+FN6XoK7GaHlQhgx/hIZl6Va0bF45RQOOwhLIy8lQDbuCiadSLCBnH2CFYquit5bw==", 2615 | "dev": true, 2616 | "requires": { 2617 | "esrecurse": "^4.3.0", 2618 | "estraverse": "^4.1.1" 2619 | } 2620 | }, 2621 | "eslint-utils": { 2622 | "version": "2.1.0", 2623 | "resolved": "https://registry.npmjs.org/eslint-utils/-/eslint-utils-2.1.0.tgz", 2624 | "integrity": "sha512-w94dQYoauyvlDc43XnGB8lU3Zt713vNChgt4EWwhXAP2XkBvndfxF0AgIqKOOasjPIPzj9JqgwkwbCYD0/V3Zg==", 2625 | "dev": true, 2626 | "requires": { 2627 | "eslint-visitor-keys": "^1.1.0" 2628 | }, 2629 | "dependencies": { 2630 | "eslint-visitor-keys": { 2631 | "version": "1.3.0", 2632 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-1.3.0.tgz", 2633 | "integrity": "sha512-6J72N8UNa462wa/KFODt/PJ3IU60SDpC3QXC1Hjc1BXXpfL2C9R5+AU7jhe0F6GREqVMh4Juu+NY7xn+6dipUQ==", 2634 | "dev": true 2635 | } 2636 | } 2637 | }, 2638 | "eslint-visitor-keys": { 2639 | "version": "2.1.0", 2640 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-2.1.0.tgz", 2641 | "integrity": "sha512-0rSmRBzXgDzIsD6mGdJgevzgezI534Cer5L/vyMX0kHzT/jiB43jRhd9YUlMGYLQy2zprNmoT8qasCGtY+QaKw==", 2642 | "dev": true 2643 | }, 2644 | "espree": { 2645 | "version": "7.3.1", 2646 | "resolved": "https://registry.npmjs.org/espree/-/espree-7.3.1.tgz", 2647 | "integrity": "sha512-v3JCNCE64umkFpmkFGqzVKsOT0tN1Zr+ueqLZfpV1Ob8e+CEgPWa+OxCoGH3tnhimMKIaBm4m/vaRpJ/krRz2g==", 2648 | "dev": true, 2649 | "requires": { 2650 | "acorn": "^7.4.0", 2651 | "acorn-jsx": "^5.3.1", 2652 | "eslint-visitor-keys": "^1.3.0" 2653 | }, 2654 | "dependencies": { 2655 | "eslint-visitor-keys": { 2656 | "version": "1.3.0", 2657 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-1.3.0.tgz", 2658 | "integrity": "sha512-6J72N8UNa462wa/KFODt/PJ3IU60SDpC3QXC1Hjc1BXXpfL2C9R5+AU7jhe0F6GREqVMh4Juu+NY7xn+6dipUQ==", 2659 | "dev": true 2660 | } 2661 | } 2662 | }, 2663 | "esprima": { 2664 | "version": "4.0.1", 2665 | "resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.1.tgz", 2666 | "integrity": "sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A==", 2667 | "dev": true 2668 | }, 2669 | "esquery": { 2670 | "version": "1.4.0", 2671 | "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.4.0.tgz", 2672 | "integrity": "sha512-cCDispWt5vHHtwMY2YrAQ4ibFkAL8RbH5YGBnZBc90MolvvfkkQcJro/aZiAQUlQ3qgrYS6D6v8Gc5G5CQsc9w==", 2673 | "dev": true, 2674 | "requires": { 2675 | "estraverse": "^5.1.0" 2676 | }, 2677 | "dependencies": { 2678 | "estraverse": { 2679 | "version": "5.2.0", 2680 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.2.0.tgz", 2681 | "integrity": "sha512-BxbNGGNm0RyRYvUdHpIwv9IWzeM9XClbOxwoATuFdOE7ZE6wHL+HQ5T8hoPM+zHvmKzzsEqhgy0GrQ5X13afiQ==", 2682 | "dev": true 2683 | } 2684 | } 2685 | }, 2686 | "esrecurse": { 2687 | "version": "4.3.0", 2688 | "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.3.0.tgz", 2689 | "integrity": "sha512-KmfKL3b6G+RXvP8N1vr3Tq1kL/oCFgn2NYXEtqP8/L3pKapUA4G8cFVaoF3SU323CD4XypR/ffioHmkti6/Tag==", 2690 | "dev": true, 2691 | "requires": { 2692 | "estraverse": "^5.2.0" 2693 | }, 2694 | "dependencies": { 2695 | "estraverse": { 2696 | "version": "5.2.0", 2697 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.2.0.tgz", 2698 | "integrity": "sha512-BxbNGGNm0RyRYvUdHpIwv9IWzeM9XClbOxwoATuFdOE7ZE6wHL+HQ5T8hoPM+zHvmKzzsEqhgy0GrQ5X13afiQ==", 2699 | "dev": true 2700 | } 2701 | } 2702 | }, 2703 | "estraverse": { 2704 | "version": "4.3.0", 2705 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-4.3.0.tgz", 2706 | "integrity": "sha512-39nnKffWz8xN1BU/2c79n9nB9HDzo0niYUqx6xyqUnyoAnQyyWpOTdZEeiCch8BBu515t4wp9ZmgVfVhn9EBpw==", 2707 | "dev": true 2708 | }, 2709 | "esutils": { 2710 | "version": "2.0.3", 2711 | "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz", 2712 | "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==", 2713 | "dev": true 2714 | }, 2715 | "fast-deep-equal": { 2716 | "version": "3.1.3", 2717 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz", 2718 | "integrity": "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==", 2719 | "dev": true 2720 | }, 2721 | "fast-diff": { 2722 | "version": "1.2.0", 2723 | "resolved": "https://registry.npmjs.org/fast-diff/-/fast-diff-1.2.0.tgz", 2724 | "integrity": "sha512-xJuoT5+L99XlZ8twedaRf6Ax2TgQVxvgZOYoPKqZufmJib0tL2tegPBOZb1pVNgIhlqDlA0eO0c3wBvQcmzx4w==", 2725 | "dev": true 2726 | }, 2727 | "fast-json-stable-stringify": { 2728 | "version": "2.1.0", 2729 | "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz", 2730 | "integrity": "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==", 2731 | "dev": true 2732 | }, 2733 | "fast-levenshtein": { 2734 | "version": "2.0.6", 2735 | "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", 2736 | "integrity": "sha1-PYpcZog6FqMMqGQ+hR8Zuqd5eRc=", 2737 | "dev": true 2738 | }, 2739 | "file-entry-cache": { 2740 | "version": "6.0.1", 2741 | "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-6.0.1.tgz", 2742 | "integrity": "sha512-7Gps/XWymbLk2QLYK4NzpMOrYjMhdIxXuIvy2QBsLE6ljuodKvdkWs/cpyJJ3CVIVpH0Oi1Hvg1ovbMzLdFBBg==", 2743 | "dev": true, 2744 | "requires": { 2745 | "flat-cache": "^3.0.4" 2746 | } 2747 | }, 2748 | "fill-range": { 2749 | "version": "7.0.1", 2750 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", 2751 | "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", 2752 | "dev": true, 2753 | "requires": { 2754 | "to-regex-range": "^5.0.1" 2755 | } 2756 | }, 2757 | "find-up": { 2758 | "version": "5.0.0", 2759 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-5.0.0.tgz", 2760 | "integrity": "sha512-78/PXT1wlLLDgTzDs7sjq9hzz0vXD+zn+7wypEe4fXQxCmdmqfGsEPQxmiCSQI3ajFV91bVSsvNtrJRiW6nGng==", 2761 | "dev": true, 2762 | "requires": { 2763 | "locate-path": "^6.0.0", 2764 | "path-exists": "^4.0.0" 2765 | } 2766 | }, 2767 | "flat": { 2768 | "version": "5.0.2", 2769 | "resolved": "https://registry.npmjs.org/flat/-/flat-5.0.2.tgz", 2770 | "integrity": "sha512-b6suED+5/3rTpUBdG1gupIl8MPFCAMA0QXwmljLhvCUKcUvdE4gWky9zpuGCcXHOsz4J9wPGNWq6OKpmIzz3hQ==", 2771 | "dev": true 2772 | }, 2773 | "flat-cache": { 2774 | "version": "3.0.4", 2775 | "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-3.0.4.tgz", 2776 | "integrity": "sha512-dm9s5Pw7Jc0GvMYbshN6zchCA9RgQlzzEZX3vylR9IqFfS8XciblUXOKfW6SiuJ0e13eDYZoZV5wdrev7P3Nwg==", 2777 | "dev": true, 2778 | "requires": { 2779 | "flatted": "^3.1.0", 2780 | "rimraf": "^3.0.2" 2781 | } 2782 | }, 2783 | "flatted": { 2784 | "version": "3.2.2", 2785 | "resolved": "https://registry.npmjs.org/flatted/-/flatted-3.2.2.tgz", 2786 | "integrity": "sha512-JaTY/wtrcSyvXJl4IMFHPKyFur1sE9AUqc0QnhOaJ0CxHtAoIV8pYDzeEfAaNEtGkOfq4gr3LBFmdXW5mOQFnA==", 2787 | "dev": true 2788 | }, 2789 | "fs.realpath": { 2790 | "version": "1.0.0", 2791 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 2792 | "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=", 2793 | "dev": true 2794 | }, 2795 | "fsevents": { 2796 | "version": "2.3.2", 2797 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.2.tgz", 2798 | "integrity": "sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA==", 2799 | "dev": true, 2800 | "optional": true 2801 | }, 2802 | "functional-red-black-tree": { 2803 | "version": "1.0.1", 2804 | "resolved": "https://registry.npmjs.org/functional-red-black-tree/-/functional-red-black-tree-1.0.1.tgz", 2805 | "integrity": "sha1-GwqzvVU7Kg1jmdKcDj6gslIHgyc=", 2806 | "dev": true 2807 | }, 2808 | "get-caller-file": { 2809 | "version": "2.0.5", 2810 | "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-2.0.5.tgz", 2811 | "integrity": "sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg==", 2812 | "dev": true 2813 | }, 2814 | "get-func-name": { 2815 | "version": "2.0.0", 2816 | "resolved": "https://registry.npmjs.org/get-func-name/-/get-func-name-2.0.0.tgz", 2817 | "integrity": "sha1-6td0q+5y4gQJQzoGY2YCPdaIekE=", 2818 | "dev": true 2819 | }, 2820 | "glob": { 2821 | "version": "7.1.7", 2822 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.7.tgz", 2823 | "integrity": "sha512-OvD9ENzPLbegENnYP5UUfJIirTg4+XwMWGaQfQTY0JenxNvvIKP3U3/tAQSPIu/lHxXYSZmpXlUHeqAIdKzBLQ==", 2824 | "dev": true, 2825 | "requires": { 2826 | "fs.realpath": "^1.0.0", 2827 | "inflight": "^1.0.4", 2828 | "inherits": "2", 2829 | "minimatch": "^3.0.4", 2830 | "once": "^1.3.0", 2831 | "path-is-absolute": "^1.0.0" 2832 | } 2833 | }, 2834 | "glob-parent": { 2835 | "version": "5.1.2", 2836 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", 2837 | "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", 2838 | "dev": true, 2839 | "requires": { 2840 | "is-glob": "^4.0.1" 2841 | } 2842 | }, 2843 | "globals": { 2844 | "version": "13.11.0", 2845 | "resolved": "https://registry.npmjs.org/globals/-/globals-13.11.0.tgz", 2846 | "integrity": "sha512-08/xrJ7wQjK9kkkRoI3OFUBbLx4f+6x3SGwcPvQ0QH6goFDrOU2oyAWrmh3dJezu65buo+HBMzAMQy6rovVC3g==", 2847 | "dev": true, 2848 | "requires": { 2849 | "type-fest": "^0.20.2" 2850 | } 2851 | }, 2852 | "growl": { 2853 | "version": "1.10.5", 2854 | "resolved": "https://registry.npmjs.org/growl/-/growl-1.10.5.tgz", 2855 | "integrity": "sha512-qBr4OuELkhPenW6goKVXiv47US3clb3/IbuWF9KNKEijAy9oeHxU9IgzjvJhHkUzhaj7rOUD7+YGWqUjLp5oSA==", 2856 | "dev": true 2857 | }, 2858 | "has-flag": { 2859 | "version": "4.0.0", 2860 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 2861 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", 2862 | "dev": true 2863 | }, 2864 | "he": { 2865 | "version": "1.2.0", 2866 | "resolved": "https://registry.npmjs.org/he/-/he-1.2.0.tgz", 2867 | "integrity": "sha512-F/1DnUGPopORZi0ni+CvrCgHQ5FyEAHRLSApuYWMmrbSwoN2Mn/7k+Gl38gJnR7yyDZk6WLXwiGod1JOWNDKGw==", 2868 | "dev": true 2869 | }, 2870 | "ignore": { 2871 | "version": "4.0.6", 2872 | "resolved": "https://registry.npmjs.org/ignore/-/ignore-4.0.6.tgz", 2873 | "integrity": "sha512-cyFDKrqc/YdcWFniJhzI42+AzS+gNwmUzOSFcRCQYwySuBBBy/KjuxWLZ/FHEH6Moq1NizMOBWyTcv8O4OZIMg==", 2874 | "dev": true 2875 | }, 2876 | "import-fresh": { 2877 | "version": "3.3.0", 2878 | "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.3.0.tgz", 2879 | "integrity": "sha512-veYYhQa+D1QBKznvhUHxb8faxlrwUnxseDAbAp457E0wLNio2bOSKnjYDhMj+YiAq61xrMGhQk9iXVk5FzgQMw==", 2880 | "dev": true, 2881 | "requires": { 2882 | "parent-module": "^1.0.0", 2883 | "resolve-from": "^4.0.0" 2884 | } 2885 | }, 2886 | "imurmurhash": { 2887 | "version": "0.1.4", 2888 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", 2889 | "integrity": "sha1-khi5srkoojixPcT7a21XbyMUU+o=", 2890 | "dev": true 2891 | }, 2892 | "inflight": { 2893 | "version": "1.0.6", 2894 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 2895 | "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", 2896 | "dev": true, 2897 | "requires": { 2898 | "once": "^1.3.0", 2899 | "wrappy": "1" 2900 | } 2901 | }, 2902 | "inherits": { 2903 | "version": "2.0.4", 2904 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 2905 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", 2906 | "dev": true 2907 | }, 2908 | "is-binary-path": { 2909 | "version": "2.1.0", 2910 | "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz", 2911 | "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==", 2912 | "dev": true, 2913 | "requires": { 2914 | "binary-extensions": "^2.0.0" 2915 | } 2916 | }, 2917 | "is-extglob": { 2918 | "version": "2.1.1", 2919 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 2920 | "integrity": "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=", 2921 | "dev": true 2922 | }, 2923 | "is-fullwidth-code-point": { 2924 | "version": "3.0.0", 2925 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 2926 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", 2927 | "dev": true 2928 | }, 2929 | "is-glob": { 2930 | "version": "4.0.1", 2931 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.1.tgz", 2932 | "integrity": "sha512-5G0tKtBTFImOqDnLB2hG6Bp2qcKEFduo4tZu9MT/H6NQv/ghhy30o55ufafxJ/LdH79LLs2Kfrn85TLKyA7BUg==", 2933 | "dev": true, 2934 | "requires": { 2935 | "is-extglob": "^2.1.1" 2936 | } 2937 | }, 2938 | "is-number": { 2939 | "version": "7.0.0", 2940 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", 2941 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", 2942 | "dev": true 2943 | }, 2944 | "is-plain-obj": { 2945 | "version": "2.1.0", 2946 | "resolved": "https://registry.npmjs.org/is-plain-obj/-/is-plain-obj-2.1.0.tgz", 2947 | "integrity": "sha512-YWnfyRwxL/+SsrWYfOpUtz5b3YD+nyfkHvjbcanzk8zgyO4ASD67uVMRt8k5bM4lLMDnXfriRhOpemw+NfT1eA==", 2948 | "dev": true 2949 | }, 2950 | "is-unicode-supported": { 2951 | "version": "0.1.0", 2952 | "resolved": "https://registry.npmjs.org/is-unicode-supported/-/is-unicode-supported-0.1.0.tgz", 2953 | "integrity": "sha512-knxG2q4UC3u8stRGyAVJCOdxFmv5DZiRcdlIaAQXAbSfJya+OhopNotLQrstBhququ4ZpuKbDc/8S6mgXgPFPw==", 2954 | "dev": true 2955 | }, 2956 | "isexe": { 2957 | "version": "2.0.0", 2958 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 2959 | "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=", 2960 | "dev": true 2961 | }, 2962 | "js-tokens": { 2963 | "version": "4.0.0", 2964 | "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", 2965 | "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==", 2966 | "dev": true 2967 | }, 2968 | "js-yaml": { 2969 | "version": "3.14.1", 2970 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.14.1.tgz", 2971 | "integrity": "sha512-okMH7OXXJ7YrN9Ok3/SXrnu4iX9yOk+25nqX4imS2npuvTYDmo/QEZoqwZkYaIDk3jVvBOTOIEgEhaLOynBS9g==", 2972 | "dev": true, 2973 | "requires": { 2974 | "argparse": "^1.0.7", 2975 | "esprima": "^4.0.0" 2976 | } 2977 | }, 2978 | "jsdoc-type-pratt-parser": { 2979 | "version": "1.1.1", 2980 | "resolved": "https://registry.npmjs.org/jsdoc-type-pratt-parser/-/jsdoc-type-pratt-parser-1.1.1.tgz", 2981 | "integrity": "sha512-uelRmpghNwPBuZScwgBG/OzodaFk5RbO5xaivBdsAY70icWfShwZ7PCMO0x1zSkOa8T1FzHThmrdoyg/0AwV5g==", 2982 | "dev": true 2983 | }, 2984 | "json-schema-traverse": { 2985 | "version": "0.4.1", 2986 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", 2987 | "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==", 2988 | "dev": true 2989 | }, 2990 | "json-stable-stringify-without-jsonify": { 2991 | "version": "1.0.1", 2992 | "resolved": "https://registry.npmjs.org/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz", 2993 | "integrity": "sha1-nbe1lJatPzz+8wp1FC0tkwrXJlE=", 2994 | "dev": true 2995 | }, 2996 | "levn": { 2997 | "version": "0.4.1", 2998 | "resolved": "https://registry.npmjs.org/levn/-/levn-0.4.1.tgz", 2999 | "integrity": "sha512-+bT2uH4E5LGE7h/n3evcS/sQlJXCpIp6ym8OWJ5eV6+67Dsql/LaaT7qJBAt2rzfoa/5QBGBhxDix1dMt2kQKQ==", 3000 | "dev": true, 3001 | "requires": { 3002 | "prelude-ls": "^1.2.1", 3003 | "type-check": "~0.4.0" 3004 | } 3005 | }, 3006 | "locate-path": { 3007 | "version": "6.0.0", 3008 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-6.0.0.tgz", 3009 | "integrity": "sha512-iPZK6eYjbxRu3uB4/WZ3EsEIMJFMqAoopl3R+zuq0UjcAm/MO6KCweDgPfP3elTztoKP3KtnVHxTn2NHBSDVUw==", 3010 | "dev": true, 3011 | "requires": { 3012 | "p-locate": "^5.0.0" 3013 | } 3014 | }, 3015 | "lodash": { 3016 | "version": "4.17.21", 3017 | "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.21.tgz", 3018 | "integrity": "sha512-v2kDEe57lecTulaDIuNTPy3Ry4gLGJ6Z1O3vE1krgXZNrsQ+LFTGHVxVjcXPs17LhbZVGedAJv8XZ1tvj5FvSg==", 3019 | "dev": true 3020 | }, 3021 | "lodash.clonedeep": { 3022 | "version": "4.5.0", 3023 | "resolved": "https://registry.npmjs.org/lodash.clonedeep/-/lodash.clonedeep-4.5.0.tgz", 3024 | "integrity": "sha1-4j8/nE+Pvd6HJSnBBxhXoIblzO8=", 3025 | "dev": true 3026 | }, 3027 | "lodash.merge": { 3028 | "version": "4.6.2", 3029 | "resolved": "https://registry.npmjs.org/lodash.merge/-/lodash.merge-4.6.2.tgz", 3030 | "integrity": "sha512-0KpjqXRVvrYyCsX1swR/XTK0va6VQkQM6MNo7PqW77ByjAhoARA8EfrP1N4+KlKj8YS0ZUCtRT/YUuhyYDujIQ==", 3031 | "dev": true 3032 | }, 3033 | "lodash.truncate": { 3034 | "version": "4.4.2", 3035 | "resolved": "https://registry.npmjs.org/lodash.truncate/-/lodash.truncate-4.4.2.tgz", 3036 | "integrity": "sha1-WjUNoLERO4N+z//VgSy+WNbq4ZM=", 3037 | "dev": true 3038 | }, 3039 | "log-symbols": { 3040 | "version": "4.1.0", 3041 | "resolved": "https://registry.npmjs.org/log-symbols/-/log-symbols-4.1.0.tgz", 3042 | "integrity": "sha512-8XPvpAA8uyhfteu8pIvQxpJZ7SYYdpUivZpGy6sFsBuKRY/7rQGavedeB8aK+Zkyq6upMFVL/9AW6vOYzfRyLg==", 3043 | "dev": true, 3044 | "requires": { 3045 | "chalk": "^4.1.0", 3046 | "is-unicode-supported": "^0.1.0" 3047 | } 3048 | }, 3049 | "lru-cache": { 3050 | "version": "6.0.0", 3051 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", 3052 | "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", 3053 | "dev": true, 3054 | "requires": { 3055 | "yallist": "^4.0.0" 3056 | } 3057 | }, 3058 | "minimatch": { 3059 | "version": "3.0.4", 3060 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", 3061 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", 3062 | "dev": true, 3063 | "requires": { 3064 | "brace-expansion": "^1.1.7" 3065 | } 3066 | }, 3067 | "mocha": { 3068 | "version": "9.1.2", 3069 | "resolved": "https://registry.npmjs.org/mocha/-/mocha-9.1.2.tgz", 3070 | "integrity": "sha512-ta3LtJ+63RIBP03VBjMGtSqbe6cWXRejF9SyM9Zyli1CKZJZ+vfCTj3oW24V7wAphMJdpOFLoMI3hjJ1LWbs0w==", 3071 | "dev": true, 3072 | "requires": { 3073 | "@ungap/promise-all-settled": "1.1.2", 3074 | "ansi-colors": "4.1.1", 3075 | "browser-stdout": "1.3.1", 3076 | "chokidar": "3.5.2", 3077 | "debug": "4.3.2", 3078 | "diff": "5.0.0", 3079 | "escape-string-regexp": "4.0.0", 3080 | "find-up": "5.0.0", 3081 | "glob": "7.1.7", 3082 | "growl": "1.10.5", 3083 | "he": "1.2.0", 3084 | "js-yaml": "4.1.0", 3085 | "log-symbols": "4.1.0", 3086 | "minimatch": "3.0.4", 3087 | "ms": "2.1.3", 3088 | "nanoid": "3.1.25", 3089 | "serialize-javascript": "6.0.0", 3090 | "strip-json-comments": "3.1.1", 3091 | "supports-color": "8.1.1", 3092 | "which": "2.0.2", 3093 | "workerpool": "6.1.5", 3094 | "yargs": "16.2.0", 3095 | "yargs-parser": "20.2.4", 3096 | "yargs-unparser": "2.0.0" 3097 | }, 3098 | "dependencies": { 3099 | "argparse": { 3100 | "version": "2.0.1", 3101 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-2.0.1.tgz", 3102 | "integrity": "sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==", 3103 | "dev": true 3104 | }, 3105 | "js-yaml": { 3106 | "version": "4.1.0", 3107 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-4.1.0.tgz", 3108 | "integrity": "sha512-wpxZs9NoxZaJESJGIZTyDEaYpl0FKSA+FB9aJiyemKhMwkxQg63h4T1KJgUGHpTqPDNRcmmYLugrRjJlBtWvRA==", 3109 | "dev": true, 3110 | "requires": { 3111 | "argparse": "^2.0.1" 3112 | } 3113 | }, 3114 | "ms": { 3115 | "version": "2.1.3", 3116 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", 3117 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==", 3118 | "dev": true 3119 | }, 3120 | "supports-color": { 3121 | "version": "8.1.1", 3122 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-8.1.1.tgz", 3123 | "integrity": "sha512-MpUEN2OodtUzxvKQl72cUF7RQ5EiHsGvSsVG0ia9c5RbWGL2CI4C7EpPS8UTBIplnlzZiNuV56w+FuNxy3ty2Q==", 3124 | "dev": true, 3125 | "requires": { 3126 | "has-flag": "^4.0.0" 3127 | } 3128 | } 3129 | } 3130 | }, 3131 | "ms": { 3132 | "version": "2.1.2", 3133 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 3134 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 3135 | "dev": true 3136 | }, 3137 | "nanoid": { 3138 | "version": "3.1.25", 3139 | "resolved": "https://registry.npmjs.org/nanoid/-/nanoid-3.1.25.tgz", 3140 | "integrity": "sha512-rdwtIXaXCLFAQbnfqDRnI6jaRHp9fTcYBjtFKE8eezcZ7LuLjhUaQGNeMXf1HmRoCH32CLz6XwX0TtxEOS/A3Q==", 3141 | "dev": true 3142 | }, 3143 | "natural-compare": { 3144 | "version": "1.4.0", 3145 | "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", 3146 | "integrity": "sha1-Sr6/7tdUHywnrPspvbvRXI1bpPc=", 3147 | "dev": true 3148 | }, 3149 | "normalize-path": { 3150 | "version": "3.0.0", 3151 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", 3152 | "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==", 3153 | "dev": true 3154 | }, 3155 | "once": { 3156 | "version": "1.4.0", 3157 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 3158 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", 3159 | "dev": true, 3160 | "requires": { 3161 | "wrappy": "1" 3162 | } 3163 | }, 3164 | "optionator": { 3165 | "version": "0.9.1", 3166 | "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.9.1.tgz", 3167 | "integrity": "sha512-74RlY5FCnhq4jRxVUPKDaRwrVNXMqsGsiW6AJw4XK8hmtm10wC0ypZBLw5IIp85NZMr91+qd1RvvENwg7jjRFw==", 3168 | "dev": true, 3169 | "requires": { 3170 | "deep-is": "^0.1.3", 3171 | "fast-levenshtein": "^2.0.6", 3172 | "levn": "^0.4.1", 3173 | "prelude-ls": "^1.2.1", 3174 | "type-check": "^0.4.0", 3175 | "word-wrap": "^1.2.3" 3176 | } 3177 | }, 3178 | "p-limit": { 3179 | "version": "3.1.0", 3180 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-3.1.0.tgz", 3181 | "integrity": "sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ==", 3182 | "dev": true, 3183 | "requires": { 3184 | "yocto-queue": "^0.1.0" 3185 | } 3186 | }, 3187 | "p-locate": { 3188 | "version": "5.0.0", 3189 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-5.0.0.tgz", 3190 | "integrity": "sha512-LaNjtRWUBY++zB5nE/NwcaoMylSPk+S+ZHNB1TzdbMJMny6dynpAGt7X/tl/QYq3TIeE6nxHppbo2LGymrG5Pw==", 3191 | "dev": true, 3192 | "requires": { 3193 | "p-limit": "^3.0.2" 3194 | } 3195 | }, 3196 | "parent-module": { 3197 | "version": "1.0.1", 3198 | "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz", 3199 | "integrity": "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==", 3200 | "dev": true, 3201 | "requires": { 3202 | "callsites": "^3.0.0" 3203 | } 3204 | }, 3205 | "path-exists": { 3206 | "version": "4.0.0", 3207 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz", 3208 | "integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==", 3209 | "dev": true 3210 | }, 3211 | "path-is-absolute": { 3212 | "version": "1.0.1", 3213 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 3214 | "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=", 3215 | "dev": true 3216 | }, 3217 | "path-key": { 3218 | "version": "3.1.1", 3219 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", 3220 | "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", 3221 | "dev": true 3222 | }, 3223 | "pathval": { 3224 | "version": "1.1.1", 3225 | "resolved": "https://registry.npmjs.org/pathval/-/pathval-1.1.1.tgz", 3226 | "integrity": "sha512-Dp6zGqpTdETdR63lehJYPeIOqpiNBNtc7BpWSLrOje7UaIsE5aY92r/AunQA7rsXvet3lrJ3JnZX29UPTKXyKQ==", 3227 | "dev": true 3228 | }, 3229 | "picomatch": { 3230 | "version": "2.3.0", 3231 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.0.tgz", 3232 | "integrity": "sha512-lY1Q/PiJGC2zOv/z391WOTD+Z02bCgsFfvxoXXf6h7kv9o+WmsmzYqrAwY63sNgOxE4xEdq0WyUnXfKeBrSvYw==", 3233 | "dev": true 3234 | }, 3235 | "prelude-ls": { 3236 | "version": "1.2.1", 3237 | "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.2.1.tgz", 3238 | "integrity": "sha512-vkcDPrRZo1QZLbn5RLGPpg/WmIQ65qoWWhcGKf/b5eplkkarX0m9z8ppCat4mlOqUsWpyNuYgO3VRyrYHSzX5g==", 3239 | "dev": true 3240 | }, 3241 | "prettier": { 3242 | "version": "2.4.1", 3243 | "resolved": "https://registry.npmjs.org/prettier/-/prettier-2.4.1.tgz", 3244 | "integrity": "sha512-9fbDAXSBcc6Bs1mZrDYb3XKzDLm4EXXL9sC1LqKP5rZkT6KRr/rf9amVUcODVXgguK/isJz0d0hP72WeaKWsvA==", 3245 | "dev": true 3246 | }, 3247 | "prettier-linter-helpers": { 3248 | "version": "1.0.0", 3249 | "resolved": "https://registry.npmjs.org/prettier-linter-helpers/-/prettier-linter-helpers-1.0.0.tgz", 3250 | "integrity": "sha512-GbK2cP9nraSSUF9N2XwUwqfzlAFlMNYYl+ShE/V+H8a9uNl/oUqB1w2EL54Jh0OlyRSd8RfWYJ3coVS4TROP2w==", 3251 | "dev": true, 3252 | "requires": { 3253 | "fast-diff": "^1.1.2" 3254 | } 3255 | }, 3256 | "progress": { 3257 | "version": "2.0.3", 3258 | "resolved": "https://registry.npmjs.org/progress/-/progress-2.0.3.tgz", 3259 | "integrity": "sha512-7PiHtLll5LdnKIMw100I+8xJXR5gW2QwWYkT6iJva0bXitZKa/XMrSbdmg3r2Xnaidz9Qumd0VPaMrZlF9V9sA==", 3260 | "dev": true 3261 | }, 3262 | "punycode": { 3263 | "version": "2.1.1", 3264 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.1.1.tgz", 3265 | "integrity": "sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A==", 3266 | "dev": true 3267 | }, 3268 | "randombytes": { 3269 | "version": "2.1.0", 3270 | "resolved": "https://registry.npmjs.org/randombytes/-/randombytes-2.1.0.tgz", 3271 | "integrity": "sha512-vYl3iOX+4CKUWuxGi9Ukhie6fsqXqS9FE2Zaic4tNFD2N2QQaXOMFbuKK4QmDHC0JO6B1Zp41J0LpT0oR68amQ==", 3272 | "dev": true, 3273 | "requires": { 3274 | "safe-buffer": "^5.1.0" 3275 | } 3276 | }, 3277 | "readdirp": { 3278 | "version": "3.6.0", 3279 | "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.6.0.tgz", 3280 | "integrity": "sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==", 3281 | "dev": true, 3282 | "requires": { 3283 | "picomatch": "^2.2.1" 3284 | } 3285 | }, 3286 | "regexpp": { 3287 | "version": "3.2.0", 3288 | "resolved": "https://registry.npmjs.org/regexpp/-/regexpp-3.2.0.tgz", 3289 | "integrity": "sha512-pq2bWo9mVD43nbts2wGv17XLiNLya+GklZ8kaDLV2Z08gDCsGpnKn9BFMepvWuHCbyVvY7J5o5+BVvoQbmlJLg==", 3290 | "dev": true 3291 | }, 3292 | "regextras": { 3293 | "version": "0.8.0", 3294 | "resolved": "https://registry.npmjs.org/regextras/-/regextras-0.8.0.tgz", 3295 | "integrity": "sha512-k519uI04Z3SaY0fLX843MRXnDeG2+vHOFsyhiPZvNLe7r8rD2YNRjq4BQLZZ0oAr2NrtvZlICsXysGNFPGa3CQ==", 3296 | "dev": true 3297 | }, 3298 | "require-directory": { 3299 | "version": "2.1.1", 3300 | "resolved": "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz", 3301 | "integrity": "sha1-jGStX9MNqxyXbiNE/+f3kqam30I=", 3302 | "dev": true 3303 | }, 3304 | "require-from-string": { 3305 | "version": "2.0.2", 3306 | "resolved": "https://registry.npmjs.org/require-from-string/-/require-from-string-2.0.2.tgz", 3307 | "integrity": "sha512-Xf0nWe6RseziFMu+Ap9biiUbmplq6S9/p+7w7YXP/JBHhrUDDUhwa+vANyubuqfZWTveU//DYVGsDG7RKL/vEw==", 3308 | "dev": true 3309 | }, 3310 | "resolve-from": { 3311 | "version": "4.0.0", 3312 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz", 3313 | "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==", 3314 | "dev": true 3315 | }, 3316 | "rimraf": { 3317 | "version": "3.0.2", 3318 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-3.0.2.tgz", 3319 | "integrity": "sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA==", 3320 | "dev": true, 3321 | "requires": { 3322 | "glob": "^7.1.3" 3323 | } 3324 | }, 3325 | "safe-buffer": { 3326 | "version": "5.2.1", 3327 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz", 3328 | "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==", 3329 | "dev": true 3330 | }, 3331 | "semver": { 3332 | "version": "7.3.5", 3333 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.3.5.tgz", 3334 | "integrity": "sha512-PoeGJYh8HK4BTO/a9Tf6ZG3veo/A7ZVsYrSA6J8ny9nb3B1VrpkuN+z9OE5wfE5p6H4LchYZsegiQgbJD94ZFQ==", 3335 | "dev": true, 3336 | "requires": { 3337 | "lru-cache": "^6.0.0" 3338 | } 3339 | }, 3340 | "serialize-javascript": { 3341 | "version": "6.0.0", 3342 | "resolved": "https://registry.npmjs.org/serialize-javascript/-/serialize-javascript-6.0.0.tgz", 3343 | "integrity": "sha512-Qr3TosvguFt8ePWqsvRfrKyQXIiW+nGbYpy8XK24NQHE83caxWt+mIymTT19DGFbNWNLfEwsrkSmN64lVWB9ag==", 3344 | "dev": true, 3345 | "requires": { 3346 | "randombytes": "^2.1.0" 3347 | } 3348 | }, 3349 | "shebang-command": { 3350 | "version": "2.0.0", 3351 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", 3352 | "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", 3353 | "dev": true, 3354 | "requires": { 3355 | "shebang-regex": "^3.0.0" 3356 | } 3357 | }, 3358 | "shebang-regex": { 3359 | "version": "3.0.0", 3360 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", 3361 | "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", 3362 | "dev": true 3363 | }, 3364 | "slice-ansi": { 3365 | "version": "4.0.0", 3366 | "resolved": "https://registry.npmjs.org/slice-ansi/-/slice-ansi-4.0.0.tgz", 3367 | "integrity": "sha512-qMCMfhY040cVHT43K9BFygqYbUPFZKHOg7K73mtTWJRb8pyP3fzf4Ixd5SzdEJQ6MRUg/WBnOLxghZtKKurENQ==", 3368 | "dev": true, 3369 | "requires": { 3370 | "ansi-styles": "^4.0.0", 3371 | "astral-regex": "^2.0.0", 3372 | "is-fullwidth-code-point": "^3.0.0" 3373 | } 3374 | }, 3375 | "spdx-exceptions": { 3376 | "version": "2.3.0", 3377 | "resolved": "https://registry.npmjs.org/spdx-exceptions/-/spdx-exceptions-2.3.0.tgz", 3378 | "integrity": "sha512-/tTrYOC7PPI1nUAgx34hUpqXuyJG+DTHJTnIULG4rDygi4xu/tfgmq1e1cIRwRzwZgo4NLySi+ricLkZkw4i5A==", 3379 | "dev": true 3380 | }, 3381 | "spdx-expression-parse": { 3382 | "version": "3.0.1", 3383 | "resolved": "https://registry.npmjs.org/spdx-expression-parse/-/spdx-expression-parse-3.0.1.tgz", 3384 | "integrity": "sha512-cbqHunsQWnJNE6KhVSMsMeH5H/L9EpymbzqTQ3uLwNCLZ1Q481oWaofqH7nO6V07xlXwY6PhQdQ2IedWx/ZK4Q==", 3385 | "dev": true, 3386 | "requires": { 3387 | "spdx-exceptions": "^2.1.0", 3388 | "spdx-license-ids": "^3.0.0" 3389 | } 3390 | }, 3391 | "spdx-license-ids": { 3392 | "version": "3.0.10", 3393 | "resolved": "https://registry.npmjs.org/spdx-license-ids/-/spdx-license-ids-3.0.10.tgz", 3394 | "integrity": "sha512-oie3/+gKf7QtpitB0LYLETe+k8SifzsX4KixvpOsbI6S0kRiRQ5MKOio8eMSAKQ17N06+wdEOXRiId+zOxo0hA==", 3395 | "dev": true 3396 | }, 3397 | "sprintf-js": { 3398 | "version": "1.0.3", 3399 | "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.0.3.tgz", 3400 | "integrity": "sha1-BOaSb2YolTVPPdAVIDYzuFcpfiw=", 3401 | "dev": true 3402 | }, 3403 | "string-width": { 3404 | "version": "4.2.3", 3405 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", 3406 | "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", 3407 | "dev": true, 3408 | "requires": { 3409 | "emoji-regex": "^8.0.0", 3410 | "is-fullwidth-code-point": "^3.0.0", 3411 | "strip-ansi": "^6.0.1" 3412 | } 3413 | }, 3414 | "strip-ansi": { 3415 | "version": "6.0.1", 3416 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", 3417 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", 3418 | "dev": true, 3419 | "requires": { 3420 | "ansi-regex": "^5.0.1" 3421 | } 3422 | }, 3423 | "strip-json-comments": { 3424 | "version": "3.1.1", 3425 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz", 3426 | "integrity": "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==", 3427 | "dev": true 3428 | }, 3429 | "supports-color": { 3430 | "version": "7.2.0", 3431 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", 3432 | "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", 3433 | "dev": true, 3434 | "requires": { 3435 | "has-flag": "^4.0.0" 3436 | } 3437 | }, 3438 | "table": { 3439 | "version": "6.7.1", 3440 | "resolved": "https://registry.npmjs.org/table/-/table-6.7.1.tgz", 3441 | "integrity": "sha512-ZGum47Yi6KOOFDE8m223td53ath2enHcYLgOCjGr5ngu8bdIARQk6mN/wRMv4yMRcHnCSnHbCEha4sobQx5yWg==", 3442 | "dev": true, 3443 | "requires": { 3444 | "ajv": "^8.0.1", 3445 | "lodash.clonedeep": "^4.5.0", 3446 | "lodash.truncate": "^4.4.2", 3447 | "slice-ansi": "^4.0.0", 3448 | "string-width": "^4.2.0", 3449 | "strip-ansi": "^6.0.0" 3450 | }, 3451 | "dependencies": { 3452 | "ajv": { 3453 | "version": "8.6.3", 3454 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-8.6.3.tgz", 3455 | "integrity": "sha512-SMJOdDP6LqTkD0Uq8qLi+gMwSt0imXLSV080qFVwJCpH9U6Mb+SUGHAXM0KNbcBPguytWyvFxcHgMLe2D2XSpw==", 3456 | "dev": true, 3457 | "requires": { 3458 | "fast-deep-equal": "^3.1.1", 3459 | "json-schema-traverse": "^1.0.0", 3460 | "require-from-string": "^2.0.2", 3461 | "uri-js": "^4.2.2" 3462 | } 3463 | }, 3464 | "json-schema-traverse": { 3465 | "version": "1.0.0", 3466 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-1.0.0.tgz", 3467 | "integrity": "sha512-NM8/P9n3XjXhIZn1lLhkFaACTOURQXjWhV4BA/RnOv8xvgqtqpAX9IO4mRQxSx1Rlo4tqzeqb0sOlruaOy3dug==", 3468 | "dev": true 3469 | } 3470 | } 3471 | }, 3472 | "text-table": { 3473 | "version": "0.2.0", 3474 | "resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz", 3475 | "integrity": "sha1-f17oI66AUgfACvLfSoTsP8+lcLQ=", 3476 | "dev": true 3477 | }, 3478 | "to-regex-range": { 3479 | "version": "5.0.1", 3480 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", 3481 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", 3482 | "dev": true, 3483 | "requires": { 3484 | "is-number": "^7.0.0" 3485 | } 3486 | }, 3487 | "type-check": { 3488 | "version": "0.4.0", 3489 | "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.4.0.tgz", 3490 | "integrity": "sha512-XleUoc9uwGXqjWwXaUTZAmzMcFZ5858QA2vvx1Ur5xIcixXIP+8LnFDgRplU30us6teqdlskFfu+ae4K79Ooew==", 3491 | "dev": true, 3492 | "requires": { 3493 | "prelude-ls": "^1.2.1" 3494 | } 3495 | }, 3496 | "type-detect": { 3497 | "version": "4.0.8", 3498 | "resolved": "https://registry.npmjs.org/type-detect/-/type-detect-4.0.8.tgz", 3499 | "integrity": "sha512-0fr/mIH1dlO+x7TlcMy+bIDqKPsw/70tVyeHW787goQjhmqaZe10uwLujubK9q9Lg6Fiho1KUKDYz0Z7k7g5/g==", 3500 | "dev": true 3501 | }, 3502 | "type-fest": { 3503 | "version": "0.20.2", 3504 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.20.2.tgz", 3505 | "integrity": "sha512-Ne+eE4r0/iWnpAxD852z3A+N0Bt5RN//NjJwRd2VFHEmrywxf5vsZlh4R6lixl6B+wz/8d+maTSAkN1FIkI3LQ==", 3506 | "dev": true 3507 | }, 3508 | "uglify-js": { 3509 | "version": "3.14.2", 3510 | "resolved": "https://registry.npmjs.org/uglify-js/-/uglify-js-3.14.2.tgz", 3511 | "integrity": "sha512-rtPMlmcO4agTUfz10CbgJ1k6UAoXM2gWb3GoMPPZB/+/Ackf8lNWk11K4rYi2D0apgoFRLtQOZhb+/iGNJq26A==", 3512 | "dev": true 3513 | }, 3514 | "uri-js": { 3515 | "version": "4.4.1", 3516 | "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.4.1.tgz", 3517 | "integrity": "sha512-7rKUyy33Q1yc98pQ1DAmLtwX109F7TIfWlW1Ydo8Wl1ii1SeHieeh0HHfPeL2fMXK6z0s8ecKs9frCuLJvndBg==", 3518 | "dev": true, 3519 | "requires": { 3520 | "punycode": "^2.1.0" 3521 | } 3522 | }, 3523 | "v8-compile-cache": { 3524 | "version": "2.3.0", 3525 | "resolved": "https://registry.npmjs.org/v8-compile-cache/-/v8-compile-cache-2.3.0.tgz", 3526 | "integrity": "sha512-l8lCEmLcLYZh4nbunNZvQCJc5pv7+RCwa8q/LdUx8u7lsWvPDKmpodJAJNwkAhJC//dFY48KuIEmjtd4RViDrA==", 3527 | "dev": true 3528 | }, 3529 | "which": { 3530 | "version": "2.0.2", 3531 | "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", 3532 | "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", 3533 | "dev": true, 3534 | "requires": { 3535 | "isexe": "^2.0.0" 3536 | } 3537 | }, 3538 | "word-wrap": { 3539 | "version": "1.2.3", 3540 | "resolved": "https://registry.npmjs.org/word-wrap/-/word-wrap-1.2.3.tgz", 3541 | "integrity": "sha512-Hz/mrNwitNRh/HUAtM/VT/5VH+ygD6DV7mYKZAtHOrbs8U7lvPS6xf7EJKMF0uW1KJCl0H701g3ZGus+muE5vQ==", 3542 | "dev": true 3543 | }, 3544 | "workerpool": { 3545 | "version": "6.1.5", 3546 | "resolved": "https://registry.npmjs.org/workerpool/-/workerpool-6.1.5.tgz", 3547 | "integrity": "sha512-XdKkCK0Zqc6w3iTxLckiuJ81tiD/o5rBE/m+nXpRCB+/Sq4DqkfXZ/x0jW02DG1tGsfUGXbTJyZDP+eu67haSw==", 3548 | "dev": true 3549 | }, 3550 | "wrap-ansi": { 3551 | "version": "7.0.0", 3552 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz", 3553 | "integrity": "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==", 3554 | "dev": true, 3555 | "requires": { 3556 | "ansi-styles": "^4.0.0", 3557 | "string-width": "^4.1.0", 3558 | "strip-ansi": "^6.0.0" 3559 | } 3560 | }, 3561 | "wrappy": { 3562 | "version": "1.0.2", 3563 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 3564 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=", 3565 | "dev": true 3566 | }, 3567 | "y18n": { 3568 | "version": "5.0.8", 3569 | "resolved": "https://registry.npmjs.org/y18n/-/y18n-5.0.8.tgz", 3570 | "integrity": "sha512-0pfFzegeDWJHJIAmTLRP2DwHjdF5s7jo9tuztdQxAhINCdvS+3nGINqPd00AphqJR/0LhANUS6/+7SCb98YOfA==", 3571 | "dev": true 3572 | }, 3573 | "yallist": { 3574 | "version": "4.0.0", 3575 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", 3576 | "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", 3577 | "dev": true 3578 | }, 3579 | "yargs": { 3580 | "version": "16.2.0", 3581 | "resolved": "https://registry.npmjs.org/yargs/-/yargs-16.2.0.tgz", 3582 | "integrity": "sha512-D1mvvtDG0L5ft/jGWkLpG1+m0eQxOfaBvTNELraWj22wSVUMWxZUvYgJYcKh6jGGIkJFhH4IZPQhR4TKpc8mBw==", 3583 | "dev": true, 3584 | "requires": { 3585 | "cliui": "^7.0.2", 3586 | "escalade": "^3.1.1", 3587 | "get-caller-file": "^2.0.5", 3588 | "require-directory": "^2.1.1", 3589 | "string-width": "^4.2.0", 3590 | "y18n": "^5.0.5", 3591 | "yargs-parser": "^20.2.2" 3592 | } 3593 | }, 3594 | "yargs-parser": { 3595 | "version": "20.2.4", 3596 | "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-20.2.4.tgz", 3597 | "integrity": "sha512-WOkpgNhPTlE73h4VFAFsOnomJVaovO8VqLDzy5saChRBFQFBoMYirowyW+Q9HB4HFF4Z7VZTiG3iSzJJA29yRA==", 3598 | "dev": true 3599 | }, 3600 | "yargs-unparser": { 3601 | "version": "2.0.0", 3602 | "resolved": "https://registry.npmjs.org/yargs-unparser/-/yargs-unparser-2.0.0.tgz", 3603 | "integrity": "sha512-7pRTIA9Qc1caZ0bZ6RYRGbHJthJWuakf+WmHK0rVeLkNrrGhfoabBNdue6kdINI6r4if7ocq9aD/n7xwKOdzOA==", 3604 | "dev": true, 3605 | "requires": { 3606 | "camelcase": "^6.0.0", 3607 | "decamelize": "^4.0.0", 3608 | "flat": "^5.0.2", 3609 | "is-plain-obj": "^2.1.0" 3610 | } 3611 | }, 3612 | "yocto-queue": { 3613 | "version": "0.1.0", 3614 | "resolved": "https://registry.npmjs.org/yocto-queue/-/yocto-queue-0.1.0.tgz", 3615 | "integrity": "sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q==", 3616 | "dev": true 3617 | } 3618 | } 3619 | } 3620 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "blueimp-tmpl", 3 | "version": "3.20.0", 4 | "title": "JavaScript Templates", 5 | "description": "1KB lightweight, fast & powerful JavaScript templating engine with zero dependencies. Compatible with server-side environments like Node.js, module loaders like RequireJS, Browserify or webpack and all web browsers.", 6 | "keywords": [ 7 | "javascript", 8 | "templates", 9 | "templating" 10 | ], 11 | "homepage": "https://github.com/blueimp/JavaScript-Templates", 12 | "author": { 13 | "name": "Sebastian Tschan", 14 | "url": "https://blueimp.net" 15 | }, 16 | "repository": { 17 | "type": "git", 18 | "url": "git://github.com/blueimp/JavaScript-Templates.git" 19 | }, 20 | "license": "MIT", 21 | "devDependencies": { 22 | "chai": "4", 23 | "eslint": "7", 24 | "eslint-config-blueimp": "2", 25 | "eslint-config-prettier": "8", 26 | "eslint-plugin-jsdoc": "36", 27 | "eslint-plugin-prettier": "4", 28 | "mocha": "9", 29 | "prettier": "2", 30 | "uglify-js": "3" 31 | }, 32 | "eslintConfig": { 33 | "extends": [ 34 | "blueimp", 35 | "plugin:jsdoc/recommended", 36 | "plugin:prettier/recommended" 37 | ], 38 | "env": { 39 | "browser": true, 40 | "node": true 41 | } 42 | }, 43 | "eslintIgnore": [ 44 | "js/*.min.js", 45 | "test/vendor" 46 | ], 47 | "prettier": { 48 | "arrowParens": "avoid", 49 | "proseWrap": "always", 50 | "semi": false, 51 | "singleQuote": true, 52 | "trailingComma": "none" 53 | }, 54 | "scripts": { 55 | "lint": "eslint .", 56 | "unit": "mocha", 57 | "test": "npm run lint && npm run unit", 58 | "prebuild": "bin/sync-vendor-libs.sh", 59 | "build": "cd js && uglifyjs tmpl.js -c -m -o tmpl.min.js --source-map url=tmpl.min.js.map", 60 | "preversion": "npm test", 61 | "version": "npm run build && git add -A js", 62 | "postversion": "git push --tags origin master master:gh-pages && npm publish" 63 | }, 64 | "bin": { 65 | "tmpl.js": "js/compile.js" 66 | }, 67 | "files": [ 68 | "js/*.js", 69 | "js/*.js.map" 70 | ], 71 | "main": "js/tmpl.js" 72 | } 73 | -------------------------------------------------------------------------------- /test/index.html: -------------------------------------------------------------------------------- 1 | 2 | 14 | 15 | 16 | 19 | 20 | JavaScript Templates Test 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 31 | 34 | 35 | 36 | 40 | 41 | 42 | -------------------------------------------------------------------------------- /test/test.js: -------------------------------------------------------------------------------- 1 | /* 2 | * JavaScript Templates Test 3 | * https://github.com/blueimp/JavaScript-Templates 4 | * 5 | * Copyright 2011, Sebastian Tschan 6 | * https://blueimp.net 7 | * 8 | * Licensed under the MIT license: 9 | * https://opensource.org/licenses/MIT 10 | */ 11 | 12 | /* global beforeEach, afterEach, describe, it */ 13 | 14 | /* eslint-disable strict */ 15 | 16 | ;(function (context, expect, tmpl) { 17 | 'use strict' 18 | 19 | if (context.require === undefined) { 20 | // Override the template loading method: 21 | tmpl.load = function (id) { 22 | switch (id) { 23 | case 'template': 24 | return '{%=o.value%}' 25 | } 26 | } 27 | } 28 | 29 | var data 30 | 31 | beforeEach(function () { 32 | // Initialize the sample data: 33 | data = { 34 | value: 'value', 35 | nullValue: null, 36 | falseValue: false, 37 | zeroValue: 0, 38 | special: '<>&"\'\x00', 39 | list: [1, 2, 3, 4, 5], 40 | func: function () { 41 | return this.value 42 | }, 43 | deep: { 44 | value: 'value' 45 | } 46 | } 47 | }) 48 | 49 | afterEach(function () { 50 | // Purge the template cache: 51 | tmpl.cache = {} 52 | }) 53 | 54 | describe('Template loading', function () { 55 | it('String template', function () { 56 | expect(tmpl('{%=o.value%}', data)).to.equal('value') 57 | }) 58 | 59 | it('Load template by id', function () { 60 | expect(tmpl('template', data)).to.equal('value') 61 | }) 62 | 63 | it('Retun function when called without data parameter', function () { 64 | expect(tmpl('{%=o.value%}')(data)).to.equal('value') 65 | }) 66 | 67 | it('Cache templates loaded by id', function () { 68 | tmpl('template') 69 | expect(tmpl.cache.template).to.be.a('function') 70 | }) 71 | }) 72 | 73 | describe('Interpolation', function () { 74 | it('Escape HTML special characters with {%=o.prop%}', function () { 75 | expect(tmpl('{%=o.special%}', data)).to.equal('<>&"'') 76 | }) 77 | 78 | it('Allow HTML special characters with {%#o.prop%}', function () { 79 | expect(tmpl('{%#o.special%}', data)).to.equal('<>&"\'\x00') 80 | }) 81 | 82 | it('Function call', function () { 83 | expect(tmpl('{%=o.func()%}', data)).to.equal('value') 84 | }) 85 | 86 | it('Dot notation', function () { 87 | expect(tmpl('{%=o.deep.value%}', data)).to.equal('value') 88 | }) 89 | 90 | it('Handle single quotes', function () { 91 | expect(tmpl("'single quotes'{%=\": '\"%}", data)).to.equal( 92 | "'single quotes': '" 93 | ) 94 | }) 95 | 96 | it('Handle double quotes', function () { 97 | expect(tmpl('"double quotes"{%=": \\""%}', data)).to.equal( 98 | '"double quotes": "' 99 | ) 100 | }) 101 | 102 | it('Handle backslashes', function () { 103 | expect(tmpl('\\backslashes\\{%=": \\\\"%}', data)).to.equal( 104 | '\\backslashes\\: \\' 105 | ) 106 | }) 107 | 108 | it('Interpolate escaped falsy values except undefined or null', function () { 109 | expect( 110 | tmpl( 111 | '{%=o.undefinedValue%}' + 112 | '{%=o.nullValue%}' + 113 | '{%=o.falseValue%}' + 114 | '{%=o.zeroValue%}', 115 | data 116 | ) 117 | ).to.equal('false0') 118 | }) 119 | 120 | it('Interpolate unescaped falsy values except undefined or null', function () { 121 | expect( 122 | tmpl( 123 | '{%#o.undefinedValue%}' + 124 | '{%#o.nullValue%}' + 125 | '{%#o.falseValue%}' + 126 | '{%#o.zeroValue%}', 127 | data 128 | ) 129 | ).to.equal('false0') 130 | }) 131 | 132 | it('Preserve whitespace', function () { 133 | expect(tmpl('\n\r\t{%=o.value%} \n\r\t{%=o.value%} ', data)).to.equal( 134 | '\n\r\tvalue \n\r\tvalue ' 135 | ) 136 | }) 137 | }) 138 | 139 | describe('Evaluation', function () { 140 | it('Escape HTML special characters with print(data)', function () { 141 | expect(tmpl('{% print(o.special); %}', data)).to.equal( 142 | '<>&"'' 143 | ) 144 | }) 145 | 146 | it('Allow HTML special characters with print(data, true)', function () { 147 | expect(tmpl('{% print(o.special, true); %}', data)).to.equal('<>&"\'\x00') 148 | }) 149 | 150 | it('Print out escaped falsy values except undefined or null', function () { 151 | expect( 152 | tmpl( 153 | '{% print(o.undefinedValue); %}' + 154 | '{% print(o.nullValue); %}' + 155 | '{% print(o.falseValue); %}' + 156 | '{% print(o.zeroValue); %}', 157 | data 158 | ) 159 | ).to.equal('false0') 160 | }) 161 | 162 | it('Print out unescaped falsy values except undefined or null', function () { 163 | expect( 164 | tmpl( 165 | '{% print(o.undefinedValue, true); %}' + 166 | '{% print(o.nullValue, true); %}' + 167 | '{% print(o.falseValue, true); %}' + 168 | '{% print(o.zeroValue, true); %}', 169 | data 170 | ) 171 | ).to.equal('false0') 172 | }) 173 | 174 | it('Include template', function () { 175 | expect( 176 | tmpl('{% include("template", {value: "value"}); %}', data) 177 | ).to.equal('value') 178 | }) 179 | 180 | it('If condition', function () { 181 | expect( 182 | tmpl('{% if (o.value) { %}true{% } else { %}false{% } %}', data) 183 | ).to.equal('true') 184 | }) 185 | 186 | it('Else condition', function () { 187 | expect( 188 | tmpl( 189 | '{% if (o.undefinedValue) { %}false{% } else { %}true{% } %}', 190 | data 191 | ) 192 | ).to.equal('true') 193 | }) 194 | 195 | it('For loop', function () { 196 | expect( 197 | tmpl( 198 | '{% for (var i=0; i