├── .eslintrc.json ├── .gitignore ├── LICENCE ├── README.md ├── content.css ├── content.js ├── images ├── cat-paw.svg ├── channel-fileinput-add.svg ├── channel-fileinput-user.svg ├── eyes-state-01.svg ├── illu-video-fileinput.svg ├── logo128.png ├── logo16.png ├── logo32.png └── logo48.png ├── manifest.json ├── package-lock.json ├── package.json ├── popup-wrapper.html ├── popup-wrapper.js ├── popup.html ├── popup.js ├── pull_request_template.md └── style.css /.eslintrc.json: -------------------------------------------------------------------------------- 1 | { 2 | "env": { 3 | "browser": true, 4 | "es2021": true 5 | }, 6 | "parserOptions": { 7 | "ecmaVersion": 12, 8 | "sourceType": "module" 9 | }, 10 | "rules": { 11 | "semi": [ 12 | "error", 13 | "never" 14 | ], 15 | "quotes": [ 16 | "error", 17 | "single" 18 | ], 19 | "indent": [ 20 | "error", 21 | 4 22 | ], 23 | "no-unused-vars": [ 24 | "error", 25 | { 26 | "caughtErrors": "all" 27 | } 28 | ] 29 | } 30 | } -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | /.idea/ 2 | .DS_Store 3 | node_modules 4 | prevyou.zip 5 | -------------------------------------------------------------------------------- /LICENCE: -------------------------------------------------------------------------------- 1 | MIT License 2 | 3 | Copyright (c) 2021 Benjamin Debon 4 | 5 | Permission is hereby granted, free of charge, to any person obtaining a copy 6 | of this software and associated documentation files (the "Software"), to deal 7 | in the Software without restriction, including without limitation the rights 8 | to use, copy, modify, merge, publish, distribute, sublicense, and/or sell 9 | copies of the Software, and to permit persons to whom the Software is 10 | furnished to do so, subject to the following conditions: 11 | 12 | The above copyright notice and this permission notice shall be included in all 13 | copies or substantial portions of the Software. 14 | 15 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 16 | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 17 | FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 18 | AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 19 | LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, 20 | OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE 21 | SOFTWARE. -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # youtube-thumbnail-tester-chrome-extension 2 | 3 | ## Installation 4 | - Clone the repo 5 | - Go to chrome://extensions 6 | - Enable the *developer options* if it's not already 7 | - Click *Load unpacked extension...* (FR: "Charger l'extension non empaquetée") 8 | - Navigate and select the repo's root directory 9 | 10 | 11 | Then you should see the extension was installed 12 | 13 | ## Linter - ESLint 14 | 15 | To install ESLint launch 16 | 17 | ``` 18 | npm install 19 | ``` 20 | 21 | To execute and fix all syntaxes error launch 22 | 23 | ``` 24 | npm run lint 25 | ``` 26 | 27 | #### Configuration 28 | 29 | The main config file is ``.eslintrc.json`` 30 | 31 | - [Disallow semicolons instead of ASI](https://eslint.org/docs/rules/semi) 32 | - [Use of single quotes wherever possible](https://eslint.org/docs/rules/quotes) 33 | - [2-space or 1 tab for indentation](https://eslint.org/docs/rules/indent) 34 | - [Disallow Unused Variables](https://eslint.org/docs/rules/no-unused-vars) 35 | 36 | ## Things to improve 37 | - [x] Dark mode 38 | - [ ] The app needs an icon because as of now we are using the default google one... 39 | - [x] Install a linter on the project so that we all can collaborate without having so many useless changes to review 40 | - [ ] Animation on the YouTube Homepage to show where the thumbnail is updated. Like a scale up scale down on the thumbnail for example. 41 | - [ ] Drag and drop thumbnail should work. For now the integration is done and if you hover the dropzone with a file, you'll see the good animation. But once you release the click, it does not work. It's a small thing to fix. 42 | - [x] People would also like to be able to use this extension on the *subscribe feed* of YouTube. And it is really a good feature that needs to be done 43 | - [x] Integrating the V2.0 of the design made by BastiUI ([Figma Link](https://www.figma.com/file/lceF92oVJ4QRAbnfddO5FL/BastiUi-%E2%80%A2-PrevYou?node-id=116%3A56)) 44 | - [ ] Creating tests ? (even if @liior after many tried, realised that it may not be that good of an idea. Follow the discussion [here](https://twitter.com/LiiorC/status/1378610942498508802)) 45 | 46 | 47 | ## Credits 48 | Made by benjamincode live on Twitch : 49 | - [Youtube : Benjamin Code](https://www.youtube.com/channel/UCLOAPb7ATQUs_nDs9ViLcMw) 50 | - [Twitch : benjamincode](https://www.twitch.tv/benjamincode) 51 | - [Twitter : @benjamincodeYT](https://twitter.com/benjamincodeYT) 52 | -------------------------------------------------------------------------------- /content.css: -------------------------------------------------------------------------------- 1 | .py-popup-overlay { 2 | position: fixed; 3 | z-index: 2147483645; 4 | top: 0; 5 | bottom: 0; 6 | left: 0; 7 | right: 0; 8 | margin: 0; 9 | width: 100%; 10 | height: 100%; 11 | padding: 0; 12 | } 13 | 14 | .py-popup-container { 15 | position: fixed; 16 | top: 0; 17 | right: 105px; 18 | width: 400px; 19 | height: 630px; /* height auto not working */ 20 | margin: 0; 21 | padding: 0; 22 | background-color: white; 23 | border-radius: 16px; 24 | box-shadow: 0 1px 1px rgb(0 0 0 / 15%), 0 2px 2px rgb(0 0 0 / 15%), 0 4px 4px rgb(0 0 0 / 15%), 0 8px 8px rgb(0 0 0 / 15%); 25 | } 26 | -------------------------------------------------------------------------------- /content.js: -------------------------------------------------------------------------------- 1 | var overlay = null, 2 | frame = null; 3 | 4 | window.__PREVYOU_LOADED = true 5 | 6 | // Event send by the inner `` script 7 | window.addEventListener('message', e => { 8 | if (e.data && e.data.type === 'find_card') { 9 | findCard() 10 | } 11 | }) 12 | 13 | // Event send by the extension popup 14 | chrome.runtime.onMessage.addListener((request, sender, sendResponse) => { 15 | if (request.type == "popup") { 16 | //console.log(request); 17 | showPopup(); 18 | } else if (request.type === 'close_popup') { 19 | hidePopup(); 20 | } 21 | return true; 22 | }); 23 | 24 | function showPopup() { 25 | if (document.querySelector(".py-popup-overlay")) { 26 | hidePopup(); 27 | return false; 28 | } 29 | 30 | overlay = document.createElement('div'); 31 | frame = document.createElement('object'); 32 | 33 | overlay.className = "py-popup-overlay"; 34 | frame.className = "py-popup-container"; 35 | frame.setAttribute("scrolling", "no"); 36 | frame.setAttribute("frameborder", "0"); 37 | 38 | // file need to be added in manifest web_accessible_resources 39 | frame.data = chrome.runtime.getURL("popup.html"); 40 | overlay.appendChild(frame); 41 | document.body.appendChild(overlay); 42 | 43 | overlay.addEventListener("click", hidePopup); 44 | } 45 | 46 | function hidePopup() { 47 | // Remove EventListener 48 | overlay.removeEventListener("click", hidePopup); 49 | 50 | // Remove the elements: 51 | document.querySelector(".py-popup-overlay").remove(); 52 | 53 | // Clean up references: 54 | overlay = null; 55 | frame = null; 56 | } 57 | 58 | function findCard() { 59 | // Select a random a card in between a range 60 | let cardPositionIndex = 0 61 | 62 | const activeScreen = document.querySelector('[role="main"]') 63 | // Target only ytd-rich-item-renderer element and not ytd-rich-item-renderer with id content for the main page 64 | let cards = activeScreen.querySelectorAll('.ytd-rich-grid-media:not(#content):not(ytd-display-ad-renderer)') 65 | if (cards.length === 0) { 66 | cards = activeScreen.getElementsByTagName('ytd-grid-video-renderer') 67 | } 68 | if (cards.length === 0) { 69 | cards = activeScreen.getElementsByTagName('ytd-compact-video-renderer') 70 | } 71 | 72 | chrome.storage.local.get('thumbnailProperties', (result) => { 73 | 74 | if (result.thumbnailProperties.shuffle) { 75 | const min = 1 76 | const max = 12 77 | cardPositionIndex = Math.floor(Math.random() * (max - min + 1)) + min 78 | } 79 | let target = cards[cardPositionIndex] 80 | const thumbnail = target.querySelector('.ytd-thumbnail > img') 81 | thumbnail.src = result.thumbnailProperties.thumbnail 82 | 83 | const title = target.querySelector('#video-title') 84 | let channelName = target.querySelector('.ytd-channel-name a') 85 | if (!channelName) { 86 | channelName = target.querySelector('.ytd-channel-name') 87 | } 88 | 89 | title.textContent = result.thumbnailProperties.title 90 | channelName.textContent = result.thumbnailProperties.channelName 91 | 92 | // Channel's thumbnail management 93 | let channelThumbnailFromExtension = result.thumbnailProperties.channelThumbnail 94 | let channelThumbnailFromYoutube = document.querySelector('#avatar-btn .yt-img-shadow') 95 | 96 | // By default, we get the image from the extension 97 | let channelThumbnailValue = channelThumbnailFromExtension 98 | 99 | // But if there's no image then we try to get the real YT thumbnail 100 | // => Thumbnail from YT is null if not logged in so we check for it 101 | if (channelThumbnailValue == null && channelThumbnailFromYoutube != null) { 102 | channelThumbnailValue = channelThumbnailFromYoutube.src 103 | } 104 | 105 | // Finally, set the channel's thumbnail in the preview 106 | let avatar = target.querySelector('#avatar-link .yt-img-shadow') 107 | // YouTube use two avatar nowadays, and because I don't know which one it will use since both are present in the DOM, I'll change both. 108 | let avatarV2 = target.querySelector('#decorated-avatar .yt-core-image') 109 | if (avatar) { 110 | avatar.src = channelThumbnailValue 111 | avatarV2.src = channelThumbnailValue 112 | } 113 | 114 | hidePopup() 115 | }) 116 | } 117 | 118 | showPopup() 119 | -------------------------------------------------------------------------------- /images/cat-paw.svg: -------------------------------------------------------------------------------- 1 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 | -------------------------------------------------------------------------------- /images/channel-fileinput-add.svg: -------------------------------------------------------------------------------- 1 | 3 | 4 | 5 | -------------------------------------------------------------------------------- /images/channel-fileinput-user.svg: -------------------------------------------------------------------------------- 1 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | -------------------------------------------------------------------------------- /images/eyes-state-01.svg: -------------------------------------------------------------------------------- 1 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 | 32 | 33 | 34 | 35 | 36 | 37 | 38 | 39 | 40 | 41 | 42 | 43 | 44 | 45 | 46 | 47 | 48 | 49 | 50 | -------------------------------------------------------------------------------- /images/illu-video-fileinput.svg: -------------------------------------------------------------------------------- 1 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | -------------------------------------------------------------------------------- /images/logo128.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/bdebon/youtube-thumbnail-tester-chrome-extension/d993eb276eede10c66cbc4db8d8c411e2b9b1353/images/logo128.png -------------------------------------------------------------------------------- /images/logo16.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/bdebon/youtube-thumbnail-tester-chrome-extension/d993eb276eede10c66cbc4db8d8c411e2b9b1353/images/logo16.png -------------------------------------------------------------------------------- /images/logo32.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/bdebon/youtube-thumbnail-tester-chrome-extension/d993eb276eede10c66cbc4db8d8c411e2b9b1353/images/logo32.png -------------------------------------------------------------------------------- /images/logo48.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/bdebon/youtube-thumbnail-tester-chrome-extension/d993eb276eede10c66cbc4db8d8c411e2b9b1353/images/logo48.png -------------------------------------------------------------------------------- /manifest.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "PrevYou — YouTube Thumbnail Previewer", 3 | "description": "Preview your video thumbnail and title on YouTube home page or subscription feed.", 4 | "version": "1.6", 5 | "manifest_version": 3, 6 | "permissions": ["storage", "activeTab", "scripting"], 7 | "action": { 8 | "default_popup": "popup-wrapper.html", 9 | "default_icon": { 10 | "16": "/images/logo16.png", 11 | "32": "/images/logo32.png", 12 | "48": "/images/logo48.png", 13 | "128": "/images/logo128.png" 14 | } 15 | }, 16 | "web_accessible_resources": [{ 17 | "resources": ["popup.html"], 18 | "matches": ["https://www.youtube.com/*"] 19 | }], 20 | "icons": { 21 | "16": "/images/logo16.png", 22 | "32": "/images/logo32.png", 23 | "48": "/images/logo48.png", 24 | "128": "/images/logo128.png" 25 | } 26 | } 27 | -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "youtube-thumbnail-tester-chrome-extension", 3 | "version": "0.1.0", 4 | "lockfileVersion": 2, 5 | "requires": true, 6 | "packages": { 7 | "": { 8 | "name": "youtube-thumbnail-tester-chrome-extension", 9 | "version": "0.1.0", 10 | "license": "ISC", 11 | "devDependencies": { 12 | "eslint": "^7.23.0" 13 | } 14 | }, 15 | "node_modules/@babel/code-frame": { 16 | "version": "7.12.11", 17 | "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.12.11.tgz", 18 | "integrity": "sha512-Zt1yodBx1UcyiePMSkWnU4hPqhwq7hGi2nFL1LeA3EUl+q2LQx16MISgJ0+z7dnmgvP9QtIleuETGOiOH1RcIw==", 19 | "dev": true, 20 | "dependencies": { 21 | "@babel/highlight": "^7.10.4" 22 | } 23 | }, 24 | "node_modules/@babel/helper-validator-identifier": { 25 | "version": "7.12.11", 26 | "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.12.11.tgz", 27 | "integrity": "sha512-np/lG3uARFybkoHokJUmf1QfEvRVCPbmQeUQpKow5cQ3xWrV9i3rUHodKDJPQfTVX61qKi+UdYk8kik84n7XOw==", 28 | "dev": true 29 | }, 30 | "node_modules/@babel/highlight": { 31 | "version": "7.13.10", 32 | "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.13.10.tgz", 33 | "integrity": "sha512-5aPpe5XQPzflQrFwL1/QoeHkP2MsA4JCntcXHRhEsdsfPVkvPi2w7Qix4iV7t5S/oC9OodGrggd8aco1g3SZFg==", 34 | "dev": true, 35 | "dependencies": { 36 | "@babel/helper-validator-identifier": "^7.12.11", 37 | "chalk": "^2.0.0", 38 | "js-tokens": "^4.0.0" 39 | } 40 | }, 41 | "node_modules/@babel/highlight/node_modules/ansi-styles": { 42 | "version": "3.2.1", 43 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", 44 | "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", 45 | "dev": true, 46 | "dependencies": { 47 | "color-convert": "^1.9.0" 48 | }, 49 | "engines": { 50 | "node": ">=4" 51 | } 52 | }, 53 | "node_modules/@babel/highlight/node_modules/chalk": { 54 | "version": "2.4.2", 55 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", 56 | "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", 57 | "dev": true, 58 | "dependencies": { 59 | "ansi-styles": "^3.2.1", 60 | "escape-string-regexp": "^1.0.5", 61 | "supports-color": "^5.3.0" 62 | }, 63 | "engines": { 64 | "node": ">=4" 65 | } 66 | }, 67 | "node_modules/@babel/highlight/node_modules/color-convert": { 68 | "version": "1.9.3", 69 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", 70 | "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", 71 | "dev": true, 72 | "dependencies": { 73 | "color-name": "1.1.3" 74 | } 75 | }, 76 | "node_modules/@babel/highlight/node_modules/color-name": { 77 | "version": "1.1.3", 78 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", 79 | "integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=", 80 | "dev": true 81 | }, 82 | "node_modules/@babel/highlight/node_modules/has-flag": { 83 | "version": "3.0.0", 84 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 85 | "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=", 86 | "dev": true, 87 | "engines": { 88 | "node": ">=4" 89 | } 90 | }, 91 | "node_modules/@babel/highlight/node_modules/supports-color": { 92 | "version": "5.5.0", 93 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 94 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 95 | "dev": true, 96 | "dependencies": { 97 | "has-flag": "^3.0.0" 98 | }, 99 | "engines": { 100 | "node": ">=4" 101 | } 102 | }, 103 | "node_modules/@eslint/eslintrc": { 104 | "version": "0.4.0", 105 | "resolved": "https://registry.npmjs.org/@eslint/eslintrc/-/eslintrc-0.4.0.tgz", 106 | "integrity": "sha512-2ZPCc+uNbjV5ERJr+aKSPRwZgKd2z11x0EgLvb1PURmUrn9QNRXFqje0Ldq454PfAVyaJYyrDvvIKSFP4NnBog==", 107 | "dev": true, 108 | "dependencies": { 109 | "ajv": "^6.12.4", 110 | "debug": "^4.1.1", 111 | "espree": "^7.3.0", 112 | "globals": "^12.1.0", 113 | "ignore": "^4.0.6", 114 | "import-fresh": "^3.2.1", 115 | "js-yaml": "^3.13.1", 116 | "minimatch": "^3.0.4", 117 | "strip-json-comments": "^3.1.1" 118 | }, 119 | "engines": { 120 | "node": "^10.12.0 || >=12.0.0" 121 | } 122 | }, 123 | "node_modules/@eslint/eslintrc/node_modules/globals": { 124 | "version": "12.4.0", 125 | "resolved": "https://registry.npmjs.org/globals/-/globals-12.4.0.tgz", 126 | "integrity": "sha512-BWICuzzDvDoH54NHKCseDanAhE3CeDorgDL5MT6LMXXj2WCnd9UC2szdk4AWLfjdgNBCXLUanXYcpBBKOSWGwg==", 127 | "dev": true, 128 | "dependencies": { 129 | "type-fest": "^0.8.1" 130 | }, 131 | "engines": { 132 | "node": ">=8" 133 | }, 134 | "funding": { 135 | "url": "https://github.com/sponsors/sindresorhus" 136 | } 137 | }, 138 | "node_modules/@eslint/eslintrc/node_modules/type-fest": { 139 | "version": "0.8.1", 140 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.8.1.tgz", 141 | "integrity": "sha512-4dbzIzqvjtgiM5rw1k5rEHtBANKmdudhGyBEajN01fEyhaAIhsoKNy6y7+IN93IfpFtwY9iqi7kD+xwKhQsNJA==", 142 | "dev": true, 143 | "engines": { 144 | "node": ">=8" 145 | } 146 | }, 147 | "node_modules/acorn": { 148 | "version": "7.4.1", 149 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-7.4.1.tgz", 150 | "integrity": "sha512-nQyp0o1/mNdbTO1PO6kHkwSrmgZ0MT/jCCpNiwbUjGoRN4dlBhqJtoQuCnEOKzgTVwg0ZWiCoQy6SxMebQVh8A==", 151 | "dev": true, 152 | "bin": { 153 | "acorn": "bin/acorn" 154 | }, 155 | "engines": { 156 | "node": ">=0.4.0" 157 | } 158 | }, 159 | "node_modules/acorn-jsx": { 160 | "version": "5.3.1", 161 | "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.3.1.tgz", 162 | "integrity": "sha512-K0Ptm/47OKfQRpNQ2J/oIN/3QYiK6FwW+eJbILhsdxh2WTLdl+30o8aGdTbm5JbffpFFAg/g+zi1E+jvJha5ng==", 163 | "dev": true, 164 | "peerDependencies": { 165 | "acorn": "^6.0.0 || ^7.0.0 || ^8.0.0" 166 | } 167 | }, 168 | "node_modules/ajv": { 169 | "version": "6.12.6", 170 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.12.6.tgz", 171 | "integrity": "sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g==", 172 | "dev": true, 173 | "dependencies": { 174 | "fast-deep-equal": "^3.1.1", 175 | "fast-json-stable-stringify": "^2.0.0", 176 | "json-schema-traverse": "^0.4.1", 177 | "uri-js": "^4.2.2" 178 | }, 179 | "funding": { 180 | "type": "github", 181 | "url": "https://github.com/sponsors/epoberezkin" 182 | } 183 | }, 184 | "node_modules/ansi-colors": { 185 | "version": "4.1.1", 186 | "resolved": "https://registry.npmjs.org/ansi-colors/-/ansi-colors-4.1.1.tgz", 187 | "integrity": "sha512-JoX0apGbHaUJBNl6yF+p6JAFYZ666/hhCGKN5t9QFjbJQKUU/g8MNbFDbvfrgKXvI1QpZplPOnwIo99lX/AAmA==", 188 | "dev": true, 189 | "engines": { 190 | "node": ">=6" 191 | } 192 | }, 193 | "node_modules/ansi-regex": { 194 | "version": "5.0.0", 195 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.0.tgz", 196 | "integrity": "sha512-bY6fj56OUQ0hU1KjFNDQuJFezqKdrAyFdIevADiqrWHwSlbmBNMHp5ak2f40Pm8JTFyM2mqxkG6ngkHO11f/lg==", 197 | "dev": true, 198 | "engines": { 199 | "node": ">=8" 200 | } 201 | }, 202 | "node_modules/ansi-styles": { 203 | "version": "4.3.0", 204 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 205 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 206 | "dev": true, 207 | "dependencies": { 208 | "color-convert": "^2.0.1" 209 | }, 210 | "engines": { 211 | "node": ">=8" 212 | }, 213 | "funding": { 214 | "url": "https://github.com/chalk/ansi-styles?sponsor=1" 215 | } 216 | }, 217 | "node_modules/argparse": { 218 | "version": "1.0.10", 219 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-1.0.10.tgz", 220 | "integrity": "sha512-o5Roy6tNG4SL/FOkCAN6RzjiakZS25RLYFrcMttJqbdd8BWrnA+fGz57iN5Pb06pvBGvl5gQ0B48dJlslXvoTg==", 221 | "dev": true, 222 | "dependencies": { 223 | "sprintf-js": "~1.0.2" 224 | } 225 | }, 226 | "node_modules/astral-regex": { 227 | "version": "2.0.0", 228 | "resolved": "https://registry.npmjs.org/astral-regex/-/astral-regex-2.0.0.tgz", 229 | "integrity": "sha512-Z7tMw1ytTXt5jqMcOP+OQteU1VuNK9Y02uuJtKQ1Sv69jXQKKg5cibLwGJow8yzZP+eAc18EmLGPal0bp36rvQ==", 230 | "dev": true, 231 | "engines": { 232 | "node": ">=8" 233 | } 234 | }, 235 | "node_modules/balanced-match": { 236 | "version": "1.0.0", 237 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz", 238 | "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=", 239 | "dev": true 240 | }, 241 | "node_modules/brace-expansion": { 242 | "version": "1.1.11", 243 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 244 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 245 | "dev": true, 246 | "dependencies": { 247 | "balanced-match": "^1.0.0", 248 | "concat-map": "0.0.1" 249 | } 250 | }, 251 | "node_modules/call-bind": { 252 | "version": "1.0.2", 253 | "resolved": "https://registry.npmjs.org/call-bind/-/call-bind-1.0.2.tgz", 254 | "integrity": "sha512-7O+FbCihrB5WGbFYesctwmTKae6rOiIzmz1icreWJ+0aA7LJfuqhEso2T9ncpcFtzMQtzXf2QGGueWJGTYsqrA==", 255 | "dev": true, 256 | "dependencies": { 257 | "function-bind": "^1.1.1", 258 | "get-intrinsic": "^1.0.2" 259 | }, 260 | "funding": { 261 | "url": "https://github.com/sponsors/ljharb" 262 | } 263 | }, 264 | "node_modules/callsites": { 265 | "version": "3.1.0", 266 | "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz", 267 | "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==", 268 | "dev": true, 269 | "engines": { 270 | "node": ">=6" 271 | } 272 | }, 273 | "node_modules/chalk": { 274 | "version": "4.1.0", 275 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.0.tgz", 276 | "integrity": "sha512-qwx12AxXe2Q5xQ43Ac//I6v5aXTipYrSESdOgzrN+9XjgEpyjpKuvSGaN4qE93f7TQTlerQQ8S+EQ0EyDoVL1A==", 277 | "dev": true, 278 | "dependencies": { 279 | "ansi-styles": "^4.1.0", 280 | "supports-color": "^7.1.0" 281 | }, 282 | "engines": { 283 | "node": ">=10" 284 | }, 285 | "funding": { 286 | "url": "https://github.com/chalk/chalk?sponsor=1" 287 | } 288 | }, 289 | "node_modules/color-convert": { 290 | "version": "2.0.1", 291 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 292 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 293 | "dev": true, 294 | "dependencies": { 295 | "color-name": "~1.1.4" 296 | }, 297 | "engines": { 298 | "node": ">=7.0.0" 299 | } 300 | }, 301 | "node_modules/color-name": { 302 | "version": "1.1.4", 303 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 304 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 305 | "dev": true 306 | }, 307 | "node_modules/concat-map": { 308 | "version": "0.0.1", 309 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 310 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=", 311 | "dev": true 312 | }, 313 | "node_modules/cross-spawn": { 314 | "version": "7.0.3", 315 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz", 316 | "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==", 317 | "dev": true, 318 | "dependencies": { 319 | "path-key": "^3.1.0", 320 | "shebang-command": "^2.0.0", 321 | "which": "^2.0.1" 322 | }, 323 | "engines": { 324 | "node": ">= 8" 325 | } 326 | }, 327 | "node_modules/debug": { 328 | "version": "4.3.1", 329 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.1.tgz", 330 | "integrity": "sha512-doEwdvm4PCeK4K3RQN2ZC2BYUBaxwLARCqZmMjtF8a51J2Rb0xpVloFRnCODwqjpwnAoao4pelN8l3RJdv3gRQ==", 331 | "dev": true, 332 | "dependencies": { 333 | "ms": "2.1.2" 334 | }, 335 | "engines": { 336 | "node": ">=6.0" 337 | }, 338 | "peerDependenciesMeta": { 339 | "supports-color": { 340 | "optional": true 341 | } 342 | } 343 | }, 344 | "node_modules/deep-is": { 345 | "version": "0.1.3", 346 | "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.3.tgz", 347 | "integrity": "sha1-s2nW+128E+7PUk+RsHD+7cNXzzQ=", 348 | "dev": true 349 | }, 350 | "node_modules/doctrine": { 351 | "version": "3.0.0", 352 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-3.0.0.tgz", 353 | "integrity": "sha512-yS+Q5i3hBf7GBkd4KG8a7eBNNWNGLTaEwwYWUijIYM7zrlYDM0BFXHjjPWlWZ1Rg7UaddZeIDmi9jF3HmqiQ2w==", 354 | "dev": true, 355 | "dependencies": { 356 | "esutils": "^2.0.2" 357 | }, 358 | "engines": { 359 | "node": ">=6.0.0" 360 | } 361 | }, 362 | "node_modules/emoji-regex": { 363 | "version": "8.0.0", 364 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 365 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", 366 | "dev": true 367 | }, 368 | "node_modules/enquirer": { 369 | "version": "2.3.6", 370 | "resolved": "https://registry.npmjs.org/enquirer/-/enquirer-2.3.6.tgz", 371 | "integrity": "sha512-yjNnPr315/FjS4zIsUxYguYUPP2e1NK4d7E7ZOLiyYCcbFBiTMyID+2wvm2w6+pZ/odMA7cRkjhsPbltwBOrLg==", 372 | "dev": true, 373 | "dependencies": { 374 | "ansi-colors": "^4.1.1" 375 | }, 376 | "engines": { 377 | "node": ">=8.6" 378 | } 379 | }, 380 | "node_modules/escape-string-regexp": { 381 | "version": "1.0.5", 382 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", 383 | "integrity": "sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ=", 384 | "dev": true, 385 | "engines": { 386 | "node": ">=0.8.0" 387 | } 388 | }, 389 | "node_modules/eslint": { 390 | "version": "7.23.0", 391 | "resolved": "https://registry.npmjs.org/eslint/-/eslint-7.23.0.tgz", 392 | "integrity": "sha512-kqvNVbdkjzpFy0XOszNwjkKzZ+6TcwCQ/h+ozlcIWwaimBBuhlQ4nN6kbiM2L+OjDcznkTJxzYfRFH92sx4a0Q==", 393 | "dev": true, 394 | "dependencies": { 395 | "@babel/code-frame": "7.12.11", 396 | "@eslint/eslintrc": "^0.4.0", 397 | "ajv": "^6.10.0", 398 | "chalk": "^4.0.0", 399 | "cross-spawn": "^7.0.2", 400 | "debug": "^4.0.1", 401 | "doctrine": "^3.0.0", 402 | "enquirer": "^2.3.5", 403 | "eslint-scope": "^5.1.1", 404 | "eslint-utils": "^2.1.0", 405 | "eslint-visitor-keys": "^2.0.0", 406 | "espree": "^7.3.1", 407 | "esquery": "^1.4.0", 408 | "esutils": "^2.0.2", 409 | "file-entry-cache": "^6.0.1", 410 | "functional-red-black-tree": "^1.0.1", 411 | "glob-parent": "^5.0.0", 412 | "globals": "^13.6.0", 413 | "ignore": "^4.0.6", 414 | "import-fresh": "^3.0.0", 415 | "imurmurhash": "^0.1.4", 416 | "is-glob": "^4.0.0", 417 | "js-yaml": "^3.13.1", 418 | "json-stable-stringify-without-jsonify": "^1.0.1", 419 | "levn": "^0.4.1", 420 | "lodash": "^4.17.21", 421 | "minimatch": "^3.0.4", 422 | "natural-compare": "^1.4.0", 423 | "optionator": "^0.9.1", 424 | "progress": "^2.0.0", 425 | "regexpp": "^3.1.0", 426 | "semver": "^7.2.1", 427 | "strip-ansi": "^6.0.0", 428 | "strip-json-comments": "^3.1.0", 429 | "table": "^6.0.4", 430 | "text-table": "^0.2.0", 431 | "v8-compile-cache": "^2.0.3" 432 | }, 433 | "bin": { 434 | "eslint": "bin/eslint.js" 435 | }, 436 | "engines": { 437 | "node": "^10.12.0 || >=12.0.0" 438 | }, 439 | "funding": { 440 | "url": "https://opencollective.com/eslint" 441 | } 442 | }, 443 | "node_modules/eslint-scope": { 444 | "version": "5.1.1", 445 | "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-5.1.1.tgz", 446 | "integrity": "sha512-2NxwbF/hZ0KpepYN0cNbo+FN6XoK7GaHlQhgx/hIZl6Va0bF45RQOOwhLIy8lQDbuCiadSLCBnH2CFYquit5bw==", 447 | "dev": true, 448 | "dependencies": { 449 | "esrecurse": "^4.3.0", 450 | "estraverse": "^4.1.1" 451 | }, 452 | "engines": { 453 | "node": ">=8.0.0" 454 | } 455 | }, 456 | "node_modules/eslint-utils": { 457 | "version": "2.1.0", 458 | "resolved": "https://registry.npmjs.org/eslint-utils/-/eslint-utils-2.1.0.tgz", 459 | "integrity": "sha512-w94dQYoauyvlDc43XnGB8lU3Zt713vNChgt4EWwhXAP2XkBvndfxF0AgIqKOOasjPIPzj9JqgwkwbCYD0/V3Zg==", 460 | "dev": true, 461 | "dependencies": { 462 | "eslint-visitor-keys": "^1.1.0" 463 | }, 464 | "engines": { 465 | "node": ">=6" 466 | }, 467 | "funding": { 468 | "url": "https://github.com/sponsors/mysticatea" 469 | } 470 | }, 471 | "node_modules/eslint-utils/node_modules/eslint-visitor-keys": { 472 | "version": "1.3.0", 473 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-1.3.0.tgz", 474 | "integrity": "sha512-6J72N8UNa462wa/KFODt/PJ3IU60SDpC3QXC1Hjc1BXXpfL2C9R5+AU7jhe0F6GREqVMh4Juu+NY7xn+6dipUQ==", 475 | "dev": true, 476 | "engines": { 477 | "node": ">=4" 478 | } 479 | }, 480 | "node_modules/eslint-visitor-keys": { 481 | "version": "2.0.0", 482 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-2.0.0.tgz", 483 | "integrity": "sha512-QudtT6av5WXels9WjIM7qz1XD1cWGvX4gGXvp/zBn9nXG02D0utdU3Em2m/QjTnrsk6bBjmCygl3rmj118msQQ==", 484 | "dev": true, 485 | "engines": { 486 | "node": ">=10" 487 | } 488 | }, 489 | "node_modules/espree": { 490 | "version": "7.3.1", 491 | "resolved": "https://registry.npmjs.org/espree/-/espree-7.3.1.tgz", 492 | "integrity": "sha512-v3JCNCE64umkFpmkFGqzVKsOT0tN1Zr+ueqLZfpV1Ob8e+CEgPWa+OxCoGH3tnhimMKIaBm4m/vaRpJ/krRz2g==", 493 | "dev": true, 494 | "dependencies": { 495 | "acorn": "^7.4.0", 496 | "acorn-jsx": "^5.3.1", 497 | "eslint-visitor-keys": "^1.3.0" 498 | }, 499 | "engines": { 500 | "node": "^10.12.0 || >=12.0.0" 501 | } 502 | }, 503 | "node_modules/espree/node_modules/eslint-visitor-keys": { 504 | "version": "1.3.0", 505 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-1.3.0.tgz", 506 | "integrity": "sha512-6J72N8UNa462wa/KFODt/PJ3IU60SDpC3QXC1Hjc1BXXpfL2C9R5+AU7jhe0F6GREqVMh4Juu+NY7xn+6dipUQ==", 507 | "dev": true, 508 | "engines": { 509 | "node": ">=4" 510 | } 511 | }, 512 | "node_modules/esprima": { 513 | "version": "4.0.1", 514 | "resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.1.tgz", 515 | "integrity": "sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A==", 516 | "dev": true, 517 | "bin": { 518 | "esparse": "bin/esparse.js", 519 | "esvalidate": "bin/esvalidate.js" 520 | }, 521 | "engines": { 522 | "node": ">=4" 523 | } 524 | }, 525 | "node_modules/esquery": { 526 | "version": "1.4.0", 527 | "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.4.0.tgz", 528 | "integrity": "sha512-cCDispWt5vHHtwMY2YrAQ4ibFkAL8RbH5YGBnZBc90MolvvfkkQcJro/aZiAQUlQ3qgrYS6D6v8Gc5G5CQsc9w==", 529 | "dev": true, 530 | "dependencies": { 531 | "estraverse": "^5.1.0" 532 | }, 533 | "engines": { 534 | "node": ">=0.10" 535 | } 536 | }, 537 | "node_modules/esquery/node_modules/estraverse": { 538 | "version": "5.2.0", 539 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.2.0.tgz", 540 | "integrity": "sha512-BxbNGGNm0RyRYvUdHpIwv9IWzeM9XClbOxwoATuFdOE7ZE6wHL+HQ5T8hoPM+zHvmKzzsEqhgy0GrQ5X13afiQ==", 541 | "dev": true, 542 | "engines": { 543 | "node": ">=4.0" 544 | } 545 | }, 546 | "node_modules/esrecurse": { 547 | "version": "4.3.0", 548 | "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.3.0.tgz", 549 | "integrity": "sha512-KmfKL3b6G+RXvP8N1vr3Tq1kL/oCFgn2NYXEtqP8/L3pKapUA4G8cFVaoF3SU323CD4XypR/ffioHmkti6/Tag==", 550 | "dev": true, 551 | "dependencies": { 552 | "estraverse": "^5.2.0" 553 | }, 554 | "engines": { 555 | "node": ">=4.0" 556 | } 557 | }, 558 | "node_modules/esrecurse/node_modules/estraverse": { 559 | "version": "5.2.0", 560 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.2.0.tgz", 561 | "integrity": "sha512-BxbNGGNm0RyRYvUdHpIwv9IWzeM9XClbOxwoATuFdOE7ZE6wHL+HQ5T8hoPM+zHvmKzzsEqhgy0GrQ5X13afiQ==", 562 | "dev": true, 563 | "engines": { 564 | "node": ">=4.0" 565 | } 566 | }, 567 | "node_modules/estraverse": { 568 | "version": "4.3.0", 569 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-4.3.0.tgz", 570 | "integrity": "sha512-39nnKffWz8xN1BU/2c79n9nB9HDzo0niYUqx6xyqUnyoAnQyyWpOTdZEeiCch8BBu515t4wp9ZmgVfVhn9EBpw==", 571 | "dev": true, 572 | "engines": { 573 | "node": ">=4.0" 574 | } 575 | }, 576 | "node_modules/esutils": { 577 | "version": "2.0.3", 578 | "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz", 579 | "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==", 580 | "dev": true, 581 | "engines": { 582 | "node": ">=0.10.0" 583 | } 584 | }, 585 | "node_modules/fast-deep-equal": { 586 | "version": "3.1.3", 587 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz", 588 | "integrity": "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==", 589 | "dev": true 590 | }, 591 | "node_modules/fast-json-stable-stringify": { 592 | "version": "2.1.0", 593 | "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz", 594 | "integrity": "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==", 595 | "dev": true 596 | }, 597 | "node_modules/fast-levenshtein": { 598 | "version": "2.0.6", 599 | "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", 600 | "integrity": "sha1-PYpcZog6FqMMqGQ+hR8Zuqd5eRc=", 601 | "dev": true 602 | }, 603 | "node_modules/file-entry-cache": { 604 | "version": "6.0.1", 605 | "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-6.0.1.tgz", 606 | "integrity": "sha512-7Gps/XWymbLk2QLYK4NzpMOrYjMhdIxXuIvy2QBsLE6ljuodKvdkWs/cpyJJ3CVIVpH0Oi1Hvg1ovbMzLdFBBg==", 607 | "dev": true, 608 | "dependencies": { 609 | "flat-cache": "^3.0.4" 610 | }, 611 | "engines": { 612 | "node": "^10.12.0 || >=12.0.0" 613 | } 614 | }, 615 | "node_modules/flat-cache": { 616 | "version": "3.0.4", 617 | "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-3.0.4.tgz", 618 | "integrity": "sha512-dm9s5Pw7Jc0GvMYbshN6zchCA9RgQlzzEZX3vylR9IqFfS8XciblUXOKfW6SiuJ0e13eDYZoZV5wdrev7P3Nwg==", 619 | "dev": true, 620 | "dependencies": { 621 | "flatted": "^3.1.0", 622 | "rimraf": "^3.0.2" 623 | }, 624 | "engines": { 625 | "node": "^10.12.0 || >=12.0.0" 626 | } 627 | }, 628 | "node_modules/flatted": { 629 | "version": "3.1.1", 630 | "resolved": "https://registry.npmjs.org/flatted/-/flatted-3.1.1.tgz", 631 | "integrity": "sha512-zAoAQiudy+r5SvnSw3KJy5os/oRJYHzrzja/tBDqrZtNhUw8bt6y8OBzMWcjWr+8liV8Eb6yOhw8WZ7VFZ5ZzA==", 632 | "dev": true 633 | }, 634 | "node_modules/fs.realpath": { 635 | "version": "1.0.0", 636 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 637 | "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=", 638 | "dev": true 639 | }, 640 | "node_modules/function-bind": { 641 | "version": "1.1.1", 642 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", 643 | "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==", 644 | "dev": true 645 | }, 646 | "node_modules/functional-red-black-tree": { 647 | "version": "1.0.1", 648 | "resolved": "https://registry.npmjs.org/functional-red-black-tree/-/functional-red-black-tree-1.0.1.tgz", 649 | "integrity": "sha1-GwqzvVU7Kg1jmdKcDj6gslIHgyc=", 650 | "dev": true 651 | }, 652 | "node_modules/get-intrinsic": { 653 | "version": "1.1.1", 654 | "resolved": "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.1.1.tgz", 655 | "integrity": "sha512-kWZrnVM42QCiEA2Ig1bG8zjoIMOgxWwYCEeNdwY6Tv/cOSeGpcoX4pXHfKUxNKVoArnrEr2e9srnAxxGIraS9Q==", 656 | "dev": true, 657 | "dependencies": { 658 | "function-bind": "^1.1.1", 659 | "has": "^1.0.3", 660 | "has-symbols": "^1.0.1" 661 | }, 662 | "funding": { 663 | "url": "https://github.com/sponsors/ljharb" 664 | } 665 | }, 666 | "node_modules/glob": { 667 | "version": "7.1.6", 668 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.6.tgz", 669 | "integrity": "sha512-LwaxwyZ72Lk7vZINtNNrywX0ZuLyStrdDtabefZKAY5ZGJhVtgdznluResxNmPitE0SAO+O26sWTHeKSI2wMBA==", 670 | "dev": true, 671 | "dependencies": { 672 | "fs.realpath": "^1.0.0", 673 | "inflight": "^1.0.4", 674 | "inherits": "2", 675 | "minimatch": "^3.0.4", 676 | "once": "^1.3.0", 677 | "path-is-absolute": "^1.0.0" 678 | }, 679 | "engines": { 680 | "node": "*" 681 | }, 682 | "funding": { 683 | "url": "https://github.com/sponsors/isaacs" 684 | } 685 | }, 686 | "node_modules/glob-parent": { 687 | "version": "5.1.2", 688 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", 689 | "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", 690 | "dev": true, 691 | "dependencies": { 692 | "is-glob": "^4.0.1" 693 | }, 694 | "engines": { 695 | "node": ">= 6" 696 | } 697 | }, 698 | "node_modules/globals": { 699 | "version": "13.7.0", 700 | "resolved": "https://registry.npmjs.org/globals/-/globals-13.7.0.tgz", 701 | "integrity": "sha512-Aipsz6ZKRxa/xQkZhNg0qIWXT6x6rD46f6x/PCnBomlttdIyAPak4YD9jTmKpZ72uROSMU87qJtcgpgHaVchiA==", 702 | "dev": true, 703 | "dependencies": { 704 | "type-fest": "^0.20.2" 705 | }, 706 | "engines": { 707 | "node": ">=8" 708 | }, 709 | "funding": { 710 | "url": "https://github.com/sponsors/sindresorhus" 711 | } 712 | }, 713 | "node_modules/has": { 714 | "version": "1.0.3", 715 | "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz", 716 | "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==", 717 | "dev": true, 718 | "dependencies": { 719 | "function-bind": "^1.1.1" 720 | }, 721 | "engines": { 722 | "node": ">= 0.4.0" 723 | } 724 | }, 725 | "node_modules/has-flag": { 726 | "version": "4.0.0", 727 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 728 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", 729 | "dev": true, 730 | "engines": { 731 | "node": ">=8" 732 | } 733 | }, 734 | "node_modules/has-symbols": { 735 | "version": "1.0.2", 736 | "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.2.tgz", 737 | "integrity": "sha512-chXa79rL/UC2KlX17jo3vRGz0azaWEx5tGqZg5pO3NUyEJVB17dMruQlzCCOfUvElghKcm5194+BCRvi2Rv/Gw==", 738 | "dev": true, 739 | "engines": { 740 | "node": ">= 0.4" 741 | }, 742 | "funding": { 743 | "url": "https://github.com/sponsors/ljharb" 744 | } 745 | }, 746 | "node_modules/ignore": { 747 | "version": "4.0.6", 748 | "resolved": "https://registry.npmjs.org/ignore/-/ignore-4.0.6.tgz", 749 | "integrity": "sha512-cyFDKrqc/YdcWFniJhzI42+AzS+gNwmUzOSFcRCQYwySuBBBy/KjuxWLZ/FHEH6Moq1NizMOBWyTcv8O4OZIMg==", 750 | "dev": true, 751 | "engines": { 752 | "node": ">= 4" 753 | } 754 | }, 755 | "node_modules/import-fresh": { 756 | "version": "3.3.0", 757 | "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.3.0.tgz", 758 | "integrity": "sha512-veYYhQa+D1QBKznvhUHxb8faxlrwUnxseDAbAp457E0wLNio2bOSKnjYDhMj+YiAq61xrMGhQk9iXVk5FzgQMw==", 759 | "dev": true, 760 | "dependencies": { 761 | "parent-module": "^1.0.0", 762 | "resolve-from": "^4.0.0" 763 | }, 764 | "engines": { 765 | "node": ">=6" 766 | }, 767 | "funding": { 768 | "url": "https://github.com/sponsors/sindresorhus" 769 | } 770 | }, 771 | "node_modules/imurmurhash": { 772 | "version": "0.1.4", 773 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", 774 | "integrity": "sha1-khi5srkoojixPcT7a21XbyMUU+o=", 775 | "dev": true, 776 | "engines": { 777 | "node": ">=0.8.19" 778 | } 779 | }, 780 | "node_modules/inflight": { 781 | "version": "1.0.6", 782 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 783 | "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", 784 | "dev": true, 785 | "dependencies": { 786 | "once": "^1.3.0", 787 | "wrappy": "1" 788 | } 789 | }, 790 | "node_modules/inherits": { 791 | "version": "2.0.4", 792 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 793 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", 794 | "dev": true 795 | }, 796 | "node_modules/is-boolean-object": { 797 | "version": "1.1.0", 798 | "resolved": "https://registry.npmjs.org/is-boolean-object/-/is-boolean-object-1.1.0.tgz", 799 | "integrity": "sha512-a7Uprx8UtD+HWdyYwnD1+ExtTgqQtD2k/1yJgtXP6wnMm8byhkoTZRl+95LLThpzNZJ5aEvi46cdH+ayMFRwmA==", 800 | "dev": true, 801 | "dependencies": { 802 | "call-bind": "^1.0.0" 803 | }, 804 | "engines": { 805 | "node": ">= 0.4" 806 | }, 807 | "funding": { 808 | "url": "https://github.com/sponsors/ljharb" 809 | } 810 | }, 811 | "node_modules/is-extglob": { 812 | "version": "2.1.1", 813 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 814 | "integrity": "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=", 815 | "dev": true, 816 | "engines": { 817 | "node": ">=0.10.0" 818 | } 819 | }, 820 | "node_modules/is-fullwidth-code-point": { 821 | "version": "3.0.0", 822 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 823 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", 824 | "dev": true, 825 | "engines": { 826 | "node": ">=8" 827 | } 828 | }, 829 | "node_modules/is-glob": { 830 | "version": "4.0.1", 831 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.1.tgz", 832 | "integrity": "sha512-5G0tKtBTFImOqDnLB2hG6Bp2qcKEFduo4tZu9MT/H6NQv/ghhy30o55ufafxJ/LdH79LLs2Kfrn85TLKyA7BUg==", 833 | "dev": true, 834 | "dependencies": { 835 | "is-extglob": "^2.1.1" 836 | }, 837 | "engines": { 838 | "node": ">=0.10.0" 839 | } 840 | }, 841 | "node_modules/is-number-object": { 842 | "version": "1.0.4", 843 | "resolved": "https://registry.npmjs.org/is-number-object/-/is-number-object-1.0.4.tgz", 844 | "integrity": "sha512-zohwelOAur+5uXtk8O3GPQ1eAcu4ZX3UwxQhUlfFFMNpUd83gXgjbhJh6HmB6LUNV/ieOLQuDwJO3dWJosUeMw==", 845 | "dev": true, 846 | "engines": { 847 | "node": ">= 0.4" 848 | }, 849 | "funding": { 850 | "url": "https://github.com/sponsors/ljharb" 851 | } 852 | }, 853 | "node_modules/is-string": { 854 | "version": "1.0.5", 855 | "resolved": "https://registry.npmjs.org/is-string/-/is-string-1.0.5.tgz", 856 | "integrity": "sha512-buY6VNRjhQMiF1qWDouloZlQbRhDPCebwxSjxMjxgemYT46YMd2NR0/H+fBhEfWX4A/w9TBJ+ol+okqJKFE6vQ==", 857 | "dev": true, 858 | "engines": { 859 | "node": ">= 0.4" 860 | }, 861 | "funding": { 862 | "url": "https://github.com/sponsors/ljharb" 863 | } 864 | }, 865 | "node_modules/isexe": { 866 | "version": "2.0.0", 867 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 868 | "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=", 869 | "dev": true 870 | }, 871 | "node_modules/js-tokens": { 872 | "version": "4.0.0", 873 | "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", 874 | "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==", 875 | "dev": true 876 | }, 877 | "node_modules/js-yaml": { 878 | "version": "3.14.1", 879 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.14.1.tgz", 880 | "integrity": "sha512-okMH7OXXJ7YrN9Ok3/SXrnu4iX9yOk+25nqX4imS2npuvTYDmo/QEZoqwZkYaIDk3jVvBOTOIEgEhaLOynBS9g==", 881 | "dev": true, 882 | "dependencies": { 883 | "argparse": "^1.0.7", 884 | "esprima": "^4.0.0" 885 | }, 886 | "bin": { 887 | "js-yaml": "bin/js-yaml.js" 888 | } 889 | }, 890 | "node_modules/json-schema-traverse": { 891 | "version": "0.4.1", 892 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", 893 | "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==", 894 | "dev": true 895 | }, 896 | "node_modules/json-stable-stringify-without-jsonify": { 897 | "version": "1.0.1", 898 | "resolved": "https://registry.npmjs.org/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz", 899 | "integrity": "sha1-nbe1lJatPzz+8wp1FC0tkwrXJlE=", 900 | "dev": true 901 | }, 902 | "node_modules/levn": { 903 | "version": "0.4.1", 904 | "resolved": "https://registry.npmjs.org/levn/-/levn-0.4.1.tgz", 905 | "integrity": "sha512-+bT2uH4E5LGE7h/n3evcS/sQlJXCpIp6ym8OWJ5eV6+67Dsql/LaaT7qJBAt2rzfoa/5QBGBhxDix1dMt2kQKQ==", 906 | "dev": true, 907 | "dependencies": { 908 | "prelude-ls": "^1.2.1", 909 | "type-check": "~0.4.0" 910 | }, 911 | "engines": { 912 | "node": ">= 0.8.0" 913 | } 914 | }, 915 | "node_modules/lodash": { 916 | "version": "4.17.21", 917 | "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.21.tgz", 918 | "integrity": "sha512-v2kDEe57lecTulaDIuNTPy3Ry4gLGJ6Z1O3vE1krgXZNrsQ+LFTGHVxVjcXPs17LhbZVGedAJv8XZ1tvj5FvSg==", 919 | "dev": true 920 | }, 921 | "node_modules/lodash.clonedeep": { 922 | "version": "4.5.0", 923 | "resolved": "https://registry.npmjs.org/lodash.clonedeep/-/lodash.clonedeep-4.5.0.tgz", 924 | "integrity": "sha1-4j8/nE+Pvd6HJSnBBxhXoIblzO8=", 925 | "dev": true 926 | }, 927 | "node_modules/lodash.flatten": { 928 | "version": "4.4.0", 929 | "resolved": "https://registry.npmjs.org/lodash.flatten/-/lodash.flatten-4.4.0.tgz", 930 | "integrity": "sha1-8xwiIlqWMtK7+OSt2+8kCqdlph8=", 931 | "dev": true 932 | }, 933 | "node_modules/lodash.truncate": { 934 | "version": "4.4.2", 935 | "resolved": "https://registry.npmjs.org/lodash.truncate/-/lodash.truncate-4.4.2.tgz", 936 | "integrity": "sha1-WjUNoLERO4N+z//VgSy+WNbq4ZM=", 937 | "dev": true 938 | }, 939 | "node_modules/lru-cache": { 940 | "version": "6.0.0", 941 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", 942 | "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", 943 | "dev": true, 944 | "dependencies": { 945 | "yallist": "^4.0.0" 946 | }, 947 | "engines": { 948 | "node": ">=10" 949 | } 950 | }, 951 | "node_modules/minimatch": { 952 | "version": "3.0.4", 953 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", 954 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", 955 | "dev": true, 956 | "dependencies": { 957 | "brace-expansion": "^1.1.7" 958 | }, 959 | "engines": { 960 | "node": "*" 961 | } 962 | }, 963 | "node_modules/ms": { 964 | "version": "2.1.2", 965 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 966 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 967 | "dev": true 968 | }, 969 | "node_modules/natural-compare": { 970 | "version": "1.4.0", 971 | "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", 972 | "integrity": "sha1-Sr6/7tdUHywnrPspvbvRXI1bpPc=", 973 | "dev": true 974 | }, 975 | "node_modules/once": { 976 | "version": "1.4.0", 977 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 978 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", 979 | "dev": true, 980 | "dependencies": { 981 | "wrappy": "1" 982 | } 983 | }, 984 | "node_modules/optionator": { 985 | "version": "0.9.1", 986 | "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.9.1.tgz", 987 | "integrity": "sha512-74RlY5FCnhq4jRxVUPKDaRwrVNXMqsGsiW6AJw4XK8hmtm10wC0ypZBLw5IIp85NZMr91+qd1RvvENwg7jjRFw==", 988 | "dev": true, 989 | "dependencies": { 990 | "deep-is": "^0.1.3", 991 | "fast-levenshtein": "^2.0.6", 992 | "levn": "^0.4.1", 993 | "prelude-ls": "^1.2.1", 994 | "type-check": "^0.4.0", 995 | "word-wrap": "^1.2.3" 996 | }, 997 | "engines": { 998 | "node": ">= 0.8.0" 999 | } 1000 | }, 1001 | "node_modules/parent-module": { 1002 | "version": "1.0.1", 1003 | "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz", 1004 | "integrity": "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==", 1005 | "dev": true, 1006 | "dependencies": { 1007 | "callsites": "^3.0.0" 1008 | }, 1009 | "engines": { 1010 | "node": ">=6" 1011 | } 1012 | }, 1013 | "node_modules/path-is-absolute": { 1014 | "version": "1.0.1", 1015 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 1016 | "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=", 1017 | "dev": true, 1018 | "engines": { 1019 | "node": ">=0.10.0" 1020 | } 1021 | }, 1022 | "node_modules/path-key": { 1023 | "version": "3.1.1", 1024 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", 1025 | "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", 1026 | "dev": true, 1027 | "engines": { 1028 | "node": ">=8" 1029 | } 1030 | }, 1031 | "node_modules/prelude-ls": { 1032 | "version": "1.2.1", 1033 | "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.2.1.tgz", 1034 | "integrity": "sha512-vkcDPrRZo1QZLbn5RLGPpg/WmIQ65qoWWhcGKf/b5eplkkarX0m9z8ppCat4mlOqUsWpyNuYgO3VRyrYHSzX5g==", 1035 | "dev": true, 1036 | "engines": { 1037 | "node": ">= 0.8.0" 1038 | } 1039 | }, 1040 | "node_modules/progress": { 1041 | "version": "2.0.3", 1042 | "resolved": "https://registry.npmjs.org/progress/-/progress-2.0.3.tgz", 1043 | "integrity": "sha512-7PiHtLll5LdnKIMw100I+8xJXR5gW2QwWYkT6iJva0bXitZKa/XMrSbdmg3r2Xnaidz9Qumd0VPaMrZlF9V9sA==", 1044 | "dev": true, 1045 | "engines": { 1046 | "node": ">=0.4.0" 1047 | } 1048 | }, 1049 | "node_modules/punycode": { 1050 | "version": "2.1.1", 1051 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.1.1.tgz", 1052 | "integrity": "sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A==", 1053 | "dev": true, 1054 | "engines": { 1055 | "node": ">=6" 1056 | } 1057 | }, 1058 | "node_modules/regexpp": { 1059 | "version": "3.1.0", 1060 | "resolved": "https://registry.npmjs.org/regexpp/-/regexpp-3.1.0.tgz", 1061 | "integrity": "sha512-ZOIzd8yVsQQA7j8GCSlPGXwg5PfmA1mrq0JP4nGhh54LaKN3xdai/vHUDu74pKwV8OxseMS65u2NImosQcSD0Q==", 1062 | "dev": true, 1063 | "engines": { 1064 | "node": ">=8" 1065 | }, 1066 | "funding": { 1067 | "url": "https://github.com/sponsors/mysticatea" 1068 | } 1069 | }, 1070 | "node_modules/require-from-string": { 1071 | "version": "2.0.2", 1072 | "resolved": "https://registry.npmjs.org/require-from-string/-/require-from-string-2.0.2.tgz", 1073 | "integrity": "sha512-Xf0nWe6RseziFMu+Ap9biiUbmplq6S9/p+7w7YXP/JBHhrUDDUhwa+vANyubuqfZWTveU//DYVGsDG7RKL/vEw==", 1074 | "dev": true, 1075 | "engines": { 1076 | "node": ">=0.10.0" 1077 | } 1078 | }, 1079 | "node_modules/resolve-from": { 1080 | "version": "4.0.0", 1081 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz", 1082 | "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==", 1083 | "dev": true, 1084 | "engines": { 1085 | "node": ">=4" 1086 | } 1087 | }, 1088 | "node_modules/rimraf": { 1089 | "version": "3.0.2", 1090 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-3.0.2.tgz", 1091 | "integrity": "sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA==", 1092 | "dev": true, 1093 | "dependencies": { 1094 | "glob": "^7.1.3" 1095 | }, 1096 | "bin": { 1097 | "rimraf": "bin.js" 1098 | }, 1099 | "funding": { 1100 | "url": "https://github.com/sponsors/isaacs" 1101 | } 1102 | }, 1103 | "node_modules/semver": { 1104 | "version": "7.3.5", 1105 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.3.5.tgz", 1106 | "integrity": "sha512-PoeGJYh8HK4BTO/a9Tf6ZG3veo/A7ZVsYrSA6J8ny9nb3B1VrpkuN+z9OE5wfE5p6H4LchYZsegiQgbJD94ZFQ==", 1107 | "dev": true, 1108 | "dependencies": { 1109 | "lru-cache": "^6.0.0" 1110 | }, 1111 | "bin": { 1112 | "semver": "bin/semver.js" 1113 | }, 1114 | "engines": { 1115 | "node": ">=10" 1116 | } 1117 | }, 1118 | "node_modules/shebang-command": { 1119 | "version": "2.0.0", 1120 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", 1121 | "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", 1122 | "dev": true, 1123 | "dependencies": { 1124 | "shebang-regex": "^3.0.0" 1125 | }, 1126 | "engines": { 1127 | "node": ">=8" 1128 | } 1129 | }, 1130 | "node_modules/shebang-regex": { 1131 | "version": "3.0.0", 1132 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", 1133 | "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", 1134 | "dev": true, 1135 | "engines": { 1136 | "node": ">=8" 1137 | } 1138 | }, 1139 | "node_modules/slice-ansi": { 1140 | "version": "4.0.0", 1141 | "resolved": "https://registry.npmjs.org/slice-ansi/-/slice-ansi-4.0.0.tgz", 1142 | "integrity": "sha512-qMCMfhY040cVHT43K9BFygqYbUPFZKHOg7K73mtTWJRb8pyP3fzf4Ixd5SzdEJQ6MRUg/WBnOLxghZtKKurENQ==", 1143 | "dev": true, 1144 | "dependencies": { 1145 | "ansi-styles": "^4.0.0", 1146 | "astral-regex": "^2.0.0", 1147 | "is-fullwidth-code-point": "^3.0.0" 1148 | }, 1149 | "engines": { 1150 | "node": ">=10" 1151 | }, 1152 | "funding": { 1153 | "url": "https://github.com/chalk/slice-ansi?sponsor=1" 1154 | } 1155 | }, 1156 | "node_modules/sprintf-js": { 1157 | "version": "1.0.3", 1158 | "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.0.3.tgz", 1159 | "integrity": "sha1-BOaSb2YolTVPPdAVIDYzuFcpfiw=", 1160 | "dev": true 1161 | }, 1162 | "node_modules/string-width": { 1163 | "version": "4.2.2", 1164 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.2.tgz", 1165 | "integrity": "sha512-XBJbT3N4JhVumXE0eoLU9DCjcaF92KLNqTmFCnG1pf8duUxFGwtP6AD6nkjw9a3IdiRtL3E2w3JDiE/xi3vOeA==", 1166 | "dev": true, 1167 | "dependencies": { 1168 | "emoji-regex": "^8.0.0", 1169 | "is-fullwidth-code-point": "^3.0.0", 1170 | "strip-ansi": "^6.0.0" 1171 | }, 1172 | "engines": { 1173 | "node": ">=8" 1174 | } 1175 | }, 1176 | "node_modules/strip-ansi": { 1177 | "version": "6.0.0", 1178 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.0.tgz", 1179 | "integrity": "sha512-AuvKTrTfQNYNIctbR1K/YGTR1756GycPsg7b9bdV9Duqur4gv6aKqHXah67Z8ImS7WEz5QVcOtlfW2rZEugt6w==", 1180 | "dev": true, 1181 | "dependencies": { 1182 | "ansi-regex": "^5.0.0" 1183 | }, 1184 | "engines": { 1185 | "node": ">=8" 1186 | } 1187 | }, 1188 | "node_modules/strip-json-comments": { 1189 | "version": "3.1.1", 1190 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz", 1191 | "integrity": "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==", 1192 | "dev": true, 1193 | "engines": { 1194 | "node": ">=8" 1195 | }, 1196 | "funding": { 1197 | "url": "https://github.com/sponsors/sindresorhus" 1198 | } 1199 | }, 1200 | "node_modules/supports-color": { 1201 | "version": "7.2.0", 1202 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", 1203 | "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", 1204 | "dev": true, 1205 | "dependencies": { 1206 | "has-flag": "^4.0.0" 1207 | }, 1208 | "engines": { 1209 | "node": ">=8" 1210 | } 1211 | }, 1212 | "node_modules/table": { 1213 | "version": "6.0.9", 1214 | "resolved": "https://registry.npmjs.org/table/-/table-6.0.9.tgz", 1215 | "integrity": "sha512-F3cLs9a3hL1Z7N4+EkSscsel3z55XT950AvB05bwayrNg5T1/gykXtigioTAjbltvbMSJvvhFCbnf6mX+ntnJQ==", 1216 | "dev": true, 1217 | "dependencies": { 1218 | "ajv": "^8.0.1", 1219 | "is-boolean-object": "^1.1.0", 1220 | "is-number-object": "^1.0.4", 1221 | "is-string": "^1.0.5", 1222 | "lodash.clonedeep": "^4.5.0", 1223 | "lodash.flatten": "^4.4.0", 1224 | "lodash.truncate": "^4.4.2", 1225 | "slice-ansi": "^4.0.0", 1226 | "string-width": "^4.2.0" 1227 | }, 1228 | "engines": { 1229 | "node": ">=10.0.0" 1230 | } 1231 | }, 1232 | "node_modules/table/node_modules/ajv": { 1233 | "version": "8.0.5", 1234 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-8.0.5.tgz", 1235 | "integrity": "sha512-RkiLa/AeJx7+9OvniQ/qeWu0w74A8DiPPBclQ6ji3ZQkv5KamO+QGpqmi7O4JIw3rHGUXZ6CoP9tsAkn3gyazg==", 1236 | "dev": true, 1237 | "dependencies": { 1238 | "fast-deep-equal": "^3.1.1", 1239 | "json-schema-traverse": "^1.0.0", 1240 | "require-from-string": "^2.0.2", 1241 | "uri-js": "^4.2.2" 1242 | }, 1243 | "funding": { 1244 | "type": "github", 1245 | "url": "https://github.com/sponsors/epoberezkin" 1246 | } 1247 | }, 1248 | "node_modules/table/node_modules/json-schema-traverse": { 1249 | "version": "1.0.0", 1250 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-1.0.0.tgz", 1251 | "integrity": "sha512-NM8/P9n3XjXhIZn1lLhkFaACTOURQXjWhV4BA/RnOv8xvgqtqpAX9IO4mRQxSx1Rlo4tqzeqb0sOlruaOy3dug==", 1252 | "dev": true 1253 | }, 1254 | "node_modules/text-table": { 1255 | "version": "0.2.0", 1256 | "resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz", 1257 | "integrity": "sha1-f17oI66AUgfACvLfSoTsP8+lcLQ=", 1258 | "dev": true 1259 | }, 1260 | "node_modules/type-check": { 1261 | "version": "0.4.0", 1262 | "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.4.0.tgz", 1263 | "integrity": "sha512-XleUoc9uwGXqjWwXaUTZAmzMcFZ5858QA2vvx1Ur5xIcixXIP+8LnFDgRplU30us6teqdlskFfu+ae4K79Ooew==", 1264 | "dev": true, 1265 | "dependencies": { 1266 | "prelude-ls": "^1.2.1" 1267 | }, 1268 | "engines": { 1269 | "node": ">= 0.8.0" 1270 | } 1271 | }, 1272 | "node_modules/type-fest": { 1273 | "version": "0.20.2", 1274 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.20.2.tgz", 1275 | "integrity": "sha512-Ne+eE4r0/iWnpAxD852z3A+N0Bt5RN//NjJwRd2VFHEmrywxf5vsZlh4R6lixl6B+wz/8d+maTSAkN1FIkI3LQ==", 1276 | "dev": true, 1277 | "engines": { 1278 | "node": ">=10" 1279 | }, 1280 | "funding": { 1281 | "url": "https://github.com/sponsors/sindresorhus" 1282 | } 1283 | }, 1284 | "node_modules/uri-js": { 1285 | "version": "4.4.1", 1286 | "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.4.1.tgz", 1287 | "integrity": "sha512-7rKUyy33Q1yc98pQ1DAmLtwX109F7TIfWlW1Ydo8Wl1ii1SeHieeh0HHfPeL2fMXK6z0s8ecKs9frCuLJvndBg==", 1288 | "dev": true, 1289 | "dependencies": { 1290 | "punycode": "^2.1.0" 1291 | } 1292 | }, 1293 | "node_modules/v8-compile-cache": { 1294 | "version": "2.3.0", 1295 | "resolved": "https://registry.npmjs.org/v8-compile-cache/-/v8-compile-cache-2.3.0.tgz", 1296 | "integrity": "sha512-l8lCEmLcLYZh4nbunNZvQCJc5pv7+RCwa8q/LdUx8u7lsWvPDKmpodJAJNwkAhJC//dFY48KuIEmjtd4RViDrA==", 1297 | "dev": true 1298 | }, 1299 | "node_modules/which": { 1300 | "version": "2.0.2", 1301 | "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", 1302 | "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", 1303 | "dev": true, 1304 | "dependencies": { 1305 | "isexe": "^2.0.0" 1306 | }, 1307 | "bin": { 1308 | "node-which": "bin/node-which" 1309 | }, 1310 | "engines": { 1311 | "node": ">= 8" 1312 | } 1313 | }, 1314 | "node_modules/word-wrap": { 1315 | "version": "1.2.3", 1316 | "resolved": "https://registry.npmjs.org/word-wrap/-/word-wrap-1.2.3.tgz", 1317 | "integrity": "sha512-Hz/mrNwitNRh/HUAtM/VT/5VH+ygD6DV7mYKZAtHOrbs8U7lvPS6xf7EJKMF0uW1KJCl0H701g3ZGus+muE5vQ==", 1318 | "dev": true, 1319 | "engines": { 1320 | "node": ">=0.10.0" 1321 | } 1322 | }, 1323 | "node_modules/wrappy": { 1324 | "version": "1.0.2", 1325 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 1326 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=", 1327 | "dev": true 1328 | }, 1329 | "node_modules/yallist": { 1330 | "version": "4.0.0", 1331 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", 1332 | "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", 1333 | "dev": true 1334 | } 1335 | }, 1336 | "dependencies": { 1337 | "@babel/code-frame": { 1338 | "version": "7.12.11", 1339 | "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.12.11.tgz", 1340 | "integrity": "sha512-Zt1yodBx1UcyiePMSkWnU4hPqhwq7hGi2nFL1LeA3EUl+q2LQx16MISgJ0+z7dnmgvP9QtIleuETGOiOH1RcIw==", 1341 | "dev": true, 1342 | "requires": { 1343 | "@babel/highlight": "^7.10.4" 1344 | } 1345 | }, 1346 | "@babel/helper-validator-identifier": { 1347 | "version": "7.12.11", 1348 | "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.12.11.tgz", 1349 | "integrity": "sha512-np/lG3uARFybkoHokJUmf1QfEvRVCPbmQeUQpKow5cQ3xWrV9i3rUHodKDJPQfTVX61qKi+UdYk8kik84n7XOw==", 1350 | "dev": true 1351 | }, 1352 | "@babel/highlight": { 1353 | "version": "7.13.10", 1354 | "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.13.10.tgz", 1355 | "integrity": "sha512-5aPpe5XQPzflQrFwL1/QoeHkP2MsA4JCntcXHRhEsdsfPVkvPi2w7Qix4iV7t5S/oC9OodGrggd8aco1g3SZFg==", 1356 | "dev": true, 1357 | "requires": { 1358 | "@babel/helper-validator-identifier": "^7.12.11", 1359 | "chalk": "^2.0.0", 1360 | "js-tokens": "^4.0.0" 1361 | }, 1362 | "dependencies": { 1363 | "ansi-styles": { 1364 | "version": "3.2.1", 1365 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", 1366 | "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", 1367 | "dev": true, 1368 | "requires": { 1369 | "color-convert": "^1.9.0" 1370 | } 1371 | }, 1372 | "chalk": { 1373 | "version": "2.4.2", 1374 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", 1375 | "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", 1376 | "dev": true, 1377 | "requires": { 1378 | "ansi-styles": "^3.2.1", 1379 | "escape-string-regexp": "^1.0.5", 1380 | "supports-color": "^5.3.0" 1381 | } 1382 | }, 1383 | "color-convert": { 1384 | "version": "1.9.3", 1385 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", 1386 | "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", 1387 | "dev": true, 1388 | "requires": { 1389 | "color-name": "1.1.3" 1390 | } 1391 | }, 1392 | "color-name": { 1393 | "version": "1.1.3", 1394 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", 1395 | "integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=", 1396 | "dev": true 1397 | }, 1398 | "has-flag": { 1399 | "version": "3.0.0", 1400 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 1401 | "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=", 1402 | "dev": true 1403 | }, 1404 | "supports-color": { 1405 | "version": "5.5.0", 1406 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 1407 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 1408 | "dev": true, 1409 | "requires": { 1410 | "has-flag": "^3.0.0" 1411 | } 1412 | } 1413 | } 1414 | }, 1415 | "@eslint/eslintrc": { 1416 | "version": "0.4.0", 1417 | "resolved": "https://registry.npmjs.org/@eslint/eslintrc/-/eslintrc-0.4.0.tgz", 1418 | "integrity": "sha512-2ZPCc+uNbjV5ERJr+aKSPRwZgKd2z11x0EgLvb1PURmUrn9QNRXFqje0Ldq454PfAVyaJYyrDvvIKSFP4NnBog==", 1419 | "dev": true, 1420 | "requires": { 1421 | "ajv": "^6.12.4", 1422 | "debug": "^4.1.1", 1423 | "espree": "^7.3.0", 1424 | "globals": "^12.1.0", 1425 | "ignore": "^4.0.6", 1426 | "import-fresh": "^3.2.1", 1427 | "js-yaml": "^3.13.1", 1428 | "minimatch": "^3.0.4", 1429 | "strip-json-comments": "^3.1.1" 1430 | }, 1431 | "dependencies": { 1432 | "globals": { 1433 | "version": "12.4.0", 1434 | "resolved": "https://registry.npmjs.org/globals/-/globals-12.4.0.tgz", 1435 | "integrity": "sha512-BWICuzzDvDoH54NHKCseDanAhE3CeDorgDL5MT6LMXXj2WCnd9UC2szdk4AWLfjdgNBCXLUanXYcpBBKOSWGwg==", 1436 | "dev": true, 1437 | "requires": { 1438 | "type-fest": "^0.8.1" 1439 | } 1440 | }, 1441 | "type-fest": { 1442 | "version": "0.8.1", 1443 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.8.1.tgz", 1444 | "integrity": "sha512-4dbzIzqvjtgiM5rw1k5rEHtBANKmdudhGyBEajN01fEyhaAIhsoKNy6y7+IN93IfpFtwY9iqi7kD+xwKhQsNJA==", 1445 | "dev": true 1446 | } 1447 | } 1448 | }, 1449 | "acorn": { 1450 | "version": "7.4.1", 1451 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-7.4.1.tgz", 1452 | "integrity": "sha512-nQyp0o1/mNdbTO1PO6kHkwSrmgZ0MT/jCCpNiwbUjGoRN4dlBhqJtoQuCnEOKzgTVwg0ZWiCoQy6SxMebQVh8A==", 1453 | "dev": true 1454 | }, 1455 | "acorn-jsx": { 1456 | "version": "5.3.1", 1457 | "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.3.1.tgz", 1458 | "integrity": "sha512-K0Ptm/47OKfQRpNQ2J/oIN/3QYiK6FwW+eJbILhsdxh2WTLdl+30o8aGdTbm5JbffpFFAg/g+zi1E+jvJha5ng==", 1459 | "dev": true, 1460 | "requires": {} 1461 | }, 1462 | "ajv": { 1463 | "version": "6.12.6", 1464 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.12.6.tgz", 1465 | "integrity": "sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g==", 1466 | "dev": true, 1467 | "requires": { 1468 | "fast-deep-equal": "^3.1.1", 1469 | "fast-json-stable-stringify": "^2.0.0", 1470 | "json-schema-traverse": "^0.4.1", 1471 | "uri-js": "^4.2.2" 1472 | } 1473 | }, 1474 | "ansi-colors": { 1475 | "version": "4.1.1", 1476 | "resolved": "https://registry.npmjs.org/ansi-colors/-/ansi-colors-4.1.1.tgz", 1477 | "integrity": "sha512-JoX0apGbHaUJBNl6yF+p6JAFYZ666/hhCGKN5t9QFjbJQKUU/g8MNbFDbvfrgKXvI1QpZplPOnwIo99lX/AAmA==", 1478 | "dev": true 1479 | }, 1480 | "ansi-regex": { 1481 | "version": "5.0.0", 1482 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.0.tgz", 1483 | "integrity": "sha512-bY6fj56OUQ0hU1KjFNDQuJFezqKdrAyFdIevADiqrWHwSlbmBNMHp5ak2f40Pm8JTFyM2mqxkG6ngkHO11f/lg==", 1484 | "dev": true 1485 | }, 1486 | "ansi-styles": { 1487 | "version": "4.3.0", 1488 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 1489 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 1490 | "dev": true, 1491 | "requires": { 1492 | "color-convert": "^2.0.1" 1493 | } 1494 | }, 1495 | "argparse": { 1496 | "version": "1.0.10", 1497 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-1.0.10.tgz", 1498 | "integrity": "sha512-o5Roy6tNG4SL/FOkCAN6RzjiakZS25RLYFrcMttJqbdd8BWrnA+fGz57iN5Pb06pvBGvl5gQ0B48dJlslXvoTg==", 1499 | "dev": true, 1500 | "requires": { 1501 | "sprintf-js": "~1.0.2" 1502 | } 1503 | }, 1504 | "astral-regex": { 1505 | "version": "2.0.0", 1506 | "resolved": "https://registry.npmjs.org/astral-regex/-/astral-regex-2.0.0.tgz", 1507 | "integrity": "sha512-Z7tMw1ytTXt5jqMcOP+OQteU1VuNK9Y02uuJtKQ1Sv69jXQKKg5cibLwGJow8yzZP+eAc18EmLGPal0bp36rvQ==", 1508 | "dev": true 1509 | }, 1510 | "balanced-match": { 1511 | "version": "1.0.0", 1512 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz", 1513 | "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=", 1514 | "dev": true 1515 | }, 1516 | "brace-expansion": { 1517 | "version": "1.1.11", 1518 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 1519 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 1520 | "dev": true, 1521 | "requires": { 1522 | "balanced-match": "^1.0.0", 1523 | "concat-map": "0.0.1" 1524 | } 1525 | }, 1526 | "call-bind": { 1527 | "version": "1.0.2", 1528 | "resolved": "https://registry.npmjs.org/call-bind/-/call-bind-1.0.2.tgz", 1529 | "integrity": "sha512-7O+FbCihrB5WGbFYesctwmTKae6rOiIzmz1icreWJ+0aA7LJfuqhEso2T9ncpcFtzMQtzXf2QGGueWJGTYsqrA==", 1530 | "dev": true, 1531 | "requires": { 1532 | "function-bind": "^1.1.1", 1533 | "get-intrinsic": "^1.0.2" 1534 | } 1535 | }, 1536 | "callsites": { 1537 | "version": "3.1.0", 1538 | "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz", 1539 | "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==", 1540 | "dev": true 1541 | }, 1542 | "chalk": { 1543 | "version": "4.1.0", 1544 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.0.tgz", 1545 | "integrity": "sha512-qwx12AxXe2Q5xQ43Ac//I6v5aXTipYrSESdOgzrN+9XjgEpyjpKuvSGaN4qE93f7TQTlerQQ8S+EQ0EyDoVL1A==", 1546 | "dev": true, 1547 | "requires": { 1548 | "ansi-styles": "^4.1.0", 1549 | "supports-color": "^7.1.0" 1550 | } 1551 | }, 1552 | "color-convert": { 1553 | "version": "2.0.1", 1554 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 1555 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 1556 | "dev": true, 1557 | "requires": { 1558 | "color-name": "~1.1.4" 1559 | } 1560 | }, 1561 | "color-name": { 1562 | "version": "1.1.4", 1563 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 1564 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 1565 | "dev": true 1566 | }, 1567 | "concat-map": { 1568 | "version": "0.0.1", 1569 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 1570 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=", 1571 | "dev": true 1572 | }, 1573 | "cross-spawn": { 1574 | "version": "7.0.3", 1575 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz", 1576 | "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==", 1577 | "dev": true, 1578 | "requires": { 1579 | "path-key": "^3.1.0", 1580 | "shebang-command": "^2.0.0", 1581 | "which": "^2.0.1" 1582 | } 1583 | }, 1584 | "debug": { 1585 | "version": "4.3.1", 1586 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.1.tgz", 1587 | "integrity": "sha512-doEwdvm4PCeK4K3RQN2ZC2BYUBaxwLARCqZmMjtF8a51J2Rb0xpVloFRnCODwqjpwnAoao4pelN8l3RJdv3gRQ==", 1588 | "dev": true, 1589 | "requires": { 1590 | "ms": "2.1.2" 1591 | } 1592 | }, 1593 | "deep-is": { 1594 | "version": "0.1.3", 1595 | "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.3.tgz", 1596 | "integrity": "sha1-s2nW+128E+7PUk+RsHD+7cNXzzQ=", 1597 | "dev": true 1598 | }, 1599 | "doctrine": { 1600 | "version": "3.0.0", 1601 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-3.0.0.tgz", 1602 | "integrity": "sha512-yS+Q5i3hBf7GBkd4KG8a7eBNNWNGLTaEwwYWUijIYM7zrlYDM0BFXHjjPWlWZ1Rg7UaddZeIDmi9jF3HmqiQ2w==", 1603 | "dev": true, 1604 | "requires": { 1605 | "esutils": "^2.0.2" 1606 | } 1607 | }, 1608 | "emoji-regex": { 1609 | "version": "8.0.0", 1610 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 1611 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", 1612 | "dev": true 1613 | }, 1614 | "enquirer": { 1615 | "version": "2.3.6", 1616 | "resolved": "https://registry.npmjs.org/enquirer/-/enquirer-2.3.6.tgz", 1617 | "integrity": "sha512-yjNnPr315/FjS4zIsUxYguYUPP2e1NK4d7E7ZOLiyYCcbFBiTMyID+2wvm2w6+pZ/odMA7cRkjhsPbltwBOrLg==", 1618 | "dev": true, 1619 | "requires": { 1620 | "ansi-colors": "^4.1.1" 1621 | } 1622 | }, 1623 | "escape-string-regexp": { 1624 | "version": "1.0.5", 1625 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", 1626 | "integrity": "sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ=", 1627 | "dev": true 1628 | }, 1629 | "eslint": { 1630 | "version": "7.23.0", 1631 | "resolved": "https://registry.npmjs.org/eslint/-/eslint-7.23.0.tgz", 1632 | "integrity": "sha512-kqvNVbdkjzpFy0XOszNwjkKzZ+6TcwCQ/h+ozlcIWwaimBBuhlQ4nN6kbiM2L+OjDcznkTJxzYfRFH92sx4a0Q==", 1633 | "dev": true, 1634 | "requires": { 1635 | "@babel/code-frame": "7.12.11", 1636 | "@eslint/eslintrc": "^0.4.0", 1637 | "ajv": "^6.10.0", 1638 | "chalk": "^4.0.0", 1639 | "cross-spawn": "^7.0.2", 1640 | "debug": "^4.0.1", 1641 | "doctrine": "^3.0.0", 1642 | "enquirer": "^2.3.5", 1643 | "eslint-scope": "^5.1.1", 1644 | "eslint-utils": "^2.1.0", 1645 | "eslint-visitor-keys": "^2.0.0", 1646 | "espree": "^7.3.1", 1647 | "esquery": "^1.4.0", 1648 | "esutils": "^2.0.2", 1649 | "file-entry-cache": "^6.0.1", 1650 | "functional-red-black-tree": "^1.0.1", 1651 | "glob-parent": "^5.0.0", 1652 | "globals": "^13.6.0", 1653 | "ignore": "^4.0.6", 1654 | "import-fresh": "^3.0.0", 1655 | "imurmurhash": "^0.1.4", 1656 | "is-glob": "^4.0.0", 1657 | "js-yaml": "^3.13.1", 1658 | "json-stable-stringify-without-jsonify": "^1.0.1", 1659 | "levn": "^0.4.1", 1660 | "lodash": "^4.17.21", 1661 | "minimatch": "^3.0.4", 1662 | "natural-compare": "^1.4.0", 1663 | "optionator": "^0.9.1", 1664 | "progress": "^2.0.0", 1665 | "regexpp": "^3.1.0", 1666 | "semver": "^7.2.1", 1667 | "strip-ansi": "^6.0.0", 1668 | "strip-json-comments": "^3.1.0", 1669 | "table": "^6.0.4", 1670 | "text-table": "^0.2.0", 1671 | "v8-compile-cache": "^2.0.3" 1672 | } 1673 | }, 1674 | "eslint-scope": { 1675 | "version": "5.1.1", 1676 | "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-5.1.1.tgz", 1677 | "integrity": "sha512-2NxwbF/hZ0KpepYN0cNbo+FN6XoK7GaHlQhgx/hIZl6Va0bF45RQOOwhLIy8lQDbuCiadSLCBnH2CFYquit5bw==", 1678 | "dev": true, 1679 | "requires": { 1680 | "esrecurse": "^4.3.0", 1681 | "estraverse": "^4.1.1" 1682 | } 1683 | }, 1684 | "eslint-utils": { 1685 | "version": "2.1.0", 1686 | "resolved": "https://registry.npmjs.org/eslint-utils/-/eslint-utils-2.1.0.tgz", 1687 | "integrity": "sha512-w94dQYoauyvlDc43XnGB8lU3Zt713vNChgt4EWwhXAP2XkBvndfxF0AgIqKOOasjPIPzj9JqgwkwbCYD0/V3Zg==", 1688 | "dev": true, 1689 | "requires": { 1690 | "eslint-visitor-keys": "^1.1.0" 1691 | }, 1692 | "dependencies": { 1693 | "eslint-visitor-keys": { 1694 | "version": "1.3.0", 1695 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-1.3.0.tgz", 1696 | "integrity": "sha512-6J72N8UNa462wa/KFODt/PJ3IU60SDpC3QXC1Hjc1BXXpfL2C9R5+AU7jhe0F6GREqVMh4Juu+NY7xn+6dipUQ==", 1697 | "dev": true 1698 | } 1699 | } 1700 | }, 1701 | "eslint-visitor-keys": { 1702 | "version": "2.0.0", 1703 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-2.0.0.tgz", 1704 | "integrity": "sha512-QudtT6av5WXels9WjIM7qz1XD1cWGvX4gGXvp/zBn9nXG02D0utdU3Em2m/QjTnrsk6bBjmCygl3rmj118msQQ==", 1705 | "dev": true 1706 | }, 1707 | "espree": { 1708 | "version": "7.3.1", 1709 | "resolved": "https://registry.npmjs.org/espree/-/espree-7.3.1.tgz", 1710 | "integrity": "sha512-v3JCNCE64umkFpmkFGqzVKsOT0tN1Zr+ueqLZfpV1Ob8e+CEgPWa+OxCoGH3tnhimMKIaBm4m/vaRpJ/krRz2g==", 1711 | "dev": true, 1712 | "requires": { 1713 | "acorn": "^7.4.0", 1714 | "acorn-jsx": "^5.3.1", 1715 | "eslint-visitor-keys": "^1.3.0" 1716 | }, 1717 | "dependencies": { 1718 | "eslint-visitor-keys": { 1719 | "version": "1.3.0", 1720 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-1.3.0.tgz", 1721 | "integrity": "sha512-6J72N8UNa462wa/KFODt/PJ3IU60SDpC3QXC1Hjc1BXXpfL2C9R5+AU7jhe0F6GREqVMh4Juu+NY7xn+6dipUQ==", 1722 | "dev": true 1723 | } 1724 | } 1725 | }, 1726 | "esprima": { 1727 | "version": "4.0.1", 1728 | "resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.1.tgz", 1729 | "integrity": "sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A==", 1730 | "dev": true 1731 | }, 1732 | "esquery": { 1733 | "version": "1.4.0", 1734 | "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.4.0.tgz", 1735 | "integrity": "sha512-cCDispWt5vHHtwMY2YrAQ4ibFkAL8RbH5YGBnZBc90MolvvfkkQcJro/aZiAQUlQ3qgrYS6D6v8Gc5G5CQsc9w==", 1736 | "dev": true, 1737 | "requires": { 1738 | "estraverse": "^5.1.0" 1739 | }, 1740 | "dependencies": { 1741 | "estraverse": { 1742 | "version": "5.2.0", 1743 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.2.0.tgz", 1744 | "integrity": "sha512-BxbNGGNm0RyRYvUdHpIwv9IWzeM9XClbOxwoATuFdOE7ZE6wHL+HQ5T8hoPM+zHvmKzzsEqhgy0GrQ5X13afiQ==", 1745 | "dev": true 1746 | } 1747 | } 1748 | }, 1749 | "esrecurse": { 1750 | "version": "4.3.0", 1751 | "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.3.0.tgz", 1752 | "integrity": "sha512-KmfKL3b6G+RXvP8N1vr3Tq1kL/oCFgn2NYXEtqP8/L3pKapUA4G8cFVaoF3SU323CD4XypR/ffioHmkti6/Tag==", 1753 | "dev": true, 1754 | "requires": { 1755 | "estraverse": "^5.2.0" 1756 | }, 1757 | "dependencies": { 1758 | "estraverse": { 1759 | "version": "5.2.0", 1760 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.2.0.tgz", 1761 | "integrity": "sha512-BxbNGGNm0RyRYvUdHpIwv9IWzeM9XClbOxwoATuFdOE7ZE6wHL+HQ5T8hoPM+zHvmKzzsEqhgy0GrQ5X13afiQ==", 1762 | "dev": true 1763 | } 1764 | } 1765 | }, 1766 | "estraverse": { 1767 | "version": "4.3.0", 1768 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-4.3.0.tgz", 1769 | "integrity": "sha512-39nnKffWz8xN1BU/2c79n9nB9HDzo0niYUqx6xyqUnyoAnQyyWpOTdZEeiCch8BBu515t4wp9ZmgVfVhn9EBpw==", 1770 | "dev": true 1771 | }, 1772 | "esutils": { 1773 | "version": "2.0.3", 1774 | "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz", 1775 | "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==", 1776 | "dev": true 1777 | }, 1778 | "fast-deep-equal": { 1779 | "version": "3.1.3", 1780 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz", 1781 | "integrity": "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==", 1782 | "dev": true 1783 | }, 1784 | "fast-json-stable-stringify": { 1785 | "version": "2.1.0", 1786 | "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz", 1787 | "integrity": "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==", 1788 | "dev": true 1789 | }, 1790 | "fast-levenshtein": { 1791 | "version": "2.0.6", 1792 | "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", 1793 | "integrity": "sha1-PYpcZog6FqMMqGQ+hR8Zuqd5eRc=", 1794 | "dev": true 1795 | }, 1796 | "file-entry-cache": { 1797 | "version": "6.0.1", 1798 | "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-6.0.1.tgz", 1799 | "integrity": "sha512-7Gps/XWymbLk2QLYK4NzpMOrYjMhdIxXuIvy2QBsLE6ljuodKvdkWs/cpyJJ3CVIVpH0Oi1Hvg1ovbMzLdFBBg==", 1800 | "dev": true, 1801 | "requires": { 1802 | "flat-cache": "^3.0.4" 1803 | } 1804 | }, 1805 | "flat-cache": { 1806 | "version": "3.0.4", 1807 | "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-3.0.4.tgz", 1808 | "integrity": "sha512-dm9s5Pw7Jc0GvMYbshN6zchCA9RgQlzzEZX3vylR9IqFfS8XciblUXOKfW6SiuJ0e13eDYZoZV5wdrev7P3Nwg==", 1809 | "dev": true, 1810 | "requires": { 1811 | "flatted": "^3.1.0", 1812 | "rimraf": "^3.0.2" 1813 | } 1814 | }, 1815 | "flatted": { 1816 | "version": "3.1.1", 1817 | "resolved": "https://registry.npmjs.org/flatted/-/flatted-3.1.1.tgz", 1818 | "integrity": "sha512-zAoAQiudy+r5SvnSw3KJy5os/oRJYHzrzja/tBDqrZtNhUw8bt6y8OBzMWcjWr+8liV8Eb6yOhw8WZ7VFZ5ZzA==", 1819 | "dev": true 1820 | }, 1821 | "fs.realpath": { 1822 | "version": "1.0.0", 1823 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 1824 | "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=", 1825 | "dev": true 1826 | }, 1827 | "function-bind": { 1828 | "version": "1.1.1", 1829 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", 1830 | "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==", 1831 | "dev": true 1832 | }, 1833 | "functional-red-black-tree": { 1834 | "version": "1.0.1", 1835 | "resolved": "https://registry.npmjs.org/functional-red-black-tree/-/functional-red-black-tree-1.0.1.tgz", 1836 | "integrity": "sha1-GwqzvVU7Kg1jmdKcDj6gslIHgyc=", 1837 | "dev": true 1838 | }, 1839 | "get-intrinsic": { 1840 | "version": "1.1.1", 1841 | "resolved": "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.1.1.tgz", 1842 | "integrity": "sha512-kWZrnVM42QCiEA2Ig1bG8zjoIMOgxWwYCEeNdwY6Tv/cOSeGpcoX4pXHfKUxNKVoArnrEr2e9srnAxxGIraS9Q==", 1843 | "dev": true, 1844 | "requires": { 1845 | "function-bind": "^1.1.1", 1846 | "has": "^1.0.3", 1847 | "has-symbols": "^1.0.1" 1848 | } 1849 | }, 1850 | "glob": { 1851 | "version": "7.1.6", 1852 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.6.tgz", 1853 | "integrity": "sha512-LwaxwyZ72Lk7vZINtNNrywX0ZuLyStrdDtabefZKAY5ZGJhVtgdznluResxNmPitE0SAO+O26sWTHeKSI2wMBA==", 1854 | "dev": true, 1855 | "requires": { 1856 | "fs.realpath": "^1.0.0", 1857 | "inflight": "^1.0.4", 1858 | "inherits": "2", 1859 | "minimatch": "^3.0.4", 1860 | "once": "^1.3.0", 1861 | "path-is-absolute": "^1.0.0" 1862 | } 1863 | }, 1864 | "glob-parent": { 1865 | "version": "5.1.2", 1866 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", 1867 | "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", 1868 | "dev": true, 1869 | "requires": { 1870 | "is-glob": "^4.0.1" 1871 | } 1872 | }, 1873 | "globals": { 1874 | "version": "13.7.0", 1875 | "resolved": "https://registry.npmjs.org/globals/-/globals-13.7.0.tgz", 1876 | "integrity": "sha512-Aipsz6ZKRxa/xQkZhNg0qIWXT6x6rD46f6x/PCnBomlttdIyAPak4YD9jTmKpZ72uROSMU87qJtcgpgHaVchiA==", 1877 | "dev": true, 1878 | "requires": { 1879 | "type-fest": "^0.20.2" 1880 | } 1881 | }, 1882 | "has": { 1883 | "version": "1.0.3", 1884 | "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz", 1885 | "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==", 1886 | "dev": true, 1887 | "requires": { 1888 | "function-bind": "^1.1.1" 1889 | } 1890 | }, 1891 | "has-flag": { 1892 | "version": "4.0.0", 1893 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 1894 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", 1895 | "dev": true 1896 | }, 1897 | "has-symbols": { 1898 | "version": "1.0.2", 1899 | "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.2.tgz", 1900 | "integrity": "sha512-chXa79rL/UC2KlX17jo3vRGz0azaWEx5tGqZg5pO3NUyEJVB17dMruQlzCCOfUvElghKcm5194+BCRvi2Rv/Gw==", 1901 | "dev": true 1902 | }, 1903 | "ignore": { 1904 | "version": "4.0.6", 1905 | "resolved": "https://registry.npmjs.org/ignore/-/ignore-4.0.6.tgz", 1906 | "integrity": "sha512-cyFDKrqc/YdcWFniJhzI42+AzS+gNwmUzOSFcRCQYwySuBBBy/KjuxWLZ/FHEH6Moq1NizMOBWyTcv8O4OZIMg==", 1907 | "dev": true 1908 | }, 1909 | "import-fresh": { 1910 | "version": "3.3.0", 1911 | "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.3.0.tgz", 1912 | "integrity": "sha512-veYYhQa+D1QBKznvhUHxb8faxlrwUnxseDAbAp457E0wLNio2bOSKnjYDhMj+YiAq61xrMGhQk9iXVk5FzgQMw==", 1913 | "dev": true, 1914 | "requires": { 1915 | "parent-module": "^1.0.0", 1916 | "resolve-from": "^4.0.0" 1917 | } 1918 | }, 1919 | "imurmurhash": { 1920 | "version": "0.1.4", 1921 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", 1922 | "integrity": "sha1-khi5srkoojixPcT7a21XbyMUU+o=", 1923 | "dev": true 1924 | }, 1925 | "inflight": { 1926 | "version": "1.0.6", 1927 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 1928 | "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", 1929 | "dev": true, 1930 | "requires": { 1931 | "once": "^1.3.0", 1932 | "wrappy": "1" 1933 | } 1934 | }, 1935 | "inherits": { 1936 | "version": "2.0.4", 1937 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 1938 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", 1939 | "dev": true 1940 | }, 1941 | "is-boolean-object": { 1942 | "version": "1.1.0", 1943 | "resolved": "https://registry.npmjs.org/is-boolean-object/-/is-boolean-object-1.1.0.tgz", 1944 | "integrity": "sha512-a7Uprx8UtD+HWdyYwnD1+ExtTgqQtD2k/1yJgtXP6wnMm8byhkoTZRl+95LLThpzNZJ5aEvi46cdH+ayMFRwmA==", 1945 | "dev": true, 1946 | "requires": { 1947 | "call-bind": "^1.0.0" 1948 | } 1949 | }, 1950 | "is-extglob": { 1951 | "version": "2.1.1", 1952 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 1953 | "integrity": "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=", 1954 | "dev": true 1955 | }, 1956 | "is-fullwidth-code-point": { 1957 | "version": "3.0.0", 1958 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 1959 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", 1960 | "dev": true 1961 | }, 1962 | "is-glob": { 1963 | "version": "4.0.1", 1964 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.1.tgz", 1965 | "integrity": "sha512-5G0tKtBTFImOqDnLB2hG6Bp2qcKEFduo4tZu9MT/H6NQv/ghhy30o55ufafxJ/LdH79LLs2Kfrn85TLKyA7BUg==", 1966 | "dev": true, 1967 | "requires": { 1968 | "is-extglob": "^2.1.1" 1969 | } 1970 | }, 1971 | "is-number-object": { 1972 | "version": "1.0.4", 1973 | "resolved": "https://registry.npmjs.org/is-number-object/-/is-number-object-1.0.4.tgz", 1974 | "integrity": "sha512-zohwelOAur+5uXtk8O3GPQ1eAcu4ZX3UwxQhUlfFFMNpUd83gXgjbhJh6HmB6LUNV/ieOLQuDwJO3dWJosUeMw==", 1975 | "dev": true 1976 | }, 1977 | "is-string": { 1978 | "version": "1.0.5", 1979 | "resolved": "https://registry.npmjs.org/is-string/-/is-string-1.0.5.tgz", 1980 | "integrity": "sha512-buY6VNRjhQMiF1qWDouloZlQbRhDPCebwxSjxMjxgemYT46YMd2NR0/H+fBhEfWX4A/w9TBJ+ol+okqJKFE6vQ==", 1981 | "dev": true 1982 | }, 1983 | "isexe": { 1984 | "version": "2.0.0", 1985 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 1986 | "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=", 1987 | "dev": true 1988 | }, 1989 | "js-tokens": { 1990 | "version": "4.0.0", 1991 | "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", 1992 | "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==", 1993 | "dev": true 1994 | }, 1995 | "js-yaml": { 1996 | "version": "3.14.1", 1997 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.14.1.tgz", 1998 | "integrity": "sha512-okMH7OXXJ7YrN9Ok3/SXrnu4iX9yOk+25nqX4imS2npuvTYDmo/QEZoqwZkYaIDk3jVvBOTOIEgEhaLOynBS9g==", 1999 | "dev": true, 2000 | "requires": { 2001 | "argparse": "^1.0.7", 2002 | "esprima": "^4.0.0" 2003 | } 2004 | }, 2005 | "json-schema-traverse": { 2006 | "version": "0.4.1", 2007 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", 2008 | "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==", 2009 | "dev": true 2010 | }, 2011 | "json-stable-stringify-without-jsonify": { 2012 | "version": "1.0.1", 2013 | "resolved": "https://registry.npmjs.org/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz", 2014 | "integrity": "sha1-nbe1lJatPzz+8wp1FC0tkwrXJlE=", 2015 | "dev": true 2016 | }, 2017 | "levn": { 2018 | "version": "0.4.1", 2019 | "resolved": "https://registry.npmjs.org/levn/-/levn-0.4.1.tgz", 2020 | "integrity": "sha512-+bT2uH4E5LGE7h/n3evcS/sQlJXCpIp6ym8OWJ5eV6+67Dsql/LaaT7qJBAt2rzfoa/5QBGBhxDix1dMt2kQKQ==", 2021 | "dev": true, 2022 | "requires": { 2023 | "prelude-ls": "^1.2.1", 2024 | "type-check": "~0.4.0" 2025 | } 2026 | }, 2027 | "lodash": { 2028 | "version": "4.17.21", 2029 | "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.21.tgz", 2030 | "integrity": "sha512-v2kDEe57lecTulaDIuNTPy3Ry4gLGJ6Z1O3vE1krgXZNrsQ+LFTGHVxVjcXPs17LhbZVGedAJv8XZ1tvj5FvSg==", 2031 | "dev": true 2032 | }, 2033 | "lodash.clonedeep": { 2034 | "version": "4.5.0", 2035 | "resolved": "https://registry.npmjs.org/lodash.clonedeep/-/lodash.clonedeep-4.5.0.tgz", 2036 | "integrity": "sha1-4j8/nE+Pvd6HJSnBBxhXoIblzO8=", 2037 | "dev": true 2038 | }, 2039 | "lodash.flatten": { 2040 | "version": "4.4.0", 2041 | "resolved": "https://registry.npmjs.org/lodash.flatten/-/lodash.flatten-4.4.0.tgz", 2042 | "integrity": "sha1-8xwiIlqWMtK7+OSt2+8kCqdlph8=", 2043 | "dev": true 2044 | }, 2045 | "lodash.truncate": { 2046 | "version": "4.4.2", 2047 | "resolved": "https://registry.npmjs.org/lodash.truncate/-/lodash.truncate-4.4.2.tgz", 2048 | "integrity": "sha1-WjUNoLERO4N+z//VgSy+WNbq4ZM=", 2049 | "dev": true 2050 | }, 2051 | "lru-cache": { 2052 | "version": "6.0.0", 2053 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", 2054 | "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", 2055 | "dev": true, 2056 | "requires": { 2057 | "yallist": "^4.0.0" 2058 | } 2059 | }, 2060 | "minimatch": { 2061 | "version": "3.0.4", 2062 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", 2063 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", 2064 | "dev": true, 2065 | "requires": { 2066 | "brace-expansion": "^1.1.7" 2067 | } 2068 | }, 2069 | "ms": { 2070 | "version": "2.1.2", 2071 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 2072 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 2073 | "dev": true 2074 | }, 2075 | "natural-compare": { 2076 | "version": "1.4.0", 2077 | "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", 2078 | "integrity": "sha1-Sr6/7tdUHywnrPspvbvRXI1bpPc=", 2079 | "dev": true 2080 | }, 2081 | "once": { 2082 | "version": "1.4.0", 2083 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 2084 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", 2085 | "dev": true, 2086 | "requires": { 2087 | "wrappy": "1" 2088 | } 2089 | }, 2090 | "optionator": { 2091 | "version": "0.9.1", 2092 | "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.9.1.tgz", 2093 | "integrity": "sha512-74RlY5FCnhq4jRxVUPKDaRwrVNXMqsGsiW6AJw4XK8hmtm10wC0ypZBLw5IIp85NZMr91+qd1RvvENwg7jjRFw==", 2094 | "dev": true, 2095 | "requires": { 2096 | "deep-is": "^0.1.3", 2097 | "fast-levenshtein": "^2.0.6", 2098 | "levn": "^0.4.1", 2099 | "prelude-ls": "^1.2.1", 2100 | "type-check": "^0.4.0", 2101 | "word-wrap": "^1.2.3" 2102 | } 2103 | }, 2104 | "parent-module": { 2105 | "version": "1.0.1", 2106 | "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz", 2107 | "integrity": "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==", 2108 | "dev": true, 2109 | "requires": { 2110 | "callsites": "^3.0.0" 2111 | } 2112 | }, 2113 | "path-is-absolute": { 2114 | "version": "1.0.1", 2115 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 2116 | "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=", 2117 | "dev": true 2118 | }, 2119 | "path-key": { 2120 | "version": "3.1.1", 2121 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", 2122 | "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", 2123 | "dev": true 2124 | }, 2125 | "prelude-ls": { 2126 | "version": "1.2.1", 2127 | "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.2.1.tgz", 2128 | "integrity": "sha512-vkcDPrRZo1QZLbn5RLGPpg/WmIQ65qoWWhcGKf/b5eplkkarX0m9z8ppCat4mlOqUsWpyNuYgO3VRyrYHSzX5g==", 2129 | "dev": true 2130 | }, 2131 | "progress": { 2132 | "version": "2.0.3", 2133 | "resolved": "https://registry.npmjs.org/progress/-/progress-2.0.3.tgz", 2134 | "integrity": "sha512-7PiHtLll5LdnKIMw100I+8xJXR5gW2QwWYkT6iJva0bXitZKa/XMrSbdmg3r2Xnaidz9Qumd0VPaMrZlF9V9sA==", 2135 | "dev": true 2136 | }, 2137 | "punycode": { 2138 | "version": "2.1.1", 2139 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.1.1.tgz", 2140 | "integrity": "sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A==", 2141 | "dev": true 2142 | }, 2143 | "regexpp": { 2144 | "version": "3.1.0", 2145 | "resolved": "https://registry.npmjs.org/regexpp/-/regexpp-3.1.0.tgz", 2146 | "integrity": "sha512-ZOIzd8yVsQQA7j8GCSlPGXwg5PfmA1mrq0JP4nGhh54LaKN3xdai/vHUDu74pKwV8OxseMS65u2NImosQcSD0Q==", 2147 | "dev": true 2148 | }, 2149 | "require-from-string": { 2150 | "version": "2.0.2", 2151 | "resolved": "https://registry.npmjs.org/require-from-string/-/require-from-string-2.0.2.tgz", 2152 | "integrity": "sha512-Xf0nWe6RseziFMu+Ap9biiUbmplq6S9/p+7w7YXP/JBHhrUDDUhwa+vANyubuqfZWTveU//DYVGsDG7RKL/vEw==", 2153 | "dev": true 2154 | }, 2155 | "resolve-from": { 2156 | "version": "4.0.0", 2157 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz", 2158 | "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==", 2159 | "dev": true 2160 | }, 2161 | "rimraf": { 2162 | "version": "3.0.2", 2163 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-3.0.2.tgz", 2164 | "integrity": "sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA==", 2165 | "dev": true, 2166 | "requires": { 2167 | "glob": "^7.1.3" 2168 | } 2169 | }, 2170 | "semver": { 2171 | "version": "7.3.5", 2172 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.3.5.tgz", 2173 | "integrity": "sha512-PoeGJYh8HK4BTO/a9Tf6ZG3veo/A7ZVsYrSA6J8ny9nb3B1VrpkuN+z9OE5wfE5p6H4LchYZsegiQgbJD94ZFQ==", 2174 | "dev": true, 2175 | "requires": { 2176 | "lru-cache": "^6.0.0" 2177 | } 2178 | }, 2179 | "shebang-command": { 2180 | "version": "2.0.0", 2181 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", 2182 | "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", 2183 | "dev": true, 2184 | "requires": { 2185 | "shebang-regex": "^3.0.0" 2186 | } 2187 | }, 2188 | "shebang-regex": { 2189 | "version": "3.0.0", 2190 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", 2191 | "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", 2192 | "dev": true 2193 | }, 2194 | "slice-ansi": { 2195 | "version": "4.0.0", 2196 | "resolved": "https://registry.npmjs.org/slice-ansi/-/slice-ansi-4.0.0.tgz", 2197 | "integrity": "sha512-qMCMfhY040cVHT43K9BFygqYbUPFZKHOg7K73mtTWJRb8pyP3fzf4Ixd5SzdEJQ6MRUg/WBnOLxghZtKKurENQ==", 2198 | "dev": true, 2199 | "requires": { 2200 | "ansi-styles": "^4.0.0", 2201 | "astral-regex": "^2.0.0", 2202 | "is-fullwidth-code-point": "^3.0.0" 2203 | } 2204 | }, 2205 | "sprintf-js": { 2206 | "version": "1.0.3", 2207 | "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.0.3.tgz", 2208 | "integrity": "sha1-BOaSb2YolTVPPdAVIDYzuFcpfiw=", 2209 | "dev": true 2210 | }, 2211 | "string-width": { 2212 | "version": "4.2.2", 2213 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.2.tgz", 2214 | "integrity": "sha512-XBJbT3N4JhVumXE0eoLU9DCjcaF92KLNqTmFCnG1pf8duUxFGwtP6AD6nkjw9a3IdiRtL3E2w3JDiE/xi3vOeA==", 2215 | "dev": true, 2216 | "requires": { 2217 | "emoji-regex": "^8.0.0", 2218 | "is-fullwidth-code-point": "^3.0.0", 2219 | "strip-ansi": "^6.0.0" 2220 | } 2221 | }, 2222 | "strip-ansi": { 2223 | "version": "6.0.0", 2224 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.0.tgz", 2225 | "integrity": "sha512-AuvKTrTfQNYNIctbR1K/YGTR1756GycPsg7b9bdV9Duqur4gv6aKqHXah67Z8ImS7WEz5QVcOtlfW2rZEugt6w==", 2226 | "dev": true, 2227 | "requires": { 2228 | "ansi-regex": "^5.0.0" 2229 | } 2230 | }, 2231 | "strip-json-comments": { 2232 | "version": "3.1.1", 2233 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz", 2234 | "integrity": "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==", 2235 | "dev": true 2236 | }, 2237 | "supports-color": { 2238 | "version": "7.2.0", 2239 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", 2240 | "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", 2241 | "dev": true, 2242 | "requires": { 2243 | "has-flag": "^4.0.0" 2244 | } 2245 | }, 2246 | "table": { 2247 | "version": "6.0.9", 2248 | "resolved": "https://registry.npmjs.org/table/-/table-6.0.9.tgz", 2249 | "integrity": "sha512-F3cLs9a3hL1Z7N4+EkSscsel3z55XT950AvB05bwayrNg5T1/gykXtigioTAjbltvbMSJvvhFCbnf6mX+ntnJQ==", 2250 | "dev": true, 2251 | "requires": { 2252 | "ajv": "^8.0.1", 2253 | "is-boolean-object": "^1.1.0", 2254 | "is-number-object": "^1.0.4", 2255 | "is-string": "^1.0.5", 2256 | "lodash.clonedeep": "^4.5.0", 2257 | "lodash.flatten": "^4.4.0", 2258 | "lodash.truncate": "^4.4.2", 2259 | "slice-ansi": "^4.0.0", 2260 | "string-width": "^4.2.0" 2261 | }, 2262 | "dependencies": { 2263 | "ajv": { 2264 | "version": "8.0.5", 2265 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-8.0.5.tgz", 2266 | "integrity": "sha512-RkiLa/AeJx7+9OvniQ/qeWu0w74A8DiPPBclQ6ji3ZQkv5KamO+QGpqmi7O4JIw3rHGUXZ6CoP9tsAkn3gyazg==", 2267 | "dev": true, 2268 | "requires": { 2269 | "fast-deep-equal": "^3.1.1", 2270 | "json-schema-traverse": "^1.0.0", 2271 | "require-from-string": "^2.0.2", 2272 | "uri-js": "^4.2.2" 2273 | } 2274 | }, 2275 | "json-schema-traverse": { 2276 | "version": "1.0.0", 2277 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-1.0.0.tgz", 2278 | "integrity": "sha512-NM8/P9n3XjXhIZn1lLhkFaACTOURQXjWhV4BA/RnOv8xvgqtqpAX9IO4mRQxSx1Rlo4tqzeqb0sOlruaOy3dug==", 2279 | "dev": true 2280 | } 2281 | } 2282 | }, 2283 | "text-table": { 2284 | "version": "0.2.0", 2285 | "resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz", 2286 | "integrity": "sha1-f17oI66AUgfACvLfSoTsP8+lcLQ=", 2287 | "dev": true 2288 | }, 2289 | "type-check": { 2290 | "version": "0.4.0", 2291 | "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.4.0.tgz", 2292 | "integrity": "sha512-XleUoc9uwGXqjWwXaUTZAmzMcFZ5858QA2vvx1Ur5xIcixXIP+8LnFDgRplU30us6teqdlskFfu+ae4K79Ooew==", 2293 | "dev": true, 2294 | "requires": { 2295 | "prelude-ls": "^1.2.1" 2296 | } 2297 | }, 2298 | "type-fest": { 2299 | "version": "0.20.2", 2300 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.20.2.tgz", 2301 | "integrity": "sha512-Ne+eE4r0/iWnpAxD852z3A+N0Bt5RN//NjJwRd2VFHEmrywxf5vsZlh4R6lixl6B+wz/8d+maTSAkN1FIkI3LQ==", 2302 | "dev": true 2303 | }, 2304 | "uri-js": { 2305 | "version": "4.4.1", 2306 | "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.4.1.tgz", 2307 | "integrity": "sha512-7rKUyy33Q1yc98pQ1DAmLtwX109F7TIfWlW1Ydo8Wl1ii1SeHieeh0HHfPeL2fMXK6z0s8ecKs9frCuLJvndBg==", 2308 | "dev": true, 2309 | "requires": { 2310 | "punycode": "^2.1.0" 2311 | } 2312 | }, 2313 | "v8-compile-cache": { 2314 | "version": "2.3.0", 2315 | "resolved": "https://registry.npmjs.org/v8-compile-cache/-/v8-compile-cache-2.3.0.tgz", 2316 | "integrity": "sha512-l8lCEmLcLYZh4nbunNZvQCJc5pv7+RCwa8q/LdUx8u7lsWvPDKmpodJAJNwkAhJC//dFY48KuIEmjtd4RViDrA==", 2317 | "dev": true 2318 | }, 2319 | "which": { 2320 | "version": "2.0.2", 2321 | "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", 2322 | "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", 2323 | "dev": true, 2324 | "requires": { 2325 | "isexe": "^2.0.0" 2326 | } 2327 | }, 2328 | "word-wrap": { 2329 | "version": "1.2.3", 2330 | "resolved": "https://registry.npmjs.org/word-wrap/-/word-wrap-1.2.3.tgz", 2331 | "integrity": "sha512-Hz/mrNwitNRh/HUAtM/VT/5VH+ygD6DV7mYKZAtHOrbs8U7lvPS6xf7EJKMF0uW1KJCl0H701g3ZGus+muE5vQ==", 2332 | "dev": true 2333 | }, 2334 | "wrappy": { 2335 | "version": "1.0.2", 2336 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 2337 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=", 2338 | "dev": true 2339 | }, 2340 | "yallist": { 2341 | "version": "4.0.0", 2342 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", 2343 | "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", 2344 | "dev": true 2345 | } 2346 | } 2347 | } 2348 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "youtube-thumbnail-tester-chrome-extension", 3 | "version": "0.1.6", 4 | "description": "youtube-thumbnail-tester-chrome-extension", 5 | "main": "popup.js", 6 | "scripts": { 7 | "lint": "./node_modules/.bin/eslint popup.js --fix", 8 | "test": "echo \"Error: no test specified\" && exit 1", 9 | "package": "git archive -o prevyou.zip HEAD" 10 | }, 11 | "repository": { 12 | "type": "git", 13 | "url": "git+https://github.com/bdebon/youtube-thumbnail-tester-chrome-extension.git" 14 | }, 15 | "author": "", 16 | "license": "ISC", 17 | "bugs": { 18 | "url": "https://github.com/bdebon/youtube-thumbnail-tester-chrome-extension/issues" 19 | }, 20 | "homepage": "https://github.com/bdebon/youtube-thumbnail-tester-chrome-extension#readme", 21 | "devDependencies": { 22 | "eslint": "^7.23.0" 23 | } 24 | } 25 | -------------------------------------------------------------------------------- /popup-wrapper.html: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 |

