diff --git a/.github/workflows/github-actions.yml b/.github/workflows/github-actions.yml new file mode 100644 index 0000000..0e62df7 --- /dev/null +++ b/.github/workflows/github-actions.yml @@ -0,0 +1,20 @@ +name: GitHub Actions +run-name: Running necessary checks ๐Ÿš€ +on: [push] +jobs: + Code-Checks: + runs-on: ubuntu-latest + steps: + - name: Check out repository code + uses: actions/checkout@v4 + - run: echo "๐Ÿ’ก The ${{ github.repository }} repository has been cloned to the runner." + - name: ๐Ÿšš Installing dependencies + run: yarn + - name: ๐Ÿท๏ธ running typecheck + run: yarn build + - name: ๐Ÿงช Running tests + run: yarn test + - name: ๐Ÿšจ Linting code + run: yarn lint + - name: ๐Ÿšจ prettier check code + run: yarn format:check diff --git a/.locorc.js b/.locorc.js index 33bbe81..ff1fbd7 100644 --- a/.locorc.js +++ b/.locorc.js @@ -1,14 +1,14 @@ /** @type {import('loco-cli/types').Config} */ module.exports = { - accessKey: "", - localesDir: "public/locales", + accessKey: '', + localesDir: 'public/locales', namespaces: true, push: { - "flag-new": "provisional", - "tag-new": process.env.npm_package_version, - "delete-absent": false, + 'flag-new': 'provisional', + 'tag-new': process.env.npm_package_version, + 'delete-absent': false }, pull: { - fallback: "en", - }, + fallback: 'en' + } }; diff --git a/.prettierignore b/.prettierignore new file mode 100644 index 0000000..9f46784 --- /dev/null +++ b/.prettierignore @@ -0,0 +1,11 @@ +# Ignore everything except the code in src/. +#ย Based on https://stackoverflow.com/a/70715829/458193 +* +!src/**/*.js +!src/**/*.jsx +!src/**/*.ts +!src/**/*.tsx +!src/**/*.json +!*/ + +# More specific ignores go below. diff --git a/.prettierrc b/.prettierrc new file mode 100644 index 0000000..7aef96e --- /dev/null +++ b/.prettierrc @@ -0,0 +1,10 @@ +{ + "arrowParens": "avoid", + "bracketSameLine": false, + "printWidth": 100, + "semi": true, + "singleQuote": true, + "tabWidth": 2, + "trailingComma": "none", + "useTabs": false +} diff --git a/.vscode/settings.json b/.vscode/settings.json new file mode 100644 index 0000000..ad92582 --- /dev/null +++ b/.vscode/settings.json @@ -0,0 +1,3 @@ +{ + "editor.formatOnSave": true +} diff --git a/README.md b/README.md index 326e462..a236272 100644 --- a/README.md +++ b/README.md @@ -66,40 +66,40 @@ Global options are passed as options in the terminal or read from a `loco.config // loco.config.js /** @type {import('loco-cli/types').Config} */ module.exports = { - accessKey: "", - localesDir: "src/app/i18n/locales", + accessKey: '', + localesDir: 'src/app/i18n/locales', namespaces: false, push: { - "flag-new": "provisional", - "tag-new": process.env.npm_package_version, - "delete-absent": false, - }, -} + 'flag-new': 'provisional', + 'tag-new': process.env.npm_package_version, + 'delete-absent': false + } +}; ``` -| Config key | CLI flag | Type | Description | -| ------ | ---- | ---- | ----------- | -| accessKey | `-a`, `--access-key ` | `string` | The API key of the Loco project you wish to sync to/from. You can find this in the Loco project under `Developer Tools โ€บ API Keys โ€บ Full Access Key` (if you do not intend to use `loco-cli push`, an `Export key` will work too). | -| localesDir | `-d`, `--locales-dir ` | `string` | The folder in which the JSON translation files are stored (defaults to current working dir). | -| namespaces | `-N`, `--namespaces` | `boolean` | Organize translations into namespaces (default: `false`). Set this flag to `true` when dividing translations into multiple files. The uploaded asset ID's will be prefixed with `:`. | -| push | - | `PushOptions` | Loco API options used for `loco-cli push`. (https://localise.biz/api/docs/import/import) | -| pull | - | `PullOptions` | Loco API options used for `loco-cli pull`. (https://localise.biz/api/docs/export/exportall) | +| Config key | CLI flag | Type | Description | +| ---------- | ---------------------------- | ------------- | ---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | +| accessKey | `-a`, `--access-key ` | `string` | The API key of the Loco project you wish to sync to/from. You can find this in the Loco project under `Developer Tools โ€บ API Keys โ€บ Full Access Key` (if you do not intend to use `loco-cli push`, an `Export key` will work too). | +| localesDir | `-d`, `--locales-dir ` | `string` | The folder in which the JSON translation files are stored (defaults to current working dir). | +| namespaces | `-N`, `--namespaces` | `boolean` | Organize translations into namespaces (default: `false`). Set this flag to `true` when dividing translations into multiple files. The uploaded asset ID's will be prefixed with `:`. | +| push | - | `PushOptions` | Loco API options used for `loco-cli push`. (https://localise.biz/api/docs/import/import) | +| pull | - | `PullOptions` | Loco API options used for `loco-cli pull`. (https://localise.biz/api/docs/export/exportall) |
PushOptions
- - `ignore-new`: Specify that new assets will NOT be added to the project. - - `ignore-existing`: Specify that existing assets encountered in the file will NOT be updated. - - `tag-new`: Tag any NEW assets added during the import with the given tags (comma separated). - - `tag-all`: Tag ALL assets in the file with the given tags (comma separated). - - `untag-all`: Remove existing tags from any assets matched in the imported file (comma separated). - - `tag-updated`: Tag existing assets that are MODIFIED by this import. - - `untag-updated`: Remove existing tags from assets that are MODIFIED during import. - - `tag-absent`: Tag existing assets in the project that are NOT found in the imported file. - - `untag-absent`: Remove existing tags from assets NOT found in the imported file. - - `delete-absent`: Permanently DELETES project assets NOT found in the file (use with extreme caution). - - `flag-new`: Set this flag on any NEW (non-empty) translations imported into the current locale. +- `ignore-new`: Specify that new assets will NOT be added to the project. +- `ignore-existing`: Specify that existing assets encountered in the file will NOT be updated. +- `tag-new`: Tag any NEW assets added during the import with the given tags (comma separated). +- `tag-all`: Tag ALL assets in the file with the given tags (comma separated). +- `untag-all`: Remove existing tags from any assets matched in the imported file (comma separated). +- `tag-updated`: Tag existing assets that are MODIFIED by this import. +- `untag-updated`: Remove existing tags from assets that are MODIFIED during import. +- `tag-absent`: Tag existing assets in the project that are NOT found in the imported file. +- `untag-absent`: Remove existing tags from assets NOT found in the imported file. +- `delete-absent`: Permanently DELETES project assets NOT found in the file (use with extreme caution). +- `flag-new`: Set this flag on any NEW (non-empty) translations imported into the current locale.
@@ -107,12 +107,12 @@ module.exports = {
- - `filter`: Filter assets by comma-separated tag names. Match any tag with `*` and negate tags by prefixing with `!`. - - `fallback`: Fallback locale for untranslated assets, specified as short code. e.g. en or en_GB. - - `order`: Export translations according to asset order. - - `status`: Export translations with a specific status or flag. Negate values by prefixing with !. e.g. "translated", or "!fuzzy". - - `charset`: Specify preferred character encoding. Alternative to Accept-Charset header but accepts a single value which must be valid. - - `breaks`: Force platform-specific line-endings. Default is Unix (LF) breaks. +- `filter`: Filter assets by comma-separated tag names. Match any tag with `*` and negate tags by prefixing with `!`. +- `fallback`: Fallback locale for untranslated assets, specified as short code. e.g. en or en_GB. +- `order`: Export translations according to asset order. +- `status`: Export translations with a specific status or flag. Negate values by prefixing with !. e.g. "translated", or "!fuzzy". +- `charset`: Specify preferred character encoding. Alternative to Accept-Charset header but accepts a single value which must be valid. +- `breaks`: Force platform-specific line-endings. Default is Unix (LF) breaks.
## Usage diff --git a/cli.ts b/cli.ts index de6a77e..8d40696 100755 --- a/cli.ts +++ b/cli.ts @@ -1,49 +1,45 @@ #!/usr/bin/env node -import { Command, Option } from "commander"; +import { Command, Option } from 'commander'; -import pull from "./src/commands/pull"; -import push from "./src/commands/push"; -import status from "./src/commands/status"; -import { version } from "./package.json"; -import { handleAsyncErrors } from "./src/util/handleAsyncErrors"; +import pull from './src/commands/pull'; +import push from './src/commands/push'; +import status from './src/commands/status'; +import { version } from './package.json'; +import { handleAsyncErrors } from './src/util/handleAsyncErrors'; -const program = new Command("loco-cli") +const program = new Command('loco-cli') .version(version) - .option("-a, --access-key ", "Loco API token") - .option( - "-d, --locales-dir ", - "The folder in which the translations are stored.", - "." - ) - .option("-N, --namespaces", "Organize translations into namespaces", false); + .option('-a, --access-key ', 'Loco API token') + .option('-d, --locales-dir ', 'The folder in which the translations are stored.', '.') + .option('-N, --namespaces', 'Organize translations into namespaces', false); program - .command("pull") - .option("-y, --yes", "Answer yes to all confirmation prompts", false) - .description("Fetch assets from Loco") + .command('pull') + .option('-y, --yes', 'Answer yes to all confirmation prompts', false) + .description('Fetch assets from Loco') .action(handleAsyncErrors(pull)); program - .command("push") + .command('push') .option( - "-t, --tag [tag]", - "The tag option is removed in v2, use the `push.tag-new` option in `loco.config.js` instead" + '-t, --tag [tag]', + 'The tag option is removed in v2, use the `push.tag-new` option in `loco.config.js` instead' ) .option( - "-s, --status [status]", - "The status option is removed in v2, use the `push.flag-new` option in `loco.config.js` instead" + '-s, --status [status]', + 'The status option is removed in v2, use the `push.flag-new` option in `loco.config.js` instead' ) - .option("-y, --yes", "Answer yes to all confirmation prompts", false) - .description("Upload assets to Loco") + .option('-y, --yes', 'Answer yes to all confirmation prompts', false) + .description('Upload assets to Loco') .action(handleAsyncErrors(push)); program - .command("status") + .command('status') .addOption( - new Option("--direction [direction]", "Direction to diff the assets IDs to") - .choices(["remote", "local", "both"]) - .default("both") + new Option('--direction [direction]', 'Direction to diff the assets IDs to') + .choices(['remote', 'local', 'both']) + .default('both') ) - .description("Check status of local file") + .description('Check status of local file') .action(handleAsyncErrors(status)); program.parse(process.argv); diff --git a/eslint.config.mjs b/eslint.config.mjs new file mode 100644 index 0000000..9bdc10d --- /dev/null +++ b/eslint.config.mjs @@ -0,0 +1,21 @@ +// @ts-check + +import eslint from "@eslint/js"; +import tseslint from "typescript-eslint"; +import prettierConfig from "eslint-config-prettier"; + +const ignoreConfig = { + ignores: ["node_modules/", "dist/", ".locorc.js"], +}; + +export default tseslint.config( + eslint.configs.recommended, + ...tseslint.configs.recommended, + ignoreConfig, + prettierConfig, + { + rules: { + "@typescript-eslint/no-explicit-any": "warn", + }, + }, +); diff --git a/package.json b/package.json index dd3f667..2df8cfd 100644 --- a/package.json +++ b/package.json @@ -17,9 +17,12 @@ "node": "14.x || 16.x || 18.x || 20.x" }, "scripts": { - "test": "vitest run", "build": "tsc", - "loco-cli": "yarn build && node ./dist/cli.js" + "format:check": "prettier --check .", + "format": "prettier --write .", + "lint": "eslint .", + "loco-cli": "yarn build && node ./dist/cli.js", + "test": "vitest run" }, "files": [ "dist", @@ -41,10 +44,16 @@ "isomorphic-unfetch": "^3.1.0" }, "devDependencies": { + "@eslint/js": "9.2.0", "@types/cli-progress": "3.11.0", "@types/inquirer": "8.2.1", "@types/node": "14.x", - "typescript": "4.9.4", + "eslint": "9.2.0", + "eslint-config-prettier": "9.1.0", + "eslint-plugin-prettier": "5.1.3", + "prettier": "3.2.5", + "typescript": "5.4.5", + "typescript-eslint": "7.8.0", "vitest": "0.26.1" } } diff --git a/src/commands/pull.ts b/src/commands/pull.ts index fd6d5fa..7f41e2e 100644 --- a/src/commands/pull.ts +++ b/src/commands/pull.ts @@ -1,13 +1,13 @@ -import { Command } from "commander"; -import { diff } from "../lib/diff"; -import { readFiles } from "../lib/readFiles"; -import { getGlobalOptions } from "../util/options"; -import { apiPull as apiPull } from "../lib/api"; -import inquirer from "inquirer"; -import chalk from "chalk"; -import { printDiff } from "../util/print"; -import { writeFiles } from "../lib/writeFiles"; -import { log } from "../util/logger"; +import { Command } from 'commander'; +import { diff } from '../lib/diff'; +import { readFiles } from '../lib/readFiles'; +import { getGlobalOptions } from '../util/options'; +import { apiPull as apiPull } from '../lib/api'; +import inquirer from 'inquirer'; +import chalk from 'chalk'; +import { printDiff } from '../util/print'; +import { writeFiles } from '../lib/writeFiles'; +import { log } from '../util/logger'; interface CommandOptions { yes?: boolean; @@ -21,7 +21,7 @@ const pull = async ({ yes }: CommandOptions, program: Command) => { const { added, updated, deleted, totalCount: count } = diff(local, remote); if (!count) { - log.success("Everything up to date!"); + log.success('Everything up to date!'); process.exit(0); } @@ -33,14 +33,14 @@ const pull = async ({ yes }: CommandOptions, program: Command) => { if (!yes) { const { confirm } = await inquirer.prompt([ { - type: "confirm", - name: "confirm", - message: "Continue?", - }, + type: 'confirm', + name: 'confirm', + message: 'Continue?' + } ]); if (!confirm) { - log.error("Nothing pulled"); + log.error('Nothing pulled'); process.exit(0); } } diff --git a/src/commands/push.ts b/src/commands/push.ts index 7101b8f..1925bad 100644 --- a/src/commands/push.ts +++ b/src/commands/push.ts @@ -1,14 +1,14 @@ -import chalk from "chalk"; -import { Command } from "commander"; -import inquirer from "inquirer"; -import cliProgress from "cli-progress"; -import { apiPull, apiPush } from "../lib/api"; -import { diff } from "../lib/diff"; -import { readFiles } from "../lib/readFiles"; -import { getGlobalOptions } from "../util/options"; -import { printDiff } from "../util/print"; -import { dotObject } from "../lib/dotObject"; -import { log } from "../util/logger"; +import chalk from 'chalk'; +import { Command } from 'commander'; +import inquirer from 'inquirer'; +import cliProgress from 'cli-progress'; +import { apiPull, apiPush } from '../lib/api'; +import { diff } from '../lib/diff'; +import { readFiles } from '../lib/readFiles'; +import { getGlobalOptions } from '../util/options'; +import { printDiff } from '../util/print'; +import { dotObject } from '../lib/dotObject'; +import { log } from '../util/logger'; interface CommandOptions { yes?: boolean; @@ -18,63 +18,70 @@ interface CommandOptions { const push = async ({ yes, status, tag }: CommandOptions, program: Command) => { if (status) { - log.warn("The status option is removed in v2, use the `push.flag-new` option in `loco.config.js` instead"); + log.warn( + 'The status option is removed in v2, use the `push.flag-new` option in `loco.config.js` instead' + ); } if (tag) { - log.warn("The tag option is removed in v2, use the `push.tag-new` option in `loco.config.js` instead"); + log.warn( + 'The tag option is removed in v2, use the `push.tag-new` option in `loco.config.js` instead' + ); } const options = await getGlobalOptions(program); const { accessKey, localesDir, namespaces, push: pushOptions, pull: pullOptions } = options; - const deleteAbsent = pushOptions?.["delete-absent"] ?? false; + const deleteAbsent = pushOptions?.['delete-absent'] ?? false; const local = await readFiles(localesDir, namespaces); const remote = await apiPull(accessKey, pullOptions); const { added, deleted, updated, totalCount, deletedCount } = diff(remote, local, pushOptions); if (!totalCount || (!deleteAbsent && totalCount === deletedCount)) { - log.info(`Pushing will not delete remote assets when the ${chalk.bold("delete-abscent")} flag is disabled`); - log.success("Everything up to date!"); + log.info( + `Pushing will not delete remote assets when the ${chalk.bold('delete-abscent')} flag is disabled` + ); + log.success('Everything up to date!'); process.exit(0); } log.log(` Pushing will have the following effect: ${printDiff({ - added, - updated, - deleted: deleteAbsent ? deleted : undefined, + added, + updated, + deleted: deleteAbsent ? deleted : undefined })} `); if (!yes) { - if (deletedCount) { if (deleteAbsent) { - log.warn(`${chalk.bold("delete-abscent")} enabled, proceed with caution!\n`); + log.warn(`${chalk.bold('delete-abscent')} enabled, proceed with caution!\n`); } else { - log.info(`Pushing will not delete remote assets when the ${chalk.bold("delete-abscent")} flag is disabled\n`); + log.info( + `Pushing will not delete remote assets when the ${chalk.bold('delete-abscent')} flag is disabled\n` + ); } } const { confirm } = await inquirer.prompt([ { - type: "confirm", - name: "confirm", - message: "Continue?", - }, + type: 'confirm', + name: 'confirm', + message: 'Continue?' + } ]); if (!confirm) { - log.error("Nothing pushed"); + log.error('Nothing pushed'); process.exit(0); } } const length = Object.keys(remote).length; const progressbar = new cliProgress.SingleBar({ - format: `Uploading in ${length} locales |${chalk.cyan("{bar}")}| {value}/{total}`, - barCompleteChar: "\u2588", - barIncompleteChar: "\u2591", - hideCursor: true, + format: `Uploading in ${length} locales |${chalk.cyan('{bar}')}| {value}/{total}`, + barCompleteChar: '\u2588', + barIncompleteChar: '\u2591', + hideCursor: true }); progressbar.start(length, 0); for (const [locale, translations] of Object.entries(local)) { @@ -86,9 +93,9 @@ const push = async ({ yes, status, tag }: CommandOptions, program: Command) => { log.log(); log.warn( - "Be kind to your translators, provide a note in the `Notes` field on Loco when there is not enough context." + 'Be kind to your translators, provide a note in the `Notes` field on Loco when there is not enough context.' ); - log.success("All done."); + log.success('All done.'); process.exit(0); }; diff --git a/src/commands/status.ts b/src/commands/status.ts index 8330e1a..51fe154 100644 --- a/src/commands/status.ts +++ b/src/commands/status.ts @@ -1,38 +1,28 @@ -import { Command } from "commander"; +import { Command } from 'commander'; -import { getGlobalOptions } from "../util/options"; -import { readFiles } from "../lib/readFiles"; -import { apiPull } from "../lib/api"; -import { diff } from "../lib/diff"; -import chalk from "chalk"; -import { printDiff } from "../util/print"; -import { log } from "../util/logger"; +import { getGlobalOptions } from '../util/options'; +import { readFiles } from '../lib/readFiles'; +import { apiPull } from '../lib/api'; +import { diff } from '../lib/diff'; +import chalk from 'chalk'; +import { printDiff } from '../util/print'; +import { log } from '../util/logger'; interface CommandOptions { - direction: "remote" | "local" | "both"; + direction: 'remote' | 'local' | 'both'; } const status = async ({ direction }: CommandOptions, program: Command) => { - const { - accessKey, - localesDir, - namespaces, - pull: pullOptions, - } = await getGlobalOptions(program); + const { accessKey, localesDir, namespaces, pull: pullOptions } = await getGlobalOptions(program); const local = await readFiles(localesDir, namespaces); const remote = await apiPull(accessKey, pullOptions); - const { - added, - deleted, - updated, - totalCount, - addedCount, - deletedCount, - updatedCount, - } = diff(remote, local); + const { added, deleted, updated, totalCount, addedCount, deletedCount, updatedCount } = diff( + remote, + local + ); if (!totalCount) { - log.success("Everything up to date!"); + log.success('Everything up to date!'); process.exit(0); } @@ -40,18 +30,16 @@ const status = async ({ direction }: CommandOptions, program: Command) => { log.log(); - if (["both", "remote"].includes(direction) && addedCount) { + if (['both', 'remote'].includes(direction) && addedCount) { isDirty = true; log.log( - `${chalk.bold( - addedCount - )} local assets are not present remote (fix with \`loco-cli push\`): + `${chalk.bold(addedCount)} local assets are not present remote (fix with \`loco-cli push\`): ${printDiff({ added })} ` ); } - if (["both", "local"].includes(direction) && updatedCount) { + if (['both', 'local'].includes(direction) && updatedCount) { isDirty = true; log.log( `${chalk.bold(updatedCount)} translations are different remotely: @@ -60,7 +48,7 @@ ${printDiff({ updated })} ); } - if (["both", "local"].includes(direction) && deletedCount) { + if (['both', 'local'].includes(direction) && deletedCount) { isDirty = true; log.log( `${chalk.bold( @@ -74,7 +62,7 @@ ${printDiff({ deleted })} if (isDirty) { process.exit(1); } else { - log.success("Everything up to date!"); + log.success('Everything up to date!'); process.exit(0); } }; diff --git a/src/lib/api.ts b/src/lib/api.ts index 08027d6..777a266 100644 --- a/src/lib/api.ts +++ b/src/lib/api.ts @@ -1,12 +1,7 @@ -import fetch from "isomorphic-unfetch"; -import { - ProjectLocale, - PullOptions, - PushOptions, - Translations, -} from "../../types"; +import fetch from 'isomorphic-unfetch'; +import { ProjectLocale, PullOptions, PushOptions, Translations } from '../../types'; -const BASE_URL = "https://localise.biz/api"; +const BASE_URL = 'https://localise.biz/api'; const fetchApi = async ( apiKey: string, @@ -21,8 +16,8 @@ const fetchApi = async ( ...fetchOptions, headers: { ...(fetchOptions?.headers || {}), - Authorization: `Loco ${apiKey}`, - }, + Authorization: `Loco ${apiKey}` + } }); if (!response.ok) { throw new Error(`HTTPError: ${response.status} ${response.statusText}`); @@ -32,12 +27,8 @@ const fetchApi = async ( }; export const apiPull = async (key: string, options: PullOptions = {}) => { - const translations = await fetchApi( - key, - "/export/all.json", - options - ); - const locales = await fetchApi(key, "/locales"); + const translations = await fetchApi(key, '/export/all.json', options); + const locales = await fetchApi(key, '/locales'); if (locales?.length === 1) { return { [locales[0].code]: translations }; } @@ -52,19 +43,19 @@ export const apiPush = ( ) => fetchApi( key, - "/import/json", + '/import/json', { locale, ...Object.keys(options).reduce( (acc, key) => ({ ...acc, - [key]: options[key as keyof PushOptions]?.toString(), + [key]: options[key as keyof PushOptions]?.toString() }), {} - ), + ) }, { - method: "POST", - body: JSON.stringify(translations), + method: 'POST', + body: JSON.stringify(translations) } ); diff --git a/src/lib/diff.ts b/src/lib/diff.ts index 337d844..199e490 100644 --- a/src/lib/diff.ts +++ b/src/lib/diff.ts @@ -1,6 +1,6 @@ -import { detailedDiff } from "deep-object-diff"; -import { PushOptions, Translations } from "../../types"; -import { dotObject } from "./dotObject"; +import { detailedDiff } from 'deep-object-diff'; +import { PushOptions, Translations } from '../../types'; +import { dotObject } from './dotObject'; interface DetailedDiff { added: object; @@ -8,17 +8,10 @@ interface DetailedDiff { deleted: object; } -export const diff = ( - local: Translations, - remote: Translations, - options?: PushOptions -) => { - const { added, updated, deleted } = detailedDiff( - local, - remote - ) as DetailedDiff; - const ignoreAdded = options?.["ignore-new"]; - const ignoreUpdated = options?.["ignore-existing"]; +export const diff = (local: Translations, remote: Translations, options?: PushOptions) => { + const { added, updated, deleted } = detailedDiff(local, remote) as DetailedDiff; + const ignoreAdded = options?.['ignore-new']; + const ignoreUpdated = options?.['ignore-existing']; const addedRes = ignoreAdded ? {} : dotObject(added); const updatedRes = ignoreUpdated ? {} : dotObject(updated); @@ -33,6 +26,6 @@ export const diff = ( updated: updatedRes, updatedCount: Object.keys(updatedRes).length, deleted: deletedRes, - deletedCount: Object.keys(deletedRes).length, + deletedCount: Object.keys(deletedRes).length }; }; diff --git a/src/lib/dotObject.ts b/src/lib/dotObject.ts index 859571c..85aa14d 100644 --- a/src/lib/dotObject.ts +++ b/src/lib/dotObject.ts @@ -8,7 +8,7 @@ export const dotObject = (obj: object): Record => { for (const key in obj) { const value = obj[key as keyof typeof obj]; const newKey = keyPrefix ? `${keyPrefix}.${key}` : key; - if (value && typeof value === "object") { + if (value && typeof value === 'object') { // it's a nested object, so do it again recurse(value, newKey); } else { diff --git a/src/lib/readFiles.ts b/src/lib/readFiles.ts index 2da3763..ecc3f67 100644 --- a/src/lib/readFiles.ts +++ b/src/lib/readFiles.ts @@ -1,8 +1,8 @@ -import { existsSync, readdirSync, statSync } from "fs"; -import { readFile } from "fs"; -import { join } from "path"; -import { Translations } from "../../types"; -import { log } from "../util/logger"; +import { existsSync, readdirSync, statSync } from 'fs'; +import { readFile } from 'fs'; +import { join } from 'path'; +import { Translations } from '../../types'; +import { log } from '../util/logger'; const readJSON = async (path: string) => { if (!existsSync(path)) { @@ -11,7 +11,7 @@ const readJSON = async (path: string) => { } return new Promise((resolve, reject) => { - readFile(path, "utf8", (err, data) => { + readFile(path, 'utf8', (err, data) => { if (err) { reject(err); } @@ -29,12 +29,12 @@ const readFilesInDir = async (path: string, separator?: string) => { const files = readdirSync(path); await Promise.all( - files.map(async (file) => { - if (file.endsWith(".json")) { + files.map(async file => { + if (file.endsWith('.json')) { const json = await readJSON(join(path, file)); - Object.keys(json).forEach((key) => { - // @ts-expect-error - res[`${file.replace(".json", "")}${separator}${key}`] = json[key]; + Object.keys(json).forEach(key => { + // @ts-expect-error Element implicitly has an any type because expression of type string can't be used to index type {}. + res[`${file.replace('.json', '')}${separator}${key}`] = json[key]; }); } }) @@ -42,10 +42,7 @@ const readFilesInDir = async (path: string, separator?: string) => { return res; }; -export const readFiles = async ( - dir: string, - useNamespaces: boolean -): Promise => { +export const readFiles = async (dir: string, useNamespaces: boolean): Promise => { if (!existsSync(dir)) { return {}; } @@ -55,19 +52,17 @@ export const readFiles = async ( return {}; } await Promise.all( - locales.map(async (locale) => { + locales.map(async locale => { const localeDir = join(dir, locale); if (useNamespaces) { // using namespaces; locales should be folders if (statSync(localeDir).isDirectory()) { - translations[locale] = await readFilesInDir(localeDir, ":"); + translations[locale] = await readFilesInDir(localeDir, ':'); } } else { // using namespaces; locales shoud be JSON files - if (locale.endsWith(".json")) { - translations[locale.replace(".json", "")] = await readJSON( - join(dir, locale) - ); + if (locale.endsWith('.json')) { + translations[locale.replace('.json', '')] = await readJSON(join(dir, locale)); } } }) diff --git a/src/lib/writeFiles.ts b/src/lib/writeFiles.ts index b998678..f114653 100644 --- a/src/lib/writeFiles.ts +++ b/src/lib/writeFiles.ts @@ -1,7 +1,7 @@ -import { mkdirSync, writeFileSync } from "fs"; -import { join } from "path"; -import { Config, Translations } from "../../types"; -import { splitIntoNamespaces } from "../util/namespaces"; +import { mkdirSync, writeFileSync } from 'fs'; +import { join } from 'path'; +import { Config, Translations } from '../../types'; +import { splitIntoNamespaces } from '../util/namespaces'; export const writeFiles = (translations: Translations, options: Config) => { const { localesDir, namespaces } = options; @@ -12,9 +12,7 @@ export const writeFiles = (translations: Translations, options: Config) => { mkdirSync(join(localesDir, language), { recursive: true }); const availableNamespaces = splitIntoNamespaces(assets); - for (const [namespace, scopedAssets] of Object.entries( - availableNamespaces - )) { + for (const [namespace, scopedAssets] of Object.entries(availableNamespaces)) { const filePath = join(localesDir, language, `${namespace}.json`); writeFileSync(filePath, JSON.stringify(scopedAssets, null, 2)); } diff --git a/src/util/config.ts b/src/util/config.ts index 75929da..8202bd9 100644 --- a/src/util/config.ts +++ b/src/util/config.ts @@ -1,7 +1,7 @@ -import { Config } from "../../types"; -import { cosmiconfig } from "cosmiconfig"; +import { Config } from '../../types'; +import { cosmiconfig } from 'cosmiconfig'; -const explorer = cosmiconfig("loco"); +const explorer = cosmiconfig('loco'); export const readConfig = async (): Promise => { const result = await explorer.search(); diff --git a/src/util/handleAsyncErrors.ts b/src/util/handleAsyncErrors.ts index 3648f88..b919bd7 100644 --- a/src/util/handleAsyncErrors.ts +++ b/src/util/handleAsyncErrors.ts @@ -1,20 +1,18 @@ -import chalk from "chalk"; +import chalk from 'chalk'; type Fun = (...args: any[]) => Promise; export const handleAsyncErrors = (fn: Fun) => { return (...args: any[]) => - fn(...args).catch((error) => { - if (error.message === "HTTPError: 401 Authorization Required") { + fn(...args).catch(error => { + if (error.message === 'HTTPError: 401 Authorization Required') { console.log( `\n${chalk.red( - "โœ— Invalid access key. Make sure to use a Full access key.\nSee https://localise.biz/help/developers/api-keys#writeable for more info.\n" + 'โœ— Invalid access key. Make sure to use a Full access key.\nSee https://localise.biz/help/developers/api-keys#writeable for more info.\n' )}` ); } else { - console.log( - chalk.red(`\nโœ— An unexpected error occurred:\n ${error.message}\n`) - ); + console.log(chalk.red(`\nโœ— An unexpected error occurred:\n ${error.message}\n`)); } }); }; diff --git a/src/util/logger.ts b/src/util/logger.ts index eb0c9fe..2831e81 100644 --- a/src/util/logger.ts +++ b/src/util/logger.ts @@ -1,11 +1,9 @@ -import chalk from "chalk"; +import chalk from 'chalk'; export const log = { log: console.log, info: (msg: string, ...args: any) => console.log(`๐Ÿ’ก ${msg}`, ...args), warn: (msg: string, ...args: any) => console.warn(`โš ๏ธ ${msg}`, ...args), - error: (msg: string, ...args: any) => - console.error(`${chalk.red("โœ—")} ${msg}`, ...args), - success: (msg: string, ...args: any) => - console.log(`${chalk.green("โœ”")} ${msg}`, ...args), + error: (msg: string, ...args: any) => console.error(`${chalk.red('โœ—')} ${msg}`, ...args), + success: (msg: string, ...args: any) => console.log(`${chalk.green('โœ”')} ${msg}`, ...args) }; diff --git a/src/util/namespaces.ts b/src/util/namespaces.ts index 9a2aa33..668ff06 100644 --- a/src/util/namespaces.ts +++ b/src/util/namespaces.ts @@ -1,6 +1,6 @@ export const splitIntoNamespaces = ( json: object, - { defaultNs = "default", separator = ":" } = {} + { defaultNs = 'default', separator = ':' } = {} ) => Object.entries(json).reduce>((acc, [key, value]) => { // Pull out the group name from the key @@ -13,7 +13,7 @@ export const splitIntoNamespaces = ( acc[namespace] = {}; } // Add the current entry to the result - // @ts-expect-error + // @ts-expect-error Element implicitly has an any type because expression of type string can't be used to index type {}. acc[namespace][assetKey] = value; return acc; }, {}); diff --git a/src/util/options.ts b/src/util/options.ts index bdd104a..2b137bb 100644 --- a/src/util/options.ts +++ b/src/util/options.ts @@ -1,11 +1,11 @@ -import { Command } from "commander"; -import type { Config } from "../../types"; -import { readConfig } from "./config"; -import { log } from "./logger"; +import { Command } from 'commander'; +import type { Config } from '../../types'; +import { readConfig } from './config'; +import { log } from './logger'; export const getGlobalOptions = async (program: Command): Promise => { if (!program.parent) { - log.error("Something went wrong. Sorry!"); + log.error('Something went wrong. Sorry!'); process.exit(1); } const cliOptions = program.parent.opts(); @@ -16,23 +16,23 @@ export const getGlobalOptions = async (program: Command): Promise => { if (!fileOptions.accessKey && !cliOptions.accessKey) { log.error( - "No personal access token found. Provide one with the `-a` option, or in the config file." + 'No personal access token found. Provide one with the `-a` option, or in the config file.' ); process.exit(1); } if (hasFileOptions) { - log.log("๐Ÿ” Reading from config file"); + log.log('๐Ÿ” Reading from config file'); } if (fileOptions.defaultLanguage) { log.warn( - "The `defaultLanguage` option is deprecated. Starting from v2, all languages are used." + 'The `defaultLanguage` option is deprecated. Starting from v2, all languages are used.' ); } // Note: merge deep when options will be nested return { ...cliOptions, - ...fileOptions, + ...fileOptions }; }; diff --git a/src/util/print.ts b/src/util/print.ts index 8c14b97..5e9e85f 100644 --- a/src/util/print.ts +++ b/src/util/print.ts @@ -1,46 +1,37 @@ -import chalk from "chalk"; -import { truncateString } from "./string"; +import chalk from 'chalk'; +import { truncateString } from './string'; export const printDiff = ({ added, updated, - deleted, + deleted }: { added?: Record; deleted?: Record; updated?: Record; }) => [ - printAssets( - added, - chalk.greenBright(chalk.dim(" added ") + chalk.bold("+")) - ), - printAssets( - updated, - chalk.yellowBright(chalk.dim("modified ") + chalk.bold("~")) - ), - printAssets(deleted, chalk.red(chalk.dim(" deleted ") + chalk.bold("-"))), + printAssets(added, chalk.greenBright(chalk.dim(' added ') + chalk.bold('+'))), + printAssets(updated, chalk.yellowBright(chalk.dim('modified ') + chalk.bold('~'))), + printAssets(deleted, chalk.red(chalk.dim(' deleted ') + chalk.bold('-'))) ] .filter(Boolean) - .join("\n"); + .join('\n'); -export const printAssets = ( - assets: Record | undefined, - prefix?: string -) => { +export const printAssets = (assets: Record | undefined, prefix?: string) => { const amount = assets ? Object.keys(assets).length : 0; if (!assets || amount < 1) { - return ""; + return ''; } const res = Object.entries(assets) .slice(0, 20) .map(([key, value]) => { - const [locale, ...asset] = key.split("."); + const [locale, ...asset] = key.split('.'); return `${prefix} ${chalk.dim(`(${locale})`)} ${chalk.bold( - asset.join(".") - )}${value ? chalk.cyan(` (${truncateString(value)})`) : ""}`; + asset.join('.') + )}${value ? chalk.cyan(` (${truncateString(value)})`) : ''}`; }) - .join("\n"); + .join('\n'); return amount > 20 ? `${res}\n...and ${chalk.bold(amount - 20)} more` : res; }; diff --git a/src/util/string.ts b/src/util/string.ts index b276d9e..073f62f 100644 --- a/src/util/string.ts +++ b/src/util/string.ts @@ -2,5 +2,5 @@ export function truncateString(str: string, num = 40) { if (str.length <= num) { return str; } - return str.slice(0, num) + "โ€ฆ"; + return str.slice(0, num) + 'โ€ฆ'; } diff --git a/test/diff.test.ts b/test/diff.test.ts index a0522b0..d199112 100644 --- a/test/diff.test.ts +++ b/test/diff.test.ts @@ -1,15 +1,15 @@ -import { expect, test } from "vitest"; -import { diff } from "../src/lib/diff"; -import { local, remote } from "./mockdata/mockDiff"; +import { expect, test } from 'vitest'; +import { diff } from '../src/lib/diff'; +import { local, remote } from './mockdata/mockDiff'; -test("returns diff", () => { +test('returns diff', () => { expect(diff(local, remote)).toMatchSnapshot(); }); -test("returns diff without new assets", () => { - expect(diff(local, remote, { "ignore-new": true })).toMatchSnapshot(); +test('returns diff without new assets', () => { + expect(diff(local, remote, { 'ignore-new': true })).toMatchSnapshot(); }); -test("returns diff without updated assets", () => { - expect(diff(local, remote, { "ignore-existing": true })).toMatchSnapshot(); +test('returns diff without updated assets', () => { + expect(diff(local, remote, { 'ignore-existing': true })).toMatchSnapshot(); }); diff --git a/test/dotObject.test.ts b/test/dotObject.test.ts index 4a3d126..3327061 100644 --- a/test/dotObject.test.ts +++ b/test/dotObject.test.ts @@ -1,12 +1,12 @@ -import { expect, test } from "vitest"; -import { dotObject } from "../src/lib/dotObject"; -import { local } from "./mockdata/mockDiff"; +import { expect, test } from 'vitest'; +import { dotObject } from '../src/lib/dotObject'; +import { local } from './mockdata/mockDiff'; -test("dotObject", () => { +test('dotObject', () => { expect(dotObject(local.en)).toStrictEqual({ - title: "Newly added key local in EN only", - "buttons.confirm": "Confirm", - "buttons.dismiss": "Dismiss", - "buttons.skip": "Newly added key deep local in EN only", + title: 'Newly added key local in EN only', + 'buttons.confirm': 'Confirm', + 'buttons.dismiss': 'Dismiss', + 'buttons.skip': 'Newly added key deep local in EN only' }); }); diff --git a/test/mockdata/mockDiff.ts b/test/mockdata/mockDiff.ts index 8746eb5..65e8aa4 100644 --- a/test/mockdata/mockDiff.ts +++ b/test/mockdata/mockDiff.ts @@ -1,45 +1,45 @@ export const local = { en: { - title: "Newly added key local in EN only", + title: 'Newly added key local in EN only', buttons: { - confirm: "Confirm", - dismiss: "Dismiss", - skip: "Newly added key deep local in EN only", - }, + confirm: 'Confirm', + dismiss: 'Dismiss', + skip: 'Newly added key deep local in EN only' + } }, fr: { buttons: { - confirm: "Confirmer", - dismiss: "Rejeter", - }, + confirm: 'Confirmer', + dismiss: 'Rejeter' + } }, es: { buttons: { - confirm: "Confirmar", - dismiss: "Despedir", - }, - }, + confirm: 'Confirmar', + dismiss: 'Despedir' + } + } }; export const remote = { en: { - body: "Newly added key remote in EN only", + body: 'Newly added key remote in EN only', buttons: { - confirm: "Different translation local/remote", - dismiss: "Dismiss", - accept: "Newly added key deep remote in EN only", - }, + confirm: 'Different translation local/remote', + dismiss: 'Dismiss', + accept: 'Newly added key deep remote in EN only' + } }, fr: { buttons: { - confirm: "Confirmer", - dismiss: "Rejeter", - }, + confirm: 'Confirmer', + dismiss: 'Rejeter' + } }, es: { buttons: { - confirm: "Confirmar", - dismiss: "Despedir", - }, - }, + confirm: 'Confirmar', + dismiss: 'Despedir' + } + } }; diff --git a/test/mockdata/namespaces/en/common.json b/test/mockdata/namespaces/en/common.json index 3ce46cf..957226d 100644 --- a/test/mockdata/namespaces/en/common.json +++ b/test/mockdata/namespaces/en/common.json @@ -3,4 +3,4 @@ "confirm": "Confirm", "dismiss": "Dismiss" } -} \ No newline at end of file +} diff --git a/test/mockdata/namespaces/en/home.json b/test/mockdata/namespaces/en/home.json index 83a3996..c94aae8 100644 --- a/test/mockdata/namespaces/en/home.json +++ b/test/mockdata/namespaces/en/home.json @@ -3,4 +3,4 @@ "title": "Welcome to the dummy data", "description": "It is used in the tests" } -} \ No newline at end of file +} diff --git a/test/mockdata/namespaces/es/common.json b/test/mockdata/namespaces/es/common.json index 31c2443..5cb2399 100644 --- a/test/mockdata/namespaces/es/common.json +++ b/test/mockdata/namespaces/es/common.json @@ -3,4 +3,4 @@ "confirm": "Confirmar", "dismiss": "Despedir" } -} \ No newline at end of file +} diff --git a/test/mockdata/namespaces/es/home.json b/test/mockdata/namespaces/es/home.json index 9f990e8..51322ee 100644 --- a/test/mockdata/namespaces/es/home.json +++ b/test/mockdata/namespaces/es/home.json @@ -3,4 +3,4 @@ "title": "Bienvenido a los datos ficticios", "description": "Se utiliza en las pruebas" } -} \ No newline at end of file +} diff --git a/test/mockdata/namespaces/nl/common.json b/test/mockdata/namespaces/nl/common.json index 8f02f48..fa402ab 100644 --- a/test/mockdata/namespaces/nl/common.json +++ b/test/mockdata/namespaces/nl/common.json @@ -3,4 +3,4 @@ "confirm": "Bevestigen", "dismiss": "Annuleren" } -} \ No newline at end of file +} diff --git a/test/mockdata/namespaces/nl/home.json b/test/mockdata/namespaces/nl/home.json index e5c4bdd..938bea9 100644 --- a/test/mockdata/namespaces/nl/home.json +++ b/test/mockdata/namespaces/nl/home.json @@ -3,4 +3,4 @@ "title": "Welkom in de dummy data", "description": "Ze wordt gebruikt bij de testen" } -} \ No newline at end of file +} diff --git a/test/mockdata/no-namespaces/en.json b/test/mockdata/no-namespaces/en.json index e8048bb..c333055 100644 --- a/test/mockdata/no-namespaces/en.json +++ b/test/mockdata/no-namespaces/en.json @@ -7,4 +7,4 @@ "title": "Welcome to the dummy data", "description": "It is used in the tests" } -} \ No newline at end of file +} diff --git a/test/mockdata/no-namespaces/es.json b/test/mockdata/no-namespaces/es.json index f6bb08e..cbf78db 100644 --- a/test/mockdata/no-namespaces/es.json +++ b/test/mockdata/no-namespaces/es.json @@ -7,4 +7,4 @@ "title": "Bienvenido a los datos ficticios", "description": "Se utiliza en las pruebas" } -} \ No newline at end of file +} diff --git a/test/mockdata/no-namespaces/nl.json b/test/mockdata/no-namespaces/nl.json index 332bb3f..95cb67e 100644 --- a/test/mockdata/no-namespaces/nl.json +++ b/test/mockdata/no-namespaces/nl.json @@ -7,4 +7,4 @@ "title": "Welkom in de dummy data", "description": "Ze wordt gebruikt bij de testen" } -} \ No newline at end of file +} diff --git a/test/namespaces.test.ts b/test/namespaces.test.ts index 936c87b..bc3fc75 100644 --- a/test/namespaces.test.ts +++ b/test/namespaces.test.ts @@ -1,27 +1,26 @@ -import { expect, test } from "vitest"; -import { splitIntoNamespaces } from "../src/util/namespaces"; +import { expect, test } from 'vitest'; +import { splitIntoNamespaces } from '../src/util/namespaces'; -test("splitIntoNamespaces", async () => { - test("splits keys with colons into namespaces", async () => { - - const input = splitIntoNamespaces({ - "default:key": "value", - "group:key-with-colon:": "Value with colon:", - "another:group:key": "Value: with colon", - }); +test('splitIntoNamespaces', async () => { + test('splits keys with colons into namespaces', async () => { + const input = splitIntoNamespaces({ + 'default:key': 'value', + 'group:key-with-colon:': 'Value with colon:', + 'another:group:key': 'Value: with colon' + }); - const expected = { - default: { - key: "value", - }, - group: { - "key-with-colon:": "Value with colon:", - }, - another: { - "group:key": "Value: with colon", - }, - }; + const expected = { + default: { + key: 'value' + }, + group: { + 'key-with-colon:': 'Value with colon:' + }, + another: { + 'group:key': 'Value: with colon' + } + }; - expect(input).toStrictEqual(expected); - }); + expect(input).toStrictEqual(expected); + }); }); diff --git a/test/readFiles.test.ts b/test/readFiles.test.ts index 136aeb8..d613a3f 100644 --- a/test/readFiles.test.ts +++ b/test/readFiles.test.ts @@ -1,12 +1,10 @@ -import { expect, test } from "vitest"; -import { readFiles } from "../src/lib/readFiles"; +import { expect, test } from 'vitest'; +import { readFiles } from '../src/lib/readFiles'; -test("readFiles without namespaces", async () => { - expect( - await readFiles("./test/mockdata/no-namespaces", false) - ).toMatchSnapshot(); +test('readFiles without namespaces', async () => { + expect(await readFiles('./test/mockdata/no-namespaces', false)).toMatchSnapshot(); }); -test("readFiles with namespaces", async () => { - expect(await readFiles("./test/mockdata/namespaces", true)).toMatchSnapshot(); +test('readFiles with namespaces', async () => { + expect(await readFiles('./test/mockdata/namespaces', true)).toMatchSnapshot(); }); diff --git a/types.d.ts b/types.d.ts index 9bc5a55..322d407 100644 --- a/types.d.ts +++ b/types.d.ts @@ -13,7 +13,7 @@ export interface PullOptions { * Export translations according to asset order. * @see https://localise.biz/api/docs/export/exportall#query */ - order?: "created" | "id"; + order?: 'created' | 'id'; /** * Export translations with a specific status or flag. Negate values by prefixing with !. e.g. "translated", or "!fuzzy". * @see https://localise.biz/api/docs/export/exportall#query @@ -28,7 +28,7 @@ export interface PullOptions { * Force platform-specific line-endings. Default is Unix (LF) breaks. * @see https://localise.biz/api/docs/export/exportall#query */ - breaks?: "Unix" | "DOS" | "Mac"; + breaks?: 'Unix' | 'DOS' | 'Mac'; } export interface PushOptions { @@ -36,57 +36,57 @@ export interface PushOptions { * Specify that new assets will NOT be added to the project. * @see https://localise.biz/api/docs/import/import#query */ - "ignore-new"?: boolean; + 'ignore-new'?: boolean; /** * Specify that existing assets encountered in the file will NOT be updated. * @see https://localise.biz/api/docs/import/import#query */ - "ignore-existing"?: boolean; + 'ignore-existing'?: boolean; /** * Tag any NEW assets added during the import with the given tags (comma separated). * @see https://localise.biz/api/docs/import/import#query */ - "tag-new"?: string; + 'tag-new'?: string; /** * Tag ALL assets in the file with the given tags (comma separated). * @see https://localise.biz/api/docs/import/import#query */ - "tag-all"?: string; + 'tag-all'?: string; /** * Remove existing tags from any assets matched in the imported file (comma separated). * @see https://localise.biz/api/docs/import/import#query */ - "untag-all"?: string; + 'untag-all'?: string; /** * Tag existing assets that are MODIFIED by this import. * @see https://localise.biz/api/docs/import/import#query */ - "tag-updated"?: string; + 'tag-updated'?: string; /** * Remove existing tags from assets that are MODIFIED during import. * @see https://localise.biz/api/docs/import/import#query */ - "untag-updated"?: string; + 'untag-updated'?: string; /** * Tag existing assets in the project that are NOT found in the imported file. * @see https://localise.biz/api/docs/import/import#query */ - "tag-absent"?: string; + 'tag-absent'?: string; /** * Remove existing tags from assets NOT found in the imported file. * @see https://localise.biz/api/docs/import/import#query */ - "untag-absent"?: string; + 'untag-absent'?: string; /** * Permanently DELETES project assets NOT found in the file (use with extreme caution). * @see https://localise.biz/api/docs/import/import#query */ - "delete-absent"?: boolean; + 'delete-absent'?: boolean; /** * Set this flag on any NEW (non-empty) translations imported into the current locale. * @see https://localise.biz/api/docs/import/import#query */ - "flag-new"?: string; + 'flag-new'?: string; } export interface Config { diff --git a/yarn.lock b/yarn.lock index 5e220e5..97588cd 100644 --- a/yarn.lock +++ b/yarn.lock @@ -133,6 +133,88 @@ resolved "https://registry.yarnpkg.com/@esbuild/win32-x64/-/win32-x64-0.16.10.tgz#0e9c6a5e69c10d96aff2386b7ee9646138c2a831" integrity sha512-qddWullt3sC1EIpfHvCRBq3H4g3L86DZpD6n8k2XFjFVyp01D++uNbN1hT/JRsHxTbyyemZcpwL5aRlJwc/zFw== +"@eslint-community/eslint-utils@^4.2.0", "@eslint-community/eslint-utils@^4.4.0": + version "4.4.0" + resolved "https://registry.yarnpkg.com/@eslint-community/eslint-utils/-/eslint-utils-4.4.0.tgz#a23514e8fb9af1269d5f7788aa556798d61c6b59" + integrity sha512-1/sA4dwrzBAyeUoQ6oxahHKmrZvsnLCg4RfxW3ZFGGmQkSNQPFNLV9CUEFQP1x9EYXHTo5p6xdhZM1Ne9p/AfA== + dependencies: + eslint-visitor-keys "^3.3.0" + +"@eslint-community/regexpp@^4.10.0", "@eslint-community/regexpp@^4.6.1": + version "4.10.0" + resolved "https://registry.yarnpkg.com/@eslint-community/regexpp/-/regexpp-4.10.0.tgz#548f6de556857c8bb73bbee70c35dc82a2e74d63" + integrity sha512-Cu96Sd2By9mCNTx2iyKOmq10v22jUVQv0lQnlGNy16oE9589yE+QADPbrMGCkA51cKZSg3Pu/aTJVTGfL/qjUA== + +"@eslint/eslintrc@^3.0.2": + version "3.0.2" + resolved "https://registry.yarnpkg.com/@eslint/eslintrc/-/eslintrc-3.0.2.tgz#36180f8e85bf34d2fe3ccc2261e8e204a411ab4e" + integrity sha512-wV19ZEGEMAC1eHgrS7UQPqsdEiCIbTKTasEfcXAigzoXICcqZSjBZEHlZwNVvKg6UBCjSlos84XiLqsRJnIcIg== + dependencies: + ajv "^6.12.4" + debug "^4.3.2" + espree "^10.0.1" + globals "^14.0.0" + ignore "^5.2.0" + import-fresh "^3.2.1" + js-yaml "^4.1.0" + minimatch "^3.1.2" + strip-json-comments "^3.1.1" + +"@eslint/js@9.2.0": + version "9.2.0" + resolved "https://registry.yarnpkg.com/@eslint/js/-/js-9.2.0.tgz#b0a9123e8e91a3d9a2eed3a04a6ed44fdab639aa" + integrity sha512-ESiIudvhoYni+MdsI8oD7skpprZ89qKocwRM2KEvhhBJ9nl5MRh7BXU5GTod7Mdygq+AUl+QzId6iWJKR/wABA== + +"@humanwhocodes/config-array@^0.13.0": + version "0.13.0" + resolved "https://registry.yarnpkg.com/@humanwhocodes/config-array/-/config-array-0.13.0.tgz#fb907624df3256d04b9aa2df50d7aa97ec648748" + integrity sha512-DZLEEqFWQFiyK6h5YIeynKx7JlvCYWL0cImfSRXZ9l4Sg2efkFGTuFf6vzXjK1cq6IYkU+Eg/JizXw+TD2vRNw== + dependencies: + "@humanwhocodes/object-schema" "^2.0.3" + debug "^4.3.1" + minimatch "^3.0.5" + +"@humanwhocodes/module-importer@^1.0.1": + version "1.0.1" + resolved "https://registry.yarnpkg.com/@humanwhocodes/module-importer/-/module-importer-1.0.1.tgz#af5b2691a22b44be847b0ca81641c5fb6ad0172c" + integrity sha512-bxveV4V8v5Yb4ncFTT3rPSgZBOpCkjfK0y4oVVVJwIuDVBRMDXrPyXRL988i5ap9m9bnyEEjWfm5WkBmtffLfA== + +"@humanwhocodes/object-schema@^2.0.3": + version "2.0.3" + resolved "https://registry.yarnpkg.com/@humanwhocodes/object-schema/-/object-schema-2.0.3.tgz#4a2868d75d6d6963e423bcf90b7fd1be343409d3" + integrity sha512-93zYdMES/c1D69yZiKDBj0V24vqNzB/koF26KPaagAfd3P/4gUlh3Dys5ogAK+Exi9QyzlD8x/08Zt7wIKcDcA== + +"@humanwhocodes/retry@^0.2.3": + version "0.2.4" + resolved "https://registry.yarnpkg.com/@humanwhocodes/retry/-/retry-0.2.4.tgz#4f3059423823bd8176132ceea9447dee101dfac1" + integrity sha512-Ttl/jHpxfS3st5sxwICYfk4pOH0WrLI1SpW283GgQL7sCWU7EHIOhX4b4fkIxr3tkfzwg8+FNojtzsIEE7Ecgg== + +"@nodelib/fs.scandir@2.1.5": + version "2.1.5" + resolved "https://registry.yarnpkg.com/@nodelib/fs.scandir/-/fs.scandir-2.1.5.tgz#7619c2eb21b25483f6d167548b4cfd5a7488c3d5" + integrity sha512-vq24Bq3ym5HEQm2NKCr3yXDwjc7vTsEThRDnkp2DK9p1uqLR+DHurm/NOTo0KG7HYHU7eppKZj3MyqYuMBf62g== + dependencies: + "@nodelib/fs.stat" "2.0.5" + run-parallel "^1.1.9" + +"@nodelib/fs.stat@2.0.5", "@nodelib/fs.stat@^2.0.2": + version "2.0.5" + resolved "https://registry.yarnpkg.com/@nodelib/fs.stat/-/fs.stat-2.0.5.tgz#5bd262af94e9d25bd1e71b05deed44876a222e8b" + integrity sha512-RkhPPp2zrqDAQA/2jNhnztcPAlv64XdhIp7a7454A5ovI7Bukxgt7MX7udwAu3zg1DcpPU0rz3VV1SeaqvY4+A== + +"@nodelib/fs.walk@^1.2.3", "@nodelib/fs.walk@^1.2.8": + version "1.2.8" + resolved "https://registry.yarnpkg.com/@nodelib/fs.walk/-/fs.walk-1.2.8.tgz#e95737e8bb6746ddedf69c556953494f196fe69a" + integrity sha512-oGB+UxlgWcgQkgwo8GcEGwemoTFt3FIO9ababBmaGwXIoBKZ+GTy0pP185beGg7Llih/NSHSV2XAs1lnznocSg== + dependencies: + "@nodelib/fs.scandir" "2.1.5" + fastq "^1.6.0" + +"@pkgr/core@^0.1.0": + version "0.1.1" + resolved "https://registry.yarnpkg.com/@pkgr/core/-/core-0.1.1.tgz#1ec17e2edbec25c8306d424ecfbf13c7de1aaa31" + integrity sha512-cq8o4cWH0ibXh9VGi5P20Tu9XF/0fFXl9EUinr9QfTM7a7p0oTA4iJRCQWppXR1Pg8dSM0UCItCkPwsk9qWWYA== + "@types/chai-subset@^1.3.3": version "1.3.3" resolved "https://registry.yarnpkg.com/@types/chai-subset/-/chai-subset-1.3.3.tgz#97893814e92abd2c534de422cb377e0e0bdaac94" @@ -165,6 +247,11 @@ "@types/through" "*" rxjs "^7.2.0" +"@types/json-schema@^7.0.15": + version "7.0.15" + resolved "https://registry.yarnpkg.com/@types/json-schema/-/json-schema-7.0.15.tgz#596a1747233694d50f6ad8a7869fcb6f56cf5841" + integrity sha512-5+fP8P8MFNC+AyZCDxrB2pkZFPGzqQWUzpSeuuVLvm8VMcorNYavBqoFcxK8bQz4Qsbn4oUEEem4wDLfcysGHA== + "@types/node@*": version "16.11.11" resolved "https://registry.yarnpkg.com/@types/node/-/node-16.11.11.tgz#6ea7342dfb379ea1210835bada87b3c512120234" @@ -175,6 +262,11 @@ resolved "https://registry.yarnpkg.com/@types/node/-/node-14.18.35.tgz#879c4659cb7b3fe515844f029c75079c941bb65c" integrity sha512-2ATO8pfhG1kDvw4Lc4C0GXIMSQFFJBCo/R1fSgTwmUlq5oy95LXyjDQinsRVgQY6gp6ghh3H91wk9ES5/5C+Tw== +"@types/semver@^7.5.8": + version "7.5.8" + resolved "https://registry.yarnpkg.com/@types/semver/-/semver-7.5.8.tgz#8268a8c57a3e4abd25c165ecd36237db7948a55e" + integrity sha512-I8EUhyrgfLrcTkzV3TSsGyl1tSuPrEDzr0yd5m90UgNxQkyDXULk3b6MlQqTCpZpNtWe1K0hzclnZkTcLBe2UQ== + "@types/through@*": version "0.0.30" resolved "https://registry.yarnpkg.com/@types/through/-/through-0.0.30.tgz#e0e42ce77e897bd6aead6f6ea62aeb135b8a3895" @@ -182,16 +274,122 @@ dependencies: "@types/node" "*" +"@typescript-eslint/eslint-plugin@7.8.0": + version "7.8.0" + resolved "https://registry.yarnpkg.com/@typescript-eslint/eslint-plugin/-/eslint-plugin-7.8.0.tgz#c78e309fe967cb4de05b85cdc876fb95f8e01b6f" + integrity sha512-gFTT+ezJmkwutUPmB0skOj3GZJtlEGnlssems4AjkVweUPGj7jRwwqg0Hhg7++kPGJqKtTYx+R05Ftww372aIg== + dependencies: + "@eslint-community/regexpp" "^4.10.0" + "@typescript-eslint/scope-manager" "7.8.0" + "@typescript-eslint/type-utils" "7.8.0" + "@typescript-eslint/utils" "7.8.0" + "@typescript-eslint/visitor-keys" "7.8.0" + debug "^4.3.4" + graphemer "^1.4.0" + ignore "^5.3.1" + natural-compare "^1.4.0" + semver "^7.6.0" + ts-api-utils "^1.3.0" + +"@typescript-eslint/parser@7.8.0": + version "7.8.0" + resolved "https://registry.yarnpkg.com/@typescript-eslint/parser/-/parser-7.8.0.tgz#1e1db30c8ab832caffee5f37e677dbcb9357ddc8" + integrity sha512-KgKQly1pv0l4ltcftP59uQZCi4HUYswCLbTqVZEJu7uLX8CTLyswqMLqLN+2QFz4jCptqWVV4SB7vdxcH2+0kQ== + dependencies: + "@typescript-eslint/scope-manager" "7.8.0" + "@typescript-eslint/types" "7.8.0" + "@typescript-eslint/typescript-estree" "7.8.0" + "@typescript-eslint/visitor-keys" "7.8.0" + debug "^4.3.4" + +"@typescript-eslint/scope-manager@7.8.0": + version "7.8.0" + resolved "https://registry.yarnpkg.com/@typescript-eslint/scope-manager/-/scope-manager-7.8.0.tgz#bb19096d11ec6b87fb6640d921df19b813e02047" + integrity sha512-viEmZ1LmwsGcnr85gIq+FCYI7nO90DVbE37/ll51hjv9aG+YZMb4WDE2fyWpUR4O/UrhGRpYXK/XajcGTk2B8g== + dependencies: + "@typescript-eslint/types" "7.8.0" + "@typescript-eslint/visitor-keys" "7.8.0" + +"@typescript-eslint/type-utils@7.8.0": + version "7.8.0" + resolved "https://registry.yarnpkg.com/@typescript-eslint/type-utils/-/type-utils-7.8.0.tgz#9de166f182a6e4d1c5da76e94880e91831e3e26f" + integrity sha512-H70R3AefQDQpz9mGv13Uhi121FNMh+WEaRqcXTX09YEDky21km4dV1ZXJIp8QjXc4ZaVkXVdohvWDzbnbHDS+A== + dependencies: + "@typescript-eslint/typescript-estree" "7.8.0" + "@typescript-eslint/utils" "7.8.0" + debug "^4.3.4" + ts-api-utils "^1.3.0" + +"@typescript-eslint/types@7.8.0": + version "7.8.0" + resolved "https://registry.yarnpkg.com/@typescript-eslint/types/-/types-7.8.0.tgz#1fd2577b3ad883b769546e2d1ef379f929a7091d" + integrity sha512-wf0peJ+ZGlcH+2ZS23aJbOv+ztjeeP8uQ9GgwMJGVLx/Nj9CJt17GWgWWoSmoRVKAX2X+7fzEnAjxdvK2gqCLw== + +"@typescript-eslint/typescript-estree@7.8.0": + version "7.8.0" + resolved "https://registry.yarnpkg.com/@typescript-eslint/typescript-estree/-/typescript-estree-7.8.0.tgz#b028a9226860b66e623c1ee55cc2464b95d2987c" + integrity sha512-5pfUCOwK5yjPaJQNy44prjCwtr981dO8Qo9J9PwYXZ0MosgAbfEMB008dJ5sNo3+/BN6ytBPuSvXUg9SAqB0dg== + dependencies: + "@typescript-eslint/types" "7.8.0" + "@typescript-eslint/visitor-keys" "7.8.0" + debug "^4.3.4" + globby "^11.1.0" + is-glob "^4.0.3" + minimatch "^9.0.4" + semver "^7.6.0" + ts-api-utils "^1.3.0" + +"@typescript-eslint/utils@7.8.0": + version "7.8.0" + resolved "https://registry.yarnpkg.com/@typescript-eslint/utils/-/utils-7.8.0.tgz#57a79f9c0c0740ead2f622e444cfaeeb9fd047cd" + integrity sha512-L0yFqOCflVqXxiZyXrDr80lnahQfSOfc9ELAAZ75sqicqp2i36kEZZGuUymHNFoYOqxRT05up760b4iGsl02nQ== + dependencies: + "@eslint-community/eslint-utils" "^4.4.0" + "@types/json-schema" "^7.0.15" + "@types/semver" "^7.5.8" + "@typescript-eslint/scope-manager" "7.8.0" + "@typescript-eslint/types" "7.8.0" + "@typescript-eslint/typescript-estree" "7.8.0" + semver "^7.6.0" + +"@typescript-eslint/visitor-keys@7.8.0": + version "7.8.0" + resolved "https://registry.yarnpkg.com/@typescript-eslint/visitor-keys/-/visitor-keys-7.8.0.tgz#7285aab991da8bee411a42edbd5db760d22fdd91" + integrity sha512-q4/gibTNBQNA0lGyYQCmWRS5D15n8rXh4QjK3KV+MBPlTYHpfBUT3D3PaPR/HeNiI9W6R7FvlkcGhNyAoP+caA== + dependencies: + "@typescript-eslint/types" "7.8.0" + eslint-visitor-keys "^3.4.3" + +acorn-jsx@^5.3.2: + version "5.3.2" + resolved "https://registry.yarnpkg.com/acorn-jsx/-/acorn-jsx-5.3.2.tgz#7ed5bb55908b3b2f1bc55c6af1653bada7f07937" + integrity sha512-rq9s+JNhf0IChjtDXxllJ7g41oZk5SlXtp0LHwyA5cejwn7vKmKp4pPri6YEePv2PU65sAsegbXtIinmDFDXgQ== + acorn-walk@^8.2.0: version "8.2.0" resolved "https://registry.yarnpkg.com/acorn-walk/-/acorn-walk-8.2.0.tgz#741210f2e2426454508853a2f44d0ab83b7f69c1" integrity sha512-k+iyHEuPgSw6SbuDpGQM+06HQUa04DZ3o+F6CSzXMvvI5KMvnaEqXe+YVe555R9nn6GPt404fos4wcgpw12SDA== +acorn@^8.11.3: + version "8.11.3" + resolved "https://registry.yarnpkg.com/acorn/-/acorn-8.11.3.tgz#71e0b14e13a4ec160724b38fb7b0f233b1b81d7a" + integrity sha512-Y9rRfJG5jcKOE0CLisYbojUjIrIEE7AGMzA/Sm4BslANhbS+cDMpgBdcPT91oJ7OuJ9hYJBx59RjbhxVnrF8Xg== + acorn@^8.8.1: version "8.8.1" resolved "https://registry.yarnpkg.com/acorn/-/acorn-8.8.1.tgz#0a3f9cbecc4ec3bea6f0a80b66ae8dd2da250b73" integrity sha512-7zFpHzhnqYKrkYdUjF1HI1bzd0VygEGX8lFk4k5zVMqHEoES+P+7TKI+EvLO9WVMJ8eekdO0aDEK044xTXwPPA== +ajv@^6.12.4: + version "6.12.6" + resolved "https://registry.yarnpkg.com/ajv/-/ajv-6.12.6.tgz#baf5a62e802b07d977034586f8c3baf5adf26df4" + integrity sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g== + dependencies: + fast-deep-equal "^3.1.1" + fast-json-stable-stringify "^2.0.0" + json-schema-traverse "^0.4.1" + uri-js "^4.2.2" + ansi-escapes@^4.2.1: version "4.3.2" resolved "https://registry.yarnpkg.com/ansi-escapes/-/ansi-escapes-4.3.2.tgz#6b2291d1db7d98b6521d5f1efa42d0f3a9feb65e" @@ -223,11 +421,21 @@ argparse@^2.0.1: resolved "https://registry.yarnpkg.com/argparse/-/argparse-2.0.1.tgz#246f50f3ca78a3240f6c997e8a9bd1eac49e4b38" integrity sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q== +array-union@^2.1.0: + version "2.1.0" + resolved "https://registry.yarnpkg.com/array-union/-/array-union-2.1.0.tgz#b798420adbeb1de828d84acd8a2e23d3efe85e8d" + integrity sha512-HGyxoOTYUyCM6stUe6EJgnd4EoewAI7zMdfqO+kGjnlZmBDz/cR5pf8r/cR4Wq60sL/p0IkcjUEEPwS3GFrIyw== + assertion-error@^1.1.0: version "1.1.0" resolved "https://registry.yarnpkg.com/assertion-error/-/assertion-error-1.1.0.tgz#e60b6b0e8f301bd97e5375215bda406c85118c0b" integrity sha512-jgsaNduz+ndvGyFt3uSuWqvy4lCnIJiovtouQN5JZHOKCS2QuhEdbcQHFhVksz2N2U9hXJo8odG7ETyWlEeuDw== +balanced-match@^1.0.0: + version "1.0.2" + resolved "https://registry.yarnpkg.com/balanced-match/-/balanced-match-1.0.2.tgz#e83e3a7e3f300b34cb9d87f615fa0cbf357690ee" + integrity sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw== + base64-js@^1.3.1: version "1.5.1" resolved "https://registry.yarnpkg.com/base64-js/-/base64-js-1.5.1.tgz#1b1b440160a5bf7ad40b650f095963481903930a" @@ -242,6 +450,28 @@ bl@^4.1.0: inherits "^2.0.4" readable-stream "^3.4.0" +brace-expansion@^1.1.7: + version "1.1.11" + resolved "https://registry.yarnpkg.com/brace-expansion/-/brace-expansion-1.1.11.tgz#3c7fcbf529d87226f3d2f52b966ff5271eb441dd" + integrity sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA== + dependencies: + balanced-match "^1.0.0" + concat-map "0.0.1" + +brace-expansion@^2.0.1: + version "2.0.1" + resolved "https://registry.yarnpkg.com/brace-expansion/-/brace-expansion-2.0.1.tgz#1edc459e0f0c548486ecf9fc99f2221364b9a0ae" + integrity sha512-XnAIvQ8eM+kC6aULx6wuQiwVsnzsi9d3WxzV3FpWTGA19F621kwdbsAcFKXgKUHZWsy+mY6iL1sHTxWEFCytDA== + dependencies: + balanced-match "^1.0.0" + +braces@^3.0.2: + version "3.0.2" + resolved "https://registry.yarnpkg.com/braces/-/braces-3.0.2.tgz#3454e1a462ee8d599e236df336cd9ea4f8afe107" + integrity sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A== + dependencies: + fill-range "^7.0.1" + buffer-from@^1.0.0: version "1.1.2" resolved "https://registry.yarnpkg.com/buffer-from/-/buffer-from-1.1.2.tgz#2b146a6fd72e80b4f55d255f35ed59a3a9a41bd5" @@ -282,7 +512,7 @@ chalk@^2.0.0: escape-string-regexp "^1.0.5" supports-color "^5.3.0" -chalk@^4.1.0, chalk@^4.1.1, chalk@^4.1.2: +chalk@^4.0.0, chalk@^4.1.0, chalk@^4.1.1, chalk@^4.1.2: version "4.1.2" resolved "https://registry.yarnpkg.com/chalk/-/chalk-4.1.2.tgz#aac4e2b7734a740867aeb16bf02aad556a1e7a01" integrity sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA== @@ -358,6 +588,11 @@ commander@^9.4.1: resolved "https://registry.yarnpkg.com/commander/-/commander-9.4.1.tgz#d1dd8f2ce6faf93147295c0df13c7c21141cfbdd" integrity sha512-5EEkTNyHNGFPD2H+c/dXXfQZYa/scCKasxWcXJaWnNJ99pnQN9Vnmqow+p+PlFPE63Q6mThaZws1T+HxfpgtPw== +concat-map@0.0.1: + version "0.0.1" + resolved "https://registry.yarnpkg.com/concat-map/-/concat-map-0.0.1.tgz#d8a96bd77fd68df7793a73036a3ba0d5405d477b" + integrity sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg== + cosmiconfig@^8.0.0: version "8.0.0" resolved "https://registry.yarnpkg.com/cosmiconfig/-/cosmiconfig-8.0.0.tgz#e9feae014eab580f858f8a0288f38997a7bebe97" @@ -368,7 +603,16 @@ cosmiconfig@^8.0.0: parse-json "^5.0.0" path-type "^4.0.0" -debug@^4.3.4: +cross-spawn@^7.0.2: + version "7.0.3" + resolved "https://registry.yarnpkg.com/cross-spawn/-/cross-spawn-7.0.3.tgz#f73a85b9d5d41d045551c177e2882d4ac85728a6" + integrity sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w== + dependencies: + path-key "^3.1.0" + shebang-command "^2.0.0" + which "^2.0.1" + +debug@^4.3.1, debug@^4.3.2, debug@^4.3.4: version "4.3.4" resolved "https://registry.yarnpkg.com/debug/-/debug-4.3.4.tgz#1319f6579357f2338d3337d2cdd4914bb5dcc865" integrity sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ== @@ -382,6 +626,11 @@ deep-eql@^4.1.2: dependencies: type-detect "^4.0.0" +deep-is@^0.1.3: + version "0.1.4" + resolved "https://registry.yarnpkg.com/deep-is/-/deep-is-0.1.4.tgz#a6f2dce612fadd2ef1f519b73551f17e85199831" + integrity sha512-oIPzksmTg4/MriiaYGO+okXDT7ztn/w3Eptv/+gSIdMdKsJo0u4CfYNFJPy+4SKMuCqGw2wxnA+URMg3t8a/bQ== + deep-object-diff@^1.1.9: version "1.1.9" resolved "https://registry.yarnpkg.com/deep-object-diff/-/deep-object-diff-1.1.9.tgz#6df7ef035ad6a0caa44479c536ed7b02570f4595" @@ -394,6 +643,13 @@ defaults@^1.0.3: dependencies: clone "^1.0.2" +dir-glob@^3.0.1: + version "3.0.1" + resolved "https://registry.yarnpkg.com/dir-glob/-/dir-glob-3.0.1.tgz#56dbf73d992a4a93ba1584f4534063fd2e41717f" + integrity sha512-WkrWp9GR4KXfKGYzOLmTuGVi1UWFfws377n9cc55/tb6DuqyF6pcQ5AbiHEshaDpY9v6oaSr2XCDidGmMwdzIA== + dependencies: + path-type "^4.0.0" + emoji-regex@^8.0.0: version "8.0.0" resolved "https://registry.yarnpkg.com/emoji-regex/-/emoji-regex-8.0.0.tgz#e818fd69ce5ccfcb404594f842963bf53164cc37" @@ -439,6 +695,115 @@ escape-string-regexp@^1.0.5: resolved "https://registry.yarnpkg.com/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz#1b61c0562190a8dff6ae3bb2cf0200ca130b86d4" integrity sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ= +escape-string-regexp@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz#14ba83a5d373e3d311e5afca29cf5bfad965bf34" + integrity sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA== + +eslint-config-prettier@9.1.0: + version "9.1.0" + resolved "https://registry.yarnpkg.com/eslint-config-prettier/-/eslint-config-prettier-9.1.0.tgz#31af3d94578645966c082fcb71a5846d3c94867f" + integrity sha512-NSWl5BFQWEPi1j4TjVNItzYV7dZXZ+wP6I6ZhrBGpChQhZRUaElihE9uRRkcbRnNb76UMKDF3r+WTmNcGPKsqw== + +eslint-plugin-prettier@5.1.3: + version "5.1.3" + resolved "https://registry.yarnpkg.com/eslint-plugin-prettier/-/eslint-plugin-prettier-5.1.3.tgz#17cfade9e732cef32b5f5be53bd4e07afd8e67e1" + integrity sha512-C9GCVAs4Eq7ZC/XFQHITLiHJxQngdtraXaM+LoUFoFp/lHNl2Zn8f3WQbe9HvTBBQ9YnKFB0/2Ajdqwo5D1EAw== + dependencies: + prettier-linter-helpers "^1.0.0" + synckit "^0.8.6" + +eslint-scope@^8.0.1: + version "8.0.1" + resolved "https://registry.yarnpkg.com/eslint-scope/-/eslint-scope-8.0.1.tgz#a9601e4b81a0b9171657c343fb13111688963cfc" + integrity sha512-pL8XjgP4ZOmmwfFE8mEhSxA7ZY4C+LWyqjQ3o4yWkkmD0qcMT9kkW3zWHOczhWcjTSgqycYAgwSlXvZltv65og== + dependencies: + esrecurse "^4.3.0" + estraverse "^5.2.0" + +eslint-visitor-keys@^3.3.0, eslint-visitor-keys@^3.4.3: + version "3.4.3" + resolved "https://registry.yarnpkg.com/eslint-visitor-keys/-/eslint-visitor-keys-3.4.3.tgz#0cd72fe8550e3c2eae156a96a4dddcd1c8ac5800" + integrity sha512-wpc+LXeiyiisxPlEkUzU6svyS1frIO3Mgxj1fdy7Pm8Ygzguax2N3Fa/D/ag1WqbOprdI+uY6wMUl8/a2G+iag== + +eslint-visitor-keys@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/eslint-visitor-keys/-/eslint-visitor-keys-4.0.0.tgz#e3adc021aa038a2a8e0b2f8b0ce8f66b9483b1fb" + integrity sha512-OtIRv/2GyiF6o/d8K7MYKKbXrOUBIK6SfkIRM4Z0dY3w+LiQ0vy3F57m0Z71bjbyeiWFiHJ8brqnmE6H6/jEuw== + +eslint@9.2.0: + version "9.2.0" + resolved "https://registry.yarnpkg.com/eslint/-/eslint-9.2.0.tgz#0700ebc99528753315d78090876911d3cdbf19fe" + integrity sha512-0n/I88vZpCOzO+PQpt0lbsqmn9AsnsJAQseIqhZFI8ibQT0U1AkEKRxA3EVMos0BoHSXDQvCXY25TUjB5tr8Og== + dependencies: + "@eslint-community/eslint-utils" "^4.2.0" + "@eslint-community/regexpp" "^4.6.1" + "@eslint/eslintrc" "^3.0.2" + "@eslint/js" "9.2.0" + "@humanwhocodes/config-array" "^0.13.0" + "@humanwhocodes/module-importer" "^1.0.1" + "@humanwhocodes/retry" "^0.2.3" + "@nodelib/fs.walk" "^1.2.8" + ajv "^6.12.4" + chalk "^4.0.0" + cross-spawn "^7.0.2" + debug "^4.3.2" + escape-string-regexp "^4.0.0" + eslint-scope "^8.0.1" + eslint-visitor-keys "^4.0.0" + espree "^10.0.1" + esquery "^1.4.2" + esutils "^2.0.2" + fast-deep-equal "^3.1.3" + file-entry-cache "^8.0.0" + find-up "^5.0.0" + glob-parent "^6.0.2" + ignore "^5.2.0" + imurmurhash "^0.1.4" + is-glob "^4.0.0" + is-path-inside "^3.0.3" + json-stable-stringify-without-jsonify "^1.0.1" + levn "^0.4.1" + lodash.merge "^4.6.2" + minimatch "^3.1.2" + natural-compare "^1.4.0" + optionator "^0.9.3" + strip-ansi "^6.0.1" + text-table "^0.2.0" + +espree@^10.0.1: + version "10.0.1" + resolved "https://registry.yarnpkg.com/espree/-/espree-10.0.1.tgz#600e60404157412751ba4a6f3a2ee1a42433139f" + integrity sha512-MWkrWZbJsL2UwnjxTX3gG8FneachS/Mwg7tdGXce011sJd5b0JG54vat5KHnfSBODZ3Wvzd2WnjxyzsRoVv+ww== + dependencies: + acorn "^8.11.3" + acorn-jsx "^5.3.2" + eslint-visitor-keys "^4.0.0" + +esquery@^1.4.2: + version "1.5.0" + resolved "https://registry.yarnpkg.com/esquery/-/esquery-1.5.0.tgz#6ce17738de8577694edd7361c57182ac8cb0db0b" + integrity sha512-YQLXUplAwJgCydQ78IMJywZCceoqk1oH01OERdSAJc/7U2AylwjhSCLDEtqwg811idIS/9fIU5GjG73IgjKMVg== + dependencies: + estraverse "^5.1.0" + +esrecurse@^4.3.0: + version "4.3.0" + resolved "https://registry.yarnpkg.com/esrecurse/-/esrecurse-4.3.0.tgz#7ad7964d679abb28bee72cec63758b1c5d2c9921" + integrity sha512-KmfKL3b6G+RXvP8N1vr3Tq1kL/oCFgn2NYXEtqP8/L3pKapUA4G8cFVaoF3SU323CD4XypR/ffioHmkti6/Tag== + dependencies: + estraverse "^5.2.0" + +estraverse@^5.1.0, estraverse@^5.2.0: + version "5.3.0" + resolved "https://registry.yarnpkg.com/estraverse/-/estraverse-5.3.0.tgz#2eea5290702f26ab8fe5370370ff86c965d21123" + integrity sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA== + +esutils@^2.0.2: + version "2.0.3" + resolved "https://registry.yarnpkg.com/esutils/-/esutils-2.0.3.tgz#74d2eb4de0b8da1293711910d50775b9b710ef64" + integrity sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g== + external-editor@^3.0.3: version "3.1.0" resolved "https://registry.yarnpkg.com/external-editor/-/external-editor-3.1.0.tgz#cb03f740befae03ea4d283caed2741a83f335495" @@ -448,6 +813,44 @@ external-editor@^3.0.3: iconv-lite "^0.4.24" tmp "^0.0.33" +fast-deep-equal@^3.1.1, fast-deep-equal@^3.1.3: + version "3.1.3" + resolved "https://registry.yarnpkg.com/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz#3a7d56b559d6cbc3eb512325244e619a65c6c525" + integrity sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q== + +fast-diff@^1.1.2: + version "1.3.0" + resolved "https://registry.yarnpkg.com/fast-diff/-/fast-diff-1.3.0.tgz#ece407fa550a64d638536cd727e129c61616e0f0" + integrity sha512-VxPP4NqbUjj6MaAOafWeUn2cXWLcCtljklUtZf0Ind4XQ+QPtmA0b18zZy0jIQx+ExRVCR/ZQpBmik5lXshNsw== + +fast-glob@^3.2.9: + version "3.3.2" + resolved "https://registry.yarnpkg.com/fast-glob/-/fast-glob-3.3.2.tgz#a904501e57cfdd2ffcded45e99a54fef55e46129" + integrity sha512-oX2ruAFQwf/Orj8m737Y5adxDQO0LAB7/S5MnxCdTNDd4p6BsyIVsv9JQsATbTSq8KHRpLwIHbVlUNatxd+1Ow== + dependencies: + "@nodelib/fs.stat" "^2.0.2" + "@nodelib/fs.walk" "^1.2.3" + glob-parent "^5.1.2" + merge2 "^1.3.0" + micromatch "^4.0.4" + +fast-json-stable-stringify@^2.0.0: + version "2.1.0" + resolved "https://registry.yarnpkg.com/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz#874bf69c6f404c2b5d99c481341399fd55892633" + integrity sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw== + +fast-levenshtein@^2.0.6: + version "2.0.6" + resolved "https://registry.yarnpkg.com/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz#3d8a5c66883a16a30ca8643e851f19baa7797917" + integrity sha512-DCXu6Ifhqcks7TZKY3Hxp3y6qphY5SJZmrWMDrKcERSOXWQdMhU9Ig/PYrzyw/ul9jOIyh0N4M0tbC5hodg8dw== + +fastq@^1.6.0: + version "1.17.1" + resolved "https://registry.yarnpkg.com/fastq/-/fastq-1.17.1.tgz#2a523f07a4e7b1e81a42b91b8bf2254107753b47" + integrity sha512-sRVD3lWVIXWg6By68ZN7vho9a1pQcN/WBFaAAsDDFzlJjvoGx0P8z7V1t72grFJfJhu3YPZBuu25f7Kaw2jN1w== + dependencies: + reusify "^1.0.4" + figures@^3.0.0: version "3.2.0" resolved "https://registry.yarnpkg.com/figures/-/figures-3.2.0.tgz#625c18bd293c604dc4a8ddb2febf0c88341746af" @@ -455,6 +858,41 @@ figures@^3.0.0: dependencies: escape-string-regexp "^1.0.5" +file-entry-cache@^8.0.0: + version "8.0.0" + resolved "https://registry.yarnpkg.com/file-entry-cache/-/file-entry-cache-8.0.0.tgz#7787bddcf1131bffb92636c69457bbc0edd6d81f" + integrity sha512-XXTUwCvisa5oacNGRP9SfNtYBNAMi+RPwBFmblZEF7N7swHYQS6/Zfk7SRwx4D5j3CH211YNRco1DEMNVfZCnQ== + dependencies: + flat-cache "^4.0.0" + +fill-range@^7.0.1: + version "7.0.1" + resolved "https://registry.yarnpkg.com/fill-range/-/fill-range-7.0.1.tgz#1919a6a7c75fe38b2c7c77e5198535da9acdda40" + integrity sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ== + dependencies: + to-regex-range "^5.0.1" + +find-up@^5.0.0: + version "5.0.0" + resolved "https://registry.yarnpkg.com/find-up/-/find-up-5.0.0.tgz#4c92819ecb7083561e4f4a240a86be5198f536fc" + integrity sha512-78/PXT1wlLLDgTzDs7sjq9hzz0vXD+zn+7wypEe4fXQxCmdmqfGsEPQxmiCSQI3ajFV91bVSsvNtrJRiW6nGng== + dependencies: + locate-path "^6.0.0" + path-exists "^4.0.0" + +flat-cache@^4.0.0: + version "4.0.1" + resolved "https://registry.yarnpkg.com/flat-cache/-/flat-cache-4.0.1.tgz#0ece39fcb14ee012f4b0410bd33dd9c1f011127c" + integrity sha512-f7ccFPK3SXFHpx15UIGyRJ/FJQctuKZ0zVuN3frBo4HnK3cay9VEW0R6yPYFHC0AgqhukPzKjq22t5DmAyqGyw== + dependencies: + flatted "^3.2.9" + keyv "^4.5.4" + +flatted@^3.2.9: + version "3.3.1" + resolved "https://registry.yarnpkg.com/flatted/-/flatted-3.3.1.tgz#21db470729a6734d4997002f439cb308987f567a" + integrity sha512-X8cqMLLie7KsNUDSdzeN8FYK9rEt4Dt67OsG/DNGnYTSDBG4uFAJFBnUeiV+zCVAvwFy56IjM9sH51jVaEhNxw== + fsevents@~2.3.2: version "2.3.2" resolved "https://registry.yarnpkg.com/fsevents/-/fsevents-2.3.2.tgz#8a526f78b8fdf4623b709e0b975c52c24c02fd1a" @@ -470,6 +908,42 @@ get-func-name@^2.0.0: resolved "https://registry.yarnpkg.com/get-func-name/-/get-func-name-2.0.0.tgz#ead774abee72e20409433a066366023dd6887a41" integrity sha512-Hm0ixYtaSZ/V7C8FJrtZIuBBI+iSgL+1Aq82zSu8VQNB4S3Gk8e7Qs3VwBDJAhmRZcFqkl3tQu36g/Foh5I5ig== +glob-parent@^5.1.2: + version "5.1.2" + resolved "https://registry.yarnpkg.com/glob-parent/-/glob-parent-5.1.2.tgz#869832c58034fe68a4093c17dc15e8340d8401c4" + integrity sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow== + dependencies: + is-glob "^4.0.1" + +glob-parent@^6.0.2: + version "6.0.2" + resolved "https://registry.yarnpkg.com/glob-parent/-/glob-parent-6.0.2.tgz#6d237d99083950c79290f24c7642a3de9a28f9e3" + integrity sha512-XxwI8EOhVQgWp6iDL+3b0r86f4d6AX6zSU55HfB4ydCEuXLXc5FcYeOu+nnGftS4TEju/11rt4KJPTMgbfmv4A== + dependencies: + is-glob "^4.0.3" + +globals@^14.0.0: + version "14.0.0" + resolved "https://registry.yarnpkg.com/globals/-/globals-14.0.0.tgz#898d7413c29babcf6bafe56fcadded858ada724e" + integrity sha512-oahGvuMGQlPw/ivIYBjVSrWAfWLBeku5tpPE2fOPLi+WHffIWbuh2tCjhyQhTBPMf5E9jDEH4FOmTYgYwbKwtQ== + +globby@^11.1.0: + version "11.1.0" + resolved "https://registry.yarnpkg.com/globby/-/globby-11.1.0.tgz#bd4be98bb042f83d796f7e3811991fbe82a0d34b" + integrity sha512-jhIXaOzy1sb8IyocaruWSn1TjmnBVs8Ayhcy83rmxNJ8q2uWKCAj3CnJY+KpGSXCueAPc0i05kVvVKtP1t9S3g== + dependencies: + array-union "^2.1.0" + dir-glob "^3.0.1" + fast-glob "^3.2.9" + ignore "^5.2.0" + merge2 "^1.4.1" + slash "^3.0.0" + +graphemer@^1.4.0: + version "1.4.0" + resolved "https://registry.yarnpkg.com/graphemer/-/graphemer-1.4.0.tgz#fb2f1d55e0e3a1849aeffc90c4fa0dd53a0e66c6" + integrity sha512-EtKwoO6kxCL9WO5xipiHTZlSzBm7WLT627TqC/uVRd0HKmq8NXyebnNYxDoBi7wt8eTWrUrKXCOVaFq9x1kgag== + has-flag@^3.0.0: version "3.0.0" resolved "https://registry.yarnpkg.com/has-flag/-/has-flag-3.0.0.tgz#b5d454dc2199ae225699f3467e5a07f3b955bafd" @@ -499,6 +973,11 @@ ieee754@^1.1.13: resolved "https://registry.yarnpkg.com/ieee754/-/ieee754-1.2.1.tgz#8eb7a10a63fff25d15a57b001586d177d1b0d352" integrity sha512-dcyqhDvX1C46lXZcVqCpK+FtMRQVdIMN6/Df5js2zouUsqG7I6sFxitIC+7KYK29KdXOLHdu9zL4sFnoVQnqaA== +ignore@^5.2.0, ignore@^5.3.1: + version "5.3.1" + resolved "https://registry.yarnpkg.com/ignore/-/ignore-5.3.1.tgz#5073e554cd42c5b33b394375f538b8593e34d4ef" + integrity sha512-5Fytz/IraMjqpwfd34ke28PTVMjZjJG2MPn5t7OE4eUCUNf8BAa7b5WUS9/Qvr6mwOQS7Mk6vdsMno5he+T8Xw== + import-fresh@^3.2.1: version "3.3.0" resolved "https://registry.yarnpkg.com/import-fresh/-/import-fresh-3.3.0.tgz#37162c25fcb9ebaa2e6e53d5b4d88ce17d9e0c2b" @@ -507,6 +986,11 @@ import-fresh@^3.2.1: parent-module "^1.0.0" resolve-from "^4.0.0" +imurmurhash@^0.1.4: + version "0.1.4" + resolved "https://registry.yarnpkg.com/imurmurhash/-/imurmurhash-0.1.4.tgz#9218b9b2b928a238b13dc4fb6b6d576f231453ea" + integrity sha512-JmXMZ6wuvDmLiHEml9ykzqO6lwFbof0GG4IkcGaENdCRDDmMVnny7s5HsIgHCbaq0w2MyPhDqkhTUgS2LU2PHA== + inherits@^2.0.3, inherits@^2.0.4: version "2.0.4" resolved "https://registry.yarnpkg.com/inherits/-/inherits-2.0.4.tgz#0fa2c64f932917c3433a0ded55363aae37416b7c" @@ -545,21 +1029,48 @@ is-core-module@^2.9.0: dependencies: has "^1.0.3" +is-extglob@^2.1.1: + version "2.1.1" + resolved "https://registry.yarnpkg.com/is-extglob/-/is-extglob-2.1.1.tgz#a88c02535791f02ed37c76a1b9ea9773c833f8c2" + integrity sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ== + is-fullwidth-code-point@^3.0.0: version "3.0.0" resolved "https://registry.yarnpkg.com/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz#f116f8064fe90b3f7844a38997c0b75051269f1d" integrity sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg== +is-glob@^4.0.0, is-glob@^4.0.1, is-glob@^4.0.3: + version "4.0.3" + resolved "https://registry.yarnpkg.com/is-glob/-/is-glob-4.0.3.tgz#64f61e42cbbb2eec2071a9dac0b28ba1e65d5084" + integrity sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg== + dependencies: + is-extglob "^2.1.1" + is-interactive@^1.0.0: version "1.0.0" resolved "https://registry.yarnpkg.com/is-interactive/-/is-interactive-1.0.0.tgz#cea6e6ae5c870a7b0a0004070b7b587e0252912e" integrity sha512-2HvIEKRoqS62guEC+qBjpvRubdX910WCMuJTZ+I9yvqKU2/12eSL549HMwtabb4oupdj2sMP50k+XJfB/8JE6w== +is-number@^7.0.0: + version "7.0.0" + resolved "https://registry.yarnpkg.com/is-number/-/is-number-7.0.0.tgz#7535345b896734d5f80c4d06c50955527a14f12b" + integrity sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng== + +is-path-inside@^3.0.3: + version "3.0.3" + resolved "https://registry.yarnpkg.com/is-path-inside/-/is-path-inside-3.0.3.tgz#d231362e53a07ff2b0e0ea7fed049161ffd16283" + integrity sha512-Fd4gABb+ycGAmKou8eMftCupSir5lRxqf4aD/vd0cD2qc4HL07OjCeuHMr8Ro4CoMaeCKDB0/ECBOVWjTwUvPQ== + is-unicode-supported@^0.1.0: version "0.1.0" resolved "https://registry.yarnpkg.com/is-unicode-supported/-/is-unicode-supported-0.1.0.tgz#3f26c76a809593b52bfa2ecb5710ed2779b522a7" integrity sha512-knxG2q4UC3u8stRGyAVJCOdxFmv5DZiRcdlIaAQXAbSfJya+OhopNotLQrstBhququ4ZpuKbDc/8S6mgXgPFPw== +isexe@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/isexe/-/isexe-2.0.0.tgz#e8fbf374dc556ff8947a10dcb0572d633f2cfa10" + integrity sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw== + isomorphic-unfetch@^3.1.0: version "3.1.0" resolved "https://registry.yarnpkg.com/isomorphic-unfetch/-/isomorphic-unfetch-3.1.0.tgz#87341d5f4f7b63843d468438128cb087b7c3e98f" @@ -580,16 +1091,46 @@ js-yaml@^4.1.0: dependencies: argparse "^2.0.1" +json-buffer@3.0.1: + version "3.0.1" + resolved "https://registry.yarnpkg.com/json-buffer/-/json-buffer-3.0.1.tgz#9338802a30d3b6605fbe0613e094008ca8c05a13" + integrity sha512-4bV5BfR2mqfQTJm+V5tPPdf+ZpuhiIvTuAB5g8kcrXOZpTT/QwwVRWBywX1ozr6lEuPdbHxwaJlm9G6mI2sfSQ== + json-parse-even-better-errors@^2.3.0: version "2.3.1" resolved "https://registry.yarnpkg.com/json-parse-even-better-errors/-/json-parse-even-better-errors-2.3.1.tgz#7c47805a94319928e05777405dc12e1f7a4ee02d" integrity sha512-xyFwyhro/JEof6Ghe2iz2NcXoj2sloNsWr/XsERDK/oiPCfaNhl5ONfp+jQdAZRQQ0IJWNzH9zIZF7li91kh2w== +json-schema-traverse@^0.4.1: + version "0.4.1" + resolved "https://registry.yarnpkg.com/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz#69f6a87d9513ab8bb8fe63bdb0979c448e684660" + integrity sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg== + +json-stable-stringify-without-jsonify@^1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz#9db7b59496ad3f3cfef30a75142d2d930ad72651" + integrity sha512-Bdboy+l7tA3OGW6FjyFHWkP5LuByj1Tk33Ljyq0axyzdk9//JSi2u3fP1QSmd1KNwq6VOKYGlAu87CisVir6Pw== + jsonc-parser@^3.2.0: version "3.2.0" resolved "https://registry.yarnpkg.com/jsonc-parser/-/jsonc-parser-3.2.0.tgz#31ff3f4c2b9793f89c67212627c51c6394f88e76" integrity sha512-gfFQZrcTc8CnKXp6Y4/CBT3fTc0OVuDofpre4aEeEpSBPV5X5v4+Vmx+8snU7RLPrNHPKSgLxGo9YuQzz20o+w== +keyv@^4.5.4: + version "4.5.4" + resolved "https://registry.yarnpkg.com/keyv/-/keyv-4.5.4.tgz#a879a99e29452f942439f2a405e3af8b31d4de93" + integrity sha512-oxVHkHR/EJf2CNXnWxRLW6mg7JyCCUcG0DtEGmL2ctUo1PNTin1PUil+r/+4r5MpVgC/fn1kjsx7mjSujKqIpw== + dependencies: + json-buffer "3.0.1" + +levn@^0.4.1: + version "0.4.1" + resolved "https://registry.yarnpkg.com/levn/-/levn-0.4.1.tgz#ae4562c007473b932a6200d403268dd2fffc6ade" + integrity sha512-+bT2uH4E5LGE7h/n3evcS/sQlJXCpIp6ym8OWJ5eV6+67Dsql/LaaT7qJBAt2rzfoa/5QBGBhxDix1dMt2kQKQ== + dependencies: + prelude-ls "^1.2.1" + type-check "~0.4.0" + lines-and-columns@^1.1.6: version "1.2.4" resolved "https://registry.yarnpkg.com/lines-and-columns/-/lines-and-columns-1.2.4.tgz#eca284f75d2965079309dc0ad9255abb2ebc1632" @@ -600,6 +1141,18 @@ local-pkg@^0.4.2: resolved "https://registry.yarnpkg.com/local-pkg/-/local-pkg-0.4.2.tgz#13107310b77e74a0e513147a131a2ba288176c2f" integrity sha512-mlERgSPrbxU3BP4qBqAvvwlgW4MTg78iwJdGGnv7kibKjWcJksrG3t6LB5lXI93wXRDvG4NpUgJFmTG4T6rdrg== +locate-path@^6.0.0: + version "6.0.0" + resolved "https://registry.yarnpkg.com/locate-path/-/locate-path-6.0.0.tgz#55321eb309febbc59c4801d931a72452a681d286" + integrity sha512-iPZK6eYjbxRu3uB4/WZ3EsEIMJFMqAoopl3R+zuq0UjcAm/MO6KCweDgPfP3elTztoKP3KtnVHxTn2NHBSDVUw== + dependencies: + p-locate "^5.0.0" + +lodash.merge@^4.6.2: + version "4.6.2" + resolved "https://registry.yarnpkg.com/lodash.merge/-/lodash.merge-4.6.2.tgz#558aa53b43b661e1925a0afdfa36a9a1085fe57a" + integrity sha512-0KpjqXRVvrYyCsX1swR/XTK0va6VQkQM6MNo7PqW77ByjAhoARA8EfrP1N4+KlKj8YS0ZUCtRT/YUuhyYDujIQ== + lodash@^4.17.21: version "4.17.21" resolved "https://registry.yarnpkg.com/lodash/-/lodash-4.17.21.tgz#679591c564c3bffaae8454cf0b3df370c3d6911c" @@ -620,11 +1173,45 @@ loupe@^2.3.1: dependencies: get-func-name "^2.0.0" +lru-cache@^6.0.0: + version "6.0.0" + resolved "https://registry.yarnpkg.com/lru-cache/-/lru-cache-6.0.0.tgz#6d6fe6570ebd96aaf90fcad1dafa3b2566db3a94" + integrity sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA== + dependencies: + yallist "^4.0.0" + +merge2@^1.3.0, merge2@^1.4.1: + version "1.4.1" + resolved "https://registry.yarnpkg.com/merge2/-/merge2-1.4.1.tgz#4368892f885e907455a6fd7dc55c0c9d404990ae" + integrity sha512-8q7VEgMJW4J8tcfVPy8g09NcQwZdbwFEqhe/WZkoIzjn/3TGDwtOCYtXGxA3O8tPzpczCCDgv+P2P5y00ZJOOg== + +micromatch@^4.0.4: + version "4.0.5" + resolved "https://registry.yarnpkg.com/micromatch/-/micromatch-4.0.5.tgz#bc8999a7cbbf77cdc89f132f6e467051b49090c6" + integrity sha512-DMy+ERcEW2q8Z2Po+WNXuw3c5YaUSFjAO5GsJqfEl7UjvtIuFKO6ZrKvcItdy98dwFI2N1tg3zNIdKaQT+aNdA== + dependencies: + braces "^3.0.2" + picomatch "^2.3.1" + mimic-fn@^2.1.0: version "2.1.0" resolved "https://registry.yarnpkg.com/mimic-fn/-/mimic-fn-2.1.0.tgz#7ed2c2ccccaf84d3ffcb7a69b57711fc2083401b" integrity sha512-OqbOk5oEQeAZ8WXWydlu9HJjz9WVdEIvamMCcXmuqUYjTknH/sqsWvhQ3vgwKFRR1HpjvNBKQ37nbJgYzGqGcg== +minimatch@^3.0.5, minimatch@^3.1.2: + version "3.1.2" + resolved "https://registry.yarnpkg.com/minimatch/-/minimatch-3.1.2.tgz#19cd194bfd3e428f049a70817c038d89ab4be35b" + integrity sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw== + dependencies: + brace-expansion "^1.1.7" + +minimatch@^9.0.4: + version "9.0.4" + resolved "https://registry.yarnpkg.com/minimatch/-/minimatch-9.0.4.tgz#8e49c731d1749cbec05050ee5145147b32496a51" + integrity sha512-KqWh+VchfxcMNRAJjj2tnsSJdNbHsVgnkBhTNrW7AjVo6OvLtxw8zfT9oLw1JSohlFzJ8jCoTgaoXvJ+kHt6fw== + dependencies: + brace-expansion "^2.0.1" + mlly@^1.0.0: version "1.0.0" resolved "https://registry.yarnpkg.com/mlly/-/mlly-1.0.0.tgz#d38ca6e33ab89b60654f71ef08931d51e83d3569" @@ -650,6 +1237,11 @@ nanoid@^3.3.4: resolved "https://registry.yarnpkg.com/nanoid/-/nanoid-3.3.4.tgz#730b67e3cd09e2deacf03c027c81c9d9dbc5e8ab" integrity sha512-MqBkQh/OHTS2egovRtLk45wEyNXwF+cokD+1YPf9u5VfJiRdAiRwB2froX5Co9Rh20xs4siNPm8naNotSD6RBw== +natural-compare@^1.4.0: + version "1.4.0" + resolved "https://registry.yarnpkg.com/natural-compare/-/natural-compare-1.4.0.tgz#4abebfeed7541f2c27acfb29bdbbd15c8d5ba4f7" + integrity sha512-OWND8ei3VtNC9h7V60qff3SVobHr996CTwgxubgyQYEpg290h9J0buyECNNJexkFm5sOajh5G116RYA1c8ZMSw== + node-fetch@^2.6.1: version "2.6.7" resolved "https://registry.yarnpkg.com/node-fetch/-/node-fetch-2.6.7.tgz#24de9fba827e3b4ae44dc8b20256a379160052ad" @@ -664,6 +1256,18 @@ onetime@^5.1.0: dependencies: mimic-fn "^2.1.0" +optionator@^0.9.3: + version "0.9.4" + resolved "https://registry.yarnpkg.com/optionator/-/optionator-0.9.4.tgz#7ea1c1a5d91d764fb282139c88fe11e182a3a734" + integrity sha512-6IpQ7mKUxRcZNLIObR0hz7lxsapSSIYNZJwXPGeF0mTVqGKFIXj1DQcMoT22S3ROcLyY/rz0PWaWZ9ayWmad9g== + dependencies: + deep-is "^0.1.3" + fast-levenshtein "^2.0.6" + levn "^0.4.1" + prelude-ls "^1.2.1" + type-check "^0.4.0" + word-wrap "^1.2.5" + ora@^5.4.1: version "5.4.1" resolved "https://registry.yarnpkg.com/ora/-/ora-5.4.1.tgz#1b2678426af4ac4a509008e5e4ac9e9959db9e18" @@ -684,6 +1288,20 @@ os-tmpdir@~1.0.2: resolved "https://registry.yarnpkg.com/os-tmpdir/-/os-tmpdir-1.0.2.tgz#bbe67406c79aa85c5cfec766fe5734555dfa1274" integrity sha1-u+Z0BseaqFxc/sdm/lc0VV36EnQ= +p-limit@^3.0.2: + version "3.1.0" + resolved "https://registry.yarnpkg.com/p-limit/-/p-limit-3.1.0.tgz#e1daccbe78d0d1388ca18c64fea38e3e57e3706b" + integrity sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ== + dependencies: + yocto-queue "^0.1.0" + +p-locate@^5.0.0: + version "5.0.0" + resolved "https://registry.yarnpkg.com/p-locate/-/p-locate-5.0.0.tgz#83c8315c6785005e3bd021839411c9e110e6d834" + integrity sha512-LaNjtRWUBY++zB5nE/NwcaoMylSPk+S+ZHNB1TzdbMJMny6dynpAGt7X/tl/QYq3TIeE6nxHppbo2LGymrG5Pw== + dependencies: + p-limit "^3.0.2" + parent-module@^1.0.0: version "1.0.1" resolved "https://registry.yarnpkg.com/parent-module/-/parent-module-1.0.1.tgz#691d2709e78c79fae3a156622452d00762caaaa2" @@ -701,6 +1319,16 @@ parse-json@^5.0.0: json-parse-even-better-errors "^2.3.0" lines-and-columns "^1.1.6" +path-exists@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/path-exists/-/path-exists-4.0.0.tgz#513bdbe2d3b95d7762e8c1137efa195c6c61b5b3" + integrity sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w== + +path-key@^3.1.0: + version "3.1.1" + resolved "https://registry.yarnpkg.com/path-key/-/path-key-3.1.1.tgz#581f6ade658cbba65a0d3380de7753295054f375" + integrity sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q== + path-parse@^1.0.7: version "1.0.7" resolved "https://registry.yarnpkg.com/path-parse/-/path-parse-1.0.7.tgz#fbc114b60ca42b30d9daf5858e4bd68bbedb6735" @@ -731,6 +1359,11 @@ picocolors@^1.0.0: resolved "https://registry.yarnpkg.com/picocolors/-/picocolors-1.0.0.tgz#cb5bdc74ff3f51892236eaf79d68bc44564ab81c" integrity sha512-1fygroTLlHu66zi26VoTDv8yRgm0Fccecssto+MhsZ0D/DGW2sm8E8AjW7NU5VVTRt5GxbeZ5qBuJr+HyLYkjQ== +picomatch@^2.3.1: + version "2.3.1" + resolved "https://registry.yarnpkg.com/picomatch/-/picomatch-2.3.1.tgz#3ba3833733646d9d3e4995946c1365a67fb07a42" + integrity sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA== + pkg-types@^1.0.0: version "1.0.1" resolved "https://registry.yarnpkg.com/pkg-types/-/pkg-types-1.0.1.tgz#25234407f9dc63409af45ced9407625ff446a761" @@ -749,6 +1382,33 @@ postcss@^8.4.20: picocolors "^1.0.0" source-map-js "^1.0.2" +prelude-ls@^1.2.1: + version "1.2.1" + resolved "https://registry.yarnpkg.com/prelude-ls/-/prelude-ls-1.2.1.tgz#debc6489d7a6e6b0e7611888cec880337d316396" + integrity sha512-vkcDPrRZo1QZLbn5RLGPpg/WmIQ65qoWWhcGKf/b5eplkkarX0m9z8ppCat4mlOqUsWpyNuYgO3VRyrYHSzX5g== + +prettier-linter-helpers@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/prettier-linter-helpers/-/prettier-linter-helpers-1.0.0.tgz#d23d41fe1375646de2d0104d3454a3008802cf7b" + integrity sha512-GbK2cP9nraSSUF9N2XwUwqfzlAFlMNYYl+ShE/V+H8a9uNl/oUqB1w2EL54Jh0OlyRSd8RfWYJ3coVS4TROP2w== + dependencies: + fast-diff "^1.1.2" + +prettier@3.2.5: + version "3.2.5" + resolved "https://registry.yarnpkg.com/prettier/-/prettier-3.2.5.tgz#e52bc3090586e824964a8813b09aba6233b28368" + integrity sha512-3/GWa9aOC0YeD7LUfvOG2NiDyhOWRvt1k+rcKhOuYnMY24iiCphgneUfJDyFXd6rZCAnuLBv6UeAULtrhT/F4A== + +punycode@^2.1.0: + version "2.3.1" + resolved "https://registry.yarnpkg.com/punycode/-/punycode-2.3.1.tgz#027422e2faec0b25e1549c3e1bd8309b9133b6e5" + integrity sha512-vYt7UD1U9Wg6138shLtLOvdAu+8DsC/ilFtEVHcH+wydcSpNE20AfSOduf6MkRFahL5FY7X1oU7nKVZFtfq8Fg== + +queue-microtask@^1.2.2: + version "1.2.3" + resolved "https://registry.yarnpkg.com/queue-microtask/-/queue-microtask-1.2.3.tgz#4929228bbc724dfac43e0efb058caf7b6cfb6243" + integrity sha512-NuaNSa6flKT5JaSYQzJok04JzTL1CA6aGhv5rfLW3PgqA+M2ChpZQnAC8h8i4ZFkBS8X5RqkDBHA7r4hej3K9A== + readable-stream@^3.4.0: version "3.6.0" resolved "https://registry.yarnpkg.com/readable-stream/-/readable-stream-3.6.0.tgz#337bbda3adc0706bd3e024426a286d4b4b2c9198" @@ -780,6 +1440,11 @@ restore-cursor@^3.1.0: onetime "^5.1.0" signal-exit "^3.0.2" +reusify@^1.0.4: + version "1.0.4" + resolved "https://registry.yarnpkg.com/reusify/-/reusify-1.0.4.tgz#90da382b1e126efc02146e90845a88db12925d76" + integrity sha512-U9nH88a3fc/ekCF1l0/UP1IosiuIjyTh7hBvXVMHYgVcfGvt897Xguj2UOLDeI5BG2m7/uwyaLVT6fbtCwTyzw== + rollup@^3.7.0: version "3.7.5" resolved "https://registry.yarnpkg.com/rollup/-/rollup-3.7.5.tgz#db580f8eda50237b0721ddea301fb981cd992933" @@ -792,6 +1457,13 @@ run-async@^2.4.0: resolved "https://registry.yarnpkg.com/run-async/-/run-async-2.4.1.tgz#8440eccf99ea3e70bd409d49aab88e10c189a455" integrity sha512-tvVnVv01b8c1RrA6Ep7JkStj85Guv/YrMcwqYQnwjsAS2cTmmPGBBjAjpCW7RrSodNSoE2/qg9O4bceNvUuDgQ== +run-parallel@^1.1.9: + version "1.2.0" + resolved "https://registry.yarnpkg.com/run-parallel/-/run-parallel-1.2.0.tgz#66d1368da7bdf921eb9d95bd1a9229e7f21a43ee" + integrity sha512-5l4VyZR86LZ/lDxZTR6jqL8AFE2S0IFLMP26AbjsLVADxHdhB/c0GUsH+y39UfCi3dzz8OlQuPmnaJOMoDHQBA== + dependencies: + queue-microtask "^1.2.2" + rxjs@^7.2.0: version "7.4.0" resolved "https://registry.yarnpkg.com/rxjs/-/rxjs-7.4.0.tgz#a12a44d7eebf016f5ff2441b87f28c9a51cebc68" @@ -816,11 +1488,35 @@ safe-buffer@~5.2.0: resolved "https://registry.yarnpkg.com/safer-buffer/-/safer-buffer-2.1.2.tgz#44fa161b0187b9549dd84bb91802f9bd8385cd6a" integrity sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg== +semver@^7.6.0: + version "7.6.0" + resolved "https://registry.yarnpkg.com/semver/-/semver-7.6.0.tgz#1a46a4db4bffcccd97b743b5005c8325f23d4e2d" + integrity sha512-EnwXhrlwXMk9gKu5/flx5sv/an57AkRplG3hTK68W7FRDN+k+OWBj65M7719OkA82XLBxrcX0KSHj+X5COhOVg== + dependencies: + lru-cache "^6.0.0" + +shebang-command@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/shebang-command/-/shebang-command-2.0.0.tgz#ccd0af4f8835fbdc265b82461aaf0c36663f34ea" + integrity sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA== + dependencies: + shebang-regex "^3.0.0" + +shebang-regex@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/shebang-regex/-/shebang-regex-3.0.0.tgz#ae16f1644d873ecad843b0307b143362d4c42172" + integrity sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A== + signal-exit@^3.0.2: version "3.0.6" resolved "https://registry.yarnpkg.com/signal-exit/-/signal-exit-3.0.6.tgz#24e630c4b0f03fea446a2bd299e62b4a6ca8d0af" integrity sha512-sDl4qMFpijcGw22U5w63KmD3cZJfBuFlVNbVMKje2keoKML7X2UzWbc4XrmEbDwg0NXJc3yv4/ox7b+JWb57kQ== +slash@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/slash/-/slash-3.0.0.tgz#6539be870c165adbd5240220dbe361f1bc4d4634" + integrity sha512-g9Q1haeby36OSStwb4ntCGGGaKsaVSjQ68fBxoQcutl5fS1vuY18H3wSt3jFyFtrkx+Kz0V1G85A4MyAdDMi2Q== + source-map-js@^1.0.2: version "1.0.2" resolved "https://registry.yarnpkg.com/source-map-js/-/source-map-js-1.0.2.tgz#adbc361d9c62df380125e7f161f71c826f1e490c" @@ -862,6 +1558,11 @@ strip-ansi@^6.0.0, strip-ansi@^6.0.1: dependencies: ansi-regex "^5.0.1" +strip-json-comments@^3.1.1: + version "3.1.1" + resolved "https://registry.yarnpkg.com/strip-json-comments/-/strip-json-comments-3.1.1.tgz#31f1281b3832630434831c310c01cccda8cbe006" + integrity sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig== + strip-literal@^1.0.0: version "1.0.0" resolved "https://registry.yarnpkg.com/strip-literal/-/strip-literal-1.0.0.tgz#0a484ed5a978cd9d2becf3cf8f4f2cb5ab0e1e74" @@ -888,6 +1589,19 @@ supports-preserve-symlinks-flag@^1.0.0: resolved "https://registry.yarnpkg.com/supports-preserve-symlinks-flag/-/supports-preserve-symlinks-flag-1.0.0.tgz#6eda4bd344a3c94aea376d4cc31bc77311039e09" integrity sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w== +synckit@^0.8.6: + version "0.8.8" + resolved "https://registry.yarnpkg.com/synckit/-/synckit-0.8.8.tgz#fe7fe446518e3d3d49f5e429f443cf08b6edfcd7" + integrity sha512-HwOKAP7Wc5aRGYdKH+dw0PRRpbO841v2DENBtjnR5HFWoiNByAl7vrx3p0G/rCyYXQsrxqtX48TImFtPcIHSpQ== + dependencies: + "@pkgr/core" "^0.1.0" + tslib "^2.6.2" + +text-table@^0.2.0: + version "0.2.0" + resolved "https://registry.yarnpkg.com/text-table/-/text-table-0.2.0.tgz#7f5ee823ae805207c00af2df4a84ec3fcfa570b4" + integrity sha512-N+8UisAXDGk8PFXP4HAzVR9nbfmVJ3zYLAWiTIoqC5v5isinhr+r5uaO8+7r3BMfuNIufIsA7RdpVgacC2cSpw== + through@^2.3.6: version "2.3.8" resolved "https://registry.yarnpkg.com/through/-/through-2.3.8.tgz#0dd4c9ffaabc357960b1b724115d7e0e86a2e1f5" @@ -915,21 +1629,45 @@ tmp@^0.0.33: dependencies: os-tmpdir "~1.0.2" +to-regex-range@^5.0.1: + version "5.0.1" + resolved "https://registry.yarnpkg.com/to-regex-range/-/to-regex-range-5.0.1.tgz#1648c44aae7c8d988a326018ed72f5b4dd0392e4" + integrity sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ== + dependencies: + is-number "^7.0.0" + tr46@~0.0.3: version "0.0.3" resolved "https://registry.yarnpkg.com/tr46/-/tr46-0.0.3.tgz#8184fd347dac9cdc185992f3a6622e14b9d9ab6a" integrity sha1-gYT9NH2snNwYWZLzpmIuFLnZq2o= +ts-api-utils@^1.3.0: + version "1.3.0" + resolved "https://registry.yarnpkg.com/ts-api-utils/-/ts-api-utils-1.3.0.tgz#4b490e27129f1e8e686b45cc4ab63714dc60eea1" + integrity sha512-UQMIo7pb8WRomKR1/+MFVLTroIvDVtMX3K6OUir8ynLyzB8Jeriont2bTAtmNPa1ekAgN7YPDyf6V+ygrdU+eQ== + tslib@^2.1.0: version "2.3.1" resolved "https://registry.yarnpkg.com/tslib/-/tslib-2.3.1.tgz#e8a335add5ceae51aa261d32a490158ef042ef01" integrity sha512-77EbyPPpMz+FRFRuAFlWMtmgUWGe9UOG2Z25NqCwiIjRhOf5iKGuzSe5P2w1laq+FkRy4p+PCuVkJSGkzTEKVw== +tslib@^2.6.2: + version "2.6.2" + resolved "https://registry.yarnpkg.com/tslib/-/tslib-2.6.2.tgz#703ac29425e7b37cd6fd456e92404d46d1f3e4ae" + integrity sha512-AEYxH93jGFPn/a2iVAwW87VuUIkR1FVUKB77NwMF7nBTDkDrrT/Hpt/IrCJ0QXhW27jTBDcf5ZY7w6RiqTMw2Q== + tslib@~2.1.0: version "2.1.0" resolved "https://registry.yarnpkg.com/tslib/-/tslib-2.1.0.tgz#da60860f1c2ecaa5703ab7d39bc05b6bf988b97a" integrity sha512-hcVC3wYEziELGGmEEXue7D75zbwIIVUMWAVbHItGPx0ziyXxrOMQx4rQEVEV45Ut/1IotuEvwqPopzIOkDMf0A== +type-check@^0.4.0, type-check@~0.4.0: + version "0.4.0" + resolved "https://registry.yarnpkg.com/type-check/-/type-check-0.4.0.tgz#07b8203bfa7056c0657050e3ccd2c37730bab8f1" + integrity sha512-XleUoc9uwGXqjWwXaUTZAmzMcFZ5858QA2vvx1Ur5xIcixXIP+8LnFDgRplU30us6teqdlskFfu+ae4K79Ooew== + dependencies: + prelude-ls "^1.2.1" + type-detect@^4.0.0, type-detect@^4.0.5: version "4.0.8" resolved "https://registry.yarnpkg.com/type-detect/-/type-detect-4.0.8.tgz#7646fb5f18871cfbb7749e69bd39a6388eb7450c" @@ -940,10 +1678,19 @@ type-fest@^0.21.3: resolved "https://registry.yarnpkg.com/type-fest/-/type-fest-0.21.3.tgz#d260a24b0198436e133fa26a524a6d65fa3b2e37" integrity sha512-t0rzBq87m3fVcduHDUFhKmyyX+9eo6WQjZvf51Ea/M0Q7+T374Jp1aUiyUl0GKxp8M/OETVHSDvmkyPgvX+X2w== -typescript@4.9.4: - version "4.9.4" - resolved "https://registry.yarnpkg.com/typescript/-/typescript-4.9.4.tgz#a2a3d2756c079abda241d75f149df9d561091e78" - integrity sha512-Uz+dTXYzxXXbsFpM86Wh3dKCxrQqUcVMxwU54orwlJjOpO3ao8L7j5lH+dWfTwgCwIuM9GQ2kvVotzYJMXTBZg== +typescript-eslint@7.8.0: + version "7.8.0" + resolved "https://registry.yarnpkg.com/typescript-eslint/-/typescript-eslint-7.8.0.tgz#d2a73d4caac35d4d9825bfdfac06a9bf2ba175e4" + integrity sha512-sheFG+/D8N/L7gC3WT0Q8sB97Nm573Yfr+vZFzl/4nBdYcmviBPtwGSX9TJ7wpVg28ocerKVOt+k2eGmHzcgVA== + dependencies: + "@typescript-eslint/eslint-plugin" "7.8.0" + "@typescript-eslint/parser" "7.8.0" + "@typescript-eslint/utils" "7.8.0" + +typescript@5.4.5: + version "5.4.5" + resolved "https://registry.yarnpkg.com/typescript/-/typescript-5.4.5.tgz#42ccef2c571fdbd0f6718b1d1f5e6e5ef006f611" + integrity sha512-vcI4UpRgg81oIRUFwR0WSIHKt11nJ7SAVlYNIu+QpqeyXP+gpQJy/Z4+F0aGxSE4MqwjyXvW/TzgkLAx2AGHwQ== ufo@^1.0.0: version "1.0.1" @@ -955,6 +1702,13 @@ unfetch@^4.2.0: resolved "https://registry.yarnpkg.com/unfetch/-/unfetch-4.2.0.tgz#7e21b0ef7d363d8d9af0fb929a5555f6ef97a3be" integrity sha512-F9p7yYCn6cIW9El1zi0HI6vqpeIvBsr3dSuRO6Xuppb1u5rXpCPmMvLSyECLhybr9isec8Ohl0hPekMVrEinDA== +uri-js@^4.2.2: + version "4.4.1" + resolved "https://registry.yarnpkg.com/uri-js/-/uri-js-4.4.1.tgz#9b1a52595225859e55f669d928f88c6c57f2a77e" + integrity sha512-7rKUyy33Q1yc98pQ1DAmLtwX109F7TIfWlW1Ydo8Wl1ii1SeHieeh0HHfPeL2fMXK6z0s8ecKs9frCuLJvndBg== + dependencies: + punycode "^2.1.0" + util-deprecate@^1.0.1: version "1.0.2" resolved "https://registry.yarnpkg.com/util-deprecate/-/util-deprecate-1.0.2.tgz#450d4dc9fa70de732762fbd2d4a28981419a0ccf" @@ -1025,6 +1779,18 @@ whatwg-url@^5.0.0: tr46 "~0.0.3" webidl-conversions "^3.0.0" +which@^2.0.1: + version "2.0.2" + resolved "https://registry.yarnpkg.com/which/-/which-2.0.2.tgz#7c6a8dd0a636a0327e10b59c9286eee93f3f51b1" + integrity sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA== + dependencies: + isexe "^2.0.0" + +word-wrap@^1.2.5: + version "1.2.5" + resolved "https://registry.yarnpkg.com/word-wrap/-/word-wrap-1.2.5.tgz#d2c45c6dd4fbce621a66f136cbe328afd0410b34" + integrity sha512-BN22B5eaMMI9UMtjrGd5g5eCYPpCPDUy0FJXbYsaT5zYxjFOckS53SQDE3pWkVoWpHXVb3BrYcEN4Twa55B5cA== + wrap-ansi@^7.0.0: version "7.0.0" resolved "https://registry.yarnpkg.com/wrap-ansi/-/wrap-ansi-7.0.0.tgz#67e145cff510a6a6984bdf1152911d69d2eb9e43" @@ -1033,3 +1799,13 @@ wrap-ansi@^7.0.0: ansi-styles "^4.0.0" string-width "^4.1.0" strip-ansi "^6.0.0" + +yallist@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/yallist/-/yallist-4.0.0.tgz#9bb92790d9c0effec63be73519e11a35019a3a72" + integrity sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A== + +yocto-queue@^0.1.0: + version "0.1.0" + resolved "https://registry.yarnpkg.com/yocto-queue/-/yocto-queue-0.1.0.tgz#0294eb3dee05028d31ee1a5fa2c556a6aaf10a1b" + integrity sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q==