├── .eslintrc.js ├── .gitignore ├── LICENSE ├── README.md ├── code.js ├── code.ts ├── cover.png ├── manifest.json ├── package-lock.json ├── package.json └── tsconfig.json /.eslintrc.js: -------------------------------------------------------------------------------- 1 | /* eslint-env node */ 2 | module.exports = { 3 | extends: [ 4 | 'eslint:recommended', 5 | 'plugin:@typescript-eslint/recommended', 6 | 'plugin:@figma/figma-plugins/recommended', 7 | ], 8 | parser: '@typescript-eslint/parser', 9 | parserOptions: { 10 | project: 'tsconfig.json', 11 | tsconfigRootDir: __dirname, 12 | sourceType: 'module', 13 | }, 14 | root: true, 15 | } 16 | -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | node_modules/ 2 | .DS_Store -------------------------------------------------------------------------------- /LICENSE: -------------------------------------------------------------------------------- 1 | MIT License 2 | 3 | Copyright (c) 2019 Charlie Chao 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 | # Fix San Francisco 2 | 3 | ![](/cover.png?raw=true) 4 | 5 | This plugin won't fix the city's problems, but it will automatically apply the [correct font variant and tracking](https://developer.apple.com/design/human-interface-guidelines/foundations/typography#tracking-values-ios) for selected texts using the San Francisco typeface. 6 | 7 | ## Usage 8 | 9 | 1. Select a Frame or texts with `SF Pro`, `SF Pro Display`, `SF Pro Text`, `SF Pro Rounded`, or `New York` font. 10 | 2. Run `Fix San Francisco` from Plugins menu. 11 | 12 | The plugin will find all relevant texts in your selections and apply the fix. 13 | 14 | **Note:** Texts with text style will not be changed. 15 | 16 | **Note:** For New York, you must use the “New York” font and not the optical variants (“New York Small”, “New York Medium”, etc.) for the plugin to apply the appropriate tracking. 17 | 18 | ## Context 19 | 20 | When texts with SF fonts are rendered on iOS, their variant and tracking (letter spacing) are adjusted based on their point size and the user's accessibility settings. In Figma, the tracking must be manually applied to get a more accurate representation. Hence, **Fix San Francisco** is here to automate this process for you ♥ 21 | 22 | Inspired by [Sketch-SF-UI-Font-Fixer](https://github.com/kylehickinson/Sketch-SF-UI-Font-Fixer). 23 | 24 | ## Development 25 | 26 | Setup your environment by following the [Setup Guide](https://www.figma.com/plugin-docs/setup/). 27 | 28 | To develop locally in [VSCode](https://code.visualstudio.com), hit ⌘⇧B and select `tsc: watch - tsconfig.json`. 29 | 30 | To update [Figma API typings](https://www.figma.com/plugin-docs/api/typings/), run `npm i --save-dev @figma/plugin-typings`. 31 | -------------------------------------------------------------------------------- /code.js: -------------------------------------------------------------------------------- 1 | /** 2 | * Fix San Francisco 3 | * Fixes texts with SF typeface according to Apple's official tracking table: 4 | * https://developer.apple.com/design/human-interface-guidelines/ios/visual-design/typography/#font-usage-and-tracking 5 | */ 6 | var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { 7 | function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); } 8 | return new (P || (P = Promise))(function (resolve, reject) { 9 | function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } 10 | function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } 11 | function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); } 12 | step((generator = generator.apply(thisArg, _arguments || [])).next()); 13 | }); 14 | }; 15 | const FONT_DEFAULT = "SF Pro"; 16 | const FONT_TEXT = "SF Pro Text"; 17 | const FONT_DISPLAY = "SF Pro Display"; 18 | const FONT_ROUNDED = "SF Pro Rounded"; 19 | const FONT_NEW_YORK = "New York"; 20 | const SIZE_MIN = 6; 21 | const SIZE_MAX = 80; 22 | const SIZE_MAX_ROUNDED = 80; 23 | const SIZE_MAX_NEW_YORK = 261; 24 | const SIZE_SWAP = 20; 25 | const TRACKING_UNIT = 1000; 26 | // Fills missing font size values inbetween defined values 27 | function fillTracking(dict, min, max) { 28 | let value = 0; 29 | for (let i = min; i < max; i++) { 30 | if (i in dict) { 31 | value = dict[i]; 32 | continue; 33 | } 34 | dict[i] = value; 35 | } 36 | return dict; 37 | } 38 | const TRACKING_DEFAULT = fillTracking({ 39 | 6: 41, 40 | 7: 34, 41 | 8: 26, 42 | 9: 19, 43 | 10: 12, 44 | 11: 6, 45 | 12: 0, 46 | 13: -6, 47 | 14: -11, 48 | 15: -16, 49 | 16: -20, 50 | 17: -26, 51 | 18: -25, 52 | 19: -24, 53 | 20: -23, 54 | 21: -18, 55 | 22: -12, 56 | 23: -4, 57 | 24: 3, 58 | 25: 6, 59 | 26: 8, 60 | 27: 11, 61 | 28: 14, 62 | 31: 13, 63 | 33: 12, 64 | 35: 11, 65 | 36: 10, 66 | 41: 9, 67 | 44: 8, 68 | 49: 7, 69 | 52: 6, 70 | 58: 5, 71 | 60: 4, 72 | 66: 3, 73 | 68: 2, 74 | 76: 1, 75 | 80: 0 76 | }, SIZE_MIN, SIZE_MAX); 77 | const TRACKING_TEXT = fillTracking({ 78 | 6: 41, 79 | 7: 34, 80 | 8: 26, 81 | 9: 19, 82 | 10: 12, 83 | 11: 6, 84 | 12: 0, 85 | 13: -6, 86 | 14: -11, 87 | 15: -16, 88 | 16: -20, 89 | 17: -26, 90 | 18: -25, 91 | 19: -24, 92 | }, SIZE_MIN, SIZE_SWAP); 93 | const TRACKING_DISPLAY = fillTracking({ 94 | 20: 19, 95 | 21: 17, 96 | 22: 16, 97 | 24: 15, 98 | 25: 14, 99 | 27: 13, 100 | 30: 12, 101 | 33: 11, 102 | 36: 10, 103 | 41: 9, 104 | 44: 8, 105 | 49: 7, 106 | 52: 6, 107 | 56: 5, 108 | 60: 4, 109 | 66: 3, 110 | 68: 2, 111 | 76: 1, 112 | }, SIZE_SWAP, SIZE_MAX); 113 | const TRACKING_ROUNDED = fillTracking({ 114 | 6: 87, 115 | 7: 80, 116 | 8: 72, 117 | 9: 65, 118 | 10: 58, 119 | 11: 52, 120 | 12: 46, 121 | 13: 40, 122 | 14: 35, 123 | 15: 30, 124 | 16: 26, 125 | 17: 22, 126 | 18: 21, 127 | 19: 20, 128 | 20: 18, 129 | 21: 17, 130 | 22: 16, 131 | 24: 15, 132 | 25: 14, 133 | 28: 13, 134 | 30: 12, 135 | 35: 11, 136 | 37: 10, 137 | 43: 9, 138 | 44: 8, 139 | 50: 7, 140 | 51: 6, 141 | 58: 4, 142 | 64: 3, 143 | 66: 2, 144 | 76: 1, 145 | }, SIZE_MIN, SIZE_MAX_ROUNDED); 146 | const TRACKING_NEW_YORK = fillTracking({ 147 | 6: 40, 148 | 7: 32, 149 | 8: 25, 150 | 9: 20, 151 | 10: 16, 152 | 11: 11, 153 | 12: 6, 154 | 13: 4, 155 | 14: 2, 156 | 15: 0, 157 | 16: -2, 158 | 17: -4, 159 | 18: -6, 160 | 19: -8, 161 | 20: -10, 162 | 23: -11, 163 | 26: -12, 164 | 31: -13, 165 | 34: -14, 166 | 54: -15, 167 | 70: -16, 168 | 180: -17, 169 | 220: -18, 170 | }, SIZE_MIN, SIZE_MAX_NEW_YORK); 171 | var TextOutcome; 172 | (function (TextOutcome) { 173 | TextOutcome[TextOutcome["Modified"] = 0] = "Modified"; 174 | TextOutcome[TextOutcome["Unmodified"] = 1] = "Unmodified"; 175 | TextOutcome[TextOutcome["Unsupported"] = 2] = "Unsupported"; 176 | })(TextOutcome || (TextOutcome = {})); 177 | function applyToRange(node, start, end) { 178 | return __awaiter(this, void 0, void 0, function* () { 179 | const fontName = node.getRangeFontName(start, end); 180 | const fontSize = node.getRangeFontSize(start, end); 181 | const letterSpacing = node.getRangeLetterSpacing(start, end); 182 | if (fontName === figma.mixed || 183 | fontSize === figma.mixed || 184 | letterSpacing === figma.mixed) 185 | // Ignore mixed range 186 | return; 187 | let isModified = false; 188 | let fontFamily = fontName.family; 189 | if (fontFamily !== FONT_DEFAULT && fontFamily !== FONT_DISPLAY && fontFamily !== FONT_TEXT && fontFamily !== FONT_ROUNDED && fontFamily !== FONT_NEW_YORK) { 190 | // Font family is not supported 191 | return TextOutcome.Unsupported; 192 | } 193 | if (fontFamily === FONT_DISPLAY && fontSize < SIZE_SWAP) { 194 | // Switch to Text variation if text is small 195 | fontFamily = FONT_TEXT; 196 | isModified = true; 197 | } 198 | if (fontFamily === FONT_TEXT && fontSize >= SIZE_SWAP) { 199 | // Switch to Display variation if text is larger 200 | fontFamily = FONT_DISPLAY; 201 | isModified = true; 202 | } 203 | // Load and assign font family 204 | const newFontName = { 205 | family: fontFamily, 206 | style: fontName.style, 207 | }; 208 | yield figma.loadFontAsync(newFontName); 209 | node.setRangeFontName(start, end, newFontName); 210 | // Apply tracking 211 | const newLetterSpacing = { 212 | value: 0, 213 | unit: "PIXELS", 214 | }; 215 | switch (fontFamily) { 216 | case FONT_DEFAULT: 217 | if (fontSize >= SIZE_MAX) { 218 | newLetterSpacing.value = 0; 219 | break; 220 | } 221 | newLetterSpacing.value = 222 | (fontSize * TRACKING_DEFAULT[Math.floor(fontSize)]) / TRACKING_UNIT; 223 | break; 224 | case FONT_DISPLAY: 225 | if (fontSize >= SIZE_MAX) { 226 | newLetterSpacing.value = 0; 227 | break; 228 | } 229 | newLetterSpacing.value = 230 | (fontSize * TRACKING_DISPLAY[Math.floor(fontSize)]) / TRACKING_UNIT; 231 | break; 232 | case FONT_TEXT: 233 | newLetterSpacing.value = 234 | (fontSize * TRACKING_TEXT[Math.max(SIZE_MIN, Math.floor(fontSize))]) / 235 | TRACKING_UNIT; 236 | break; 237 | case FONT_ROUNDED: 238 | if (fontSize >= SIZE_MAX_ROUNDED) { 239 | newLetterSpacing.value = 0; 240 | break; 241 | } 242 | newLetterSpacing.value = 243 | (fontSize * TRACKING_ROUNDED[Math.max(SIZE_MIN, Math.floor(fontSize))]) / 244 | TRACKING_UNIT; 245 | break; 246 | case FONT_NEW_YORK: 247 | if (fontSize >= SIZE_MAX_NEW_YORK) { 248 | newLetterSpacing.value = 0; 249 | break; 250 | } 251 | newLetterSpacing.value = 252 | (fontSize * TRACKING_NEW_YORK[Math.max(SIZE_MIN, Math.floor(fontSize))]) / 253 | TRACKING_UNIT; 254 | break; 255 | } 256 | node.setRangeLetterSpacing(start, end, newLetterSpacing); 257 | // Check if tracking has been modified 258 | if (newLetterSpacing.value.toPrecision(2) !== 259 | letterSpacing.value.toPrecision(2) || 260 | newLetterSpacing.unit !== letterSpacing.unit) 261 | isModified = true; 262 | return isModified ? TextOutcome.Modified : TextOutcome.Unmodified; 263 | }); 264 | } 265 | function traverse(nodes) { 266 | return __awaiter(this, void 0, void 0, function* () { 267 | const count = { 268 | texts: 0, // Nodes with supported fonts 269 | others: 0, // Nodes without supported fonts 270 | modified: 0, // Nodes with modification 271 | }; 272 | for (let i = 0; i < nodes.length; i++) { 273 | const node = nodes[i]; 274 | if ("children" in node) { 275 | const { texts, modified, others } = yield traverse(node.children); 276 | count.texts += texts; 277 | count.modified += modified; 278 | count.others += others; 279 | } 280 | if (node.type !== "TEXT" || node.textStyleId) { 281 | count.others++; 282 | continue; 283 | } 284 | const textNode = node; 285 | if (textNode.fontName === figma.mixed || 286 | textNode.fontSize === figma.mixed || 287 | textNode.letterSpacing === figma.mixed) { 288 | // Check each character when text has mixed styles 289 | for (let i = 0; i < textNode.characters.length; i++) { 290 | // Load all current fonts first 291 | yield figma.loadFontAsync(node.getRangeFontName(i, i + 1)); 292 | } 293 | let isModified = false; 294 | let isUnmodified = false; 295 | for (let i = 0; i < textNode.characters.length; i++) { 296 | switch (yield applyToRange(textNode, i, i + 1)) { 297 | case TextOutcome.Modified: 298 | isModified = true; 299 | break; 300 | case TextOutcome.Unmodified: 301 | isUnmodified = true; 302 | break; 303 | case TextOutcome.Unsupported: 304 | break; 305 | } 306 | } 307 | if (isModified) 308 | count.modified++; 309 | else if (isUnmodified) 310 | count.texts++; 311 | else 312 | count.others++; 313 | } 314 | else { 315 | // Check entire text 316 | switch (yield applyToRange(textNode, 0, textNode.characters.length)) { 317 | case TextOutcome.Modified: 318 | count.modified++; 319 | break; 320 | case TextOutcome.Unmodified: 321 | count.texts++; 322 | break; 323 | case TextOutcome.Unsupported: 324 | count.others++; 325 | break; 326 | default: 327 | break; 328 | } 329 | } 330 | } 331 | return count; 332 | }); 333 | } 334 | function run() { 335 | return __awaiter(this, void 0, void 0, function* () { 336 | const count = yield traverse(figma.currentPage.selection); 337 | let message = ""; 338 | if (count.modified === 1) { 339 | message = "Updated 1 text ✅"; 340 | } 341 | else if (count.modified) { 342 | message = `Updated ${count.modified} texts ✅`; 343 | } 344 | else if (count.texts && count.others) { 345 | message = "Texts in selection are already fixed 👍"; 346 | } 347 | else if (count.texts === 1 && !count.others) { 348 | message = "Text is already fixed 👍"; 349 | } 350 | else if (count.texts) { 351 | message = "Selected texts are already fixed 👍"; 352 | } 353 | else { 354 | message = 355 | "Please select texts with 'SF Pro', 'SF Pro Display', 'SF Pro Text', 'SF Pro Rounded', or 'New York' font."; 356 | } 357 | figma.closePlugin(message); 358 | }); 359 | } 360 | run(); 361 | -------------------------------------------------------------------------------- /code.ts: -------------------------------------------------------------------------------- 1 | /** 2 | * Fix San Francisco 3 | * Fixes texts with SF typeface according to Apple's official tracking table: 4 | * https://developer.apple.com/design/human-interface-guidelines/ios/visual-design/typography/#font-usage-and-tracking 5 | */ 6 | 7 | const FONT_DEFAULT = "SF Pro" 8 | const FONT_TEXT = "SF Pro Text" 9 | const FONT_DISPLAY = "SF Pro Display" 10 | const FONT_ROUNDED = "SF Pro Rounded" 11 | const FONT_NEW_YORK = "New York" 12 | 13 | const SIZE_MIN = 6 14 | const SIZE_MAX = 80 15 | const SIZE_MAX_ROUNDED = 80 16 | const SIZE_MAX_NEW_YORK = 261 17 | const SIZE_SWAP = 20 18 | const TRACKING_UNIT = 1000 19 | 20 | // Fills missing font size values inbetween defined values 21 | function fillTracking( 22 | dict: { [key: number]: number }, 23 | min: number, 24 | max: number 25 | ) { 26 | let value = 0 27 | for (let i = min; i < max; i++) { 28 | if (i in dict) { 29 | value = dict[i] 30 | continue 31 | } 32 | dict[i] = value 33 | } 34 | return dict 35 | } 36 | 37 | const TRACKING_DEFAULT = fillTracking( 38 | { 39 | 6: 41, 40 | 7: 34, 41 | 8: 26, 42 | 9: 19, 43 | 10: 12, 44 | 11: 6, 45 | 12: 0, 46 | 13: -6, 47 | 14: -11, 48 | 15: -16, 49 | 16: -20, 50 | 17: -26, 51 | 18: -25, 52 | 19: -24, 53 | 20: -23, 54 | 21: -18, 55 | 22: -12, 56 | 23: -4, 57 | 24: 3, 58 | 25: 6, 59 | 26: 8, 60 | 27: 11, 61 | 28: 14, 62 | 31: 13, 63 | 33: 12, 64 | 35: 11, 65 | 36: 10, 66 | 41: 9, 67 | 44: 8, 68 | 49: 7, 69 | 52: 6, 70 | 58: 5, 71 | 60: 4, 72 | 66: 3, 73 | 68: 2, 74 | 76: 1, 75 | 80: 0 76 | }, 77 | SIZE_MIN, 78 | SIZE_MAX 79 | ) 80 | 81 | const TRACKING_TEXT = fillTracking( 82 | { 83 | 6: 41, 84 | 7: 34, 85 | 8: 26, 86 | 9: 19, 87 | 10: 12, 88 | 11: 6, 89 | 12: 0, 90 | 13: -6, 91 | 14: -11, 92 | 15: -16, 93 | 16: -20, 94 | 17: -26, 95 | 18: -25, 96 | 19: -24, 97 | }, 98 | SIZE_MIN, 99 | SIZE_SWAP 100 | ) 101 | 102 | const TRACKING_DISPLAY = fillTracking( 103 | { 104 | 20: 19, 105 | 21: 17, 106 | 22: 16, 107 | 24: 15, 108 | 25: 14, 109 | 27: 13, 110 | 30: 12, 111 | 33: 11, 112 | 36: 10, 113 | 41: 9, 114 | 44: 8, 115 | 49: 7, 116 | 52: 6, 117 | 56: 5, 118 | 60: 4, 119 | 66: 3, 120 | 68: 2, 121 | 76: 1, 122 | }, 123 | SIZE_SWAP, 124 | SIZE_MAX 125 | ) 126 | 127 | const TRACKING_ROUNDED = fillTracking( 128 | { 129 | 6: 87, 130 | 7: 80, 131 | 8: 72, 132 | 9: 65, 133 | 10: 58, 134 | 11: 52, 135 | 12: 46, 136 | 13: 40, 137 | 14: 35, 138 | 15: 30, 139 | 16: 26, 140 | 17: 22, 141 | 18: 21, 142 | 19: 20, 143 | 20: 18, 144 | 21: 17, 145 | 22: 16, 146 | 24: 15, 147 | 25: 14, 148 | 28: 13, 149 | 30: 12, 150 | 35: 11, 151 | 37: 10, 152 | 43: 9, 153 | 44: 8, 154 | 50: 7, 155 | 51: 6, 156 | 58: 4, 157 | 64: 3, 158 | 66: 2, 159 | 76: 1, 160 | }, 161 | SIZE_MIN, 162 | SIZE_MAX_ROUNDED 163 | ) 164 | 165 | const TRACKING_NEW_YORK = fillTracking( 166 | { 167 | 6: 40, 168 | 7: 32, 169 | 8: 25, 170 | 9: 20, 171 | 10: 16, 172 | 11: 11, 173 | 12: 6, 174 | 13: 4, 175 | 14: 2, 176 | 15: 0, 177 | 16: -2, 178 | 17: -4, 179 | 18: -6, 180 | 19: -8, 181 | 20: -10, 182 | 23: -11, 183 | 26: -12, 184 | 31: -13, 185 | 34: -14, 186 | 54: -15, 187 | 70: -16, 188 | 180: -17, 189 | 220: -18, 190 | }, 191 | SIZE_MIN, 192 | SIZE_MAX_NEW_YORK 193 | ) 194 | 195 | enum TextOutcome { 196 | Modified, 197 | Unmodified, 198 | Unsupported, 199 | } 200 | 201 | async function applyToRange( 202 | node: TextNode, 203 | start: number, 204 | end: number 205 | ): Promise { 206 | const fontName = node.getRangeFontName(start, end) 207 | const fontSize = node.getRangeFontSize(start, end) 208 | const letterSpacing = node.getRangeLetterSpacing(start, end) 209 | if ( 210 | fontName === figma.mixed || 211 | fontSize === figma.mixed || 212 | letterSpacing === figma.mixed 213 | ) 214 | // Ignore mixed range 215 | return 216 | 217 | let isModified = false 218 | let fontFamily = fontName.family 219 | if (fontFamily !== FONT_DEFAULT && fontFamily !== FONT_DISPLAY && fontFamily !== FONT_TEXT && fontFamily !== FONT_ROUNDED && fontFamily !== FONT_NEW_YORK) { 220 | // Font family is not supported 221 | return TextOutcome.Unsupported 222 | } 223 | 224 | if (fontFamily === FONT_DISPLAY && fontSize < SIZE_SWAP) { 225 | // Switch to Text variation if text is small 226 | fontFamily = FONT_TEXT 227 | isModified = true 228 | } 229 | 230 | if (fontFamily === FONT_TEXT && fontSize >= SIZE_SWAP) { 231 | // Switch to Display variation if text is larger 232 | fontFamily = FONT_DISPLAY 233 | isModified = true 234 | } 235 | 236 | // Load and assign font family 237 | const newFontName = { 238 | family: fontFamily, 239 | style: fontName.style, 240 | } 241 | await figma.loadFontAsync(newFontName) 242 | node.setRangeFontName(start, end, newFontName) 243 | 244 | // Apply tracking 245 | const newLetterSpacing = { 246 | value: 0, 247 | unit: "PIXELS", 248 | } 249 | switch (fontFamily) { 250 | case FONT_DEFAULT: 251 | if (fontSize >= SIZE_MAX) { 252 | newLetterSpacing.value = 0 253 | break 254 | } 255 | newLetterSpacing.value = 256 | (fontSize * TRACKING_DEFAULT[Math.floor(fontSize)]) / TRACKING_UNIT 257 | break 258 | case FONT_DISPLAY: 259 | if (fontSize >= SIZE_MAX) { 260 | newLetterSpacing.value = 0 261 | break 262 | } 263 | newLetterSpacing.value = 264 | (fontSize * TRACKING_DISPLAY[Math.floor(fontSize)]) / TRACKING_UNIT 265 | break 266 | case FONT_TEXT: 267 | newLetterSpacing.value = 268 | (fontSize * TRACKING_TEXT[Math.max(SIZE_MIN, Math.floor(fontSize))]) / 269 | TRACKING_UNIT 270 | break 271 | case FONT_ROUNDED: 272 | if (fontSize >= SIZE_MAX_ROUNDED) { 273 | newLetterSpacing.value = 0 274 | break 275 | } 276 | newLetterSpacing.value = 277 | (fontSize * TRACKING_ROUNDED[Math.max(SIZE_MIN, Math.floor(fontSize))]) / 278 | TRACKING_UNIT 279 | break 280 | case FONT_NEW_YORK: 281 | if (fontSize >= SIZE_MAX_NEW_YORK) { 282 | newLetterSpacing.value = 0 283 | break 284 | } 285 | newLetterSpacing.value = 286 | (fontSize * TRACKING_NEW_YORK[Math.max(SIZE_MIN, Math.floor(fontSize))]) / 287 | TRACKING_UNIT 288 | break 289 | } 290 | node.setRangeLetterSpacing(start, end, newLetterSpacing as LetterSpacing) 291 | 292 | // Check if tracking has been modified 293 | if ( 294 | newLetterSpacing.value.toPrecision(2) !== 295 | letterSpacing.value.toPrecision(2) || 296 | newLetterSpacing.unit !== letterSpacing.unit 297 | ) 298 | isModified = true 299 | 300 | return isModified ? TextOutcome.Modified : TextOutcome.Unmodified 301 | } 302 | 303 | async function traverse(nodes: readonly SceneNode[]) { 304 | const count = { 305 | texts: 0, // Nodes with supported fonts 306 | others: 0, // Nodes without supported fonts 307 | modified: 0, // Nodes with modification 308 | } 309 | 310 | for (let i = 0; i < nodes.length; i++) { 311 | const node = nodes[i] 312 | if ("children" in node) { 313 | const { texts, modified, others } = await traverse(node.children) 314 | count.texts += texts 315 | count.modified += modified 316 | count.others += others 317 | } 318 | 319 | if (node.type !== "TEXT" || node.textStyleId) { 320 | count.others++ 321 | continue 322 | } 323 | 324 | const textNode = node as TextNode 325 | if ( 326 | textNode.fontName === figma.mixed || 327 | textNode.fontSize === figma.mixed || 328 | textNode.letterSpacing === figma.mixed 329 | ) { 330 | // Check each character when text has mixed styles 331 | for (let i = 0; i < textNode.characters.length; i++) { 332 | // Load all current fonts first 333 | await figma.loadFontAsync(node.getRangeFontName(i, i + 1) as FontName) 334 | } 335 | let isModified = false 336 | let isUnmodified = false 337 | for (let i = 0; i < textNode.characters.length; i++) { 338 | switch (await applyToRange(textNode, i, i + 1)) { 339 | case TextOutcome.Modified: 340 | isModified = true 341 | break 342 | case TextOutcome.Unmodified: 343 | isUnmodified = true 344 | break 345 | case TextOutcome.Unsupported: 346 | break 347 | } 348 | } 349 | if (isModified) count.modified++ 350 | else if (isUnmodified) count.texts++ 351 | else count.others++ 352 | } else { 353 | // Check entire text 354 | switch (await applyToRange(textNode, 0, textNode.characters.length)) { 355 | case TextOutcome.Modified: 356 | count.modified++ 357 | break 358 | case TextOutcome.Unmodified: 359 | count.texts++ 360 | break 361 | case TextOutcome.Unsupported: 362 | count.others++ 363 | break 364 | default: 365 | break 366 | } 367 | } 368 | } 369 | 370 | return count 371 | } 372 | 373 | async function run() { 374 | const count = await traverse(figma.currentPage.selection) 375 | let message = "" 376 | if (count.modified === 1) { 377 | message = "Updated 1 text ✅" 378 | } else if (count.modified) { 379 | message = `Updated ${count.modified} texts ✅` 380 | } else if (count.texts && count.others) { 381 | message = "Texts in selection are already fixed 👍" 382 | } else if (count.texts === 1 && !count.others) { 383 | message = "Text is already fixed 👍" 384 | } else if (count.texts) { 385 | message = "Selected texts are already fixed 👍" 386 | } else { 387 | message = 388 | "Please select texts with 'SF Pro', 'SF Pro Display', 'SF Pro Text', 'SF Pro Rounded', or 'New York' font." 389 | } 390 | figma.closePlugin(message) 391 | } 392 | 393 | run() 394 | -------------------------------------------------------------------------------- /cover.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/charliecm/figma-fix-sf/fe045581a8973e29303c7364c4beffe51c5045db/cover.png -------------------------------------------------------------------------------- /manifest.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "Fix San Francisco", 3 | "id": "742063658553085504", 4 | "api": "1.0.0", 5 | "main": "code.js", 6 | "editorType": [ 7 | "figma" 8 | ], 9 | "documentAccess": "dynamic-page", 10 | "networkAccess": { 11 | "allowedDomains": [ 12 | "none" 13 | ] 14 | } 15 | } -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "figma-fix-sf", 3 | "lockfileVersion": 2, 4 | "requires": true, 5 | "packages": { 6 | "": { 7 | "name": "figma-fix-sf", 8 | "license": "MIT", 9 | "devDependencies": { 10 | "@figma/eslint-plugin-figma-plugins": "^0.14.0", 11 | "@figma/plugin-typings": "^1.87.0", 12 | "@typescript-eslint/eslint-plugin": "^7.1.0", 13 | "@typescript-eslint/parser": "^7.1.0", 14 | "eslint": "^8.57.0", 15 | "typescript": "^5.3.3", 16 | "typescript-eslint": "^7.1.0" 17 | } 18 | }, 19 | "node_modules/@aashutoshrathi/word-wrap": { 20 | "version": "1.2.6", 21 | "resolved": "https://registry.npmjs.org/@aashutoshrathi/word-wrap/-/word-wrap-1.2.6.tgz", 22 | "integrity": "sha512-1Yjs2SvM8TflER/OD3cOjhWWOZb58A2t7wpE2S9XfBYTiIl+XFhQG2bjy4Pu1I+EAlCNUzRDYDdFwFYUKvXcIA==", 23 | "dev": true, 24 | "engines": { 25 | "node": ">=0.10.0" 26 | } 27 | }, 28 | "node_modules/@eslint-community/eslint-utils": { 29 | "version": "4.4.0", 30 | "resolved": "https://registry.npmjs.org/@eslint-community/eslint-utils/-/eslint-utils-4.4.0.tgz", 31 | "integrity": "sha512-1/sA4dwrzBAyeUoQ6oxahHKmrZvsnLCg4RfxW3ZFGGmQkSNQPFNLV9CUEFQP1x9EYXHTo5p6xdhZM1Ne9p/AfA==", 32 | "dev": true, 33 | "dependencies": { 34 | "eslint-visitor-keys": "^3.3.0" 35 | }, 36 | "engines": { 37 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 38 | }, 39 | "peerDependencies": { 40 | "eslint": "^6.0.0 || ^7.0.0 || >=8.0.0" 41 | } 42 | }, 43 | "node_modules/@eslint-community/regexpp": { 44 | "version": "4.10.0", 45 | "resolved": "https://registry.npmjs.org/@eslint-community/regexpp/-/regexpp-4.10.0.tgz", 46 | "integrity": "sha512-Cu96Sd2By9mCNTx2iyKOmq10v22jUVQv0lQnlGNy16oE9589yE+QADPbrMGCkA51cKZSg3Pu/aTJVTGfL/qjUA==", 47 | "dev": true, 48 | "engines": { 49 | "node": "^12.0.0 || ^14.0.0 || >=16.0.0" 50 | } 51 | }, 52 | "node_modules/@eslint/eslintrc": { 53 | "version": "2.1.4", 54 | "resolved": "https://registry.npmjs.org/@eslint/eslintrc/-/eslintrc-2.1.4.tgz", 55 | "integrity": "sha512-269Z39MS6wVJtsoUl10L60WdkhJVdPG24Q4eZTH3nnF6lpvSShEK3wQjDX9JRWAUPvPh7COouPpU9IrqaZFvtQ==", 56 | "dev": true, 57 | "dependencies": { 58 | "ajv": "^6.12.4", 59 | "debug": "^4.3.2", 60 | "espree": "^9.6.0", 61 | "globals": "^13.19.0", 62 | "ignore": "^5.2.0", 63 | "import-fresh": "^3.2.1", 64 | "js-yaml": "^4.1.0", 65 | "minimatch": "^3.1.2", 66 | "strip-json-comments": "^3.1.1" 67 | }, 68 | "engines": { 69 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 70 | }, 71 | "funding": { 72 | "url": "https://opencollective.com/eslint" 73 | } 74 | }, 75 | "node_modules/@eslint/eslintrc/node_modules/brace-expansion": { 76 | "version": "1.1.11", 77 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 78 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 79 | "dev": true, 80 | "dependencies": { 81 | "balanced-match": "^1.0.0", 82 | "concat-map": "0.0.1" 83 | } 84 | }, 85 | "node_modules/@eslint/eslintrc/node_modules/minimatch": { 86 | "version": "3.1.2", 87 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", 88 | "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", 89 | "dev": true, 90 | "dependencies": { 91 | "brace-expansion": "^1.1.7" 92 | }, 93 | "engines": { 94 | "node": "*" 95 | } 96 | }, 97 | "node_modules/@eslint/js": { 98 | "version": "8.57.0", 99 | "resolved": "https://registry.npmjs.org/@eslint/js/-/js-8.57.0.tgz", 100 | "integrity": "sha512-Ys+3g2TaW7gADOJzPt83SJtCDhMjndcDMFVQ/Tj9iA1BfJzFKD9mAUXT3OenpuPHbI6P/myECxRJrofUsDx/5g==", 101 | "dev": true, 102 | "engines": { 103 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 104 | } 105 | }, 106 | "node_modules/@figma/eslint-plugin-figma-plugins": { 107 | "version": "0.14.0", 108 | "resolved": "https://registry.npmjs.org/@figma/eslint-plugin-figma-plugins/-/eslint-plugin-figma-plugins-0.14.0.tgz", 109 | "integrity": "sha512-tkWXJACqX84t0vnxCO+298xw1AJByds/97Xgf26KR8bzGA21NoFM9CZOSLOggCnXZANJH6720qLxBYi/HVZMcA==", 110 | "dev": true, 111 | "dependencies": { 112 | "@typescript-eslint/typescript-estree": "^6.13.2", 113 | "@typescript-eslint/utils": "^6.12.0", 114 | "typescript": "^5.3.2" 115 | } 116 | }, 117 | "node_modules/@figma/eslint-plugin-figma-plugins/node_modules/@typescript-eslint/scope-manager": { 118 | "version": "6.21.0", 119 | "resolved": "https://registry.npmjs.org/@typescript-eslint/scope-manager/-/scope-manager-6.21.0.tgz", 120 | "integrity": "sha512-OwLUIWZJry80O99zvqXVEioyniJMa+d2GrqpUTqi5/v5D5rOrppJVBPa0yKCblcigC0/aYAzxxqQ1B+DS2RYsg==", 121 | "dev": true, 122 | "dependencies": { 123 | "@typescript-eslint/types": "6.21.0", 124 | "@typescript-eslint/visitor-keys": "6.21.0" 125 | }, 126 | "engines": { 127 | "node": "^16.0.0 || >=18.0.0" 128 | }, 129 | "funding": { 130 | "type": "opencollective", 131 | "url": "https://opencollective.com/typescript-eslint" 132 | } 133 | }, 134 | "node_modules/@figma/eslint-plugin-figma-plugins/node_modules/@typescript-eslint/types": { 135 | "version": "6.21.0", 136 | "resolved": "https://registry.npmjs.org/@typescript-eslint/types/-/types-6.21.0.tgz", 137 | "integrity": "sha512-1kFmZ1rOm5epu9NZEZm1kckCDGj5UJEf7P1kliH4LKu/RkwpsfqqGmY2OOcUs18lSlQBKLDYBOGxRVtrMN5lpg==", 138 | "dev": true, 139 | "engines": { 140 | "node": "^16.0.0 || >=18.0.0" 141 | }, 142 | "funding": { 143 | "type": "opencollective", 144 | "url": "https://opencollective.com/typescript-eslint" 145 | } 146 | }, 147 | "node_modules/@figma/eslint-plugin-figma-plugins/node_modules/@typescript-eslint/typescript-estree": { 148 | "version": "6.21.0", 149 | "resolved": "https://registry.npmjs.org/@typescript-eslint/typescript-estree/-/typescript-estree-6.21.0.tgz", 150 | "integrity": "sha512-6npJTkZcO+y2/kr+z0hc4HwNfrrP4kNYh57ek7yCNlrBjWQ1Y0OS7jiZTkgumrvkX5HkEKXFZkkdFNkaW2wmUQ==", 151 | "dev": true, 152 | "dependencies": { 153 | "@typescript-eslint/types": "6.21.0", 154 | "@typescript-eslint/visitor-keys": "6.21.0", 155 | "debug": "^4.3.4", 156 | "globby": "^11.1.0", 157 | "is-glob": "^4.0.3", 158 | "minimatch": "9.0.3", 159 | "semver": "^7.5.4", 160 | "ts-api-utils": "^1.0.1" 161 | }, 162 | "engines": { 163 | "node": "^16.0.0 || >=18.0.0" 164 | }, 165 | "funding": { 166 | "type": "opencollective", 167 | "url": "https://opencollective.com/typescript-eslint" 168 | }, 169 | "peerDependenciesMeta": { 170 | "typescript": { 171 | "optional": true 172 | } 173 | } 174 | }, 175 | "node_modules/@figma/eslint-plugin-figma-plugins/node_modules/@typescript-eslint/utils": { 176 | "version": "6.21.0", 177 | "resolved": "https://registry.npmjs.org/@typescript-eslint/utils/-/utils-6.21.0.tgz", 178 | "integrity": "sha512-NfWVaC8HP9T8cbKQxHcsJBY5YE1O33+jpMwN45qzWWaPDZgLIbo12toGMWnmhvCpd3sIxkpDw3Wv1B3dYrbDQQ==", 179 | "dev": true, 180 | "dependencies": { 181 | "@eslint-community/eslint-utils": "^4.4.0", 182 | "@types/json-schema": "^7.0.12", 183 | "@types/semver": "^7.5.0", 184 | "@typescript-eslint/scope-manager": "6.21.0", 185 | "@typescript-eslint/types": "6.21.0", 186 | "@typescript-eslint/typescript-estree": "6.21.0", 187 | "semver": "^7.5.4" 188 | }, 189 | "engines": { 190 | "node": "^16.0.0 || >=18.0.0" 191 | }, 192 | "funding": { 193 | "type": "opencollective", 194 | "url": "https://opencollective.com/typescript-eslint" 195 | }, 196 | "peerDependencies": { 197 | "eslint": "^7.0.0 || ^8.0.0" 198 | } 199 | }, 200 | "node_modules/@figma/eslint-plugin-figma-plugins/node_modules/@typescript-eslint/visitor-keys": { 201 | "version": "6.21.0", 202 | "resolved": "https://registry.npmjs.org/@typescript-eslint/visitor-keys/-/visitor-keys-6.21.0.tgz", 203 | "integrity": "sha512-JJtkDduxLi9bivAB+cYOVMtbkqdPOhZ+ZI5LC47MIRrDV4Yn2o+ZnW10Nkmr28xRpSpdJ6Sm42Hjf2+REYXm0A==", 204 | "dev": true, 205 | "dependencies": { 206 | "@typescript-eslint/types": "6.21.0", 207 | "eslint-visitor-keys": "^3.4.1" 208 | }, 209 | "engines": { 210 | "node": "^16.0.0 || >=18.0.0" 211 | }, 212 | "funding": { 213 | "type": "opencollective", 214 | "url": "https://opencollective.com/typescript-eslint" 215 | } 216 | }, 217 | "node_modules/@figma/plugin-typings": { 218 | "version": "1.87.0", 219 | "resolved": "https://registry.npmjs.org/@figma/plugin-typings/-/plugin-typings-1.87.0.tgz", 220 | "integrity": "sha512-n/dZtw4G5J91mgi+OHZ8MpKkeFd5oRwIVZ8/Ju0BN+/LTcvj9lOPPDuCFBplS0lMBpcBYKn5eQxFuBpQv5t2lw==", 221 | "dev": true 222 | }, 223 | "node_modules/@humanwhocodes/config-array": { 224 | "version": "0.11.14", 225 | "resolved": "https://registry.npmjs.org/@humanwhocodes/config-array/-/config-array-0.11.14.tgz", 226 | "integrity": "sha512-3T8LkOmg45BV5FICb15QQMsyUSWrQ8AygVfC7ZG32zOalnqrilm018ZVCw0eapXux8FtA33q8PSRSstjee3jSg==", 227 | "dev": true, 228 | "dependencies": { 229 | "@humanwhocodes/object-schema": "^2.0.2", 230 | "debug": "^4.3.1", 231 | "minimatch": "^3.0.5" 232 | }, 233 | "engines": { 234 | "node": ">=10.10.0" 235 | } 236 | }, 237 | "node_modules/@humanwhocodes/config-array/node_modules/brace-expansion": { 238 | "version": "1.1.11", 239 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 240 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 241 | "dev": true, 242 | "dependencies": { 243 | "balanced-match": "^1.0.0", 244 | "concat-map": "0.0.1" 245 | } 246 | }, 247 | "node_modules/@humanwhocodes/config-array/node_modules/minimatch": { 248 | "version": "3.1.2", 249 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", 250 | "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", 251 | "dev": true, 252 | "dependencies": { 253 | "brace-expansion": "^1.1.7" 254 | }, 255 | "engines": { 256 | "node": "*" 257 | } 258 | }, 259 | "node_modules/@humanwhocodes/module-importer": { 260 | "version": "1.0.1", 261 | "resolved": "https://registry.npmjs.org/@humanwhocodes/module-importer/-/module-importer-1.0.1.tgz", 262 | "integrity": "sha512-bxveV4V8v5Yb4ncFTT3rPSgZBOpCkjfK0y4oVVVJwIuDVBRMDXrPyXRL988i5ap9m9bnyEEjWfm5WkBmtffLfA==", 263 | "dev": true, 264 | "engines": { 265 | "node": ">=12.22" 266 | }, 267 | "funding": { 268 | "type": "github", 269 | "url": "https://github.com/sponsors/nzakas" 270 | } 271 | }, 272 | "node_modules/@humanwhocodes/object-schema": { 273 | "version": "2.0.2", 274 | "resolved": "https://registry.npmjs.org/@humanwhocodes/object-schema/-/object-schema-2.0.2.tgz", 275 | "integrity": "sha512-6EwiSjwWYP7pTckG6I5eyFANjPhmPjUX9JRLUSfNPC7FX7zK9gyZAfUEaECL6ALTpGX5AjnBq3C9XmVWPitNpw==", 276 | "dev": true 277 | }, 278 | "node_modules/@nodelib/fs.scandir": { 279 | "version": "2.1.5", 280 | "resolved": "https://registry.npmjs.org/@nodelib/fs.scandir/-/fs.scandir-2.1.5.tgz", 281 | "integrity": "sha512-vq24Bq3ym5HEQm2NKCr3yXDwjc7vTsEThRDnkp2DK9p1uqLR+DHurm/NOTo0KG7HYHU7eppKZj3MyqYuMBf62g==", 282 | "dev": true, 283 | "dependencies": { 284 | "@nodelib/fs.stat": "2.0.5", 285 | "run-parallel": "^1.1.9" 286 | }, 287 | "engines": { 288 | "node": ">= 8" 289 | } 290 | }, 291 | "node_modules/@nodelib/fs.stat": { 292 | "version": "2.0.5", 293 | "resolved": "https://registry.npmjs.org/@nodelib/fs.stat/-/fs.stat-2.0.5.tgz", 294 | "integrity": "sha512-RkhPPp2zrqDAQA/2jNhnztcPAlv64XdhIp7a7454A5ovI7Bukxgt7MX7udwAu3zg1DcpPU0rz3VV1SeaqvY4+A==", 295 | "dev": true, 296 | "engines": { 297 | "node": ">= 8" 298 | } 299 | }, 300 | "node_modules/@nodelib/fs.walk": { 301 | "version": "1.2.8", 302 | "resolved": "https://registry.npmjs.org/@nodelib/fs.walk/-/fs.walk-1.2.8.tgz", 303 | "integrity": "sha512-oGB+UxlgWcgQkgwo8GcEGwemoTFt3FIO9ababBmaGwXIoBKZ+GTy0pP185beGg7Llih/NSHSV2XAs1lnznocSg==", 304 | "dev": true, 305 | "dependencies": { 306 | "@nodelib/fs.scandir": "2.1.5", 307 | "fastq": "^1.6.0" 308 | }, 309 | "engines": { 310 | "node": ">= 8" 311 | } 312 | }, 313 | "node_modules/@types/json-schema": { 314 | "version": "7.0.15", 315 | "resolved": "https://registry.npmjs.org/@types/json-schema/-/json-schema-7.0.15.tgz", 316 | "integrity": "sha512-5+fP8P8MFNC+AyZCDxrB2pkZFPGzqQWUzpSeuuVLvm8VMcorNYavBqoFcxK8bQz4Qsbn4oUEEem4wDLfcysGHA==", 317 | "dev": true 318 | }, 319 | "node_modules/@types/semver": { 320 | "version": "7.5.8", 321 | "resolved": "https://registry.npmjs.org/@types/semver/-/semver-7.5.8.tgz", 322 | "integrity": "sha512-I8EUhyrgfLrcTkzV3TSsGyl1tSuPrEDzr0yd5m90UgNxQkyDXULk3b6MlQqTCpZpNtWe1K0hzclnZkTcLBe2UQ==", 323 | "dev": true 324 | }, 325 | "node_modules/@typescript-eslint/eslint-plugin": { 326 | "version": "7.1.0", 327 | "resolved": "https://registry.npmjs.org/@typescript-eslint/eslint-plugin/-/eslint-plugin-7.1.0.tgz", 328 | "integrity": "sha512-j6vT/kCulhG5wBmGtstKeiVr1rdXE4nk+DT1k6trYkwlrvW9eOF5ZbgKnd/YR6PcM4uTEXa0h6Fcvf6X7Dxl0w==", 329 | "dev": true, 330 | "dependencies": { 331 | "@eslint-community/regexpp": "^4.5.1", 332 | "@typescript-eslint/scope-manager": "7.1.0", 333 | "@typescript-eslint/type-utils": "7.1.0", 334 | "@typescript-eslint/utils": "7.1.0", 335 | "@typescript-eslint/visitor-keys": "7.1.0", 336 | "debug": "^4.3.4", 337 | "graphemer": "^1.4.0", 338 | "ignore": "^5.2.4", 339 | "natural-compare": "^1.4.0", 340 | "semver": "^7.5.4", 341 | "ts-api-utils": "^1.0.1" 342 | }, 343 | "engines": { 344 | "node": "^16.0.0 || >=18.0.0" 345 | }, 346 | "funding": { 347 | "type": "opencollective", 348 | "url": "https://opencollective.com/typescript-eslint" 349 | }, 350 | "peerDependencies": { 351 | "@typescript-eslint/parser": "^7.0.0", 352 | "eslint": "^8.56.0" 353 | }, 354 | "peerDependenciesMeta": { 355 | "typescript": { 356 | "optional": true 357 | } 358 | } 359 | }, 360 | "node_modules/@typescript-eslint/parser": { 361 | "version": "7.1.0", 362 | "resolved": "https://registry.npmjs.org/@typescript-eslint/parser/-/parser-7.1.0.tgz", 363 | "integrity": "sha512-V1EknKUubZ1gWFjiOZhDSNToOjs63/9O0puCgGS8aDOgpZY326fzFu15QAUjwaXzRZjf/qdsdBrckYdv9YxB8w==", 364 | "dev": true, 365 | "dependencies": { 366 | "@typescript-eslint/scope-manager": "7.1.0", 367 | "@typescript-eslint/types": "7.1.0", 368 | "@typescript-eslint/typescript-estree": "7.1.0", 369 | "@typescript-eslint/visitor-keys": "7.1.0", 370 | "debug": "^4.3.4" 371 | }, 372 | "engines": { 373 | "node": "^16.0.0 || >=18.0.0" 374 | }, 375 | "funding": { 376 | "type": "opencollective", 377 | "url": "https://opencollective.com/typescript-eslint" 378 | }, 379 | "peerDependencies": { 380 | "eslint": "^8.56.0" 381 | }, 382 | "peerDependenciesMeta": { 383 | "typescript": { 384 | "optional": true 385 | } 386 | } 387 | }, 388 | "node_modules/@typescript-eslint/scope-manager": { 389 | "version": "7.1.0", 390 | "resolved": "https://registry.npmjs.org/@typescript-eslint/scope-manager/-/scope-manager-7.1.0.tgz", 391 | "integrity": "sha512-6TmN4OJiohHfoOdGZ3huuLhpiUgOGTpgXNUPJgeZOZR3DnIpdSgtt83RS35OYNNXxM4TScVlpVKC9jyQSETR1A==", 392 | "dev": true, 393 | "dependencies": { 394 | "@typescript-eslint/types": "7.1.0", 395 | "@typescript-eslint/visitor-keys": "7.1.0" 396 | }, 397 | "engines": { 398 | "node": "^16.0.0 || >=18.0.0" 399 | }, 400 | "funding": { 401 | "type": "opencollective", 402 | "url": "https://opencollective.com/typescript-eslint" 403 | } 404 | }, 405 | "node_modules/@typescript-eslint/type-utils": { 406 | "version": "7.1.0", 407 | "resolved": "https://registry.npmjs.org/@typescript-eslint/type-utils/-/type-utils-7.1.0.tgz", 408 | "integrity": "sha512-UZIhv8G+5b5skkcuhgvxYWHjk7FW7/JP5lPASMEUoliAPwIH/rxoUSQPia2cuOj9AmDZmwUl1usKm85t5VUMew==", 409 | "dev": true, 410 | "dependencies": { 411 | "@typescript-eslint/typescript-estree": "7.1.0", 412 | "@typescript-eslint/utils": "7.1.0", 413 | "debug": "^4.3.4", 414 | "ts-api-utils": "^1.0.1" 415 | }, 416 | "engines": { 417 | "node": "^16.0.0 || >=18.0.0" 418 | }, 419 | "funding": { 420 | "type": "opencollective", 421 | "url": "https://opencollective.com/typescript-eslint" 422 | }, 423 | "peerDependencies": { 424 | "eslint": "^8.56.0" 425 | }, 426 | "peerDependenciesMeta": { 427 | "typescript": { 428 | "optional": true 429 | } 430 | } 431 | }, 432 | "node_modules/@typescript-eslint/types": { 433 | "version": "7.1.0", 434 | "resolved": "https://registry.npmjs.org/@typescript-eslint/types/-/types-7.1.0.tgz", 435 | "integrity": "sha512-qTWjWieJ1tRJkxgZYXx6WUYtWlBc48YRxgY2JN1aGeVpkhmnopq+SUC8UEVGNXIvWH7XyuTjwALfG6bFEgCkQA==", 436 | "dev": true, 437 | "engines": { 438 | "node": "^16.0.0 || >=18.0.0" 439 | }, 440 | "funding": { 441 | "type": "opencollective", 442 | "url": "https://opencollective.com/typescript-eslint" 443 | } 444 | }, 445 | "node_modules/@typescript-eslint/typescript-estree": { 446 | "version": "7.1.0", 447 | "resolved": "https://registry.npmjs.org/@typescript-eslint/typescript-estree/-/typescript-estree-7.1.0.tgz", 448 | "integrity": "sha512-k7MyrbD6E463CBbSpcOnwa8oXRdHzH1WiVzOipK3L5KSML92ZKgUBrTlehdi7PEIMT8k0bQixHUGXggPAlKnOQ==", 449 | "dev": true, 450 | "dependencies": { 451 | "@typescript-eslint/types": "7.1.0", 452 | "@typescript-eslint/visitor-keys": "7.1.0", 453 | "debug": "^4.3.4", 454 | "globby": "^11.1.0", 455 | "is-glob": "^4.0.3", 456 | "minimatch": "9.0.3", 457 | "semver": "^7.5.4", 458 | "ts-api-utils": "^1.0.1" 459 | }, 460 | "engines": { 461 | "node": "^16.0.0 || >=18.0.0" 462 | }, 463 | "funding": { 464 | "type": "opencollective", 465 | "url": "https://opencollective.com/typescript-eslint" 466 | }, 467 | "peerDependenciesMeta": { 468 | "typescript": { 469 | "optional": true 470 | } 471 | } 472 | }, 473 | "node_modules/@typescript-eslint/utils": { 474 | "version": "7.1.0", 475 | "resolved": "https://registry.npmjs.org/@typescript-eslint/utils/-/utils-7.1.0.tgz", 476 | "integrity": "sha512-WUFba6PZC5OCGEmbweGpnNJytJiLG7ZvDBJJoUcX4qZYf1mGZ97mO2Mps6O2efxJcJdRNpqweCistDbZMwIVHw==", 477 | "dev": true, 478 | "dependencies": { 479 | "@eslint-community/eslint-utils": "^4.4.0", 480 | "@types/json-schema": "^7.0.12", 481 | "@types/semver": "^7.5.0", 482 | "@typescript-eslint/scope-manager": "7.1.0", 483 | "@typescript-eslint/types": "7.1.0", 484 | "@typescript-eslint/typescript-estree": "7.1.0", 485 | "semver": "^7.5.4" 486 | }, 487 | "engines": { 488 | "node": "^16.0.0 || >=18.0.0" 489 | }, 490 | "funding": { 491 | "type": "opencollective", 492 | "url": "https://opencollective.com/typescript-eslint" 493 | }, 494 | "peerDependencies": { 495 | "eslint": "^8.56.0" 496 | } 497 | }, 498 | "node_modules/@typescript-eslint/visitor-keys": { 499 | "version": "7.1.0", 500 | "resolved": "https://registry.npmjs.org/@typescript-eslint/visitor-keys/-/visitor-keys-7.1.0.tgz", 501 | "integrity": "sha512-FhUqNWluiGNzlvnDZiXad4mZRhtghdoKW6e98GoEOYSu5cND+E39rG5KwJMUzeENwm1ztYBRqof8wMLP+wNPIA==", 502 | "dev": true, 503 | "dependencies": { 504 | "@typescript-eslint/types": "7.1.0", 505 | "eslint-visitor-keys": "^3.4.1" 506 | }, 507 | "engines": { 508 | "node": "^16.0.0 || >=18.0.0" 509 | }, 510 | "funding": { 511 | "type": "opencollective", 512 | "url": "https://opencollective.com/typescript-eslint" 513 | } 514 | }, 515 | "node_modules/@ungap/structured-clone": { 516 | "version": "1.2.0", 517 | "resolved": "https://registry.npmjs.org/@ungap/structured-clone/-/structured-clone-1.2.0.tgz", 518 | "integrity": "sha512-zuVdFrMJiuCDQUMCzQaD6KL28MjnqqN8XnAqiEq9PNm/hCPTSGfrXCOfwj1ow4LFb/tNymJPwsNbVePc1xFqrQ==", 519 | "dev": true 520 | }, 521 | "node_modules/acorn": { 522 | "version": "8.11.3", 523 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.11.3.tgz", 524 | "integrity": "sha512-Y9rRfJG5jcKOE0CLisYbojUjIrIEE7AGMzA/Sm4BslANhbS+cDMpgBdcPT91oJ7OuJ9hYJBx59RjbhxVnrF8Xg==", 525 | "dev": true, 526 | "bin": { 527 | "acorn": "bin/acorn" 528 | }, 529 | "engines": { 530 | "node": ">=0.4.0" 531 | } 532 | }, 533 | "node_modules/acorn-jsx": { 534 | "version": "5.3.2", 535 | "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.3.2.tgz", 536 | "integrity": "sha512-rq9s+JNhf0IChjtDXxllJ7g41oZk5SlXtp0LHwyA5cejwn7vKmKp4pPri6YEePv2PU65sAsegbXtIinmDFDXgQ==", 537 | "dev": true, 538 | "peerDependencies": { 539 | "acorn": "^6.0.0 || ^7.0.0 || ^8.0.0" 540 | } 541 | }, 542 | "node_modules/ajv": { 543 | "version": "6.12.6", 544 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.12.6.tgz", 545 | "integrity": "sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g==", 546 | "dev": true, 547 | "dependencies": { 548 | "fast-deep-equal": "^3.1.1", 549 | "fast-json-stable-stringify": "^2.0.0", 550 | "json-schema-traverse": "^0.4.1", 551 | "uri-js": "^4.2.2" 552 | }, 553 | "funding": { 554 | "type": "github", 555 | "url": "https://github.com/sponsors/epoberezkin" 556 | } 557 | }, 558 | "node_modules/ansi-regex": { 559 | "version": "5.0.1", 560 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 561 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 562 | "dev": true, 563 | "engines": { 564 | "node": ">=8" 565 | } 566 | }, 567 | "node_modules/ansi-styles": { 568 | "version": "4.3.0", 569 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 570 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 571 | "dev": true, 572 | "dependencies": { 573 | "color-convert": "^2.0.1" 574 | }, 575 | "engines": { 576 | "node": ">=8" 577 | }, 578 | "funding": { 579 | "url": "https://github.com/chalk/ansi-styles?sponsor=1" 580 | } 581 | }, 582 | "node_modules/argparse": { 583 | "version": "2.0.1", 584 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-2.0.1.tgz", 585 | "integrity": "sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==", 586 | "dev": true 587 | }, 588 | "node_modules/array-union": { 589 | "version": "2.1.0", 590 | "resolved": "https://registry.npmjs.org/array-union/-/array-union-2.1.0.tgz", 591 | "integrity": "sha512-HGyxoOTYUyCM6stUe6EJgnd4EoewAI7zMdfqO+kGjnlZmBDz/cR5pf8r/cR4Wq60sL/p0IkcjUEEPwS3GFrIyw==", 592 | "dev": true, 593 | "engines": { 594 | "node": ">=8" 595 | } 596 | }, 597 | "node_modules/balanced-match": { 598 | "version": "1.0.2", 599 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", 600 | "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==", 601 | "dev": true 602 | }, 603 | "node_modules/brace-expansion": { 604 | "version": "2.0.1", 605 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-2.0.1.tgz", 606 | "integrity": "sha512-XnAIvQ8eM+kC6aULx6wuQiwVsnzsi9d3WxzV3FpWTGA19F621kwdbsAcFKXgKUHZWsy+mY6iL1sHTxWEFCytDA==", 607 | "dev": true, 608 | "dependencies": { 609 | "balanced-match": "^1.0.0" 610 | } 611 | }, 612 | "node_modules/braces": { 613 | "version": "3.0.2", 614 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", 615 | "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", 616 | "dev": true, 617 | "dependencies": { 618 | "fill-range": "^7.0.1" 619 | }, 620 | "engines": { 621 | "node": ">=8" 622 | } 623 | }, 624 | "node_modules/callsites": { 625 | "version": "3.1.0", 626 | "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz", 627 | "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==", 628 | "dev": true, 629 | "engines": { 630 | "node": ">=6" 631 | } 632 | }, 633 | "node_modules/chalk": { 634 | "version": "4.1.2", 635 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", 636 | "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", 637 | "dev": true, 638 | "dependencies": { 639 | "ansi-styles": "^4.1.0", 640 | "supports-color": "^7.1.0" 641 | }, 642 | "engines": { 643 | "node": ">=10" 644 | }, 645 | "funding": { 646 | "url": "https://github.com/chalk/chalk?sponsor=1" 647 | } 648 | }, 649 | "node_modules/color-convert": { 650 | "version": "2.0.1", 651 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 652 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 653 | "dev": true, 654 | "dependencies": { 655 | "color-name": "~1.1.4" 656 | }, 657 | "engines": { 658 | "node": ">=7.0.0" 659 | } 660 | }, 661 | "node_modules/color-name": { 662 | "version": "1.1.4", 663 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 664 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 665 | "dev": true 666 | }, 667 | "node_modules/concat-map": { 668 | "version": "0.0.1", 669 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 670 | "integrity": "sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg==", 671 | "dev": true 672 | }, 673 | "node_modules/cross-spawn": { 674 | "version": "7.0.3", 675 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz", 676 | "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==", 677 | "dev": true, 678 | "dependencies": { 679 | "path-key": "^3.1.0", 680 | "shebang-command": "^2.0.0", 681 | "which": "^2.0.1" 682 | }, 683 | "engines": { 684 | "node": ">= 8" 685 | } 686 | }, 687 | "node_modules/debug": { 688 | "version": "4.3.4", 689 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", 690 | "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", 691 | "dev": true, 692 | "dependencies": { 693 | "ms": "2.1.2" 694 | }, 695 | "engines": { 696 | "node": ">=6.0" 697 | }, 698 | "peerDependenciesMeta": { 699 | "supports-color": { 700 | "optional": true 701 | } 702 | } 703 | }, 704 | "node_modules/deep-is": { 705 | "version": "0.1.4", 706 | "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.4.tgz", 707 | "integrity": "sha512-oIPzksmTg4/MriiaYGO+okXDT7ztn/w3Eptv/+gSIdMdKsJo0u4CfYNFJPy+4SKMuCqGw2wxnA+URMg3t8a/bQ==", 708 | "dev": true 709 | }, 710 | "node_modules/dir-glob": { 711 | "version": "3.0.1", 712 | "resolved": "https://registry.npmjs.org/dir-glob/-/dir-glob-3.0.1.tgz", 713 | "integrity": "sha512-WkrWp9GR4KXfKGYzOLmTuGVi1UWFfws377n9cc55/tb6DuqyF6pcQ5AbiHEshaDpY9v6oaSr2XCDidGmMwdzIA==", 714 | "dev": true, 715 | "dependencies": { 716 | "path-type": "^4.0.0" 717 | }, 718 | "engines": { 719 | "node": ">=8" 720 | } 721 | }, 722 | "node_modules/doctrine": { 723 | "version": "3.0.0", 724 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-3.0.0.tgz", 725 | "integrity": "sha512-yS+Q5i3hBf7GBkd4KG8a7eBNNWNGLTaEwwYWUijIYM7zrlYDM0BFXHjjPWlWZ1Rg7UaddZeIDmi9jF3HmqiQ2w==", 726 | "dev": true, 727 | "dependencies": { 728 | "esutils": "^2.0.2" 729 | }, 730 | "engines": { 731 | "node": ">=6.0.0" 732 | } 733 | }, 734 | "node_modules/escape-string-regexp": { 735 | "version": "4.0.0", 736 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", 737 | "integrity": "sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA==", 738 | "dev": true, 739 | "engines": { 740 | "node": ">=10" 741 | }, 742 | "funding": { 743 | "url": "https://github.com/sponsors/sindresorhus" 744 | } 745 | }, 746 | "node_modules/eslint": { 747 | "version": "8.57.0", 748 | "resolved": "https://registry.npmjs.org/eslint/-/eslint-8.57.0.tgz", 749 | "integrity": "sha512-dZ6+mexnaTIbSBZWgou51U6OmzIhYM2VcNdtiTtI7qPNZm35Akpr0f6vtw3w1Kmn5PYo+tZVfh13WrhpS6oLqQ==", 750 | "dev": true, 751 | "dependencies": { 752 | "@eslint-community/eslint-utils": "^4.2.0", 753 | "@eslint-community/regexpp": "^4.6.1", 754 | "@eslint/eslintrc": "^2.1.4", 755 | "@eslint/js": "8.57.0", 756 | "@humanwhocodes/config-array": "^0.11.14", 757 | "@humanwhocodes/module-importer": "^1.0.1", 758 | "@nodelib/fs.walk": "^1.2.8", 759 | "@ungap/structured-clone": "^1.2.0", 760 | "ajv": "^6.12.4", 761 | "chalk": "^4.0.0", 762 | "cross-spawn": "^7.0.2", 763 | "debug": "^4.3.2", 764 | "doctrine": "^3.0.0", 765 | "escape-string-regexp": "^4.0.0", 766 | "eslint-scope": "^7.2.2", 767 | "eslint-visitor-keys": "^3.4.3", 768 | "espree": "^9.6.1", 769 | "esquery": "^1.4.2", 770 | "esutils": "^2.0.2", 771 | "fast-deep-equal": "^3.1.3", 772 | "file-entry-cache": "^6.0.1", 773 | "find-up": "^5.0.0", 774 | "glob-parent": "^6.0.2", 775 | "globals": "^13.19.0", 776 | "graphemer": "^1.4.0", 777 | "ignore": "^5.2.0", 778 | "imurmurhash": "^0.1.4", 779 | "is-glob": "^4.0.0", 780 | "is-path-inside": "^3.0.3", 781 | "js-yaml": "^4.1.0", 782 | "json-stable-stringify-without-jsonify": "^1.0.1", 783 | "levn": "^0.4.1", 784 | "lodash.merge": "^4.6.2", 785 | "minimatch": "^3.1.2", 786 | "natural-compare": "^1.4.0", 787 | "optionator": "^0.9.3", 788 | "strip-ansi": "^6.0.1", 789 | "text-table": "^0.2.0" 790 | }, 791 | "bin": { 792 | "eslint": "bin/eslint.js" 793 | }, 794 | "engines": { 795 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 796 | }, 797 | "funding": { 798 | "url": "https://opencollective.com/eslint" 799 | } 800 | }, 801 | "node_modules/eslint-scope": { 802 | "version": "7.2.2", 803 | "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-7.2.2.tgz", 804 | "integrity": "sha512-dOt21O7lTMhDM+X9mB4GX+DZrZtCUJPL/wlcTqxyrx5IvO0IYtILdtrQGQp+8n5S0gwSVmOf9NQrjMOgfQZlIg==", 805 | "dev": true, 806 | "dependencies": { 807 | "esrecurse": "^4.3.0", 808 | "estraverse": "^5.2.0" 809 | }, 810 | "engines": { 811 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 812 | }, 813 | "funding": { 814 | "url": "https://opencollective.com/eslint" 815 | } 816 | }, 817 | "node_modules/eslint-visitor-keys": { 818 | "version": "3.4.3", 819 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-3.4.3.tgz", 820 | "integrity": "sha512-wpc+LXeiyiisxPlEkUzU6svyS1frIO3Mgxj1fdy7Pm8Ygzguax2N3Fa/D/ag1WqbOprdI+uY6wMUl8/a2G+iag==", 821 | "dev": true, 822 | "engines": { 823 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 824 | }, 825 | "funding": { 826 | "url": "https://opencollective.com/eslint" 827 | } 828 | }, 829 | "node_modules/eslint/node_modules/brace-expansion": { 830 | "version": "1.1.11", 831 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 832 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 833 | "dev": true, 834 | "dependencies": { 835 | "balanced-match": "^1.0.0", 836 | "concat-map": "0.0.1" 837 | } 838 | }, 839 | "node_modules/eslint/node_modules/minimatch": { 840 | "version": "3.1.2", 841 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", 842 | "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", 843 | "dev": true, 844 | "dependencies": { 845 | "brace-expansion": "^1.1.7" 846 | }, 847 | "engines": { 848 | "node": "*" 849 | } 850 | }, 851 | "node_modules/espree": { 852 | "version": "9.6.1", 853 | "resolved": "https://registry.npmjs.org/espree/-/espree-9.6.1.tgz", 854 | "integrity": "sha512-oruZaFkjorTpF32kDSI5/75ViwGeZginGGy2NoOSg3Q9bnwlnmDm4HLnkl0RE3n+njDXR037aY1+x58Z/zFdwQ==", 855 | "dev": true, 856 | "dependencies": { 857 | "acorn": "^8.9.0", 858 | "acorn-jsx": "^5.3.2", 859 | "eslint-visitor-keys": "^3.4.1" 860 | }, 861 | "engines": { 862 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 863 | }, 864 | "funding": { 865 | "url": "https://opencollective.com/eslint" 866 | } 867 | }, 868 | "node_modules/esquery": { 869 | "version": "1.5.0", 870 | "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.5.0.tgz", 871 | "integrity": "sha512-YQLXUplAwJgCydQ78IMJywZCceoqk1oH01OERdSAJc/7U2AylwjhSCLDEtqwg811idIS/9fIU5GjG73IgjKMVg==", 872 | "dev": true, 873 | "dependencies": { 874 | "estraverse": "^5.1.0" 875 | }, 876 | "engines": { 877 | "node": ">=0.10" 878 | } 879 | }, 880 | "node_modules/esrecurse": { 881 | "version": "4.3.0", 882 | "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.3.0.tgz", 883 | "integrity": "sha512-KmfKL3b6G+RXvP8N1vr3Tq1kL/oCFgn2NYXEtqP8/L3pKapUA4G8cFVaoF3SU323CD4XypR/ffioHmkti6/Tag==", 884 | "dev": true, 885 | "dependencies": { 886 | "estraverse": "^5.2.0" 887 | }, 888 | "engines": { 889 | "node": ">=4.0" 890 | } 891 | }, 892 | "node_modules/estraverse": { 893 | "version": "5.3.0", 894 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.3.0.tgz", 895 | "integrity": "sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==", 896 | "dev": true, 897 | "engines": { 898 | "node": ">=4.0" 899 | } 900 | }, 901 | "node_modules/esutils": { 902 | "version": "2.0.3", 903 | "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz", 904 | "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==", 905 | "dev": true, 906 | "engines": { 907 | "node": ">=0.10.0" 908 | } 909 | }, 910 | "node_modules/fast-deep-equal": { 911 | "version": "3.1.3", 912 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz", 913 | "integrity": "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==", 914 | "dev": true 915 | }, 916 | "node_modules/fast-glob": { 917 | "version": "3.3.2", 918 | "resolved": "https://registry.npmjs.org/fast-glob/-/fast-glob-3.3.2.tgz", 919 | "integrity": "sha512-oX2ruAFQwf/Orj8m737Y5adxDQO0LAB7/S5MnxCdTNDd4p6BsyIVsv9JQsATbTSq8KHRpLwIHbVlUNatxd+1Ow==", 920 | "dev": true, 921 | "dependencies": { 922 | "@nodelib/fs.stat": "^2.0.2", 923 | "@nodelib/fs.walk": "^1.2.3", 924 | "glob-parent": "^5.1.2", 925 | "merge2": "^1.3.0", 926 | "micromatch": "^4.0.4" 927 | }, 928 | "engines": { 929 | "node": ">=8.6.0" 930 | } 931 | }, 932 | "node_modules/fast-glob/node_modules/glob-parent": { 933 | "version": "5.1.2", 934 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", 935 | "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", 936 | "dev": true, 937 | "dependencies": { 938 | "is-glob": "^4.0.1" 939 | }, 940 | "engines": { 941 | "node": ">= 6" 942 | } 943 | }, 944 | "node_modules/fast-json-stable-stringify": { 945 | "version": "2.1.0", 946 | "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz", 947 | "integrity": "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==", 948 | "dev": true 949 | }, 950 | "node_modules/fast-levenshtein": { 951 | "version": "2.0.6", 952 | "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", 953 | "integrity": "sha512-DCXu6Ifhqcks7TZKY3Hxp3y6qphY5SJZmrWMDrKcERSOXWQdMhU9Ig/PYrzyw/ul9jOIyh0N4M0tbC5hodg8dw==", 954 | "dev": true 955 | }, 956 | "node_modules/fastq": { 957 | "version": "1.17.1", 958 | "resolved": "https://registry.npmjs.org/fastq/-/fastq-1.17.1.tgz", 959 | "integrity": "sha512-sRVD3lWVIXWg6By68ZN7vho9a1pQcN/WBFaAAsDDFzlJjvoGx0P8z7V1t72grFJfJhu3YPZBuu25f7Kaw2jN1w==", 960 | "dev": true, 961 | "dependencies": { 962 | "reusify": "^1.0.4" 963 | } 964 | }, 965 | "node_modules/file-entry-cache": { 966 | "version": "6.0.1", 967 | "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-6.0.1.tgz", 968 | "integrity": "sha512-7Gps/XWymbLk2QLYK4NzpMOrYjMhdIxXuIvy2QBsLE6ljuodKvdkWs/cpyJJ3CVIVpH0Oi1Hvg1ovbMzLdFBBg==", 969 | "dev": true, 970 | "dependencies": { 971 | "flat-cache": "^3.0.4" 972 | }, 973 | "engines": { 974 | "node": "^10.12.0 || >=12.0.0" 975 | } 976 | }, 977 | "node_modules/fill-range": { 978 | "version": "7.0.1", 979 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", 980 | "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", 981 | "dev": true, 982 | "dependencies": { 983 | "to-regex-range": "^5.0.1" 984 | }, 985 | "engines": { 986 | "node": ">=8" 987 | } 988 | }, 989 | "node_modules/find-up": { 990 | "version": "5.0.0", 991 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-5.0.0.tgz", 992 | "integrity": "sha512-78/PXT1wlLLDgTzDs7sjq9hzz0vXD+zn+7wypEe4fXQxCmdmqfGsEPQxmiCSQI3ajFV91bVSsvNtrJRiW6nGng==", 993 | "dev": true, 994 | "dependencies": { 995 | "locate-path": "^6.0.0", 996 | "path-exists": "^4.0.0" 997 | }, 998 | "engines": { 999 | "node": ">=10" 1000 | }, 1001 | "funding": { 1002 | "url": "https://github.com/sponsors/sindresorhus" 1003 | } 1004 | }, 1005 | "node_modules/flat-cache": { 1006 | "version": "3.2.0", 1007 | "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-3.2.0.tgz", 1008 | "integrity": "sha512-CYcENa+FtcUKLmhhqyctpclsq7QF38pKjZHsGNiSQF5r4FtoKDWabFDl3hzaEQMvT1LHEysw5twgLvpYYb4vbw==", 1009 | "dev": true, 1010 | "dependencies": { 1011 | "flatted": "^3.2.9", 1012 | "keyv": "^4.5.3", 1013 | "rimraf": "^3.0.2" 1014 | }, 1015 | "engines": { 1016 | "node": "^10.12.0 || >=12.0.0" 1017 | } 1018 | }, 1019 | "node_modules/flatted": { 1020 | "version": "3.3.1", 1021 | "resolved": "https://registry.npmjs.org/flatted/-/flatted-3.3.1.tgz", 1022 | "integrity": "sha512-X8cqMLLie7KsNUDSdzeN8FYK9rEt4Dt67OsG/DNGnYTSDBG4uFAJFBnUeiV+zCVAvwFy56IjM9sH51jVaEhNxw==", 1023 | "dev": true 1024 | }, 1025 | "node_modules/fs.realpath": { 1026 | "version": "1.0.0", 1027 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 1028 | "integrity": "sha512-OO0pH2lK6a0hZnAdau5ItzHPI6pUlvI7jMVnxUQRtw4owF2wk8lOSabtGDCTP4Ggrg2MbGnWO9X8K1t4+fGMDw==", 1029 | "dev": true 1030 | }, 1031 | "node_modules/glob": { 1032 | "version": "7.2.3", 1033 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.3.tgz", 1034 | "integrity": "sha512-nFR0zLpU2YCaRxwoCJvL6UvCH2JFyFVIvwTLsIf21AuHlMskA1hhTdk+LlYJtOlYt9v6dvszD2BGRqBL+iQK9Q==", 1035 | "dev": true, 1036 | "dependencies": { 1037 | "fs.realpath": "^1.0.0", 1038 | "inflight": "^1.0.4", 1039 | "inherits": "2", 1040 | "minimatch": "^3.1.1", 1041 | "once": "^1.3.0", 1042 | "path-is-absolute": "^1.0.0" 1043 | }, 1044 | "engines": { 1045 | "node": "*" 1046 | }, 1047 | "funding": { 1048 | "url": "https://github.com/sponsors/isaacs" 1049 | } 1050 | }, 1051 | "node_modules/glob-parent": { 1052 | "version": "6.0.2", 1053 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-6.0.2.tgz", 1054 | "integrity": "sha512-XxwI8EOhVQgWp6iDL+3b0r86f4d6AX6zSU55HfB4ydCEuXLXc5FcYeOu+nnGftS4TEju/11rt4KJPTMgbfmv4A==", 1055 | "dev": true, 1056 | "dependencies": { 1057 | "is-glob": "^4.0.3" 1058 | }, 1059 | "engines": { 1060 | "node": ">=10.13.0" 1061 | } 1062 | }, 1063 | "node_modules/glob/node_modules/brace-expansion": { 1064 | "version": "1.1.11", 1065 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 1066 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 1067 | "dev": true, 1068 | "dependencies": { 1069 | "balanced-match": "^1.0.0", 1070 | "concat-map": "0.0.1" 1071 | } 1072 | }, 1073 | "node_modules/glob/node_modules/minimatch": { 1074 | "version": "3.1.2", 1075 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", 1076 | "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", 1077 | "dev": true, 1078 | "dependencies": { 1079 | "brace-expansion": "^1.1.7" 1080 | }, 1081 | "engines": { 1082 | "node": "*" 1083 | } 1084 | }, 1085 | "node_modules/globals": { 1086 | "version": "13.24.0", 1087 | "resolved": "https://registry.npmjs.org/globals/-/globals-13.24.0.tgz", 1088 | "integrity": "sha512-AhO5QUcj8llrbG09iWhPU2B204J1xnPeL8kQmVorSsy+Sjj1sk8gIyh6cUocGmH4L0UuhAJy+hJMRA4mgA4mFQ==", 1089 | "dev": true, 1090 | "dependencies": { 1091 | "type-fest": "^0.20.2" 1092 | }, 1093 | "engines": { 1094 | "node": ">=8" 1095 | }, 1096 | "funding": { 1097 | "url": "https://github.com/sponsors/sindresorhus" 1098 | } 1099 | }, 1100 | "node_modules/globby": { 1101 | "version": "11.1.0", 1102 | "resolved": "https://registry.npmjs.org/globby/-/globby-11.1.0.tgz", 1103 | "integrity": "sha512-jhIXaOzy1sb8IyocaruWSn1TjmnBVs8Ayhcy83rmxNJ8q2uWKCAj3CnJY+KpGSXCueAPc0i05kVvVKtP1t9S3g==", 1104 | "dev": true, 1105 | "dependencies": { 1106 | "array-union": "^2.1.0", 1107 | "dir-glob": "^3.0.1", 1108 | "fast-glob": "^3.2.9", 1109 | "ignore": "^5.2.0", 1110 | "merge2": "^1.4.1", 1111 | "slash": "^3.0.0" 1112 | }, 1113 | "engines": { 1114 | "node": ">=10" 1115 | }, 1116 | "funding": { 1117 | "url": "https://github.com/sponsors/sindresorhus" 1118 | } 1119 | }, 1120 | "node_modules/graphemer": { 1121 | "version": "1.4.0", 1122 | "resolved": "https://registry.npmjs.org/graphemer/-/graphemer-1.4.0.tgz", 1123 | "integrity": "sha512-EtKwoO6kxCL9WO5xipiHTZlSzBm7WLT627TqC/uVRd0HKmq8NXyebnNYxDoBi7wt8eTWrUrKXCOVaFq9x1kgag==", 1124 | "dev": true 1125 | }, 1126 | "node_modules/has-flag": { 1127 | "version": "4.0.0", 1128 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 1129 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", 1130 | "dev": true, 1131 | "engines": { 1132 | "node": ">=8" 1133 | } 1134 | }, 1135 | "node_modules/ignore": { 1136 | "version": "5.3.1", 1137 | "resolved": "https://registry.npmjs.org/ignore/-/ignore-5.3.1.tgz", 1138 | "integrity": "sha512-5Fytz/IraMjqpwfd34ke28PTVMjZjJG2MPn5t7OE4eUCUNf8BAa7b5WUS9/Qvr6mwOQS7Mk6vdsMno5he+T8Xw==", 1139 | "dev": true, 1140 | "engines": { 1141 | "node": ">= 4" 1142 | } 1143 | }, 1144 | "node_modules/import-fresh": { 1145 | "version": "3.3.0", 1146 | "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.3.0.tgz", 1147 | "integrity": "sha512-veYYhQa+D1QBKznvhUHxb8faxlrwUnxseDAbAp457E0wLNio2bOSKnjYDhMj+YiAq61xrMGhQk9iXVk5FzgQMw==", 1148 | "dev": true, 1149 | "dependencies": { 1150 | "parent-module": "^1.0.0", 1151 | "resolve-from": "^4.0.0" 1152 | }, 1153 | "engines": { 1154 | "node": ">=6" 1155 | }, 1156 | "funding": { 1157 | "url": "https://github.com/sponsors/sindresorhus" 1158 | } 1159 | }, 1160 | "node_modules/imurmurhash": { 1161 | "version": "0.1.4", 1162 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", 1163 | "integrity": "sha512-JmXMZ6wuvDmLiHEml9ykzqO6lwFbof0GG4IkcGaENdCRDDmMVnny7s5HsIgHCbaq0w2MyPhDqkhTUgS2LU2PHA==", 1164 | "dev": true, 1165 | "engines": { 1166 | "node": ">=0.8.19" 1167 | } 1168 | }, 1169 | "node_modules/inflight": { 1170 | "version": "1.0.6", 1171 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 1172 | "integrity": "sha512-k92I/b08q4wvFscXCLvqfsHCrjrF7yiXsQuIVvVE7N82W3+aqpzuUdBbfhWcy/FZR3/4IgflMgKLOsvPDrGCJA==", 1173 | "dev": true, 1174 | "dependencies": { 1175 | "once": "^1.3.0", 1176 | "wrappy": "1" 1177 | } 1178 | }, 1179 | "node_modules/inherits": { 1180 | "version": "2.0.4", 1181 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 1182 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", 1183 | "dev": true 1184 | }, 1185 | "node_modules/is-extglob": { 1186 | "version": "2.1.1", 1187 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 1188 | "integrity": "sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==", 1189 | "dev": true, 1190 | "engines": { 1191 | "node": ">=0.10.0" 1192 | } 1193 | }, 1194 | "node_modules/is-glob": { 1195 | "version": "4.0.3", 1196 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", 1197 | "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", 1198 | "dev": true, 1199 | "dependencies": { 1200 | "is-extglob": "^2.1.1" 1201 | }, 1202 | "engines": { 1203 | "node": ">=0.10.0" 1204 | } 1205 | }, 1206 | "node_modules/is-number": { 1207 | "version": "7.0.0", 1208 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", 1209 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", 1210 | "dev": true, 1211 | "engines": { 1212 | "node": ">=0.12.0" 1213 | } 1214 | }, 1215 | "node_modules/is-path-inside": { 1216 | "version": "3.0.3", 1217 | "resolved": "https://registry.npmjs.org/is-path-inside/-/is-path-inside-3.0.3.tgz", 1218 | "integrity": "sha512-Fd4gABb+ycGAmKou8eMftCupSir5lRxqf4aD/vd0cD2qc4HL07OjCeuHMr8Ro4CoMaeCKDB0/ECBOVWjTwUvPQ==", 1219 | "dev": true, 1220 | "engines": { 1221 | "node": ">=8" 1222 | } 1223 | }, 1224 | "node_modules/isexe": { 1225 | "version": "2.0.0", 1226 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 1227 | "integrity": "sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw==", 1228 | "dev": true 1229 | }, 1230 | "node_modules/js-yaml": { 1231 | "version": "4.1.0", 1232 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-4.1.0.tgz", 1233 | "integrity": "sha512-wpxZs9NoxZaJESJGIZTyDEaYpl0FKSA+FB9aJiyemKhMwkxQg63h4T1KJgUGHpTqPDNRcmmYLugrRjJlBtWvRA==", 1234 | "dev": true, 1235 | "dependencies": { 1236 | "argparse": "^2.0.1" 1237 | }, 1238 | "bin": { 1239 | "js-yaml": "bin/js-yaml.js" 1240 | } 1241 | }, 1242 | "node_modules/json-buffer": { 1243 | "version": "3.0.1", 1244 | "resolved": "https://registry.npmjs.org/json-buffer/-/json-buffer-3.0.1.tgz", 1245 | "integrity": "sha512-4bV5BfR2mqfQTJm+V5tPPdf+ZpuhiIvTuAB5g8kcrXOZpTT/QwwVRWBywX1ozr6lEuPdbHxwaJlm9G6mI2sfSQ==", 1246 | "dev": true 1247 | }, 1248 | "node_modules/json-schema-traverse": { 1249 | "version": "0.4.1", 1250 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", 1251 | "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==", 1252 | "dev": true 1253 | }, 1254 | "node_modules/json-stable-stringify-without-jsonify": { 1255 | "version": "1.0.1", 1256 | "resolved": "https://registry.npmjs.org/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz", 1257 | "integrity": "sha512-Bdboy+l7tA3OGW6FjyFHWkP5LuByj1Tk33Ljyq0axyzdk9//JSi2u3fP1QSmd1KNwq6VOKYGlAu87CisVir6Pw==", 1258 | "dev": true 1259 | }, 1260 | "node_modules/keyv": { 1261 | "version": "4.5.4", 1262 | "resolved": "https://registry.npmjs.org/keyv/-/keyv-4.5.4.tgz", 1263 | "integrity": "sha512-oxVHkHR/EJf2CNXnWxRLW6mg7JyCCUcG0DtEGmL2ctUo1PNTin1PUil+r/+4r5MpVgC/fn1kjsx7mjSujKqIpw==", 1264 | "dev": true, 1265 | "dependencies": { 1266 | "json-buffer": "3.0.1" 1267 | } 1268 | }, 1269 | "node_modules/levn": { 1270 | "version": "0.4.1", 1271 | "resolved": "https://registry.npmjs.org/levn/-/levn-0.4.1.tgz", 1272 | "integrity": "sha512-+bT2uH4E5LGE7h/n3evcS/sQlJXCpIp6ym8OWJ5eV6+67Dsql/LaaT7qJBAt2rzfoa/5QBGBhxDix1dMt2kQKQ==", 1273 | "dev": true, 1274 | "dependencies": { 1275 | "prelude-ls": "^1.2.1", 1276 | "type-check": "~0.4.0" 1277 | }, 1278 | "engines": { 1279 | "node": ">= 0.8.0" 1280 | } 1281 | }, 1282 | "node_modules/locate-path": { 1283 | "version": "6.0.0", 1284 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-6.0.0.tgz", 1285 | "integrity": "sha512-iPZK6eYjbxRu3uB4/WZ3EsEIMJFMqAoopl3R+zuq0UjcAm/MO6KCweDgPfP3elTztoKP3KtnVHxTn2NHBSDVUw==", 1286 | "dev": true, 1287 | "dependencies": { 1288 | "p-locate": "^5.0.0" 1289 | }, 1290 | "engines": { 1291 | "node": ">=10" 1292 | }, 1293 | "funding": { 1294 | "url": "https://github.com/sponsors/sindresorhus" 1295 | } 1296 | }, 1297 | "node_modules/lodash.merge": { 1298 | "version": "4.6.2", 1299 | "resolved": "https://registry.npmjs.org/lodash.merge/-/lodash.merge-4.6.2.tgz", 1300 | "integrity": "sha512-0KpjqXRVvrYyCsX1swR/XTK0va6VQkQM6MNo7PqW77ByjAhoARA8EfrP1N4+KlKj8YS0ZUCtRT/YUuhyYDujIQ==", 1301 | "dev": true 1302 | }, 1303 | "node_modules/lru-cache": { 1304 | "version": "6.0.0", 1305 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", 1306 | "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", 1307 | "dev": true, 1308 | "dependencies": { 1309 | "yallist": "^4.0.0" 1310 | }, 1311 | "engines": { 1312 | "node": ">=10" 1313 | } 1314 | }, 1315 | "node_modules/merge2": { 1316 | "version": "1.4.1", 1317 | "resolved": "https://registry.npmjs.org/merge2/-/merge2-1.4.1.tgz", 1318 | "integrity": "sha512-8q7VEgMJW4J8tcfVPy8g09NcQwZdbwFEqhe/WZkoIzjn/3TGDwtOCYtXGxA3O8tPzpczCCDgv+P2P5y00ZJOOg==", 1319 | "dev": true, 1320 | "engines": { 1321 | "node": ">= 8" 1322 | } 1323 | }, 1324 | "node_modules/micromatch": { 1325 | "version": "4.0.5", 1326 | "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-4.0.5.tgz", 1327 | "integrity": "sha512-DMy+ERcEW2q8Z2Po+WNXuw3c5YaUSFjAO5GsJqfEl7UjvtIuFKO6ZrKvcItdy98dwFI2N1tg3zNIdKaQT+aNdA==", 1328 | "dev": true, 1329 | "dependencies": { 1330 | "braces": "^3.0.2", 1331 | "picomatch": "^2.3.1" 1332 | }, 1333 | "engines": { 1334 | "node": ">=8.6" 1335 | } 1336 | }, 1337 | "node_modules/minimatch": { 1338 | "version": "9.0.3", 1339 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-9.0.3.tgz", 1340 | "integrity": "sha512-RHiac9mvaRw0x3AYRgDC1CxAP7HTcNrrECeA8YYJeWnpo+2Q5CegtZjaotWTWxDG3UeGA1coE05iH1mPjT/2mg==", 1341 | "dev": true, 1342 | "dependencies": { 1343 | "brace-expansion": "^2.0.1" 1344 | }, 1345 | "engines": { 1346 | "node": ">=16 || 14 >=14.17" 1347 | }, 1348 | "funding": { 1349 | "url": "https://github.com/sponsors/isaacs" 1350 | } 1351 | }, 1352 | "node_modules/ms": { 1353 | "version": "2.1.2", 1354 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 1355 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 1356 | "dev": true 1357 | }, 1358 | "node_modules/natural-compare": { 1359 | "version": "1.4.0", 1360 | "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", 1361 | "integrity": "sha512-OWND8ei3VtNC9h7V60qff3SVobHr996CTwgxubgyQYEpg290h9J0buyECNNJexkFm5sOajh5G116RYA1c8ZMSw==", 1362 | "dev": true 1363 | }, 1364 | "node_modules/once": { 1365 | "version": "1.4.0", 1366 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 1367 | "integrity": "sha512-lNaJgI+2Q5URQBkccEKHTQOPaXdUxnZZElQTZY0MFUAuaEqe1E+Nyvgdz/aIyNi6Z9MzO5dv1H8n58/GELp3+w==", 1368 | "dev": true, 1369 | "dependencies": { 1370 | "wrappy": "1" 1371 | } 1372 | }, 1373 | "node_modules/optionator": { 1374 | "version": "0.9.3", 1375 | "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.9.3.tgz", 1376 | "integrity": "sha512-JjCoypp+jKn1ttEFExxhetCKeJt9zhAgAve5FXHixTvFDW/5aEktX9bufBKLRRMdU7bNtpLfcGu94B3cdEJgjg==", 1377 | "dev": true, 1378 | "dependencies": { 1379 | "@aashutoshrathi/word-wrap": "^1.2.3", 1380 | "deep-is": "^0.1.3", 1381 | "fast-levenshtein": "^2.0.6", 1382 | "levn": "^0.4.1", 1383 | "prelude-ls": "^1.2.1", 1384 | "type-check": "^0.4.0" 1385 | }, 1386 | "engines": { 1387 | "node": ">= 0.8.0" 1388 | } 1389 | }, 1390 | "node_modules/p-limit": { 1391 | "version": "3.1.0", 1392 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-3.1.0.tgz", 1393 | "integrity": "sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ==", 1394 | "dev": true, 1395 | "dependencies": { 1396 | "yocto-queue": "^0.1.0" 1397 | }, 1398 | "engines": { 1399 | "node": ">=10" 1400 | }, 1401 | "funding": { 1402 | "url": "https://github.com/sponsors/sindresorhus" 1403 | } 1404 | }, 1405 | "node_modules/p-locate": { 1406 | "version": "5.0.0", 1407 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-5.0.0.tgz", 1408 | "integrity": "sha512-LaNjtRWUBY++zB5nE/NwcaoMylSPk+S+ZHNB1TzdbMJMny6dynpAGt7X/tl/QYq3TIeE6nxHppbo2LGymrG5Pw==", 1409 | "dev": true, 1410 | "dependencies": { 1411 | "p-limit": "^3.0.2" 1412 | }, 1413 | "engines": { 1414 | "node": ">=10" 1415 | }, 1416 | "funding": { 1417 | "url": "https://github.com/sponsors/sindresorhus" 1418 | } 1419 | }, 1420 | "node_modules/parent-module": { 1421 | "version": "1.0.1", 1422 | "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz", 1423 | "integrity": "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==", 1424 | "dev": true, 1425 | "dependencies": { 1426 | "callsites": "^3.0.0" 1427 | }, 1428 | "engines": { 1429 | "node": ">=6" 1430 | } 1431 | }, 1432 | "node_modules/path-exists": { 1433 | "version": "4.0.0", 1434 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz", 1435 | "integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==", 1436 | "dev": true, 1437 | "engines": { 1438 | "node": ">=8" 1439 | } 1440 | }, 1441 | "node_modules/path-is-absolute": { 1442 | "version": "1.0.1", 1443 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 1444 | "integrity": "sha512-AVbw3UJ2e9bq64vSaS9Am0fje1Pa8pbGqTTsmXfaIiMpnr5DlDhfJOuLj9Sf95ZPVDAUerDfEk88MPmPe7UCQg==", 1445 | "dev": true, 1446 | "engines": { 1447 | "node": ">=0.10.0" 1448 | } 1449 | }, 1450 | "node_modules/path-key": { 1451 | "version": "3.1.1", 1452 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", 1453 | "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", 1454 | "dev": true, 1455 | "engines": { 1456 | "node": ">=8" 1457 | } 1458 | }, 1459 | "node_modules/path-type": { 1460 | "version": "4.0.0", 1461 | "resolved": "https://registry.npmjs.org/path-type/-/path-type-4.0.0.tgz", 1462 | "integrity": "sha512-gDKb8aZMDeD/tZWs9P6+q0J9Mwkdl6xMV8TjnGP3qJVJ06bdMgkbBlLU8IdfOsIsFz2BW1rNVT3XuNEl8zPAvw==", 1463 | "dev": true, 1464 | "engines": { 1465 | "node": ">=8" 1466 | } 1467 | }, 1468 | "node_modules/picomatch": { 1469 | "version": "2.3.1", 1470 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz", 1471 | "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==", 1472 | "dev": true, 1473 | "engines": { 1474 | "node": ">=8.6" 1475 | }, 1476 | "funding": { 1477 | "url": "https://github.com/sponsors/jonschlinkert" 1478 | } 1479 | }, 1480 | "node_modules/prelude-ls": { 1481 | "version": "1.2.1", 1482 | "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.2.1.tgz", 1483 | "integrity": "sha512-vkcDPrRZo1QZLbn5RLGPpg/WmIQ65qoWWhcGKf/b5eplkkarX0m9z8ppCat4mlOqUsWpyNuYgO3VRyrYHSzX5g==", 1484 | "dev": true, 1485 | "engines": { 1486 | "node": ">= 0.8.0" 1487 | } 1488 | }, 1489 | "node_modules/punycode": { 1490 | "version": "2.3.1", 1491 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.3.1.tgz", 1492 | "integrity": "sha512-vYt7UD1U9Wg6138shLtLOvdAu+8DsC/ilFtEVHcH+wydcSpNE20AfSOduf6MkRFahL5FY7X1oU7nKVZFtfq8Fg==", 1493 | "dev": true, 1494 | "engines": { 1495 | "node": ">=6" 1496 | } 1497 | }, 1498 | "node_modules/queue-microtask": { 1499 | "version": "1.2.3", 1500 | "resolved": "https://registry.npmjs.org/queue-microtask/-/queue-microtask-1.2.3.tgz", 1501 | "integrity": "sha512-NuaNSa6flKT5JaSYQzJok04JzTL1CA6aGhv5rfLW3PgqA+M2ChpZQnAC8h8i4ZFkBS8X5RqkDBHA7r4hej3K9A==", 1502 | "dev": true, 1503 | "funding": [ 1504 | { 1505 | "type": "github", 1506 | "url": "https://github.com/sponsors/feross" 1507 | }, 1508 | { 1509 | "type": "patreon", 1510 | "url": "https://www.patreon.com/feross" 1511 | }, 1512 | { 1513 | "type": "consulting", 1514 | "url": "https://feross.org/support" 1515 | } 1516 | ] 1517 | }, 1518 | "node_modules/resolve-from": { 1519 | "version": "4.0.0", 1520 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz", 1521 | "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==", 1522 | "dev": true, 1523 | "engines": { 1524 | "node": ">=4" 1525 | } 1526 | }, 1527 | "node_modules/reusify": { 1528 | "version": "1.0.4", 1529 | "resolved": "https://registry.npmjs.org/reusify/-/reusify-1.0.4.tgz", 1530 | "integrity": "sha512-U9nH88a3fc/ekCF1l0/UP1IosiuIjyTh7hBvXVMHYgVcfGvt897Xguj2UOLDeI5BG2m7/uwyaLVT6fbtCwTyzw==", 1531 | "dev": true, 1532 | "engines": { 1533 | "iojs": ">=1.0.0", 1534 | "node": ">=0.10.0" 1535 | } 1536 | }, 1537 | "node_modules/rimraf": { 1538 | "version": "3.0.2", 1539 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-3.0.2.tgz", 1540 | "integrity": "sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA==", 1541 | "dev": true, 1542 | "dependencies": { 1543 | "glob": "^7.1.3" 1544 | }, 1545 | "bin": { 1546 | "rimraf": "bin.js" 1547 | }, 1548 | "funding": { 1549 | "url": "https://github.com/sponsors/isaacs" 1550 | } 1551 | }, 1552 | "node_modules/run-parallel": { 1553 | "version": "1.2.0", 1554 | "resolved": "https://registry.npmjs.org/run-parallel/-/run-parallel-1.2.0.tgz", 1555 | "integrity": "sha512-5l4VyZR86LZ/lDxZTR6jqL8AFE2S0IFLMP26AbjsLVADxHdhB/c0GUsH+y39UfCi3dzz8OlQuPmnaJOMoDHQBA==", 1556 | "dev": true, 1557 | "funding": [ 1558 | { 1559 | "type": "github", 1560 | "url": "https://github.com/sponsors/feross" 1561 | }, 1562 | { 1563 | "type": "patreon", 1564 | "url": "https://www.patreon.com/feross" 1565 | }, 1566 | { 1567 | "type": "consulting", 1568 | "url": "https://feross.org/support" 1569 | } 1570 | ], 1571 | "dependencies": { 1572 | "queue-microtask": "^1.2.2" 1573 | } 1574 | }, 1575 | "node_modules/semver": { 1576 | "version": "7.6.0", 1577 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.6.0.tgz", 1578 | "integrity": "sha512-EnwXhrlwXMk9gKu5/flx5sv/an57AkRplG3hTK68W7FRDN+k+OWBj65M7719OkA82XLBxrcX0KSHj+X5COhOVg==", 1579 | "dev": true, 1580 | "dependencies": { 1581 | "lru-cache": "^6.0.0" 1582 | }, 1583 | "bin": { 1584 | "semver": "bin/semver.js" 1585 | }, 1586 | "engines": { 1587 | "node": ">=10" 1588 | } 1589 | }, 1590 | "node_modules/shebang-command": { 1591 | "version": "2.0.0", 1592 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", 1593 | "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", 1594 | "dev": true, 1595 | "dependencies": { 1596 | "shebang-regex": "^3.0.0" 1597 | }, 1598 | "engines": { 1599 | "node": ">=8" 1600 | } 1601 | }, 1602 | "node_modules/shebang-regex": { 1603 | "version": "3.0.0", 1604 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", 1605 | "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", 1606 | "dev": true, 1607 | "engines": { 1608 | "node": ">=8" 1609 | } 1610 | }, 1611 | "node_modules/slash": { 1612 | "version": "3.0.0", 1613 | "resolved": "https://registry.npmjs.org/slash/-/slash-3.0.0.tgz", 1614 | "integrity": "sha512-g9Q1haeby36OSStwb4ntCGGGaKsaVSjQ68fBxoQcutl5fS1vuY18H3wSt3jFyFtrkx+Kz0V1G85A4MyAdDMi2Q==", 1615 | "dev": true, 1616 | "engines": { 1617 | "node": ">=8" 1618 | } 1619 | }, 1620 | "node_modules/strip-ansi": { 1621 | "version": "6.0.1", 1622 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", 1623 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", 1624 | "dev": true, 1625 | "dependencies": { 1626 | "ansi-regex": "^5.0.1" 1627 | }, 1628 | "engines": { 1629 | "node": ">=8" 1630 | } 1631 | }, 1632 | "node_modules/strip-json-comments": { 1633 | "version": "3.1.1", 1634 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz", 1635 | "integrity": "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==", 1636 | "dev": true, 1637 | "engines": { 1638 | "node": ">=8" 1639 | }, 1640 | "funding": { 1641 | "url": "https://github.com/sponsors/sindresorhus" 1642 | } 1643 | }, 1644 | "node_modules/supports-color": { 1645 | "version": "7.2.0", 1646 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", 1647 | "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", 1648 | "dev": true, 1649 | "dependencies": { 1650 | "has-flag": "^4.0.0" 1651 | }, 1652 | "engines": { 1653 | "node": ">=8" 1654 | } 1655 | }, 1656 | "node_modules/text-table": { 1657 | "version": "0.2.0", 1658 | "resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz", 1659 | "integrity": "sha512-N+8UisAXDGk8PFXP4HAzVR9nbfmVJ3zYLAWiTIoqC5v5isinhr+r5uaO8+7r3BMfuNIufIsA7RdpVgacC2cSpw==", 1660 | "dev": true 1661 | }, 1662 | "node_modules/to-regex-range": { 1663 | "version": "5.0.1", 1664 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", 1665 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", 1666 | "dev": true, 1667 | "dependencies": { 1668 | "is-number": "^7.0.0" 1669 | }, 1670 | "engines": { 1671 | "node": ">=8.0" 1672 | } 1673 | }, 1674 | "node_modules/ts-api-utils": { 1675 | "version": "1.2.1", 1676 | "resolved": "https://registry.npmjs.org/ts-api-utils/-/ts-api-utils-1.2.1.tgz", 1677 | "integrity": "sha512-RIYA36cJn2WiH9Hy77hdF9r7oEwxAtB/TS9/S4Qd90Ap4z5FSiin5zEiTL44OII1Y3IIlEvxwxFUVgrHSZ/UpA==", 1678 | "dev": true, 1679 | "engines": { 1680 | "node": ">=16" 1681 | }, 1682 | "peerDependencies": { 1683 | "typescript": ">=4.2.0" 1684 | } 1685 | }, 1686 | "node_modules/type-check": { 1687 | "version": "0.4.0", 1688 | "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.4.0.tgz", 1689 | "integrity": "sha512-XleUoc9uwGXqjWwXaUTZAmzMcFZ5858QA2vvx1Ur5xIcixXIP+8LnFDgRplU30us6teqdlskFfu+ae4K79Ooew==", 1690 | "dev": true, 1691 | "dependencies": { 1692 | "prelude-ls": "^1.2.1" 1693 | }, 1694 | "engines": { 1695 | "node": ">= 0.8.0" 1696 | } 1697 | }, 1698 | "node_modules/type-fest": { 1699 | "version": "0.20.2", 1700 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.20.2.tgz", 1701 | "integrity": "sha512-Ne+eE4r0/iWnpAxD852z3A+N0Bt5RN//NjJwRd2VFHEmrywxf5vsZlh4R6lixl6B+wz/8d+maTSAkN1FIkI3LQ==", 1702 | "dev": true, 1703 | "engines": { 1704 | "node": ">=10" 1705 | }, 1706 | "funding": { 1707 | "url": "https://github.com/sponsors/sindresorhus" 1708 | } 1709 | }, 1710 | "node_modules/typescript": { 1711 | "version": "5.3.3", 1712 | "resolved": "https://registry.npmjs.org/typescript/-/typescript-5.3.3.tgz", 1713 | "integrity": "sha512-pXWcraxM0uxAS+tN0AG/BF2TyqmHO014Z070UsJ+pFvYuRSq8KH8DmWpnbXe0pEPDHXZV3FcAbJkijJ5oNEnWw==", 1714 | "dev": true, 1715 | "bin": { 1716 | "tsc": "bin/tsc", 1717 | "tsserver": "bin/tsserver" 1718 | }, 1719 | "engines": { 1720 | "node": ">=14.17" 1721 | } 1722 | }, 1723 | "node_modules/typescript-eslint": { 1724 | "version": "7.1.0", 1725 | "resolved": "https://registry.npmjs.org/typescript-eslint/-/typescript-eslint-7.1.0.tgz", 1726 | "integrity": "sha512-GfAALH4zoqae5mIfHr7WU3BsULHP73hjwF8vCmyTkH3IXHXjqg3JNWwUcd8CwOTLIr4tjRTZQWpToyESPnpOhg==", 1727 | "dev": true, 1728 | "dependencies": { 1729 | "@typescript-eslint/eslint-plugin": "7.1.0", 1730 | "@typescript-eslint/parser": "7.1.0" 1731 | }, 1732 | "engines": { 1733 | "node": "^16.0.0 || >=18.0.0" 1734 | }, 1735 | "funding": { 1736 | "type": "opencollective", 1737 | "url": "https://opencollective.com/typescript-eslint" 1738 | }, 1739 | "peerDependencies": { 1740 | "eslint": "^8.56.0" 1741 | }, 1742 | "peerDependenciesMeta": { 1743 | "typescript": { 1744 | "optional": true 1745 | } 1746 | } 1747 | }, 1748 | "node_modules/uri-js": { 1749 | "version": "4.4.1", 1750 | "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.4.1.tgz", 1751 | "integrity": "sha512-7rKUyy33Q1yc98pQ1DAmLtwX109F7TIfWlW1Ydo8Wl1ii1SeHieeh0HHfPeL2fMXK6z0s8ecKs9frCuLJvndBg==", 1752 | "dev": true, 1753 | "dependencies": { 1754 | "punycode": "^2.1.0" 1755 | } 1756 | }, 1757 | "node_modules/which": { 1758 | "version": "2.0.2", 1759 | "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", 1760 | "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", 1761 | "dev": true, 1762 | "dependencies": { 1763 | "isexe": "^2.0.0" 1764 | }, 1765 | "bin": { 1766 | "node-which": "bin/node-which" 1767 | }, 1768 | "engines": { 1769 | "node": ">= 8" 1770 | } 1771 | }, 1772 | "node_modules/wrappy": { 1773 | "version": "1.0.2", 1774 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 1775 | "integrity": "sha512-l4Sp/DRseor9wL6EvV2+TuQn63dMkPjZ/sp9XkghTEbV9KlPS1xUsZ3u7/IQO4wxtcFB4bgpQPRcR3QCvezPcQ==", 1776 | "dev": true 1777 | }, 1778 | "node_modules/yallist": { 1779 | "version": "4.0.0", 1780 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", 1781 | "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", 1782 | "dev": true 1783 | }, 1784 | "node_modules/yocto-queue": { 1785 | "version": "0.1.0", 1786 | "resolved": "https://registry.npmjs.org/yocto-queue/-/yocto-queue-0.1.0.tgz", 1787 | "integrity": "sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q==", 1788 | "dev": true, 1789 | "engines": { 1790 | "node": ">=10" 1791 | }, 1792 | "funding": { 1793 | "url": "https://github.com/sponsors/sindresorhus" 1794 | } 1795 | } 1796 | }, 1797 | "dependencies": { 1798 | "@aashutoshrathi/word-wrap": { 1799 | "version": "1.2.6", 1800 | "resolved": "https://registry.npmjs.org/@aashutoshrathi/word-wrap/-/word-wrap-1.2.6.tgz", 1801 | "integrity": "sha512-1Yjs2SvM8TflER/OD3cOjhWWOZb58A2t7wpE2S9XfBYTiIl+XFhQG2bjy4Pu1I+EAlCNUzRDYDdFwFYUKvXcIA==", 1802 | "dev": true 1803 | }, 1804 | "@eslint-community/eslint-utils": { 1805 | "version": "4.4.0", 1806 | "resolved": "https://registry.npmjs.org/@eslint-community/eslint-utils/-/eslint-utils-4.4.0.tgz", 1807 | "integrity": "sha512-1/sA4dwrzBAyeUoQ6oxahHKmrZvsnLCg4RfxW3ZFGGmQkSNQPFNLV9CUEFQP1x9EYXHTo5p6xdhZM1Ne9p/AfA==", 1808 | "dev": true, 1809 | "requires": { 1810 | "eslint-visitor-keys": "^3.3.0" 1811 | } 1812 | }, 1813 | "@eslint-community/regexpp": { 1814 | "version": "4.10.0", 1815 | "resolved": "https://registry.npmjs.org/@eslint-community/regexpp/-/regexpp-4.10.0.tgz", 1816 | "integrity": "sha512-Cu96Sd2By9mCNTx2iyKOmq10v22jUVQv0lQnlGNy16oE9589yE+QADPbrMGCkA51cKZSg3Pu/aTJVTGfL/qjUA==", 1817 | "dev": true 1818 | }, 1819 | "@eslint/eslintrc": { 1820 | "version": "2.1.4", 1821 | "resolved": "https://registry.npmjs.org/@eslint/eslintrc/-/eslintrc-2.1.4.tgz", 1822 | "integrity": "sha512-269Z39MS6wVJtsoUl10L60WdkhJVdPG24Q4eZTH3nnF6lpvSShEK3wQjDX9JRWAUPvPh7COouPpU9IrqaZFvtQ==", 1823 | "dev": true, 1824 | "requires": { 1825 | "ajv": "^6.12.4", 1826 | "debug": "^4.3.2", 1827 | "espree": "^9.6.0", 1828 | "globals": "^13.19.0", 1829 | "ignore": "^5.2.0", 1830 | "import-fresh": "^3.2.1", 1831 | "js-yaml": "^4.1.0", 1832 | "minimatch": "^3.1.2", 1833 | "strip-json-comments": "^3.1.1" 1834 | }, 1835 | "dependencies": { 1836 | "brace-expansion": { 1837 | "version": "1.1.11", 1838 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 1839 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 1840 | "dev": true, 1841 | "requires": { 1842 | "balanced-match": "^1.0.0", 1843 | "concat-map": "0.0.1" 1844 | } 1845 | }, 1846 | "minimatch": { 1847 | "version": "3.1.2", 1848 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", 1849 | "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", 1850 | "dev": true, 1851 | "requires": { 1852 | "brace-expansion": "^1.1.7" 1853 | } 1854 | } 1855 | } 1856 | }, 1857 | "@eslint/js": { 1858 | "version": "8.57.0", 1859 | "resolved": "https://registry.npmjs.org/@eslint/js/-/js-8.57.0.tgz", 1860 | "integrity": "sha512-Ys+3g2TaW7gADOJzPt83SJtCDhMjndcDMFVQ/Tj9iA1BfJzFKD9mAUXT3OenpuPHbI6P/myECxRJrofUsDx/5g==", 1861 | "dev": true 1862 | }, 1863 | "@figma/eslint-plugin-figma-plugins": { 1864 | "version": "0.14.0", 1865 | "resolved": "https://registry.npmjs.org/@figma/eslint-plugin-figma-plugins/-/eslint-plugin-figma-plugins-0.14.0.tgz", 1866 | "integrity": "sha512-tkWXJACqX84t0vnxCO+298xw1AJByds/97Xgf26KR8bzGA21NoFM9CZOSLOggCnXZANJH6720qLxBYi/HVZMcA==", 1867 | "dev": true, 1868 | "requires": { 1869 | "@typescript-eslint/typescript-estree": "^6.13.2", 1870 | "@typescript-eslint/utils": "^6.12.0", 1871 | "typescript": "^5.3.2" 1872 | }, 1873 | "dependencies": { 1874 | "@typescript-eslint/scope-manager": { 1875 | "version": "6.21.0", 1876 | "resolved": "https://registry.npmjs.org/@typescript-eslint/scope-manager/-/scope-manager-6.21.0.tgz", 1877 | "integrity": "sha512-OwLUIWZJry80O99zvqXVEioyniJMa+d2GrqpUTqi5/v5D5rOrppJVBPa0yKCblcigC0/aYAzxxqQ1B+DS2RYsg==", 1878 | "dev": true, 1879 | "requires": { 1880 | "@typescript-eslint/types": "6.21.0", 1881 | "@typescript-eslint/visitor-keys": "6.21.0" 1882 | } 1883 | }, 1884 | "@typescript-eslint/types": { 1885 | "version": "6.21.0", 1886 | "resolved": "https://registry.npmjs.org/@typescript-eslint/types/-/types-6.21.0.tgz", 1887 | "integrity": "sha512-1kFmZ1rOm5epu9NZEZm1kckCDGj5UJEf7P1kliH4LKu/RkwpsfqqGmY2OOcUs18lSlQBKLDYBOGxRVtrMN5lpg==", 1888 | "dev": true 1889 | }, 1890 | "@typescript-eslint/typescript-estree": { 1891 | "version": "6.21.0", 1892 | "resolved": "https://registry.npmjs.org/@typescript-eslint/typescript-estree/-/typescript-estree-6.21.0.tgz", 1893 | "integrity": "sha512-6npJTkZcO+y2/kr+z0hc4HwNfrrP4kNYh57ek7yCNlrBjWQ1Y0OS7jiZTkgumrvkX5HkEKXFZkkdFNkaW2wmUQ==", 1894 | "dev": true, 1895 | "requires": { 1896 | "@typescript-eslint/types": "6.21.0", 1897 | "@typescript-eslint/visitor-keys": "6.21.0", 1898 | "debug": "^4.3.4", 1899 | "globby": "^11.1.0", 1900 | "is-glob": "^4.0.3", 1901 | "minimatch": "9.0.3", 1902 | "semver": "^7.5.4", 1903 | "ts-api-utils": "^1.0.1" 1904 | } 1905 | }, 1906 | "@typescript-eslint/utils": { 1907 | "version": "6.21.0", 1908 | "resolved": "https://registry.npmjs.org/@typescript-eslint/utils/-/utils-6.21.0.tgz", 1909 | "integrity": "sha512-NfWVaC8HP9T8cbKQxHcsJBY5YE1O33+jpMwN45qzWWaPDZgLIbo12toGMWnmhvCpd3sIxkpDw3Wv1B3dYrbDQQ==", 1910 | "dev": true, 1911 | "requires": { 1912 | "@eslint-community/eslint-utils": "^4.4.0", 1913 | "@types/json-schema": "^7.0.12", 1914 | "@types/semver": "^7.5.0", 1915 | "@typescript-eslint/scope-manager": "6.21.0", 1916 | "@typescript-eslint/types": "6.21.0", 1917 | "@typescript-eslint/typescript-estree": "6.21.0", 1918 | "semver": "^7.5.4" 1919 | } 1920 | }, 1921 | "@typescript-eslint/visitor-keys": { 1922 | "version": "6.21.0", 1923 | "resolved": "https://registry.npmjs.org/@typescript-eslint/visitor-keys/-/visitor-keys-6.21.0.tgz", 1924 | "integrity": "sha512-JJtkDduxLi9bivAB+cYOVMtbkqdPOhZ+ZI5LC47MIRrDV4Yn2o+ZnW10Nkmr28xRpSpdJ6Sm42Hjf2+REYXm0A==", 1925 | "dev": true, 1926 | "requires": { 1927 | "@typescript-eslint/types": "6.21.0", 1928 | "eslint-visitor-keys": "^3.4.1" 1929 | } 1930 | } 1931 | } 1932 | }, 1933 | "@figma/plugin-typings": { 1934 | "version": "1.87.0", 1935 | "resolved": "https://registry.npmjs.org/@figma/plugin-typings/-/plugin-typings-1.87.0.tgz", 1936 | "integrity": "sha512-n/dZtw4G5J91mgi+OHZ8MpKkeFd5oRwIVZ8/Ju0BN+/LTcvj9lOPPDuCFBplS0lMBpcBYKn5eQxFuBpQv5t2lw==", 1937 | "dev": true 1938 | }, 1939 | "@humanwhocodes/config-array": { 1940 | "version": "0.11.14", 1941 | "resolved": "https://registry.npmjs.org/@humanwhocodes/config-array/-/config-array-0.11.14.tgz", 1942 | "integrity": "sha512-3T8LkOmg45BV5FICb15QQMsyUSWrQ8AygVfC7ZG32zOalnqrilm018ZVCw0eapXux8FtA33q8PSRSstjee3jSg==", 1943 | "dev": true, 1944 | "requires": { 1945 | "@humanwhocodes/object-schema": "^2.0.2", 1946 | "debug": "^4.3.1", 1947 | "minimatch": "^3.0.5" 1948 | }, 1949 | "dependencies": { 1950 | "brace-expansion": { 1951 | "version": "1.1.11", 1952 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 1953 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 1954 | "dev": true, 1955 | "requires": { 1956 | "balanced-match": "^1.0.0", 1957 | "concat-map": "0.0.1" 1958 | } 1959 | }, 1960 | "minimatch": { 1961 | "version": "3.1.2", 1962 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", 1963 | "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", 1964 | "dev": true, 1965 | "requires": { 1966 | "brace-expansion": "^1.1.7" 1967 | } 1968 | } 1969 | } 1970 | }, 1971 | "@humanwhocodes/module-importer": { 1972 | "version": "1.0.1", 1973 | "resolved": "https://registry.npmjs.org/@humanwhocodes/module-importer/-/module-importer-1.0.1.tgz", 1974 | "integrity": "sha512-bxveV4V8v5Yb4ncFTT3rPSgZBOpCkjfK0y4oVVVJwIuDVBRMDXrPyXRL988i5ap9m9bnyEEjWfm5WkBmtffLfA==", 1975 | "dev": true 1976 | }, 1977 | "@humanwhocodes/object-schema": { 1978 | "version": "2.0.2", 1979 | "resolved": "https://registry.npmjs.org/@humanwhocodes/object-schema/-/object-schema-2.0.2.tgz", 1980 | "integrity": "sha512-6EwiSjwWYP7pTckG6I5eyFANjPhmPjUX9JRLUSfNPC7FX7zK9gyZAfUEaECL6ALTpGX5AjnBq3C9XmVWPitNpw==", 1981 | "dev": true 1982 | }, 1983 | "@nodelib/fs.scandir": { 1984 | "version": "2.1.5", 1985 | "resolved": "https://registry.npmjs.org/@nodelib/fs.scandir/-/fs.scandir-2.1.5.tgz", 1986 | "integrity": "sha512-vq24Bq3ym5HEQm2NKCr3yXDwjc7vTsEThRDnkp2DK9p1uqLR+DHurm/NOTo0KG7HYHU7eppKZj3MyqYuMBf62g==", 1987 | "dev": true, 1988 | "requires": { 1989 | "@nodelib/fs.stat": "2.0.5", 1990 | "run-parallel": "^1.1.9" 1991 | } 1992 | }, 1993 | "@nodelib/fs.stat": { 1994 | "version": "2.0.5", 1995 | "resolved": "https://registry.npmjs.org/@nodelib/fs.stat/-/fs.stat-2.0.5.tgz", 1996 | "integrity": "sha512-RkhPPp2zrqDAQA/2jNhnztcPAlv64XdhIp7a7454A5ovI7Bukxgt7MX7udwAu3zg1DcpPU0rz3VV1SeaqvY4+A==", 1997 | "dev": true 1998 | }, 1999 | "@nodelib/fs.walk": { 2000 | "version": "1.2.8", 2001 | "resolved": "https://registry.npmjs.org/@nodelib/fs.walk/-/fs.walk-1.2.8.tgz", 2002 | "integrity": "sha512-oGB+UxlgWcgQkgwo8GcEGwemoTFt3FIO9ababBmaGwXIoBKZ+GTy0pP185beGg7Llih/NSHSV2XAs1lnznocSg==", 2003 | "dev": true, 2004 | "requires": { 2005 | "@nodelib/fs.scandir": "2.1.5", 2006 | "fastq": "^1.6.0" 2007 | } 2008 | }, 2009 | "@types/json-schema": { 2010 | "version": "7.0.15", 2011 | "resolved": "https://registry.npmjs.org/@types/json-schema/-/json-schema-7.0.15.tgz", 2012 | "integrity": "sha512-5+fP8P8MFNC+AyZCDxrB2pkZFPGzqQWUzpSeuuVLvm8VMcorNYavBqoFcxK8bQz4Qsbn4oUEEem4wDLfcysGHA==", 2013 | "dev": true 2014 | }, 2015 | "@types/semver": { 2016 | "version": "7.5.8", 2017 | "resolved": "https://registry.npmjs.org/@types/semver/-/semver-7.5.8.tgz", 2018 | "integrity": "sha512-I8EUhyrgfLrcTkzV3TSsGyl1tSuPrEDzr0yd5m90UgNxQkyDXULk3b6MlQqTCpZpNtWe1K0hzclnZkTcLBe2UQ==", 2019 | "dev": true 2020 | }, 2021 | "@typescript-eslint/eslint-plugin": { 2022 | "version": "7.1.0", 2023 | "resolved": "https://registry.npmjs.org/@typescript-eslint/eslint-plugin/-/eslint-plugin-7.1.0.tgz", 2024 | "integrity": "sha512-j6vT/kCulhG5wBmGtstKeiVr1rdXE4nk+DT1k6trYkwlrvW9eOF5ZbgKnd/YR6PcM4uTEXa0h6Fcvf6X7Dxl0w==", 2025 | "dev": true, 2026 | "requires": { 2027 | "@eslint-community/regexpp": "^4.5.1", 2028 | "@typescript-eslint/scope-manager": "7.1.0", 2029 | "@typescript-eslint/type-utils": "7.1.0", 2030 | "@typescript-eslint/utils": "7.1.0", 2031 | "@typescript-eslint/visitor-keys": "7.1.0", 2032 | "debug": "^4.3.4", 2033 | "graphemer": "^1.4.0", 2034 | "ignore": "^5.2.4", 2035 | "natural-compare": "^1.4.0", 2036 | "semver": "^7.5.4", 2037 | "ts-api-utils": "^1.0.1" 2038 | } 2039 | }, 2040 | "@typescript-eslint/parser": { 2041 | "version": "7.1.0", 2042 | "resolved": "https://registry.npmjs.org/@typescript-eslint/parser/-/parser-7.1.0.tgz", 2043 | "integrity": "sha512-V1EknKUubZ1gWFjiOZhDSNToOjs63/9O0puCgGS8aDOgpZY326fzFu15QAUjwaXzRZjf/qdsdBrckYdv9YxB8w==", 2044 | "dev": true, 2045 | "requires": { 2046 | "@typescript-eslint/scope-manager": "7.1.0", 2047 | "@typescript-eslint/types": "7.1.0", 2048 | "@typescript-eslint/typescript-estree": "7.1.0", 2049 | "@typescript-eslint/visitor-keys": "7.1.0", 2050 | "debug": "^4.3.4" 2051 | } 2052 | }, 2053 | "@typescript-eslint/scope-manager": { 2054 | "version": "7.1.0", 2055 | "resolved": "https://registry.npmjs.org/@typescript-eslint/scope-manager/-/scope-manager-7.1.0.tgz", 2056 | "integrity": "sha512-6TmN4OJiohHfoOdGZ3huuLhpiUgOGTpgXNUPJgeZOZR3DnIpdSgtt83RS35OYNNXxM4TScVlpVKC9jyQSETR1A==", 2057 | "dev": true, 2058 | "requires": { 2059 | "@typescript-eslint/types": "7.1.0", 2060 | "@typescript-eslint/visitor-keys": "7.1.0" 2061 | } 2062 | }, 2063 | "@typescript-eslint/type-utils": { 2064 | "version": "7.1.0", 2065 | "resolved": "https://registry.npmjs.org/@typescript-eslint/type-utils/-/type-utils-7.1.0.tgz", 2066 | "integrity": "sha512-UZIhv8G+5b5skkcuhgvxYWHjk7FW7/JP5lPASMEUoliAPwIH/rxoUSQPia2cuOj9AmDZmwUl1usKm85t5VUMew==", 2067 | "dev": true, 2068 | "requires": { 2069 | "@typescript-eslint/typescript-estree": "7.1.0", 2070 | "@typescript-eslint/utils": "7.1.0", 2071 | "debug": "^4.3.4", 2072 | "ts-api-utils": "^1.0.1" 2073 | } 2074 | }, 2075 | "@typescript-eslint/types": { 2076 | "version": "7.1.0", 2077 | "resolved": "https://registry.npmjs.org/@typescript-eslint/types/-/types-7.1.0.tgz", 2078 | "integrity": "sha512-qTWjWieJ1tRJkxgZYXx6WUYtWlBc48YRxgY2JN1aGeVpkhmnopq+SUC8UEVGNXIvWH7XyuTjwALfG6bFEgCkQA==", 2079 | "dev": true 2080 | }, 2081 | "@typescript-eslint/typescript-estree": { 2082 | "version": "7.1.0", 2083 | "resolved": "https://registry.npmjs.org/@typescript-eslint/typescript-estree/-/typescript-estree-7.1.0.tgz", 2084 | "integrity": "sha512-k7MyrbD6E463CBbSpcOnwa8oXRdHzH1WiVzOipK3L5KSML92ZKgUBrTlehdi7PEIMT8k0bQixHUGXggPAlKnOQ==", 2085 | "dev": true, 2086 | "requires": { 2087 | "@typescript-eslint/types": "7.1.0", 2088 | "@typescript-eslint/visitor-keys": "7.1.0", 2089 | "debug": "^4.3.4", 2090 | "globby": "^11.1.0", 2091 | "is-glob": "^4.0.3", 2092 | "minimatch": "9.0.3", 2093 | "semver": "^7.5.4", 2094 | "ts-api-utils": "^1.0.1" 2095 | } 2096 | }, 2097 | "@typescript-eslint/utils": { 2098 | "version": "7.1.0", 2099 | "resolved": "https://registry.npmjs.org/@typescript-eslint/utils/-/utils-7.1.0.tgz", 2100 | "integrity": "sha512-WUFba6PZC5OCGEmbweGpnNJytJiLG7ZvDBJJoUcX4qZYf1mGZ97mO2Mps6O2efxJcJdRNpqweCistDbZMwIVHw==", 2101 | "dev": true, 2102 | "requires": { 2103 | "@eslint-community/eslint-utils": "^4.4.0", 2104 | "@types/json-schema": "^7.0.12", 2105 | "@types/semver": "^7.5.0", 2106 | "@typescript-eslint/scope-manager": "7.1.0", 2107 | "@typescript-eslint/types": "7.1.0", 2108 | "@typescript-eslint/typescript-estree": "7.1.0", 2109 | "semver": "^7.5.4" 2110 | } 2111 | }, 2112 | "@typescript-eslint/visitor-keys": { 2113 | "version": "7.1.0", 2114 | "resolved": "https://registry.npmjs.org/@typescript-eslint/visitor-keys/-/visitor-keys-7.1.0.tgz", 2115 | "integrity": "sha512-FhUqNWluiGNzlvnDZiXad4mZRhtghdoKW6e98GoEOYSu5cND+E39rG5KwJMUzeENwm1ztYBRqof8wMLP+wNPIA==", 2116 | "dev": true, 2117 | "requires": { 2118 | "@typescript-eslint/types": "7.1.0", 2119 | "eslint-visitor-keys": "^3.4.1" 2120 | } 2121 | }, 2122 | "@ungap/structured-clone": { 2123 | "version": "1.2.0", 2124 | "resolved": "https://registry.npmjs.org/@ungap/structured-clone/-/structured-clone-1.2.0.tgz", 2125 | "integrity": "sha512-zuVdFrMJiuCDQUMCzQaD6KL28MjnqqN8XnAqiEq9PNm/hCPTSGfrXCOfwj1ow4LFb/tNymJPwsNbVePc1xFqrQ==", 2126 | "dev": true 2127 | }, 2128 | "acorn": { 2129 | "version": "8.11.3", 2130 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.11.3.tgz", 2131 | "integrity": "sha512-Y9rRfJG5jcKOE0CLisYbojUjIrIEE7AGMzA/Sm4BslANhbS+cDMpgBdcPT91oJ7OuJ9hYJBx59RjbhxVnrF8Xg==", 2132 | "dev": true 2133 | }, 2134 | "acorn-jsx": { 2135 | "version": "5.3.2", 2136 | "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.3.2.tgz", 2137 | "integrity": "sha512-rq9s+JNhf0IChjtDXxllJ7g41oZk5SlXtp0LHwyA5cejwn7vKmKp4pPri6YEePv2PU65sAsegbXtIinmDFDXgQ==", 2138 | "dev": true, 2139 | "requires": {} 2140 | }, 2141 | "ajv": { 2142 | "version": "6.12.6", 2143 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.12.6.tgz", 2144 | "integrity": "sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g==", 2145 | "dev": true, 2146 | "requires": { 2147 | "fast-deep-equal": "^3.1.1", 2148 | "fast-json-stable-stringify": "^2.0.0", 2149 | "json-schema-traverse": "^0.4.1", 2150 | "uri-js": "^4.2.2" 2151 | } 2152 | }, 2153 | "ansi-regex": { 2154 | "version": "5.0.1", 2155 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 2156 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 2157 | "dev": true 2158 | }, 2159 | "ansi-styles": { 2160 | "version": "4.3.0", 2161 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 2162 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 2163 | "dev": true, 2164 | "requires": { 2165 | "color-convert": "^2.0.1" 2166 | } 2167 | }, 2168 | "argparse": { 2169 | "version": "2.0.1", 2170 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-2.0.1.tgz", 2171 | "integrity": "sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==", 2172 | "dev": true 2173 | }, 2174 | "array-union": { 2175 | "version": "2.1.0", 2176 | "resolved": "https://registry.npmjs.org/array-union/-/array-union-2.1.0.tgz", 2177 | "integrity": "sha512-HGyxoOTYUyCM6stUe6EJgnd4EoewAI7zMdfqO+kGjnlZmBDz/cR5pf8r/cR4Wq60sL/p0IkcjUEEPwS3GFrIyw==", 2178 | "dev": true 2179 | }, 2180 | "balanced-match": { 2181 | "version": "1.0.2", 2182 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", 2183 | "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==", 2184 | "dev": true 2185 | }, 2186 | "brace-expansion": { 2187 | "version": "2.0.1", 2188 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-2.0.1.tgz", 2189 | "integrity": "sha512-XnAIvQ8eM+kC6aULx6wuQiwVsnzsi9d3WxzV3FpWTGA19F621kwdbsAcFKXgKUHZWsy+mY6iL1sHTxWEFCytDA==", 2190 | "dev": true, 2191 | "requires": { 2192 | "balanced-match": "^1.0.0" 2193 | } 2194 | }, 2195 | "braces": { 2196 | "version": "3.0.2", 2197 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", 2198 | "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", 2199 | "dev": true, 2200 | "requires": { 2201 | "fill-range": "^7.0.1" 2202 | } 2203 | }, 2204 | "callsites": { 2205 | "version": "3.1.0", 2206 | "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz", 2207 | "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==", 2208 | "dev": true 2209 | }, 2210 | "chalk": { 2211 | "version": "4.1.2", 2212 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", 2213 | "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", 2214 | "dev": true, 2215 | "requires": { 2216 | "ansi-styles": "^4.1.0", 2217 | "supports-color": "^7.1.0" 2218 | } 2219 | }, 2220 | "color-convert": { 2221 | "version": "2.0.1", 2222 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 2223 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 2224 | "dev": true, 2225 | "requires": { 2226 | "color-name": "~1.1.4" 2227 | } 2228 | }, 2229 | "color-name": { 2230 | "version": "1.1.4", 2231 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 2232 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 2233 | "dev": true 2234 | }, 2235 | "concat-map": { 2236 | "version": "0.0.1", 2237 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 2238 | "integrity": "sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg==", 2239 | "dev": true 2240 | }, 2241 | "cross-spawn": { 2242 | "version": "7.0.3", 2243 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz", 2244 | "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==", 2245 | "dev": true, 2246 | "requires": { 2247 | "path-key": "^3.1.0", 2248 | "shebang-command": "^2.0.0", 2249 | "which": "^2.0.1" 2250 | } 2251 | }, 2252 | "debug": { 2253 | "version": "4.3.4", 2254 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", 2255 | "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", 2256 | "dev": true, 2257 | "requires": { 2258 | "ms": "2.1.2" 2259 | } 2260 | }, 2261 | "deep-is": { 2262 | "version": "0.1.4", 2263 | "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.4.tgz", 2264 | "integrity": "sha512-oIPzksmTg4/MriiaYGO+okXDT7ztn/w3Eptv/+gSIdMdKsJo0u4CfYNFJPy+4SKMuCqGw2wxnA+URMg3t8a/bQ==", 2265 | "dev": true 2266 | }, 2267 | "dir-glob": { 2268 | "version": "3.0.1", 2269 | "resolved": "https://registry.npmjs.org/dir-glob/-/dir-glob-3.0.1.tgz", 2270 | "integrity": "sha512-WkrWp9GR4KXfKGYzOLmTuGVi1UWFfws377n9cc55/tb6DuqyF6pcQ5AbiHEshaDpY9v6oaSr2XCDidGmMwdzIA==", 2271 | "dev": true, 2272 | "requires": { 2273 | "path-type": "^4.0.0" 2274 | } 2275 | }, 2276 | "doctrine": { 2277 | "version": "3.0.0", 2278 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-3.0.0.tgz", 2279 | "integrity": "sha512-yS+Q5i3hBf7GBkd4KG8a7eBNNWNGLTaEwwYWUijIYM7zrlYDM0BFXHjjPWlWZ1Rg7UaddZeIDmi9jF3HmqiQ2w==", 2280 | "dev": true, 2281 | "requires": { 2282 | "esutils": "^2.0.2" 2283 | } 2284 | }, 2285 | "escape-string-regexp": { 2286 | "version": "4.0.0", 2287 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", 2288 | "integrity": "sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA==", 2289 | "dev": true 2290 | }, 2291 | "eslint": { 2292 | "version": "8.57.0", 2293 | "resolved": "https://registry.npmjs.org/eslint/-/eslint-8.57.0.tgz", 2294 | "integrity": "sha512-dZ6+mexnaTIbSBZWgou51U6OmzIhYM2VcNdtiTtI7qPNZm35Akpr0f6vtw3w1Kmn5PYo+tZVfh13WrhpS6oLqQ==", 2295 | "dev": true, 2296 | "requires": { 2297 | "@eslint-community/eslint-utils": "^4.2.0", 2298 | "@eslint-community/regexpp": "^4.6.1", 2299 | "@eslint/eslintrc": "^2.1.4", 2300 | "@eslint/js": "8.57.0", 2301 | "@humanwhocodes/config-array": "^0.11.14", 2302 | "@humanwhocodes/module-importer": "^1.0.1", 2303 | "@nodelib/fs.walk": "^1.2.8", 2304 | "@ungap/structured-clone": "^1.2.0", 2305 | "ajv": "^6.12.4", 2306 | "chalk": "^4.0.0", 2307 | "cross-spawn": "^7.0.2", 2308 | "debug": "^4.3.2", 2309 | "doctrine": "^3.0.0", 2310 | "escape-string-regexp": "^4.0.0", 2311 | "eslint-scope": "^7.2.2", 2312 | "eslint-visitor-keys": "^3.4.3", 2313 | "espree": "^9.6.1", 2314 | "esquery": "^1.4.2", 2315 | "esutils": "^2.0.2", 2316 | "fast-deep-equal": "^3.1.3", 2317 | "file-entry-cache": "^6.0.1", 2318 | "find-up": "^5.0.0", 2319 | "glob-parent": "^6.0.2", 2320 | "globals": "^13.19.0", 2321 | "graphemer": "^1.4.0", 2322 | "ignore": "^5.2.0", 2323 | "imurmurhash": "^0.1.4", 2324 | "is-glob": "^4.0.0", 2325 | "is-path-inside": "^3.0.3", 2326 | "js-yaml": "^4.1.0", 2327 | "json-stable-stringify-without-jsonify": "^1.0.1", 2328 | "levn": "^0.4.1", 2329 | "lodash.merge": "^4.6.2", 2330 | "minimatch": "^3.1.2", 2331 | "natural-compare": "^1.4.0", 2332 | "optionator": "^0.9.3", 2333 | "strip-ansi": "^6.0.1", 2334 | "text-table": "^0.2.0" 2335 | }, 2336 | "dependencies": { 2337 | "brace-expansion": { 2338 | "version": "1.1.11", 2339 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 2340 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 2341 | "dev": true, 2342 | "requires": { 2343 | "balanced-match": "^1.0.0", 2344 | "concat-map": "0.0.1" 2345 | } 2346 | }, 2347 | "minimatch": { 2348 | "version": "3.1.2", 2349 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", 2350 | "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", 2351 | "dev": true, 2352 | "requires": { 2353 | "brace-expansion": "^1.1.7" 2354 | } 2355 | } 2356 | } 2357 | }, 2358 | "eslint-scope": { 2359 | "version": "7.2.2", 2360 | "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-7.2.2.tgz", 2361 | "integrity": "sha512-dOt21O7lTMhDM+X9mB4GX+DZrZtCUJPL/wlcTqxyrx5IvO0IYtILdtrQGQp+8n5S0gwSVmOf9NQrjMOgfQZlIg==", 2362 | "dev": true, 2363 | "requires": { 2364 | "esrecurse": "^4.3.0", 2365 | "estraverse": "^5.2.0" 2366 | } 2367 | }, 2368 | "eslint-visitor-keys": { 2369 | "version": "3.4.3", 2370 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-3.4.3.tgz", 2371 | "integrity": "sha512-wpc+LXeiyiisxPlEkUzU6svyS1frIO3Mgxj1fdy7Pm8Ygzguax2N3Fa/D/ag1WqbOprdI+uY6wMUl8/a2G+iag==", 2372 | "dev": true 2373 | }, 2374 | "espree": { 2375 | "version": "9.6.1", 2376 | "resolved": "https://registry.npmjs.org/espree/-/espree-9.6.1.tgz", 2377 | "integrity": "sha512-oruZaFkjorTpF32kDSI5/75ViwGeZginGGy2NoOSg3Q9bnwlnmDm4HLnkl0RE3n+njDXR037aY1+x58Z/zFdwQ==", 2378 | "dev": true, 2379 | "requires": { 2380 | "acorn": "^8.9.0", 2381 | "acorn-jsx": "^5.3.2", 2382 | "eslint-visitor-keys": "^3.4.1" 2383 | } 2384 | }, 2385 | "esquery": { 2386 | "version": "1.5.0", 2387 | "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.5.0.tgz", 2388 | "integrity": "sha512-YQLXUplAwJgCydQ78IMJywZCceoqk1oH01OERdSAJc/7U2AylwjhSCLDEtqwg811idIS/9fIU5GjG73IgjKMVg==", 2389 | "dev": true, 2390 | "requires": { 2391 | "estraverse": "^5.1.0" 2392 | } 2393 | }, 2394 | "esrecurse": { 2395 | "version": "4.3.0", 2396 | "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.3.0.tgz", 2397 | "integrity": "sha512-KmfKL3b6G+RXvP8N1vr3Tq1kL/oCFgn2NYXEtqP8/L3pKapUA4G8cFVaoF3SU323CD4XypR/ffioHmkti6/Tag==", 2398 | "dev": true, 2399 | "requires": { 2400 | "estraverse": "^5.2.0" 2401 | } 2402 | }, 2403 | "estraverse": { 2404 | "version": "5.3.0", 2405 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.3.0.tgz", 2406 | "integrity": "sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==", 2407 | "dev": true 2408 | }, 2409 | "esutils": { 2410 | "version": "2.0.3", 2411 | "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz", 2412 | "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==", 2413 | "dev": true 2414 | }, 2415 | "fast-deep-equal": { 2416 | "version": "3.1.3", 2417 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz", 2418 | "integrity": "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==", 2419 | "dev": true 2420 | }, 2421 | "fast-glob": { 2422 | "version": "3.3.2", 2423 | "resolved": "https://registry.npmjs.org/fast-glob/-/fast-glob-3.3.2.tgz", 2424 | "integrity": "sha512-oX2ruAFQwf/Orj8m737Y5adxDQO0LAB7/S5MnxCdTNDd4p6BsyIVsv9JQsATbTSq8KHRpLwIHbVlUNatxd+1Ow==", 2425 | "dev": true, 2426 | "requires": { 2427 | "@nodelib/fs.stat": "^2.0.2", 2428 | "@nodelib/fs.walk": "^1.2.3", 2429 | "glob-parent": "^5.1.2", 2430 | "merge2": "^1.3.0", 2431 | "micromatch": "^4.0.4" 2432 | }, 2433 | "dependencies": { 2434 | "glob-parent": { 2435 | "version": "5.1.2", 2436 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", 2437 | "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", 2438 | "dev": true, 2439 | "requires": { 2440 | "is-glob": "^4.0.1" 2441 | } 2442 | } 2443 | } 2444 | }, 2445 | "fast-json-stable-stringify": { 2446 | "version": "2.1.0", 2447 | "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz", 2448 | "integrity": "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==", 2449 | "dev": true 2450 | }, 2451 | "fast-levenshtein": { 2452 | "version": "2.0.6", 2453 | "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", 2454 | "integrity": "sha512-DCXu6Ifhqcks7TZKY3Hxp3y6qphY5SJZmrWMDrKcERSOXWQdMhU9Ig/PYrzyw/ul9jOIyh0N4M0tbC5hodg8dw==", 2455 | "dev": true 2456 | }, 2457 | "fastq": { 2458 | "version": "1.17.1", 2459 | "resolved": "https://registry.npmjs.org/fastq/-/fastq-1.17.1.tgz", 2460 | "integrity": "sha512-sRVD3lWVIXWg6By68ZN7vho9a1pQcN/WBFaAAsDDFzlJjvoGx0P8z7V1t72grFJfJhu3YPZBuu25f7Kaw2jN1w==", 2461 | "dev": true, 2462 | "requires": { 2463 | "reusify": "^1.0.4" 2464 | } 2465 | }, 2466 | "file-entry-cache": { 2467 | "version": "6.0.1", 2468 | "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-6.0.1.tgz", 2469 | "integrity": "sha512-7Gps/XWymbLk2QLYK4NzpMOrYjMhdIxXuIvy2QBsLE6ljuodKvdkWs/cpyJJ3CVIVpH0Oi1Hvg1ovbMzLdFBBg==", 2470 | "dev": true, 2471 | "requires": { 2472 | "flat-cache": "^3.0.4" 2473 | } 2474 | }, 2475 | "fill-range": { 2476 | "version": "7.0.1", 2477 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", 2478 | "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", 2479 | "dev": true, 2480 | "requires": { 2481 | "to-regex-range": "^5.0.1" 2482 | } 2483 | }, 2484 | "find-up": { 2485 | "version": "5.0.0", 2486 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-5.0.0.tgz", 2487 | "integrity": "sha512-78/PXT1wlLLDgTzDs7sjq9hzz0vXD+zn+7wypEe4fXQxCmdmqfGsEPQxmiCSQI3ajFV91bVSsvNtrJRiW6nGng==", 2488 | "dev": true, 2489 | "requires": { 2490 | "locate-path": "^6.0.0", 2491 | "path-exists": "^4.0.0" 2492 | } 2493 | }, 2494 | "flat-cache": { 2495 | "version": "3.2.0", 2496 | "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-3.2.0.tgz", 2497 | "integrity": "sha512-CYcENa+FtcUKLmhhqyctpclsq7QF38pKjZHsGNiSQF5r4FtoKDWabFDl3hzaEQMvT1LHEysw5twgLvpYYb4vbw==", 2498 | "dev": true, 2499 | "requires": { 2500 | "flatted": "^3.2.9", 2501 | "keyv": "^4.5.3", 2502 | "rimraf": "^3.0.2" 2503 | } 2504 | }, 2505 | "flatted": { 2506 | "version": "3.3.1", 2507 | "resolved": "https://registry.npmjs.org/flatted/-/flatted-3.3.1.tgz", 2508 | "integrity": "sha512-X8cqMLLie7KsNUDSdzeN8FYK9rEt4Dt67OsG/DNGnYTSDBG4uFAJFBnUeiV+zCVAvwFy56IjM9sH51jVaEhNxw==", 2509 | "dev": true 2510 | }, 2511 | "fs.realpath": { 2512 | "version": "1.0.0", 2513 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 2514 | "integrity": "sha512-OO0pH2lK6a0hZnAdau5ItzHPI6pUlvI7jMVnxUQRtw4owF2wk8lOSabtGDCTP4Ggrg2MbGnWO9X8K1t4+fGMDw==", 2515 | "dev": true 2516 | }, 2517 | "glob": { 2518 | "version": "7.2.3", 2519 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.3.tgz", 2520 | "integrity": "sha512-nFR0zLpU2YCaRxwoCJvL6UvCH2JFyFVIvwTLsIf21AuHlMskA1hhTdk+LlYJtOlYt9v6dvszD2BGRqBL+iQK9Q==", 2521 | "dev": true, 2522 | "requires": { 2523 | "fs.realpath": "^1.0.0", 2524 | "inflight": "^1.0.4", 2525 | "inherits": "2", 2526 | "minimatch": "^3.1.1", 2527 | "once": "^1.3.0", 2528 | "path-is-absolute": "^1.0.0" 2529 | }, 2530 | "dependencies": { 2531 | "brace-expansion": { 2532 | "version": "1.1.11", 2533 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 2534 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 2535 | "dev": true, 2536 | "requires": { 2537 | "balanced-match": "^1.0.0", 2538 | "concat-map": "0.0.1" 2539 | } 2540 | }, 2541 | "minimatch": { 2542 | "version": "3.1.2", 2543 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", 2544 | "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", 2545 | "dev": true, 2546 | "requires": { 2547 | "brace-expansion": "^1.1.7" 2548 | } 2549 | } 2550 | } 2551 | }, 2552 | "glob-parent": { 2553 | "version": "6.0.2", 2554 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-6.0.2.tgz", 2555 | "integrity": "sha512-XxwI8EOhVQgWp6iDL+3b0r86f4d6AX6zSU55HfB4ydCEuXLXc5FcYeOu+nnGftS4TEju/11rt4KJPTMgbfmv4A==", 2556 | "dev": true, 2557 | "requires": { 2558 | "is-glob": "^4.0.3" 2559 | } 2560 | }, 2561 | "globals": { 2562 | "version": "13.24.0", 2563 | "resolved": "https://registry.npmjs.org/globals/-/globals-13.24.0.tgz", 2564 | "integrity": "sha512-AhO5QUcj8llrbG09iWhPU2B204J1xnPeL8kQmVorSsy+Sjj1sk8gIyh6cUocGmH4L0UuhAJy+hJMRA4mgA4mFQ==", 2565 | "dev": true, 2566 | "requires": { 2567 | "type-fest": "^0.20.2" 2568 | } 2569 | }, 2570 | "globby": { 2571 | "version": "11.1.0", 2572 | "resolved": "https://registry.npmjs.org/globby/-/globby-11.1.0.tgz", 2573 | "integrity": "sha512-jhIXaOzy1sb8IyocaruWSn1TjmnBVs8Ayhcy83rmxNJ8q2uWKCAj3CnJY+KpGSXCueAPc0i05kVvVKtP1t9S3g==", 2574 | "dev": true, 2575 | "requires": { 2576 | "array-union": "^2.1.0", 2577 | "dir-glob": "^3.0.1", 2578 | "fast-glob": "^3.2.9", 2579 | "ignore": "^5.2.0", 2580 | "merge2": "^1.4.1", 2581 | "slash": "^3.0.0" 2582 | } 2583 | }, 2584 | "graphemer": { 2585 | "version": "1.4.0", 2586 | "resolved": "https://registry.npmjs.org/graphemer/-/graphemer-1.4.0.tgz", 2587 | "integrity": "sha512-EtKwoO6kxCL9WO5xipiHTZlSzBm7WLT627TqC/uVRd0HKmq8NXyebnNYxDoBi7wt8eTWrUrKXCOVaFq9x1kgag==", 2588 | "dev": true 2589 | }, 2590 | "has-flag": { 2591 | "version": "4.0.0", 2592 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 2593 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", 2594 | "dev": true 2595 | }, 2596 | "ignore": { 2597 | "version": "5.3.1", 2598 | "resolved": "https://registry.npmjs.org/ignore/-/ignore-5.3.1.tgz", 2599 | "integrity": "sha512-5Fytz/IraMjqpwfd34ke28PTVMjZjJG2MPn5t7OE4eUCUNf8BAa7b5WUS9/Qvr6mwOQS7Mk6vdsMno5he+T8Xw==", 2600 | "dev": true 2601 | }, 2602 | "import-fresh": { 2603 | "version": "3.3.0", 2604 | "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.3.0.tgz", 2605 | "integrity": "sha512-veYYhQa+D1QBKznvhUHxb8faxlrwUnxseDAbAp457E0wLNio2bOSKnjYDhMj+YiAq61xrMGhQk9iXVk5FzgQMw==", 2606 | "dev": true, 2607 | "requires": { 2608 | "parent-module": "^1.0.0", 2609 | "resolve-from": "^4.0.0" 2610 | } 2611 | }, 2612 | "imurmurhash": { 2613 | "version": "0.1.4", 2614 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", 2615 | "integrity": "sha512-JmXMZ6wuvDmLiHEml9ykzqO6lwFbof0GG4IkcGaENdCRDDmMVnny7s5HsIgHCbaq0w2MyPhDqkhTUgS2LU2PHA==", 2616 | "dev": true 2617 | }, 2618 | "inflight": { 2619 | "version": "1.0.6", 2620 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 2621 | "integrity": "sha512-k92I/b08q4wvFscXCLvqfsHCrjrF7yiXsQuIVvVE7N82W3+aqpzuUdBbfhWcy/FZR3/4IgflMgKLOsvPDrGCJA==", 2622 | "dev": true, 2623 | "requires": { 2624 | "once": "^1.3.0", 2625 | "wrappy": "1" 2626 | } 2627 | }, 2628 | "inherits": { 2629 | "version": "2.0.4", 2630 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 2631 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", 2632 | "dev": true 2633 | }, 2634 | "is-extglob": { 2635 | "version": "2.1.1", 2636 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 2637 | "integrity": "sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==", 2638 | "dev": true 2639 | }, 2640 | "is-glob": { 2641 | "version": "4.0.3", 2642 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", 2643 | "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", 2644 | "dev": true, 2645 | "requires": { 2646 | "is-extglob": "^2.1.1" 2647 | } 2648 | }, 2649 | "is-number": { 2650 | "version": "7.0.0", 2651 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", 2652 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", 2653 | "dev": true 2654 | }, 2655 | "is-path-inside": { 2656 | "version": "3.0.3", 2657 | "resolved": "https://registry.npmjs.org/is-path-inside/-/is-path-inside-3.0.3.tgz", 2658 | "integrity": "sha512-Fd4gABb+ycGAmKou8eMftCupSir5lRxqf4aD/vd0cD2qc4HL07OjCeuHMr8Ro4CoMaeCKDB0/ECBOVWjTwUvPQ==", 2659 | "dev": true 2660 | }, 2661 | "isexe": { 2662 | "version": "2.0.0", 2663 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 2664 | "integrity": "sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw==", 2665 | "dev": true 2666 | }, 2667 | "js-yaml": { 2668 | "version": "4.1.0", 2669 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-4.1.0.tgz", 2670 | "integrity": "sha512-wpxZs9NoxZaJESJGIZTyDEaYpl0FKSA+FB9aJiyemKhMwkxQg63h4T1KJgUGHpTqPDNRcmmYLugrRjJlBtWvRA==", 2671 | "dev": true, 2672 | "requires": { 2673 | "argparse": "^2.0.1" 2674 | } 2675 | }, 2676 | "json-buffer": { 2677 | "version": "3.0.1", 2678 | "resolved": "https://registry.npmjs.org/json-buffer/-/json-buffer-3.0.1.tgz", 2679 | "integrity": "sha512-4bV5BfR2mqfQTJm+V5tPPdf+ZpuhiIvTuAB5g8kcrXOZpTT/QwwVRWBywX1ozr6lEuPdbHxwaJlm9G6mI2sfSQ==", 2680 | "dev": true 2681 | }, 2682 | "json-schema-traverse": { 2683 | "version": "0.4.1", 2684 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", 2685 | "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==", 2686 | "dev": true 2687 | }, 2688 | "json-stable-stringify-without-jsonify": { 2689 | "version": "1.0.1", 2690 | "resolved": "https://registry.npmjs.org/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz", 2691 | "integrity": "sha512-Bdboy+l7tA3OGW6FjyFHWkP5LuByj1Tk33Ljyq0axyzdk9//JSi2u3fP1QSmd1KNwq6VOKYGlAu87CisVir6Pw==", 2692 | "dev": true 2693 | }, 2694 | "keyv": { 2695 | "version": "4.5.4", 2696 | "resolved": "https://registry.npmjs.org/keyv/-/keyv-4.5.4.tgz", 2697 | "integrity": "sha512-oxVHkHR/EJf2CNXnWxRLW6mg7JyCCUcG0DtEGmL2ctUo1PNTin1PUil+r/+4r5MpVgC/fn1kjsx7mjSujKqIpw==", 2698 | "dev": true, 2699 | "requires": { 2700 | "json-buffer": "3.0.1" 2701 | } 2702 | }, 2703 | "levn": { 2704 | "version": "0.4.1", 2705 | "resolved": "https://registry.npmjs.org/levn/-/levn-0.4.1.tgz", 2706 | "integrity": "sha512-+bT2uH4E5LGE7h/n3evcS/sQlJXCpIp6ym8OWJ5eV6+67Dsql/LaaT7qJBAt2rzfoa/5QBGBhxDix1dMt2kQKQ==", 2707 | "dev": true, 2708 | "requires": { 2709 | "prelude-ls": "^1.2.1", 2710 | "type-check": "~0.4.0" 2711 | } 2712 | }, 2713 | "locate-path": { 2714 | "version": "6.0.0", 2715 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-6.0.0.tgz", 2716 | "integrity": "sha512-iPZK6eYjbxRu3uB4/WZ3EsEIMJFMqAoopl3R+zuq0UjcAm/MO6KCweDgPfP3elTztoKP3KtnVHxTn2NHBSDVUw==", 2717 | "dev": true, 2718 | "requires": { 2719 | "p-locate": "^5.0.0" 2720 | } 2721 | }, 2722 | "lodash.merge": { 2723 | "version": "4.6.2", 2724 | "resolved": "https://registry.npmjs.org/lodash.merge/-/lodash.merge-4.6.2.tgz", 2725 | "integrity": "sha512-0KpjqXRVvrYyCsX1swR/XTK0va6VQkQM6MNo7PqW77ByjAhoARA8EfrP1N4+KlKj8YS0ZUCtRT/YUuhyYDujIQ==", 2726 | "dev": true 2727 | }, 2728 | "lru-cache": { 2729 | "version": "6.0.0", 2730 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", 2731 | "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", 2732 | "dev": true, 2733 | "requires": { 2734 | "yallist": "^4.0.0" 2735 | } 2736 | }, 2737 | "merge2": { 2738 | "version": "1.4.1", 2739 | "resolved": "https://registry.npmjs.org/merge2/-/merge2-1.4.1.tgz", 2740 | "integrity": "sha512-8q7VEgMJW4J8tcfVPy8g09NcQwZdbwFEqhe/WZkoIzjn/3TGDwtOCYtXGxA3O8tPzpczCCDgv+P2P5y00ZJOOg==", 2741 | "dev": true 2742 | }, 2743 | "micromatch": { 2744 | "version": "4.0.5", 2745 | "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-4.0.5.tgz", 2746 | "integrity": "sha512-DMy+ERcEW2q8Z2Po+WNXuw3c5YaUSFjAO5GsJqfEl7UjvtIuFKO6ZrKvcItdy98dwFI2N1tg3zNIdKaQT+aNdA==", 2747 | "dev": true, 2748 | "requires": { 2749 | "braces": "^3.0.2", 2750 | "picomatch": "^2.3.1" 2751 | } 2752 | }, 2753 | "minimatch": { 2754 | "version": "9.0.3", 2755 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-9.0.3.tgz", 2756 | "integrity": "sha512-RHiac9mvaRw0x3AYRgDC1CxAP7HTcNrrECeA8YYJeWnpo+2Q5CegtZjaotWTWxDG3UeGA1coE05iH1mPjT/2mg==", 2757 | "dev": true, 2758 | "requires": { 2759 | "brace-expansion": "^2.0.1" 2760 | } 2761 | }, 2762 | "ms": { 2763 | "version": "2.1.2", 2764 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 2765 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 2766 | "dev": true 2767 | }, 2768 | "natural-compare": { 2769 | "version": "1.4.0", 2770 | "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", 2771 | "integrity": "sha512-OWND8ei3VtNC9h7V60qff3SVobHr996CTwgxubgyQYEpg290h9J0buyECNNJexkFm5sOajh5G116RYA1c8ZMSw==", 2772 | "dev": true 2773 | }, 2774 | "once": { 2775 | "version": "1.4.0", 2776 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 2777 | "integrity": "sha512-lNaJgI+2Q5URQBkccEKHTQOPaXdUxnZZElQTZY0MFUAuaEqe1E+Nyvgdz/aIyNi6Z9MzO5dv1H8n58/GELp3+w==", 2778 | "dev": true, 2779 | "requires": { 2780 | "wrappy": "1" 2781 | } 2782 | }, 2783 | "optionator": { 2784 | "version": "0.9.3", 2785 | "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.9.3.tgz", 2786 | "integrity": "sha512-JjCoypp+jKn1ttEFExxhetCKeJt9zhAgAve5FXHixTvFDW/5aEktX9bufBKLRRMdU7bNtpLfcGu94B3cdEJgjg==", 2787 | "dev": true, 2788 | "requires": { 2789 | "@aashutoshrathi/word-wrap": "^1.2.3", 2790 | "deep-is": "^0.1.3", 2791 | "fast-levenshtein": "^2.0.6", 2792 | "levn": "^0.4.1", 2793 | "prelude-ls": "^1.2.1", 2794 | "type-check": "^0.4.0" 2795 | } 2796 | }, 2797 | "p-limit": { 2798 | "version": "3.1.0", 2799 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-3.1.0.tgz", 2800 | "integrity": "sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ==", 2801 | "dev": true, 2802 | "requires": { 2803 | "yocto-queue": "^0.1.0" 2804 | } 2805 | }, 2806 | "p-locate": { 2807 | "version": "5.0.0", 2808 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-5.0.0.tgz", 2809 | "integrity": "sha512-LaNjtRWUBY++zB5nE/NwcaoMylSPk+S+ZHNB1TzdbMJMny6dynpAGt7X/tl/QYq3TIeE6nxHppbo2LGymrG5Pw==", 2810 | "dev": true, 2811 | "requires": { 2812 | "p-limit": "^3.0.2" 2813 | } 2814 | }, 2815 | "parent-module": { 2816 | "version": "1.0.1", 2817 | "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz", 2818 | "integrity": "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==", 2819 | "dev": true, 2820 | "requires": { 2821 | "callsites": "^3.0.0" 2822 | } 2823 | }, 2824 | "path-exists": { 2825 | "version": "4.0.0", 2826 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz", 2827 | "integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==", 2828 | "dev": true 2829 | }, 2830 | "path-is-absolute": { 2831 | "version": "1.0.1", 2832 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 2833 | "integrity": "sha512-AVbw3UJ2e9bq64vSaS9Am0fje1Pa8pbGqTTsmXfaIiMpnr5DlDhfJOuLj9Sf95ZPVDAUerDfEk88MPmPe7UCQg==", 2834 | "dev": true 2835 | }, 2836 | "path-key": { 2837 | "version": "3.1.1", 2838 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", 2839 | "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", 2840 | "dev": true 2841 | }, 2842 | "path-type": { 2843 | "version": "4.0.0", 2844 | "resolved": "https://registry.npmjs.org/path-type/-/path-type-4.0.0.tgz", 2845 | "integrity": "sha512-gDKb8aZMDeD/tZWs9P6+q0J9Mwkdl6xMV8TjnGP3qJVJ06bdMgkbBlLU8IdfOsIsFz2BW1rNVT3XuNEl8zPAvw==", 2846 | "dev": true 2847 | }, 2848 | "picomatch": { 2849 | "version": "2.3.1", 2850 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz", 2851 | "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==", 2852 | "dev": true 2853 | }, 2854 | "prelude-ls": { 2855 | "version": "1.2.1", 2856 | "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.2.1.tgz", 2857 | "integrity": "sha512-vkcDPrRZo1QZLbn5RLGPpg/WmIQ65qoWWhcGKf/b5eplkkarX0m9z8ppCat4mlOqUsWpyNuYgO3VRyrYHSzX5g==", 2858 | "dev": true 2859 | }, 2860 | "punycode": { 2861 | "version": "2.3.1", 2862 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.3.1.tgz", 2863 | "integrity": "sha512-vYt7UD1U9Wg6138shLtLOvdAu+8DsC/ilFtEVHcH+wydcSpNE20AfSOduf6MkRFahL5FY7X1oU7nKVZFtfq8Fg==", 2864 | "dev": true 2865 | }, 2866 | "queue-microtask": { 2867 | "version": "1.2.3", 2868 | "resolved": "https://registry.npmjs.org/queue-microtask/-/queue-microtask-1.2.3.tgz", 2869 | "integrity": "sha512-NuaNSa6flKT5JaSYQzJok04JzTL1CA6aGhv5rfLW3PgqA+M2ChpZQnAC8h8i4ZFkBS8X5RqkDBHA7r4hej3K9A==", 2870 | "dev": true 2871 | }, 2872 | "resolve-from": { 2873 | "version": "4.0.0", 2874 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz", 2875 | "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==", 2876 | "dev": true 2877 | }, 2878 | "reusify": { 2879 | "version": "1.0.4", 2880 | "resolved": "https://registry.npmjs.org/reusify/-/reusify-1.0.4.tgz", 2881 | "integrity": "sha512-U9nH88a3fc/ekCF1l0/UP1IosiuIjyTh7hBvXVMHYgVcfGvt897Xguj2UOLDeI5BG2m7/uwyaLVT6fbtCwTyzw==", 2882 | "dev": true 2883 | }, 2884 | "rimraf": { 2885 | "version": "3.0.2", 2886 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-3.0.2.tgz", 2887 | "integrity": "sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA==", 2888 | "dev": true, 2889 | "requires": { 2890 | "glob": "^7.1.3" 2891 | } 2892 | }, 2893 | "run-parallel": { 2894 | "version": "1.2.0", 2895 | "resolved": "https://registry.npmjs.org/run-parallel/-/run-parallel-1.2.0.tgz", 2896 | "integrity": "sha512-5l4VyZR86LZ/lDxZTR6jqL8AFE2S0IFLMP26AbjsLVADxHdhB/c0GUsH+y39UfCi3dzz8OlQuPmnaJOMoDHQBA==", 2897 | "dev": true, 2898 | "requires": { 2899 | "queue-microtask": "^1.2.2" 2900 | } 2901 | }, 2902 | "semver": { 2903 | "version": "7.6.0", 2904 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.6.0.tgz", 2905 | "integrity": "sha512-EnwXhrlwXMk9gKu5/flx5sv/an57AkRplG3hTK68W7FRDN+k+OWBj65M7719OkA82XLBxrcX0KSHj+X5COhOVg==", 2906 | "dev": true, 2907 | "requires": { 2908 | "lru-cache": "^6.0.0" 2909 | } 2910 | }, 2911 | "shebang-command": { 2912 | "version": "2.0.0", 2913 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", 2914 | "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", 2915 | "dev": true, 2916 | "requires": { 2917 | "shebang-regex": "^3.0.0" 2918 | } 2919 | }, 2920 | "shebang-regex": { 2921 | "version": "3.0.0", 2922 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", 2923 | "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", 2924 | "dev": true 2925 | }, 2926 | "slash": { 2927 | "version": "3.0.0", 2928 | "resolved": "https://registry.npmjs.org/slash/-/slash-3.0.0.tgz", 2929 | "integrity": "sha512-g9Q1haeby36OSStwb4ntCGGGaKsaVSjQ68fBxoQcutl5fS1vuY18H3wSt3jFyFtrkx+Kz0V1G85A4MyAdDMi2Q==", 2930 | "dev": true 2931 | }, 2932 | "strip-ansi": { 2933 | "version": "6.0.1", 2934 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", 2935 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", 2936 | "dev": true, 2937 | "requires": { 2938 | "ansi-regex": "^5.0.1" 2939 | } 2940 | }, 2941 | "strip-json-comments": { 2942 | "version": "3.1.1", 2943 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz", 2944 | "integrity": "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==", 2945 | "dev": true 2946 | }, 2947 | "supports-color": { 2948 | "version": "7.2.0", 2949 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", 2950 | "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", 2951 | "dev": true, 2952 | "requires": { 2953 | "has-flag": "^4.0.0" 2954 | } 2955 | }, 2956 | "text-table": { 2957 | "version": "0.2.0", 2958 | "resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz", 2959 | "integrity": "sha512-N+8UisAXDGk8PFXP4HAzVR9nbfmVJ3zYLAWiTIoqC5v5isinhr+r5uaO8+7r3BMfuNIufIsA7RdpVgacC2cSpw==", 2960 | "dev": true 2961 | }, 2962 | "to-regex-range": { 2963 | "version": "5.0.1", 2964 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", 2965 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", 2966 | "dev": true, 2967 | "requires": { 2968 | "is-number": "^7.0.0" 2969 | } 2970 | }, 2971 | "ts-api-utils": { 2972 | "version": "1.2.1", 2973 | "resolved": "https://registry.npmjs.org/ts-api-utils/-/ts-api-utils-1.2.1.tgz", 2974 | "integrity": "sha512-RIYA36cJn2WiH9Hy77hdF9r7oEwxAtB/TS9/S4Qd90Ap4z5FSiin5zEiTL44OII1Y3IIlEvxwxFUVgrHSZ/UpA==", 2975 | "dev": true, 2976 | "requires": {} 2977 | }, 2978 | "type-check": { 2979 | "version": "0.4.0", 2980 | "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.4.0.tgz", 2981 | "integrity": "sha512-XleUoc9uwGXqjWwXaUTZAmzMcFZ5858QA2vvx1Ur5xIcixXIP+8LnFDgRplU30us6teqdlskFfu+ae4K79Ooew==", 2982 | "dev": true, 2983 | "requires": { 2984 | "prelude-ls": "^1.2.1" 2985 | } 2986 | }, 2987 | "type-fest": { 2988 | "version": "0.20.2", 2989 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.20.2.tgz", 2990 | "integrity": "sha512-Ne+eE4r0/iWnpAxD852z3A+N0Bt5RN//NjJwRd2VFHEmrywxf5vsZlh4R6lixl6B+wz/8d+maTSAkN1FIkI3LQ==", 2991 | "dev": true 2992 | }, 2993 | "typescript": { 2994 | "version": "5.3.3", 2995 | "resolved": "https://registry.npmjs.org/typescript/-/typescript-5.3.3.tgz", 2996 | "integrity": "sha512-pXWcraxM0uxAS+tN0AG/BF2TyqmHO014Z070UsJ+pFvYuRSq8KH8DmWpnbXe0pEPDHXZV3FcAbJkijJ5oNEnWw==", 2997 | "dev": true 2998 | }, 2999 | "typescript-eslint": { 3000 | "version": "7.1.0", 3001 | "resolved": "https://registry.npmjs.org/typescript-eslint/-/typescript-eslint-7.1.0.tgz", 3002 | "integrity": "sha512-GfAALH4zoqae5mIfHr7WU3BsULHP73hjwF8vCmyTkH3IXHXjqg3JNWwUcd8CwOTLIr4tjRTZQWpToyESPnpOhg==", 3003 | "dev": true, 3004 | "requires": { 3005 | "@typescript-eslint/eslint-plugin": "7.1.0", 3006 | "@typescript-eslint/parser": "7.1.0" 3007 | } 3008 | }, 3009 | "uri-js": { 3010 | "version": "4.4.1", 3011 | "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.4.1.tgz", 3012 | "integrity": "sha512-7rKUyy33Q1yc98pQ1DAmLtwX109F7TIfWlW1Ydo8Wl1ii1SeHieeh0HHfPeL2fMXK6z0s8ecKs9frCuLJvndBg==", 3013 | "dev": true, 3014 | "requires": { 3015 | "punycode": "^2.1.0" 3016 | } 3017 | }, 3018 | "which": { 3019 | "version": "2.0.2", 3020 | "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", 3021 | "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", 3022 | "dev": true, 3023 | "requires": { 3024 | "isexe": "^2.0.0" 3025 | } 3026 | }, 3027 | "wrappy": { 3028 | "version": "1.0.2", 3029 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 3030 | "integrity": "sha512-l4Sp/DRseor9wL6EvV2+TuQn63dMkPjZ/sp9XkghTEbV9KlPS1xUsZ3u7/IQO4wxtcFB4bgpQPRcR3QCvezPcQ==", 3031 | "dev": true 3032 | }, 3033 | "yallist": { 3034 | "version": "4.0.0", 3035 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", 3036 | "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", 3037 | "dev": true 3038 | }, 3039 | "yocto-queue": { 3040 | "version": "0.1.0", 3041 | "resolved": "https://registry.npmjs.org/yocto-queue/-/yocto-queue-0.1.0.tgz", 3042 | "integrity": "sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q==", 3043 | "dev": true 3044 | } 3045 | } 3046 | } 3047 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "figma-fix-sf", 3 | "main": "code.js", 4 | "scripts": { 5 | "build": "tsc -p tsconfig.json" 6 | }, 7 | "author": "@charliecm", 8 | "license": "MIT", 9 | "devDependencies": { 10 | "@figma/eslint-plugin-figma-plugins": "^0.14.0", 11 | "@figma/plugin-typings": "^1.87.0", 12 | "@typescript-eslint/eslint-plugin": "^7.1.0", 13 | "@typescript-eslint/parser": "^7.1.0", 14 | "eslint": "^8.57.0", 15 | "typescript": "^5.3.3", 16 | "typescript-eslint": "^7.1.0" 17 | } 18 | } 19 | -------------------------------------------------------------------------------- /tsconfig.json: -------------------------------------------------------------------------------- 1 | { 2 | "compilerOptions": { 3 | "target": "es6", 4 | "lib": ["es6"], 5 | "typeRoots": [ 6 | "./node_modules/@types", 7 | "./node_modules/@figma" 8 | ] 9 | } 10 | } 11 | --------------------------------------------------------------------------------