9 | 10 | 11 | -------------------------------------------------------------------------------- /popup-wrapper.js: -------------------------------------------------------------------------------- 1 | chrome.tabs.query({active: true, currentWindow: true}, (tabs) => { 2 | if (tabs[0] === undefined || !tabs[0].url.startsWith('https://www.youtube.com/')) { 3 | const errorMessageSpan = document.querySelector('#extErrorMessage') 4 | errorMessageSpan.textContent = 'You need to be on YouTube!' 5 | return 6 | } 7 | 8 | chrome.scripting.executeScript({ 9 | target: {tabId: tabs[0].id}, 10 | // showPopup acutally toggles popup here 11 | func: () => window.__PREVYOU_LOADED ? (showPopup(), true) : false, 12 | }, results => { 13 | if (!results[0].result) { 14 | chrome.scripting.executeScript({ 15 | target: {tabId: tabs[0].id}, 16 | files: ['/content.js'] 17 | }); 18 | 19 | chrome.scripting.insertCSS({ 20 | target: {tabId: tabs[0].id}, 21 | files: ['/content.css'] 22 | }) 23 | } 24 | 25 | window.close(); 26 | }); 27 | }); 28 | -------------------------------------------------------------------------------- /popup.html: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 |
11 | 12 |
13 | 14 | 15 | 16 |
17 | 18 |
19 | 20 | 22 | 23 |
24 | 25 | 26 |
27 | 28 | 29 | 30 | 31 | 32 | 33 | 34 | 35 | 36 | 37 | 38 | 39 | 40 | 41 | 42 | 43 | 44 | 45 | 46 | 47 | 48 | 49 | 50 | 51 | 52 | 53 | 54 | 55 | 56 | 57 | 58 | 59 | 60 | 61 | 62 | 63 | 64 | 65 | 66 | 67 | 68 | 69 | 70 | 71 | 72 | 73 | 74 | 75 |
PrevYou
76 |
77 |
78 |
79 | 80 | 85 |
86 | 87 |
88 | 89 | 90 |
91 |
92 | 93 |
94 | 95 | 102 |
103 | 104 |
105 | 106 | 107 |
108 | 109 |
110 | 111 | 115 |
116 | 117 |
118 | 119 | 120 | 121 | 122 | 123 | 124 | 125 | 126 | 127 | 128 | 129 | 130 | 131 | 132 | 133 | 134 | 135 | 136 | 137 | 138 | 139 | 140 | 141 | 142 | 143 | 144 | 145 | 146 | 147 | 148 | 149 | 150 | 151 | 152 | 153 | 154 | 155 | 156 | 157 | 158 | 159 | 160 | 161 | 162 | 163 | 164 | 165 | 166 | Preview 167 |
168 | 171 | 172 |
173 | 174 | 175 | 176 | -------------------------------------------------------------------------------- /popup.js: -------------------------------------------------------------------------------- 1 | // ============================================= 2 | // Elements from popup.html 3 | let findCardBtn = document.querySelector('.js-find-card') 4 | let resetBtn = document.querySelector('.js-reset-btn') 5 | const titleInput = document.querySelector('.js-title-input') 6 | const channelThumbnailInput = document.querySelector('.js-channel-thumbnail-input') 7 | const channelNameInput = document.querySelector('.js-channel-name-input') 8 | const randomButton = document.querySelector('#random') 9 | const thumbnailVideoDropzone = document.querySelector('.py-label-video-thumbnail') 10 | const thumbnailInput = document.querySelector('.js-thumbnail-input') 11 | const darkModeBtn = document.querySelector('.js-darkmode-btn') 12 | const root = document.documentElement // to easily access and modify CSS custom properties for Dark/Light Mode 13 | const headerEye = document.querySelector('.js-header-eyes') 14 | const eyesPupils = document.querySelectorAll('.js-animated-eyes') 15 | 16 | // ============================================= 17 | 18 | // ============================================= 19 | // DARK/LIGHT MODE handler 20 | 21 | // Once the page is loaded, check if the Dark Mode is activated with a function that 22 | // returns 'on' or null depending on the existence of a 'darkMode' key on LocalStorage 23 | window.onload = () => { 24 | if (isDarkModeOn() == 'on') { 25 | setTimeout(darkMode, 26 | 300) 27 | } 28 | } 29 | 30 | darkModeBtn.addEventListener('click', () => { 31 | if (isDarkModeOn() == null) { 32 | darkMode() 33 | localStorage.setItem('darkMode', 'on') 34 | } else { 35 | lightMode() 36 | localStorage.removeItem('darkMode') 37 | } 38 | }) 39 | 40 | // Function that checks the existence of the key 'darkMode' on LocalStorage 41 | function isDarkModeOn() { 42 | return localStorage.getItem('darkMode') ? 'on' : null 43 | } 44 | 45 | function darkMode() { 46 | darkModeBtn.innerHTML = 47 | '' 48 | + '' 49 | + '' 50 | 51 | let styleToChange = { 52 | bg: '#161827', 53 | btnBg: '#1C1F30', 54 | headerColor: '#FFFFFF', 55 | formText: '#FFFFFF', 56 | btnColor: '#24008C', 57 | btnBorder: '#6116FF' 58 | } 59 | 60 | switchProperties(styleToChange) 61 | } 62 | 63 | function lightMode() { 64 | darkModeBtn.innerHTML = 65 | '' 66 | + '' 67 | + '' 68 | 69 | let styleToChange = { 70 | bg: '#FFFFFF', 71 | btnBg: '#F8F5FF', 72 | headerColor: '#000000', 73 | formText: '#000000', 74 | btnColor: '#6116FF', 75 | btnBorder: '#24008C' 76 | } 77 | 78 | switchProperties(styleToChange) 79 | } 80 | 81 | function switchProperties(properties) { 82 | for (let el in properties) { 83 | root.style.setProperty('--' + el, properties[el]) 84 | } 85 | } 86 | 87 | 88 | // ============================================= 89 | 90 | let videoThumbnail = null 91 | let channelThumbnailBase64 = null 92 | const preview = document.querySelector('.preview-channel-thumbnail') 93 | const previewVideo = document.querySelector('.preview-video-thumbnail') 94 | 95 | initInputs() 96 | 97 | // Init value from chrome store 98 | function initInputs() { 99 | chrome.storage.local.get('thumbnailProperties', (result) => { 100 | var storedThumbnail = result.thumbnailProperties 101 | 102 | // If valid data is stored 103 | if (typeof (storedThumbnail) !== 'undefined') { 104 | titleInput.value = storedThumbnail.title || null 105 | channelNameInput.value = storedThumbnail.channelName || null 106 | 107 | videoThumbnail = storedThumbnail.thumbnail 108 | if (videoThumbnail) { 109 | previewVideo.src = videoThumbnail 110 | thumbnailInput.classList.add('loaded') 111 | } 112 | 113 | channelThumbnailBase64 = storedThumbnail.channelThumbnail 114 | if (channelThumbnailBase64) { 115 | preview.src = channelThumbnailBase64 116 | channelThumbnailInput.classList.add('loaded') 117 | } 118 | } 119 | }) 120 | } 121 | 122 | randomButton.addEventListener('change', (e) => { 123 | const isChecked = e.target.checked 124 | if (isChecked) { 125 | e.target.parentNode.parentNode.classList.add('active') 126 | } else { 127 | e.target.parentNode.parentNode.classList.remove('active') 128 | } 129 | }) 130 | 131 | findCardBtn.addEventListener('click', async () => { 132 | await launchScript(randomButton.checked) 133 | }) 134 | 135 | async function launchScript(shuffle = false) { 136 | const title = titleInput.value 137 | const channelName = channelNameInput.value 138 | 139 | try { 140 | //console.log(shuffle) 141 | chrome.storage.local.set({ 142 | thumbnailProperties: { 143 | title: title, 144 | channelName: channelName, 145 | thumbnail: videoThumbnail, 146 | channelThumbnail: channelThumbnailBase64, 147 | shuffle: shuffle 148 | } 149 | }) 150 | 151 | } catch (e) { 152 | console.error('Error with the Youtube thumbnail extension : ' + e) 153 | } 154 | 155 | window.parent.postMessage({ type: 'find_card' }, '*') 156 | 157 | // Everything went smooth so we can close the popup to let the user enjoy 158 | window.close() 159 | } 160 | 161 | thumbnailInput.addEventListener('change', () => { 162 | const file = thumbnailInput.files[0] 163 | const reader = new FileReader() 164 | 165 | reader.addEventListener('load', function () { 166 | // Convert image file to base64 string 167 | videoThumbnail = reader.result 168 | previewVideo.src = reader.result 169 | }, false) 170 | 171 | if (file) { 172 | reader.readAsDataURL(file) 173 | } 174 | }) 175 | 176 | thumbnailVideoDropzone.addEventListener('dragover', (e) => { 177 | e.preventDefault() 178 | }) 179 | 180 | thumbnailVideoDropzone.addEventListener('drop', (e) => { 181 | e.preventDefault() 182 | 183 | if (e.dataTransfer.items.length) { 184 | const file = e.dataTransfer.items[0].getAsFile() 185 | const reader = new FileReader() 186 | const dtFile = new DataTransfer() 187 | dtFile.items.add(file) 188 | thumbnailInput.files = dtFile.files 189 | 190 | reader.addEventListener('load', function () { 191 | // Convert image file to base64 string 192 | videoThumbnail = reader.result 193 | previewVideo.src = reader.result 194 | thumbnailInput.classList.add('loaded') 195 | }, false) 196 | 197 | reader.readAsDataURL(file) 198 | } 199 | }) 200 | 201 | channelThumbnailInput.addEventListener('change', () => { 202 | const file = channelThumbnailInput.files[0] 203 | const reader = new FileReader() 204 | 205 | reader.addEventListener('load', function () { 206 | // Convert image file to base64 string 207 | channelThumbnailBase64 = reader.result 208 | preview.src = reader.result 209 | }, false) 210 | 211 | if (file) { 212 | reader.readAsDataURL(file) 213 | } 214 | }) 215 | 216 | resetBtn.addEventListener('click', () => { 217 | refreshApp() 218 | }) 219 | 220 | function refreshApp() { 221 | chrome.storage.local.get('thumbnailProperties', (result) => { 222 | chrome.storage.local.set({ 223 | thumbnailProperties: { 224 | channelName: result.thumbnailProperties.channelName, 225 | channelThumbnail: result.thumbnailProperties.channelThumbnail 226 | } 227 | }) 228 | }) 229 | 230 | titleInput.value = null 231 | thumbnailInput.classList.remove('loaded') 232 | thumbnailInput.value = null 233 | } 234 | 235 | 236 | // ============================================= 237 | // ANIMATED EYES 238 | 239 | // First, we find the eyes's positions and their center : 240 | let eyeCoord = headerEye.getBoundingClientRect() 241 | let centerOfEyeX = Math.round(((eyeCoord.right - eyeCoord.left) / 2) + eyeCoord.left) 242 | let centerOfEyeY = Math.round(((eyeCoord.bottom - eyeCoord.top) / 2) + eyeCoord.top) 243 | 244 | 245 | // On mousemove, we locate the mouse position and compare its X & Y coordinates to the eyes's center. 246 | // let=eyeDirection indicates the eyes's direction with cardinal directions 247 | 248 | document.addEventListener('mousemove', (e) => { 249 | let mouseX = e.clientX 250 | let mouseY = e.clientY 251 | let eyeDirection 252 | 253 | eyeDirection = mouseY < centerOfEyeY ? 'N' : 'S' 254 | eyeDirection += mouseX < centerOfEyeX ? 'W' : 'E' 255 | 256 | if (approx(mouseX, centerOfEyeX)) { 257 | eyeDirection = mouseY > centerOfEyeY ? 'S' : 'N' 258 | } 259 | 260 | if (approx(mouseY, centerOfEyeY)) { 261 | eyeDirection = mouseX > centerOfEyeX ? 'E' : 'W' 262 | } 263 | 264 | if (approx(mouseY, centerOfEyeY) && approx(mouseX, centerOfEyeX)) { 265 | eyeDirection = 'C' 266 | } 267 | 268 | // Cardinal directions are calculated on an approximative direction ( eyes's center +/- 10px ) 269 | function approx(nbToCompare, nbToApprox) { 270 | return (nbToApprox - 10 < nbToCompare && nbToCompare < nbToApprox + 10) 271 | } 272 | 273 | function wichDirection(dir) { 274 | let direction = { 275 | 'N': '(2px, -5px)', 276 | 'NE': '(4px, -4px)', 277 | 'E': '(5px, 0px)', 278 | 'SE': '(4px, 4px)', 279 | 'S': '(2px, 5px)', 280 | 'SW': '(0px, 4px)', 281 | 'W': '(0px, 0px)', 282 | 'NW': '(0px, -4px)', 283 | 'C': '(2px, 0px)', 284 | } 285 | 286 | return direction[dir] 287 | } 288 | 289 | function setPupilsDirection(dir) { 290 | for (let pupils of eyesPupils) { 291 | pupils.style.setProperty('transform', 'translate' + (dir)) 292 | 293 | } 294 | } 295 | 296 | setPupilsDirection(wichDirection(eyeDirection)) 297 | }) 298 | -------------------------------------------------------------------------------- /pull_request_template.md: -------------------------------------------------------------------------------- 1 | Please define your PR by giving the maximum information about your changes. Why you did it, and how you proceed. 2 | -------------------------------------------------------------------------------- /style.css: -------------------------------------------------------------------------------- 1 | * { 2 | box-sizing: border-box; 3 | margin: 0; 4 | padding: 0; 5 | } 6 | 7 | :root { 8 | --grey: #A7A3C2; 9 | --grey-light: #D5CEEA; 10 | --grey-lighter: #F8F5FF; 11 | --black: #2A2C40; 12 | --main :#6116FF ; 13 | 14 | --btnColor: #6116FF; 15 | --btnBorder: #24008C; 16 | --bg: #FFFFFF; /* Dark/Light Mode : */ 17 | --btnBg: #F8F5FF; /* These custom properties are the colors that change */ 18 | --formText: #000000; /* when we switch from one mode to another */ 19 | --headerColor : #161827; /* we binded some JS to them to facilitate the switch */ 20 | } 21 | 22 | body { 23 | font-family: 'Epilogue', sans-serif; 24 | } 25 | 26 | /* Button */ 27 | .py-button { 28 | display: inline-flex; 29 | align-items: center; 30 | justify-content: center; 31 | border: none; 32 | padding: 12px; 33 | margin: 0; 34 | margin-bottom: 16px; 35 | text-decoration: none; 36 | background: var(--btnColor); 37 | color: #fff; 38 | font-family: 'Epilogue', sans-serif; 39 | font-size: 15px; 40 | font-weight: 600; 41 | border-radius: 8px; 42 | cursor: pointer; 43 | position: relative; 44 | overflow: hidden; 45 | text-align: center; 46 | transition: all 150ms ease; 47 | -webkit-appearance: none; 48 | -moz-appearance: none; 49 | width: 100%; 50 | } 51 | 52 | .py-button circle { 53 | transition: transform 150ms ease; 54 | } 55 | 56 | .py-button > span { 57 | transition: transform 300ms ease; 58 | display: inline-block; 59 | } 60 | 61 | .py-button:hover { 62 | box-shadow: 0px -4px 0px 0px var(--btnBorder) inset; 63 | -webkit-box-shadow: 0px -4px 0px 0px var(--btnBorder) inset; 64 | -moz-box-shadow: 0px -4px 0px 0px var(--btnBorder) inset; 65 | } 66 | 67 | .py-button:hover circle { 68 | transform: translateX(5px); 69 | } 70 | 71 | .py-button:hover > span { 72 | transform: translateX(-5px); 73 | } 74 | 75 | .py-dice { 76 | font-size: 32px; 77 | position: absolute; 78 | right: 0; 79 | transform: translateX(100%); 80 | padding: 0 10px; 81 | transition: transform 600ms ease-out; 82 | } 83 | 84 | .py-dice:hover div { 85 | animation: diceShaking 150ms infinite alternate linear; 86 | } 87 | 88 | .py-button:hover .py-dice { 89 | transform: translate(50%); 90 | } 91 | 92 | .py-dice:hover { 93 | transform: translateX(0%) !important; 94 | } 95 | 96 | .py-button-icon { 97 | margin-right: 12px; 98 | } 99 | 100 | .py-secondary-button { 101 | width: 32px; 102 | height: 32px; 103 | display: flex; 104 | align-items: center; 105 | justify-content: center; 106 | background: transparent; 107 | border-radius: 50%; 108 | transition: all 150ms ease; 109 | cursor: pointer; 110 | } 111 | 112 | .py-secondary-button:hover { 113 | background-color: var(--btnBg); 114 | } 115 | 116 | .py-secondary-button svg * { transition: all 150ms; } 117 | .py-secondary-button:hover svg * { 118 | fill: var(--main); 119 | } 120 | 121 | .py-container { 122 | position: relative; 123 | width: 400px; 124 | height: 630px; /* had to fix the height because object height auto not working */ 125 | border: none; 126 | background-color: var(--bg); 127 | box-shadow: rgba(100, 100, 111, 0.2) 0px 7px 29px 0px; 128 | padding: 24px 24px 16px; 129 | transition : background-color 250ms; 130 | } 131 | 132 | .reset-button { 133 | position: absolute; 134 | top: 24px; 135 | right: 24px; 136 | } 137 | 138 | .darkmode-button { 139 | position: absolute; 140 | top: 24px; 141 | left: 24px; 142 | } 143 | 144 | .py-header { 145 | display: flex; 146 | align-items: center; 147 | justify-content: center; 148 | text-align: center; 149 | margin-bottom: 24px; 150 | } 151 | 152 | .py-header-eyes { 153 | width: 32px; 154 | margin-right: 8px; 155 | } 156 | 157 | .py-header-eyes circle { 158 | transition: all 150ms ease; 159 | } 160 | 161 | .py-header-eyes:hover circle { 162 | transform: translateX(5px); 163 | } 164 | 165 | .py-header-title { 166 | font-size: 24px; 167 | color: var(--headerColor); 168 | font-weight: 900; 169 | } 170 | 171 | .py-footer { 172 | text-align: center; 173 | font-size: 11px; 174 | color: var(--grey); 175 | } 176 | 177 | .py-footer a { 178 | color: var(--headerColor); 179 | } 180 | 181 | input { 182 | -webkit-appearance: none; 183 | -moz-appearance: none; 184 | } 185 | 186 | .py-form-group { 187 | display: block; 188 | position: relative; 189 | width: 100%; 190 | margin-bottom: 24px; 191 | } 192 | 193 | .py-form-group.c-thumb { 194 | flex-basis: 56px; 195 | margin-right: 24px; 196 | margin-bottom: 16px; 197 | } 198 | 199 | .py-form-label { 200 | position: absolute; 201 | top: calc(50% - 7.5px); 202 | transition: all 0.15s ease-in; 203 | pointer-events: none; 204 | font-size: 15px; 205 | color: var(--grey); 206 | } 207 | 208 | .py-form-field { 209 | background: transparent; 210 | display: block; 211 | width: 100%; 212 | border: 0; 213 | border-bottom: 1px solid var(--grey-light); 214 | font-size: 15px; 215 | height: 40px; 216 | outline: 0; 217 | color: var(--formText); 218 | transition: color 250ms; 219 | } 220 | 221 | .py-form-field:focus { 222 | border-color: var(--main); 223 | } 224 | 225 | .py-form-field:focus + .py-form-label, 226 | .py-form-field:valid + .py-form-label { 227 | top: -6px; 228 | font-size: 11px; 229 | font-weight: 600; 230 | color: var(--main); 231 | } 232 | 233 | .py-form-file { 234 | width: 0.1px; 235 | height: 0.1px; 236 | opacity: 0; 237 | overflow: hidden; 238 | position: absolute; 239 | z-index: -1; 240 | } 241 | 242 | .py-error { 243 | display: block; 244 | margin-top: 12px; 245 | } 246 | 247 | /* Channel file */ 248 | .file-channel-thumbnail + .py-form-filelabel { 249 | display: block; 250 | width: 56px; 251 | height: 56px; 252 | overflow: hidden; 253 | position: relative; 254 | cursor: pointer; 255 | border-radius: 50%; 256 | transition: all 250ms; 257 | background-color: var(--btnBg); 258 | } 259 | 260 | .file-channel-thumbnail:focus + .py-form-filelabel, 261 | .file-channel-thumbnail + .py-form-filelabel:hover { 262 | background-color: var(--grey-light); 263 | } 264 | 265 | .preview-channel-thumbnail { 266 | max-width: 56px; 267 | } 268 | 269 | .channel-fileinput-img { 270 | position: relative; 271 | z-index: 10; 272 | display: none; 273 | top: 50%; 274 | transform: translateY(-50%); 275 | } 276 | 277 | .file-channel-thumbnail:valid + .py-form-filelabel .channel-fileinput-img, 278 | .file-channel-thumbnail.loaded + .py-form-filelabel .channel-fileinput-img{ 279 | display: block; 280 | } 281 | 282 | .channel-fileinput-user { 283 | position: absolute; 284 | left: 50%; 285 | bottom: -2px; 286 | transition: all 250ms; 287 | transform-origin: 50% 150%; 288 | opacity: 1; 289 | transform: translateX(-50%); 290 | } 291 | 292 | .file-channel-thumbnail + .py-form-filelabel:hover .channel-fileinput-user { 293 | transform: rotate(-90deg); 294 | opacity: 0; 295 | } 296 | 297 | .channel-fileinput-add { 298 | position: absolute; 299 | width: 18px; 300 | left: 19px; 301 | top: 19px; 302 | transition: all 250ms; 303 | transform-origin: 50% 200%; 304 | transform: rotate(90deg); 305 | } 306 | 307 | .file-channel-thumbnail + .py-form-filelabel:hover .channel-fileinput-add { 308 | transform: rotate(0deg); 309 | } 310 | 311 | .file-channel-thumbnail:valid + .py-form-filelabel .channel-fileinput-user, 312 | .file-channel-thumbnail:valid + .py-form-filelabel .channel-fileinput-add, 313 | .file-channel-thumbnail.loaded + .py-form-filelabel .channel-fileinput-user, 314 | .file-channel-thumbnail.loaded + .py-form-filelabel .channel-fileinput-add{ 315 | display: none; 316 | } 317 | 318 | /* Video thumbnail file */ 319 | .file-video-thumbnail + .py-form-filelabel { 320 | display: flex; 321 | flex-direction: column; 322 | align-items: center; 323 | justify-content: center; 324 | width: 100%; 325 | height: 200px; 326 | background-color: var(--btnBg); 327 | border-radius: 4px; 328 | overflow: hidden; 329 | position: relative; 330 | cursor: pointer; 331 | transition: background-color 350ms; 332 | } 333 | 334 | .file-video-thumbnail:focus + .py-form-filelabel, 335 | .file-video-thumbnail + .py-form-filelabel:hover { 336 | 337 | } 338 | 339 | .video-fileinput-img { 340 | position: absolute; 341 | z-index: 6; 342 | display: none; 343 | width: 100%; 344 | height: 100%; 345 | object-fit: cover; 346 | border: 6px solid var(--btnBg); 347 | } 348 | 349 | .file-video-thumbnail:valid + .py-form-filelabel .video-fileinput-img, 350 | .file-video-thumbnail.loaded + .py-form-filelabel .video-fileinput-img { 351 | display: block; 352 | } 353 | 354 | .file-video-dragarea { 355 | position: absolute; 356 | display: block; 357 | pointer-events: none; 358 | top: 2px; 359 | right: 2px; 360 | bottom: 2px; 361 | left: 2px; 362 | border-radius: 4px; 363 | border: 1px dashed var(--grey-light); 364 | transition: ease 250ms; 365 | z-index: 5; 366 | } 367 | 368 | .file-video-thumbnail + .py-form-filelabel:hover .file-video-dragarea { 369 | border-color: var(--main); 370 | } 371 | 372 | .file-video-text { 373 | font-size: 13px; 374 | color: var(--grey); 375 | display: inline-block; 376 | font-weight: 600; 377 | transition: ease 250ms; 378 | opacity: 1; 379 | } 380 | 381 | .file-video-thumbnail + .py-form-filelabel:hover .file-video-text { 382 | opacity: 0; 383 | } 384 | 385 | .file-video-illu { 386 | width: 68px; 387 | margin-bottom: 24px; 388 | transition: ease 250ms; 389 | } 390 | 391 | .file-video-thumbnail + .py-form-filelabel:hover .file-video-illu { 392 | transform: scale(1.3) rotate(-5deg); 393 | transform-origin: 50% 50%; 394 | } 395 | 396 | .file-video-catpaw { 397 | transform: rotate(-45deg); 398 | position: absolute; 399 | right: -40%; 400 | bottom: -100%; 401 | transition: ease 250ms; 402 | pointer-events: none; 403 | opacity: 0; 404 | } 405 | 406 | .file-video-thumbnail + .py-form-filelabel:hover .file-video-catpaw { 407 | right: 0px; 408 | bottom: -45%; 409 | opacity: 1; 410 | } 411 | 412 | /* Random position */ 413 | .random-switch {display: flex; margin-bottom: 18px;} 414 | .random-switch.active .py-form-label {color: var(--formText);} 415 | 416 | .switch { 417 | display: inline-block; 418 | margin-left: auto; 419 | width: 40px; 420 | height: 24px; 421 | } 422 | 423 | .slider { 424 | position: relative; 425 | cursor: pointer; 426 | width: 100%; 427 | height: 100%; 428 | display: block; 429 | background-color: #7D7A90; 430 | transition: .4s; 431 | border-radius: 34px; 432 | } 433 | 434 | .slider:before { 435 | position: absolute; 436 | content: ''; 437 | border-radius: 50%; 438 | height: 20px; 439 | width: 20px; 440 | left: 2px; 441 | bottom: 2px; 442 | background-color: white; 443 | transition: .4s; 444 | } 445 | 446 | input:checked + .slider {background-color: var(--btnColor);} 447 | input:focus + .slider {box-shadow: 0 0 1px var(--btnColor);} 448 | input:checked + .slider:before {transform: translateX(16px);} 449 | 450 | /* //////// */ 451 | 452 | .row { 453 | display: flex; 454 | align-items: center; 455 | margin-bottom: 20px; 456 | } 457 | 458 | .row .py-form-group { 459 | margin-bottom: 0; 460 | } 461 | 462 | 463 | @keyframes diceShaking { 464 | 0% { 465 | transform: rotate(8deg); 466 | } 467 | 468 | 100% { 469 | transform: rotate(-8deg); 470 | } 471 | } 472 | --------------------------------------------------------------------------------